// // impl/post.hpp // ~~~~~~~~~~~~~ // // Copyright (c) 2003-2019 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_IMPL_POST_HPP #define BOOST_ASIO_IMPL_POST_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif // defined(_MSC_VER) && (_MSC_VER >= 1200) #include #include #include #include #include namespace boost { namespace asio { namespace detail { struct initiate_post { template void operator()(BOOST_ASIO_MOVE_ARG(CompletionHandler) handler) const { typedef typename decay::type DecayedHandler; typename associated_executor::type ex( (get_associated_executor)(handler)); typename associated_allocator::type alloc( (get_associated_allocator)(handler)); ex.post(BOOST_ASIO_MOVE_CAST(CompletionHandler)(handler), alloc); } template void operator()(BOOST_ASIO_MOVE_ARG(CompletionHandler) handler, BOOST_ASIO_MOVE_ARG(Executor) ex) const { typedef typename decay::type DecayedHandler; typename associated_allocator::type alloc( (get_associated_allocator)(handler)); ex.post(detail::work_dispatcher( BOOST_ASIO_MOVE_CAST(CompletionHandler)(handler)), alloc); } }; } // namespace detail template BOOST_ASIO_INITFN_RESULT_TYPE(CompletionToken, void()) post( BOOST_ASIO_MOVE_ARG(CompletionToken) token) { return async_initiate( detail::initiate_post(), token); } template BOOST_ASIO_INITFN_RESULT_TYPE(CompletionToken, void()) post( const Executor& ex, BOOST_ASIO_MOVE_ARG(CompletionToken) token, typename enable_if::value>::type*) { return async_initiate( detail::initiate_post(), token, ex); } template inline BOOST_ASIO_INITFN_RESULT_TYPE(CompletionToken, void()) post( ExecutionContext& ctx, BOOST_ASIO_MOVE_ARG(CompletionToken) token, typename enable_if::value>::type*) { return (post)(ctx.get_executor(), BOOST_ASIO_MOVE_CAST(CompletionToken)(token)); } } // namespace asio } // namespace boost #include #endif // BOOST_ASIO_IMPL_POST_HPP