// // Copyright (c) 2016-2019 Vinnie Falco (vinnie dot falco at gmail 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) // // Official repository: https://github.com/boostorg/beast // #ifndef BOOST_BEAST_DETAIL_BIND_CONTINUATION_HPP #define BOOST_BEAST_DETAIL_BIND_CONTINUATION_HPP #include #include #include #include #include #include namespace boost { namespace beast { namespace detail { #if 0 /** Mark a completion handler as a continuation. This function wraps a completion handler to associate it with an executor whose `post` operation is remapped to the `defer` operation. It is used by composed asynchronous operation implementations to indicate that a completion handler submitted to an initiating function represents a continuation of the current asynchronous flow of control. @param handler The handler to wrap. The implementation takes ownership of the handler by performing a decay-copy. @see @li [N4242] Executors and Asynchronous Operations, Revision 1 */ template #if BOOST_BEAST_DOXYGEN __implementation_defined__ #else net::executor_binder< typename std::decay::type, detail::remap_post_to_defer< net::associated_executor_t>> #endif bind_continuation(CompletionHandler&& handler) { return net::bind_executor( detail::remap_post_to_defer< net::associated_executor_t>( net::get_associated_executor(handler)), std::forward(handler)); } /** Mark a completion handler as a continuation. This function wraps a completion handler to associate it with an executor whose `post` operation is remapped to the `defer` operation. It is used by composed asynchronous operation implementations to indicate that a completion handler submitted to an initiating function represents a continuation of the current asynchronous flow of control. @param ex The executor to use @param handler The handler to wrap The implementation takes ownership of the handler by performing a decay-copy. @see @li [N4242] Executors and Asynchronous Operations, Revision 1 */ template #if BOOST_BEAST_DOXYGEN __implementation_defined__ #else net::executor_binder::type, detail::remap_post_to_defer> #endif bind_continuation( Executor const& ex, CompletionHandler&& handler) { return net::bind_executor( detail::remap_post_to_defer(ex), std::forward(handler)); } #else // VFALCO I turned these off at the last minute because they cause // the completion handler to be moved before the initiating // function is invoked rather than after, which is a foot-gun. // // REMINDER: Uncomment the tests when this is put back template F&& bind_continuation(F&& f) { return std::forward(f); } #endif } // detail } // beast } // boost #endif