mirror of
https://github.com/subsurface/subsurface.git
synced 2025-01-31 20:43:24 +00:00
core/bt: ensure that BT/BLE addresses with name sort first
We don't order the list of addresses alphabetically, but we want to ensure that devices that offer us a name are listed before those that don't. This should only be relevant if the user selects the option to show all BT/BLE devices, not just recognized dive computer, because if we recognize a computer we always have the product name prepended to the address. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
a1a51e5d89
commit
34ebaf6599
1 changed files with 15 additions and 2 deletions
|
@ -1,6 +1,9 @@
|
|||
// SPDX-License-Identifier: GPL-2.0
|
||||
|
||||
#include "core/connectionlistmodel.h"
|
||||
#if defined(BT_SUPPORT)
|
||||
#include "core/btdiscovery.h"
|
||||
#endif
|
||||
|
||||
ConnectionListModel::ConnectionListModel(QObject *parent) :
|
||||
QAbstractListModel(parent)
|
||||
|
@ -31,8 +34,18 @@ int ConnectionListModel::rowCount(const QModelIndex&) const
|
|||
void ConnectionListModel::addAddress(const QString &address)
|
||||
{
|
||||
if (!m_addresses.contains(address)) {
|
||||
beginInsertRows(QModelIndex(), rowCount(), rowCount());
|
||||
m_addresses.append(address);
|
||||
int idx = rowCount();
|
||||
#if defined(BT_SUPPORT)
|
||||
// make sure that addresses that are just a BT/BLE address without name stay at the end of the list
|
||||
if (address != extractBluetoothAddress(address)) {
|
||||
for (idx = 0; idx < rowCount(); idx++)
|
||||
if (m_addresses[idx] == extractBluetoothAddress(m_addresses[idx]))
|
||||
// found the first name-less BT/BLE address, insert before that
|
||||
break;
|
||||
}
|
||||
#endif
|
||||
beginInsertRows(QModelIndex(), idx, idx);
|
||||
m_addresses.insert(idx, address);
|
||||
endInsertRows();
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue