1 | #include <boost/config.hpp> |
2 | |
3 | #if defined(BOOST_MSVC) |
4 | #pragma warning(disable: 4786) // identifier truncated in debug info |
5 | #pragma warning(disable: 4710) // function not inlined |
6 | #pragma warning(disable: 4711) // function selected for automatic inline expansion |
7 | #pragma warning(disable: 4514) // unreferenced inline removed |
8 | #endif |
9 | |
10 | // |
11 | // bind_const_test.cpp - test const bind objects |
12 | // |
13 | // Copyright (c) 2001-2004 Peter Dimov and Multi Media Ltd. |
14 | // Copyright (c) 2001 David Abrahams |
15 | // |
16 | // Distributed under the Boost Software License, Version 1.0. (See |
17 | // accompanying file LICENSE_1_0.txt or copy at |
18 | // http://www.boost.org/LICENSE_1_0.txt) |
19 | // |
20 | |
21 | #include <boost/bind/bind.hpp> |
22 | #include <boost/ref.hpp> |
23 | #include <boost/core/lightweight_test.hpp> |
24 | |
25 | using namespace boost::placeholders; |
26 | |
27 | // |
28 | |
29 | long f_0() |
30 | { |
31 | return 17041L; |
32 | } |
33 | |
34 | long f_1(long a) |
35 | { |
36 | return a; |
37 | } |
38 | |
39 | long f_2(long a, long b) |
40 | { |
41 | return a + 10 * b; |
42 | } |
43 | |
44 | long f_3(long a, long b, long c) |
45 | { |
46 | return a + 10 * b + 100 * c; |
47 | } |
48 | |
49 | long f_4(long a, long b, long c, long d) |
50 | { |
51 | return a + 10 * b + 100 * c + 1000 * d; |
52 | } |
53 | |
54 | long f_5(long a, long b, long c, long d, long e) |
55 | { |
56 | return a + 10 * b + 100 * c + 1000 * d + 10000 * e; |
57 | } |
58 | |
59 | long f_6(long a, long b, long c, long d, long e, long f) |
60 | { |
61 | return a + 10 * b + 100 * c + 1000 * d + 10000 * e + 100000 * f; |
62 | } |
63 | |
64 | long f_7(long a, long b, long c, long d, long e, long f, long g) |
65 | { |
66 | return a + 10 * b + 100 * c + 1000 * d + 10000 * e + 100000 * f + 1000000 * g; |
67 | } |
68 | |
69 | long f_8(long a, long b, long c, long d, long e, long f, long g, long h) |
70 | { |
71 | return a + 10 * b + 100 * c + 1000 * d + 10000 * e + 100000 * f + 1000000 * g + 10000000 * h; |
72 | } |
73 | |
74 | long f_9(long a, long b, long c, long d, long e, long f, long g, long h, long i) |
75 | { |
76 | return a + 10 * b + 100 * c + 1000 * d + 10000 * e + 100000 * f + 1000000 * g + 10000000 * h + 100000000 * i; |
77 | } |
78 | |
79 | long global_result; |
80 | |
81 | void fv_0() |
82 | { |
83 | global_result = 17041L; |
84 | } |
85 | |
86 | void fv_1(long a) |
87 | { |
88 | global_result = a; |
89 | } |
90 | |
91 | void fv_2(long a, long b) |
92 | { |
93 | global_result = a + 10 * b; |
94 | } |
95 | |
96 | void fv_3(long a, long b, long c) |
97 | { |
98 | global_result = a + 10 * b + 100 * c; |
99 | } |
100 | |
101 | void fv_4(long a, long b, long c, long d) |
102 | { |
103 | global_result = a + 10 * b + 100 * c + 1000 * d; |
104 | } |
105 | |
106 | void fv_5(long a, long b, long c, long d, long e) |
107 | { |
108 | global_result = a + 10 * b + 100 * c + 1000 * d + 10000 * e; |
109 | } |
110 | |
111 | void fv_6(long a, long b, long c, long d, long e, long f) |
112 | { |
113 | global_result = a + 10 * b + 100 * c + 1000 * d + 10000 * e + 100000 * f; |
114 | } |
115 | |
116 | void fv_7(long a, long b, long c, long d, long e, long f, long g) |
117 | { |
118 | global_result = a + 10 * b + 100 * c + 1000 * d + 10000 * e + 100000 * f + 1000000 * g; |
119 | } |
120 | |
121 | void fv_8(long a, long b, long c, long d, long e, long f, long g, long h) |
122 | { |
123 | global_result = a + 10 * b + 100 * c + 1000 * d + 10000 * e + 100000 * f + 1000000 * g + 10000000 * h; |
124 | } |
125 | |
126 | void fv_9(long a, long b, long c, long d, long e, long f, long g, long h, long i) |
127 | { |
128 | global_result = a + 10 * b + 100 * c + 1000 * d + 10000 * e + 100000 * f + 1000000 * g + 10000000 * h + 100000000 * i; |
129 | } |
130 | |
131 | template<class F, class A> long test(F const & f, A const & a) |
132 | { |
133 | return f(a); |
134 | } |
135 | |
136 | template<class F, class A> long testv(F const & f, A const & a) |
137 | { |
138 | f(a); |
139 | return global_result; |
140 | } |
141 | |
142 | void function_test() |
143 | { |
144 | using namespace boost; |
145 | |
146 | int const i = 1; |
147 | |
148 | BOOST_TEST( test( bind(f_0), i ) == 17041L ); |
149 | BOOST_TEST( test( bind(f_1, _1), i ) == 1L ); |
150 | BOOST_TEST( test( bind(f_2, _1, 2), i ) == 21L ); |
151 | BOOST_TEST( test( bind(f_3, _1, 2, 3), i ) == 321L ); |
152 | BOOST_TEST( test( bind(f_4, _1, 2, 3, 4), i ) == 4321L ); |
153 | BOOST_TEST( test( bind(f_5, _1, 2, 3, 4, 5), i ) == 54321L ); |
154 | BOOST_TEST( test( bind(f_6, _1, 2, 3, 4, 5, 6), i ) == 654321L ); |
155 | BOOST_TEST( test( bind(f_7, _1, 2, 3, 4, 5, 6, 7), i ) == 7654321L ); |
156 | BOOST_TEST( test( bind(f_8, _1, 2, 3, 4, 5, 6, 7, 8), i ) == 87654321L ); |
157 | BOOST_TEST( test( bind(f_9, _1, 2, 3, 4, 5, 6, 7, 8, 9), i ) == 987654321L ); |
158 | |
159 | BOOST_TEST( testv( bind(fv_0), i ) == 17041L ); |
160 | BOOST_TEST( testv( bind(fv_1, _1), i ) == 1L ); |
161 | BOOST_TEST( testv( bind(fv_2, _1, 2), i ) == 21L ); |
162 | BOOST_TEST( testv( bind(fv_3, _1, 2, 3), i ) == 321L ); |
163 | BOOST_TEST( testv( bind(fv_4, _1, 2, 3, 4), i ) == 4321L ); |
164 | BOOST_TEST( testv( bind(fv_5, _1, 2, 3, 4, 5), i ) == 54321L ); |
165 | BOOST_TEST( testv( bind(fv_6, _1, 2, 3, 4, 5, 6), i ) == 654321L ); |
166 | BOOST_TEST( testv( bind(fv_7, _1, 2, 3, 4, 5, 6, 7), i ) == 7654321L ); |
167 | BOOST_TEST( testv( bind(fv_8, _1, 2, 3, 4, 5, 6, 7, 8), i ) == 87654321L ); |
168 | BOOST_TEST( testv( bind(fv_9, _1, 2, 3, 4, 5, 6, 7, 8, 9), i ) == 987654321L ); |
169 | } |
170 | |
171 | int main() |
172 | { |
173 | function_test(); |
174 | return boost::report_errors(); |
175 | } |
176 | |