diff options
author | Joey Grover <joeygrover@gmail.com> | 2019-05-02 11:38:11 -0400 |
---|---|---|
committer | Joey Grover <joeygrover@gmail.com> | 2019-05-02 11:38:11 -0400 |
commit | 349bca1ecd3fa6a39f0c2f3ee8248c2cd759ae3f (patch) | |
tree | 0fce2d02886313536398d24a820a1fe8de525ef9 | |
parent | 209c17ebb40a0b552fcc40b084e2f5422f52bf6a (diff) | |
download | sdl_android-349bca1ecd3fa6a39f0c2f3ee8248c2cd759ae3f.tar.gz |
Fix #1051
-rw-r--r-- | android/sdl_android/src/main/java/com/smartdevicelink/transport/TransportManager.java | 67 |
1 files changed, 60 insertions, 7 deletions
diff --git a/android/sdl_android/src/main/java/com/smartdevicelink/transport/TransportManager.java b/android/sdl_android/src/main/java/com/smartdevicelink/transport/TransportManager.java index ad4b41b84..a2e7cf5cd 100644 --- a/android/sdl_android/src/main/java/com/smartdevicelink/transport/TransportManager.java +++ b/android/sdl_android/src/main/java/com/smartdevicelink/transport/TransportManager.java @@ -49,6 +49,7 @@ import com.smartdevicelink.protocol.SdlPacket; import com.smartdevicelink.protocol.enums.ControlFrameTags; import com.smartdevicelink.transport.enums.TransportType; import com.smartdevicelink.transport.utl.TransportRecord; +import com.smartdevicelink.util.DebugTool; import java.lang.ref.WeakReference; import java.util.List; @@ -262,6 +263,7 @@ public class TransportManager extends TransportManagerBase{ protected class TransportBrokerImpl extends TransportBroker{ + boolean shuttingDown = false; public TransportBrokerImpl(Context context, String appId, ComponentName routerService){ super(context,appId,routerService); } @@ -274,8 +276,12 @@ public class TransportManager extends TransportManagerBase{ } @Override - public boolean onHardwareConnected(List<TransportRecord> transports) { + public synchronized boolean onHardwareConnected(List<TransportRecord> transports) { super.onHardwareConnected(transports); + DebugTool.logInfo("OnHardwareConnected"); + if(shuttingDown){ + return false; + } synchronized (TRANSPORT_STATUS_LOCK){ transportStatus.clear(); transportStatus.addAll(transports); @@ -286,14 +292,16 @@ public class TransportManager extends TransportManagerBase{ @Override - public void onHardwareDisconnected(TransportRecord record, List<TransportRecord> connectedTransports) { + public synchronized void onHardwareDisconnected(TransportRecord record, List<TransportRecord> connectedTransports) { if(record != null){ Log.d(TAG, "Transport disconnected - " + record); }else{ Log.d(TAG, "Transport disconnected"); } - + if(shuttingDown){ + return; + } synchronized (TRANSPORT_STATUS_LOCK){ boolean wasRemoved = TransportManager.this.transportStatus.remove(record); //Might check connectedTransports vs transportStatus to ensure they are equal @@ -328,10 +336,12 @@ public class TransportManager extends TransportManagerBase{ if(isLegacyModeEnabled() && record != null - && TransportType.BLUETOOTH.equals(record.getType()) //Make sure it's bluetooth that has be d/c - && legacyBluetoothTransport == null){ //Make sure we aren't already in legacy mode - //Legacy mode has been enabled so we need to cycle - enterLegacyMode("Router service has enabled legacy mode"); + && TransportType.BLUETOOTH.equals(record.getType())){ //Make sure it's bluetooth that has be d/c + //&& legacyBluetoothTransport == null){ //Make sure we aren't already in legacy mode + if(legacyBluetoothTransport == null) { + //Legacy mode has been enabled so we need to cycle + enterLegacyModeAndStart("Router service has enabled legacy mode"); + } }else{ //Inform the transport listener that a transport has disconnected transportListener.onTransportDisconnected("", record, connectedTransports); @@ -339,13 +349,52 @@ public class TransportManager extends TransportManagerBase{ } @Override + public synchronized void onLegacyModeEnabled() { + if(shuttingDown){ + return; + } + if( legacyBluetoothTransport == null){ + //First remove the connected bluetooth transport if one exists + TransportRecord toBeRemoved = null; + for (TransportRecord transportRecord : TransportManager.this.transportStatus) { + if (TransportType.BLUETOOTH.equals(transportRecord.getType())) { + //There was a previously connected bluetooth transport through the router service + toBeRemoved = transportRecord; + break; + } + } + + if(toBeRemoved != null){ //Remove item after the loop to avoid concurrent modifications + TransportManager.this.transportStatus.remove(toBeRemoved); + } + + enterLegacyModeAndStart("Router service has enabled legacy mode"); + } + } + + @Override public void onPacketReceived(Parcelable packet) { if(packet!=null){ transportListener.onPacketReceived((SdlPacket)packet); } } + + @Override + public synchronized void stop() { + shuttingDown = true; + super.stop(); + } } + void enterLegacyModeAndStart(final String info){ + enterLegacyMode(info); + if(legacyBluetoothTransport != null + && legacyBluetoothTransport.getState() == MultiplexBaseTransport.STATE_NONE){ + legacyBluetoothTransport.start(); + } + } + + @Override synchronized void enterLegacyMode(final String info){ if(legacyBluetoothTransport != null && legacyBluetoothHandler != null){ @@ -434,6 +483,10 @@ public class TransportManager extends TransportManagerBase{ // Currently attempting to connect - update UI? break; case MultiplexBaseTransport.STATE_LISTEN: + if(service.transport != null){ + service.transport.stop(); + service.transport = null; + } break; case MultiplexBaseTransport.STATE_NONE: // We've just lost the connection |