| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195 | //// detail/initiate_dispatch.hpp// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~//// Copyright (c) 2003-2024 Christopher M. Kohlhoff (chris at kohlhoff dot com)//// Distributed under the Boost Software License, Version 1.0. (See accompanying// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)//#ifndef BOOST_ASIO_DETAIL_INITIATE_DISPATCH_HPP#define BOOST_ASIO_DETAIL_INITIATE_DISPATCH_HPP#if defined(_MSC_VER) && (_MSC_VER >= 1200)# pragma once#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)#include <boost/asio/detail/config.hpp>#include <boost/asio/associated_allocator.hpp>#include <boost/asio/associated_executor.hpp>#include <boost/asio/detail/work_dispatcher.hpp>#include <boost/asio/execution/allocator.hpp>#include <boost/asio/execution/blocking.hpp>#include <boost/asio/prefer.hpp>#include <boost/asio/detail/push_options.hpp>namespace boost {namespace asio {namespace detail {class initiate_dispatch{public:  template <typename CompletionHandler>  void operator()(CompletionHandler&& handler,      enable_if_t<        execution::is_executor<          associated_executor_t<decay_t<CompletionHandler>>        >::value      >* = 0) const  {    associated_executor_t<decay_t<CompletionHandler>> ex(        (get_associated_executor)(handler));    associated_allocator_t<decay_t<CompletionHandler>> alloc(        (get_associated_allocator)(handler));    boost::asio::prefer(ex, execution::allocator(alloc)).execute(        boost::asio::detail::bind_handler(          static_cast<CompletionHandler&&>(handler)));  }  template <typename CompletionHandler>  void operator()(CompletionHandler&& handler,      enable_if_t<        !execution::is_executor<          associated_executor_t<decay_t<CompletionHandler>>        >::value      >* = 0) const  {    associated_executor_t<decay_t<CompletionHandler>> ex(        (get_associated_executor)(handler));    associated_allocator_t<decay_t<CompletionHandler>> alloc(        (get_associated_allocator)(handler));    ex.dispatch(boost::asio::detail::bind_handler(          static_cast<CompletionHandler&&>(handler)), alloc);  }};template <typename Executor>class initiate_dispatch_with_executor{public:  typedef Executor executor_type;  explicit initiate_dispatch_with_executor(const Executor& ex)    : ex_(ex)  {  }  executor_type get_executor() const noexcept  {    return ex_;  }  template <typename CompletionHandler>  void operator()(CompletionHandler&& handler,      enable_if_t<        execution::is_executor<          conditional_t<true, executor_type, CompletionHandler>        >::value      >* = 0,      enable_if_t<        !detail::is_work_dispatcher_required<          decay_t<CompletionHandler>,          Executor        >::value      >* = 0) const  {    associated_allocator_t<decay_t<CompletionHandler>> alloc(        (get_associated_allocator)(handler));    boost::asio::prefer(ex_, execution::allocator(alloc)).execute(        boost::asio::detail::bind_handler(          static_cast<CompletionHandler&&>(handler)));  }  template <typename CompletionHandler>  void operator()(CompletionHandler&& handler,      enable_if_t<        execution::is_executor<          conditional_t<true, executor_type, CompletionHandler>        >::value      >* = 0,      enable_if_t<        detail::is_work_dispatcher_required<          decay_t<CompletionHandler>,          Executor        >::value      >* = 0) const  {    typedef decay_t<CompletionHandler> handler_t;    typedef associated_executor_t<handler_t, Executor> handler_ex_t;    handler_ex_t handler_ex((get_associated_executor)(handler, ex_));    associated_allocator_t<handler_t> alloc(        (get_associated_allocator)(handler));    boost::asio::prefer(ex_, execution::allocator(alloc)).execute(        detail::work_dispatcher<handler_t, handler_ex_t>(          static_cast<CompletionHandler&&>(handler), handler_ex));  }  template <typename CompletionHandler>  void operator()(CompletionHandler&& handler,      enable_if_t<        !execution::is_executor<          conditional_t<true, executor_type, CompletionHandler>        >::value      >* = 0,      enable_if_t<        !detail::is_work_dispatcher_required<          decay_t<CompletionHandler>,          Executor        >::value      >* = 0) const  {    associated_allocator_t<decay_t<CompletionHandler>> alloc(        (get_associated_allocator)(handler));    ex_.dispatch(boost::asio::detail::bind_handler(          static_cast<CompletionHandler&&>(handler)), alloc);  }  template <typename CompletionHandler>  void operator()(CompletionHandler&& handler,      enable_if_t<        !execution::is_executor<          conditional_t<true, executor_type, CompletionHandler>        >::value      >* = 0,      enable_if_t<        detail::is_work_dispatcher_required<          decay_t<CompletionHandler>,          Executor        >::value      >* = 0) const  {    typedef decay_t<CompletionHandler> handler_t;    typedef associated_executor_t<handler_t, Executor> handler_ex_t;    handler_ex_t handler_ex((get_associated_executor)(handler, ex_));    associated_allocator_t<handler_t> alloc(        (get_associated_allocator)(handler));    ex_.dispatch(detail::work_dispatcher<handler_t, handler_ex_t>(          static_cast<CompletionHandler&&>(handler), handler_ex), alloc);  }private:  Executor ex_;};} // namespace detail} // namespace asio} // namespace boost#include <boost/asio/detail/pop_options.hpp>#endif // BOOST_ASIO_DETAIL_INITIATE_DISPATCH_HPP
 |