Revert "Retry with current ruffy."
This reverts commit f9281c1f996679a2c8065aa52cbb8cb4698353bc.
This commit is contained in:
parent
2a80111034
commit
0705755368
4 changed files with 15 additions and 47 deletions
|
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
//b916a900c0899ef58ad58c7427d1c30d3c8731f4
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue