Attempt at fixing a (re-) connection issue
Sometimes reconnection lead only to "Connected" state, but not "Initialized". This probably happened when the device got disconnected earlier and then was automatically reconnected. The reconnection closed the previous connection, which caused the dispatch-thread to wake up and think the connection is actually establish. Then, when the first action is invoked, it would fail with an NPE because mBluetoothGatt passed to the action is actually null.
This commit is contained in:
parent
70ae5a2a3a
commit
109146c8c1
|
@ -63,6 +63,7 @@ public final class BtLEQueue {
|
||||||
Transaction transaction = mTransactions.take();
|
Transaction transaction = mTransactions.take();
|
||||||
|
|
||||||
if (!isConnected()) {
|
if (!isConnected()) {
|
||||||
|
LOG.debug("not connected, waiting for connection...");
|
||||||
// TODO: request connection and initialization from the outside and wait until finished
|
// TODO: request connection and initialization from the outside and wait until finished
|
||||||
internalGattCallback.reset();
|
internalGattCallback.reset();
|
||||||
|
|
||||||
|
@ -168,15 +169,17 @@ public final class BtLEQueue {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setDeviceConnectionState(State newState) {
|
private void setDeviceConnectionState(State newState) {
|
||||||
|
LOG.debug("new device connection state: " + newState);
|
||||||
mGbDevice.setState(newState);
|
mGbDevice.setState(newState);
|
||||||
mGbDevice.sendDeviceUpdateIntent(mContext);
|
mGbDevice.sendDeviceUpdateIntent(mContext);
|
||||||
if (mConnectionLatch != null) {
|
if (mConnectionLatch != null && newState == State.CONNECTED) {
|
||||||
mConnectionLatch.countDown();
|
mConnectionLatch.countDown();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void disconnect() {
|
public void disconnect() {
|
||||||
synchronized (mGattMonitor) {
|
synchronized (mGattMonitor) {
|
||||||
|
LOG.debug("disconnect()");
|
||||||
BluetoothGatt gatt = mBluetoothGatt;
|
BluetoothGatt gatt = mBluetoothGatt;
|
||||||
if (gatt != null) {
|
if (gatt != null) {
|
||||||
mBluetoothGatt = null;
|
mBluetoothGatt = null;
|
||||||
|
@ -189,6 +192,7 @@ public final class BtLEQueue {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleDisconnected(int status) {
|
private void handleDisconnected(int status) {
|
||||||
|
LOG.debug("handleDisconnected: " + status);
|
||||||
internalGattCallback.reset();
|
internalGattCallback.reset();
|
||||||
mTransactions.clear();
|
mTransactions.clear();
|
||||||
mAbortTransaction = true;
|
mAbortTransaction = true;
|
||||||
|
|
Loading…
Reference in New Issue