std:: indirectly_unary_invocable, std:: indirectly_regular_unary_invocable
|
Definido en el encabezado
<iterator>
|
||
std::indirectly_unary_invocable
|
||
|
template
<
class
F,
class
I
>
concept indirectly_unary_invocable
=
|
(desde C++20) | |
std::indirectly_regular_unary_invocable
|
||
|
template
<
class
F,
class
I
>
concept indirectly_regular_unary_invocable
=
|
(desde C++20) | |
Los conceptos
indirectly_unary_invocable
y
indirectly_regular_unary_invocable
especifican requisitos para algoritmos que llaman invocables unarios (regulares) como sus argumentos. La diferencia clave entre estos conceptos y
std::invocable
es que se aplican al tipo al que hace referencia
I
, en lugar de a
I
mismo.
Notas
La distinción entre
indirectly_unary_invocable
y
indirectly_regular_unary_invocable
es puramente semántica.
Ejemplo
#include <algorithm> #include <iterator> #include <print> #include <ranges> struct IntWrapper { int i; explicit IntWrapper(int i) : i(i) {} IntWrapper(IntWrapper&&) = default; IntWrapper& operator=(IntWrapper&&) = default; }; int main() { auto ints = std::views::iota(1, 10); auto print = [] (IntWrapper w) { std::print("{} ", w.i); }; auto wrap = [] (int i) { return IntWrapper{i}; }; using Proj = std::projected<decltype(ints.begin()), decltype(wrap)>; // error (evaluado como false) hasta P2609R3: // esto se debía a que 'std::iter_value_t<Proj> &' es igual a 'IntWrapper&' // que no es convertible a 'IntWrapper' (constructor de copia eliminado implícitamente) static_assert(std::indirectly_unary_invocable<decltype(print), Proj>); // si la verificación en tiempo de compilación anterior se evalúa como true, entonces esto está bien formado: std::ranges::for_each(ints, print, wrap); }
Salida:
1 2 3 4 5 6 7 8 9
Informes de defectos
Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.
| DR | Aplicado a | Comportamiento publicado | Comportamiento correcto |
|---|---|---|---|
| P2609R3 | C++20 |
algunos requisitos se definieron en términos de
std::
iter_value_t
<
I
>
&
lo cual manejó incorrectamente las proyecciones resultando en incompatibilidad con invocable F & |
definido en términos de
/*indirect-value-t*/
<
I
>
para manejar correctamente dichas proyecciones |
| P2997R1 | C++20 |
los conceptos correspondientes requerían que
F
&
cumpliera con
invocable
y
regular_invocable
, respectivamente, con
std::
iter_common_reference_t
<
I
>
|
no requiere |