diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/corelib/thread/qfutureinterface.cpp | 14 | ||||
-rw-r--r-- | src/corelib/thread/qfutureinterface.h | 2 | ||||
-rw-r--r-- | src/corelib/thread/qfutureinterface_p.h | 5 |
3 files changed, 16 insertions, 5 deletions
diff --git a/src/corelib/thread/qfutureinterface.cpp b/src/corelib/thread/qfutureinterface.cpp index ee3d113196..4f51fd7a0a 100644 --- a/src/corelib/thread/qfutureinterface.cpp +++ b/src/corelib/thread/qfutureinterface.cpp @@ -48,7 +48,6 @@ #include <QtCore/qatomic.h> #include <QtCore/qthread.h> -#include <QtCore/qthreadpool.h> #include <private/qthreadpool_p.h> QT_BEGIN_NAMESPACE @@ -195,7 +194,7 @@ void QFutureInterfaceBase::waitForResume() return; // decrease active thread count since this thread will wait. - const ThreadPoolThreadReleaser releaser(QThreadPool::globalInstance()); + const ThreadPoolThreadReleaser releaser(d->pool()); d->pausedWaitCondition.wait(&d->m_mutex); } @@ -301,7 +300,7 @@ void QFutureInterfaceBase::waitForResult(int resultIndex) // To avoid deadlocks and reduce the number of threads used, try to // run the runnable in the current thread. - QThreadPool::globalInstance()->d_func()->stealRunnable(d->runnable); + d->pool()->d_func()->stealRunnable(d->runnable); lock.relock(); @@ -322,7 +321,7 @@ void QFutureInterfaceBase::waitForFinished() lock.unlock(); if (!alreadyFinished) { - QThreadPool::globalInstance()->d_func()->stealRunnable(d->runnable); + d->pool()->d_func()->stealRunnable(d->runnable); lock.relock(); @@ -364,6 +363,11 @@ void QFutureInterfaceBase::setRunnable(QRunnable *runnable) d->runnable = runnable; } +void QFutureInterfaceBase::setThreadPool(QThreadPool *pool) +{ + d->m_pool = pool; +} + void QFutureInterfaceBase::setFilterMode(bool enable) { QMutexLocker locker(&d->m_mutex); @@ -444,7 +448,7 @@ bool QFutureInterfaceBase::derefT() const QFutureInterfaceBasePrivate::QFutureInterfaceBasePrivate(QFutureInterfaceBase::State initialState) : refCount(1), m_progressValue(0), m_progressMinimum(0), m_progressMaximum(0), state(initialState), - manualProgress(false), m_expectedResultCount(0), runnable(0) + manualProgress(false), m_expectedResultCount(0), runnable(0), m_pool(0) { progressTime.invalidate(); } diff --git a/src/corelib/thread/qfutureinterface.h b/src/corelib/thread/qfutureinterface.h index e0a59697a1..2b2a211a2f 100644 --- a/src/corelib/thread/qfutureinterface.h +++ b/src/corelib/thread/qfutureinterface.h @@ -54,6 +54,7 @@ QT_BEGIN_NAMESPACE template <typename T> class QFuture; +class QThreadPool; class QFutureInterfaceBasePrivate; class QFutureWatcherBase; class QFutureWatcherBasePrivate; @@ -85,6 +86,7 @@ public: void reportResultsReady(int beginIndex, int endIndex); void setRunnable(QRunnable *runnable); + void setThreadPool(QThreadPool *pool); void setFilterMode(bool enable); void setProgressRange(int minimum, int maximum); int progressMinimum() const; diff --git a/src/corelib/thread/qfutureinterface_p.h b/src/corelib/thread/qfutureinterface_p.h index 8b38ebfc66..7d9fc850fa 100644 --- a/src/corelib/thread/qfutureinterface_p.h +++ b/src/corelib/thread/qfutureinterface_p.h @@ -58,6 +58,7 @@ #include <QtCore/qlist.h> #include <QtCore/qwaitcondition.h> #include <QtCore/qrunnable.h> +#include <QtCore/qthreadpool.h> QT_BEGIN_NAMESPACE @@ -169,6 +170,10 @@ public: QtPrivate::ExceptionStore m_exceptionStore; QString m_progressText; QRunnable *runnable; + QThreadPool *m_pool; + + inline QThreadPool *pool() const + { return m_pool ? m_pool : QThreadPool::globalInstance(); } // Internal functions that does not change the mutex state. // The mutex must be locked when calling these. |