## QtConcurrent QtPromise integrates with [QtConcurrent](https://doc.qt.io/qt-5/qtconcurrent-index.html) to make easy chaining QFuture with QPromise. ## Convert Converting `QFuture` to `QPromise` is done using the [`qPromise`](helpers/qpromise.md) helper: ```cpp QFuture future = QtConcurrent::run([]() { // {...} return 42; }); QPromise promise = qPromise(future); ``` or simply: ```cpp auto promise = qPromise(QtConcurrent::run([]() { // {...} })); ``` ## Chain Returning a `QFuture` in [`then`](qpromise/then.md) or [`fail`](qpromise/fail.md) automatically translate to `QPromise`: ```cpp QPromise input = ... auto output = input.then([](int res) { return QtConcurrent::run([]() { // {...} return QString("42"); }); }); // output type: QPromise output.then([](const QString& res) { // {...} }); ``` The `output` promise is resolved when the `QFuture` is [finished](https://doc.qt.io/qt-5/qfuture.html#isFinished). ## Error Exceptions thrown from a QtConcurrent thread reject the associated promise with the exception as the reason. Note that if you throw an exception that is not a subclass of `QException`, the promise with be rejected with [`QUnhandledException`](https://doc.qt.io/qt-5/qunhandledexception.html#details) (this restriction only applies to exceptions thrown from a QtConcurrent thread, [read more](https://doc.qt.io/qt-5/qexception.html#details)). ```cpp QPromise promise = ... promise.then([](int res) { return QtConcurrent::run([]() { // {...} if (!success) { throw CustomException(); } return QString("42"); }); }).fail(const CustomException& err) { // {...} }); ```