Add the connections that we find to the model

So far this only deals with BT addresses. We also need to add other
connections that we detect.

Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
Dirk Hohndel 2017-07-16 21:49:11 -07:00
parent c21845aa01
commit a4f045abaa
3 changed files with 31 additions and 14 deletions

View file

@ -197,7 +197,8 @@ void BTDiscovery::btDeviceDiscoveredMain(const btPairedDevice &device)
qDebug() << "Found new device:" << newDevice << device.address; qDebug() << "Found new device:" << newDevice << device.address;
QString vendor; QString vendor;
if (newDC) foreach (vendor, productList.keys()) { if (newDC)
foreach (vendor, productList.keys()) {
if (productList[vendor].contains(newDevice)) { if (productList[vendor].contains(newDevice)) {
qDebug() << "this could be a " + vendor + " " + qDebug() << "this could be a " + vendor + " " +
(newDevice == "OSTC 3" ? "OSTC family" : newDevice); (newDevice == "OSTC 3" ? "OSTC family" : newDevice);
@ -208,9 +209,11 @@ void BTDiscovery::btDeviceDiscoveredMain(const btPairedDevice &device)
qDebug() << "adding new btDCs entry (detected DC)" << newDevice << btVP.vendorIdx << btVP.productIdx << btVP.btpdi.address;; qDebug() << "adding new btDCs entry (detected DC)" << newDevice << btVP.vendorIdx << btVP.productIdx << btVP.btpdi.address;;
btDCs << btVP; btDCs << btVP;
productList[QObject::tr("Paired Bluetooth Devices")].append(device.name + " (" + device.address + ")"); productList[QObject::tr("Paired Bluetooth Devices")].append(device.name + " (" + device.address + ")");
connectionListModel.addAddress(device.address + " (" + device.name + ")");
return; return;
} }
} }
connectionListModel.addAddress(device.address);
qDebug() << "Not recognized as dive computer"; qDebug() << "Not recognized as dive computer";
} }

View file

@ -7,6 +7,7 @@ QStringList vendorList;
QHash<QString, QStringList> productList; QHash<QString, QStringList> productList;
static QHash<QString, QStringList> mobileProductList; // BT, BLE or FTDI supported DCs for mobile static QHash<QString, QStringList> mobileProductList; // BT, BLE or FTDI supported DCs for mobile
QMap<QString, dc_descriptor_t *> descriptorLookup; QMap<QString, dc_descriptor_t *> descriptorLookup;
ConnectionListModel connectionListModel;
static QString str_error(const char *fmt, ...) static QString str_error(const char *fmt, ...)
{ {
@ -193,6 +194,16 @@ QStringList DCDeviceData::getProductListFromVendor(const QString &vendor)
return productList[vendor]; return productList[vendor];
} }
int DCDeviceData::getMatchingAddress(const QString &vendor, const QString &product)
{
for (int i = 0; i < connectionListModel.rowCount(); i++) {
QString address = connectionListModel.address(i);
if (address.contains(product))
return i;
}
return -1;
}
DCDeviceData * DownloadThread::data() DCDeviceData * DownloadThread::data()
{ {
return m_data; return m_data;

View file

@ -45,6 +45,8 @@ public:
device_data_t* internalData(); device_data_t* internalData();
Q_INVOKABLE QStringList getProductListFromVendor(const QString& vendor); Q_INVOKABLE QStringList getProductListFromVendor(const QString& vendor);
Q_INVOKABLE int getMatchingAddress(const QString &vendor, const QString &product);
Q_INVOKABLE int getDetectedVendorIndex(const QString &currentText); Q_INVOKABLE int getDetectedVendorIndex(const QString &currentText);
Q_INVOKABLE int getDetectedProductIndex(const QString &currentVendorText, Q_INVOKABLE int getDetectedProductIndex(const QString &currentVendorText,
const QString &currentProductText); const QString &currentProductText);
@ -102,5 +104,6 @@ void fill_computer_list();
extern QStringList vendorList; extern QStringList vendorList;
extern QHash<QString, QStringList> productList; extern QHash<QString, QStringList> productList;
extern QMap<QString, dc_descriptor_t *> descriptorLookup; extern QMap<QString, dc_descriptor_t *> descriptorLookup;
extern ConnectionListModel connectionListModel;
#endif #endif