| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303 | //// cancel_after.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_CANCEL_AFTER_HPP#define BOOST_ASIO_CANCEL_AFTER_HPP#if defined(_MSC_VER) && (_MSC_VER >= 1200)# pragma once#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)#include <boost/asio/detail/config.hpp>#include <boost/asio/basic_waitable_timer.hpp>#include <boost/asio/cancellation_type.hpp>#include <boost/asio/detail/chrono.hpp>#include <boost/asio/detail/type_traits.hpp>#include <boost/asio/wait_traits.hpp>#include <boost/asio/detail/push_options.hpp>namespace boost {namespace asio {/// A @ref completion_token adapter that cancels an operation after a timeout./** * The cancel_after_t class is used to indicate that an asynchronous operation * should be cancelled if not complete before the specified duration has * elapsed. */template <typename CompletionToken, typename Clock,    typename WaitTraits = boost::asio::wait_traits<Clock>>class cancel_after_t{public:  /// Constructor.  template <typename T>  cancel_after_t(T&& completion_token, const typename Clock::duration& timeout,      cancellation_type_t cancel_type = cancellation_type::terminal)    : token_(static_cast<T&&>(completion_token)),      timeout_(timeout),      cancel_type_(cancel_type)  {  }//private:  CompletionToken token_;  typename Clock::duration timeout_;  cancellation_type_t cancel_type_;};/// A @ref completion_token adapter that cancels an operation after a timeout./** * The cancel_after_timer class is used to indicate that an asynchronous * operation should be cancelled if not complete before the specified duration * has elapsed. */template <typename CompletionToken, typename Clock,    typename WaitTraits = boost::asio::wait_traits<Clock>,    typename Executor = any_io_executor>class cancel_after_timer{public:  /// Constructor.  template <typename T>  cancel_after_timer(T&& completion_token,      basic_waitable_timer<Clock, WaitTraits, Executor>& timer,      const typename Clock::duration& timeout,      cancellation_type_t cancel_type = cancellation_type::terminal)    : token_(static_cast<T&&>(completion_token)),      timer_(timer),      timeout_(timeout),      cancel_type_(cancel_type)  {  }//private:  CompletionToken token_;  basic_waitable_timer<Clock, WaitTraits, Executor>& timer_;  typename Clock::duration timeout_;  cancellation_type_t cancel_type_;};/// A function object type that adapts a @ref completion_token to cancel an/// operation after a timeout./** * May also be used directly as a completion token, in which case it adapts the * asynchronous operation's default completion token (or boost::asio::deferred * if no default is available). */template <typename Clock, typename WaitTraits = boost::asio::wait_traits<Clock>>class partial_cancel_after{public:  /// Constructor that specifies the timeout duration and cancellation type.  explicit partial_cancel_after(const typename Clock::duration& timeout,      cancellation_type_t cancel_type = cancellation_type::terminal)    : timeout_(timeout),      cancel_type_(cancel_type)  {  }  /// Adapt a @ref completion_token to specify that the completion handler  /// arguments should be combined into a single tuple argument.  template <typename CompletionToken>  BOOST_ASIO_NODISCARD inline  cancel_after_t<decay_t<CompletionToken>, Clock, WaitTraits>  operator()(CompletionToken&& completion_token) const  {    return cancel_after_t<decay_t<CompletionToken>, Clock, WaitTraits>(        static_cast<CompletionToken&&>(completion_token),        timeout_, cancel_type_);  }//private:  typename Clock::duration timeout_;  cancellation_type_t cancel_type_;};/// A function object type that adapts a @ref completion_token to cancel an/// operation after a timeout./** * May also be used directly as a completion token, in which case it adapts the * asynchronous operation's default completion token (or boost::asio::deferred * if no default is available). */template <typename Clock, typename WaitTraits = boost::asio::wait_traits<Clock>,    typename Executor = any_io_executor>class partial_cancel_after_timer{public:  /// Constructor that specifies the timeout duration and cancellation type.  explicit partial_cancel_after_timer(      basic_waitable_timer<Clock, WaitTraits, Executor>& timer,      const typename Clock::duration& timeout,      cancellation_type_t cancel_type = cancellation_type::terminal)    : timer_(timer),      timeout_(timeout),      cancel_type_(cancel_type)  {  }  /// Adapt a @ref completion_token to specify that the completion handler  /// arguments should be combined into a single tuple argument.  template <typename CompletionToken>  BOOST_ASIO_NODISCARD inline  cancel_after_timer<decay_t<CompletionToken>, Clock, WaitTraits, Executor>  operator()(CompletionToken&& completion_token) const  {    return cancel_after_timer<decay_t<CompletionToken>,      Clock, WaitTraits, Executor>(        static_cast<CompletionToken&&>(completion_token),        timeout_, cancel_type_);  }//private:  basic_waitable_timer<Clock, WaitTraits, Executor>& timer_;  typename Clock::duration timeout_;  cancellation_type_t cancel_type_;};/// Create a partial completion token adapter that cancels an operation if not/// complete before the specified relative timeout has elapsed./** * @par Thread Safety * When an asynchronous operation is used with cancel_after, a timer async_wait * operation is performed in parallel to the main operation. If this parallel * async_wait completes first, a cancellation request is emitted to cancel the * main operation. Consequently, the application must ensure that the * asynchronous operation is performed within an implicit or explicit strand. */template <typename Rep, typename Period>BOOST_ASIO_NODISCARD inline partial_cancel_after<chrono::steady_clock>cancel_after(const chrono::duration<Rep, Period>& timeout,    cancellation_type_t cancel_type = cancellation_type::terminal){  return partial_cancel_after<chrono::steady_clock>(timeout, cancel_type);}/// Create a partial completion token adapter that cancels an operation if not/// complete before the specified relative timeout has elapsed./** * @par Thread Safety * When an asynchronous operation is used with cancel_after, a timer async_wait * operation is performed in parallel to the main operation. If this parallel * async_wait completes first, a cancellation request is emitted to cancel the * main operation. Consequently, the application must ensure that the * asynchronous operation is performed within an implicit or explicit strand. */template <typename Clock, typename WaitTraits,    typename Executor, typename Rep, typename Period>BOOST_ASIO_NODISCARD inlinepartial_cancel_after_timer<Clock, WaitTraits, Executor>cancel_after(basic_waitable_timer<Clock, WaitTraits, Executor>& timer,    const chrono::duration<Rep, Period>& timeout,    cancellation_type_t cancel_type = cancellation_type::terminal){  return partial_cancel_after_timer<Clock, WaitTraits, Executor>(      timer, timeout, cancel_type);}/// Adapt a @ref completion_token to cancel an operation if not complete before/// the specified relative timeout has elapsed./** * @par Thread Safety * When an asynchronous operation is used with cancel_after, a timer async_wait * operation is performed in parallel to the main operation. If this parallel * async_wait completes first, a cancellation request is emitted to cancel the * main operation. Consequently, the application must ensure that the * asynchronous operation is performed within an implicit or explicit strand. */template <typename Rep, typename Period, typename CompletionToken>BOOST_ASIO_NODISCARD inlinecancel_after_t<decay_t<CompletionToken>, chrono::steady_clock>cancel_after(const chrono::duration<Rep, Period>& timeout,    CompletionToken&& completion_token){  return cancel_after_t<decay_t<CompletionToken>, chrono::steady_clock>(      static_cast<CompletionToken&&>(completion_token),      timeout, cancellation_type::terminal);}/// Adapt a @ref completion_token to cancel an operation if not complete before/// the specified relative timeout has elapsed./** * @par Thread Safety * When an asynchronous operation is used with cancel_after, a timer async_wait * operation is performed in parallel to the main operation. If this parallel * async_wait completes first, a cancellation request is emitted to cancel the * main operation. Consequently, the application must ensure that the * asynchronous operation is performed within an implicit or explicit strand. */template <typename Rep, typename Period, typename CompletionToken>BOOST_ASIO_NODISCARD inlinecancel_after_t<decay_t<CompletionToken>, chrono::steady_clock>cancel_after(const chrono::duration<Rep, Period>& timeout,    cancellation_type_t cancel_type, CompletionToken&& completion_token){  return cancel_after_t<decay_t<CompletionToken>, chrono::steady_clock>(      static_cast<CompletionToken&&>(completion_token), timeout, cancel_type);}/// Adapt a @ref completion_token to cancel an operation if not complete before/// the specified relative timeout has elapsed./** * @par Thread Safety * When an asynchronous operation is used with cancel_after, a timer async_wait * operation is performed in parallel to the main operation. If this parallel * async_wait completes first, a cancellation request is emitted to cancel the * main operation. Consequently, the application must ensure that the * asynchronous operation is performed within an implicit or explicit strand. */template <typename Clock, typename WaitTraits, typename Executor,    typename Rep, typename Period, typename CompletionToken>BOOST_ASIO_NODISCARD inlinecancel_after_timer<decay_t<CompletionToken>, Clock, WaitTraits, Executor>cancel_after(basic_waitable_timer<Clock, WaitTraits, Executor>& timer,    const chrono::duration<Rep, Period>& timeout,    CompletionToken&& completion_token){  return cancel_after_timer<decay_t<CompletionToken>,    Clock, WaitTraits, Executor>(      static_cast<CompletionToken&&>(completion_token),      timer, timeout, cancellation_type::terminal);}/// Adapt a @ref completion_token to cancel an operation if not complete before/// the specified relative timeout has elapsed./** * @par Thread Safety * When an asynchronous operation is used with cancel_after, a timer async_wait * operation is performed in parallel to the main operation. If this parallel * async_wait completes first, a cancellation request is emitted to cancel the * main operation. Consequently, the application must ensure that the * asynchronous operation is performed within an implicit or explicit strand. */template <typename Clock, typename WaitTraits, typename Executor,    typename Rep, typename Period, typename CompletionToken>BOOST_ASIO_NODISCARD inlinecancel_after_timer<decay_t<CompletionToken>, chrono::steady_clock>cancel_after(basic_waitable_timer<Clock, WaitTraits, Executor>& timer,    const chrono::duration<Rep, Period>& timeout,    cancellation_type_t cancel_type, CompletionToken&& completion_token){  return cancel_after_timer<decay_t<CompletionToken>,    Clock, WaitTraits, Executor>(      static_cast<CompletionToken&&>(completion_token),      timer, timeout, cancel_type);}} // namespace asio} // namespace boost#include <boost/asio/detail/pop_options.hpp>#include <boost/asio/impl/cancel_after.hpp>#endif // BOOST_ASIO_CANCEL_AFTER_HPP
 |