summaryrefslogtreecommitdiffstats
path: root/src/corelib/concurrent/qfutureinterface_p.h
diff options
context:
space:
mode:
authorThiago Macieira <thiago.macieira@intel.com>2012-11-18 23:54:41 +0100
committerThe Qt Project <gerrit-noreply@qt-project.org>2012-11-20 00:27:56 +0100
commit8ef339ed2fed66646f458c60b2e0e7ac560dad06 (patch)
tree38db8c86f4c27e68d8855820da49b0da9cac44b9 /src/corelib/concurrent/qfutureinterface_p.h
parent94be95934fb3f0ab339fd169ef529f05f1a6707d (diff)
Revert "QtConcurrent: Fix for leak in QFuture"
This reverts commit 28b06b3ebae3d411c74f09fa7de52bc290c47dc3 That commit contains new symbols added in a patch release of Qt. That is not permitted. Change-Id: I1d36b50d4c26aa32072fd3f9c311a0e773527abd Reviewed-by: Christian Stromme <christian.stromme@digia.com> Reviewed-by: Lars Knoll <lars.knoll@digia.com>
Diffstat (limited to 'src/corelib/concurrent/qfutureinterface_p.h')
-rw-r--r--src/corelib/concurrent/qfutureinterface_p.h26
1 files changed, 1 insertions, 25 deletions
diff --git a/src/corelib/concurrent/qfutureinterface_p.h b/src/corelib/concurrent/qfutureinterface_p.h
index 8431b1ad37..407c926137 100644
--- a/src/corelib/concurrent/qfutureinterface_p.h
+++ b/src/corelib/concurrent/qfutureinterface_p.h
@@ -129,31 +129,7 @@ class QFutureInterfaceBasePrivate
public:
QFutureInterfaceBasePrivate(QFutureInterfaceBase::State initialState);
- // When the last QFuture<T> reference is removed, we need to make
- // sure that data stored in the ResultStore is cleaned out.
- // Since QFutureInterfaceBasePrivate can be shared between QFuture<T>
- // and QFuture<void> objects, we use a separate ref. counter
- // to keep track of QFuture<T> objects.
- class RefCount
- {
- public:
- inline RefCount(int r = 0, int rt = 0)
- : m_refCount(r), m_refCountT(rt) {}
- // Default ref counter for QFIBP
- inline bool ref() { return m_refCount.ref(); }
- inline bool deref() { return m_refCount.deref(); }
- // Ref counter for type T
- inline bool refT() { return m_refCountT.ref(); }
- inline bool derefT() { return m_refCountT.deref(); }
- inline operator int() const { return int(m_refCount); }
- inline bool operator==(int value) const { return m_refCount == value; }
-
- private:
- QAtomicInt m_refCount;
- QAtomicInt m_refCountT;
- };
-
- RefCount refCount;
+ QAtomicInt refCount;
mutable QMutex m_mutex;
QWaitCondition waitCondition;
QList<QFutureCallOutInterface *> outputConnections;