mirror of
https://github.com/QuasarApp/Heart.git
synced 2025-05-05 05:59:40 +00:00
155 lines
5.6 KiB
C++
155 lines
5.6 KiB
C++
/*
|
|
* Copyright (C) 2018-2025 QuasarApp.
|
|
* Distributed under the lgplv3 software license, see the accompanying
|
|
* Everyone is permitted to copy and distribute verbatim copies
|
|
* of this license document, but changing it is not allowed.
|
|
*/
|
|
|
|
#ifndef ASYNC_H
|
|
#define ASYNC_H
|
|
#include <QObject>
|
|
#include <functional>
|
|
#include "config.h"
|
|
#include "heart_global.h"
|
|
|
|
namespace QH {
|
|
|
|
/**
|
|
* @brief The Async class This is bundle of async templates and async wrappers.
|
|
* @note If you use this object then you do not need include QObject because this class include the QObject class.
|
|
* Do not forget the Q_OBJECT macross.
|
|
*
|
|
* @note All objects of this class must be initialized with the .
|
|
* So The constructor is private and the AsynFactyry class is a friend class of the Async class.
|
|
*/
|
|
class HEARTSHARED_EXPORT Async: public QObject {
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/**
|
|
* The Job is wrapper of the std::function<bool()> type. This type registered like the Qt meta type
|
|
* For using in the qt metasystem.
|
|
*/
|
|
using Job = std::function<bool()>;
|
|
|
|
/**
|
|
* @brief asyncLauncher This method invoke a job on the thread (using the asyncHandler method) of this object.
|
|
* @param job This is function with needed job.
|
|
* @param await This is boolean option for enable or disable wait for finish of the job function.
|
|
* @param freaze This option disaable process event of waiting of results.
|
|
* @return true if the job function started correctly. If the await option is true then
|
|
* this method return result of job function.
|
|
*/
|
|
bool asyncLauncher(const Job &job, bool await = false, bool freaze = true) const;
|
|
|
|
protected:
|
|
/**
|
|
* @brief Async This is default constructor of the async object.
|
|
* @param thread This is work thread of the async object.
|
|
* @param ptr This is pointer to qtparent of this object.
|
|
* @note @a thread must be different of the main thread.
|
|
*/
|
|
Async(QThread* thread, QObject* ptr = nullptr);
|
|
|
|
/**
|
|
@note This is async distructor.
|
|
This distructor wait for finishing of the own threads befor delete.
|
|
*/
|
|
~Async();
|
|
|
|
/**
|
|
* @brief waitFor This is base wait function.
|
|
* @param condition This is pointer to awaiting boolean variable.
|
|
* @param timeout This is maximum time for wait. By default this value equals WAIT_TIME it is 30000 msec.
|
|
* @param freaze This frease current thread for waiting results of another thread. If you set this option to false then will be invoked process event method.
|
|
* @return true if condition is true.
|
|
*/
|
|
bool waitFor(bool* condition, int timeout = WAIT_TIME, bool freaze = true) const;
|
|
|
|
/**
|
|
* @brief waitFor This is base wait function.
|
|
* @param condition This is lambda method with condition results.
|
|
* @param timeout This is maximum time for wait. By default this value equals WAIT_TIME it is 30000 msec.
|
|
* @param freaze This frease current thread for waiting results of another thread. If you set this option to false then will be invoked process event method.
|
|
* @return true if condition is true.
|
|
*/
|
|
bool waitFor(const Job &condition, int timeout = WAIT_TIME, bool freaze = true) const;
|
|
|
|
private slots:
|
|
|
|
/**
|
|
* @brief asyncHandler async This is base async launcher method for move jobs to new thread.
|
|
* @param job This is job to do.
|
|
* @param resultOfWork This is pointer of bool value of a result of the job method.
|
|
* @note If you want to disable check results, just use nullptr value.
|
|
* @param endOfWork This is pointer to bool value. If value of this method changed to true then the job method has ben finished.
|
|
* For check result of the job function use the resultOfWork option.
|
|
*
|
|
* Example of use:
|
|
*
|
|
* Async Await:
|
|
* \code{cpp}
|
|
*
|
|
* auto job = [](){
|
|
* ...
|
|
* return true;
|
|
* }
|
|
* bool invoke = QMetaObject::invokeMethod(this,
|
|
"asyncHandler",
|
|
Qt::QueuedConnection,
|
|
Q_ARG(QH::Async::Job, job),
|
|
Q_ARG(bool *, &workResult),
|
|
Q_ARG(bool *, &workOfEnd));
|
|
|
|
if (!invoke) {
|
|
return false;
|
|
}
|
|
|
|
|
|
if (!waitFor(&workOfEnd)) {
|
|
return false;
|
|
}
|
|
|
|
return workResult;
|
|
* \endcode
|
|
*
|
|
*
|
|
* Async:
|
|
* \code{cpp}
|
|
*
|
|
* auto job = [](){
|
|
* ...
|
|
* return true;
|
|
* }
|
|
* bool invoke = QMetaObject::invokeMethod(this,
|
|
"asyncHandler",
|
|
Qt::QueuedConnection,
|
|
Q_ARG(std::function<bool()>, job));
|
|
|
|
return invoke;
|
|
* \endcode
|
|
*
|
|
* @warning if you use the resultOfWork parameter then necessarily set the endOfWork parameter and wait the endOfWork condition. If you do not set this then this method broken the stack of the main thread.
|
|
*
|
|
*/
|
|
void asyncHandler (QH::Async::Job job,
|
|
bool* endOfWork = nullptr,
|
|
bool* resultOfWork = nullptr) const;
|
|
|
|
|
|
private:
|
|
/**
|
|
* @brief threadAnalize This method check @a thread.
|
|
* if @a a thread is main thread then this method print error message in release build and
|
|
* invoke abort method in debug.
|
|
* @param thread This is checked thread object.
|
|
*/
|
|
void threadAnalize(QThread* thread);
|
|
};
|
|
|
|
}
|
|
|
|
Q_DECLARE_METATYPE(QH::Async::Job)
|
|
#endif // ASYNC_H
|