Combo: cleanup code
This commit is contained in:
parent
c1dc41908b
commit
ad8c2297a0
16 changed files with 296 additions and 352 deletions
|
@ -260,7 +260,7 @@ class DetermineBasalAdapterSMBDynamicISFJS internal constructor(private val scri
|
|||
|
||||
this.mealData.put("TDDAIMI7", tddCalculator.averageTDD(tddCalculator.calculate(7)).totalAmount)
|
||||
this.mealData.put("TDDPUMP", tddCalculator.calculateDaily().totalAmount)
|
||||
this.mealData.put("TDDLast24", tddCalculator!!.calculate24Daily().totalAmount)
|
||||
this.mealData.put("TDDLast24", tddCalculator.calculate24Daily().totalAmount)
|
||||
|
||||
if (constraintChecker.isAutosensModeEnabled().value()) {
|
||||
autosensData.put("ratio", autosensDataRatio)
|
||||
|
|
|
@ -142,7 +142,7 @@ class TddCalculator @Inject constructor(
|
|||
//result.put(midnight, tdd)
|
||||
}
|
||||
val calculationStep = T.mins(5).msecs()
|
||||
val tempBasals = iobCobCalculator.getTempBasalIncludingConvertedExtendedForRange(startTime, endTime, calculationStep)
|
||||
//val tempBasals = iobCobCalculator.getTempBasalIncludingConvertedExtendedForRange(startTime, endTime, calculationStep)
|
||||
for (t in startTime until endTime step calculationStep) {
|
||||
|
||||
//val midnight = MidnightTime.calc(t)
|
||||
|
|
|
@ -40,6 +40,7 @@ public class ComboFragment extends DaggerFragment {
|
|||
@Inject DateUtil dateUtil;
|
||||
@Inject FabricPrivacy fabricPrivacy;
|
||||
@Inject AapsSchedulers aapsSchedulers;
|
||||
@Inject ComboErrorUtil errorUtil;
|
||||
|
||||
private final CompositeDisposable disposable = new CompositeDisposable();
|
||||
|
||||
|
@ -264,8 +265,6 @@ public class ComboFragment extends DaggerFragment {
|
|||
private void updateErrorDisplay(boolean forceHide) {
|
||||
int errorCount = -1;
|
||||
|
||||
ComboErrorUtil errorUtil = ComboErrorUtil.getInstance();
|
||||
|
||||
if (!forceHide) {
|
||||
ComboErrorUtil.DisplayType displayType = errorUtil.getDisplayType();
|
||||
|
||||
|
|
|
@ -38,9 +38,6 @@ import info.nightscout.androidaps.interfaces.Pump;
|
|||
import info.nightscout.androidaps.interfaces.PumpDescription;
|
||||
import info.nightscout.androidaps.interfaces.PumpPluginBase;
|
||||
import info.nightscout.androidaps.interfaces.PumpSync;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.data.ComboErrorUtil;
|
||||
import info.nightscout.shared.logging.AAPSLogger;
|
||||
import info.nightscout.shared.logging.LTag;
|
||||
import info.nightscout.androidaps.plugins.bus.RxBus;
|
||||
import info.nightscout.androidaps.plugins.common.ManufacturerType;
|
||||
import info.nightscout.androidaps.plugins.general.overview.events.EventDismissNotification;
|
||||
|
@ -65,6 +62,8 @@ import info.nightscout.androidaps.utils.DateUtil;
|
|||
import info.nightscout.androidaps.utils.InstanceId;
|
||||
import info.nightscout.androidaps.utils.T;
|
||||
import info.nightscout.androidaps.utils.resources.ResourceHelper;
|
||||
import info.nightscout.shared.logging.AAPSLogger;
|
||||
import info.nightscout.shared.logging.LTag;
|
||||
import info.nightscout.shared.sharedPreferences.SP;
|
||||
|
||||
/**
|
||||
|
@ -99,10 +98,10 @@ public class ComboPlugin extends PumpPluginBase implements Pump, Constraints {
|
|||
private final Context context;
|
||||
private final PumpSync pumpSync;
|
||||
private final DateUtil dateUtil;
|
||||
private final RuffyCommands ruffyScripter;
|
||||
|
||||
private final static PumpDescription pumpDescription = new PumpDescription();
|
||||
|
||||
private RuffyCommands ruffyScripter;
|
||||
|
||||
@NonNull
|
||||
private static final ComboPump pump = new ComboPump();
|
||||
|
@ -154,7 +153,8 @@ public class ComboPlugin extends PumpPluginBase implements Pump, Constraints {
|
|||
CommandQueue commandQueue,
|
||||
Context context,
|
||||
PumpSync pumpSync,
|
||||
DateUtil dateUtil
|
||||
DateUtil dateUtil,
|
||||
RuffyScripter ruffyScripter
|
||||
) {
|
||||
super(new PluginDescription()
|
||||
.mainType(PluginType.PUMP)
|
||||
|
@ -173,16 +173,13 @@ public class ComboPlugin extends PumpPluginBase implements Pump, Constraints {
|
|||
this.context = context;
|
||||
this.pumpSync = pumpSync;
|
||||
this.dateUtil = dateUtil;
|
||||
|
||||
ComboErrorUtil.getInstance().setSP(sp);
|
||||
ComboErrorUtil.getInstance().clearErrors();
|
||||
this.ruffyScripter = ruffyScripter;
|
||||
|
||||
pumpDescription.fillFor(PumpType.ACCU_CHEK_COMBO);
|
||||
}
|
||||
|
||||
@Override protected void onStart() {
|
||||
super.onStart();
|
||||
ruffyScripter = new RuffyScripter(context);
|
||||
OPERATION_NOT_SUPPORTED = new PumpEnactResult(getInjector())
|
||||
.success(false).enacted(false).comment(R.string.combo_pump_unsupported_operation);
|
||||
}
|
||||
|
|
|
@ -1,106 +0,0 @@
|
|||
package info.nightscout.androidaps.plugins.pump.combo.data;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import info.nightscout.androidaps.combo.R;
|
||||
import info.nightscout.shared.sharedPreferences.SP;
|
||||
|
||||
/**
|
||||
* Created by andy on 3/17/18.
|
||||
*/
|
||||
public class ComboErrorUtil {
|
||||
|
||||
private SP sp;
|
||||
|
||||
Map<String, List<ErrorState>> errorMap = new HashMap<>();
|
||||
|
||||
private static final ComboErrorUtil comboDataUtil = new ComboErrorUtil();
|
||||
|
||||
private ComboErrorUtil() {
|
||||
}
|
||||
|
||||
public static ComboErrorUtil getInstance() {
|
||||
return comboDataUtil;
|
||||
}
|
||||
|
||||
public void setSP(SP sp) {
|
||||
this.sp = sp;
|
||||
}
|
||||
|
||||
public void addError(Exception exception) {
|
||||
String exceptionMsg = exception.getMessage();
|
||||
|
||||
if (!errorMap.containsKey(exceptionMsg)) {
|
||||
List<ErrorState> list = new ArrayList<>();
|
||||
list.add(createErrorState(exception));
|
||||
|
||||
errorMap.put(exceptionMsg, list);
|
||||
} else {
|
||||
errorMap.get(exceptionMsg).add(createErrorState(exception));
|
||||
}
|
||||
|
||||
updateErrorCount();
|
||||
}
|
||||
|
||||
|
||||
private void updateErrorCount() {
|
||||
int errorCount = 0;
|
||||
|
||||
if (!isErrorPresent()) {
|
||||
for (List<ErrorState> errorStates : errorMap.values()) {
|
||||
errorCount += errorStates.size();
|
||||
}
|
||||
}
|
||||
|
||||
if (errorCount==0) {
|
||||
if (sp.contains(R.string.key_combo_error_count)) {
|
||||
sp.remove(R.string.key_combo_error_count);
|
||||
}
|
||||
} else {
|
||||
sp.putInt(R.string.key_combo_error_count, errorCount);
|
||||
}
|
||||
}
|
||||
|
||||
private ErrorState createErrorState(Exception exception) {
|
||||
ErrorState errorState = new ErrorState();
|
||||
errorState.setException(exception);
|
||||
errorState.setTimeInMillis(System.currentTimeMillis());
|
||||
|
||||
return errorState;
|
||||
}
|
||||
|
||||
public void clearErrors() {
|
||||
if (errorMap != null)
|
||||
this.errorMap.clear();
|
||||
else
|
||||
this.errorMap = new HashMap<>();
|
||||
|
||||
if (sp.contains(R.string.key_combo_error_count)) {
|
||||
sp.remove(R.string.key_combo_error_count);
|
||||
}
|
||||
}
|
||||
|
||||
public boolean isErrorPresent() {
|
||||
return !this.errorMap.isEmpty();
|
||||
}
|
||||
|
||||
public int getErrorCount() {
|
||||
return sp.contains(R.string.key_combo_error_count) ?
|
||||
sp.getInt(R.string.key_combo_error_count, -1) : -1;
|
||||
}
|
||||
|
||||
public DisplayType getDisplayType() {
|
||||
String displayTypeString = sp.getString(R.string.key_show_comm_error_count, "ON_ERROR");
|
||||
return DisplayType.valueOf(displayTypeString);
|
||||
}
|
||||
|
||||
public enum DisplayType {
|
||||
NEVER,
|
||||
ON_ERROR,
|
||||
ALWAYS
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,49 @@
|
|||
package info.nightscout.androidaps.plugins.pump.combo.data
|
||||
|
||||
import info.nightscout.androidaps.combo.R
|
||||
import info.nightscout.shared.sharedPreferences.SP
|
||||
import javax.inject.Inject
|
||||
import javax.inject.Singleton
|
||||
|
||||
@Singleton
|
||||
class ComboErrorUtil @Inject constructor(
|
||||
private val sp: SP
|
||||
) {
|
||||
|
||||
class ErrorState(val exception: Exception, val timeInMillis: Long)
|
||||
|
||||
enum class DisplayType {
|
||||
NEVER, ON_ERROR, ALWAYS
|
||||
}
|
||||
|
||||
private var errorMap: MutableMap<String, MutableList<ErrorState>> = HashMap()
|
||||
|
||||
fun addError(exception: Exception) {
|
||||
val exceptionMsg = exception.message ?: return
|
||||
if (!errorMap.containsKey(exceptionMsg)) errorMap[exceptionMsg] = ArrayList<ErrorState>().also { it.add(createErrorState(exception)) }
|
||||
else errorMap[exceptionMsg]?.add(createErrorState(exception))
|
||||
updateErrorCount()
|
||||
}
|
||||
|
||||
private fun updateErrorCount() {
|
||||
var errorCount = 0
|
||||
if (!isErrorPresent) for (errorStates in errorMap.values) errorCount += errorStates.size
|
||||
if (errorCount == 0) {
|
||||
if (sp.contains(R.string.key_combo_error_count)) sp.remove(R.string.key_combo_error_count)
|
||||
} else sp.putInt(R.string.key_combo_error_count, errorCount)
|
||||
}
|
||||
|
||||
private fun createErrorState(exception: Exception) = ErrorState(exception, System.currentTimeMillis())
|
||||
|
||||
fun clearErrors() {
|
||||
errorMap.clear()
|
||||
if (sp.contains(R.string.key_combo_error_count)) sp.remove(R.string.key_combo_error_count)
|
||||
}
|
||||
|
||||
private val isErrorPresent: Boolean
|
||||
get() = errorMap.isNotEmpty()
|
||||
val errorCount: Int
|
||||
get() = if (sp.contains(R.string.key_combo_error_count)) sp.getInt(R.string.key_combo_error_count, -1) else -1
|
||||
val displayType: DisplayType
|
||||
get() = DisplayType.valueOf(sp.getString(R.string.key_show_comm_error_count, "ON_ERROR"))
|
||||
}
|
|
@ -1,17 +0,0 @@
|
|||
package info.nightscout.androidaps.plugins.pump.combo.data;
|
||||
|
||||
public class ErrorState {
|
||||
|
||||
private Exception exception;
|
||||
private long timeInMillis;
|
||||
|
||||
|
||||
public void setException(Exception exception) {
|
||||
this.exception = exception;
|
||||
}
|
||||
|
||||
|
||||
public void setTimeInMillis(long timeInMillis) {
|
||||
this.timeInMillis = timeInMillis;
|
||||
}
|
||||
}
|
|
@ -7,6 +7,7 @@ import android.content.ServiceConnection;
|
|||
import android.os.IBinder;
|
||||
import android.os.RemoteException;
|
||||
import android.os.SystemClock;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
|
||||
|
@ -19,16 +20,15 @@ import org.monkey.d.ruffy.ruffy.driver.display.MenuAttribute;
|
|||
import org.monkey.d.ruffy.ruffy.driver.display.MenuType;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.menu.BolusType;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.menu.MenuTime;
|
||||
import org.slf4j.Logger;
|
||||
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
import java.util.Objects;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
import info.nightscout.androidaps.plugins.pump.combo.data.ComboErrorUtil;
|
||||
import info.nightscout.shared.logging.StacktraceLoggerWrapper;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.ReadQuickInfoCommand;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.history.PumpHistoryRequest;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.BolusCommand;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.CancelTbrCommand;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.Command;
|
||||
|
@ -37,18 +37,24 @@ import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.Conf
|
|||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.ReadBasalProfileCommand;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.ReadHistoryCommand;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.ReadPumpStateCommand;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.ReadQuickInfoCommand;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.SetBasalProfileCommand;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands.SetTbrCommand;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.history.PumpHistoryRequest;
|
||||
import info.nightscout.shared.logging.AAPSLogger;
|
||||
import info.nightscout.shared.logging.LTag;
|
||||
|
||||
/**
|
||||
* Provides scripting 'runtime' and operations. consider moving operations into a separate
|
||||
* class and inject that into executing commands, so that commands operately solely on
|
||||
* operations and are cleanly separated from the thread management, connection management etc
|
||||
*/
|
||||
@Singleton
|
||||
public class RuffyScripter implements RuffyCommands {
|
||||
private static final Logger log = StacktraceLoggerWrapper.getLogger(RuffyScripter.class);
|
||||
|
||||
private IRuffyService ruffyService;
|
||||
private final ComboErrorUtil comboErrorUtil;
|
||||
private final AAPSLogger aapsLogger;
|
||||
|
||||
@Nullable
|
||||
private volatile Menu currentMenu;
|
||||
|
@ -64,30 +70,28 @@ public class RuffyScripter implements RuffyCommands {
|
|||
private final IRTHandler mHandler = new IRTHandler.Stub() {
|
||||
@Override
|
||||
public void log(String message) {
|
||||
if (log.isTraceEnabled()) {
|
||||
log.trace("Ruffy says: " + message);
|
||||
}
|
||||
aapsLogger.debug(LTag.PUMP, "Ruffy says: " + message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void fail(String message) {
|
||||
log.warn("Ruffy warns: " + message);
|
||||
aapsLogger.warn(LTag.PUMP, "Ruffy warns: " + message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void requestBluetooth() {
|
||||
log.trace("Ruffy invoked requestBluetooth callback");
|
||||
aapsLogger.debug(LTag.PUMP, "Ruffy invoked requestBluetooth callback");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void rtStopped() {
|
||||
log.debug("rtStopped callback invoked");
|
||||
aapsLogger.debug(LTag.PUMP, "rtStopped callback invoked");
|
||||
currentMenu = null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void rtStarted() {
|
||||
log.debug("rtStarted callback invoked");
|
||||
aapsLogger.debug(LTag.PUMP, "rtStarted callback invoked");
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -101,7 +105,7 @@ public class RuffyScripter implements RuffyCommands {
|
|||
@Override
|
||||
public void rtDisplayHandleMenu(Menu menu) {
|
||||
// method is called every ~500ms
|
||||
log.debug("rtDisplayHandleMenu: " + menu);
|
||||
aapsLogger.debug(LTag.PUMP, "rtDisplayHandleMenu: " + menu);
|
||||
|
||||
currentMenu = menu;
|
||||
menuLastUpdated = System.currentTimeMillis();
|
||||
|
@ -113,14 +117,18 @@ public class RuffyScripter implements RuffyCommands {
|
|||
|
||||
@Override
|
||||
public void rtDisplayHandleNoMenu() {
|
||||
log.warn("rtDisplayHandleNoMenu callback invoked");
|
||||
aapsLogger.warn(LTag.PUMP, "rtDisplayHandleNoMenu callback invoked");
|
||||
unparsableMenuEncountered = true;
|
||||
}
|
||||
};
|
||||
|
||||
public RuffyScripter(Context context) {
|
||||
@Inject
|
||||
public RuffyScripter(Context context, ComboErrorUtil comboErrorUtil, AAPSLogger aapsLogger) {
|
||||
boolean boundSucceeded = false;
|
||||
|
||||
this.comboErrorUtil = comboErrorUtil;
|
||||
this.aapsLogger = aapsLogger;
|
||||
|
||||
try {
|
||||
Intent intent = new Intent()
|
||||
.setComponent(new ComponentName(
|
||||
|
@ -139,28 +147,28 @@ public class RuffyScripter implements RuffyCommands {
|
|||
ServiceConnection mRuffyServiceConnection = new ServiceConnection() {
|
||||
@Override
|
||||
public void onServiceConnected(ComponentName name, IBinder service) {
|
||||
log.debug("ruffy service connected");
|
||||
aapsLogger.debug(LTag.PUMP, "ruffy service connected");
|
||||
ruffyService = IRuffyService.Stub.asInterface(service);
|
||||
try {
|
||||
ruffyService.setHandler(mHandler);
|
||||
} catch (Exception e) {
|
||||
log.error("Ruffy handler has issues", e);
|
||||
aapsLogger.error(LTag.PUMP, "Ruffy handler has issues", e);
|
||||
}
|
||||
started = true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onServiceDisconnected(ComponentName name) {
|
||||
log.debug("ruffy service disconnected");
|
||||
aapsLogger.debug(LTag.PUMP, "ruffy service disconnected");
|
||||
}
|
||||
};
|
||||
boundSucceeded = context.bindService(intent, mRuffyServiceConnection, Context.BIND_AUTO_CREATE);
|
||||
} catch (Exception e) {
|
||||
log.error("Binding to ruffy service failed", e);
|
||||
aapsLogger.error(LTag.PUMP, "Binding to ruffy service failed", e);
|
||||
}
|
||||
|
||||
if (!boundSucceeded) {
|
||||
log.info("No connection to ruffy. Pump control unavailable.");
|
||||
aapsLogger.info(LTag.PUMP, "No connection to ruffy. Pump control unavailable.");
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -191,9 +199,9 @@ public class RuffyScripter implements RuffyCommands {
|
|||
|
||||
private void addError(Exception e) {
|
||||
try {
|
||||
ComboErrorUtil.getInstance().addError(e);
|
||||
comboErrorUtil.addError(e);
|
||||
} catch (Exception ex) {
|
||||
log.error("Combo data util problem." + ex.getMessage(), ex);
|
||||
aapsLogger.error(LTag.PUMP, "Combo data util problem." + ex.getMessage(), ex);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -203,17 +211,17 @@ public class RuffyScripter implements RuffyCommands {
|
|||
return;
|
||||
}
|
||||
try {
|
||||
log.debug("Disconnecting");
|
||||
aapsLogger.debug(LTag.PUMP, "Disconnecting");
|
||||
ruffyService.doRTDisconnect();
|
||||
try {
|
||||
ComboErrorUtil.getInstance().clearErrors();
|
||||
comboErrorUtil.clearErrors();
|
||||
} catch (Exception ex) {
|
||||
log.error("Combo data util problem." + ex.getMessage(), ex);
|
||||
aapsLogger.error(LTag.PUMP, "Combo data util problem." + ex.getMessage(), ex);
|
||||
}
|
||||
} catch (RemoteException e) {
|
||||
// ignore
|
||||
} catch (Exception e) {
|
||||
log.warn("Disconnect not happy", e);
|
||||
aapsLogger.warn(LTag.PUMP, "Disconnect not happy", e);
|
||||
addError(e);
|
||||
}
|
||||
}
|
||||
|
@ -225,14 +233,14 @@ public class RuffyScripter implements RuffyCommands {
|
|||
|
||||
@Override
|
||||
public CommandResult readQuickInfo(int numberOfBolusRecordsToRetrieve) {
|
||||
return runCommand(new ReadQuickInfoCommand(numberOfBolusRecordsToRetrieve));
|
||||
return runCommand(new ReadQuickInfoCommand(numberOfBolusRecordsToRetrieve, aapsLogger));
|
||||
}
|
||||
|
||||
public void returnToRootMenu() {
|
||||
// returning to main menu using the 'back' key does not cause a vibration
|
||||
MenuType menuType = getCurrentMenu().getType();
|
||||
while (menuType != MenuType.MAIN_MENU && menuType != MenuType.STOP && menuType != MenuType.WARNING_OR_ERROR) {
|
||||
log.debug("Going back to main menu, currently at " + menuType);
|
||||
aapsLogger.debug(LTag.PUMP, "Going back to main menu, currently at " + menuType);
|
||||
pressBackKey();
|
||||
while (getCurrentMenu().getType() == menuType) {
|
||||
waitForScreenUpdate();
|
||||
|
@ -245,11 +253,11 @@ public class RuffyScripter implements RuffyCommands {
|
|||
* Always returns a CommandResult, never throws
|
||||
*/
|
||||
private CommandResult runCommand(final Command cmd) {
|
||||
log.debug("Attempting to run cmd: " + cmd);
|
||||
aapsLogger.debug(LTag.PUMP, "Attempting to run cmd: " + cmd);
|
||||
|
||||
List<String> violations = cmd.validateArguments();
|
||||
if (!violations.isEmpty()) {
|
||||
log.error("Command argument violations: " + Joiner.on(", ").join(violations));
|
||||
aapsLogger.error(LTag.PUMP, "Command argument violations: " + Joiner.on(", ").join(violations));
|
||||
return new CommandResult().success(false).state(new PumpState());
|
||||
}
|
||||
|
||||
|
@ -260,27 +268,27 @@ public class RuffyScripter implements RuffyCommands {
|
|||
unparsableMenuEncountered = false;
|
||||
long connectStart = System.currentTimeMillis();
|
||||
ensureConnected();
|
||||
log.debug("Connection ready to execute cmd " + cmd);
|
||||
aapsLogger.debug(LTag.PUMP, "Connection ready to execute cmd " + cmd);
|
||||
cmdThread = new Thread(() -> {
|
||||
try {
|
||||
if (!runPreCommandChecks(cmd)) {
|
||||
return;
|
||||
}
|
||||
PumpState pumpState = readPumpStateInternal();
|
||||
log.debug("Pump state before running command: " + pumpState);
|
||||
aapsLogger.debug(LTag.PUMP, "Pump state before running command: " + pumpState);
|
||||
|
||||
// execute the command
|
||||
cmd.setScripter(RuffyScripter.this);
|
||||
long cmdStartTime = System.currentTimeMillis();
|
||||
cmd.execute();
|
||||
long cmdEndTime = System.currentTimeMillis();
|
||||
log.debug("Executing " + cmd + " took " + (cmdEndTime - cmdStartTime) + "ms");
|
||||
aapsLogger.debug(LTag.PUMP, "Executing " + cmd + " took " + (cmdEndTime - cmdStartTime) + "ms");
|
||||
} catch (CommandException e) {
|
||||
log.info("CommandException running command", e);
|
||||
aapsLogger.info(LTag.PUMP, "CommandException running command", e);
|
||||
addError(e);
|
||||
cmd.getResult().success = false;
|
||||
} catch (Exception e) {
|
||||
log.error("Unexpected exception running cmd", e);
|
||||
aapsLogger.error(LTag.PUMP, "Unexpected exception running cmd", e);
|
||||
addError(e);
|
||||
cmd.getResult().success = false;
|
||||
}
|
||||
|
@ -294,7 +302,7 @@ public class RuffyScripter implements RuffyCommands {
|
|||
// on connection loss try to reconnect, confirm warning alerts caused by
|
||||
// the disconnected and then return the command as failed (the caller
|
||||
// can retry if needed).
|
||||
log.debug("Connection unusable (ruffy connection: " + ruffyService.isConnected() + ", "
|
||||
aapsLogger.debug(LTag.PUMP, "Connection unusable (ruffy connection: " + ruffyService.isConnected() + ", "
|
||||
+ "time since last menu update: " + (System.currentTimeMillis() - menuLastUpdated) + " ms, "
|
||||
+ "aborting command and attempting reconnect ...");
|
||||
cmdThread.interrupt();
|
||||
|
@ -317,46 +325,44 @@ public class RuffyScripter implements RuffyCommands {
|
|||
}
|
||||
|
||||
if (System.currentTimeMillis() > overallTimeout) {
|
||||
log.error("Command " + cmd + " timed out");
|
||||
aapsLogger.error(LTag.PUMP, "Command " + cmd + " timed out");
|
||||
cmdThread.interrupt();
|
||||
activeCmd.getResult().success = false;
|
||||
break;
|
||||
}
|
||||
|
||||
if (unparsableMenuEncountered) {
|
||||
log.error("UnparsableMenuEncountered flagged, aborting command");
|
||||
aapsLogger.error(LTag.PUMP, "UnparsableMenuEncountered flagged, aborting command");
|
||||
cmdThread.interrupt();
|
||||
activeCmd.getResult().invalidSetup = true;
|
||||
activeCmd.getResult().success = false;
|
||||
}
|
||||
|
||||
log.trace("Waiting for running command to complete");
|
||||
aapsLogger.debug(LTag.PUMP, "Waiting for running command to complete");
|
||||
SystemClock.sleep(500);
|
||||
}
|
||||
|
||||
activeCmd.getResult().state = readPumpStateInternal();
|
||||
CommandResult result = activeCmd.getResult();
|
||||
if (log.isDebugEnabled()) {
|
||||
long connectDurationSec = (executionStart - connectStart) / 1000;
|
||||
long executionDurationSec = (System.currentTimeMillis() - executionStart) / 1000;
|
||||
log.debug("Command result: " + result);
|
||||
log.debug("Connect: " + connectDurationSec + "s, execution: " + executionDurationSec + "s");
|
||||
}
|
||||
long connectDurationSec = (executionStart - connectStart) / 1000;
|
||||
long executionDurationSec = (System.currentTimeMillis() - executionStart) / 1000;
|
||||
aapsLogger.debug(LTag.PUMP, "Command result: " + result);
|
||||
aapsLogger.debug(LTag.PUMP, "Connect: " + connectDurationSec + "s, execution: " + executionDurationSec + "s");
|
||||
return result;
|
||||
} catch (CommandException e) {
|
||||
log.error("CommandException while executing command", e);
|
||||
aapsLogger.error(LTag.PUMP, "CommandException while executing command", e);
|
||||
PumpState pumpState = recoverFromCommandFailure();
|
||||
addError(e);
|
||||
return activeCmd.getResult().success(false).state(pumpState);
|
||||
} catch (Exception e) {
|
||||
log.error("Unexpected exception communication with ruffy", e);
|
||||
aapsLogger.error(LTag.PUMP, "Unexpected exception communication with ruffy", e);
|
||||
PumpState pumpState = recoverFromCommandFailure();
|
||||
addError(e);
|
||||
return activeCmd.getResult().success(false).state(pumpState);
|
||||
} finally {
|
||||
Menu menu = this.currentMenu;
|
||||
if (activeCmd.getResult().success && menu != null && menu.getType() != MenuType.MAIN_MENU) {
|
||||
log.warn("Command " + activeCmd + " successful, but finished leaving pump on menu " + getCurrentMenuName());
|
||||
aapsLogger.warn(LTag.PUMP, "Command " + activeCmd + " successful, but finished leaving pump on menu " + getCurrentMenuName());
|
||||
}
|
||||
if (cmdThread != null) {
|
||||
try {
|
||||
|
@ -377,18 +383,18 @@ public class RuffyScripter implements RuffyCommands {
|
|||
activeCmd.getResult().success = true;
|
||||
} else if (getCurrentMenu().getType() == MenuType.STOP) {
|
||||
if (cmd.needsRunMode()) {
|
||||
log.error("Requested command requires run mode, but pump is suspended");
|
||||
aapsLogger.error(LTag.PUMP, "Requested command requires run mode, but pump is suspended");
|
||||
activeCmd.getResult().success = false;
|
||||
return false;
|
||||
}
|
||||
} else if (getCurrentMenu().getType() == MenuType.WARNING_OR_ERROR) {
|
||||
if (!(cmd instanceof ConfirmAlertCommand)) {
|
||||
log.warn("Warning/alert active on pump, but requested command is not ConfirmAlertCommand");
|
||||
aapsLogger.warn(LTag.PUMP, "Warning/alert active on pump, but requested command is not ConfirmAlertCommand");
|
||||
activeCmd.getResult().success = false;
|
||||
return false;
|
||||
}
|
||||
} else if (getCurrentMenu().getType() != MenuType.MAIN_MENU) {
|
||||
log.debug("Pump is unexpectedly not on main menu but " + getCurrentMenuName() + ", trying to recover");
|
||||
aapsLogger.debug(LTag.PUMP, "Pump is unexpectedly not on main menu but " + getCurrentMenuName() + ", trying to recover");
|
||||
try {
|
||||
recoverFromCommandFailure();
|
||||
} catch (Exception e) {
|
||||
|
@ -411,12 +417,12 @@ public class RuffyScripter implements RuffyCommands {
|
|||
* @return whether the reconnect and return to main menu was successful
|
||||
*/
|
||||
private boolean recoverFromConnectionLoss() {
|
||||
log.debug("Connection was lost, trying to reconnect");
|
||||
aapsLogger.debug(LTag.PUMP, "Connection was lost, trying to reconnect");
|
||||
ensureConnected();
|
||||
if (getCurrentMenu().getType() == MenuType.WARNING_OR_ERROR) {
|
||||
WarningOrErrorCode warningOrErrorCode = readWarningOrErrorCode();
|
||||
if (Objects.equals(activeCmd.getReconnectWarningId(), warningOrErrorCode.warningCode)) {
|
||||
log.debug("Confirming warning caused by disconnect: #" + warningOrErrorCode.warningCode);
|
||||
aapsLogger.debug(LTag.PUMP, "Confirming warning caused by disconnect: #" + warningOrErrorCode.warningCode);
|
||||
// confirm alert
|
||||
verifyMenuIsDisplayed(MenuType.WARNING_OR_ERROR);
|
||||
pressCheckKey();
|
||||
|
@ -433,7 +439,7 @@ public class RuffyScripter implements RuffyCommands {
|
|||
returnToRootMenu();
|
||||
}
|
||||
}
|
||||
log.debug("Recovery from connection loss " + (connected ? "succeeded" : "failed"));
|
||||
aapsLogger.debug(LTag.PUMP, "Recovery from connection loss " + (connected ? "succeeded" : "failed"));
|
||||
return connected;
|
||||
}
|
||||
|
||||
|
@ -449,17 +455,16 @@ public class RuffyScripter implements RuffyCommands {
|
|||
MenuType type = menu.getType();
|
||||
if (type != MenuType.WARNING_OR_ERROR && type != MenuType.MAIN_MENU) {
|
||||
try {
|
||||
log.debug("Command execution yielded an error, returning to main menu");
|
||||
aapsLogger.debug(LTag.PUMP, "Command execution yielded an error, returning to main menu");
|
||||
returnToRootMenu();
|
||||
} catch (Exception e) {
|
||||
log.warn("Error returning to main menu, when trying to recover from command failure", e);
|
||||
aapsLogger.warn(LTag.PUMP, "Error returning to main menu, when trying to recover from command failure", e);
|
||||
}
|
||||
}
|
||||
try {
|
||||
PumpState pumpState = readPumpStateInternal();
|
||||
return pumpState;
|
||||
return readPumpStateInternal();
|
||||
} catch (Exception e) {
|
||||
log.debug("Reading pump state during recovery failed", e);
|
||||
aapsLogger.debug(LTag.PUMP, "Reading pump state during recovery failed", e);
|
||||
return new PumpState();
|
||||
}
|
||||
}
|
||||
|
@ -474,8 +479,8 @@ public class RuffyScripter implements RuffyCommands {
|
|||
}
|
||||
|
||||
boolean connectInitSuccessful = ruffyService.doRTConnect() == 0;
|
||||
log.debug("Connect init successful: " + connectInitSuccessful);
|
||||
log.debug("Waiting for first menu update to be sent");
|
||||
aapsLogger.debug(LTag.PUMP, "Connect init successful: " + connectInitSuccessful);
|
||||
aapsLogger.debug(LTag.PUMP, "Waiting for first menu update to be sent");
|
||||
long timeoutExpired = System.currentTimeMillis() + 90 * 1000;
|
||||
long initialUpdateTime = menuLastUpdated;
|
||||
while (initialUpdateTime == menuLastUpdated) {
|
||||
|
@ -488,14 +493,14 @@ public class RuffyScripter implements RuffyCommands {
|
|||
try {
|
||||
ruffyService.doRTDisconnect();
|
||||
} catch (RemoteException e1) {
|
||||
log.warn("Disconnect after connect failure failed", e1);
|
||||
aapsLogger.warn(LTag.PUMP, "Disconnect after connect failure failed", e1);
|
||||
}
|
||||
throw e;
|
||||
} catch (Exception e) {
|
||||
try {
|
||||
ruffyService.doRTDisconnect();
|
||||
} catch (RemoteException e1) {
|
||||
log.warn("Disconnect after connect failure failed", e1);
|
||||
aapsLogger.warn(LTag.PUMP, "Disconnect after connect failure failed", e1);
|
||||
}
|
||||
throw new CommandException("Unexpected exception while initiating/restoring pump connection", e);
|
||||
}
|
||||
|
@ -510,11 +515,11 @@ public class RuffyScripter implements RuffyCommands {
|
|||
state.timestamp = System.currentTimeMillis();
|
||||
Menu menu = currentMenu;
|
||||
if (menu == null) {
|
||||
log.debug("Returning empty PumpState, menu is unavailable");
|
||||
aapsLogger.debug(LTag.PUMP, "Returning empty PumpState, menu is unavailable");
|
||||
return state;
|
||||
}
|
||||
|
||||
log.debug("Parsing menu: " + menu);
|
||||
aapsLogger.debug(LTag.PUMP, "Parsing menu: " + menu);
|
||||
MenuType menuType = menu.getType();
|
||||
state.menu = menuType.name();
|
||||
|
||||
|
@ -577,7 +582,7 @@ public class RuffyScripter implements RuffyCommands {
|
|||
}
|
||||
}
|
||||
|
||||
log.debug("State read: " + state);
|
||||
aapsLogger.debug(LTag.PUMP, "State read: " + state);
|
||||
return state;
|
||||
}
|
||||
|
||||
|
@ -615,7 +620,7 @@ public class RuffyScripter implements RuffyCommands {
|
|||
throw new CommandException("Interrupted");
|
||||
Menu menu = this.currentMenu;
|
||||
if (menu == null) {
|
||||
log.error("currentMenu == null, bailing");
|
||||
aapsLogger.error(LTag.PUMP, "currentMenu == null, bailing");
|
||||
throw new CommandException("Unable to read current menu");
|
||||
}
|
||||
return menu;
|
||||
|
@ -628,39 +633,39 @@ public class RuffyScripter implements RuffyCommands {
|
|||
}
|
||||
|
||||
public void pressUpKey() {
|
||||
log.debug("Pressing up key");
|
||||
aapsLogger.debug(LTag.PUMP, "Pressing up key");
|
||||
pressKey(Key.UP);
|
||||
log.debug("Releasing up key");
|
||||
aapsLogger.debug(LTag.PUMP, "Releasing up key");
|
||||
}
|
||||
|
||||
public void pressDownKey() {
|
||||
log.debug("Pressing down key");
|
||||
aapsLogger.debug(LTag.PUMP, "Pressing down key");
|
||||
pressKey(Key.DOWN);
|
||||
log.debug("Releasing down key");
|
||||
aapsLogger.debug(LTag.PUMP, "Releasing down key");
|
||||
}
|
||||
|
||||
public void pressCheckKey() {
|
||||
log.debug("Pressing check key");
|
||||
aapsLogger.debug(LTag.PUMP, "Pressing check key");
|
||||
pressKey(Key.CHECK);
|
||||
log.debug("Releasing check key");
|
||||
aapsLogger.debug(LTag.PUMP, "Releasing check key");
|
||||
}
|
||||
|
||||
public void pressMenuKey() {
|
||||
log.debug("Pressing menu key");
|
||||
aapsLogger.debug(LTag.PUMP, "Pressing menu key");
|
||||
pressKey(Key.MENU);
|
||||
log.debug("Releasing menu key");
|
||||
aapsLogger.debug(LTag.PUMP, "Releasing menu key");
|
||||
}
|
||||
|
||||
private void pressBackKey() {
|
||||
log.debug("Pressing back key");
|
||||
aapsLogger.debug(LTag.PUMP, "Pressing back key");
|
||||
pressKey(Key.BACK);
|
||||
log.debug("Releasing back key");
|
||||
aapsLogger.debug(LTag.PUMP, "Releasing back key");
|
||||
}
|
||||
|
||||
public void pressKeyMs(final byte key, long ms) {
|
||||
long stepMs = 100;
|
||||
try {
|
||||
log.debug("Scroll: Pressing key for " + ms + " ms with step " + stepMs + " ms");
|
||||
aapsLogger.debug(LTag.PUMP, "Scroll: Pressing key for " + ms + " ms with step " + stepMs + " ms");
|
||||
ruffyService.rtSendKey(key, true);
|
||||
ruffyService.rtSendKey(key, false);
|
||||
while (ms > stepMs) {
|
||||
|
@ -670,7 +675,7 @@ public class RuffyScripter implements RuffyCommands {
|
|||
}
|
||||
SystemClock.sleep(ms);
|
||||
ruffyService.rtSendKey(Key.NO_KEY, true);
|
||||
log.debug("Releasing key");
|
||||
aapsLogger.debug(LTag.PUMP, "Releasing key");
|
||||
} catch (Exception e) {
|
||||
throw new CommandException("Error while pressing buttons");
|
||||
}
|
||||
|
@ -709,7 +714,7 @@ public class RuffyScripter implements RuffyCommands {
|
|||
int moves = 20;
|
||||
MenuType lastSeenMenu = getCurrentMenu().getType();
|
||||
while (lastSeenMenu != desiredMenu) {
|
||||
log.debug("Navigating to menu " + desiredMenu + ", current menu: " + lastSeenMenu);
|
||||
aapsLogger.debug(LTag.PUMP, "Navigating to menu " + desiredMenu + ", current menu: " + lastSeenMenu);
|
||||
moves--;
|
||||
if (moves == 0) {
|
||||
throw new CommandException("Menu not found searching for " + desiredMenu
|
||||
|
@ -788,7 +793,7 @@ public class RuffyScripter implements RuffyCommands {
|
|||
|
||||
@Override
|
||||
public CommandResult deliverBolus(double amount, BolusProgressReporter bolusProgressReporter) {
|
||||
return runCommand(new BolusCommand(amount, bolusProgressReporter));
|
||||
return runCommand(new BolusCommand(amount, bolusProgressReporter, aapsLogger));
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -796,18 +801,18 @@ public class RuffyScripter implements RuffyCommands {
|
|||
if (activeCmd instanceof BolusCommand) {
|
||||
((BolusCommand) activeCmd).requestCancellation();
|
||||
} else {
|
||||
log.error("cancelBolus called, but active command is not a bolus:" + activeCmd);
|
||||
aapsLogger.error(LTag.PUMP, "cancelBolus called, but active command is not a bolus:" + activeCmd);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public CommandResult setTbr(int percent, int duration) {
|
||||
return runCommand(new SetTbrCommand(percent, duration));
|
||||
return runCommand(new SetTbrCommand(percent, duration, aapsLogger));
|
||||
}
|
||||
|
||||
@Override
|
||||
public CommandResult cancelTbr() {
|
||||
return runCommand(new CancelTbrCommand());
|
||||
return runCommand(new CancelTbrCommand(aapsLogger));
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -817,17 +822,17 @@ public class RuffyScripter implements RuffyCommands {
|
|||
|
||||
@Override
|
||||
public CommandResult readHistory(PumpHistoryRequest request) {
|
||||
return runCommand(new ReadHistoryCommand(request));
|
||||
return runCommand(new ReadHistoryCommand(request, aapsLogger));
|
||||
}
|
||||
|
||||
@Override
|
||||
public CommandResult readBasalProfile() {
|
||||
return runCommand(new ReadBasalProfileCommand());
|
||||
return runCommand(new ReadBasalProfileCommand(aapsLogger));
|
||||
}
|
||||
|
||||
@Override
|
||||
public CommandResult setBasalProfile(BasalProfile basalProfile) {
|
||||
return runCommand(new SetBasalProfileCommand(basalProfile));
|
||||
return runCommand(new SetBasalProfileCommand(basalProfile, aapsLogger));
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -887,8 +892,8 @@ public class RuffyScripter implements RuffyCommands {
|
|||
// when a command returns
|
||||
WarningOrErrorCode displayedWarning = readWarningOrErrorCode();
|
||||
while (Objects.equals(displayedWarning.warningCode, warningCode)) {
|
||||
waitForScreenUpdate();
|
||||
displayedWarning = readWarningOrErrorCode();
|
||||
waitForScreenUpdate();
|
||||
displayedWarning = readWarningOrErrorCode();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
|
|
@ -1,39 +1,41 @@
|
|||
package info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands;
|
||||
|
||||
import android.os.SystemClock;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuAttribute;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuType;
|
||||
import org.slf4j.Logger;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Objects;
|
||||
|
||||
import info.nightscout.shared.logging.StacktraceLoggerWrapper;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.BolusProgressReporter;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.PumpWarningCodes;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.RuffyScripter;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.WarningOrErrorCode;
|
||||
|
||||
import static info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.BolusProgressReporter.State.DELIVERED;
|
||||
import static info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.BolusProgressReporter.State.DELIVERING;
|
||||
import static info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.BolusProgressReporter.State.PROGRAMMING;
|
||||
import static info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.BolusProgressReporter.State.STOPPED;
|
||||
import static info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.BolusProgressReporter.State.STOPPING;
|
||||
|
||||
import android.os.SystemClock;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuAttribute;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuType;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Objects;
|
||||
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.BolusProgressReporter;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.PumpWarningCodes;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.RuffyScripter;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.WarningOrErrorCode;
|
||||
import info.nightscout.shared.logging.AAPSLogger;
|
||||
import info.nightscout.shared.logging.LTag;
|
||||
|
||||
public class BolusCommand extends BaseCommand {
|
||||
private static final Logger log = StacktraceLoggerWrapper.getLogger(BolusCommand.class);
|
||||
|
||||
private final AAPSLogger aapsLogger;
|
||||
|
||||
protected final double bolus;
|
||||
private final BolusProgressReporter bolusProgressReporter;
|
||||
private volatile boolean cancelRequested;
|
||||
|
||||
public BolusCommand(double bolus, BolusProgressReporter bolusProgressReporter) {
|
||||
public BolusCommand(double bolus, BolusProgressReporter bolusProgressReporter, AAPSLogger aapsLogger) {
|
||||
this.bolus = bolus;
|
||||
this.bolusProgressReporter = bolusProgressReporter;
|
||||
this.aapsLogger = aapsLogger;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -57,7 +59,7 @@ public class BolusCommand extends BaseCommand {
|
|||
if (cancelRequested) {
|
||||
bolusProgressReporter.report(STOPPED, 0, 0);
|
||||
result.success = true;
|
||||
log.debug("Stage 0: cancelled bolus before programming");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 0: cancelled bolus before programming");
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -72,26 +74,26 @@ public class BolusCommand extends BaseCommand {
|
|||
scripter.returnToRootMenu();
|
||||
bolusProgressReporter.report(STOPPED, 0, 0);
|
||||
result.success = true;
|
||||
log.debug("Stage 1: cancelled bolus after programming");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 1: cancelled bolus after programming");
|
||||
return;
|
||||
}
|
||||
|
||||
// confirm bolus
|
||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
||||
scripter.pressCheckKey();
|
||||
log.debug("Stage 2: bolus confirmed");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 2: bolus confirmed");
|
||||
|
||||
// the pump displays the entered bolus and waits a few seconds to let user check and cancel
|
||||
while (scripter.getCurrentMenu().getType() == MenuType.BOLUS_ENTER) {
|
||||
if (cancelRequested) {
|
||||
log.debug("Stage 2: cancelling during confirmation wait");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 2: cancelling during confirmation wait");
|
||||
bolusProgressReporter.report(STOPPING, 0, 0);
|
||||
scripter.pressUpKey();
|
||||
// wait up to 1s for a BOLUS_CANCELLED alert, if it doesn't happen we missed
|
||||
// the window, simply continue and let the next cancel attempt try its luck
|
||||
boolean alertWasCancelled = scripter.confirmAlert(PumpWarningCodes.BOLUS_CANCELLED, 1000);
|
||||
if (alertWasCancelled) {
|
||||
log.debug("Stage 2: successfully cancelled during confirmation wait");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 2: successfully cancelled during confirmation wait");
|
||||
bolusProgressReporter.report(STOPPED, 0, 0);
|
||||
result.success = true;
|
||||
return;
|
||||
|
@ -113,7 +115,7 @@ public class BolusCommand extends BaseCommand {
|
|||
Thread cancellationThread = null;
|
||||
while (bolusRemaining != null || scripter.getCurrentMenu().getType() == MenuType.WARNING_OR_ERROR) {
|
||||
if (cancelRequested && !cancelInProgress) {
|
||||
log.debug("Stage 3: cancellation while delivering bolus");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 3: cancellation while delivering bolus");
|
||||
bolusProgressReporter.report(STOPPING, 0, 0);
|
||||
cancelInProgress = true;
|
||||
cancellationThread = new Thread(() ->
|
||||
|
@ -139,15 +141,15 @@ public class BolusCommand extends BaseCommand {
|
|||
}
|
||||
scripter.confirmAlert(PumpWarningCodes.BOLUS_CANCELLED, 2000);
|
||||
bolusProgressReporter.report(STOPPED, 0, 0);
|
||||
log.debug("Stage 3: confirmed BOLUS CANCELLED after cancelling bolus during delivery");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 3: confirmed BOLUS CANCELLED after cancelling bolus during delivery");
|
||||
} else if (Objects.equals(warningCode, PumpWarningCodes.CARTRIDGE_LOW)) {
|
||||
scripter.confirmAlert(PumpWarningCodes.CARTRIDGE_LOW, 2000);
|
||||
result.forwardedWarnings.add(PumpWarningCodes.CARTRIDGE_LOW);
|
||||
log.debug("Stage 3: confirmed low cartridge alert and forwarding to AAPS");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 3: confirmed low cartridge alert and forwarding to AAPS");
|
||||
} else if (Objects.equals(warningCode, PumpWarningCodes.BATTERY_LOW)) {
|
||||
scripter.confirmAlert(PumpWarningCodes.BATTERY_LOW, 2000);
|
||||
result.forwardedWarnings.add(PumpWarningCodes.BATTERY_LOW);
|
||||
log.debug("Stage 3: confirmed low battery alert and forwarding to AAPS");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 3: confirmed low battery alert and forwarding to AAPS");
|
||||
} else {
|
||||
// all other warnings or errors;
|
||||
// An occlusion error can also occur during bolus. To read the partially delivered
|
||||
|
@ -165,7 +167,7 @@ public class BolusCommand extends BaseCommand {
|
|||
}
|
||||
}
|
||||
if (bolusRemaining != null && !Objects.equals(bolusRemaining, lastBolusReported)) {
|
||||
log.debug("Delivering bolus, remaining: " + bolusRemaining);
|
||||
aapsLogger.debug(LTag.PUMP, "Delivering bolus, remaining: " + bolusRemaining);
|
||||
int percentDelivered = (int) (100 - (bolusRemaining / bolus * 100));
|
||||
bolusProgressReporter.report(DELIVERING, percentDelivered, bolus - bolusRemaining);
|
||||
lastBolusReported = bolusRemaining;
|
||||
|
@ -185,9 +187,9 @@ public class BolusCommand extends BaseCommand {
|
|||
}
|
||||
|
||||
if (cancelInProgress) {
|
||||
log.debug("Stage 4: bolus was cancelled, with unknown amount delivered");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 4: bolus was cancelled, with unknown amount delivered");
|
||||
} else {
|
||||
log.debug("Stage 4: full bolus of " + bolus + " U was successfully delivered");
|
||||
aapsLogger.debug(LTag.PUMP, "Stage 4: full bolus of " + bolus + " U was successfully delivered");
|
||||
bolusProgressReporter.report(DELIVERED, 100, bolus);
|
||||
}
|
||||
result.success = true;
|
||||
|
@ -219,12 +221,12 @@ public class BolusCommand extends BaseCommand {
|
|||
double displayedBolus = scripter.readBlinkingValue(Double.class, MenuAttribute.BOLUS);
|
||||
long timeout = System.currentTimeMillis() + 10 * 1000;
|
||||
while (timeout > System.currentTimeMillis() && bolus - displayedBolus > 0.05) {
|
||||
log.debug("Waiting for pump to process scrolling input for amount, current: " + displayedBolus + ", desired: " + bolus);
|
||||
aapsLogger.debug(LTag.PUMP, "Waiting for pump to process scrolling input for amount, current: " + displayedBolus + ", desired: " + bolus);
|
||||
SystemClock.sleep(50);
|
||||
displayedBolus = scripter.readBlinkingValue(Double.class, MenuAttribute.BOLUS);
|
||||
}
|
||||
|
||||
log.debug("Final bolus: " + displayedBolus);
|
||||
aapsLogger.debug(LTag.PUMP, "Final bolus: " + displayedBolus);
|
||||
if (Math.abs(displayedBolus - bolus) > 0.01) {
|
||||
throw new CommandException("Failed to set correct bolus. Expected: " + bolus + ", actual: " + displayedBolus);
|
||||
}
|
||||
|
@ -240,7 +242,7 @@ public class BolusCommand extends BaseCommand {
|
|||
}
|
||||
|
||||
public void requestCancellation() {
|
||||
log.debug("Bolus cancellation requested");
|
||||
aapsLogger.debug(LTag.PUMP, "Bolus cancellation requested");
|
||||
cancelRequested = true;
|
||||
bolusProgressReporter.report(STOPPING, 0, 0);
|
||||
}
|
||||
|
|
|
@ -3,15 +3,19 @@ package info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands;
|
|||
import androidx.annotation.NonNull;
|
||||
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuType;
|
||||
import org.slf4j.Logger;
|
||||
|
||||
import info.nightscout.shared.logging.StacktraceLoggerWrapper;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.PumpState;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.PumpWarningCodes;
|
||||
import info.nightscout.shared.logging.AAPSLogger;
|
||||
import info.nightscout.shared.logging.LTag;
|
||||
|
||||
public class CancelTbrCommand extends BaseCommand {
|
||||
private static final Logger log = StacktraceLoggerWrapper.getLogger(CancelTbrCommand.class);
|
||||
private final AAPSLogger aapsLogger;
|
||||
|
||||
public CancelTbrCommand(AAPSLogger aapsLogger) {
|
||||
this.aapsLogger = aapsLogger;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Integer getReconnectWarningId() {
|
||||
return PumpWarningCodes.TBR_CANCELLED;
|
||||
|
@ -28,9 +32,9 @@ public class CancelTbrCommand extends BaseCommand {
|
|||
return;
|
||||
}
|
||||
|
||||
log.debug("Cancelling active TBR of " + pumpState.tbrPercent
|
||||
aapsLogger.debug(LTag.PUMP, "Cancelling active TBR of " + pumpState.tbrPercent
|
||||
+ "% with " + pumpState.tbrRemainingDuration + " min remaining");
|
||||
SetTbrCommand setTbrCommand = new SetTbrCommand(100, 0);
|
||||
SetTbrCommand setTbrCommand = new SetTbrCommand(100, 0, aapsLogger);
|
||||
setTbrCommand.setScripter(scripter);
|
||||
setTbrCommand.execute();
|
||||
result = setTbrCommand.result;
|
||||
|
|
|
@ -1,19 +1,25 @@
|
|||
package info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.Menu;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuAttribute;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuType;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.menu.MenuTime;
|
||||
import org.slf4j.Logger;
|
||||
|
||||
import java.util.Arrays;
|
||||
|
||||
import info.nightscout.shared.logging.StacktraceLoggerWrapper;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.BasalProfile;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.PumpState;
|
||||
import info.nightscout.shared.logging.AAPSLogger;
|
||||
import info.nightscout.shared.logging.LTag;
|
||||
|
||||
public class ReadBasalProfileCommand extends BaseCommand {
|
||||
private static final Logger log = StacktraceLoggerWrapper.getLogger(ReadBasalProfileCommand.class);
|
||||
private final AAPSLogger aapsLogger;
|
||||
|
||||
public ReadBasalProfileCommand(AAPSLogger aapsLogger) {
|
||||
this.aapsLogger = aapsLogger;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void execute() {
|
||||
|
@ -44,10 +50,10 @@ public class ReadBasalProfileCommand extends BaseCommand {
|
|||
throw new CommandException("Attempting to read basal rate for hour " + i + ", but hour " + startTime.getHour() + " is displayed");
|
||||
}
|
||||
basalProfile.hourlyRates[i] = scripter.readBlinkingValue(Double.class, MenuAttribute.BASAL_RATE);
|
||||
log.debug("Read basal profile, hour " + i + ": " + basalProfile.hourlyRates[i]);
|
||||
aapsLogger.debug(LTag.PUMP, "Read basal profile, hour " + i + ": " + basalProfile.hourlyRates[i]);
|
||||
}
|
||||
|
||||
log.debug("Basal profile read: " + Arrays.toString(basalProfile.hourlyRates));
|
||||
aapsLogger.debug(LTag.PUMP, "Basal profile read: " + Arrays.toString(basalProfile.hourlyRates));
|
||||
|
||||
scripter.returnToRootMenu();
|
||||
scripter.verifyRootMenuIsDisplayed();
|
||||
|
@ -55,7 +61,7 @@ public class ReadBasalProfileCommand extends BaseCommand {
|
|||
result.success(true).basalProfile(basalProfile);
|
||||
}
|
||||
|
||||
@Override
|
||||
@NonNull @Override
|
||||
public String toString() {
|
||||
return "ReadBasalProfileCommand{}";
|
||||
}
|
||||
|
|
|
@ -6,27 +6,27 @@ import org.monkey.d.ruffy.ruffy.driver.display.MenuAttribute;
|
|||
import org.monkey.d.ruffy.ruffy.driver.display.MenuType;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.menu.MenuDate;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.menu.MenuTime;
|
||||
import org.slf4j.Logger;
|
||||
|
||||
import java.util.Calendar;
|
||||
import java.util.Date;
|
||||
|
||||
import info.nightscout.shared.logging.StacktraceLoggerWrapper;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.history.Bolus;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.history.PumpAlert;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.history.PumpHistory;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.history.PumpHistoryRequest;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.history.Tbr;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.history.Tdd;
|
||||
import info.nightscout.shared.logging.AAPSLogger;
|
||||
import info.nightscout.shared.logging.LTag;
|
||||
|
||||
public class ReadHistoryCommand extends BaseCommand {
|
||||
private static final Logger log = StacktraceLoggerWrapper.getLogger(ReadHistoryCommand.class);
|
||||
|
||||
private final AAPSLogger aapsLogger;
|
||||
private final PumpHistoryRequest request;
|
||||
private final PumpHistory history = new PumpHistory();
|
||||
|
||||
public ReadHistoryCommand(PumpHistoryRequest request) {
|
||||
public ReadHistoryCommand(PumpHistoryRequest request, AAPSLogger aapsLogger) {
|
||||
this.request = request;
|
||||
this.aapsLogger = aapsLogger;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -106,30 +106,28 @@ public class ReadHistoryCommand extends BaseCommand {
|
|||
}
|
||||
}
|
||||
|
||||
if (log.isDebugEnabled()) {
|
||||
if (!history.bolusHistory.isEmpty()) {
|
||||
log.debug("Read bolus history (" + history.bolusHistory.size() + "):");
|
||||
for (Bolus bolus : history.bolusHistory) {
|
||||
log.debug(new Date(bolus.timestamp) + ": " + bolus.toString());
|
||||
}
|
||||
if (!history.bolusHistory.isEmpty()) {
|
||||
aapsLogger.debug(LTag.PUMP, "Read bolus history (" + history.bolusHistory.size() + "):");
|
||||
for (Bolus bolus : history.bolusHistory) {
|
||||
aapsLogger.debug(LTag.PUMP, new Date(bolus.timestamp) + ": " + bolus.toString());
|
||||
}
|
||||
if (!history.pumpAlertHistory.isEmpty()) {
|
||||
log.debug("Read error history (" + history.pumpAlertHistory.size() + "):");
|
||||
for (PumpAlert pumpAlert : history.pumpAlertHistory) {
|
||||
log.debug(new Date(pumpAlert.timestamp) + ": " + pumpAlert.toString());
|
||||
}
|
||||
}
|
||||
if (!history.pumpAlertHistory.isEmpty()) {
|
||||
aapsLogger.debug(LTag.PUMP, "Read error history (" + history.pumpAlertHistory.size() + "):");
|
||||
for (PumpAlert pumpAlert : history.pumpAlertHistory) {
|
||||
aapsLogger.debug(LTag.PUMP, new Date(pumpAlert.timestamp) + ": " + pumpAlert.toString());
|
||||
}
|
||||
if (!history.tddHistory.isEmpty()) {
|
||||
log.debug("Read TDD history (" + history.tddHistory.size() + "):");
|
||||
for (Tdd tdd : history.tddHistory) {
|
||||
log.debug(new Date(tdd.timestamp) + ": " + tdd.toString());
|
||||
}
|
||||
}
|
||||
if (!history.tddHistory.isEmpty()) {
|
||||
aapsLogger.debug(LTag.PUMP, "Read TDD history (" + history.tddHistory.size() + "):");
|
||||
for (Tdd tdd : history.tddHistory) {
|
||||
aapsLogger.debug(LTag.PUMP, new Date(tdd.timestamp) + ": " + tdd.toString());
|
||||
}
|
||||
if (!history.tbrHistory.isEmpty()) {
|
||||
log.debug("Read TBR history (" + history.tbrHistory.size() + "):");
|
||||
for (Tbr tbr : history.tbrHistory) {
|
||||
log.debug(new Date(tbr.timestamp) + ": " + tbr.toString());
|
||||
}
|
||||
}
|
||||
if (!history.tbrHistory.isEmpty()) {
|
||||
aapsLogger.debug(LTag.PUMP, "Read TBR history (" + history.tbrHistory.size() + "):");
|
||||
for (Tbr tbr : history.tbrHistory) {
|
||||
aapsLogger.debug(LTag.PUMP, new Date(tbr.timestamp) + ": " + tbr.toString());
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -147,9 +145,9 @@ public class ReadHistoryCommand extends BaseCommand {
|
|||
if (requestedTime != PumpHistoryRequest.FULL && tdd.timestamp < requestedTime) {
|
||||
break;
|
||||
}
|
||||
log.debug("Read TDD record #" + record + "/" + totalRecords);
|
||||
aapsLogger.debug(LTag.PUMP, "Read TDD record #" + record + "/" + totalRecords);
|
||||
history.tddHistory.add(tdd);
|
||||
log.debug("Parsed " + scripter.getCurrentMenu().toString() + " => " + tdd);
|
||||
aapsLogger.debug(LTag.PUMP, "Parsed " + scripter.getCurrentMenu() + " => " + tdd);
|
||||
if (record == totalRecords) {
|
||||
break;
|
||||
}
|
||||
|
@ -174,7 +172,7 @@ public class ReadHistoryCommand extends BaseCommand {
|
|||
Calendar calendar = Calendar.getInstance();
|
||||
calendar.set(year, date.getMonth() - 1, date.getDay(), 0, 0, 0);
|
||||
long time = calendar.getTimeInMillis();
|
||||
time = time - time%1000;
|
||||
time = time - time % 1000;
|
||||
return new Tdd(time, dailyTotal);
|
||||
}
|
||||
|
||||
|
@ -186,9 +184,9 @@ public class ReadHistoryCommand extends BaseCommand {
|
|||
if (requestedTime != PumpHistoryRequest.FULL && tbr.timestamp < requestedTime) {
|
||||
break;
|
||||
}
|
||||
log.debug("Read TBR record #" + record + "/" + totalRecords);
|
||||
aapsLogger.debug(LTag.PUMP, "Read TBR record #" + record + "/" + totalRecords);
|
||||
history.tbrHistory.add(tbr);
|
||||
log.debug("Parsed " + scripter.getCurrentMenu().toString() + " => " + tbr);
|
||||
aapsLogger.debug(LTag.PUMP, "Parsed " + scripter.getCurrentMenu() + " => " + tbr);
|
||||
if (record == totalRecords) {
|
||||
break;
|
||||
}
|
||||
|
@ -206,7 +204,7 @@ public class ReadHistoryCommand extends BaseCommand {
|
|||
Double percentage = (Double) scripter.getCurrentMenu().getAttribute(MenuAttribute.TBR);
|
||||
MenuTime durationTime = (MenuTime) scripter.getCurrentMenu().getAttribute(MenuAttribute.RUNTIME);
|
||||
int duration = durationTime.getHour() * 60 + durationTime.getMinute();
|
||||
long tbrStartDate = readRecordDate() - duration * 60 * 1000;
|
||||
long tbrStartDate = readRecordDate() - duration * 60L * 1000;
|
||||
return new Tbr(tbrStartDate, duration, percentage.intValue());
|
||||
}
|
||||
|
||||
|
@ -218,9 +216,9 @@ public class ReadHistoryCommand extends BaseCommand {
|
|||
if (requestedTime != PumpHistoryRequest.FULL && bolus.timestamp < requestedTime) {
|
||||
break;
|
||||
}
|
||||
log.debug("Read bolus record #" + record + "/" + totalRecords);
|
||||
aapsLogger.debug(LTag.PUMP, "Read bolus record #" + record + "/" + totalRecords);
|
||||
history.bolusHistory.add(bolus);
|
||||
log.debug("Parsed " + scripter.getCurrentMenu().toString() + " => " + bolus);
|
||||
aapsLogger.debug(LTag.PUMP, "Parsed " + scripter.getCurrentMenu() + " => " + bolus);
|
||||
if (record == totalRecords) {
|
||||
break;
|
||||
}
|
||||
|
@ -240,9 +238,9 @@ public class ReadHistoryCommand extends BaseCommand {
|
|||
if (requestedTime != PumpHistoryRequest.FULL && error.timestamp < requestedTime) {
|
||||
break;
|
||||
}
|
||||
log.debug("Read alert record #" + record + "/" + totalRecords);
|
||||
aapsLogger.debug(LTag.PUMP, "Read alert record #" + record + "/" + totalRecords);
|
||||
history.pumpAlertHistory.add(error);
|
||||
log.debug("Parsed " + scripter.getCurrentMenu().toString() + " => " + error);
|
||||
aapsLogger.debug(LTag.PUMP, "Parsed " + scripter.getCurrentMenu() + " => " + error);
|
||||
if (record == totalRecords) {
|
||||
break;
|
||||
}
|
||||
|
@ -265,7 +263,7 @@ public class ReadHistoryCommand extends BaseCommand {
|
|||
return new PumpAlert(recordDate, warningCode, errorCode, message);
|
||||
}
|
||||
|
||||
@Override
|
||||
@NonNull @Override
|
||||
public String toString() {
|
||||
return "ReadHistoryCommand{" +
|
||||
"request=" + request +
|
||||
|
|
|
@ -1,24 +1,27 @@
|
|||
package info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuAttribute;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuType;
|
||||
import org.slf4j.Logger;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
import info.nightscout.shared.logging.StacktraceLoggerWrapper;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.history.Bolus;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.history.PumpHistory;
|
||||
import info.nightscout.shared.logging.AAPSLogger;
|
||||
import info.nightscout.shared.logging.LTag;
|
||||
|
||||
public class ReadQuickInfoCommand extends BaseCommand {
|
||||
private static final Logger log = StacktraceLoggerWrapper.getLogger(ReadQuickInfoCommand.class);
|
||||
private final AAPSLogger aapsLogger;
|
||||
|
||||
private final int numberOfBolusRecordsToRetrieve;
|
||||
|
||||
public ReadQuickInfoCommand(int numberOfBolusRecordsToRetrieve) {
|
||||
public ReadQuickInfoCommand(int numberOfBolusRecordsToRetrieve, AAPSLogger aapsLogger) {
|
||||
this.numberOfBolusRecordsToRetrieve = numberOfBolusRecordsToRetrieve;
|
||||
this.aapsLogger = aapsLogger;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -53,12 +56,10 @@ public class ReadQuickInfoCommand extends BaseCommand {
|
|||
record = (int) scripter.getCurrentMenu().getAttribute(MenuAttribute.CURRENT_RECORD);
|
||||
}
|
||||
}
|
||||
if (log.isDebugEnabled()) {
|
||||
if (!result.history.bolusHistory.isEmpty()) {
|
||||
log.debug("Read bolus history (" + result.history.bolusHistory.size() + "):");
|
||||
for (Bolus bolus : result.history.bolusHistory) {
|
||||
log.debug(new Date(bolus.timestamp) + ": " + bolus.toString());
|
||||
}
|
||||
if (!result.history.bolusHistory.isEmpty()) {
|
||||
aapsLogger.debug(LTag.PUMP, "Read bolus history (" + result.history.bolusHistory.size() + "):");
|
||||
for (Bolus bolus : result.history.bolusHistory) {
|
||||
aapsLogger.debug(LTag.PUMP, new Date(bolus.timestamp) + ": " + bolus);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -71,7 +72,7 @@ public class ReadQuickInfoCommand extends BaseCommand {
|
|||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
@NonNull @Override
|
||||
public String toString() {
|
||||
return "ReadQuickInfoCommand{}";
|
||||
}
|
||||
|
|
|
@ -2,26 +2,29 @@ package info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands;
|
|||
|
||||
import android.os.SystemClock;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.Menu;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuAttribute;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuType;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.menu.MenuTime;
|
||||
import org.slf4j.Logger;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import info.nightscout.shared.logging.StacktraceLoggerWrapper;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.BasalProfile;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.PumpState;
|
||||
import info.nightscout.shared.logging.AAPSLogger;
|
||||
import info.nightscout.shared.logging.LTag;
|
||||
|
||||
public class SetBasalProfileCommand extends BaseCommand {
|
||||
private static final Logger log = StacktraceLoggerWrapper.getLogger(SetBasalProfileCommand.class);
|
||||
private final AAPSLogger aapsLogger;
|
||||
|
||||
private final BasalProfile basalProfile;
|
||||
|
||||
public SetBasalProfileCommand(BasalProfile basalProfile) {
|
||||
public SetBasalProfileCommand(BasalProfile basalProfile, AAPSLogger aapsLogger) {
|
||||
this.basalProfile = basalProfile;
|
||||
this.aapsLogger = aapsLogger;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -52,7 +55,7 @@ public class SetBasalProfileCommand extends BaseCommand {
|
|||
verifyDisplayedRate(requestedRate, change);
|
||||
}
|
||||
|
||||
log.debug("Set basal profile, hour " + i + ": " + requestedRate);
|
||||
aapsLogger.debug(LTag.PUMP, "Set basal profile, hour " + i + ": " + requestedRate);
|
||||
}
|
||||
|
||||
// move from hourly values to basal total
|
||||
|
@ -78,9 +81,9 @@ public class SetBasalProfileCommand extends BaseCommand {
|
|||
|
||||
private long inputBasalRate(double requestedRate) {
|
||||
double currentRate = scripter.readBlinkingValue(Double.class, MenuAttribute.BASAL_RATE);
|
||||
log.debug("Current rate: " + currentRate + ", requested: " + requestedRate);
|
||||
aapsLogger.debug(LTag.PUMP, "Current rate: " + currentRate + ", requested: " + requestedRate);
|
||||
// the pump changes steps size from 0.01 to 0.05 when crossing 1.00 U
|
||||
long steps = 0;
|
||||
long steps;
|
||||
if (currentRate == 0) {
|
||||
// edge case of starting from 0.00;
|
||||
steps = stepsToOne(0.05) - stepsToOne(requestedRate) + 1;
|
||||
|
@ -90,10 +93,10 @@ public class SetBasalProfileCommand extends BaseCommand {
|
|||
if (steps == 0) {
|
||||
return 0;
|
||||
}
|
||||
log.debug("Pressing " + (steps > 0 ? "up" : "down") + " " + Math.abs(steps) + " times");
|
||||
aapsLogger.debug(LTag.PUMP, "Pressing " + (steps > 0 ? "up" : "down") + " " + Math.abs(steps) + " times");
|
||||
for (int i = 0; i < Math.abs(steps); i++) {
|
||||
scripter.verifyMenuIsDisplayed(MenuType.BASAL_SET);
|
||||
log.debug("Push #" + (i + 1) + "/" + Math.abs(steps));
|
||||
aapsLogger.debug(LTag.PUMP, "Push #" + (i + 1) + "/" + Math.abs(steps));
|
||||
if (steps > 0) scripter.pressUpKey();
|
||||
else scripter.pressDownKey();
|
||||
SystemClock.sleep(50);
|
||||
|
@ -119,13 +122,13 @@ public class SetBasalProfileCommand extends BaseCommand {
|
|||
while (timeout > System.currentTimeMillis()
|
||||
&& ((change > 0 && requestedRate - displayedRate > 0.001) // displayedRate < requestedRate)
|
||||
|| (change < 0 && displayedRate - requestedRate > 0.001))) { //displayedRate > requestedRate))) {
|
||||
log.debug("Waiting for pump to process scrolling input for rate, current: "
|
||||
aapsLogger.debug(LTag.PUMP, "Waiting for pump to process scrolling input for rate, current: "
|
||||
+ displayedRate + ", desired: " + requestedRate + ", scrolling "
|
||||
+ (change > 0 ? "up" : "down"));
|
||||
scripter.waitForScreenUpdate();
|
||||
displayedRate = scripter.readBlinkingValue(Double.class, MenuAttribute.BASAL_RATE);
|
||||
}
|
||||
log.debug("Final displayed basal rate: " + displayedRate);
|
||||
aapsLogger.debug(LTag.PUMP, "Final displayed basal rate: " + displayedRate);
|
||||
if (Math.abs(displayedRate - requestedRate) > 0.001) {
|
||||
throw new CommandException("Failed to set basal rate, requested: "
|
||||
+ requestedRate + ", actual: " + displayedRate);
|
||||
|
@ -153,7 +156,7 @@ public class SetBasalProfileCommand extends BaseCommand {
|
|||
return violations;
|
||||
}
|
||||
|
||||
@Override
|
||||
@NonNull @Override
|
||||
public String toString() {
|
||||
return "SetBasalProfileCommand{" +
|
||||
"basalProfile=" + basalProfile +
|
||||
|
|
|
@ -2,29 +2,32 @@ package info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.commands;
|
|||
|
||||
import android.os.SystemClock;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuAttribute;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.MenuType;
|
||||
import org.monkey.d.ruffy.ruffy.driver.display.menu.MenuTime;
|
||||
import org.slf4j.Logger;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Objects;
|
||||
|
||||
import info.nightscout.shared.logging.StacktraceLoggerWrapper;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.PumpState;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.PumpWarningCodes;
|
||||
import info.nightscout.androidaps.plugins.pump.combo.ruffyscripter.WarningOrErrorCode;
|
||||
import info.nightscout.shared.logging.AAPSLogger;
|
||||
import info.nightscout.shared.logging.LTag;
|
||||
|
||||
public class SetTbrCommand extends BaseCommand {
|
||||
private static final Logger log = StacktraceLoggerWrapper.getLogger(SetTbrCommand.class);
|
||||
private final AAPSLogger aapsLogger;
|
||||
|
||||
private final long percentage;
|
||||
private final long duration;
|
||||
|
||||
public SetTbrCommand(long percentage, long duration) {
|
||||
public SetTbrCommand(long percentage, long duration, AAPSLogger aapsLogger) {
|
||||
this.percentage = percentage;
|
||||
this.duration = duration;
|
||||
this.aapsLogger = aapsLogger;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -116,7 +119,7 @@ public class SetTbrCommand extends BaseCommand {
|
|||
PumpState state = scripter.readPumpStateInternal();
|
||||
if (state.tbrRemainingDuration == 1) {
|
||||
while (state.tbrActive && System.currentTimeMillis() < timeout) {
|
||||
log.debug("Waiting for existing TBR to run out to avoid alert while setting TBR");
|
||||
aapsLogger.debug(LTag.PUMP, "Waiting for existing TBR to run out to avoid alert while setting TBR");
|
||||
scripter.waitForScreenUpdate();
|
||||
state = scripter.readPumpStateInternal();
|
||||
}
|
||||
|
@ -140,14 +143,14 @@ public class SetTbrCommand extends BaseCommand {
|
|||
private boolean inputTbrPercentage() {
|
||||
scripter.verifyMenuIsDisplayed(MenuType.TBR_SET);
|
||||
long currentPercent = readDisplayedPercentage();
|
||||
log.debug("Current TBR %: " + currentPercent);
|
||||
aapsLogger.debug(LTag.PUMP, "Current TBR %: " + currentPercent);
|
||||
long percentageChange = percentage - currentPercent;
|
||||
long percentageSteps = percentageChange / 10;
|
||||
boolean increasePercentage = percentageSteps > 0;
|
||||
log.debug("Pressing " + (increasePercentage ? "up" : "down") + " " + percentageSteps + " times");
|
||||
aapsLogger.debug(LTag.PUMP, "Pressing " + (increasePercentage ? "up" : "down") + " " + percentageSteps + " times");
|
||||
for (int i = 0; i < Math.abs(percentageSteps); i++) {
|
||||
scripter.verifyMenuIsDisplayed(MenuType.TBR_SET);
|
||||
log.debug("Push #" + (i + 1) + "/" + Math.abs(percentageSteps));
|
||||
aapsLogger.debug(LTag.PUMP, "Push #" + (i + 1) + "/" + Math.abs(percentageSteps));
|
||||
if (increasePercentage) scripter.pressUpKey();
|
||||
else scripter.pressDownKey();
|
||||
SystemClock.sleep(50);
|
||||
|
@ -163,13 +166,13 @@ public class SetTbrCommand extends BaseCommand {
|
|||
while (timeout > System.currentTimeMillis()
|
||||
&& ((increasingPercentage && displayedPercentage < percentage)
|
||||
|| (!increasingPercentage && displayedPercentage > percentage))) {
|
||||
log.debug("Waiting for pump to process scrolling input for percentage, current: "
|
||||
aapsLogger.debug(LTag.PUMP, "Waiting for pump to process scrolling input for percentage, current: "
|
||||
+ displayedPercentage + ", desired: " + percentage + ", scrolling "
|
||||
+ (increasingPercentage ? "up" : "down"));
|
||||
SystemClock.sleep(50);
|
||||
displayedPercentage = readDisplayedPercentage();
|
||||
}
|
||||
log.debug("Final displayed TBR percentage: " + displayedPercentage);
|
||||
aapsLogger.debug(LTag.PUMP, "Final displayed TBR percentage: " + displayedPercentage);
|
||||
if (displayedPercentage != percentage) {
|
||||
throw new CommandException("Failed to set TBR percentage, requested: "
|
||||
+ percentage + ", actual: " + displayedPercentage);
|
||||
|
@ -179,11 +182,11 @@ public class SetTbrCommand extends BaseCommand {
|
|||
// value due to due scrolling taking extremely long
|
||||
SystemClock.sleep(1000);
|
||||
scripter.verifyMenuIsDisplayed(MenuType.TBR_SET);
|
||||
long refreshedDisplayedTbrPecentage = readDisplayedPercentage();
|
||||
if (displayedPercentage != refreshedDisplayedTbrPecentage) {
|
||||
long refreshedDisplayedTbrPercentage = readDisplayedPercentage();
|
||||
if (displayedPercentage != refreshedDisplayedTbrPercentage) {
|
||||
throw new CommandException("Failed to set TBR percentage: " +
|
||||
"percentage changed after input stopped from "
|
||||
+ displayedPercentage + " -> " + refreshedDisplayedTbrPecentage);
|
||||
+ displayedPercentage + " -> " + refreshedDisplayedTbrPercentage);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -191,10 +194,10 @@ public class SetTbrCommand extends BaseCommand {
|
|||
scripter.verifyMenuIsDisplayed(MenuType.TBR_DURATION);
|
||||
long durationSteps = calculateDurationSteps();
|
||||
boolean increaseDuration = durationSteps > 0;
|
||||
log.debug("Pressing " + (increaseDuration ? "up" : "down") + " " + durationSteps + " times");
|
||||
aapsLogger.debug(LTag.PUMP, "Pressing " + (increaseDuration ? "up" : "down") + " " + durationSteps + " times");
|
||||
for (int i = 0; i < Math.abs(durationSteps); i++) {
|
||||
scripter.verifyMenuIsDisplayed(MenuType.TBR_DURATION);
|
||||
log.debug("Push #" + (i + 1) + "/" + Math.abs(durationSteps));
|
||||
aapsLogger.debug(LTag.PUMP, "Push #" + (i + 1) + "/" + Math.abs(durationSteps));
|
||||
if (increaseDuration) scripter.pressUpKey();
|
||||
else scripter.pressDownKey();
|
||||
SystemClock.sleep(50);
|
||||
|
@ -204,7 +207,7 @@ public class SetTbrCommand extends BaseCommand {
|
|||
|
||||
private long calculateDurationSteps() {
|
||||
long currentDuration = readDisplayedDuration();
|
||||
log.debug("Initial TBR duration: " + currentDuration);
|
||||
aapsLogger.debug(LTag.PUMP, "Initial TBR duration: " + currentDuration);
|
||||
|
||||
long difference = duration - currentDuration;
|
||||
long durationSteps = difference / 15;
|
||||
|
@ -224,14 +227,14 @@ public class SetTbrCommand extends BaseCommand {
|
|||
while (timeout > System.currentTimeMillis()
|
||||
&& ((increasingPercentage && displayedDuration < duration)
|
||||
|| (!increasingPercentage && displayedDuration > duration))) {
|
||||
log.debug("Waiting for pump to process scrolling input for duration, current: "
|
||||
aapsLogger.debug(LTag.PUMP, "Waiting for pump to process scrolling input for duration, current: "
|
||||
+ displayedDuration + ", desired: " + duration
|
||||
+ ", scrolling " + (increasingPercentage ? "up" : "down"));
|
||||
SystemClock.sleep(50);
|
||||
displayedDuration = readDisplayedDuration();
|
||||
}
|
||||
|
||||
log.debug("Final displayed TBR duration: " + displayedDuration);
|
||||
aapsLogger.debug(LTag.PUMP, "Final displayed TBR duration: " + displayedDuration);
|
||||
if (displayedDuration != duration) {
|
||||
throw new CommandException("Failed to set TBR duration, requested: "
|
||||
+ duration + ", actual: " + displayedDuration);
|
||||
|
@ -264,7 +267,7 @@ public class SetTbrCommand extends BaseCommand {
|
|||
|
||||
private long readDisplayedDuration() {
|
||||
MenuTime duration = scripter.readBlinkingValue(MenuTime.class, MenuAttribute.RUNTIME);
|
||||
return duration.getHour() * 60 + duration.getMinute();
|
||||
return duration.getHour() * 60L + duration.getMinute();
|
||||
}
|
||||
|
||||
private long readDisplayedPercentage() {
|
||||
|
@ -276,7 +279,7 @@ public class SetTbrCommand extends BaseCommand {
|
|||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
@NonNull @Override
|
||||
public String toString() {
|
||||
return "SetTbrCommand{" +
|
||||
"percentage=" + percentage +
|
||||
|
|
|
@ -28,7 +28,7 @@ class ResourceHelperImplementation @Inject constructor(private val context: Cont
|
|||
} catch (exception: Exception) {
|
||||
val resourceName = context.resources.getResourceEntryName(id)
|
||||
val resourceValue = context.getString(id)
|
||||
val currentLocale: Locale = context.resources.configuration.locale
|
||||
val currentLocale: Locale = context.resources.configuration.locales[0]
|
||||
fabricPrivacy.logMessage("Failed to get string for resource $resourceName ($id) '$resourceValue' for locale $currentLocale with args ${args.map{it.toString()}}")
|
||||
fabricPrivacy.logException(exception)
|
||||
try {
|
||||
|
|
Loading…
Reference in a new issue