Espacios de nombres
Variantes

std::expected<T,E>::transform_error

De cppreference.com
 
 
Biblioteca de servicios
 
 
Plantilla primaria
template< class F > constexpr auto transform_error( F&& f ) &;
(1) (desde C++23)
template< class F > constexpr auto transform_error( F&& f ) const&;
(2) (desde C++23)
template< class F > constexpr auto transform_error( F&& f ) &&;
(3) (desde C++23)
template< class F > constexpr auto transform_error( F&& f ) const&&;
(4) (desde C++23)
Especialización parcial void
template< class F > constexpr auto transform_error( F&& f ) &;
(5) (desde C++23)
template< class F > constexpr auto transform_error( F&& f ) const&;
(6) (desde C++23)
template< class F > constexpr auto transform_error( F&& f ) &&;
(7) (desde C++23)
template< class F > constexpr auto transform_error( F&& f ) const&&;
(8) (desde C++23)

Si *this contiene un valor no esperado, invoca a f con el valor no esperado de *this como argumento y devuelve un objeto std::expected que contiene un valor no esperado, el cual se inicializa con el resultado de f. En caso contrario, devuelve un objeto std::expected que representa un valor esperado.

1-4) El valor esperado se inicializa con el valor esperado val de *this.

Dado el tipo G como:

1,2) std::remove_cv_t<std::invoke_result_t<F, decltype(error())>>
3,4) std::remove_cv_t<std::invoke_result_t<F, decltype(std::move(error()))>>
5,6) std::remove_cv_t<std::invoke_result_t<F, decltype(error())>>
7,8) std::remove_cv_t<std::invoke_result_t<F, decltype(std::move(error()))>>

Si se cumple alguna de las siguientes condiciones, el programa está mal formado:

  • G no es un argumento de plantilla válido para std::unexpected.
  • La siguiente declaración correspondiente está mal formada:
1,2) G g(std::invoke(std::forward<F>(f), error()));
3,4) G g(std::invoke(std::forward<F>(f), std::move(error()));
5,6) G g(std::invoke(std::forward<F>(f), error()));
7,8) G g(std::invoke(std::forward<F>(f), std::move(error()));


1,2) Esta sobrecarga solo participa en la resolución de sobrecargas si std::is_constructible_v<T, decltype((val))> es true.
3,4) Esta sobrecarga solo participa en la resolución de sobrecargas si std::is_constructible_v<T, decltype(std::move(val))> es true.

Parámetros

f - Una función adecuada o un objeto Callable cuya signatura de llamada devuelva un tipo no referencia.

Valor de retorno

Dada la expresión expr como:

1,2) std::invoke(std::forward<F>(f), error())
3,4) std::invoke(std::forward<F>(f), std::move(error()))
5,6) std::invoke(std::forward<F>(f), error())
7,8) std::invoke(std::forward<F>(f), std::move(error()))

Los valores de retorno se definen de la siguiente manera:

 Sobrecarga  Valor de has_value()
true false
(1,2) std::expected<T, G>(std::in_place, val) std::expected<T, G>
(std::unexpect, expr)
(3,4) std::expected<T, G>(std::in_place, std::move(val))
(5,6) std::expected<T, G>()
(7,8)

Notas

Macro de prueba de característica
__cpp_lib_expected 202211L (C++23) Funciones monádicas para std::expected.

Ejemplo

Informes de defectos

Los siguientes informes de defectos de cambio de comportamiento se aplicaron de manera retroactiva a los estándares de C++ publicados anteriormente.

ID Aplicado a Comportamiento según lo publicado Comportamiento correcto
LWG 3938 C++23 El valor esperado se obtenía por value()[1] Se cambió a **this.
LWG 3973 C++23 El valor esperado se obtenía por **this[2] Se cambió a val.
  1. value() requiere que E sea construible por copia (véase Asunto LWG 3843), pero operator* no.
  2. **this puede activar la búsqueda dependiente de argumento.

Véase también

Devuelve el propio expected si contiene un valor esperado; de lo contrario, devuelve el resultado de la función dada en el valor no esperado.
(función miembro pública) [editar]
Devuelve un objeto expected que contiene el valor esperado transformado si existe; de lo contrario, devuelve el propio expected.
(función miembro pública) [editar]