mirror of
https://github.com/boostorg/fusion.git
synced 2025-07-31 04:57:28 +02:00
Merge pull request #11 from daminetreg/fusion_adapters
ADAPT_STRUCT_NAMED macros supporting type deduction
This commit is contained in:
@ -337,10 +337,31 @@ arbitrary struct a model of __random_access_sequence__. The given struct is
|
|||||||
adapted using the given name.
|
adapted using the given name.
|
||||||
|
|
||||||
[heading Synopsis]
|
[heading Synopsis]
|
||||||
|
BOOST_FUSION_ADAPT_STRUCT_NAMED(
|
||||||
|
struct_name, adapted_name,
|
||||||
|
member_name0,
|
||||||
|
member_name1,
|
||||||
|
member_name2,
|
||||||
|
...
|
||||||
|
)
|
||||||
|
|
||||||
|
BOOST_FUSION_ADAPT_STRUCT_NAMED_NS(
|
||||||
|
struct_name,
|
||||||
|
(namespace0)(namespace1)...,
|
||||||
|
adapted_name,
|
||||||
|
member_name0,
|
||||||
|
member_name1,
|
||||||
|
member_name2,
|
||||||
|
...
|
||||||
|
)
|
||||||
|
|
||||||
|
// When BOOST_PP_VARIADICS is missing :
|
||||||
|
|
||||||
BOOST_FUSION_ADAPT_STRUCT_NAMED(
|
BOOST_FUSION_ADAPT_STRUCT_NAMED(
|
||||||
struct_name, adapted_name,
|
struct_name, adapted_name,
|
||||||
(member_type0, member_name0)
|
(member_type0, member_name0)
|
||||||
(member_type1, member_name1)
|
(member_type1, member_name1)
|
||||||
|
(BOOST_FUSION_ADAPT_AUTO, member_name2),
|
||||||
...
|
...
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -350,9 +371,12 @@ adapted using the given name.
|
|||||||
adapted_name,
|
adapted_name,
|
||||||
(member_type0, member_name0)
|
(member_type0, member_name0)
|
||||||
(member_type1, member_name1)
|
(member_type1, member_name1)
|
||||||
|
(BOOST_FUSION_ADAPT_AUTO, member_name2),
|
||||||
...
|
...
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[heading Semantics]
|
[heading Semantics]
|
||||||
|
|
||||||
The above macros generate the necessary code to adapt `struct_name`
|
The above macros generate the necessary code to adapt `struct_name`
|
||||||
@ -365,9 +389,12 @@ If an empty namespace sequence is given (that is a macro that expands to
|
|||||||
nothing), the adapted view is placed in the global namespace.
|
nothing), the adapted view is placed in the global namespace.
|
||||||
If no namespace sequence is given (i.e. `BOOST_FUSION_ADAPT_STRUCT_NAMED`), the
|
If no namespace sequence is given (i.e. `BOOST_FUSION_ADAPT_STRUCT_NAMED`), the
|
||||||
adapted view is placed in the namespace `boost::fusion::adapted`.
|
adapted view is placed in the namespace `boost::fusion::adapted`.
|
||||||
The sequence of `(member_typeN, member_nameN)`
|
The sequence of `member_nameN,` arguments or `(member_typeN, member_nameN)`
|
||||||
pairs declares the type and names of each of the struct members that are
|
pairs declares the type and names of each of the struct members that are part of
|
||||||
part of the sequence.
|
the sequence.
|
||||||
|
|
||||||
|
Omitting the type or using BOOST_FUSION_ADAPT_AUTO can be used to infer the type,
|
||||||
|
as with decltype.
|
||||||
|
|
||||||
The macros should be used at global scope, and `struct_name` should be the fully
|
The macros should be used at global scope, and `struct_name` should be the fully
|
||||||
namespace qualified name of the struct to be converted.
|
namespace qualified name of the struct to be converted.
|
||||||
@ -391,8 +418,14 @@ namespace qualified name of the struct to be converted.
|
|||||||
// referring to demo::employee
|
// referring to demo::employee
|
||||||
BOOST_FUSION_ADAPT_STRUCT_NAMED(
|
BOOST_FUSION_ADAPT_STRUCT_NAMED(
|
||||||
demo::employee, adapted_employee,
|
demo::employee, adapted_employee,
|
||||||
(std::string, name)
|
name,
|
||||||
(int, age))
|
age)
|
||||||
|
|
||||||
|
// When BOOST_PP_VARIADICS is missing :
|
||||||
|
BOOST_FUSION_ADAPT_STRUCT_NAMED(
|
||||||
|
demo::employee, adapted_employee,
|
||||||
|
(BOOST_FUSION_ADAPT_AUTO, name),
|
||||||
|
(BOOST_FUSION_ADAPT_AUTO, age))
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
||||||
|
|
||||||
|
@ -40,7 +40,8 @@
|
|||||||
#define BOOST_FUSION_ADAPT_ADT_FILLER_0_END
|
#define BOOST_FUSION_ADAPT_ADT_FILLER_0_END
|
||||||
#define BOOST_FUSION_ADAPT_ADT_FILLER_1_END
|
#define BOOST_FUSION_ADAPT_ADT_FILLER_1_END
|
||||||
|
|
||||||
#define BOOST_FUSION_ADAPT_ADT_C(TEMPLATE_PARAMS_SEQ, NAME_SEQ, I, ATTRIBUTE) \
|
#define BOOST_FUSION_ADAPT_ADT_C( \
|
||||||
|
TEMPLATE_PARAMS_SEQ, NAME_SEQ, IS_VIEW, I, ATTRIBUTE) \
|
||||||
BOOST_FUSION_ADAPT_ADT_C_BASE( \
|
BOOST_FUSION_ADAPT_ADT_C_BASE( \
|
||||||
TEMPLATE_PARAMS_SEQ, NAME_SEQ, I, ATTRIBUTE, 4)
|
TEMPLATE_PARAMS_SEQ, NAME_SEQ, I, ATTRIBUTE, 4)
|
||||||
|
|
||||||
|
@ -44,7 +44,7 @@
|
|||||||
#define BOOST_FUSION_ADAPT_ASSOC_ADT_FILLER_1_END
|
#define BOOST_FUSION_ADAPT_ASSOC_ADT_FILLER_1_END
|
||||||
|
|
||||||
#define BOOST_FUSION_ADAPT_ASSOC_ADT_C( \
|
#define BOOST_FUSION_ADAPT_ASSOC_ADT_C( \
|
||||||
TEMPLATE_PARAMS_SEQ, NAME_SEQ, I, ATTRIBUTE) \
|
TEMPLATE_PARAMS_SEQ, NAME_SEQ, IS_VIEW, I, ATTRIBUTE) \
|
||||||
\
|
\
|
||||||
BOOST_FUSION_ADAPT_ADT_C_BASE(TEMPLATE_PARAMS_SEQ,NAME_SEQ,I,ATTRIBUTE,5) \
|
BOOST_FUSION_ADAPT_ADT_C_BASE(TEMPLATE_PARAMS_SEQ,NAME_SEQ,I,ATTRIBUTE,5) \
|
||||||
\
|
\
|
||||||
|
@ -43,10 +43,10 @@
|
|||||||
#define BOOST_FUSION_ADAPT_ASSOC_STRUCT_FILLER_1_END
|
#define BOOST_FUSION_ADAPT_ASSOC_STRUCT_FILLER_1_END
|
||||||
|
|
||||||
#define BOOST_FUSION_ADAPT_ASSOC_STRUCT_C_BASE( \
|
#define BOOST_FUSION_ADAPT_ASSOC_STRUCT_C_BASE( \
|
||||||
TEMPLATE_PARAMS_SEQ,NAME_SEQ,I,PREFIX,ATTRIBUTE) \
|
TEMPLATE_PARAMS_SEQ,NAME_SEQ,IS_VIEW,I,PREFIX,ATTRIBUTE) \
|
||||||
\
|
\
|
||||||
BOOST_FUSION_ADAPT_STRUCT_C_BASE( \
|
BOOST_FUSION_ADAPT_STRUCT_C_BASE( \
|
||||||
TEMPLATE_PARAMS_SEQ, NAME_SEQ, I, PREFIX, ATTRIBUTE, 3) \
|
TEMPLATE_PARAMS_SEQ, NAME_SEQ, IS_VIEW, I, PREFIX, ATTRIBUTE, 3) \
|
||||||
\
|
\
|
||||||
template< \
|
template< \
|
||||||
BOOST_FUSION_ADAPT_STRUCT_UNPACK_TEMPLATE_PARAMS(TEMPLATE_PARAMS_SEQ) \
|
BOOST_FUSION_ADAPT_STRUCT_UNPACK_TEMPLATE_PARAMS(TEMPLATE_PARAMS_SEQ) \
|
||||||
@ -57,10 +57,10 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
#define BOOST_FUSION_ADAPT_ASSOC_STRUCT_C( \
|
#define BOOST_FUSION_ADAPT_ASSOC_STRUCT_C( \
|
||||||
TEMPLATE_PARAMS_SEQ,NAME_SEQ, I, ATTRIBUTE) \
|
TEMPLATE_PARAMS_SEQ,NAME_SEQ,IS_VIEW, I, ATTRIBUTE) \
|
||||||
\
|
\
|
||||||
BOOST_FUSION_ADAPT_ASSOC_STRUCT_C_BASE( \
|
BOOST_FUSION_ADAPT_ASSOC_STRUCT_C_BASE( \
|
||||||
TEMPLATE_PARAMS_SEQ,NAME_SEQ,I,BOOST_PP_EMPTY,ATTRIBUTE)
|
TEMPLATE_PARAMS_SEQ,NAME_SEQ,IS_VIEW,I,BOOST_PP_EMPTY,ATTRIBUTE)
|
||||||
|
|
||||||
#define BOOST_FUSION_ADAPT_ASSOC_TPL_STRUCT( \
|
#define BOOST_FUSION_ADAPT_ASSOC_TPL_STRUCT( \
|
||||||
TEMPLATE_PARAMS_SEQ, NAME_SEQ, ATTRIBUTES) \
|
TEMPLATE_PARAMS_SEQ, NAME_SEQ, ATTRIBUTES) \
|
||||||
|
@ -34,12 +34,14 @@
|
|||||||
#include <boost/fusion/adapted/struct/detail/value_of_impl.hpp>
|
#include <boost/fusion/adapted/struct/detail/value_of_impl.hpp>
|
||||||
#include <boost/fusion/adapted/struct/detail/deref_impl.hpp>
|
#include <boost/fusion/adapted/struct/detail/deref_impl.hpp>
|
||||||
|
|
||||||
#define BOOST_FUSION_ADAPT_STRUCT_C(TEMPLATE_PARAMS_SEQ, NAME_SEQ, I, ATTRIBUTE)\
|
#define BOOST_FUSION_ADAPT_STRUCT_C( \
|
||||||
|
TEMPLATE_PARAMS_SEQ, NAME_SEQ, IS_VIEW, I, ATTRIBUTE) \
|
||||||
BOOST_FUSION_ADAPT_STRUCT_C_BASE( \
|
BOOST_FUSION_ADAPT_STRUCT_C_BASE( \
|
||||||
TEMPLATE_PARAMS_SEQ, \
|
TEMPLATE_PARAMS_SEQ, \
|
||||||
NAME_SEQ, \
|
NAME_SEQ, \
|
||||||
|
IS_VIEW, \
|
||||||
I, \
|
I, \
|
||||||
BOOST_PP_EMPTY, \
|
BOOST_PP_IF(IS_VIEW, BOOST_FUSION_PROXY_PREFIX, BOOST_PP_EMPTY), \
|
||||||
BOOST_PP_TUPLE_ELEM(2, 1, ATTRIBUTE), \
|
BOOST_PP_TUPLE_ELEM(2, 1, ATTRIBUTE), \
|
||||||
BOOST_PP_TUPLE_ELEM(2, 0, ATTRIBUTE))
|
BOOST_PP_TUPLE_ELEM(2, 0, ATTRIBUTE))
|
||||||
|
|
||||||
|
@ -15,12 +15,25 @@
|
|||||||
#include <boost/fusion/adapted/struct/detail/proxy_type.hpp>
|
#include <boost/fusion/adapted/struct/detail/proxy_type.hpp>
|
||||||
#include <boost/preprocessor/empty.hpp>
|
#include <boost/preprocessor/empty.hpp>
|
||||||
|
|
||||||
#define BOOST_FUSION_ADAPT_STRUCT_NAMED_FILLER_0(X, Y) \
|
#ifdef BOOST_PP_VARIADICS
|
||||||
(X, obj.Y) BOOST_FUSION_ADAPT_STRUCT_NAMED_FILLER_1
|
|
||||||
#define BOOST_FUSION_ADAPT_STRUCT_NAMED_FILLER_1(X, Y) \
|
# define BOOST_FUSION_ADAPT_STRUCT_NAMED_NS( \
|
||||||
(X, obj.Y) BOOST_FUSION_ADAPT_STRUCT_NAMED_FILLER_0
|
WRAPPED_TYPE, NAMESPACE_SEQ, NAME, ...) \
|
||||||
#define BOOST_FUSION_ADAPT_STRUCT_NAMED_FILLER_0_END
|
\
|
||||||
#define BOOST_FUSION_ADAPT_STRUCT_NAMED_FILLER_1_END
|
BOOST_FUSION_ADAPT_STRUCT_DEFINE_PROXY_TYPE_IMPL( \
|
||||||
|
WRAPPED_TYPE,(0)NAMESPACE_SEQ,NAME) \
|
||||||
|
\
|
||||||
|
BOOST_FUSION_ADAPT_STRUCT_AS_VIEW( \
|
||||||
|
BOOST_FUSION_ADAPT_STRUCT_NAMESPACE_DECLARATION( \
|
||||||
|
(0)NAMESPACE_SEQ)NAME, \
|
||||||
|
__VA_ARGS__)
|
||||||
|
|
||||||
|
# define BOOST_FUSION_ADAPT_STRUCT_NAMED(WRAPPED_TYPE, NAME, ...) \
|
||||||
|
BOOST_FUSION_ADAPT_STRUCT_NAMED_NS( \
|
||||||
|
WRAPPED_TYPE,(boost)(fusion)(adapted),NAME,__VA_ARGS__)
|
||||||
|
|
||||||
|
|
||||||
|
#else // BOOST_PP_VARIADICS
|
||||||
|
|
||||||
# define BOOST_FUSION_ADAPT_STRUCT_NAMED_NS( \
|
# define BOOST_FUSION_ADAPT_STRUCT_NAMED_NS( \
|
||||||
WRAPPED_TYPE, NAMESPACE_SEQ, NAME, ATTRIBUTES) \
|
WRAPPED_TYPE, NAMESPACE_SEQ, NAME, ATTRIBUTES) \
|
||||||
@ -29,12 +42,14 @@
|
|||||||
WRAPPED_TYPE,(0)NAMESPACE_SEQ,NAME) \
|
WRAPPED_TYPE,(0)NAMESPACE_SEQ,NAME) \
|
||||||
\
|
\
|
||||||
BOOST_FUSION_ADAPT_STRUCT_AS_VIEW( \
|
BOOST_FUSION_ADAPT_STRUCT_AS_VIEW( \
|
||||||
BOOST_FUSION_ADAPT_STRUCT_NAMESPACE_DECLARATION((0)NAMESPACE_SEQ)NAME, \
|
BOOST_FUSION_ADAPT_STRUCT_NAMESPACE_DECLARATION( \
|
||||||
BOOST_PP_CAT( \
|
(0)NAMESPACE_SEQ)NAME, \
|
||||||
BOOST_FUSION_ADAPT_STRUCT_NAMED_FILLER_0 ATTRIBUTES,_END))
|
ATTRIBUTES)
|
||||||
|
|
||||||
# define BOOST_FUSION_ADAPT_STRUCT_NAMED(WRAPPED_TYPE, NAME, ATTRIBUTES) \
|
# define BOOST_FUSION_ADAPT_STRUCT_NAMED(WRAPPED_TYPE, NAME, ATTRIBUTES) \
|
||||||
BOOST_FUSION_ADAPT_STRUCT_NAMED_NS( \
|
BOOST_FUSION_ADAPT_STRUCT_NAMED_NS( \
|
||||||
WRAPPED_TYPE,(boost)(fusion)(adapted),NAME,ATTRIBUTES)
|
WRAPPED_TYPE,(boost)(fusion)(adapted),NAME,ATTRIBUTES)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
@ -59,15 +59,15 @@
|
|||||||
BOOST_FUSION_ADAPT_STRUCT_UNPACK_TEMPLATE_PARAMS_IMPL, \
|
BOOST_FUSION_ADAPT_STRUCT_UNPACK_TEMPLATE_PARAMS_IMPL, \
|
||||||
BOOST_PP_TUPLE_EAT(1))(SEQ)
|
BOOST_PP_TUPLE_EAT(1))(SEQ)
|
||||||
|
|
||||||
|
|
||||||
#define BOOST_FUSION_ATTRIBUTE_TYPEOF( \
|
#define BOOST_FUSION_ATTRIBUTE_TYPEOF( \
|
||||||
NAME_SEQ, ATTRIBUTE, ATTRIBUTE_TUPEL_SIZE) \
|
NAME_SEQ, ATTRIBUTE, ATTRIBUTE_TUPEL_SIZE, PREFIX) \
|
||||||
BOOST_TYPEOF( \
|
BOOST_TYPEOF( \
|
||||||
BOOST_FUSION_ADAPT_STRUCT_UNPACK_NAME(NAME_SEQ) \
|
BOOST_FUSION_ADAPT_STRUCT_UNPACK_NAME(NAME_SEQ)::PREFIX() \
|
||||||
:: \
|
BOOST_PP_TUPLE_ELEM(ATTRIBUTE_TUPEL_SIZE, 0, ATTRIBUTE))
|
||||||
BOOST_PP_TUPLE_ELEM(ATTRIBUTE_TUPEL_SIZE, 0, ATTRIBUTE)) \
|
|
||||||
|
|
||||||
#define BOOST_FUSION_ATTRIBUTE_GIVENTYPE( \
|
#define BOOST_FUSION_ATTRIBUTE_GIVENTYPE( \
|
||||||
NAME_SEQ, ATTRIBUTE, ATTRIBUTE_TUPEL_SIZE) \
|
NAME_SEQ, ATTRIBUTE, ATTRIBUTE_TUPEL_SIZE, unused) \
|
||||||
BOOST_PP_TUPLE_ELEM(ATTRIBUTE_TUPEL_SIZE, 0, ATTRIBUTE)
|
BOOST_PP_TUPLE_ELEM(ATTRIBUTE_TUPEL_SIZE, 0, ATTRIBUTE)
|
||||||
|
|
||||||
#ifdef BOOST_NO_PARTIAL_SPECIALIZATION_IMPLICIT_DEFAULT_ARGS
|
#ifdef BOOST_NO_PARTIAL_SPECIALIZATION_IMPLICIT_DEFAULT_ARGS
|
||||||
@ -98,9 +98,10 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define BOOST_FUSION_ADAPT_STRUCT_BASE_UNPACK_AND_CALL(R,DATA,I,ATTRIBUTE) \
|
#define BOOST_FUSION_ADAPT_STRUCT_BASE_UNPACK_AND_CALL(R,DATA,I,ATTRIBUTE) \
|
||||||
BOOST_PP_TUPLE_ELEM(3,0,DATA)( \
|
BOOST_PP_TUPLE_ELEM(4,0,DATA)( \
|
||||||
BOOST_PP_TUPLE_ELEM(3,1,DATA), \
|
BOOST_PP_TUPLE_ELEM(4,1,DATA), \
|
||||||
BOOST_PP_TUPLE_ELEM(3,2,DATA), \
|
BOOST_PP_TUPLE_ELEM(4,2,DATA), \
|
||||||
|
BOOST_PP_TUPLE_ELEM(4,3,DATA), \
|
||||||
I, \
|
I, \
|
||||||
ATTRIBUTE)
|
ATTRIBUTE)
|
||||||
|
|
||||||
@ -122,7 +123,8 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define BOOST_FUSION_ADAPT_STRUCT_C_BASE( \
|
#define BOOST_FUSION_ADAPT_STRUCT_C_BASE( \
|
||||||
TEMPLATE_PARAMS_SEQ,NAME_SEQ,I,PREFIX,ATTRIBUTE,ATTRIBUTE_TUPEL_SIZE) \
|
TEMPLATE_PARAMS_SEQ,NAME_SEQ,IS_VIEW, \
|
||||||
|
I,PREFIX,ATTRIBUTE,ATTRIBUTE_TUPEL_SIZE) \
|
||||||
\
|
\
|
||||||
template< \
|
template< \
|
||||||
BOOST_FUSION_ADAPT_STRUCT_UNPACK_TEMPLATE_PARAMS(TEMPLATE_PARAMS_SEQ) \
|
BOOST_FUSION_ADAPT_STRUCT_UNPACK_TEMPLATE_PARAMS(TEMPLATE_PARAMS_SEQ) \
|
||||||
@ -135,7 +137,7 @@
|
|||||||
typedef \
|
typedef \
|
||||||
BOOST_PP_IF(BOOST_PP_LESS(ATTRIBUTE_TUPEL_SIZE,2), \
|
BOOST_PP_IF(BOOST_PP_LESS(ATTRIBUTE_TUPEL_SIZE,2), \
|
||||||
BOOST_FUSION_ATTRIBUTE_TYPEOF, BOOST_FUSION_ATTRIBUTE_GIVENTYPE \
|
BOOST_FUSION_ATTRIBUTE_TYPEOF, BOOST_FUSION_ATTRIBUTE_GIVENTYPE \
|
||||||
)(NAME_SEQ, ATTRIBUTE, ATTRIBUTE_TUPEL_SIZE) \
|
)(NAME_SEQ, ATTRIBUTE, ATTRIBUTE_TUPEL_SIZE, PREFIX) \
|
||||||
attribute_type; \
|
attribute_type; \
|
||||||
BOOST_FUSION_ADAPT_STRUCT_MSVC_REDEFINE_TEMPLATE_PARAMS( \
|
BOOST_FUSION_ADAPT_STRUCT_MSVC_REDEFINE_TEMPLATE_PARAMS( \
|
||||||
TEMPLATE_PARAMS_SEQ) \
|
TEMPLATE_PARAMS_SEQ) \
|
||||||
@ -216,7 +218,7 @@ namespace boost
|
|||||||
BOOST_PP_TUPLE_EAT(4))( \
|
BOOST_PP_TUPLE_EAT(4))( \
|
||||||
1, \
|
1, \
|
||||||
BOOST_FUSION_ADAPT_STRUCT_BASE_UNPACK_AND_CALL, \
|
BOOST_FUSION_ADAPT_STRUCT_BASE_UNPACK_AND_CALL, \
|
||||||
(ATTRIBUTES_CALLBACK,TEMPLATE_PARAMS_SEQ,NAME_SEQ), \
|
(ATTRIBUTES_CALLBACK,TEMPLATE_PARAMS_SEQ,NAME_SEQ, IS_VIEW),\
|
||||||
BOOST_PP_SEQ_TAIL(ATTRIBUTES_SEQ)) \
|
BOOST_PP_SEQ_TAIL(ATTRIBUTES_SEQ)) \
|
||||||
\
|
\
|
||||||
template< \
|
template< \
|
||||||
|
@ -12,6 +12,8 @@
|
|||||||
#include <boost/fusion/support/config.hpp>
|
#include <boost/fusion/support/config.hpp>
|
||||||
#include <boost/fusion/adapted/struct/detail/namespace.hpp>
|
#include <boost/fusion/adapted/struct/detail/namespace.hpp>
|
||||||
|
|
||||||
|
#define BOOST_FUSION_PROXY_PREFIX() obj.
|
||||||
|
|
||||||
#define BOOST_FUSION_ADAPT_STRUCT_DEFINE_PROXY_TYPE_IMPL( \
|
#define BOOST_FUSION_ADAPT_STRUCT_DEFINE_PROXY_TYPE_IMPL( \
|
||||||
WRAPPED_TYPE,NAMESPACE_SEQ,NAME) \
|
WRAPPED_TYPE,NAMESPACE_SEQ,NAME) \
|
||||||
\
|
\
|
||||||
|
@ -159,7 +159,7 @@ main()
|
|||||||
{
|
{
|
||||||
// conversion from point to list
|
// conversion from point to list
|
||||||
point p = {5, 3, 3};
|
point p = {5, 3, 3};
|
||||||
list<int, long> l(p);
|
list<int, long, int> l(p);
|
||||||
l = p;
|
l = p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,19 +37,39 @@ namespace ns
|
|||||||
{
|
{
|
||||||
int x;
|
int x;
|
||||||
int y;
|
int y;
|
||||||
|
int z;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if BOOST_PP_VARIADICS
|
||||||
|
|
||||||
|
// this creates a fusion view: boost::fusion::adapted::point
|
||||||
|
BOOST_FUSION_ADAPT_STRUCT_NAMED(
|
||||||
|
ns::point, point,
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
z
|
||||||
|
)
|
||||||
|
|
||||||
|
// this creates a fusion view: ns1::s1
|
||||||
|
struct s { int m; };
|
||||||
|
BOOST_FUSION_ADAPT_STRUCT_NAMED_NS(s, (ns1), s1, m)
|
||||||
|
|
||||||
|
#else // BOOST_PP_VARIADICS
|
||||||
|
|
||||||
// this creates a fusion view: boost::fusion::adapted::point
|
// this creates a fusion view: boost::fusion::adapted::point
|
||||||
BOOST_FUSION_ADAPT_STRUCT_NAMED(
|
BOOST_FUSION_ADAPT_STRUCT_NAMED(
|
||||||
ns::point, point,
|
ns::point, point,
|
||||||
(int, x)
|
(int, x)
|
||||||
(int, y)
|
(int, y)
|
||||||
|
(BOOST_FUSION_ADAPT_AUTO, z)
|
||||||
)
|
)
|
||||||
|
|
||||||
// this creates a fusion view: ns1::s1
|
// this creates a fusion view: ns1::s1
|
||||||
struct s { int m; };
|
struct s { int m; };
|
||||||
BOOST_FUSION_ADAPT_STRUCT_NAMED_NS(s, (ns1), s1, (int, m))
|
BOOST_FUSION_ADAPT_STRUCT_NAMED_NS(s, (ns1), s1, (BOOST_FUSION_ADAPT_AUTO, m))
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
int
|
int
|
||||||
main()
|
main()
|
||||||
@ -63,31 +83,33 @@ main()
|
|||||||
|
|
||||||
{
|
{
|
||||||
BOOST_MPL_ASSERT((traits::is_view<adapted::point>));
|
BOOST_MPL_ASSERT((traits::is_view<adapted::point>));
|
||||||
ns::point basep = {123, 456};
|
ns::point basep = {123, 456, 789};
|
||||||
adapted::point p(basep);
|
adapted::point p(basep);
|
||||||
|
|
||||||
std::cout << at_c<0>(p) << std::endl;
|
std::cout << at_c<0>(p) << std::endl;
|
||||||
std::cout << at_c<1>(p) << std::endl;
|
std::cout << at_c<1>(p) << std::endl;
|
||||||
|
std::cout << at_c<2>(p) << std::endl;
|
||||||
std::cout << p << std::endl;
|
std::cout << p << std::endl;
|
||||||
BOOST_TEST(p == make_vector(123, 456));
|
BOOST_TEST(p == make_vector(123, 456, 789));
|
||||||
|
|
||||||
at_c<0>(p) = 6;
|
at_c<0>(p) = 6;
|
||||||
at_c<1>(p) = 9;
|
at_c<1>(p) = 9;
|
||||||
BOOST_TEST(p == make_vector(6, 9));
|
at_c<2>(p) = 12;
|
||||||
|
BOOST_TEST(p == make_vector(6, 9, 12));
|
||||||
|
|
||||||
BOOST_STATIC_ASSERT(boost::fusion::result_of::size<adapted::point>::value == 2);
|
BOOST_STATIC_ASSERT(boost::fusion::result_of::size<adapted::point>::value == 3);
|
||||||
BOOST_STATIC_ASSERT(!boost::fusion::result_of::empty<adapted::point>::value);
|
BOOST_STATIC_ASSERT(!boost::fusion::result_of::empty<adapted::point>::value);
|
||||||
|
|
||||||
BOOST_TEST(front(p) == 6);
|
BOOST_TEST(front(p) == 6);
|
||||||
BOOST_TEST(back(p) == 9);
|
BOOST_TEST(back(p) == 12);
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
fusion::vector<int, float> v1(4, 2);
|
fusion::vector<int, float, int> v1(4, 2, 2);
|
||||||
ns::point p = {5, 3};
|
ns::point p = {5, 3, 3};
|
||||||
adapted::point v2(p);
|
adapted::point v2(p);
|
||||||
|
|
||||||
fusion::vector<long, double> v3(5, 4);
|
fusion::vector<long, double, int> v3(5, 4, 4);
|
||||||
BOOST_TEST(v1 < v2);
|
BOOST_TEST(v1 < v2);
|
||||||
BOOST_TEST(v1 <= v2);
|
BOOST_TEST(v1 <= v2);
|
||||||
BOOST_TEST(v2 > v1);
|
BOOST_TEST(v2 > v1);
|
||||||
@ -100,17 +122,17 @@ main()
|
|||||||
|
|
||||||
{
|
{
|
||||||
// conversion from adapted::point to vector
|
// conversion from adapted::point to vector
|
||||||
ns::point basep = {5, 3};
|
ns::point basep = {5, 3, 3};
|
||||||
adapted::point p(basep);
|
adapted::point p(basep);
|
||||||
fusion::vector<int, long> v(p);
|
fusion::vector<int, long, int> v(p);
|
||||||
v = p;
|
v = p;
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
// conversion from adapted::point to list
|
// conversion from adapted::point to list
|
||||||
ns::point basep = {5, 3};
|
ns::point basep = {5, 3, 3};
|
||||||
adapted::point p(basep);
|
adapted::point p(basep);
|
||||||
fusion::list<int, long> l(p);
|
fusion::list<int, long, int> l(p);
|
||||||
l = p;
|
l = p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user