Defined in header <iterator> | ||
|---|---|---|
template<class In, class Out>
concept indirectly_movable_storable =
std::indirectly_movable<In, Out> &&
std::indirectly_writable<Out, std::iter_value_t<In>> &&
std::movable<std::iter_value_t<In>> &&
std::constructible_from<std::iter_value_t<In>, std::iter_rvalue_reference_t<In>> &&
std::assignable_from<std::iter_value_t<In>&, std::iter_rvalue_reference_t<In>>;
| (since C++20) |
The indirectly_movable_storable concept specifies the relationship between an indirectly_readable type and an indirectly_writable type. In addition to indirectly_movable, this concept specifies that the move from the indirectly_readable type can be performed via an intermediate object.
In and Out model std::indirectly_movable_storable<In, Out> only if given a dereferenceable value i of type In:
std::iter_value_t<In> obj(ranges::iter_move(i));, obj is equal to the value previously denoted by *i, and std::iter_rvalue_reference_t<In> is an rvalue reference type, *i is placed in a valid but unspecified state after the initialization of obj. Expressions declared in requires-expressions of the standard library concepts are required to be equality-preserving (except where stated otherwise).
|
(C++20) | specifies that values may be moved from an indirectly_readable type to an indirectly_writable type (concept) |
|
(C++20) | specifies that values may be copied from an indirectly_readable type to an indirectly_writable type and that the copy may be performed via an intermediate object (concept) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/iterator/indirectly_movable_storable