Imported Upstream version 1.64.0
[platform/upstream/boost.git] / libs / asio / doc / requirements / WaitHandler.qbk
1 [/
2  / Copyright (c) 2003-2017 Christopher M. Kohlhoff (chris at kohlhoff dot com)
3  /
4  / Distributed under the Boost Software License, Version 1.0. (See accompanying
5  / file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
6  /]
7
8 [section:WaitHandler Wait handler requirements]
9
10 A wait handler must meet the requirements for a [link
11 boost_asio.reference.Handler handler]. A value `h` of a wait handler class
12 should work correctly in the expression `h(ec)`, where `ec` is an lvalue of
13 type `const error_code`.
14
15 [heading Examples]
16
17 A free function as a wait handler:
18
19   void wait_handler(
20       const boost::system::error_code& ec)
21   {
22     ...
23   }
24
25 A wait handler function object:
26
27   struct wait_handler
28   {
29     ...
30     void operator()(
31         const boost::system::error_code& ec)
32     {
33       ...
34     }
35     ...
36   };
37
38 A non-static class member function adapted to a wait handler using `bind()`:
39
40   void my_class::wait_handler(
41       const boost::system::error_code& ec)
42   {
43     ...
44   }
45   ...
46   socket.async_wait(...,
47       boost::bind(&my_class::wait_handler,
48         this, boost::asio::placeholders::error));
49
50 [endsect]