RuffyScripter: consider pump connected when BT connection is there AND menu updates are being received.
This commit is contained in:
parent
de06c54f1d
commit
865fc63bd4
1 changed files with 26 additions and 34 deletions
|
@ -59,7 +59,6 @@ public class RuffyScripter implements RuffyCommands {
|
||||||
private volatile Menu currentMenu;
|
private volatile Menu currentMenu;
|
||||||
private volatile long menuLastUpdated = 0;
|
private volatile long menuLastUpdated = 0;
|
||||||
|
|
||||||
private volatile long lastCmdExecutionTime;
|
|
||||||
private volatile Command activeCmd = null;
|
private volatile Command activeCmd = null;
|
||||||
|
|
||||||
private boolean started = false;
|
private boolean started = false;
|
||||||
|
@ -69,7 +68,9 @@ public class RuffyScripter implements RuffyCommands {
|
||||||
private IRTHandler mHandler = new IRTHandler.Stub() {
|
private IRTHandler mHandler = new IRTHandler.Stub() {
|
||||||
@Override
|
@Override
|
||||||
public void log(String message) throws RemoteException {
|
public void log(String message) throws RemoteException {
|
||||||
// log.debug("Ruffy says: " + message);
|
if (log.isTraceEnabled()) {
|
||||||
|
log.debug("Ruffy says: " + message);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -180,14 +181,21 @@ public class RuffyScripter implements RuffyCommands {
|
||||||
@Override
|
@Override
|
||||||
public boolean isConnected() {
|
public boolean isConnected() {
|
||||||
try {
|
try {
|
||||||
return ruffyService.isConnected();
|
return ruffyService.isConnected() && System.currentTimeMillis() - menuLastUpdated < 5000;
|
||||||
} catch (RemoteException e) {
|
} catch (RemoteException e) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void disconnect() {
|
public synchronized void disconnect() {
|
||||||
|
// TODO Clean up... is this still needed? Or caused by ruffyService.isConnected bug?
|
||||||
|
// queue is a bit overeager to close the connection, so a small gap of 100ms or so
|
||||||
|
// would cost a full reconnect of 10-20s
|
||||||
|
// SystemClock.sleep(1000);
|
||||||
|
// if (!isConnected()) {
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
try {
|
try {
|
||||||
ruffyService.doRTDisconnect();
|
ruffyService.doRTDisconnect();
|
||||||
} catch (RemoteException e) {
|
} catch (RemoteException e) {
|
||||||
|
@ -257,8 +265,6 @@ public class RuffyScripter implements RuffyCommands {
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.error("Unexpected exception running cmd", e);
|
log.error("Unexpected exception running cmd", e);
|
||||||
activeCmd.getResult().success = false;
|
activeCmd.getResult().success = false;
|
||||||
} finally {
|
|
||||||
lastCmdExecutionTime = System.currentTimeMillis();
|
|
||||||
}
|
}
|
||||||
}, cmd.getClass().getSimpleName());
|
}, cmd.getClass().getSimpleName());
|
||||||
long executionStart = System.currentTimeMillis();
|
long executionStart = System.currentTimeMillis();
|
||||||
|
@ -266,7 +272,7 @@ public class RuffyScripter implements RuffyCommands {
|
||||||
|
|
||||||
long overallTimeout = System.currentTimeMillis() + 10 * 60 * 1000;
|
long overallTimeout = System.currentTimeMillis() + 10 * 60 * 1000;
|
||||||
while (cmdThread.isAlive()) {
|
while (cmdThread.isAlive()) {
|
||||||
if (!ruffyService.isConnected()) {
|
if (!isConnected()) {
|
||||||
// on connection loss try to reconnect, confirm warning alerts caused by
|
// on connection loss try to reconnect, confirm warning alerts caused by
|
||||||
// the disconnected and then return the command as failed (the caller
|
// the disconnected and then return the command as failed (the caller
|
||||||
// can retry if needed).
|
// can retry if needed).
|
||||||
|
@ -283,14 +289,6 @@ public class RuffyScripter implements RuffyCommands {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// abort if there has been no transmission from the pump for 15s
|
|
||||||
if (!(System.currentTimeMillis() < menuLastUpdated + 15 * 1000)) {
|
|
||||||
log.error("Dynamic timeout running command " + activeCmd);
|
|
||||||
cmdThread.interrupt();
|
|
||||||
activeCmd.getResult().success = false;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (System.currentTimeMillis() > overallTimeout) {
|
if (System.currentTimeMillis() > overallTimeout) {
|
||||||
log.error("Command " + cmd + " timed out");
|
log.error("Command " + cmd + " timed out");
|
||||||
cmdThread.interrupt();
|
cmdThread.interrupt();
|
||||||
|
@ -370,7 +368,7 @@ public class RuffyScripter implements RuffyCommands {
|
||||||
// if everything broke before, the pump might still be delivering a bolus, if that's the case, wait for bolus to finish
|
// if everything broke before, the pump might still be delivering a bolus, if that's the case, wait for bolus to finish
|
||||||
Double bolusRemaining = (Double) getCurrentMenu().getAttribute(MenuAttribute.BOLUS_REMAINING);
|
Double bolusRemaining = (Double) getCurrentMenu().getAttribute(MenuAttribute.BOLUS_REMAINING);
|
||||||
try {
|
try {
|
||||||
while (ruffyService.isConnected() && bolusRemaining != null) {
|
while (isConnected() && bolusRemaining != null) {
|
||||||
log.debug("Waiting for bolus from previous connection to complete, remaining: " + bolusRemaining);
|
log.debug("Waiting for bolus from previous connection to complete, remaining: " + bolusRemaining);
|
||||||
waitForScreenUpdate();
|
waitForScreenUpdate();
|
||||||
}
|
}
|
||||||
|
@ -409,23 +407,18 @@ public class RuffyScripter implements RuffyCommands {
|
||||||
// If that happened, wait till the pump has finished the bolus, then it can be read from
|
// If that happened, wait till the pump has finished the bolus, then it can be read from
|
||||||
// the history as delivered.
|
// the history as delivered.
|
||||||
Double bolusRemaining = (Double) getCurrentMenu().getAttribute(MenuAttribute.BOLUS_REMAINING);
|
Double bolusRemaining = (Double) getCurrentMenu().getAttribute(MenuAttribute.BOLUS_REMAINING);
|
||||||
try {
|
while (isConnected() && bolusRemaining != null) {
|
||||||
while (ruffyService.isConnected() && bolusRemaining != null) {
|
waitForScreenUpdate();
|
||||||
waitForScreenUpdate();
|
|
||||||
}
|
|
||||||
boolean connected = ruffyService.isConnected();
|
|
||||||
if (connected) {
|
|
||||||
MenuType menuType = getCurrentMenu().getType();
|
|
||||||
if (menuType != MenuType.MAIN_MENU && menuType != MenuType.WARNING_OR_ERROR) {
|
|
||||||
returnToRootMenu();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
log.debug("Recovery from connection loss " + (connected ? "succeeded" : "failed"));
|
|
||||||
return connected;
|
|
||||||
} catch (RemoteException e) {
|
|
||||||
log.debug("Recovery from connection loss failed", e);
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
boolean connected = isConnected();
|
||||||
|
if (connected) {
|
||||||
|
MenuType menuType = getCurrentMenu().getType();
|
||||||
|
if (menuType != MenuType.MAIN_MENU && menuType != MenuType.WARNING_OR_ERROR) {
|
||||||
|
returnToRootMenu();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
log.debug("Recovery from connection loss " + (connected ? "succeeded" : "failed"));
|
||||||
|
return connected;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -453,8 +446,7 @@ public class RuffyScripter implements RuffyCommands {
|
||||||
*/
|
*/
|
||||||
private void ensureConnected() {
|
private void ensureConnected() {
|
||||||
try {
|
try {
|
||||||
if (ruffyService.isConnected()) {
|
if (isConnected()) {
|
||||||
log.debug("Already connected");
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue