summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2017-07-03 17:28:27 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2017-07-03 21:58:26 -0700
commit345e063eb5ff76306e4aafc110351c1bee0e1335 (patch)
treead649caa76be212ea55aad416d69e64d8f572591
parentbc864c3bce9a004f60879d33e61f97511ecbed93 (diff)
downloadsubsurface-345e063eb5ff76306e4aafc110351c1bee0e1335.tar.gz
Rewrite the matching code for BT devices
This should be much more robust in getting us the correct Bluetooth address and the correct vendor / product for our selection. When we pick a paired device, we extract the address right from its name. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--core/btdiscovery.cpp5
-rw-r--r--core/btdiscovery.h1
-rw-r--r--core/downloadfromdcthread.cpp105
3 files changed, 39 insertions, 72 deletions
diff --git a/core/btdiscovery.cpp b/core/btdiscovery.cpp
index 6b0cf266d..a59bb5ccd 100644
--- a/core/btdiscovery.cpp
+++ b/core/btdiscovery.cpp
@@ -175,11 +175,6 @@ QList<BTDiscovery::btVendorProduct> BTDiscovery::getBtDcs()
return btDCs;
}
-QList <BTDiscovery::btVendorProduct> BTDiscovery::getBtAllDevices()
-{
- return btAllDevices;
-}
-
// Android: As Qt is not able to pull the pairing data from a device, i
// a lengthy discovery process is needed to see what devices are paired. On
// https://forum.qt.io/topic/46075/solved-bluetooth-list-paired-devices
diff --git a/core/btdiscovery.h b/core/btdiscovery.h
index 0bf2ca448..1432df260 100644
--- a/core/btdiscovery.h
+++ b/core/btdiscovery.h
@@ -44,7 +44,6 @@ public:
void getBluetoothDevices();
#endif
QList<btVendorProduct> getBtDcs();
- QList<btVendorProduct> getBtAllDevices();
#endif
private:
static BTDiscovery *m_instance;
diff --git a/core/downloadfromdcthread.cpp b/core/downloadfromdcthread.cpp
index ad4f0e4d0..98550ad79 100644
--- a/core/downloadfromdcthread.cpp
+++ b/core/downloadfromdcthread.cpp
@@ -1,6 +1,7 @@
#include "downloadfromdcthread.h"
#include "core/libdivecomputer.h"
#include <QDebug>
+#include <QRegularExpression>
QStringList vendorList;
QHash<QString, QStringList> productList;
@@ -289,7 +290,6 @@ int DCDeviceData::getDetectedVendorIndex(const QString &currentText)
{
#if defined(BT_SUPPORT)
QList<BTDiscovery::btVendorProduct> btDCs = BTDiscovery::instance()->getBtDcs();
- QList<BTDiscovery::btVendorProduct> btAllDevices = BTDiscovery::instance()->getBtAllDevices();
// Pick the vendor of the first confirmed find of a DC (if any), but
// only return a true vendor, and not our virtual one
@@ -297,12 +297,6 @@ int DCDeviceData::getDetectedVendorIndex(const QString &currentText)
qDebug() << "getDetectedVendorIndex" << currentText << btDCs.first().vendorIdx;
return btDCs.first().vendorIdx;
}
-
- // When the above fails, just pick the (one and only) virtual vendor
- if (!btAllDevices.isEmpty() && currentText == QObject::tr("Paired Bluetooth Devices")) {
- qDebug() << "getDetectedVendorIndex" << currentText << btAllDevices.first().vendorIdx;
- return btAllDevices.first().vendorIdx;
- }
#endif
return -1;
}
@@ -334,86 +328,65 @@ QString DCDeviceData::getDetectedDeviceAddress(const QString &currentVendorText,
const QString &currentProductText)
{
#if defined(BT_SUPPORT)
- QList<BTDiscovery::btVendorProduct> btDCs = BTDiscovery::instance()->getBtDcs();
- QList<BTDiscovery::btVendorProduct> btAllDevices = BTDiscovery::instance()->getBtAllDevices();
-
- // Pull the BT address from the first found dive computer that is been
- // detected as a possible real dive computer (and not some other paired
- // BT device
- if (currentVendorText != QObject::tr("Paired Bluetooth Devices") && !btDCs.isEmpty()) {
- QString btAddr = btDCs.first().btpdi.address;
- qDebug() << "getDetectedDeviceAddress" << btAddr;
- return btAddr;
- }
-
- // if the above fails, pull the BT address from the selected paired device
- // unsure being a dive computer
if (currentVendorText == QObject::tr("Paired Bluetooth Devices")) {
- int i = productList[currentVendorText].indexOf(currentProductText);
- QString btAddr = btAllDevices[i].btpdi.address;
- qDebug() << "getDetectedDeviceAddress" << btAddr;
- return btAddr;
+ // simply get the address from the product text
+ QRegularExpression extractAddr(".*\\(([0-9A-FL:]*)\\)");
+ QRegularExpressionMatch m = extractAddr.match(currentProductText);
+ if (m.hasMatch()) {
+ qDebug() << "matched" << m.captured(1);
+ return m.captured(1);
+ }
+ }
+ // Otherwise, pull the vendor from the found devices that are possible real dive computers
+ // HACK: this assumes that dive computer names are unique across vendors
+ // and will only give you the first of multiple identically named dive computers - use
+ // the Paired Bluetooth Devices vendor in cases like that
+ QList<BTDiscovery::btVendorProduct> btDCs = BTDiscovery::instance()->getBtDcs();
+ BTDiscovery::btVendorProduct btDC;
+ Q_FOREACH(btDC, btDCs) {
+ if (currentProductText.startsWith(dc_descriptor_get_product(btDC.dcDescriptor)))
+ return btDC.btpdi.address;
}
#endif
- return QString();
+ return QStringLiteral("cannot determine address of dive computer");
}
QString DCDeviceData::getDeviceDescriptorVendor(const QString &currentVendorText,
const QString &currentProductText)
{
#if defined(BT_SUPPORT)
- QList<BTDiscovery::btVendorProduct> btDCs = BTDiscovery::instance()->getBtDcs();
- QList<BTDiscovery::btVendorProduct> btAllDevices = BTDiscovery::instance()->getBtAllDevices();
+ if (currentVendorText != QObject::tr("Paired Bluetooth Devices"))
+ return currentVendorText;
- // Pull the vendor from the first found dive computer that is been
- // detected as a possible real dive computer (and not some other paired
- // BT device
- if (currentVendorText != QObject::tr("Paired Bluetooth Devices") && !btDCs.isEmpty()) {
- QString dcVendor = dc_descriptor_get_vendor(btDCs.first().dcDescriptor);
- qDebug() << "getDeviceDescriptorVendor" << dcVendor;
- return dcVendor;
- }
+ QList<BTDiscovery::btVendorProduct> btDCs = BTDiscovery::instance()->getBtDcs();
- // if the above fails, pull vendor from the selected paired device
- // unsure being a dive computer
- if (currentVendorText == QObject::tr("Paired Bluetooth Devices")) {
- int i = productList[currentVendorText].indexOf(currentProductText);
- if (i < 0 || btAllDevices.length() <= i)
- return QString();
- QString dcVendor = dc_descriptor_get_vendor(btAllDevices[i].dcDescriptor);
- qDebug() << "getDeviceDescriptorVendor" << dcVendor;
- return dcVendor;
+ // Pull the vendor from the found devices that are possible real dive computers
+ // HACK: this assumes that dive computer names are unique across vendors
+ BTDiscovery::btVendorProduct btDC;
+ Q_FOREACH(btDC, btDCs) {
+ if (currentProductText.startsWith(dc_descriptor_get_product(btDC.dcDescriptor)))
+ return dc_descriptor_get_vendor(btDC.dcDescriptor);
}
#endif
- return NULL;
+ return QStringLiteral("failed to detect vendor");
}
QString DCDeviceData::getDeviceDescriptorProduct(const QString &currentVendorText,
const QString &currentProductText)
{
#if defined(BT_SUPPORT)
- QList<BTDiscovery::btVendorProduct> btDCs = BTDiscovery::instance()->getBtDcs();
- QList<BTDiscovery::btVendorProduct> btAllDevices = BTDiscovery::instance()->getBtAllDevices();
+ if (currentVendorText != QObject::tr("Paired Bluetooth Devices"))
+ return currentProductText;
- // Pull the product from the first found dive computer that is been
- // detected as a possible real dive computer (and not some other paired
- // BT device
- if (currentVendorText != QObject::tr("Paired Bluetooth Devices") && !btDCs.isEmpty()) {
- QString dcProduct = dc_descriptor_get_product(btDCs.first().dcDescriptor);
- qDebug() << "getDeviceDescriptorProduct" << dcProduct;
- return dcProduct;
- }
+ QList<BTDiscovery::btVendorProduct> btDCs = BTDiscovery::instance()->getBtDcs();
- // if the above fails, pull product from the selected paired device
- // unsure being a dive computer
- if (currentVendorText == QObject::tr("Paired Bluetooth Devices")) {
- int i = productList[currentVendorText].indexOf(currentProductText);
- if (i >= btAllDevices.length() || i < 0)
- return QString();
- QString dcProduct = dc_descriptor_get_product(btAllDevices[i].dcDescriptor);
- qDebug() << "getDeviceDescriptorProduct" << dcProduct;
- return dcProduct;
+ // Pull the canonical product from the found devices that are possible real dive computers
+ // HACK: this assumes that dive computer names are unique across vendors
+ BTDiscovery::btVendorProduct btDC;
+ Q_FOREACH(btDC, btDCs) {
+ if (currentProductText.startsWith(dc_descriptor_get_product(btDC.dcDescriptor)))
+ return dc_descriptor_get_product(btDC.dcDescriptor);
}
#endif
- return NULL;
+ return QStringLiteral("failed to detect product");
}