Namensräume
Varianten
Aktionen

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

Von cppreference.com
< cpp‎ | utility‎ | expected
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
 
Primäre Vorlage
template< class F >
constexpr auto transform_error( F&& f ) &;
(1) (seit C++23)
template< class F >
constexpr auto transform_error( F&& f ) const&;
(2) (seit C++23)
template< class F >
constexpr auto transform_error( F&& f ) &&;
(3) (seit C++23)
template< class F >
constexpr auto transform_error( F&& f ) const&&;
(4) (seit C++23)
void partielle Spezialisierung
template< class F >
constexpr auto transform_error( F&& f ) &;
(5) (seit C++23)
template< class F >
constexpr auto transform_error( F&& f ) const&;
(6) (seit C++23)
template< class F >
constexpr auto transform_error( F&& f ) &&;
(7) (seit C++23)
template< class F >
constexpr auto transform_error( F&& f ) const&&;
(8) (seit C++23)

Wenn *this einen unerwarteten Wert enthält, wird f mit dem unerwarteten Wert von *this als Argument aufgerufen und ein `std::expected`-Objekt zurückgegeben, das einen unerwarteten Wert enthält, welcher mit dem Ergebnis von f initialisiert wird. Andernfalls wird ein `std::expected`-Objekt zurückgegeben, das einen erwarteten Wert darstellt.

1-4) Der erwartete Wert wird mit dem erwarteten Wert val von *this initialisiert.

Gegebener Typ G als

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()))>>

Wenn eine der folgenden Bedingungen erfüllt ist, ist das Programm ill-formed (wohlgeformt):

  • G ist kein gültiges Template-Argument für std::unexpected.
  • Die folgende entsprechende Deklaration ist ill-formed
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) Diese Überladung nimmt an der Überladungsauflösung teil, nur wenn std::is_constructible_v<T, decltype((val))> true ist.
3,4) Diese Überladung nimmt an der Überladungsauflösung teil, nur wenn std::is_constructible_v<T, decltype(std::move(val))> true ist.

Inhalt

[edit] Parameter

f - ein geeignetes aufrufbares Objekt oder eine geeignete Callable, dessen Aufrufsignatur einen Nicht-Referenztyp zurückgibt

[edit] Rückgabewert

Ausdruck expr als

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()))

Die Rückgabewerte sind wie folgt definiert

 Überladung  Wert von 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)

[edit] Beispiel

[edit] Fehlerberichte

Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 3938 C++23 der erwartete Wert wurde durch value()[1] erhalten geändert zu **this
LWG 3973 C++23 der erwartete Wert wurde durch **this[2] erhalten geändert zu val
  1. value() erfordert, dass E kopierkonstruierbar ist (siehe LWG issue 3843), während operator* dies nicht tut.
  2. **this kann Argument-dependent lookup auslösen.

[edit] Siehe auch

gibt das expected selbst zurück, wenn es einen erwarteten Wert enthält; andernfalls gibt es das Ergebnis der gegebenen Funktion auf dem unerwarteten Wert zurück
(öffentliche Member-Funktion) [edit]
gibt ein expected mit dem transformierten erwarteten Wert zurück, falls dieser existiert; andernfalls gibt es das expected selbst zurück
(öffentliche Mitgliedsfunktion) [bearbeiten]