diff --git a/src/webui/api/synccontroller.cpp b/src/webui/api/synccontroller.cpp index 406cde859..f3f27090f 100644 --- a/src/webui/api/synccontroller.cpp +++ b/src/webui/api/synccontroller.cpp @@ -31,8 +31,8 @@ #include #include +#include #include -#include #include "base/bittorrent/peerinfo.h" #include "base/bittorrent/session.h" @@ -335,7 +335,7 @@ SyncController::SyncController(ISessionManager *sessionManager, QObject *parent) connect(m_freeDiskSpaceChecker, &FreeDiskSpaceChecker::checked, this, &SyncController::freeDiskSpaceSizeUpdated); m_freeDiskSpaceThread->start(); - QTimer::singleShot(0, m_freeDiskSpaceChecker, &FreeDiskSpaceChecker::check); + invokeChecker(); m_freeDiskSpaceElapsedTimer.start(); } @@ -521,7 +521,7 @@ void SyncController::torrentPeersAction() qint64 SyncController::getFreeDiskSpace() { if (m_freeDiskSpaceElapsedTimer.hasExpired(FREEDISKSPACE_CHECK_TIMEOUT)) { - QTimer::singleShot(0, m_freeDiskSpaceChecker, &FreeDiskSpaceChecker::check); + invokeChecker(); m_freeDiskSpaceElapsedTimer.restart(); } @@ -532,3 +532,12 @@ void SyncController::freeDiskSpaceSizeUpdated(qint64 freeSpaceSize) { m_freeDiskSpace = freeSpaceSize; } + +void SyncController::invokeChecker() const +{ +#if (QT_VERSION >= QT_VERSION_CHECK(5, 10, 0)) + QMetaObject::invokeMethod(m_freeDiskSpaceChecker, &FreeDiskSpaceChecker::check, Qt::QueuedConnection); +#else + QMetaObject::invokeMethod(m_freeDiskSpaceChecker, "check", Qt::QueuedConnection); +#endif +} diff --git a/src/webui/api/synccontroller.h b/src/webui/api/synccontroller.h index e6c48c669..35422478a 100644 --- a/src/webui/api/synccontroller.h +++ b/src/webui/api/synccontroller.h @@ -56,6 +56,7 @@ private slots: private: qint64 getFreeDiskSpace(); + void invokeChecker() const; qint64 m_freeDiskSpace = 0; FreeDiskSpaceChecker *m_freeDiskSpaceChecker = nullptr;