|
| 1 | +# sender_adaptor_closure |
| 2 | +* execution[meta header] |
| 3 | +* class template[meta id-type] |
| 4 | +* std::execution[meta namespace] |
| 5 | +* cpp26[meta cpp] |
| 6 | + |
| 7 | +```cpp |
| 8 | +namespace std::execution { |
| 9 | + template<class-type D> |
| 10 | + struct sender_adaptor_closure { }; |
| 11 | +} |
| 12 | +``` |
| 13 | +
|
| 14 | +## 概要 |
| 15 | +`sender_adaptor_closure`は、ユーザ定義のパイプ可能Senderアダプタクロージャオブジェクトの実装を補助するクラステンプレートである。 |
| 16 | +
|
| 17 | +`sender_adaptor_closure<T>`を基底クラスとして持つクラス型`T`のオブジェクトは、パイプ可能Senderアダプタクロージャオブジェクトとなる。 |
| 18 | +
|
| 19 | +`sender_adaptor_closure`のテンプレートパラメータ`D`は不完全型でもよい。 |
| 20 | +`|`演算子のオペランドにcv修飾された型`D`の式が登場するまでに、`D`は完全型かつ[`derived_from`](/reference/concepts/derived_from.md)`<sender_adaptor_closure<D>>`のモデルとなるべき。 |
| 21 | +
|
| 22 | +
|
| 23 | +### パイプ可能Senderアダプタクロージャオブジェクト |
| 24 | +パイプ可能Senderアダプタクロージャオブジェクト(pipeable sender adaptor closure object)とは、1つ以上の[`sender`](sender.md)を引数にとり、戻り値として[`sender`](sender.md)を返す関数オブジェクトである。 |
| 25 | +
|
| 26 | +パイプ可能Senderアダプタクロージャオブジェクト`c`と型`decltype((sndr))`が[`sender`](sender.md)のモデルである式`sndr`に対して、下記の2つの式は等価であり、いずれも[`sender`](sender.md)を生成する。 |
| 27 | +
|
| 28 | +```cpp |
| 29 | +c(sndr) |
| 30 | +sndr | c |
| 31 | +``` |
| 32 | + |
| 33 | +さらにパイプ可能Senderアダプタクロージャオブジェクト`d`が与えられたとき、式 `c | d` は別のパイプ可能Senderアダプタクロージャオブジェクト`e`となる。 |
| 34 | +このとき、`e`は下記の特性を持つ完全転送呼び出しラッパー(perfect forwarding call wrapper)である。 |
| 35 | + |
| 36 | +- 対象オブジェクトは、`d`で直接非リスト初期化された型`decltype(auto(d))`のオブジェクト`d2`である。 |
| 37 | +- `c`で直接非リスト初期化された型`decltype(auto(c))`のオブジェクト`c2`を、1個の束縛引数エンティティとして持つ。 |
| 38 | +- 説明用の`arg`を`e`に対する関数呼び出し式の引数としたとき、呼び出しパターン`d2(c2(arg))`に対応する。 |
| 39 | + |
| 40 | +式 `c | d` は、`e`の全て状態エンティティ(state entities)の初期化が適格な場合に限って適格となる。 |
| 41 | + |
| 42 | + |
| 43 | +### パイプ可能Senderアダプタオブジェクト |
| 44 | +パイプ可能Senderアダプタオブジェクト(pipeable sender adaptor object)とは、第1引数に[`sender`](sender.md)をとり、戻り値として[`sender`](sender.md)を返すカスタマイゼーションポイントオブジェクトである。 |
| 45 | +パイプ可能Senderアダプタオブジェクトが1個の引数しかとらないとき、パイプ可能Senderアダプタクロージャオブジェクトとなる。 |
| 46 | + |
| 47 | +パイプ可能Senderアダプタオブジェクト`adaptor`が1個より多い引数をとるとき、型`decltype((sndr))`が[`sender`](sender.md)のモデルである式`sndr`、`args...`を式`adaptor(sndr, args...)`が適格となる引数リスト、型パック`BoundsArgs`を`decltype(auto(args))...`とする。 |
| 48 | +式`adaptor(args...)`は、下記の特性をもつ完全転送呼び出しラッパーであるパイプ可能Senderアダプタクロージャオブジェクト`f`を生成する。 |
| 49 | + |
| 50 | +- 対象オブジェクトは`adaptor`のコピー。 |
| 51 | +- 束縛引数エンティティ`bound_args`は、それぞれ[`std::forward`](/reference/utility/forward.md)`<decltype((args))>(args)...`で直接非リスト初期化された型`BoundArgs...`のオブジェクトから構成される。 |
| 52 | +- 説明用の`rcvr`を`f`に対する関数呼び出し式の引数としたとき、呼び出しパターン`adaptor(rcvr, bound_args...)`に対応する。 |
| 53 | + |
| 54 | +式`adaptor(args...)`は、前述の通り結果の束縛引数エンティティの初期化が適格な場合に限って適格となる。 |
| 55 | + |
| 56 | + |
| 57 | +## バージョン |
| 58 | +### 言語 |
| 59 | +- C++26 |
| 60 | + |
| 61 | +### 処理系 |
| 62 | +- [Clang](/implementation.md#clang): ?? |
| 63 | +- [GCC](/implementation.md#gcc): ?? |
| 64 | +- [ICC](/implementation.md#icc): ?? |
| 65 | +- [Visual C++](/implementation.md#visual_cpp): ?? |
| 66 | + |
| 67 | + |
| 68 | +## 関連項目 |
| 69 | +- [`execution::sender`](sender.md) |
| 70 | + |
| 71 | + |
| 72 | +## 参照 |
| 73 | +- [P2300R10 `std::execution`](https://www.open-std.org/jtc1/sc22/wg21/docs/papers/2024/p2300r10.html) |
0 commit comments