summaryrefslogtreecommitdiffstats
path: root/async/src
diff options
context:
space:
mode:
Diffstat (limited to 'async/src')
-rw-r--r--async/src/async.h2
-rw-r--r--async/src/future.cpp20
-rw-r--r--async/src/future.h5
3 files changed, 26 insertions, 1 deletions
diff --git a/async/src/async.h b/async/src/async.h
index 6cb3825..c316639 100644
--- a/async/src/async.h
+++ b/async/src/async.h
@@ -56,7 +56,7 @@
56 * valid until the task is complete. To abort a job it has to be killed through the future handle. 56 * valid until the task is complete. To abort a job it has to be killed through the future handle.
57 * TODO: Can we tie the lifetime of the executor to the last available future handle? 57 * TODO: Can we tie the lifetime of the executor to the last available future handle?
58 * 58 *
59 * TODO: Progress reporting through future 59 * TODO: Composed progress reporting
60 * TODO: Possibility to abort a job through future (perhaps optional?) 60 * TODO: Possibility to abort a job through future (perhaps optional?)
61 * TODO: Support for timeout, specified during exec call, after which the error handler gets called with a defined errorCode. 61 * TODO: Support for timeout, specified during exec call, after which the error handler gets called with a defined errorCode.
62 */ 62 */
diff --git a/async/src/future.cpp b/async/src/future.cpp
index 970060b..4f3cd80 100644
--- a/async/src/future.cpp
+++ b/async/src/future.cpp
@@ -102,6 +102,21 @@ QString FutureBase::errorMessage() const
102 return d->errorMessage; 102 return d->errorMessage;
103} 103}
104 104
105void FutureBase::setProgress(int processed, int total)
106{
107 setProgress((qreal) processed / total);
108}
109
110void FutureBase::setProgress(qreal progress)
111{
112 for (auto watcher : d->watchers) {
113 if (watcher) {
114 watcher->futureProgressCallback(progress);
115 }
116 }
117}
118
119
105 120
106void FutureBase::addWatcher(FutureWatcherBase* watcher) 121void FutureBase::addWatcher(FutureWatcherBase* watcher)
107{ 122{
@@ -128,6 +143,11 @@ void FutureWatcherBase::futureReadyCallback()
128 Q_EMIT futureReady(); 143 Q_EMIT futureReady();
129} 144}
130 145
146void FutureWatcherBase::futureProgressCallback(qreal progress)
147{
148 Q_EMIT futureProgress(progress);
149}
150
131void FutureWatcherBase::setFutureImpl(const FutureBase &future) 151void FutureWatcherBase::setFutureImpl(const FutureBase &future)
132{ 152{
133 d->future = future; 153 d->future = future;
diff --git a/async/src/future.h b/async/src/future.h
index bc18f00..32c1015 100644
--- a/async/src/future.h
+++ b/async/src/future.h
@@ -54,6 +54,9 @@ public:
54 int errorCode() const; 54 int errorCode() const;
55 QString errorMessage() const; 55 QString errorMessage() const;
56 56
57 void setProgress(qreal progress);
58 void setProgress(int processed, int total);
59
57protected: 60protected:
58 class PrivateBase : public QSharedData 61 class PrivateBase : public QSharedData
59 { 62 {
@@ -197,12 +200,14 @@ class FutureWatcherBase : public QObject
197 200
198Q_SIGNALS: 201Q_SIGNALS:
199 void futureReady(); 202 void futureReady();
203 void futureProgress(qreal progress);
200 204
201protected: 205protected:
202 FutureWatcherBase(QObject *parent = nullptr); 206 FutureWatcherBase(QObject *parent = nullptr);
203 virtual ~FutureWatcherBase(); 207 virtual ~FutureWatcherBase();
204 208
205 void futureReadyCallback(); 209 void futureReadyCallback();
210 void futureProgressCallback(qreal progress);
206 211
207 void setFutureImpl(const Async::FutureBase &future); 212 void setFutureImpl(const Async::FutureBase &future);
208 213