std::expected<T,E>:: transform_error
|
プライマリテンプレート
|
||
|
template
<
class
F
>
constexpr auto transform_error ( F && f ) & ; |
(1) | (C++23以降) |
|
template
<
class
F
>
constexpr auto transform_error ( F && f ) const & ; |
(2) | (C++23以降) |
|
template
<
class
F
>
constexpr auto transform_error ( F && f ) && ; |
(3) | (C++23以降) |
|
template
<
class
F
>
constexpr auto transform_error ( F && f ) const && ; |
(4) | (C++23以降) |
|
void
部分特殊化
|
||
|
template
<
class
F
>
constexpr auto transform_error ( F && f ) & ; |
(5) | (C++23以降) |
|
template
<
class
F
>
constexpr auto transform_error ( F && f ) const & ; |
(6) | (C++23以降) |
|
template
<
class
F
>
constexpr auto transform_error ( F && f ) && ; |
(7) | (C++23以降) |
|
template
<
class
F
>
constexpr auto transform_error ( F && f ) const && ; |
(8) | (C++23以降) |
*
this
が予期しない値を含む場合、
f
を
*
this
の予期しない値を引数として呼び出し、
f
の結果で初期化された予期しない値を含む
std::expected
オブジェクトを返します。それ以外の場合、期待値を表す
std::expected
オブジェクトを返します。
型
G
が以下のように与えられた場合:
以下のいずれかの条件が満たされる場合、プログラムは不適格となります:
-
Gはstd::unexpectedの有効なテンプレート引数ではありません。 - 以下の対応する宣言は不適格です:
val
)
)
>
が
true
の場合にのみ、オーバーロード解決に参加します。
val
)
)
>
が
true
の場合にのみ、オーバーロード解決に参加します。
目次 |
パラメータ
| f | - | 適切な関数または Callable オブジェクトで、その呼び出しシグネチャが非参照型を返すもの |
戻り値
与えられた式 expr を以下に示します:
戻り値は以下のように定義されています:
| オーバーロード |
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 ) | ||
例
|
このセクションは不完全です
理由: 例がありません |
欠陥報告
以下の動作変更の欠陥報告書は、以前に公開されたC++規格に対して遡及的に適用されました。
| DR | 適用対象 | 公開時の動作 | 正しい動作 |
|---|---|---|---|
| LWG 3938 | C++23 | 期待値は value ( ) [1] によって取得されていた | ** this に変更 |
| LWG 3973 | C++23 | 期待値は ** this [2] によって取得されていた |
val
に変更
|
-
↑
value()はEがコピー構築可能であることを要求する( LWG issue 3843 を参照)。一方operator*はこの要求を持たない。 - ↑ ** this は 実引数依存の名前探索 を引き起こす可能性がある。
関連項目
期待される値が含まれている場合は
expected
自体を返す。それ以外の場合は、予期しない値に対する指定された関数の結果を返す
(公開メンバ関数) |
|
期待される値が存在する場合は、変換された期待値を含む
expected
を返す。それ以外の場合は、
expected
自体を返す
(公開メンバ関数) |