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_HAS_MEMBER_DATA_HPP)
|
Chris@16
|
8 #define BOOST_TTI_HAS_MEMBER_DATA_HPP
|
Chris@16
|
9
|
Chris@16
|
10 #include <boost/preprocessor/cat.hpp>
|
Chris@16
|
11 #include <boost/tti/detail/ddeftype.hpp>
|
Chris@16
|
12 #include <boost/tti/detail/dmem_data.hpp>
|
Chris@16
|
13 #include <boost/tti/gen/has_member_data_gen.hpp>
|
Chris@16
|
14 #include <boost/tti/gen/namespace_gen.hpp>
|
Chris@16
|
15 #include <boost/type_traits/remove_const.hpp>
|
Chris@16
|
16
|
Chris@16
|
17 /*
|
Chris@16
|
18
|
Chris@16
|
19 The succeeding comments in this file are in doxygen format.
|
Chris@16
|
20
|
Chris@16
|
21 */
|
Chris@16
|
22
|
Chris@16
|
23 /** \file
|
Chris@16
|
24 */
|
Chris@16
|
25
|
Chris@16
|
26 /// Expands to a metafunction which tests whether a member data with a particular name and type exists.
|
Chris@16
|
27 /**
|
Chris@16
|
28
|
Chris@16
|
29 trait = the name of the metafunction.
|
Chris@16
|
30
|
Chris@16
|
31 name = the name of the inner member to introspect.
|
Chris@16
|
32
|
Chris@16
|
33 generates a metafunction called "trait" where 'trait' is the macro parameter.
|
Chris@16
|
34
|
Chris@16
|
35 template<class BOOST_TTI_TP_ET,class BOOST_TTI_TP_TYPE>
|
Chris@16
|
36 struct trait
|
Chris@16
|
37 {
|
Chris@16
|
38 static const value = unspecified;
|
Chris@16
|
39 typedef mpl::bool_<true-or-false> type;
|
Chris@16
|
40 };
|
Chris@16
|
41
|
Chris@16
|
42 The metafunction types and return:
|
Chris@16
|
43
|
Chris@16
|
44 BOOST_TTI_TP_ET = the enclosing type in which to look for our 'name'
|
Chris@16
|
45 OR
|
Chris@16
|
46 The type of the member data in the form of a pointer
|
Chris@16
|
47 to member data.
|
Chris@16
|
48
|
Chris@16
|
49 BOOST_TTI_TP_TYPE = (optional) The type of the member data if the first
|
Chris@16
|
50 parameter is the enclosing type.
|
Chris@16
|
51
|
Chris@16
|
52 returns = 'value' is true if the 'name' exists, with the correct data type,
|
Chris@16
|
53 otherwise 'value' is false.
|
Chris@16
|
54
|
Chris@16
|
55 */
|
Chris@16
|
56 #define BOOST_TTI_TRAIT_HAS_MEMBER_DATA(trait,name) \
|
Chris@16
|
57 BOOST_TTI_DETAIL_TRAIT_HAS_MEMBER_DATA(trait,name) \
|
Chris@16
|
58 template<class BOOST_TTI_TP_ET,class BOOST_TTI_TP_TYPE = BOOST_TTI_NAMESPACE::detail::deftype> \
|
Chris@16
|
59 struct trait : \
|
Chris@16
|
60 BOOST_PP_CAT(trait,_detail_hmd) \
|
Chris@16
|
61 < \
|
Chris@16
|
62 typename BOOST_TTI_NAMESPACE::detail::dmem_get_type<BOOST_TTI_TP_ET,BOOST_TTI_TP_TYPE>::type, \
|
Chris@16
|
63 typename boost::remove_const \
|
Chris@16
|
64 < \
|
Chris@16
|
65 typename BOOST_TTI_NAMESPACE::detail::dmem_get_enclosing<BOOST_TTI_TP_ET,BOOST_TTI_TP_TYPE>::type \
|
Chris@16
|
66 >::type \
|
Chris@16
|
67 > \
|
Chris@16
|
68 { \
|
Chris@16
|
69 }; \
|
Chris@16
|
70 /**/
|
Chris@16
|
71
|
Chris@16
|
72 /// Expands to a metafunction which tests whether a member data with a particular name and type exists.
|
Chris@16
|
73 /**
|
Chris@16
|
74
|
Chris@16
|
75 name = the name of the inner member.
|
Chris@16
|
76
|
Chris@16
|
77 generates a metafunction called "has_member_data_name" where 'name' is the macro parameter.
|
Chris@16
|
78
|
Chris@16
|
79 template<class BOOST_TTI_TP_ET,class BOOST_TTI_TP_TYPE>
|
Chris@16
|
80 struct has_member_data_name
|
Chris@16
|
81 {
|
Chris@16
|
82 static const value = unspecified;
|
Chris@16
|
83 typedef mpl::bool_<true-or-false> type;
|
Chris@16
|
84 };
|
Chris@16
|
85
|
Chris@16
|
86 The metafunction types and return:
|
Chris@16
|
87
|
Chris@16
|
88 BOOST_TTI_TP_ET = the enclosing type in which to look for our 'name'
|
Chris@16
|
89 OR
|
Chris@16
|
90 The type of the member data in the form of a pointer
|
Chris@16
|
91 to member data.
|
Chris@16
|
92
|
Chris@16
|
93 BOOST_TTI_TP_TYPE = (optional) The type of the member data if the first
|
Chris@16
|
94 parameter is the enclosing type.
|
Chris@16
|
95
|
Chris@16
|
96 returns = 'value' is true if the 'name' exists, with the correct data type,
|
Chris@16
|
97 otherwise 'value' is false.
|
Chris@16
|
98
|
Chris@16
|
99 */
|
Chris@16
|
100 #define BOOST_TTI_HAS_MEMBER_DATA(name) \
|
Chris@16
|
101 BOOST_TTI_TRAIT_HAS_MEMBER_DATA \
|
Chris@16
|
102 ( \
|
Chris@16
|
103 BOOST_TTI_HAS_MEMBER_DATA_GEN(name), \
|
Chris@16
|
104 name \
|
Chris@16
|
105 ) \
|
Chris@16
|
106 /**/
|
Chris@16
|
107
|
Chris@16
|
108 #endif // BOOST_TTI_HAS_MEMBER_DATA_HPP
|