MACE  1.0.0
 All Classes Namespaces Files Functions Variables Enumerations Defines
libs/reflect/include/mace/reflect/reflect.hpp
Go to the documentation of this file.
00001 
00008 #ifndef _MACE_REFLECT_HPP_
00009 #define _MACE_REFLECT_HPP_
00010 
00011 #include <boost/static_assert.hpp>
00012 #include <boost/preprocessor/seq/for_each_i.hpp>
00013 #include <boost/preprocessor/seq/for_each.hpp>
00014 #include <boost/preprocessor/seq/enum.hpp>
00015 #include <boost/preprocessor/seq/seq.hpp>
00016 #include <boost/preprocessor/stringize.hpp>
00017 #include <boost/preprocessor/tuple/elem.hpp>
00018 #include <boost/preprocessor/facilities/empty.hpp>
00019 #include <boost/type_traits/remove_const.hpp>
00020 #include <boost/type_traits/remove_reference.hpp>
00021 #include <boost/typeof/typeof.hpp>
00022 #include <boost/type_traits/remove_pointer.hpp>
00023 #include <string>
00024 #include <typeinfo>
00025 #include <vector>
00026 #include <list>
00027 #include <set>
00028 #include <map>
00029 #include <stdint.h>
00030 #include <boost/fusion/container/vector.hpp>
00031 #include <boost/function_types/result_type.hpp>
00032 
00033 
00034 #include <mace/reflect/void.hpp>
00035 #include <mace/reflect/typeinfo.hpp>
00036 
00037 namespace mace { 
00041 namespace reflect {
00042 
00052 template<typename T>
00053 struct reflector{
00054     typedef T type;
00055     typedef boost::fusion::vector<> base_class_types;
00056     typedef boost::false_type is_defined;
00057 
00071     template<typename Visitor>
00072     static inline void visit( const Visitor& v ){}; 
00073 };
00074 
00075 } } // namespace mace::reflect
00076 
00077 #ifndef DOXYGEN
00078 
00079 #define MACE_REFLECT_VISIT_BASE(r, visitor, base) \
00080   mace::reflect::reflector<base>::visit( visitor );
00081 
00082 
00083 #ifndef WIN32
00084   #define TEMPLATE template
00085 #else
00086   #define TEMPLATE
00087 #endif
00088 
00089 #define MACE_REFLECT_VISIT_MEMBER( r, visitor, elem ) \
00090   visitor.TEMPLATE operator()<BOOST_TYPEOF(&type::elem), &type::elem>( BOOST_PP_STRINGIZE(elem) );
00091 
00092 
00093 #define MACE_REFLECT_BASE_MEMBER_COUNT( r, OP, elem ) \
00094   OP mace::reflect::reflector<elem>::member_count
00095 
00096 #define MACE_REFLECT_DERIVED_IMPL_INLINE( TYPE, INHERITS, MEMBERS ) \
00097 template<typename Visitor>\
00098 static inline void visit( const Visitor& v ) { \
00099     BOOST_PP_SEQ_FOR_EACH( MACE_REFLECT_VISIT_BASE, v, INHERITS ) \
00100     BOOST_PP_SEQ_FOR_EACH( MACE_REFLECT_VISIT_MEMBER, v, MEMBERS ) \
00101 } 
00102 
00103 #define MACE_REFLECT_DERIVED_IMPL_EXT( TYPE, INHERITS, MEMBERS ) \
00104 template<typename Visitor>\
00105 void mace::reflect::reflector<TYPE>::visit( const Visitor& v ) { \
00106     BOOST_PP_SEQ_FOR_EACH( MACE_REFLECT_VISIT_BASE, v, INHERITS ) \
00107     BOOST_PP_SEQ_FOR_EACH( MACE_REFLECT_VISIT_MEMBER, v, MEMBERS ) \
00108 } 
00109 
00110 #endif // DOXYGEN
00111 
00121 #define MACE_REFLECT_DERIVED( TYPE, INHERITS, MEMBERS ) \
00122 MACE_REFLECT_TYPEINFO(TYPE) \
00123 namespace mace { namespace reflect { \
00124 template<> struct reflector<TYPE> {\
00125     typedef TYPE type; \
00126     typedef boost::true_type is_defined; \
00127     enum  member_count_enum {  \
00128       local_member_count = BOOST_PP_SEQ_SIZE(MEMBERS), \
00129       total_member_count = local_member_count BOOST_PP_SEQ_FOR_EACH( MACE_REFLECT_BASE_MEMBER_COUNT, +, INHERITS )\
00130     }; \
00131     MACE_REFLECT_DERIVED_IMPL_INLINE( TYPE, INHERITS, MEMBERS ) \
00132 }; } }
00133 
00134 
00143 #define MACE_REFLECT( TYPE, MEMBERS ) \
00144     MACE_REFLECT_DERIVED( TYPE, BOOST_PP_SEQ_NIL, MEMBERS )
00145 
00146 #define MACE_REFLECT_FWD( TYPE ) \
00147 MACE_REFLECT_TYPEINFO(TYPE) \
00148 namespace mace { namespace reflect { \
00149 template<> struct reflector<TYPE> {\
00150     typedef TYPE type; \
00151     typedef boost::true_type is_defined; \
00152     enum  member_count_enum {  \
00153       local_member_count = BOOST_PP_SEQ_SIZE(MEMBERS), \
00154       total_member_count = local_member_count BOOST_PP_SEQ_FOR_EACH( MACE_REFLECT_BASE_MEMBER_COUNT, +, INHERITS )\
00155     }; \
00156     typedef boost::fusion::vector<BOOST_PP_SEQ_ENUM(INHERITS)> base_class_types; \
00157     template<typename Visitor> static void visit( const Visitor& v ); \
00158 }; } }
00159 
00160 
00161 #define MACE_REFLECT_DERIVED_IMPL( TYPE, MEMBERS ) \
00162     MACE_REFLECT_IMPL_DERIVED_EXT( TYPE, BOOST_PP_SEQ_NIL, MEMBERS )
00163 
00164 #define MACE_REFLECT_IMPL( TYPE, MEMBERS ) \
00165     MACE_REFLECT_DERIVED_IMPL_EXT( TYPE, BOOST_PP_SEQ_NIL, MEMBERS )
00166 
00167 
00168 
00169 #endif