diff options
Diffstat (limited to '3rdParty/Boost/src/boost/asio/strand.hpp')
| -rw-r--r-- | 3rdParty/Boost/src/boost/asio/strand.hpp | 44 | 
1 files changed, 37 insertions, 7 deletions
| diff --git a/3rdParty/Boost/src/boost/asio/strand.hpp b/3rdParty/Boost/src/boost/asio/strand.hpp index 6a1033f..f6b62fb 100644 --- a/3rdParty/Boost/src/boost/asio/strand.hpp +++ b/3rdParty/Boost/src/boost/asio/strand.hpp @@ -3,5 +3,5 @@  // ~~~~~~~~~~  // -// Copyright (c) 2003-2012 Christopher M. Kohlhoff (chris at kohlhoff dot com) +// Copyright (c) 2003-2014 Christopher M. Kohlhoff (chris at kohlhoff dot com)  //  // Distributed under the Boost Software License, Version 1.0. (See accompanying @@ -17,4 +17,5 @@  #include <boost/asio/detail/config.hpp> +#include <boost/asio/async_result.hpp>  #include <boost/asio/detail/handler_type_requirements.hpp>  #include <boost/asio/detail/strand_service.hpp> @@ -73,4 +74,7 @@ namespace asio {   * no ordering guarantee is made.   * + * @note The implementation makes no guarantee that handlers posted or + * dispatched through different @c strand objects will be invoked concurrently. + *   * @par Thread Safety   * @e Distinct @e objects: Safe.@n @@ -141,5 +145,6 @@ public:     */    template <typename CompletionHandler> -  void dispatch(BOOST_ASIO_MOVE_ARG(CompletionHandler) handler) +  BOOST_ASIO_INITFN_RESULT_TYPE(CompletionHandler, void ()) +  dispatch(BOOST_ASIO_MOVE_ARG(CompletionHandler) handler)    {      // If you get an error on the following line it means that your handler does @@ -147,5 +152,11 @@ public:      BOOST_ASIO_COMPLETION_HANDLER_CHECK(CompletionHandler, handler) type_check; -    service_.dispatch(impl_, BOOST_ASIO_MOVE_CAST(CompletionHandler)(handler)); +    detail::async_result_init< +      CompletionHandler, void ()> init( +        BOOST_ASIO_MOVE_CAST(CompletionHandler)(handler)); + +    service_.dispatch(impl_, init.handler); + +    return init.result.get();    } @@ -167,5 +178,6 @@ public:     */    template <typename CompletionHandler> -  void post(BOOST_ASIO_MOVE_ARG(CompletionHandler) handler) +  BOOST_ASIO_INITFN_RESULT_TYPE(CompletionHandler, void ()) +  post(BOOST_ASIO_MOVE_ARG(CompletionHandler) handler)    {      // If you get an error on the following line it means that your handler does @@ -173,5 +185,11 @@ public:      BOOST_ASIO_COMPLETION_HANDLER_CHECK(CompletionHandler, handler) type_check; -    service_.post(impl_, BOOST_ASIO_MOVE_CAST(CompletionHandler)(handler)); +    detail::async_result_init< +      CompletionHandler, void ()> init( +        BOOST_ASIO_MOVE_CAST(CompletionHandler)(handler)); + +    service_.post(impl_, init.handler); + +    return init.result.get();    } @@ -201,9 +219,21 @@ public:    unspecified  #else -  detail::wrapped_handler<strand, Handler> +  detail::wrapped_handler<strand, Handler, detail::is_continuation_if_running>  #endif    wrap(Handler handler)    { -    return detail::wrapped_handler<io_service::strand, Handler>(*this, handler); +    return detail::wrapped_handler<io_service::strand, Handler, +        detail::is_continuation_if_running>(*this, handler); +  } + +  /// Determine whether the strand is running in the current thread. +  /** +   * @return @c true if the current thread is executing a handler that was +   * submitted to the strand using post(), dispatch() or wrap(). Otherwise +   * returns @c false. +   */ +  bool running_in_this_thread() const +  { +    return service_.running_in_this_thread(impl_);    } | 
 Swift
 Swift