diff --git a/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/IRTHandler.aidl b/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/IRTHandler.aidl index b6a07226b8..996b10b666 100644 --- a/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/IRTHandler.aidl +++ b/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/IRTHandler.aidl @@ -10,17 +10,12 @@ interface IRTHandler { void fail(String message); void requestBluetooth(); - boolean canDisconnect(); void rtStopped(); void rtStarted(); void rtClearDisplay(); void rtUpdateDisplay(in byte[] quarter, int which); - void rtDisplayHandleMenu(in Menu menu, in int sequence); - void rtDisplayHandleNoMenu(in int sequence); - - void keySent(in int sequence); - - String getServiceIdentifier(); + void rtDisplayHandleMenu(in Menu menu); + void rtDisplayHandleNoMenu(); } diff --git a/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/IRuffyService.aidl b/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/IRuffyService.aidl index f4879445b7..6c988aa038 100644 --- a/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/IRuffyService.aidl +++ b/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/IRuffyService.aidl @@ -6,22 +6,18 @@ import org.monkey.d.ruffy.ruffy.driver.IRTHandler; interface IRuffyService { - void addHandler(IRTHandler handler); - void removeHandler(IRTHandler handler); + void setHandler(IRTHandler handler); /** Connect to the pump * * @return 0 if successful, -1 otherwise */ - int doRTConnect(IRTHandler handler); + int doRTConnect(); /** 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 resetPairing(); boolean isConnected(); - boolean isBoundToPump(); } diff --git a/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/package-info.java b/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/package-info.java new file mode 100644 index 0000000000..ab1def7407 --- /dev/null +++ b/app/src/main/aidl/org/monkey/d/ruffy/ruffy/driver/package-info.java @@ -0,0 +1 @@ +//b916a900c0899ef58ad58c7427d1c30d3c8731f4 \ No newline at end of file diff --git a/app/src/main/java/de/jotomo/ruffyscripter/RuffyScripter.java b/app/src/main/java/de/jotomo/ruffyscripter/RuffyScripter.java index 4bf0f85833..4c7111033d 100644 --- a/app/src/main/java/de/jotomo/ruffyscripter/RuffyScripter.java +++ b/app/src/main/java/de/jotomo/ruffyscripter/RuffyScripter.java @@ -51,6 +51,7 @@ public class RuffyScripter { public void start(IRuffyService newService) { try { +/* if (ruffyService != null) { try { ruffyService.removeHandler(mHandler); @@ -58,6 +59,7 @@ public class RuffyScripter { // ignore } } +*/ if (newService != null) { this.ruffyService = newService; // TODO this'll be done better in v2 via ConnectionManager @@ -65,7 +67,7 @@ public class RuffyScripter { idleDisconnectMonitorThread.start(); } started = true; - newService.addHandler(mHandler); + newService.setHandler(mHandler); } } catch (Exception e) { log.error("Unhandled exception starting RuffyScripter", e); @@ -95,7 +97,7 @@ public class RuffyScripter { log.debug("Disconnecting after " + (connectionTimeOutMs / 1000) + "s inactivity timeout"); lastDisconnected = now; canDisconnect = true; - ruffyService.doRTDisconnect(mHandler); + ruffyService.doRTDisconnect(); connected = false; // don't attempt anything fancy in the next 10s, let the pump settle SystemClock.sleep(10 * 1000); @@ -132,11 +134,6 @@ public class RuffyScripter { log.trace("Ruffy invoked requestBluetooth callback"); } - @Override - public boolean canDisconnect() throws RemoteException { - return canDisconnect; - } - @Override public void rtStopped() throws RemoteException { log.debug("rtStopped callback invoked"); @@ -159,7 +156,7 @@ public class RuffyScripter { } @Override - public void rtDisplayHandleMenu(Menu menu, int sequence) throws RemoteException { + public void rtDisplayHandleMenu(Menu menu) throws RemoteException { // method is called every ~500ms log.debug("rtDisplayHandleMenu: " + menu); @@ -182,26 +179,9 @@ public class RuffyScripter { } @Override - public void rtDisplayHandleNoMenu(int sequence) throws RemoteException { + public void rtDisplayHandleNoMenu() throws RemoteException { 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() { @@ -209,12 +189,14 @@ public class RuffyScripter { } public void unbind() { + /* if (ruffyService != null) try { ruffyService.removeHandler(mHandler); } catch (Exception e) { // ignore } + */ this.ruffyService = null; } @@ -378,7 +360,7 @@ public class RuffyScripter { } canDisconnect = false; - boolean connectInitSuccessful = ruffyService.doRTConnect(mHandler) == 0; + boolean connectInitSuccessful = ruffyService.doRTConnect() == 0; log.debug("Connect init successful: " + connectInitSuccessful); log.debug("Waiting for first menu update to be sent"); // Note: there was an 'if(currentMenu == null)' around the next call, since