diff options
Diffstat (limited to 'core')
-rw-r--r-- | core/qt-ble.cpp | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/core/qt-ble.cpp b/core/qt-ble.cpp index 71ac9bcbf..ff4bc3eda 100644 --- a/core/qt-ble.cpp +++ b/core/qt-ble.cpp @@ -10,6 +10,7 @@ #include <QThread> #include <QTimer> #include <QDebug> +#include <QLoggingCategory> #include <libdivecomputer/version.h> @@ -21,6 +22,8 @@ #include <libdivecomputer/custom_io.h> #define BLE_TIMEOUT 12000 // 12 seconds seems like a very long time to wait +#define DEBUG_THRESHOLD 20 +static int debugCounter; #define IS_HW(_d) same_string((_d)->vendor, "Heinrichs Weikamp") #define IS_SHEARWATER(_d) same_string((_d)->vendor, "Shearwater") @@ -79,7 +82,8 @@ void BLEObject::characteristicWritten(const QLowEnergyCharacteristic &c, const Q isCharacteristicWritten = true; } } else { - qDebug() << "BLEObject::characteristicWritten"; + if (debugCounter < DEBUG_THRESHOLD) + qDebug() << "BLEObject::characteristicWritten"; } } @@ -124,6 +128,7 @@ BLEObject::BLEObject(QLowEnergyController *c, dc_user_device_t *d) { controller = c; device = d; + debugCounter = 0; } BLEObject::~BLEObject() @@ -271,6 +276,9 @@ dc_status_t BLEObject::setupHwTerminalIo(QList<QLowEnergyCharacteristic> allC) dc_status_t qt_ble_open(dc_custom_io_t *io, dc_context_t *context, const char *devaddr) { Q_UNUSED(context) + debugCounter = 0; + QLoggingCategory::setFilterRules(QStringLiteral("qt.bluetooth* = true")); + /* * LE-only devices get the "LE:" prepended by the scanning * code, so that the rfcomm code can see they only do LE. @@ -398,15 +406,24 @@ dc_status_t qt_ble_close(dc_custom_io_t *io) return DC_STATUS_SUCCESS; } +static void checkThreshold() +{ + if (++debugCounter == DEBUG_THRESHOLD) { + QLoggingCategory::setFilterRules(QStringLiteral("qt.bluetooth* = false")); + qDebug() << "turning off further BT debug output"; + } +} dc_status_t qt_ble_read(dc_custom_io_t *io, void* data, size_t size, size_t *actual) { + checkThreshold(); BLEObject *ble = (BLEObject *) io->userdata; return ble->read(data, size, actual); } dc_status_t qt_ble_write(dc_custom_io_t *io, const void* data, size_t size, size_t *actual) { + checkThreshold(); BLEObject *ble = (BLEObject *) io->userdata; return ble->write(data, size, actual); } |