Revert "Retry with current ruffy."

This reverts commit f9281c1f996679a2c8065aa52cbb8cb4698353bc.
This commit is contained in:
Johannes Mockenhaupt 2017-08-27 14:27:48 +02:00
parent 2a80111034
commit 0705755368
No known key found for this signature in database
GPG key ID: 9E1EA6AF7BBBB0D1
4 changed files with 15 additions and 47 deletions

View file

@ -10,17 +10,12 @@ interface IRTHandler {
void fail(String message); void fail(String message);
void requestBluetooth(); void requestBluetooth();
boolean canDisconnect();
void rtStopped(); void rtStopped();
void rtStarted(); void rtStarted();
void rtClearDisplay(); void rtClearDisplay();
void rtUpdateDisplay(in byte[] quarter, int which); void rtUpdateDisplay(in byte[] quarter, int which);
void rtDisplayHandleMenu(in Menu menu, in int sequence); void rtDisplayHandleMenu(in Menu menu);
void rtDisplayHandleNoMenu(in int sequence); void rtDisplayHandleNoMenu();
void keySent(in int sequence);
String getServiceIdentifier();
} }

View file

@ -6,22 +6,18 @@ import org.monkey.d.ruffy.ruffy.driver.IRTHandler;
interface IRuffyService { interface IRuffyService {
void addHandler(IRTHandler handler); void setHandler(IRTHandler handler);
void removeHandler(IRTHandler handler);
/** Connect to the pump /** Connect to the pump
* *
* @return 0 if successful, -1 otherwise * @return 0 if successful, -1 otherwise
*/ */
int doRTConnect(IRTHandler handler); int doRTConnect();
/** Disconnect from the pump */ /** Disconnect from the pump */
void doRTDisconnect(IRTHandler handler); void doRTDisconnect();
/*What's the meaning of 'changed'?
* changed means if a button state has been changed, like btton pressed is a change and button release another*/
void rtSendKey(byte keyCode, boolean changed); void rtSendKey(byte keyCode, boolean changed);
void resetPairing(); void resetPairing();
boolean isConnected(); boolean isConnected();
boolean isBoundToPump();
} }

View file

@ -0,0 +1 @@
//b916a900c0899ef58ad58c7427d1c30d3c8731f4

View file

@ -46,11 +46,9 @@ public class RuffyScripter {
private final Object screenlock = new Object(); private final Object screenlock = new Object();
private final Object keylock = new Object();
private int keynotwait = 0;
public void start(IRuffyService newService) { public void start(IRuffyService newService) {
try { try {
/*
if (ruffyService != null) { if (ruffyService != null) {
try { try {
ruffyService.removeHandler(mHandler); ruffyService.removeHandler(mHandler);
@ -58,6 +56,7 @@ public class RuffyScripter {
// ignore // ignore
} }
} }
*/
if (newService != null) { if (newService != null) {
this.ruffyService = newService; this.ruffyService = newService;
// TODO this'll be done better in v2 via ConnectionManager // TODO this'll be done better in v2 via ConnectionManager
@ -65,7 +64,7 @@ public class RuffyScripter {
idleDisconnectMonitorThread.start(); idleDisconnectMonitorThread.start();
} }
started = true; started = true;
newService.addHandler(mHandler); newService.setHandler(mHandler);
} }
} catch (Exception e) { } catch (Exception e) {
log.error("Unhandled exception starting RuffyScripter", e); log.error("Unhandled exception starting RuffyScripter", e);
@ -78,7 +77,6 @@ public class RuffyScripter {
} }
private volatile boolean connected = false; private volatile boolean connected = false;
private volatile boolean canDisconnect = false;
private volatile long lastDisconnected = 0; private volatile long lastDisconnected = 0;
private Thread idleDisconnectMonitorThread = new Thread(new Runnable() { private Thread idleDisconnectMonitorThread = new Thread(new Runnable() {
@ -94,8 +92,7 @@ public class RuffyScripter {
&& now > lastDisconnected + 15 * 1000) { && now > lastDisconnected + 15 * 1000) {
log.debug("Disconnecting after " + (connectionTimeOutMs / 1000) + "s inactivity timeout"); log.debug("Disconnecting after " + (connectionTimeOutMs / 1000) + "s inactivity timeout");
lastDisconnected = now; lastDisconnected = now;
canDisconnect = true; ruffyService.doRTDisconnect();
ruffyService.doRTDisconnect(mHandler);
connected = false; connected = false;
// don't attempt anything fancy in the next 10s, let the pump settle // don't attempt anything fancy in the next 10s, let the pump settle
SystemClock.sleep(10 * 1000); SystemClock.sleep(10 * 1000);
@ -130,11 +127,6 @@ public class RuffyScripter {
log.trace("Ruffy invoked requestBluetooth callback"); log.trace("Ruffy invoked requestBluetooth callback");
} }
@Override
public boolean canDisconnect() throws RemoteException {
return canDisconnect;
}
@Override @Override
public void rtStopped() throws RemoteException { public void rtStopped() throws RemoteException {
log.debug("rtStopped callback invoked"); log.debug("rtStopped callback invoked");
@ -157,7 +149,7 @@ public class RuffyScripter {
} }
@Override @Override
public void rtDisplayHandleMenu(Menu menu, int sequence) throws RemoteException { public void rtDisplayHandleMenu(Menu menu) throws RemoteException {
// method is called every ~500ms // method is called every ~500ms
log.debug("rtDisplayHandleMenu: " + menu); log.debug("rtDisplayHandleMenu: " + menu);
@ -180,26 +172,9 @@ public class RuffyScripter {
} }
@Override @Override
public void rtDisplayHandleNoMenu(int sequence) throws RemoteException { public void rtDisplayHandleNoMenu() throws RemoteException {
log.debug("rtDisplayHandleNoMenu callback invoked"); log.debug("rtDisplayHandleNoMenu callback invoked");
} }
@Override
public void keySent(int sequence) throws RemoteException {
synchronized (keylock) {
if (keynotwait > 0)
keynotwait--;
else
keylock.notify();
}
}
@Override
public String getServiceIdentifier() throws RemoteException {
return this.toString();
}
}; };
public boolean isPumpBusy() { public boolean isPumpBusy() {
@ -207,12 +182,14 @@ public class RuffyScripter {
} }
public void unbind() { public void unbind() {
/*
if (ruffyService != null) if (ruffyService != null)
try { try {
ruffyService.removeHandler(mHandler); ruffyService.removeHandler(mHandler);
} catch (Exception e) { } catch (Exception e) {
// ignore // ignore
} }
*/
this.ruffyService = null; this.ruffyService = null;
} }
@ -375,8 +352,7 @@ public class RuffyScripter {
SystemClock.sleep(10 * 1000); SystemClock.sleep(10 * 1000);
} }
canDisconnect = false; boolean connectInitSuccessful = ruffyService.doRTConnect() == 0;
boolean connectInitSuccessful = ruffyService.doRTConnect(mHandler) == 0;
log.debug("Connect init successful: " + connectInitSuccessful); log.debug("Connect init successful: " + connectInitSuccessful);
log.debug("Waiting for first menu update to be sent"); log.debug("Waiting for first menu update to be sent");
// Note: there was an 'if(currentMenu == null)' around the next call, since // Note: there was an 'if(currentMenu == null)' around the next call, since