Skip to content

Commit

Permalink
the let_* algorithms have a dependent domain, which causes a recursiv…
Browse files Browse the repository at this point in the history
…e tree transformation
  • Loading branch information
ericniebler committed Nov 6, 2023
1 parent 9fb4521 commit 83e85d7
Show file tree
Hide file tree
Showing 6 changed files with 551 additions and 253 deletions.
40 changes: 34 additions & 6 deletions include/exec/static_thread_pool.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,11 @@ namespace exec {
}
#endif

template <class>
struct not_a_sender {
using is_sender = void;
};

struct task_base {
task_base* next;
void (*__execute)(task_base*, std::uint32_t tid) noexcept;
Expand Down Expand Up @@ -215,21 +220,44 @@ namespace exec {
};
#endif

public:
struct domain {
// For eager customization
template <stdexec::sender_expr_for<stdexec::bulk_t> Sender>
auto transform_sender(Sender&& sndr) const noexcept {
auto sched = stdexec::get_completion_scheduler<stdexec::set_value_t>(
stdexec::get_env(sndr));
return stdexec::__sexpr_apply((Sender&&) sndr, transform_bulk{*sched.pool_});
if constexpr (stdexec::__completes_on<Sender, static_thread_pool::scheduler>) {
auto sched = stdexec::get_completion_scheduler<stdexec::set_value_t>(
stdexec::get_env(sndr));
return stdexec::__sexpr_apply((Sender&&) sndr, transform_bulk{*sched.pool_});
} else {
static_assert(
stdexec::__completes_on<Sender, static_thread_pool::scheduler>,
"No static_thread_pool instance can be found in the sender's environment "
"on which to schedule bulk work.");
return not_a_sender<stdexec::__name_of<Sender>>();
}
STDEXEC_UNREACHABLE();
}

// transform the generic bulk sender into a parallel thread-pool bulk sender
template <stdexec::sender_expr_for<stdexec::bulk_t> Sender, class Env>
requires stdexec::__callable<stdexec::get_scheduler_t, Env>
auto transform_sender(Sender&& sndr, const Env& env) const noexcept {
auto sched = stdexec::get_scheduler(env);
return stdexec::__sexpr_apply((Sender&&) sndr, transform_bulk{*sched.pool_});
if constexpr (stdexec::__completes_on<Sender, static_thread_pool::scheduler>) {
auto sched = stdexec::get_completion_scheduler<stdexec::set_value_t>(
stdexec::get_env(sndr));
return stdexec::__sexpr_apply((Sender&&) sndr, transform_bulk{*sched.pool_});
} else if constexpr (stdexec::__starts_on<Sender, static_thread_pool::scheduler, Env>) {
auto sched = stdexec::get_scheduler(env);
return stdexec::__sexpr_apply((Sender&&) sndr, transform_bulk{*sched.pool_});
} else {
static_assert( //
stdexec::__starts_on<Sender, static_thread_pool::scheduler, Env>
|| stdexec::__completes_on<Sender, static_thread_pool::scheduler>,
"No static_thread_pool instance can be found in the sender's or receiver's "
"environment on which to schedule bulk work.");
return not_a_sender<stdexec::__name_of<Sender>>();
}
STDEXEC_UNREACHABLE();
}

#if STDEXEC_HAS_STD_RANGES()
Expand Down
8 changes: 8 additions & 0 deletions include/stdexec/__detail/__execution_fwd.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -175,6 +175,14 @@ namespace stdexec {
using __transfer_just::transfer_just_t;
extern const transfer_just_t transfer_just;

//////////////////////////////////////////////////////////////////////////////////////////////////
namespace __bulk {
struct bulk_t;
}

using __bulk::bulk_t;
extern const bulk_t bulk;

//////////////////////////////////////////////////////////////////////////////////////////////////
namespace __on_v2 {
struct on_t;
Expand Down
3 changes: 3 additions & 0 deletions include/stdexec/concepts.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -234,6 +234,9 @@ namespace stdexec {
template <class _Ty>
concept __nothrow_decay_copyable = __nothrow_constructible_from<__decay_t<_Ty>, _Ty>;

template <class _Ty, class _Up>
concept __decays_to_derived_from = derived_from<__decay_t<_Ty>, _Up>;

} // namespace stdexec

// #if !STDEXEC_HAS_STD_CONCEPTS_HEADER()
Expand Down
Loading

0 comments on commit 83e85d7

Please sign in to comment.