Standard library header <coroutine> (C++20)
From cppreference.com
This header is part of the coroutine support library.
Includes | |
(C++20) |
Three-way comparison operator support |
Classes | |
(C++20) |
trait type for discovering coroutine promise types (class template) |
(C++20) |
used to refer to a suspended or executing coroutine (class template) |
hash support for std::coroutine_handle (class template specialization) | |
No-op Coroutines | |
(C++20) |
used for coroutines with no observable effects (class) |
(C++20) |
std::coroutine_handle<std::noop_coroutine_promise>, intended to refer to a no-op coroutine (typedef) |
Trivial Awaitables | |
(C++20) |
indicates that an await-expression should never suspend (class) |
(C++20) |
indicates that an await-expression should always suspend (class) |
Functions | |
(C++20) |
compares two coroutine_handle objects (function) |
No-op Coroutines | |
(C++20) |
creates a coroutine handle that has no observable effects when resumed or destroyed (function) |
Synopsis
#include <compare> namespace std { // coroutine traits template<class R, class... ArgTypes> struct coroutine_traits; // coroutine handle template<class Promise = void> struct coroutine_handle; // comparison operators constexpr bool operator==(coroutine_handle<> x, coroutine_handle<> y) noexcept; constexpr strong_ordering operator<=>(coroutine_handle<> x, coroutine_handle<> y) noexcept; // hash support template<class T> struct hash; template<class P> struct hash<coroutine_handle<P>>; // no-op coroutines struct noop_coroutine_promise; template<> struct coroutine_handle<noop_coroutine_promise>; using noop_coroutine_handle = coroutine_handle<noop_coroutine_promise>; noop_coroutine_handle noop_coroutine() noexcept; // trivial awaitables struct suspend_never; struct suspend_always; }
Class template std::coroutine_handle
namespace std { template<> struct coroutine_handle<void> { // construct/reset constexpr coroutine_handle() noexcept; constexpr coroutine_handle(nullptr_t) noexcept; coroutine_handle& operator=(nullptr_t) noexcept; // export/import constexpr void* address() const noexcept; static constexpr coroutine_handle from_address(void* addr); // observers constexpr explicit operator bool() const noexcept; bool done() const; // resumption void operator()() const; void resume() const; void destroy() const; private: void* ptr; // exposition only }; template<class Promise> struct coroutine_handle { // construct/reset constexpr coroutine_handle() noexcept; constexpr coroutine_handle(nullptr_t) noexcept; static coroutine_handle from_promise(Promise&); coroutine_handle& operator=(nullptr_t) noexcept; // export/import constexpr void* address() const noexcept; static constexpr coroutine_handle from_address(void* addr); // conversion constexpr operator coroutine_handle<>() const noexcept; // observers constexpr explicit operator bool() const noexcept; bool done() const; // resumption void operator()() const; void resume() const; void destroy() const; // promise access Promise& promise() const; private: void* ptr; // exposition only }; }
Class std::noop_coroutine_promise
namespace std { struct noop_coroutine_promise {}; }
Class std::coroutine_handle<std::noop_coroutine_promise>
namespace std { template<> struct coroutine_handle<noop_coroutine_promise> { // conversion constexpr operator coroutine_handle<>() const noexcept; // observers constexpr explicit operator bool() const noexcept; constexpr bool done() const noexcept; // resumption constexpr void operator()() const noexcept; constexpr void resume() const noexcept; constexpr void destroy() const noexcept; // promise access noop_coroutine_promise& promise() const noexcept; // address constexpr void* address() const noexcept; private: coroutine_handle(/* unspecified */); void* ptr; // exposition only }; }
Class std::suspend_never
namespace std { struct suspend_never { constexpr bool await_ready() const noexcept { return true; } constexpr void await_suspend(coroutine_handle<>) const noexcept {} constexpr void await_resume() const noexcept {} }; }
Class std::suspend_always
namespace std { struct suspend_always { constexpr bool await_ready() const noexcept { return false; } constexpr void await_suspend(coroutine_handle<>) const noexcept {} constexpr void await_resume() const noexcept {} }; }