diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2018-09-25 15:20:33 -0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2018-09-25 16:41:13 -0700 |
commit | 0ba105d2a71d65fb272837a753bf54c3e5094f8f (patch) | |
tree | d1bb5c2cd9b2b9318ce5cace49625d0cf4e3d0b1 | |
parent | b19fe27e19e4174930ab1fb8983c532d92fc6d56 (diff) | |
download | subsurface-0ba105d2a71d65fb272837a753bf54c3e5094f8f.tar.gz |
qt-ble: only connect the signals to the preferred service
We used to just find all services and connect the characteristics change
signal etc to them all, but we really only care about the actual
preferred service that we'll be using.
So move the qt ble signal connection to after we've selected the
preferred service that we will actually be enabling notifications on and
do the writes to.
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | core/qt-ble.cpp | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/core/qt-ble.cpp b/core/qt-ble.cpp index 6ddc1a9b8..4fc2cd5df 100644 --- a/core/qt-ble.cpp +++ b/core/qt-ble.cpp @@ -100,10 +100,6 @@ void BLEObject::addService(const QBluetoothUuid &newService) qDebug() << " .. created service object" << service; if (service) { services.append(service); - connect(service, &QLowEnergyService::stateChanged, this, &BLEObject::serviceStateChanged); - connect(service, &QLowEnergyService::characteristicChanged, this, &BLEObject::characteristcStateChanged); - connect(service, &QLowEnergyService::characteristicWritten, this, &BLEObject::characteristicWritten); - connect(service, &QLowEnergyService::descriptorWritten, this, &BLEObject::writeCompleted); service->discoverDetails(); } } @@ -285,6 +281,11 @@ dc_status_t BLEObject::select_preferred_service(void) return DC_STATUS_IO; } + connect(preferred, &QLowEnergyService::stateChanged, this, &BLEObject::serviceStateChanged); + connect(preferred, &QLowEnergyService::characteristicChanged, this, &BLEObject::characteristcStateChanged); + connect(preferred, &QLowEnergyService::characteristicWritten, this, &BLEObject::characteristicWritten); + connect(preferred, &QLowEnergyService::descriptorWritten, this, &BLEObject::writeCompleted); + return DC_STATUS_SUCCESS; } |