]> git.proxmox.com Git - ceph.git/blame - ceph/src/boost/boost/asio/async_result.hpp
import quincy beta 17.1.0
[ceph.git] / ceph / src / boost / boost / asio / async_result.hpp
CommitLineData
b32b8144
FG
1//
2// async_result.hpp
3// ~~~~~~~~~~~~~~~~
4//
f67539c2 5// Copyright (c) 2003-2020 Christopher M. Kohlhoff (chris at kohlhoff dot com)
b32b8144
FG
6//
7// Distributed under the Boost Software License, Version 1.0. (See accompanying
8// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
9//
10
11#ifndef BOOST_ASIO_ASYNC_RESULT_HPP
12#define BOOST_ASIO_ASYNC_RESULT_HPP
13
14#if defined(_MSC_VER) && (_MSC_VER >= 1200)
15# pragma once
16#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
17
18#include <boost/asio/detail/config.hpp>
19#include <boost/asio/detail/type_traits.hpp>
92f5a8d4 20#include <boost/asio/detail/variadic_templates.hpp>
b32b8144
FG
21
22#include <boost/asio/detail/push_options.hpp>
23
24namespace boost {
25namespace asio {
26
92f5a8d4
TL
27#if defined(BOOST_ASIO_HAS_CONCEPTS) \
28 && defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES) \
29 && defined(BOOST_ASIO_HAS_DECLTYPE)
30
31namespace detail {
32
33template <typename T>
34struct is_completion_signature : false_type
35{
36};
37
38template <typename R, typename... Args>
39struct is_completion_signature<R(Args...)> : true_type
40{
41};
42
43template <typename T, typename... Args>
44BOOST_ASIO_CONCEPT callable_with = requires(T t, Args&&... args)
45{
46 t(static_cast<Args&&>(args)...);
47};
48
49template <typename T, typename Signature>
50struct is_completion_handler_for : false_type
51{
52};
53
54template <typename T, typename R, typename... Args>
55struct is_completion_handler_for<T, R(Args...)>
56 : integral_constant<bool, (callable_with<T, Args...>)>
57{
58};
59
60} // namespace detail
61
62template <typename T>
63BOOST_ASIO_CONCEPT completion_signature =
64 detail::is_completion_signature<T>::value;
65
66#define BOOST_ASIO_COMPLETION_SIGNATURE \
67 ::boost::asio::completion_signature
68
f67539c2 69template <typename T, typename Signature>
92f5a8d4 70BOOST_ASIO_CONCEPT completion_handler_for =
f67539c2
TL
71 detail::is_completion_signature<Signature>::value
72 && detail::is_completion_handler_for<T, Signature>::value;
92f5a8d4
TL
73
74#define BOOST_ASIO_COMPLETION_HANDLER_FOR(s) \
75 ::boost::asio::completion_handler_for<s>
76
77#else // defined(BOOST_ASIO_HAS_CONCEPTS)
78 // && defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES)
79 // && defined(BOOST_ASIO_HAS_DECLTYPE)
80
81#define BOOST_ASIO_COMPLETION_SIGNATURE typename
82#define BOOST_ASIO_COMPLETION_HANDLER_FOR(s) typename
83
84#endif // defined(BOOST_ASIO_HAS_CONCEPTS)
85 // && defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES)
86 // && defined(BOOST_ASIO_HAS_DECLTYPE)
87
b32b8144
FG
88/// An interface for customising the behaviour of an initiating function.
89/**
90 * The async_result traits class is used for determining:
91 *
92 * @li the concrete completion handler type to be called at the end of the
93 * asynchronous operation;
94 *
95 * @li the initiating function return type; and
96 *
97 * @li how the return value of the initiating function is obtained.
98 *
99 * The trait allows the handler and return types to be determined at the point
100 * where the specific completion handler signature is known.
101 *
102 * This template may be specialised for user-defined completion token types.
103 * The primary template assumes that the CompletionToken is the completion
104 * handler.
105 */
92f5a8d4 106template <typename CompletionToken, BOOST_ASIO_COMPLETION_SIGNATURE Signature>
b32b8144
FG
107class async_result
108{
109public:
b32b8144
FG
110 /// The concrete completion handler type for the specific signature.
111 typedef CompletionToken completion_handler_type;
112
113 /// The return type of the initiating function.
114 typedef void return_type;
b32b8144
FG
115
116 /// Construct an async result from a given handler.
117 /**
118 * When using a specalised async_result, the constructor has an opportunity
119 * to initialise some state associated with the completion handler, which is
120 * then returned from the initiating function.
121 */
122 explicit async_result(completion_handler_type& h)
b32b8144
FG
123 {
124 (void)h;
125 }
126
127 /// Obtain the value to be returned from the initiating function.
128 return_type get()
129 {
b32b8144
FG
130 }
131
92f5a8d4 132#if defined(GENERATING_DOCUMENTATION)
b32b8144 133
92f5a8d4
TL
134 /// Initiate the asynchronous operation that will produce the result, and
135 /// obtain the value to be returned from the initiating function.
136 template <typename Initiation, typename RawCompletionToken, typename... Args>
137 static return_type initiate(
138 BOOST_ASIO_MOVE_ARG(Initiation) initiation,
139 BOOST_ASIO_MOVE_ARG(RawCompletionToken) token,
140 BOOST_ASIO_MOVE_ARG(Args)... args);
b32b8144 141
92f5a8d4 142#elif defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES)
b32b8144 143
92f5a8d4
TL
144 template <typename Initiation,
145 BOOST_ASIO_COMPLETION_HANDLER_FOR(Signature) RawCompletionToken,
146 typename... Args>
147 static return_type initiate(
148 BOOST_ASIO_MOVE_ARG(Initiation) initiation,
149 BOOST_ASIO_MOVE_ARG(RawCompletionToken) token,
150 BOOST_ASIO_MOVE_ARG(Args)... args)
b32b8144 151 {
92f5a8d4
TL
152 BOOST_ASIO_MOVE_CAST(Initiation)(initiation)(
153 BOOST_ASIO_MOVE_CAST(RawCompletionToken)(token),
154 BOOST_ASIO_MOVE_CAST(Args)(args)...);
b32b8144
FG
155 }
156
92f5a8d4
TL
157#else // defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES)
158
159 template <typename Initiation,
160 BOOST_ASIO_COMPLETION_HANDLER_FOR(Signature) RawCompletionToken>
161 static return_type initiate(
162 BOOST_ASIO_MOVE_ARG(Initiation) initiation,
163 BOOST_ASIO_MOVE_ARG(RawCompletionToken) token)
b32b8144 164 {
92f5a8d4
TL
165 BOOST_ASIO_MOVE_CAST(Initiation)(initiation)(
166 BOOST_ASIO_MOVE_CAST(RawCompletionToken)(token));
b32b8144 167 }
92f5a8d4
TL
168
169#define BOOST_ASIO_PRIVATE_INITIATE_DEF(n) \
170 template <typename Initiation, \
171 BOOST_ASIO_COMPLETION_HANDLER_FOR(Signature) RawCompletionToken, \
172 BOOST_ASIO_VARIADIC_TPARAMS(n)> \
173 static return_type initiate( \
174 BOOST_ASIO_MOVE_ARG(Initiation) initiation, \
175 BOOST_ASIO_MOVE_ARG(RawCompletionToken) token, \
176 BOOST_ASIO_VARIADIC_MOVE_PARAMS(n)) \
177 { \
178 BOOST_ASIO_MOVE_CAST(Initiation)(initiation)( \
179 BOOST_ASIO_MOVE_CAST(RawCompletionToken)(token), \
180 BOOST_ASIO_VARIADIC_MOVE_ARGS(n)); \
181 } \
182 /**/
183 BOOST_ASIO_VARIADIC_GENERATE(BOOST_ASIO_PRIVATE_INITIATE_DEF)
184#undef BOOST_ASIO_PRIVATE_INITIATE_DEF
185
186#endif // defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES)
187
188private:
189 async_result(const async_result&) BOOST_ASIO_DELETED;
190 async_result& operator=(const async_result&) BOOST_ASIO_DELETED;
191};
192
193#if !defined(GENERATING_DOCUMENTATION)
194
195template <BOOST_ASIO_COMPLETION_SIGNATURE Signature>
196class async_result<void, Signature>
197{
198 // Empty.
b32b8144
FG
199};
200
92f5a8d4 201#endif // !defined(GENERATING_DOCUMENTATION)
b32b8144
FG
202
203/// Helper template to deduce the handler type from a CompletionToken, capture
204/// a local copy of the handler, and then create an async_result for the
205/// handler.
92f5a8d4 206template <typename CompletionToken, BOOST_ASIO_COMPLETION_SIGNATURE Signature>
b32b8144
FG
207struct async_completion
208{
209 /// The real handler type to be used for the asynchronous operation.
210 typedef typename boost::asio::async_result<
211 typename decay<CompletionToken>::type,
212 Signature>::completion_handler_type completion_handler_type;
213
214#if defined(BOOST_ASIO_HAS_MOVE) || defined(GENERATING_DOCUMENTATION)
215 /// Constructor.
216 /**
217 * The constructor creates the concrete completion handler and makes the link
218 * between the handler and the asynchronous result.
219 */
220 explicit async_completion(CompletionToken& token)
221 : completion_handler(static_cast<typename conditional<
222 is_same<CompletionToken, completion_handler_type>::value,
223 completion_handler_type&, CompletionToken&&>::type>(token)),
224 result(completion_handler)
225 {
226 }
227#else // defined(BOOST_ASIO_HAS_MOVE) || defined(GENERATING_DOCUMENTATION)
228 explicit async_completion(typename decay<CompletionToken>::type& token)
229 : completion_handler(token),
230 result(completion_handler)
231 {
232 }
233
234 explicit async_completion(const typename decay<CompletionToken>::type& token)
235 : completion_handler(token),
236 result(completion_handler)
237 {
238 }
239#endif // defined(BOOST_ASIO_HAS_MOVE) || defined(GENERATING_DOCUMENTATION)
240
241 /// A copy of, or reference to, a real handler object.
242#if defined(BOOST_ASIO_HAS_MOVE) || defined(GENERATING_DOCUMENTATION)
243 typename conditional<
244 is_same<CompletionToken, completion_handler_type>::value,
245 completion_handler_type&, completion_handler_type>::type completion_handler;
246#else // defined(BOOST_ASIO_HAS_MOVE) || defined(GENERATING_DOCUMENTATION)
247 completion_handler_type completion_handler;
248#endif // defined(BOOST_ASIO_HAS_MOVE) || defined(GENERATING_DOCUMENTATION)
249
250 /// The result of the asynchronous operation's initiating function.
251 async_result<typename decay<CompletionToken>::type, Signature> result;
252};
253
254namespace detail {
255
256template <typename CompletionToken, typename Signature>
257struct async_result_helper
258 : async_result<typename decay<CompletionToken>::type, Signature>
259{
260};
261
92f5a8d4
TL
262struct async_result_memfns_base
263{
264 void initiate();
265};
b32b8144 266
92f5a8d4
TL
267template <typename T>
268struct async_result_memfns_derived
269 : T, async_result_memfns_base
270{
271};
272
273template <typename T, T>
274struct async_result_memfns_check
275{
276};
277
278template <typename>
279char (&async_result_initiate_memfn_helper(...))[2];
280
281template <typename T>
282char async_result_initiate_memfn_helper(
283 async_result_memfns_check<
284 void (async_result_memfns_base::*)(),
285 &async_result_memfns_derived<T>::initiate>*);
286
287template <typename CompletionToken, typename Signature>
288struct async_result_has_initiate_memfn
289 : integral_constant<bool, sizeof(async_result_initiate_memfn_helper<
290 async_result<typename decay<CompletionToken>::type, Signature>
291 >(0)) != 1>
292{
293};
294
295} // namespace detail
b32b8144
FG
296
297#if defined(GENERATING_DOCUMENTATION)
298# define BOOST_ASIO_INITFN_RESULT_TYPE(ct, sig) \
299 void_or_deduced
300#elif defined(_MSC_VER) && (_MSC_VER < 1500)
301# define BOOST_ASIO_INITFN_RESULT_TYPE(ct, sig) \
302 typename ::boost::asio::detail::async_result_helper< \
303 ct, sig>::return_type
304#define BOOST_ASIO_HANDLER_TYPE(ct, sig) \
305 typename ::boost::asio::detail::async_result_helper< \
306 ct, sig>::completion_handler_type
307#else
308# define BOOST_ASIO_INITFN_RESULT_TYPE(ct, sig) \
309 typename ::boost::asio::async_result< \
310 typename ::boost::asio::decay<ct>::type, sig>::return_type
311#define BOOST_ASIO_HANDLER_TYPE(ct, sig) \
312 typename ::boost::asio::async_result< \
313 typename ::boost::asio::decay<ct>::type, sig>::completion_handler_type
314#endif
315
20effc67 316#if defined(GENERATING_DOCUMENTATION)
92f5a8d4
TL
317# define BOOST_ASIO_INITFN_AUTO_RESULT_TYPE(ct, sig) \
318 auto
319#elif defined(BOOST_ASIO_HAS_RETURN_TYPE_DEDUCTION)
320# define BOOST_ASIO_INITFN_AUTO_RESULT_TYPE(ct, sig) \
321 auto
322#else
323# define BOOST_ASIO_INITFN_AUTO_RESULT_TYPE(ct, sig) \
324 BOOST_ASIO_INITFN_RESULT_TYPE(ct, sig)
325#endif
326
20effc67 327#if defined(GENERATING_DOCUMENTATION)
92f5a8d4
TL
328# define BOOST_ASIO_INITFN_DEDUCED_RESULT_TYPE(ct, sig, expr) \
329 void_or_deduced
330#elif defined(BOOST_ASIO_HAS_DECLTYPE)
331# define BOOST_ASIO_INITFN_DEDUCED_RESULT_TYPE(ct, sig, expr) \
332 decltype expr
333#else
334# define BOOST_ASIO_INITFN_DEDUCED_RESULT_TYPE(ct, sig, expr) \
335 BOOST_ASIO_INITFN_RESULT_TYPE(ct, sig)
336#endif
337
338#if defined(GENERATING_DOCUMENTATION)
339
340template <typename CompletionToken,
341 completion_signature Signature,
342 typename Initiation, typename... Args>
343void_or_deduced async_initiate(
344 BOOST_ASIO_MOVE_ARG(Initiation) initiation,
345 BOOST_ASIO_NONDEDUCED_MOVE_ARG(CompletionToken),
346 BOOST_ASIO_MOVE_ARG(Args)... args);
347
348#elif defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES)
349
350template <typename CompletionToken,
351 BOOST_ASIO_COMPLETION_SIGNATURE Signature,
352 typename Initiation, typename... Args>
353inline typename enable_if<
354 detail::async_result_has_initiate_memfn<CompletionToken, Signature>::value,
355 BOOST_ASIO_INITFN_DEDUCED_RESULT_TYPE(CompletionToken, Signature,
356 (async_result<typename decay<CompletionToken>::type,
357 Signature>::initiate(declval<BOOST_ASIO_MOVE_ARG(Initiation)>(),
358 declval<BOOST_ASIO_MOVE_ARG(CompletionToken)>(),
359 declval<BOOST_ASIO_MOVE_ARG(Args)>()...)))>::type
360async_initiate(BOOST_ASIO_MOVE_ARG(Initiation) initiation,
361 BOOST_ASIO_NONDEDUCED_MOVE_ARG(CompletionToken) token,
362 BOOST_ASIO_MOVE_ARG(Args)... args)
363{
364 return async_result<typename decay<CompletionToken>::type,
365 Signature>::initiate(BOOST_ASIO_MOVE_CAST(Initiation)(initiation),
366 BOOST_ASIO_MOVE_CAST(CompletionToken)(token),
367 BOOST_ASIO_MOVE_CAST(Args)(args)...);
368}
369
370template <typename CompletionToken,
371 BOOST_ASIO_COMPLETION_SIGNATURE Signature,
372 typename Initiation, typename... Args>
373inline typename enable_if<
374 !detail::async_result_has_initiate_memfn<CompletionToken, Signature>::value,
375 BOOST_ASIO_INITFN_RESULT_TYPE(CompletionToken, Signature)>::type
376async_initiate(BOOST_ASIO_MOVE_ARG(Initiation) initiation,
377 BOOST_ASIO_NONDEDUCED_MOVE_ARG(CompletionToken) token,
378 BOOST_ASIO_MOVE_ARG(Args)... args)
379{
380 async_completion<CompletionToken, Signature> completion(token);
381
382 BOOST_ASIO_MOVE_CAST(Initiation)(initiation)(
383 BOOST_ASIO_MOVE_CAST(BOOST_ASIO_HANDLER_TYPE(CompletionToken,
384 Signature))(completion.completion_handler),
385 BOOST_ASIO_MOVE_CAST(Args)(args)...);
386
387 return completion.result.get();
388}
389
390#else // defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES)
391
392template <typename CompletionToken,
393 BOOST_ASIO_COMPLETION_SIGNATURE Signature,
394 typename Initiation>
395inline typename enable_if<
396 detail::async_result_has_initiate_memfn<CompletionToken, Signature>::value,
397 BOOST_ASIO_INITFN_DEDUCED_RESULT_TYPE(CompletionToken, Signature,
398 (async_result<typename decay<CompletionToken>::type,
399 Signature>::initiate(declval<BOOST_ASIO_MOVE_ARG(Initiation)>(),
400 declval<BOOST_ASIO_MOVE_ARG(CompletionToken)>())))>::type
401async_initiate(BOOST_ASIO_MOVE_ARG(Initiation) initiation,
402 BOOST_ASIO_NONDEDUCED_MOVE_ARG(CompletionToken) token)
403{
404 return async_result<typename decay<CompletionToken>::type,
405 Signature>::initiate(BOOST_ASIO_MOVE_CAST(Initiation)(initiation),
406 BOOST_ASIO_MOVE_CAST(CompletionToken)(token));
407}
408
409template <typename CompletionToken,
410 BOOST_ASIO_COMPLETION_SIGNATURE Signature,
411 typename Initiation>
412inline typename enable_if<
413 !detail::async_result_has_initiate_memfn<CompletionToken, Signature>::value,
414 BOOST_ASIO_INITFN_RESULT_TYPE(CompletionToken, Signature)>::type
415async_initiate(BOOST_ASIO_MOVE_ARG(Initiation) initiation,
416 BOOST_ASIO_NONDEDUCED_MOVE_ARG(CompletionToken) token)
417{
418 async_completion<CompletionToken, Signature> completion(token);
419
420 BOOST_ASIO_MOVE_CAST(Initiation)(initiation)(
421 BOOST_ASIO_MOVE_CAST(BOOST_ASIO_HANDLER_TYPE(CompletionToken,
422 Signature))(completion.completion_handler));
423
424 return completion.result.get();
425}
426
427#define BOOST_ASIO_PRIVATE_INITIATE_DEF(n) \
428 template <typename CompletionToken, \
429 BOOST_ASIO_COMPLETION_SIGNATURE Signature, \
430 typename Initiation, BOOST_ASIO_VARIADIC_TPARAMS(n)> \
431 inline typename enable_if< \
432 detail::async_result_has_initiate_memfn< \
433 CompletionToken, Signature>::value, \
434 BOOST_ASIO_INITFN_DEDUCED_RESULT_TYPE(CompletionToken, Signature, \
435 (async_result<typename decay<CompletionToken>::type, \
436 Signature>::initiate(declval<BOOST_ASIO_MOVE_ARG(Initiation)>(), \
437 declval<BOOST_ASIO_MOVE_ARG(CompletionToken)>(), \
438 BOOST_ASIO_VARIADIC_MOVE_DECLVAL(n))))>::type \
439 async_initiate(BOOST_ASIO_MOVE_ARG(Initiation) initiation, \
440 BOOST_ASIO_NONDEDUCED_MOVE_ARG(CompletionToken) token, \
441 BOOST_ASIO_VARIADIC_MOVE_PARAMS(n)) \
442 { \
443 return async_result<typename decay<CompletionToken>::type, \
444 Signature>::initiate(BOOST_ASIO_MOVE_CAST(Initiation)(initiation), \
445 BOOST_ASIO_MOVE_CAST(CompletionToken)(token), \
446 BOOST_ASIO_VARIADIC_MOVE_ARGS(n)); \
447 } \
448 \
449 template <typename CompletionToken, \
450 BOOST_ASIO_COMPLETION_SIGNATURE Signature, \
451 typename Initiation, BOOST_ASIO_VARIADIC_TPARAMS(n)> \
452 inline typename enable_if< \
453 !detail::async_result_has_initiate_memfn< \
454 CompletionToken, Signature>::value, \
455 BOOST_ASIO_INITFN_RESULT_TYPE(CompletionToken, Signature)>::type \
456 async_initiate(BOOST_ASIO_MOVE_ARG(Initiation) initiation, \
457 BOOST_ASIO_NONDEDUCED_MOVE_ARG(CompletionToken) token, \
458 BOOST_ASIO_VARIADIC_MOVE_PARAMS(n)) \
459 { \
460 async_completion<CompletionToken, Signature> completion(token); \
461 \
462 BOOST_ASIO_MOVE_CAST(Initiation)(initiation)( \
463 BOOST_ASIO_MOVE_CAST(BOOST_ASIO_HANDLER_TYPE(CompletionToken, \
464 Signature))(completion.completion_handler), \
465 BOOST_ASIO_VARIADIC_MOVE_ARGS(n)); \
466 \
467 return completion.result.get(); \
468 } \
469 /**/
470 BOOST_ASIO_VARIADIC_GENERATE(BOOST_ASIO_PRIVATE_INITIATE_DEF)
471#undef BOOST_ASIO_PRIVATE_INITIATE_DEF
472
473#endif // defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES)
474
475#if defined(BOOST_ASIO_HAS_CONCEPTS) \
476 && defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES) \
477 && defined(BOOST_ASIO_HAS_DECLTYPE)
478
479namespace detail {
480
481template <typename Signature>
482struct initiation_archetype
483{
484 template <completion_handler_for<Signature> CompletionHandler>
485 void operator()(CompletionHandler&&) const
486 {
487 }
488};
489
490} // namespace detail
491
f67539c2
TL
492template <typename T, typename Signature>
493BOOST_ASIO_CONCEPT completion_token_for =
494 detail::is_completion_signature<Signature>::value
495 &&
496 requires(T&& t)
497 {
498 async_initiate<T, Signature>(detail::initiation_archetype<Signature>{}, t);
499 };
92f5a8d4
TL
500
501#define BOOST_ASIO_COMPLETION_TOKEN_FOR(s) \
502 ::boost::asio::completion_token_for<s>
503
504#else // defined(BOOST_ASIO_HAS_CONCEPTS)
505 // && defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES)
506 // && defined(BOOST_ASIO_HAS_DECLTYPE)
507
508#define BOOST_ASIO_COMPLETION_TOKEN_FOR(s) typename
509
510#endif // defined(BOOST_ASIO_HAS_CONCEPTS)
511 // && defined(BOOST_ASIO_HAS_VARIADIC_TEMPLATES)
512 // && defined(BOOST_ASIO_HAS_DECLTYPE)
513
514namespace detail {
515
92f5a8d4
TL
516template <typename T, typename = void>
517struct default_completion_token_impl
518{
519 typedef void type;
520};
521
522template <typename T>
523struct default_completion_token_impl<T,
20effc67 524 typename void_type<typename T::default_completion_token_type>::type>
92f5a8d4
TL
525{
526 typedef typename T::default_completion_token_type type;
527};
528
529} // namespace detail
530
531#if defined(GENERATING_DOCUMENTATION)
532
533/// Traits type used to determine the default completion token type associated
534/// with a type (such as an executor).
535/**
536 * A program may specialise this traits type if the @c T template parameter in
537 * the specialisation is a user-defined type.
538 *
539 * Specialisations of this trait may provide a nested typedef @c type, which is
540 * a default-constructible completion token type.
541 */
542template <typename T>
543struct default_completion_token
544{
545 /// If @c T has a nested type @c default_completion_token_type,
546 /// <tt>T::default_completion_token_type</tt>. Otherwise the typedef @c type
547 /// is not defined.
548 typedef see_below type;
549};
550#else
551template <typename T>
552struct default_completion_token
553 : detail::default_completion_token_impl<T>
554{
555};
556#endif
557
558#if defined(BOOST_ASIO_HAS_ALIAS_TEMPLATES)
559
560template <typename T>
561using default_completion_token_t = typename default_completion_token<T>::type;
562
563#endif // defined(BOOST_ASIO_HAS_ALIAS_TEMPLATES)
564
565#if defined(BOOST_ASIO_HAS_DEFAULT_FUNCTION_TEMPLATE_ARGUMENTS)
566
567#define BOOST_ASIO_DEFAULT_COMPLETION_TOKEN_TYPE(e) \
568 = typename ::boost::asio::default_completion_token<e>::type
569#define BOOST_ASIO_DEFAULT_COMPLETION_TOKEN(e) \
570 = typename ::boost::asio::default_completion_token<e>::type()
571
572#else // defined(BOOST_ASIO_HAS_DEFAULT_FUNCTION_TEMPLATE_ARGUMENTS)
573
574#define BOOST_ASIO_DEFAULT_COMPLETION_TOKEN_TYPE(e)
575#define BOOST_ASIO_DEFAULT_COMPLETION_TOKEN(e)
576
577#endif // defined(BOOST_ASIO_HAS_DEFAULT_FUNCTION_TEMPLATE_ARGUMENTS)
578
579} // namespace asio
580} // namespace boost
581
582#include <boost/asio/detail/pop_options.hpp>
583
b32b8144 584#endif // BOOST_ASIO_ASYNC_RESULT_HPP