std::generator<Ref,V,Allocator>::iterator
|
class /*iterator*/;
|
(since C++23) | |
The return type of generator::begin. The name iterator is for exposition purposes only.
Models indirectly_readable and input_iterator.
Member types
| Member type | Definition |
value_type |
std::generator::value |
difference_type |
std::ptrdiff_t |
Data members
Typical implementations of iterator hold only one non-static data members:
- a coroutine handle of type std::coroutine_handle<std::generator::promise_type> (shown here as
coroutine_for exposition only).
Member functions
|
(C++23)
|
constructs an iterator (public member function) |
|
(C++23)
|
assigns another iterator (public member function) |
|
(C++23)
|
returns an underlying value (public member function) |
|
(C++23)
|
advances the iterator (public member function) |
std::generator::iterator::iterator
|
/*iterator*/( /*iterator*/&& other ) noexcept;
|
(since C++23) | |
Initializes coroutine_ with std::exchange(other.coroutine_, {});.
std::generator::iterator::operator=
|
/*iterator*/& operator=( /*iterator*/&& other ) noexcept;
|
(since C++23) | |
Equivalent to coroutine_ = std::exchange(other.coroutine_, {});.
Returns: *this.
std::generator::iterator::operator*
|
reference operator*() const
noexcept( std::is_nothrow_copy_constructible_v<reference> ); |
(since C++23) | |
- Let
referencebe thestd::generator's underlying type. - Let for some generator object x its
coroutine_be in the stack *x.active_. - Let x.active_->top() refer to a suspended coroutine with promise object p.
Equivalent to return static_cast<reference>(*p.value_);.
std::generator::iterator::operator++
|
constexpr /*iterator*/& operator++();
|
(1) | (since C++23) |
|
constexpr void operator++( int );
|
(2) | (since C++23) |
1) Let for some generator object x the
coroutine_ be in the stack *x.active_. Equivalent to x.active_->top().resume().
Returns: *this.
2) Equivalent to ++*this;.
Non-member functions
|
(C++23)
|
compares the underlying iterator with a sentinel (function) |
operator==(std::generator::iterator)
|
friend bool operator==( const /*iterator*/& i, std::default_sentinel_t );
|
(since C++23) | |
Equivalent to return i.coroutine_.done();.
The != operator is synthesized from operator==.
This function is not visible to ordinary unqualified or qualified lookup, and can only be found by argument-dependent lookup when std::generator::iterator is an associated class of the arguments.
Example
| This section is incomplete Reason: no example |