1#ifndef KOKKOS_EXECUTION_GRAPH_CONTINUES_ON_HPP
2#define KOKKOS_EXECUTION_GRAPH_CONTINUES_ON_HPP
20template <
typename ParentOp,
typename Env = stdexec::env_of_t<ParentOp>>
32template <stdexec::scheduler Schd, stdexec::receiver Rcvr>
40 noexcept(std::is_nothrow_move_constructible_v<Rcvr>)
42 ,
rcvr(std::move(rcvr_)) {
54template <stdexec::scheduler Schd, stdexec::sender Sndr, stdexec::receiver Rcvr>
64 std::same_as<stdexec::__completion_domain_of_t<stdexec::set_value_t, Sndr, stdexec::env_of_t<Rcvr>>,
Domain>,
82 std::is_nothrow_constructible_v<base_t, Schd&&, Rcvr&&> && stdexec::__nothrow_connectable<Sndr&&, rcvr_t>)
83 :
base_t(std::forward<Schd>(schd), std::move(
rcvr))
97 stdexec::set_error(std::move(this->
rcvr), std::current_exception());
100 if constexpr (std::same_as<completion_signal_policy_t, Impl::SubmittedPolicy::OrderOnExec>) {
101 std::move(this->
rcvr).submitted();
103 static_assert(std::same_as<completion_signal_policy_t, Impl::SyncPolicy::InlineFenceExec>);
104 stdexec::set_value(std::move(this->
rcvr));
109 stdexec::set_value(std::move(this->
rcvr));
112 template <
typename Error>
113 void complete(stdexec::set_error_t, Error&& error)
noexcept {
114 stdexec::set_error(std::move(this->
rcvr), std::forward<Error>(error));
118 stdexec::set_stopped(std::move(this->
rcvr));
123template <stdexec::operation_state OpState, Kokkos::ExecutionSpace Exec>
125 stdexec::__is_instance_of<OpState, Kokkos::Execution::GraphImpl::ContinuesOnOpState>
126 && std::same_as<typename OpState::execution_space, Exec>)
130template <stdexec::scheduler Schd, stdexec::sender Sndr>
136 template <
typename Self,
typename Rcvr>
140 template <
typename Self,
typename Rcvr>
148 template <stdexec::__decays_to<ContinuesOnSender> Self, stdexec::receiver Rcvr>
149 STDEXEC_EXPLICIT_THIS_BEGIN(
150 auto connect)(
this Self&& self, Rcvr rcvr)
157 STDEXEC_EXPLICIT_THIS_END(connect)
167 template <
typename Env, stdexec::scheduler Schd, stdexec::sender Sndr>
168 requires stdexec::__sends<stdexec::set_value_t, Sndr, Env>
170 noexcept(std::is_nothrow_constructible_v<ContinuesOnSender<Schd, Sndr>, Schd&&, Sndr&&>)
172 return {.schd = std::forward<Schd>(
schd), .sndr = std::forward<Sndr>(
sndr)};
#define KOKKOS_EXECUTION_IMPL_FORWARDING_ATTRIBUTES_GET_ENV(_type_, _obj_)
#define KOKKOS_EXECUTION_COMPL_SIGS_KEEP(_decayed_self_type_, _sndr_type_)
#define KOKKOS_EXECUTION_GET_ENV(_type_, _obj_)
Retrieve the environment of _obj_. // NOLINTNEXTLINE(cppcoreguidelines-macro-usage).
constexpr auto join_env_with_exec(Env &&env, const Exec &exec) noexcept
Unconditionally join exec to env.
typename DependencyFor< InnerOp, ExecTo >::type dependency_for_t
std::conditional_t< ContinuesOn::signals_submitted< InnerOp, ExecTo, Rcvr >, Impl::SubmittedPolicy::OrderOnExec, Impl::SyncPolicy::InlineFenceExec > completion_signal_policy_t
constexpr get_exec_t get_exec
constexpr ContinuesOnOpStateBase(const Schd &schd, Rcvr rcvr_) noexcept(std::is_nothrow_move_constructible_v< Rcvr >)
typename std::remove_cvref_t< Schd >::execution_space execution_space
Impl::State< execution_space > * state
constexpr auto query(Impl::get_exec_t) const noexcept -> Impl::ExecutionSpaceRef< execution_space >
Operation state for stdexec::continues_on.
std::optional< dependency_t > dependency
inner_opstate_t inner_opstate
void complete(stdexec::set_error_t, Error &&error) noexcept
ContinuesOnOpStateBase< Schd, Rcvr > base_t
std::conditional_t< std::same_as< stdexec::__completion_domain_of_t< stdexec::set_value_t, Sndr, stdexec::env_of_t< Rcvr > >, Domain >, ExecutionSpaceImpl::WithExecEnvPolicy, ExecutionSpaceImpl::WithoutExecEnvPolicy > exec_env_policy_t
typename base_t::execution_space execution_space
Impl::SubmittedOperationStateTag operation_state_concept
ContinuesOnOpState(Schd &&schd, Sndr &&sndr, Rcvr rcvr) noexcept(//NOLINT(cppcoreguidelines-rvalue-reference-param-not-moved) std::is_nothrow_constructible_v< base_t, Schd &&, Rcvr && > &&stdexec::__nothrow_connectable< Sndr &&, rcvr_t >)
stdexec::connect_result_t< Sndr, rcvr_t > inner_opstate_t
void complete(stdexec::set_value_t) noexcept
Impl::ContinuesOn::completion_signal_policy_t< inner_opstate_t, execution_space, Rcvr > completion_signal_policy_t
Impl::ContinuesOn::dependency_for_t< inner_opstate_t, execution_space > dependency_t
ContinuesOnReceiver< ContinuesOnOpState, stdexec::env_of_t< Rcvr > > rcvr_t
void complete(stdexec::set_stopped_t) noexcept
Receiver for continues_on.
typename ParentOp::exec_env_policy_t exec_env_policy_t
constexpr auto get_env() const noexcept -> ExecutionSpaceImpl::join_env_with_exec_t< exec_env_policy_t, Env, typename ParentOp::execution_space >
Sender for stdexec::continues_on.
stdexec::sender_tag sender_concept
static constexpr bool is_nothrow_connectable_v
ContinuesOnOpState< stdexec::__copy_cvref_t< Self, Schd >, stdexec::__copy_cvref_t< Self, Sndr >, Rcvr > connect_result_t
Wrap a Kokkos execution space to make it cheap to copy/move in new environments.
Receiver for an object parent_op that implements complete.
Kokkos::DefaultExecutionSpace execution_space
#define KOKKOS_EXECUTION_IMPL_MEMBER_CVREF_T(_Self_, _member_)
Yields the type of member _member_ as accessed from expression _Self_, preserving the cv and ref qual...
#define KOKKOS_EXECUTION_IMPL_FORWARD_THIS(_Self_, _self_)
Equivalent to std::forward<_Self_>(_self_).