aboutsummaryrefslogtreecommitdiffstats
path: root/core/qt-ble.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'core/qt-ble.cpp')
-rw-r--r--core/qt-ble.cpp60
1 files changed, 31 insertions, 29 deletions
diff --git a/core/qt-ble.cpp b/core/qt-ble.cpp
index 7bbe554cc..eae10e6b1 100644
--- a/core/qt-ble.cpp
+++ b/core/qt-ble.cpp
@@ -98,6 +98,24 @@ void BLEObject::addService(const QBluetoothUuid &newService)
{
qDebug() << "Found service" << newService;
+ if (IS_HW(device)) {
+ /* The HW BT/BLE piece or hardware uses, what we
+ * call here, "a Standard UUID. It is standard because the Telit/Stollmann
+ * manufacturer applied for an own UUID for its product, and this was granted
+ * by the Bluetooth SIG.
+ */
+ if (newService != QUuid("{0000fefb-0000-1000-8000-00805f9b34fb}"))
+ return; // skip all services except the right one
+ } else {
+ bool isStandardUuid = false;
+
+ newService.toUInt16(&isStandardUuid);
+ if (isStandardUuid) {
+ qDebug () << " .. ignoring standard service" << newService;
+ return;
+ }
+ }
+
auto service = controller->createServiceObject(newService, this);
qDebug() << " .. created service object" << service;
if (service) {
@@ -248,39 +266,23 @@ dc_status_t BLEObject::select_preferred_service(void)
if (s->state() != QLowEnergyService::ServiceDiscovered)
continue;
- bool isStandardUuid = false;
+ bool hasread = false;
+ bool haswrite = false;
QBluetoothUuid uuid = s->serviceUuid();
- uuid.toUInt16(&isStandardUuid);
-
- if (IS_HW(device)) {
- /* The HW BT/BLE piece or hardware uses, what we
- * call here, "a Standard UUID. It is standard because the Telit/Stollmann
- * manufacturer applied for an own UUID for its product, and this was granted
- * by the Bluetooth SIG.
- */
- if (uuid != QUuid("{0000fefb-0000-1000-8000-00805f9b34fb}"))
- continue; // skip all services except the right one
- } else if (isStandardUuid) {
- qDebug () << " .. ignoring standard service" << uuid;
- continue;
- } else {
- bool hasread = false;
- bool haswrite = false;
+ foreach (const QLowEnergyCharacteristic &c, s->characteristics()) {
+ hasread |= is_read_characteristic(c);
+ haswrite |= is_write_characteristic(c);
+ }
- foreach (const QLowEnergyCharacteristic &c, s->characteristics()) {
- hasread |= is_read_characteristic(c);
- haswrite |= is_write_characteristic(c);
- }
+ if (!hasread) {
+ qDebug () << " .. ignoring service without read characteristic" << uuid;
+ continue;
+ }
- if (!hasread) {
- qDebug () << " .. ignoring service without read characteristic" << uuid;
- continue;
- }
- if (!haswrite) {
- qDebug () << " .. ignoring service without write characteristic" << uuid;
- continue;
- }
+ if (!haswrite) {
+ qDebug () << " .. ignoring service without write characteristic" << uuid;
+ continue;
}
// We now know that the service has both read and write characteristics