#include <userver/engine/task/task.hpp>
Asynchronous task that has a unique ownership of the payload.
See engine::TaskWithResult for a type that could return a value or report an exception from the payload.
Public Types | |
enum class | Importance { kNormal , kCritical } |
Task importance. More... | |
enum class | State { kInvalid , kNew , kQueued , kRunning , kSuspended , kCancelled , kCompleted } |
Task state. More... | |
enum class | WaitMode { kSingleWaiter , kMultipleWaiters } |
Task wait mode. More... | |
Public Member Functions | |
Task () | |
Default constructor. | |
~Task () | |
If the task is still valid and is not finished, cancels it and waits until it finishes. | |
Task (Task &&other) noexcept | |
Moves the other task into this, leaving the other in an invalid state. | |
Task & | operator= (Task &&other) noexcept |
If this Task is still valid and is not finished, cancels it and waits until it finishes before moving the other. Otherwise just moves the other task into this, leaving the other in invalid state. | |
Task (const Task &)=delete | |
Task & | operator= (const Task &)=delete |
void | Detach () && |
Detaches task, allowing it to continue execution out of scope; memory safety is much better with concurrent::BackgroundTaskStorage. | |
bool | IsValid () const |
Checks whether this object owns an actual task (not State::kInvalid ) | |
State | GetState () const |
Gets the task State. | |
bool | IsFinished () const |
Returns whether the task finished execution. | |
void | Wait () const noexcept(false) |
Suspends execution until the task finishes or caller is cancelled. Can be called from coroutine context only. For non-coroutine context use BlockingWait(). | |
template<typename Rep , typename Period > | |
void | WaitFor (const std::chrono::duration< Rep, Period > &) const noexcept(false) |
Suspends execution until the task finishes or after the specified timeout or until caller is cancelled. | |
template<typename Clock , typename Duration > | |
void | WaitUntil (const std::chrono::time_point< Clock, Duration > &) const noexcept(false) |
Suspends execution until the task finishes or until the specified time point is reached or until caller is cancelled. | |
void | WaitUntil (Deadline) const |
Suspends execution until the task finishes or until the specified deadline is reached or until caller is cancelled. | |
void | RequestCancel () |
Queues task cancellation request. | |
void | SyncCancel () noexcept |
Cancels the task and suspends execution until it is finished. Can be called from coroutine context only. For non-coroutine context use RequestCancel() + BlockingWait(). | |
TaskCancellationReason | CancellationReason () const |
Gets task cancellation reason. | |
void | BlockingWait () const |
Static Public Member Functions | |
static const std::string & | GetStateName (State state) |
|
stronginherited |
Task importance.
Definition at line 40 of file task_base.hpp.
|
stronginherited |
Task state.
Definition at line 52 of file task_base.hpp.
|
stronginherited |
Task wait mode.
Enumerator | |
---|---|
kSingleWaiter | Can be awaited by at most one task at a time. |
kMultipleWaiters | Can be awaited by multiple tasks simultaneously. |
Definition at line 63 of file task_base.hpp.
engine::Task::Task | ( | ) |
Default constructor.
Creates an invalid task.
|
inherited |
Waits for the task in non-coroutine context (e.g. non-TaskProcessor's std::thread).
void engine::Task::Detach | ( | ) | && |
Detaches task, allowing it to continue execution out of scope; memory safety is much better with concurrent::BackgroundTaskStorage.
Async*
, should outlive the task execution. This is hard to achieve in general, detached tasks may outlive all the components! Use concurrent::BackgroundTaskStorage as a safe and efficient alternative to calling Detach().
|
inherited |
Checks whether this object owns an actual task (not State::kInvalid
)
An invalid task cannot be used. The task becomes invalid after each of the following calls:
Detach()
Get()
(see engine::TaskWithResult
)
|
inherited |
Suspends execution until the task finishes or caller is cancelled. Can be called from coroutine context only. For non-coroutine context use BlockingWait().
WaitInterruptedException | when current_task::IsCancelRequested() and no TaskCancellationBlockers are present. |
|
inherited |
Suspends execution until the task finishes or after the specified timeout or until caller is cancelled.
WaitInterruptedException | when current_task::IsCancelRequested() and no TaskCancellationBlockers are present. |
Definition at line 191 of file task_base.hpp.
|
inherited |
Suspends execution until the task finishes or until the specified time point is reached or until caller is cancelled.
WaitInterruptedException | when current_task::IsCancelRequested() and no TaskCancellationBlockers are present. |
Definition at line 197 of file task_base.hpp.
|
inherited |
Suspends execution until the task finishes or until the specified deadline is reached or until caller is cancelled.
WaitInterruptedException | when current_task::IsCancelRequested() and no TaskCancellationBlockers are present. |