summaryrefslogtreecommitdiffstats
path: root/src/bluetooth/qbluetoothservicediscoveryagent_qnx.cpp
diff options
context:
space:
mode:
authorFabian Bumberger <fbumberger@rim.com>2012-11-23 19:29:10 +0100
committerAlex <ablasche@gmail.com>2012-11-27 04:48:59 +0100
commit36976cb4f5d894beb4689af054e0456b7c7a154f (patch)
tree4d6949d3ea288deccf8ab8268db92cca714bf403 /src/bluetooth/qbluetoothservicediscoveryagent_qnx.cpp
parent159b646d7c2ab63d848e7f82abdefa5f4b777bb8 (diff)
QNX making the device discovery agent more robust
Change-Id: Ibb7da66092e0edca9ac3d7e801275de5d166d6d8 Reviewed-by: Alex <ablasche@gmail.com>
Diffstat (limited to 'src/bluetooth/qbluetoothservicediscoveryagent_qnx.cpp')
-rw-r--r--src/bluetooth/qbluetoothservicediscoveryagent_qnx.cpp18
1 files changed, 14 insertions, 4 deletions
diff --git a/src/bluetooth/qbluetoothservicediscoveryagent_qnx.cpp b/src/bluetooth/qbluetoothservicediscoveryagent_qnx.cpp
index 4eb5da05..816cfddc 100644
--- a/src/bluetooth/qbluetoothservicediscoveryagent_qnx.cpp
+++ b/src/bluetooth/qbluetoothservicediscoveryagent_qnx.cpp
@@ -68,8 +68,13 @@ void QBluetoothServiceDiscoveryAgentPrivate::start(const QBluetoothAddress &addr
{
Q_Q(QBluetoothServiceDiscoveryAgent);
qBBBluetoothDebug() << "Starting Service discovery for" << address.toString();
- if ((m_rdfd = qt_safe_open((QByteArray("/pps/services/bluetooth/remote_devices/%1").append(address.toString().toUtf8().constData())).constData(), O_RDONLY)) == -1) {
- qWarning() << "Failed to open " << "/pps/services/bluetooth/remote_devices/" << address.toString();
+ const char *filePath = QByteArray("/pps/services/bluetooth/remote_devices/").append(address.toString().toUtf8().constData()).constData();
+ if ((m_rdfd = qt_safe_open(filePath, O_RDONLY)) == -1) {
+ qWarning() << "Failed to open " << filePath;
+ error = QBluetoothServiceDiscoveryAgent::DeviceDiscoveryError;
+ errorString = QStringLiteral("Failed to open remote device file");
+ q->error(error);
+ return;
} else {
if (rdNotifier)
delete rdNotifier;
@@ -84,7 +89,6 @@ void QBluetoothServiceDiscoveryAgentPrivate::start(const QBluetoothAddress &addr
return;
}
}
-
ppsRegisterControl();
ppsSendControlMessage("service_query", QStringLiteral("{\"addr\":\"%1\"}").arg(address.toString()));
ppsRegisterForEvent(QStringLiteral("service_query"), this);
@@ -95,7 +99,7 @@ void QBluetoothServiceDiscoveryAgentPrivate::stop()
if (rdNotifier)
delete rdNotifier;
rdNotifier = 0;
- ppsUnregisterControl();
+ ppsUnregisterControl(this);
}
void QBluetoothServiceDiscoveryAgentPrivate::remoteDevicesChanged(int fd)
@@ -141,6 +145,10 @@ void QBluetoothServiceDiscoveryAgentPrivate::remoteDevicesChanged(int fd)
serviceInfo.setServiceUuid(suuid);
}
+ //Check if the UUID is in the uuidFilter
+ if (!uuidFilter.isEmpty() && !uuidFilter.contains(suuid))
+ continue;
+
serviceInfo.setAttribute(QBluetoothServiceInfo::ProtocolDescriptorList, protocolDescriptorList);
QList<QBluetoothUuid> serviceClassId;
@@ -176,6 +184,7 @@ void QBluetoothServiceDiscoveryAgentPrivate::remoteDevicesChanged(int fd)
void QBluetoothServiceDiscoveryAgentPrivate::controlReply(ppsResult result)
{
Q_Q(QBluetoothServiceDiscoveryAgent);
+ qBBBluetoothDebug() << "Control event" << result.msg;
if (!result.errorMsg.isEmpty()) {
qWarning() << Q_FUNC_INFO << result.errorMsg;
errorString = result.errorMsg;
@@ -189,6 +198,7 @@ void QBluetoothServiceDiscoveryAgentPrivate::controlReply(ppsResult result)
void QBluetoothServiceDiscoveryAgentPrivate::controlEvent(ppsResult result)
{
Q_Q(QBluetoothServiceDiscoveryAgent);
+ qBBBluetoothDebug() << "Control event" << result.msg;
if (!result.errorMsg.isEmpty()) {
qWarning() << Q_FUNC_INFO << result.errorMsg;
errorString = result.errorMsg;