source: trunk/src/corelib/concurrent/qfuturewatcher.h@ 98

Last change on this file since 98 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 6.1 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information ([email protected])
5**
6** This file is part of the QtCore module of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at [email protected].
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42#ifndef QFUTUREWATCHER_H
43#define QFUTUREWATCHER_H
44
45#include <QtCore/qfuture.h>
46
47#ifndef QT_NO_QFUTURE
48
49#include <QtCore/qobject.h>
50
51QT_BEGIN_HEADER
52QT_BEGIN_NAMESPACE
53
54QT_MODULE(Core)
55
56class QEvent;
57
58class QFutureWatcherBasePrivate;
59class Q_CORE_EXPORT QFutureWatcherBase : public QObject
60{
61 Q_OBJECT
62 Q_DECLARE_PRIVATE(QFutureWatcherBase)
63
64public:
65 QFutureWatcherBase(QObject *parent = 0);
66
67 int progressValue() const;
68 int progressMinimum() const;
69 int progressMaximum() const;
70 QString progressText() const;
71
72 bool isStarted() const;
73 bool isFinished() const;
74 bool isRunning() const;
75 bool isCanceled() const;
76 bool isPaused() const;
77
78 void waitForFinished();
79
80 void setPendingResultsLimit(int limit);
81
82 bool event(QEvent *event);
83
84Q_SIGNALS:
85 void started();
86 void finished();
87 void canceled();
88 void paused();
89 void resumed();
90 void resultReadyAt(int resultIndex);
91 void resultsReadyAt(int beginIndex, int endIndex);
92 void progressRangeChanged(int minimum, int maximum);
93 void progressValueChanged(int progressValue);
94 void progressTextChanged(const QString &progressText);
95
96public Q_SLOTS:
97 void cancel();
98 void setPaused(bool paused);
99 void pause();
100 void resume();
101 void togglePaused();
102
103protected:
104 void connectNotify (const char * signal);
105 void disconnectNotify (const char * signal);
106
107 // called from setFuture() implemented in template sub-classes
108 void connectOutputInterface();
109 void disconnectOutputInterface(bool pendingAssignment = false);
110
111private:
112 // implemented in the template sub-classes
113 virtual const QFutureInterfaceBase &futureInterface() const = 0;
114 virtual QFutureInterfaceBase &futureInterface() = 0;
115};
116
117template <typename T>
118class QFutureWatcher : public QFutureWatcherBase
119{
120public:
121 QFutureWatcher(QObject *_parent = 0)
122 : QFutureWatcherBase(_parent)
123 { }
124 ~QFutureWatcher()
125 { disconnectOutputInterface(); }
126
127 void setFuture(const QFuture<T> &future);
128 QFuture<T> future() const
129 { return m_future; }
130
131 T result() const { return m_future.result(); }
132 T resultAt(int index) const { return m_future.resultAt(index); }
133
134#ifdef qdoc
135 int progressValue() const;
136 int progressMinimum() const;
137 int progressMaximum() const;
138 QString progressText() const;
139
140 bool isStarted() const;
141 bool isFinished() const;
142 bool isRunning() const;
143 bool isCanceled() const;
144 bool isPaused() const;
145
146 void waitForFinished();
147
148 void setPendingResultsLimit(int limit);
149
150Q_SIGNALS:
151 void started();
152 void finished();
153 void canceled();
154 void paused();
155 void resumed();
156 void resultReadyAt(int resultIndex);
157 void resultsReadyAt(int beginIndex, int endIndex);
158 void progressRangeChanged(int minimum, int maximum);
159 void progressValueChanged(int progressValue);
160 void progressTextChanged(const QString &progressText);
161
162public Q_SLOTS:
163 void cancel();
164 void setPaused(bool paused);
165 void pause();
166 void resume();
167 void togglePaused();
168#endif
169
170private:
171 QFuture<T> m_future;
172 const QFutureInterfaceBase &futureInterface() const { return m_future.d; }
173 QFutureInterfaceBase &futureInterface() { return m_future.d; }
174};
175
176template <typename T>
177Q_INLINE_TEMPLATE void QFutureWatcher<T>::setFuture(const QFuture<T> &_future)
178{
179 if (_future == m_future)
180 return;
181
182 disconnectOutputInterface(true);
183 m_future = _future;
184 connectOutputInterface();
185}
186
187template <>
188class QFutureWatcher<void> : public QFutureWatcherBase
189{
190public:
191 QFutureWatcher(QObject *_parent = 0)
192 : QFutureWatcherBase(_parent)
193 { }
194 ~QFutureWatcher()
195 { disconnectOutputInterface(); }
196
197 void setFuture(const QFuture<void> &future);
198 QFuture<void> future() const
199 { return m_future; }
200
201private:
202 QFuture<void> m_future;
203 const QFutureInterfaceBase &futureInterface() const { return m_future.d; }
204 QFutureInterfaceBase &futureInterface() { return m_future.d; }
205};
206
207Q_INLINE_TEMPLATE void QFutureWatcher<void>::setFuture(const QFuture<void> &_future)
208{
209 if (_future == m_future)
210 return;
211
212 disconnectOutputInterface(true);
213 m_future = _future;
214 connectOutputInterface();
215}
216
217QT_END_NAMESPACE
218QT_END_HEADER
219
220#endif // QT_NO_CONCURRENT
221
222#endif // QFUTUREWATCHER_H
Note: See TracBrowser for help on using the repository browser.