CommandQueue
This commit is contained in:
parent
3a773feeeb
commit
8bae1a18e4
3 changed files with 349 additions and 1 deletions
|
@ -36,7 +36,7 @@ public interface PumpInterface {
|
||||||
PumpEnactResult setExtendedBolus(Double insulin, Integer durationInMinutes);
|
PumpEnactResult setExtendedBolus(Double insulin, Integer durationInMinutes);
|
||||||
//some pumps might set a very short temp close to 100% as cancelling a temp can be noisy
|
//some pumps might set a very short temp close to 100% as cancelling a temp can be noisy
|
||||||
//when the cancel request is requested by the user (forced), the pump should always do a real cancel
|
//when the cancel request is requested by the user (forced), the pump should always do a real cancel
|
||||||
PumpEnactResult cancelTempBasal(boolean force);
|
PumpEnactResult cancelTempBasal(boolean enforceNew);
|
||||||
PumpEnactResult cancelExtendedBolus();
|
PumpEnactResult cancelExtendedBolus();
|
||||||
|
|
||||||
// Status to be passed to NS
|
// Status to be passed to NS
|
||||||
|
|
|
@ -0,0 +1,347 @@
|
||||||
|
package info.nightscout.androidaps.plugins.PumpDanaRS;
|
||||||
|
|
||||||
|
import android.text.Html;
|
||||||
|
import android.text.Spanned;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.util.LinkedList;
|
||||||
|
|
||||||
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
import info.nightscout.androidaps.R;
|
||||||
|
import info.nightscout.androidaps.data.DetailedBolusInfo;
|
||||||
|
import info.nightscout.androidaps.data.Profile;
|
||||||
|
import info.nightscout.androidaps.data.PumpEnactResult;
|
||||||
|
import info.nightscout.utils.DecimalFormatter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by mike on 08.11.2017.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class CommandQueue {
|
||||||
|
private static Logger log = LoggerFactory.getLogger(CommandQueue.class);
|
||||||
|
|
||||||
|
enum CommandType {
|
||||||
|
BOLUS,
|
||||||
|
TEMPBASALPERCENT,
|
||||||
|
TEMPBASALABSOLUTE,
|
||||||
|
CANCELTEMPBASAL,
|
||||||
|
EXTENDEDBOLUS,
|
||||||
|
CANCELEXTENDEDBOLUS,
|
||||||
|
SETBASALPROFILE
|
||||||
|
}
|
||||||
|
|
||||||
|
public class Command {
|
||||||
|
CommandType commandType;
|
||||||
|
Callback callback;
|
||||||
|
|
||||||
|
int durationInMinutes;
|
||||||
|
|
||||||
|
// Bolus
|
||||||
|
DetailedBolusInfo detailedBolusInfo;
|
||||||
|
// Temp basal percent
|
||||||
|
int percent;
|
||||||
|
// Temp basal absolute
|
||||||
|
double absoluteRate;
|
||||||
|
boolean enforceNew;
|
||||||
|
// Extended bolus
|
||||||
|
double insulin;
|
||||||
|
// Basal profile
|
||||||
|
Profile profile;
|
||||||
|
|
||||||
|
public String status() {
|
||||||
|
switch (commandType) {
|
||||||
|
case BOLUS:
|
||||||
|
return "BOLUS " + DecimalFormatter.to1Decimal(detailedBolusInfo.insulin) + "U";
|
||||||
|
case TEMPBASALPERCENT:
|
||||||
|
return "TEMPBASAL " + percent + "% " + durationInMinutes + " min";
|
||||||
|
case TEMPBASALABSOLUTE:
|
||||||
|
return "TEMPBASAL " + absoluteRate + " U/h " + durationInMinutes + " min";
|
||||||
|
case CANCELTEMPBASAL:
|
||||||
|
return "CANCEL TEMPBASAL";
|
||||||
|
case EXTENDEDBOLUS:
|
||||||
|
return "EXTENDEDBOLUS " + insulin + " U " + durationInMinutes + " min";
|
||||||
|
case CANCELEXTENDEDBOLUS:
|
||||||
|
return "CANCEL EXTENDEDBOLUS";
|
||||||
|
case SETBASALPROFILE:
|
||||||
|
return "SETPROFILE";
|
||||||
|
default:
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class Callback {
|
||||||
|
public PumpEnactResult result;
|
||||||
|
Runnable runnable;
|
||||||
|
|
||||||
|
public Callback(Runnable runnable) {
|
||||||
|
this.runnable = runnable;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Callback result(PumpEnactResult result) {
|
||||||
|
this.result = result;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void run() {
|
||||||
|
runnable.run();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private LinkedList<Command> queue = new LinkedList<>();
|
||||||
|
private Command performing;
|
||||||
|
|
||||||
|
private PumpEnactResult executingNowError() {
|
||||||
|
PumpEnactResult result = new PumpEnactResult();
|
||||||
|
result.success = false;
|
||||||
|
result.enacted = false;
|
||||||
|
result.comment = MainApp.sResources.getString(R.string.executingrightnow);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isRunningTempBasal() {
|
||||||
|
if (performing != null)
|
||||||
|
if (performing.commandType == CommandType.TEMPBASALABSOLUTE || performing.commandType == CommandType.TEMPBASALPERCENT || performing.commandType == CommandType.CANCELTEMPBASAL)
|
||||||
|
return true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isRunningBolus() {
|
||||||
|
if (performing != null)
|
||||||
|
if (performing.commandType == CommandType.BOLUS)
|
||||||
|
return true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isRunningExtendedBolus() {
|
||||||
|
if (performing != null)
|
||||||
|
if (performing.commandType == CommandType.EXTENDEDBOLUS || performing.commandType == CommandType.CANCELEXTENDEDBOLUS)
|
||||||
|
return true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isRunningProfile() {
|
||||||
|
if (performing != null)
|
||||||
|
if (performing.commandType == CommandType.SETBASALPROFILE)
|
||||||
|
return true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private synchronized void removeAll(CommandType type) {
|
||||||
|
for (int i = 0; i < queue.size(); i++) {
|
||||||
|
Command c = queue.get(i);
|
||||||
|
switch (type) {
|
||||||
|
case TEMPBASALABSOLUTE:
|
||||||
|
case TEMPBASALPERCENT:
|
||||||
|
case CANCELTEMPBASAL:
|
||||||
|
if (c.commandType == CommandType.TEMPBASALABSOLUTE || c.commandType == CommandType.TEMPBASALPERCENT || c.commandType == CommandType.CANCELTEMPBASAL) {
|
||||||
|
queue.remove(i);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case BOLUS:
|
||||||
|
if (c.commandType == CommandType.BOLUS) {
|
||||||
|
queue.remove(i);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case EXTENDEDBOLUS:
|
||||||
|
case CANCELEXTENDEDBOLUS:
|
||||||
|
if (c.commandType == CommandType.EXTENDEDBOLUS || c.commandType == CommandType.CANCELEXTENDEDBOLUS) {
|
||||||
|
queue.remove(i);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case SETBASALPROFILE:
|
||||||
|
if (c.commandType == CommandType.SETBASALPROFILE) {
|
||||||
|
queue.remove(i);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private synchronized void add(Command command) {
|
||||||
|
queue.add(command);
|
||||||
|
}
|
||||||
|
|
||||||
|
private synchronized void pickup() {
|
||||||
|
performing = queue.poll();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clear() {
|
||||||
|
queue.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void notifyAboutNewCommand() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// returns true if command is queued
|
||||||
|
public boolean bolus(DetailedBolusInfo detailedBolusInfo, Callback callback) {
|
||||||
|
if (isRunningBolus()) {
|
||||||
|
callback.result(executingNowError()).run();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// remove all unfinished boluese
|
||||||
|
removeAll(CommandType.BOLUS);
|
||||||
|
|
||||||
|
// add new command to queue
|
||||||
|
Command command = new Command();
|
||||||
|
command.commandType = CommandType.BOLUS;
|
||||||
|
command.detailedBolusInfo = detailedBolusInfo;
|
||||||
|
command.callback = callback;
|
||||||
|
add(command);
|
||||||
|
|
||||||
|
notifyAboutNewCommand();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// returns true if command is queued
|
||||||
|
public boolean tempBasalAbsolute(double absoluteRate, int durationInMinutes, boolean enforceNew, Callback callback) {
|
||||||
|
if (isRunningTempBasal()) {
|
||||||
|
callback.result(executingNowError()).run();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// remove all unfinished boluese
|
||||||
|
removeAll(CommandType.TEMPBASALABSOLUTE);
|
||||||
|
|
||||||
|
// add new command to queue
|
||||||
|
Command command = new Command();
|
||||||
|
command.commandType = CommandType.TEMPBASALABSOLUTE;
|
||||||
|
command.absoluteRate = absoluteRate;
|
||||||
|
command.durationInMinutes = durationInMinutes;
|
||||||
|
command.enforceNew = enforceNew;
|
||||||
|
command.callback = callback;
|
||||||
|
add(command);
|
||||||
|
|
||||||
|
notifyAboutNewCommand();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// returns true if command is queued
|
||||||
|
public boolean tempBasalPercent(int percent, int durationInMinutes, Callback callback) {
|
||||||
|
if (isRunningTempBasal()) {
|
||||||
|
callback.result(executingNowError()).run();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// remove all unfinished boluese
|
||||||
|
removeAll(CommandType.TEMPBASALPERCENT);
|
||||||
|
|
||||||
|
// add new command to queue
|
||||||
|
Command command = new Command();
|
||||||
|
command.commandType = CommandType.TEMPBASALPERCENT;
|
||||||
|
command.percent = percent;
|
||||||
|
command.durationInMinutes = durationInMinutes;
|
||||||
|
command.callback = callback;
|
||||||
|
add(command);
|
||||||
|
|
||||||
|
notifyAboutNewCommand();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// returns true if command is queued
|
||||||
|
public boolean extendedBolus(double insulin, int durationInMinutes, Callback callback) {
|
||||||
|
if (isRunningExtendedBolus()) {
|
||||||
|
callback.result(executingNowError()).run();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// remove all unfinished boluese
|
||||||
|
removeAll(CommandType.EXTENDEDBOLUS);
|
||||||
|
|
||||||
|
// add new command to queue
|
||||||
|
Command command = new Command();
|
||||||
|
command.commandType = CommandType.EXTENDEDBOLUS;
|
||||||
|
command.insulin = insulin;
|
||||||
|
command.durationInMinutes = durationInMinutes;
|
||||||
|
command.callback = callback;
|
||||||
|
add(command);
|
||||||
|
|
||||||
|
notifyAboutNewCommand();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// returns true if command is queued
|
||||||
|
public boolean cancelTempBasal(boolean enforceNew, Callback callback) {
|
||||||
|
if (isRunningTempBasal()) {
|
||||||
|
callback.result(executingNowError()).run();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// remove all unfinished boluese
|
||||||
|
removeAll(CommandType.CANCELTEMPBASAL);
|
||||||
|
|
||||||
|
// add new command to queue
|
||||||
|
Command command = new Command();
|
||||||
|
command.commandType = CommandType.CANCELTEMPBASAL;
|
||||||
|
command.enforceNew = enforceNew;
|
||||||
|
command.callback = callback;
|
||||||
|
add(command);
|
||||||
|
|
||||||
|
notifyAboutNewCommand();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// returns true if command is queued
|
||||||
|
public boolean cancelExtended(Callback callback) {
|
||||||
|
if (isRunningExtendedBolus()) {
|
||||||
|
callback.result(executingNowError()).run();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// remove all unfinished boluese
|
||||||
|
removeAll(CommandType.CANCELEXTENDEDBOLUS);
|
||||||
|
|
||||||
|
// add new command to queue
|
||||||
|
Command command = new Command();
|
||||||
|
command.commandType = CommandType.CANCELEXTENDEDBOLUS;
|
||||||
|
command.callback = callback;
|
||||||
|
add(command);
|
||||||
|
|
||||||
|
notifyAboutNewCommand();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// returns true if command is queued
|
||||||
|
public boolean setProfile(Profile profile, Callback callback) {
|
||||||
|
if (isRunningProfile()) {
|
||||||
|
callback.result(executingNowError()).run();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// remove all unfinished boluese
|
||||||
|
removeAll(CommandType.SETBASALPROFILE);
|
||||||
|
|
||||||
|
// add new command to queue
|
||||||
|
Command command = new Command();
|
||||||
|
command.commandType = CommandType.SETBASALPROFILE;
|
||||||
|
command.profile = profile;
|
||||||
|
command.callback = callback;
|
||||||
|
add(command);
|
||||||
|
|
||||||
|
notifyAboutNewCommand();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
Spanned spannedStatus() {
|
||||||
|
String s = "";
|
||||||
|
if (performing != null) {
|
||||||
|
s += "<b>" + performing.status() + "</b><br>";
|
||||||
|
}
|
||||||
|
for (int i = 0; i < queue.size(); i++) {
|
||||||
|
s += queue.get(i).status() + "<br>";
|
||||||
|
}
|
||||||
|
return Html.fromHtml(s);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -750,5 +750,6 @@
|
||||||
<string name="waitingforestimatedbolusend" formatted="false">Waiting for bolus end. Remaining %d sec.</string>
|
<string name="waitingforestimatedbolusend" formatted="false">Waiting for bolus end. Remaining %d sec.</string>
|
||||||
<string name="processinghistory">Processing event</string>
|
<string name="processinghistory">Processing event</string>
|
||||||
<string name="startingbolus">Starting bolus delivery</string>
|
<string name="startingbolus">Starting bolus delivery</string>
|
||||||
|
<string name="executingrightnow">Command is executed right now</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue