overlapped_ptr.cpp
3.22 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
//
// overlapped_ptr.cpp
// ~~~~~~~~~~~~~~~~~~
//
// Copyright (c) 2003-2020 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)
//
// Disable autolinking for unit tests.
#if !defined(BOOST_ALL_NO_LIB)
#define BOOST_ALL_NO_LIB 1
#endif // !defined(BOOST_ALL_NO_LIB)
// Test that header file is self-contained.
#include "asio/windows/overlapped_ptr.hpp"
#include "asio/any_io_executor.hpp"
#include "asio/executor.hpp"
#include "asio/io_context.hpp"
#include "../unit_test.hpp"
//------------------------------------------------------------------------------
// windows_overlapped_ptr_compile test
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
// The following test checks that all public member functions on the class
// windows::overlapped_ptr compile and link correctly. Runtime failures are
// ignored.
namespace windows_overlapped_ptr_compile {
void overlapped_handler_1(const asio::error_code&, std::size_t)
{
}
struct overlapped_handler_2
{
void operator()(const asio::error_code&, std::size_t)
{
}
};
void test()
{
#if defined(ASIO_HAS_WINDOWS_OVERLAPPED_PTR)
using namespace asio;
namespace win = asio::windows;
try
{
io_context ioc;
asio::any_io_executor ex1(ioc.get_executor());
#if !defined(ASIO_NO_TS_EXECUTORS)
asio::executor ex2(ioc.get_executor());
#endif // !defined(ASIO_NO_TS_EXECUTORS)
// basic_overlapped_ptr constructors.
win::overlapped_ptr ptr1;
win::overlapped_ptr ptr2(ioc, &overlapped_handler_1);
win::overlapped_ptr ptr3(ioc, overlapped_handler_2());
win::overlapped_ptr ptr4(ioc.get_executor(), &overlapped_handler_1);
win::overlapped_ptr ptr5(ioc.get_executor(), overlapped_handler_2());
win::overlapped_ptr ptr6(ex1, &overlapped_handler_1);
win::overlapped_ptr ptr7(ex1, overlapped_handler_2());
#if !defined(ASIO_NO_TS_EXECUTORS)
win::overlapped_ptr ptr8(ex2, &overlapped_handler_1);
win::overlapped_ptr ptr9(ex2, overlapped_handler_2());
#endif // !defined(ASIO_NO_TS_EXECUTORS)
// overlapped_ptr functions.
ptr1.reset();
ptr2.reset(ioc, &overlapped_handler_1);
ptr3.reset(ioc, overlapped_handler_2());
ptr2.reset(ioc.get_executor(), &overlapped_handler_1);
ptr3.reset(ioc.get_executor(), overlapped_handler_2());
ptr2.reset(ex1, &overlapped_handler_1);
ptr3.reset(ex1, overlapped_handler_2());
#if !defined(ASIO_NO_TS_EXECUTORS)
ptr3.reset(ex2, &overlapped_handler_1);
ptr3.reset(ex2, overlapped_handler_2());
#endif // !defined(ASIO_NO_TS_EXECUTORS)
OVERLAPPED* ov1 = ptr1.get();
(void)ov1;
const win::overlapped_ptr& ptr10(ptr1);
const OVERLAPPED* ov2 = ptr10.get();
(void)ov2;
OVERLAPPED* ov3 = ptr1.release();
(void)ov3;
asio::error_code ec;
std::size_t bytes_transferred = 0;
ptr1.complete(ec, bytes_transferred);
}
catch (std::exception&)
{
}
#endif // defined(ASIO_HAS_WINDOWS_OVERLAPPED_PTR)
}
} // namespace windows_overlapped_ptr_compile
//------------------------------------------------------------------------------
ASIO_TEST_SUITE
(
"windows/overlapped_ptr",
ASIO_TEST_CASE(windows_overlapped_ptr_compile::test)
)