D++ (DPP)
C++ Discord API Bot Library
Loading...
Searching...
No Matches
dpp::detail::task::promise_t< void > Struct Reference

Implementation of task::promise_t for void return type. More...

#include <task.h>

Inheritance diagram for dpp::detail::task::promise_t< void >:
Collaboration diagram for dpp::detail::task::promise_t< void >:

Public Member Functions

auto await_transform (T &&expr) const noexcept(noexcept(co_await_resolve(std::forward< T >(expr))))
 Function called whenever co_await is used inside of the task.
void emplace_value (Args &&... args)
 Construct the result in place by forwarding the arguments, and by default resume any awaiter.
final_awaiter< void > final_suspend () const noexcept
 Function called by the standard library when the coroutine reaches its last suspension point.
awaitable< void > get_awaitable ()
 Get an awaitable object for this promise.
dpp::task< void > get_return_object () noexcept
 Function called by the standard library when the coroutine is created.
std_coroutine::suspend_never initial_suspend () const noexcept
 Function called by the standard library when the coroutine is created.
void notify_awaiter ()
 Notify a currently awaiting coroutine that the result is ready.
void return_value (void &&expr) noexcept(std::is_nothrow_move_constructible_v< void >)
 Function called by the standard library when the coroutine co_returns a value.
void return_void () noexcept
 Function called by the standard library when the coroutine co_returns.
void set_exception (std::exception_ptr ptr)
 Set this promise to an exception and resume any awaiter.
void set_value (U &&v)
 Construct the result by forwarding reference, and resume any awaiter.
void unhandled_exception ()
 Function called by the standard library when an exception is thrown and not caught in the coroutine.

Public Attributes

std::atomic< bool > cancelled
 Whether the task is cancelled or not.

Protected Types

using storage_type
 Variant representing one of either 3 states of the result value : empty, result, exception.

Protected Member Functions

std_coroutine::coroutine_handle release_awaiter ()
 Unlinks this promise from its currently linked awaiter and returns it.
void throw_if_not_empty ()
 Check if the result is empty, throws otherwise.

Protected Attributes

std_coroutine::coroutine_handle awaiter
 Coroutine handle currently awaiting the completion of this promise.
std::atomic< uint8_t > state
 State of the awaitable tied to this promise.
storage_type value
 State of the result value.

Friends

struct final_awaiter< R >
struct final_awaiter< void >

Detailed Description

Implementation of task::promise_t for void return type.

Member Typedef Documentation

◆ storage_type

using dpp::detail::promise::promise_base< void >::storage_type
protected

Variant representing one of either 3 states of the result value : empty, result, exception.

Member Function Documentation

◆ await_transform()

auto dpp::detail::task::promise_base< void >::await_transform ( T && expr) const
inlinenodiscardnoexcept

Function called whenever co_await is used inside of the task.

Exceptions
dpp::task_cancelled_exceptionOn resumption if the task was cancelled
Returns
proxy_awaiter Returns a proxy awaiter that will check for cancellation on resumption

◆ emplace_value()

void dpp::basic_promise< void >::emplace_value ( Args &&... args)
inline

Construct the result in place by forwarding the arguments, and by default resume any awaiter.

Template Parameters
NotifyWhether to resume any awaiter or not.
Exceptions
dpp::logic_exceptionif the promise is not empty.

◆ final_suspend()

final_awaiter< void > dpp::detail::task::promise_t< void >::final_suspend ( ) const
inlinenodiscardnoexcept

Function called by the standard library when the coroutine reaches its last suspension point.

Returns
final_awaiter Special object containing the chain resolution and clean-up logic.

◆ get_awaitable()

awaitable< void > dpp::detail::promise::promise_base< void >::get_awaitable ( )
inline

Get an awaitable object for this promise.

Exceptions
dpp::logic_exceptionif get_awaitable has already been called on this object.
Returns
awaitable<T> An object that can be co_await-ed to retrieve the value of this promise.

◆ get_return_object()

dpp::task< void > dpp::detail::task::promise_t< void >::get_return_object ( )
inlinenodiscardnoexcept

Function called by the standard library when the coroutine is created.

Returns
task The coroutine object

◆ initial_suspend()

std_coroutine::suspend_never dpp::detail::task::promise_base< void >::initial_suspend ( ) const
inlinenoexcept

Function called by the standard library when the coroutine is created.

Returns
std::suspend_never Don't suspend, the coroutine starts immediately.

◆ notify_awaiter()

void dpp::detail::promise::promise_base< void >::notify_awaiter ( )
inline

Notify a currently awaiting coroutine that the result is ready.

Note
This may resume the coroutine on the current thread.
Exceptions
?Any exception thrown by the coroutine if resumed will propagate

◆ release_awaiter()

std_coroutine::coroutine_handle dpp::detail::promise::promise_base< void >::release_awaiter ( )
inlineprotected

Unlinks this promise from its currently linked awaiter and returns it.

At the time of writing this is only used in the case of a serious internal error in dpp::task. Avoid using this as this will crash if the promise is used after this.

◆ return_value()

void dpp::detail::task::promise_t< void >::return_value ( void && expr)
inlinenoexcept

Function called by the standard library when the coroutine co_returns a value.

Stores the value internally to hand to the caller when it resumes.

Parameters
exprThe value given to co_return

◆ return_void()

void dpp::detail::task::promise_t< void >::return_void ( )
inlinenoexcept

Function called by the standard library when the coroutine co_returns.

Sets the promise state to finished.

◆ set_exception()

void dpp::detail::promise::promise_base< void >::set_exception ( std::exception_ptr ptr)
inline

Set this promise to an exception and resume any awaiter.

Template Parameters
NotifyWhether to resume any awaiter or not.
Exceptions
dpp::logic_exceptionif the promise is not empty.
?Any exception thrown by the coroutine if resumed will propagate

◆ set_value()

void dpp::basic_promise< void >::set_value ( U && v)
inline

Construct the result by forwarding reference, and resume any awaiter.

Template Parameters
NotifyWhether to resume any awaiter or not.
Exceptions
dpp::logic_exceptionif the promise is not empty.

◆ throw_if_not_empty()

void dpp::detail::promise::promise_base< void >::throw_if_not_empty ( )
inlineprotected

Check if the result is empty, throws otherwise.

Exceptions
dpp::logic_exceptionif the result isn't empty.

◆ unhandled_exception()

void dpp::detail::task::promise_base< void >::unhandled_exception ( )
inline

Function called by the standard library when an exception is thrown and not caught in the coroutine.

Stores the exception pointer to rethrow on co_await. If the task object is destroyed and was not cancelled, throw instead

◆ final_awaiter< R >

friend struct final_awaiter< void >
friend

◆ final_awaiter< void >

friend struct final_awaiter< void >
friend

Member Data Documentation

◆ awaiter

std_coroutine::coroutine_handle dpp::detail::promise::promise_base< void >::awaiter
protected

Coroutine handle currently awaiting the completion of this promise.

◆ cancelled

std::atomic<bool> dpp::detail::task::promise_base< void >::cancelled

Whether the task is cancelled or not.

◆ state

std::atomic<uint8_t> dpp::detail::promise::promise_base< void >::state
protected

State of the awaitable tied to this promise.

◆ value

State of the result value.

See also
storage_type
Note
use .index() instead of std::holds_alternative to support promise_base<std::exception_ptr> and promise_base<std::monostate> :)
D++ Library version 9.0.13D++ Library version 9.0.12D++ Library version 9.0.11D++ Library version 9.0.10D++ Library version 9.0.9D++ Library version 9.0.8D++ Library version 9.0.7D++ Library version 9.0.6D++ Library version 9.0.5D++ Library version 9.0.4D++ Library version 9.0.3D++ Library version 9.0.2D++ Library version 9.0.1D++ Library version 9.0.0D++ Library version 1.0.2D++ Library version 1.0.1D++ Library version 1.0.0