summaryrefslogtreecommitdiff
path: root/same-android/src/main/java/com/orbekk/same/android/ClientInterfaceBridge.java
diff options
context:
space:
mode:
Diffstat (limited to 'same-android/src/main/java/com/orbekk/same/android/ClientInterfaceBridge.java')
-rw-r--r--same-android/src/main/java/com/orbekk/same/android/ClientInterfaceBridge.java9
1 files changed, 5 insertions, 4 deletions
diff --git a/same-android/src/main/java/com/orbekk/same/android/ClientInterfaceBridge.java b/same-android/src/main/java/com/orbekk/same/android/ClientInterfaceBridge.java
index 8ed38a7..72dfdb7 100644
--- a/same-android/src/main/java/com/orbekk/same/android/ClientInterfaceBridge.java
+++ b/same-android/src/main/java/com/orbekk/same/android/ClientInterfaceBridge.java
@@ -36,7 +36,7 @@ public class ClientInterfaceBridge implements ClientInterface {
private int nextOperationNumber = 0;
class ResponseHandler extends Handler {
- @Override public void handleMessage(Message message) {
+ @Override public synchronized void handleMessage(Message message) {
if (serviceMessenger == null) {
logger.warn("Ignoring message to disabled ResponseHandler.");
return;
@@ -119,7 +119,7 @@ public class ClientInterfaceBridge implements ClientInterface {
this.context = context;
}
- public void connect() {
+ public synchronized void connect() {
state = new State(".Temporary");
Intent intent = new Intent(context, SameService.class);
context.bindService(intent, serviceConnection, Context.BIND_AUTO_CREATE);
@@ -135,11 +135,12 @@ public class ClientInterfaceBridge implements ClientInterface {
}
}
- public void disconnect() {
+ public synchronized void disconnect() {
if (serviceMessenger != null) {
disconnectFromService();
+ }
+ if (serviceConnection != null) {
context.unbindService(serviceConnection);
- state = null;
}
}