// // execution/detail/submit_receiver.hpp // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // // Copyright (c) 2003-2022 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_EXECUTION_DETAIL_SUBMIT_RECEIVER_HPP #define BOOST_ASIO_EXECUTION_DETAIL_SUBMIT_RECEIVER_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif // defined(_MSC_VER) && (_MSC_VER >= 1200) #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace asio { namespace execution { namespace detail { template struct submit_receiver; template struct submit_receiver_wrapper { submit_receiver* p_; explicit submit_receiver_wrapper(submit_receiver* p) : p_(p) { } #if defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES) template typename enable_if::value>::type set_value(BOOST_ASIO_MOVE_ARG(Args)... args) BOOST_ASIO_RVALUE_REF_QUAL BOOST_ASIO_NOEXCEPT_IF((is_nothrow_receiver_of::value)) { execution::set_value( BOOST_ASIO_MOVE_OR_LVALUE( typename remove_cvref::type)(p_->r_), BOOST_ASIO_MOVE_CAST(Args)(args)...); delete p_; } #else // defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES) void set_value() BOOST_ASIO_RVALUE_REF_QUAL BOOST_ASIO_NOEXCEPT_IF((is_nothrow_receiver_of::value)) { execution::set_value( BOOST_ASIO_MOVE_OR_LVALUE( typename remove_cvref::type)(p_->r_)); delete p_; } #define BOOST_ASIO_PRIVATE_SUBMIT_RECEIVER_SET_VALUE_DEF(n) \ template \ typename enable_if::value>::type \ set_value(BOOST_ASIO_VARIADIC_MOVE_PARAMS(n)) BOOST_ASIO_RVALUE_REF_QUAL \ BOOST_ASIO_NOEXCEPT_IF((is_nothrow_receiver_of< \ Receiver, BOOST_ASIO_VARIADIC_TARGS(n)>::value)) \ { \ execution::set_value( \ BOOST_ASIO_MOVE_OR_LVALUE( \ typename remove_cvref::type)(p_->r_), \ BOOST_ASIO_VARIADIC_MOVE_ARGS(n)); \ delete p_; \ } \ /**/ BOOST_ASIO_VARIADIC_GENERATE(BOOST_ASIO_PRIVATE_SUBMIT_RECEIVER_SET_VALUE_DEF) #undef BOOST_ASIO_PRIVATE_SUBMIT_RECEIVER_SET_VALUE_DEF #endif // defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES) template void set_error(BOOST_ASIO_MOVE_ARG(E) e) BOOST_ASIO_RVALUE_REF_QUAL BOOST_ASIO_NOEXCEPT { execution::set_error( BOOST_ASIO_MOVE_OR_LVALUE( typename remove_cvref::type)(p_->r_), BOOST_ASIO_MOVE_CAST(E)(e)); delete p_; } void set_done() BOOST_ASIO_RVALUE_REF_QUAL BOOST_ASIO_NOEXCEPT { execution::set_done( BOOST_ASIO_MOVE_OR_LVALUE( typename remove_cvref::type)(p_->r_)); delete p_; } }; template struct submit_receiver { typename remove_cvref::type r_; #if defined(BOOST_ASIO_HAS_MOVE) typename connect_result >::type state_; #else // defined(BOOST_ASIO_HAS_MOVE) typename connect_result& >::type state_; #endif // defined(BOOST_ASIO_HAS_MOVE) #if defined(BOOST_ASIO_HAS_MOVE) template explicit submit_receiver(BOOST_ASIO_MOVE_ARG(S) s, BOOST_ASIO_MOVE_ARG(R) r) : r_(BOOST_ASIO_MOVE_CAST(R)(r)), state_(execution::connect(BOOST_ASIO_MOVE_CAST(S)(s), submit_receiver_wrapper(this))) { } #else // defined(BOOST_ASIO_HAS_MOVE) explicit submit_receiver(Sender s, Receiver r) : r_(r), state_(execution::connect(s, submit_receiver_wrapper(this))) { } #endif // defined(BOOST_ASIO_HAS_MOVE) }; } // namespace detail } // namespace execution namespace traits { #if !defined(BOOST_ASIO_HAS_DEDUCED_SET_VALUE_MEMBER_TRAIT) #if defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES) template struct set_value_member< boost::asio::execution::detail::submit_receiver_wrapper< Sender, Receiver>, void(Args...)> { BOOST_ASIO_STATIC_CONSTEXPR(bool, is_valid = true); BOOST_ASIO_STATIC_CONSTEXPR(bool, is_noexcept = (boost::asio::execution::is_nothrow_receiver_of::value)); typedef void result_type; }; #else // defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES) template struct set_value_member< boost::asio::execution::detail::submit_receiver_wrapper< Sender, Receiver>, void()> { BOOST_ASIO_STATIC_CONSTEXPR(bool, is_valid = true); BOOST_ASIO_STATIC_CONSTEXPR(bool, is_noexcept = boost::asio::execution::is_nothrow_receiver_of::value); typedef void result_type; }; #define BOOST_ASIO_PRIVATE_SUBMIT_RECEIVER_TRAIT_DEF(n) \ template \ struct set_value_member< \ boost::asio::execution::detail::submit_receiver_wrapper< \ Sender, Receiver>, \ void(BOOST_ASIO_VARIADIC_TARGS(n))> \ { \ BOOST_ASIO_STATIC_CONSTEXPR(bool, is_valid = true); \ BOOST_ASIO_STATIC_CONSTEXPR(bool, is_noexcept = \ (boost::asio::execution::is_nothrow_receiver_of::value)); \ typedef void result_type; \ }; \ /**/ BOOST_ASIO_VARIADIC_GENERATE(BOOST_ASIO_PRIVATE_SUBMIT_RECEIVER_TRAIT_DEF) #undef BOOST_ASIO_PRIVATE_SUBMIT_RECEIVER_TRAIT_DEF #endif // defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES) #endif // !defined(BOOST_ASIO_HAS_DEDUCED_SET_VALUE_MEMBER_TRAIT) #if !defined(BOOST_ASIO_HAS_DEDUCED_SET_ERROR_MEMBER_TRAIT) template struct set_error_member< boost::asio::execution::detail::submit_receiver_wrapper< Sender, Receiver>, E> { BOOST_ASIO_STATIC_CONSTEXPR(bool, is_valid = true); BOOST_ASIO_STATIC_CONSTEXPR(bool, is_noexcept = true); typedef void result_type; }; #endif // !defined(BOOST_ASIO_HAS_DEDUCED_SET_ERROR_MEMBER_TRAIT) #if !defined(BOOST_ASIO_HAS_DEDUCED_SET_DONE_MEMBER_TRAIT) template struct set_done_member< boost::asio::execution::detail::submit_receiver_wrapper< Sender, Receiver> > { BOOST_ASIO_STATIC_CONSTEXPR(bool, is_valid = true); BOOST_ASIO_STATIC_CONSTEXPR(bool, is_noexcept = true); typedef void result_type; }; #endif // !defined(BOOST_ASIO_HAS_DEDUCED_SET_DONE_MEMBER_TRAIT) } // namespace traits } // namespace asio } // namespace boost #include #endif // BOOST_ASIO_EXECUTION_DETAIL_SUBMIT_RECEIVER_HPP