summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/qt-ble.cpp43
1 files changed, 23 insertions, 20 deletions
diff --git a/core/qt-ble.cpp b/core/qt-ble.cpp
index 730d7148e..7556b01f8 100644
--- a/core/qt-ble.cpp
+++ b/core/qt-ble.cpp
@@ -29,17 +29,26 @@ static int debugCounter;
#define MAXIMAL_HW_CREDIT 255
#define MINIMAL_HW_CREDIT 32
-static void waitFor(int ms) {
- Q_ASSERT(QCoreApplication::instance());
- Q_ASSERT(QThread::currentThread());
-
- QElapsedTimer timer;
- timer.start();
-
- do {
- QCoreApplication::processEvents(QEventLoop::AllEvents, ms);
- QThread::msleep(10);
- } while (timer.elapsed() < ms);
+#define WAITFOR(expression, ms) do { \
+ Q_ASSERT(QCoreApplication::instance()); \
+ Q_ASSERT(QThread::currentThread()); \
+ \
+ if (expression) \
+ break; \
+ QElapsedTimer timer; \
+ timer.start(); \
+ \
+ do { \
+ QCoreApplication::processEvents(QEventLoop::AllEvents, ms); \
+ if (expression) \
+ break; \
+ QThread::msleep(10); \
+ } while (timer.elapsed() < (ms)); \
+} while (0)
+
+static void waitFor(int ms)
+{
+ WAITFOR(false, ms);
}
extern "C" {
@@ -176,17 +185,11 @@ dc_status_t BLEObject::read(void *data, size_t size, size_t *actual)
if (list.isEmpty())
return DC_STATUS_IO;
- int msec = BLE_TIMEOUT;
- while (msec > 0 && receivedPackets.isEmpty()) {
- waitFor(100);
- msec -= 100;
- }
+ WAITFOR(!receivedPackets.isEmpty(), BLE_TIMEOUT);
+ if (receivedPackets.isEmpty())
+ return DC_STATUS_IO;
}
- // Still no packet?
- if (receivedPackets.isEmpty())
- return DC_STATUS_IO;
-
QByteArray packet = receivedPackets.takeFirst();
if ((size_t)packet.size() > size)