split treatments to smaller chunks before broadcast
This commit is contained in:
parent
39e83f0cfe
commit
1e5f96f841
1 changed files with 58 additions and 21 deletions
|
@ -11,6 +11,7 @@ import org.json.JSONObject;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import info.nightscout.androidaps.Services.Intents;
|
import info.nightscout.androidaps.Services.Intents;
|
||||||
|
@ -36,16 +37,19 @@ public class BroadcastTreatment {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void handleNewTreatment(JSONArray treatments, Context context, boolean isDelta) {
|
public static void handleNewTreatment(JSONArray treatments, Context context, boolean isDelta) {
|
||||||
Bundle bundle = new Bundle();
|
List<JSONArray> splitted = splitArray(treatments);
|
||||||
bundle.putString("treatments", treatments.toString());
|
for (JSONArray part: splitted) {
|
||||||
bundle.putBoolean("delta", isDelta);
|
Bundle bundle = new Bundle();
|
||||||
Intent intent = new Intent(Intents.ACTION_NEW_TREATMENT);
|
bundle.putString("treatments", part.toString());
|
||||||
intent.putExtras(bundle);
|
bundle.putBoolean("delta", isDelta);
|
||||||
intent.addFlags(Intent.FLAG_INCLUDE_STOPPED_PACKAGES);
|
Intent intent = new Intent(Intents.ACTION_NEW_TREATMENT);
|
||||||
context.sendBroadcast(intent);
|
intent.putExtras(bundle);
|
||||||
List<ResolveInfo> x = context.getPackageManager().queryBroadcastReceivers(intent, 0);
|
intent.addFlags(Intent.FLAG_INCLUDE_STOPPED_PACKAGES);
|
||||||
|
context.sendBroadcast(intent);
|
||||||
|
List<ResolveInfo> x = context.getPackageManager().queryBroadcastReceivers(intent, 0);
|
||||||
|
|
||||||
log.debug("TREAT_ADD " + treatments.length() + " " + x.size() + " receivers");
|
log.debug("TREAT_ADD " + part.length() + " " + x.size() + " receivers");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handleChangedTreatment(JSONObject treatment, Context context, boolean isDelta) {
|
public void handleChangedTreatment(JSONObject treatment, Context context, boolean isDelta) {
|
||||||
|
@ -60,20 +64,24 @@ public class BroadcastTreatment {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
log.debug("TREAT_CHANGE " + treatment.getString("_id") + " " + x.size() + " receivers");
|
log.debug("TREAT_CHANGE " + treatment.getString("_id") + " " + x.size() + " receivers");
|
||||||
} catch (JSONException e) {}
|
} catch (JSONException e) {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void handleChangedTreatment(JSONArray treatments, Context context, boolean isDelta) {
|
public static void handleChangedTreatment(JSONArray treatments, Context context, boolean isDelta) {
|
||||||
Bundle bundle = new Bundle();
|
List<JSONArray> splitted = splitArray(treatments);
|
||||||
bundle.putString("treatments", treatments.toString());
|
for (JSONArray part: splitted) {
|
||||||
bundle.putBoolean("delta", isDelta);
|
Bundle bundle = new Bundle();
|
||||||
Intent intent = new Intent(Intents.ACTION_CHANGED_TREATMENT);
|
bundle.putString("treatments", part.toString());
|
||||||
intent.putExtras(bundle);
|
bundle.putBoolean("delta", isDelta);
|
||||||
intent.addFlags(Intent.FLAG_INCLUDE_STOPPED_PACKAGES);
|
Intent intent = new Intent(Intents.ACTION_CHANGED_TREATMENT);
|
||||||
context.sendBroadcast(intent);
|
intent.putExtras(bundle);
|
||||||
List<ResolveInfo> x = context.getPackageManager().queryBroadcastReceivers(intent, 0);
|
intent.addFlags(Intent.FLAG_INCLUDE_STOPPED_PACKAGES);
|
||||||
|
context.sendBroadcast(intent);
|
||||||
|
List<ResolveInfo> x = context.getPackageManager().queryBroadcastReceivers(intent, 0);
|
||||||
|
|
||||||
log.debug("TREAT_CHANGE " + treatments.length() + " " + x.size() + " receivers");
|
log.debug("TREAT_CHANGE " + part.length() + " " + x.size() + " receivers");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void handleRemovedTreatment(JSONObject treatment, Context context, boolean isDelta) {
|
public static void handleRemovedTreatment(JSONObject treatment, Context context, boolean isDelta) {
|
||||||
|
@ -88,7 +96,8 @@ public class BroadcastTreatment {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
log.debug("TREAT_REMOVE " + treatment.getString("_id") + " " + x.size() + " receivers");
|
log.debug("TREAT_REMOVE " + treatment.getString("_id") + " " + x.size() + " receivers");
|
||||||
} catch (JSONException e) {}
|
} catch (JSONException e) {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void handleRemovedTreatment(JSONArray treatments, Context context, boolean isDelta) {
|
public static void handleRemovedTreatment(JSONArray treatments, Context context, boolean isDelta) {
|
||||||
|
@ -104,4 +113,32 @@ public class BroadcastTreatment {
|
||||||
log.debug("TREAT_REMOVE " + treatments.length() + " treatments " + x.size() + " receivers");
|
log.debug("TREAT_REMOVE " + treatments.length() + " treatments " + x.size() + " receivers");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private static List<JSONArray> splitArray(JSONArray array) {
|
||||||
|
List<JSONArray> ret = new ArrayList<>();
|
||||||
|
try {
|
||||||
|
int size = array.length();
|
||||||
|
int count = 0;
|
||||||
|
JSONArray newarr = null;
|
||||||
|
for (int i = 0; i < size; i++) {
|
||||||
|
if (count == 0) {
|
||||||
|
if (newarr != null) {
|
||||||
|
ret.add(newarr);
|
||||||
|
}
|
||||||
|
newarr = new JSONArray();
|
||||||
|
count = 200;
|
||||||
|
}
|
||||||
|
newarr.put(array.get(i));
|
||||||
|
--count;
|
||||||
|
}
|
||||||
|
if (newarr != null && newarr.length() > 0) {
|
||||||
|
ret.add(newarr);
|
||||||
|
}
|
||||||
|
} catch (JSONException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
ret = new ArrayList<>();
|
||||||
|
ret.add(array);
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue