mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge.git
synced 2025-01-15 03:21:13 +01:00
50295864f5
The issue here is the following: - we used intents in the generic BleProfile classes to notify about the results of e.g. certain read requests - we used to send these results asynchronously via LocalBroadcastManager.sendBroadcast(), which always used the main thread for sending - however, we noticed that reconnecting to devices sometimes failed because the results arrived too late and the next action in the BLE queue lacked the necessary information - the fix was to use LocalBroadcastManager.setBroadcastSync(), so that the results arrive in time - this unfortunately meant that they were not sent in the main thread anymore, and especially, this would send all pending intents that were previously queued via sendBroadcast() also in the "wrong" thread (in order to keep the order of events) The fix is to use a custom IntentListener callback interface for synchronous notifications of ble profile results *without* also causing other, previously queued intents to be sent. Fixes #1218 |
||
---|---|---|
.. | ||
actions | ||
profiles | ||
AbstractBTLEDeviceSupport.java | ||
AbstractBTLEOperation.java | ||
AbstractGattCallback.java | ||
BleNamesResolver.java | ||
BLETypeConversions.java | ||
BtLEAction.java | ||
BTLEOperation.java | ||
BtLEQueue.java | ||
GattCallback.java | ||
GattCharacteristic.java | ||
GattDescriptor.java | ||
GattService.java | ||
Transaction.java | ||
TransactionBuilder.java |