Chris@16
|
1
|
Chris@16
|
2 // (C) Copyright Edward Diener 2011,2012,2013
|
Chris@16
|
3 // Use, modification and distribution are subject to the Boost Software License,
|
Chris@16
|
4 // Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
Chris@16
|
5 // http://www.boost.org/LICENSE_1_0.txt).
|
Chris@16
|
6
|
Chris@16
|
7 #if !defined(BOOST_TTI_DETAIL_TEMPLATE_PARAMS_HPP)
|
Chris@16
|
8 #define BOOST_TTI_DETAIL_TEMPLATE_PARAMS_HPP
|
Chris@16
|
9
|
Chris@16
|
10 #include <boost/config.hpp>
|
Chris@16
|
11 #include <boost/mpl/bool.hpp>
|
Chris@101
|
12 #include <boost/mpl/eval_if.hpp>
|
Chris@16
|
13 #include <boost/mpl/has_xxx.hpp>
|
Chris@16
|
14 #include <boost/preprocessor/arithmetic/add.hpp>
|
Chris@16
|
15 #include <boost/preprocessor/arithmetic/sub.hpp>
|
Chris@16
|
16 #include <boost/preprocessor/array/elem.hpp>
|
Chris@16
|
17 #include <boost/preprocessor/cat.hpp>
|
Chris@16
|
18 #include <boost/preprocessor/punctuation/comma_if.hpp>
|
Chris@16
|
19 #include <boost/preprocessor/repetition/repeat.hpp>
|
Chris@16
|
20 #include <boost/preprocessor/repetition/enum.hpp>
|
Chris@16
|
21 #include <boost/preprocessor/array/enum.hpp>
|
Chris@16
|
22 #include <boost/preprocessor/array/size.hpp>
|
Chris@101
|
23 #include <boost/type_traits/is_class.hpp>
|
Chris@16
|
24
|
Chris@16
|
25 #if !defined(BOOST_MPL_CFG_NO_HAS_XXX_TEMPLATE)
|
Chris@16
|
26
|
Chris@16
|
27 #define BOOST_TTI_DETAIL_TEMPLATE_PARAMETERS(z,n,args) \
|
Chris@16
|
28 BOOST_PP_ARRAY_ELEM(BOOST_PP_ADD(4,n),args) \
|
Chris@16
|
29 /**/
|
Chris@16
|
30
|
Chris@16
|
31 #define BOOST_TTI_DETAIL_HAS_MEMBER_IMPLEMENTATION(args,introspect_macro) \
|
Chris@16
|
32 template \
|
Chris@16
|
33 < \
|
Chris@16
|
34 typename BOOST_TTI_DETAIL_TP_T, \
|
Chris@16
|
35 typename BOOST_TTI_DETAIL_TP_FALLBACK_ \
|
Chris@16
|
36 = boost::mpl::bool_< BOOST_PP_ARRAY_ELEM(3, args) > \
|
Chris@16
|
37 > \
|
Chris@101
|
38 struct BOOST_PP_ARRAY_ELEM(0, args) \
|
Chris@16
|
39 { \
|
Chris@101
|
40 private: \
|
Chris@16
|
41 introspect_macro(args) \
|
Chris@16
|
42 public: \
|
Chris@16
|
43 static const bool value \
|
Chris@16
|
44 = BOOST_MPL_HAS_MEMBER_INTROSPECTION_NAME(args)< BOOST_TTI_DETAIL_TP_T >::value; \
|
Chris@16
|
45 typedef typename BOOST_MPL_HAS_MEMBER_INTROSPECTION_NAME(args) \
|
Chris@16
|
46 < \
|
Chris@16
|
47 BOOST_TTI_DETAIL_TP_T \
|
Chris@16
|
48 >::type type; \
|
Chris@16
|
49 }; \
|
Chris@16
|
50 /**/
|
Chris@16
|
51
|
Chris@16
|
52 #if !BOOST_WORKAROUND(BOOST_MSVC, <= 1400)
|
Chris@16
|
53
|
Chris@16
|
54 #define BOOST_TTI_DETAIL_HAS_MEMBER_MULTI_SUBSTITUTE(z,n,args) \
|
Chris@16
|
55 template \
|
Chris@16
|
56 < \
|
Chris@16
|
57 template \
|
Chris@16
|
58 < \
|
Chris@16
|
59 BOOST_PP_ENUM_ ## z \
|
Chris@16
|
60 ( \
|
Chris@16
|
61 BOOST_PP_SUB \
|
Chris@16
|
62 ( \
|
Chris@16
|
63 BOOST_PP_ARRAY_SIZE(args), \
|
Chris@16
|
64 4 \
|
Chris@16
|
65 ), \
|
Chris@16
|
66 BOOST_TTI_DETAIL_TEMPLATE_PARAMETERS, \
|
Chris@16
|
67 args \
|
Chris@16
|
68 ) \
|
Chris@16
|
69 > \
|
Chris@16
|
70 class BOOST_TTI_DETAIL_TM_V \
|
Chris@16
|
71 > \
|
Chris@16
|
72 struct BOOST_MPL_HAS_MEMBER_INTROSPECTION_SUBSTITUTE_NAME(args, n) \
|
Chris@16
|
73 { \
|
Chris@16
|
74 }; \
|
Chris@16
|
75 /**/
|
Chris@16
|
76
|
Chris@16
|
77 #define BOOST_TTI_DETAIL_HAS_MEMBER_SUBSTITUTE(args) \
|
Chris@16
|
78 BOOST_PP_REPEAT \
|
Chris@16
|
79 ( \
|
Chris@16
|
80 BOOST_PP_ARRAY_ELEM(2, args), \
|
Chris@16
|
81 BOOST_TTI_DETAIL_HAS_MEMBER_MULTI_SUBSTITUTE, \
|
Chris@16
|
82 args \
|
Chris@16
|
83 ) \
|
Chris@16
|
84 /**/
|
Chris@16
|
85
|
Chris@16
|
86 #define BOOST_TTI_DETAIL_HAS_MEMBER_INTROSPECT(args) \
|
Chris@16
|
87 template< typename U > \
|
Chris@16
|
88 struct BOOST_MPL_HAS_MEMBER_INTROSPECTION_NAME(args) \
|
Chris@16
|
89 { \
|
Chris@16
|
90 BOOST_TTI_DETAIL_HAS_MEMBER_SUBSTITUTE(args) \
|
Chris@16
|
91 BOOST_MPL_HAS_MEMBER_REJECT(args, BOOST_PP_NIL) \
|
Chris@16
|
92 BOOST_MPL_HAS_MEMBER_ACCEPT(args, BOOST_PP_NIL) \
|
Chris@16
|
93 BOOST_STATIC_CONSTANT \
|
Chris@16
|
94 ( \
|
Chris@16
|
95 bool, value = BOOST_MPL_HAS_MEMBER_TEST(args) \
|
Chris@16
|
96 ); \
|
Chris@16
|
97 typedef boost::mpl::bool_< value > type; \
|
Chris@16
|
98 }; \
|
Chris@16
|
99 /**/
|
Chris@16
|
100
|
Chris@16
|
101 #define BOOST_TTI_DETAIL_HAS_MEMBER_WITH_FUNCTION_SFINAE(args) \
|
Chris@16
|
102 BOOST_TTI_DETAIL_HAS_MEMBER_IMPLEMENTATION \
|
Chris@16
|
103 ( \
|
Chris@16
|
104 args, \
|
Chris@16
|
105 BOOST_TTI_DETAIL_HAS_MEMBER_INTROSPECT \
|
Chris@16
|
106 ) \
|
Chris@16
|
107 /**/
|
Chris@16
|
108
|
Chris@16
|
109 #else // !!BOOST_WORKAROUND(BOOST_MSVC, <= 1400)
|
Chris@16
|
110
|
Chris@16
|
111 #define BOOST_TTI_DETAIL_HAS_MEMBER_MULTI_SUBSTITUTE_WITH_TEMPLATE_SFINAE(z,n,args) \
|
Chris@16
|
112 template \
|
Chris@16
|
113 < \
|
Chris@16
|
114 template \
|
Chris@16
|
115 < \
|
Chris@16
|
116 BOOST_PP_ENUM_ ## z \
|
Chris@16
|
117 ( \
|
Chris@16
|
118 BOOST_PP_SUB \
|
Chris@16
|
119 ( \
|
Chris@16
|
120 BOOST_PP_ARRAY_SIZE(args), \
|
Chris@16
|
121 4 \
|
Chris@16
|
122 ), \
|
Chris@16
|
123 BOOST_TTI_DETAIL_TEMPLATE_PARAMETERS, \
|
Chris@16
|
124 args \
|
Chris@16
|
125 ) \
|
Chris@16
|
126 > \
|
Chris@16
|
127 class BOOST_TTI_DETAIL_TM_U \
|
Chris@16
|
128 > \
|
Chris@16
|
129 struct BOOST_MPL_HAS_MEMBER_INTROSPECTION_SUBSTITUTE_NAME_WITH_TEMPLATE_SFINAE \
|
Chris@16
|
130 ( \
|
Chris@16
|
131 args, \
|
Chris@16
|
132 n \
|
Chris@16
|
133 ) \
|
Chris@16
|
134 { \
|
Chris@16
|
135 typedef \
|
Chris@16
|
136 BOOST_MPL_HAS_MEMBER_INTROSPECTION_SUBSTITUTE_TAG_NAME(args) \
|
Chris@16
|
137 type; \
|
Chris@16
|
138 }; \
|
Chris@16
|
139 /**/
|
Chris@16
|
140
|
Chris@16
|
141 #define BOOST_TTI_DETAIL_HAS_MEMBER_SUBSTITUTE_WITH_TEMPLATE_SFINAE(args) \
|
Chris@16
|
142 typedef void \
|
Chris@16
|
143 BOOST_MPL_HAS_MEMBER_INTROSPECTION_SUBSTITUTE_TAG_NAME(args); \
|
Chris@16
|
144 BOOST_PP_REPEAT \
|
Chris@16
|
145 ( \
|
Chris@16
|
146 BOOST_PP_ARRAY_ELEM(2, args), \
|
Chris@16
|
147 BOOST_TTI_DETAIL_HAS_MEMBER_MULTI_SUBSTITUTE_WITH_TEMPLATE_SFINAE, \
|
Chris@16
|
148 args \
|
Chris@16
|
149 ) \
|
Chris@16
|
150 /**/
|
Chris@16
|
151
|
Chris@16
|
152 #define BOOST_TTI_DETAIL_HAS_MEMBER_INTROSPECT_WITH_TEMPLATE_SFINAE(args) \
|
Chris@16
|
153 BOOST_MPL_HAS_MEMBER_REJECT_WITH_TEMPLATE_SFINAE(args,BOOST_PP_NIL) \
|
Chris@16
|
154 BOOST_MPL_HAS_MEMBER_ACCEPT_WITH_TEMPLATE_SFINAE(args,BOOST_PP_NIL) \
|
Chris@16
|
155 template< typename BOOST_TTI_DETAIL_TP_U > \
|
Chris@16
|
156 struct BOOST_MPL_HAS_MEMBER_INTROSPECTION_NAME(args) \
|
Chris@16
|
157 : BOOST_MPL_HAS_MEMBER_INTROSPECTION_TEST_NAME(args)< BOOST_TTI_DETAIL_TP_U > { \
|
Chris@16
|
158 }; \
|
Chris@16
|
159 /**/
|
Chris@16
|
160
|
Chris@16
|
161 #define BOOST_TTI_DETAIL_HAS_MEMBER_WITH_TEMPLATE_SFINAE(args) \
|
Chris@16
|
162 BOOST_TTI_DETAIL_HAS_MEMBER_SUBSTITUTE_WITH_TEMPLATE_SFINAE \
|
Chris@16
|
163 ( \
|
Chris@16
|
164 args \
|
Chris@16
|
165 ) \
|
Chris@16
|
166 BOOST_TTI_DETAIL_HAS_MEMBER_IMPLEMENTATION \
|
Chris@16
|
167 ( \
|
Chris@16
|
168 args, \
|
Chris@16
|
169 BOOST_TTI_DETAIL_HAS_MEMBER_INTROSPECT_WITH_TEMPLATE_SFINAE \
|
Chris@16
|
170 ) \
|
Chris@16
|
171 /**/
|
Chris@16
|
172
|
Chris@16
|
173 #endif // !BOOST_WORKAROUND(BOOST_MSVC, <= 1400)
|
Chris@16
|
174
|
Chris@16
|
175 #else // defined(BOOST_MPL_CFG_NO_HAS_XXX_TEMPLATE)
|
Chris@16
|
176
|
Chris@16
|
177 #define BOOST_TTI_DETAIL_SAME(trait,name) \
|
Chris@16
|
178 BOOST_MPL_HAS_XXX_TEMPLATE_NAMED_DEF \
|
Chris@16
|
179 ( \
|
Chris@16
|
180 trait, \
|
Chris@16
|
181 name, \
|
Chris@16
|
182 false \
|
Chris@16
|
183 ) \
|
Chris@16
|
184 /**/
|
Chris@16
|
185
|
Chris@16
|
186 #define BOOST_TTI_DETAIL_TRAIT_CALL_HAS_TEMPLATE_CHECK_PARAMS(trait,name,tp) \
|
Chris@16
|
187 BOOST_TTI_DETAIL_SAME(trait,name) \
|
Chris@16
|
188 /**/
|
Chris@16
|
189
|
Chris@16
|
190 #endif // !BOOST_MPL_CFG_NO_HAS_XXX_TEMPLATE
|
Chris@16
|
191
|
Chris@101
|
192 #define BOOST_TTI_DETAIL_TRAIT_HAS_TEMPLATE_CHECK_PARAMS_OP(trait,name,tpArray) \
|
Chris@16
|
193 BOOST_TTI_DETAIL_TRAIT_CALL_HAS_TEMPLATE_CHECK_PARAMS(BOOST_PP_CAT(trait,_detail),name,tpArray) \
|
Chris@16
|
194 template<class BOOST_TTI_DETAIL_TP_T> \
|
Chris@101
|
195 struct BOOST_PP_CAT(trait,_detail_cp_op) : \
|
Chris@16
|
196 BOOST_PP_CAT(trait,_detail)<BOOST_TTI_DETAIL_TP_T> \
|
Chris@16
|
197 { \
|
Chris@16
|
198 }; \
|
Chris@16
|
199 /**/
|
Chris@16
|
200
|
Chris@101
|
201 #define BOOST_TTI_DETAIL_TRAIT_HAS_TEMPLATE_CHECK_PARAMS(trait,name,tpArray) \
|
Chris@101
|
202 BOOST_TTI_DETAIL_TRAIT_HAS_TEMPLATE_CHECK_PARAMS_OP(trait,name,tpArray) \
|
Chris@101
|
203 template<class BOOST_TTI_DETAIL_TP_T> \
|
Chris@101
|
204 struct trait \
|
Chris@101
|
205 { \
|
Chris@101
|
206 typedef typename \
|
Chris@101
|
207 boost::mpl::eval_if \
|
Chris@101
|
208 < \
|
Chris@101
|
209 boost::is_class<BOOST_TTI_DETAIL_TP_T>, \
|
Chris@101
|
210 BOOST_PP_CAT(trait,_detail_cp_op)<BOOST_TTI_DETAIL_TP_T>, \
|
Chris@101
|
211 boost::mpl::false_ \
|
Chris@101
|
212 >::type type; \
|
Chris@101
|
213 BOOST_STATIC_CONSTANT(bool,value=type::value); \
|
Chris@101
|
214 }; \
|
Chris@101
|
215 /**/
|
Chris@101
|
216
|
Chris@16
|
217 #if !defined(BOOST_MPL_CFG_NO_HAS_XXX_TEMPLATE)
|
Chris@16
|
218 #if !BOOST_WORKAROUND(BOOST_MSVC, <= 1400)
|
Chris@16
|
219
|
Chris@16
|
220 #define BOOST_TTI_DETAIL_TRAIT_CALL_HAS_TEMPLATE_CHECK_PARAMS(trait,name,tpArray) \
|
Chris@16
|
221 BOOST_TTI_DETAIL_HAS_MEMBER_WITH_FUNCTION_SFINAE \
|
Chris@16
|
222 ( \
|
Chris@16
|
223 ( BOOST_PP_ADD(BOOST_PP_ARRAY_SIZE(tpArray),4), ( trait, name, 1, false, BOOST_PP_ARRAY_ENUM(tpArray) ) ) \
|
Chris@16
|
224 ) \
|
Chris@16
|
225 /**/
|
Chris@16
|
226
|
Chris@16
|
227 #else // BOOST_WORKAROUND(BOOST_MSVC, <= 1400)
|
Chris@16
|
228
|
Chris@16
|
229 #define BOOST_TTI_DETAIL_TRAIT_CALL_HAS_TEMPLATE_CHECK_PARAMS(trait,name,tpArray) \
|
Chris@16
|
230 BOOST_TTI_DETAIL_HAS_MEMBER_WITH_TEMPLATE_SFINAE \
|
Chris@16
|
231 ( \
|
Chris@16
|
232 ( BOOST_PP_ADD(BOOST_PP_ARRAY_SIZE(tpArray),4), ( trait, name, 1, false, BOOST_PP_ARRAY_ENUM(tpArray) ) ) \
|
Chris@16
|
233 ) \
|
Chris@16
|
234 /**/
|
Chris@16
|
235
|
Chris@16
|
236 #endif // !BOOST_WORKAROUND(BOOST_MSVC, <= 1400)
|
Chris@16
|
237 #endif // !defined(BOOST_MPL_CFG_NO_HAS_XXX_TEMPLATE)
|
Chris@16
|
238
|
Chris@16
|
239 #endif // BOOST_TTI_DETAIL_TEMPLATE_PARAMS_HPP
|