%PDF- %PDF-
| Direktori : /usr/include/boost/beast/core/detail/ |
| Current File : //usr/include/boost/beast/core/detail/bind_default_executor.hpp |
//
// 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_CORE_DETAIL_BIND_DEFAULT_EXECUTOR_HPP
#define BOOST_BEAST_CORE_DETAIL_BIND_DEFAULT_EXECUTOR_HPP
#include <boost/asio/associated_allocator.hpp>
#include <boost/asio/associated_executor.hpp>
#include <boost/asio/dispatch.hpp>
#include <boost/asio/executor.hpp>
#include <boost/asio/handler_alloc_hook.hpp>
#include <boost/asio/handler_continuation_hook.hpp>
#include <boost/asio/handler_invoke_hook.hpp>
#include <boost/core/empty_value.hpp>
#include <utility>
namespace boost {
namespace beast {
namespace detail {
template<class Handler, class Executor>
class bind_default_executor_wrapper
: private boost::empty_value<Executor>
{
Handler h_;
public:
template<class Handler_>
bind_default_executor_wrapper(
Handler_&& h,
Executor const& ex)
: boost::empty_value<Executor>(
boost::empty_init_t{}, ex)
, h_(std::forward<Handler_>(h))
{
}
template<class... Args>
void
operator()(Args&&... args)
{
h_(std::forward<Args>(args)...);
}
using allocator_type =
net::associated_allocator_t<Handler>;
allocator_type
get_allocator() const noexcept
{
return net::get_associated_allocator(h_);
}
using executor_type =
net::associated_executor_t<Handler, Executor>;
executor_type
get_executor() const noexcept
{
return net::get_associated_executor(
h_, this->get());
}
// The allocation hooks are still defined because they trivially forward to
// user hooks. Forward here ensures that the user will get a compile error
// if they build their code with BOOST_ASIO_NO_DEPRECATED.
friend
boost::asio::asio_handler_allocate_is_deprecated
asio_handler_allocate(
std::size_t size, bind_default_executor_wrapper* p)
{
using boost::asio::asio_handler_allocate;
return asio_handler_allocate(
size, std::addressof(p->h_));
}
friend
boost::asio::asio_handler_deallocate_is_deprecated
asio_handler_deallocate(
void* mem, std::size_t size,
bind_default_executor_wrapper* p)
{
using boost::asio::asio_handler_deallocate;
return asio_handler_deallocate(mem, size,
std::addressof(p->h_));
}
friend
bool asio_handler_is_continuation(
bind_default_executor_wrapper* p)
{
using boost::asio::asio_handler_is_continuation;
return asio_handler_is_continuation(
std::addressof(p->h_));
}
};
template<class Executor, class Handler>
auto
bind_default_executor(Executor const& ex, Handler&& h) ->
bind_default_executor_wrapper<
typename std::decay<Handler>::type,
Executor>
{
return bind_default_executor_wrapper<
typename std::decay<Handler>::type,
Executor>(std::forward<Handler>(h), ex);
}
} // detail
} // beast
} // boost
#endif