// // consign.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_CONSIGN_HPP #define BOOST_ASIO_CONSIGN_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif // defined(_MSC_VER) && (_MSC_VER >= 1200) #include #include #include #include namespace boost { namespace asio { /// Completion token type used to specify that the completion handler should /// carry additional values along with it. /** * This completion token adapter is typically used to keep at least one copy of * an object, such as a smart pointer, alive until the completion handler is * called. */ template class consign_t { public: /// Constructor. template constexpr explicit consign_t(T&& completion_token, V&&... values) : token_(static_cast(completion_token)), values_(static_cast(values)...) { } #if defined(GENERATING_DOCUMENTATION) private: #endif // defined(GENERATING_DOCUMENTATION) CompletionToken token_; std::tuple values_; }; /// Completion token adapter used to specify that the completion handler should /// carry additional values along with it. /** * This completion token adapter is typically used to keep at least one copy of * an object, such as a smart pointer, alive until the completion handler is * called. */ template BOOST_ASIO_NODISCARD inline constexpr consign_t, decay_t...> consign(CompletionToken&& completion_token, Values&&... values) { return consign_t, decay_t...>( static_cast(completion_token), static_cast(values)...); } } // namespace asio } // namespace boost #include #include #endif // BOOST_ASIO_CONSIGN_HPP