]>
git.proxmox.com Git - ceph.git/blob - ceph/src/boost/libs/fusion/test/sequence/adapt_assoc_adt_named.cpp
1 /*=============================================================================
2 Copyright (c) 2010 Christopher Schmidt
4 Distributed under the Boost Software License, Version 1.0. (See accompanying
5 file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
6 ==============================================================================*/
7 #include <boost/detail/lightweight_test.hpp>
8 #include <boost/fusion/sequence.hpp>
9 #include <boost/fusion/support.hpp>
10 #include <boost/fusion/container/list.hpp>
11 #include <boost/fusion/container/vector.hpp>
12 #include <boost/fusion/container/generation/make_vector.hpp>
13 #include <boost/fusion/adapted/adt/adapt_assoc_adt_named.hpp>
14 #include <boost/mpl/assert.hpp>
15 #include <boost/mpl/not.hpp>
16 #include <boost/mpl/front.hpp>
17 #include <boost/mpl/is_sequence.hpp>
18 #include <boost/type_traits/is_same.hpp>
19 #include <boost/static_assert.hpp>
33 point() : x(0), y(0) {}
34 point(int in_x
, int in_y
) : x(in_x
), y(in_y
) {}
36 int get_x() const { return x
; }
37 int get_y() const { return y
; }
38 void set_x(int x_
) { x
= x_
; }
39 void set_y(int y_
) { y
= y_
; }
48 #if BOOST_PP_VARIADICS
50 BOOST_FUSION_ADAPT_ASSOC_ADT_NAMED(
53 (obj
.get_x(), obj
.set_x(val
), ns::x_member
)
54 (int, int, obj
.get_y(), obj
.set_y(val
), ns::y_member
)
57 #else // BOOST_PP_VARIADICS
59 BOOST_FUSION_ADAPT_ASSOC_ADT_NAMED(
62 (auto, auto, obj
.get_x(), obj
.set_x(val
), ns::x_member
)
63 (int, int, obj
.get_y(), obj
.set_y(val
), ns::y_member
)
70 BOOST_FUSION_ADAPT_ASSOC_ADT_NAMED(empty_adt
, renamed_empty_adt
,)
75 using namespace boost::fusion
;
77 std::cout
<< tuple_open('[');
78 std::cout
<< tuple_close(']');
79 std::cout
<< tuple_delimiter(", ");
82 BOOST_MPL_ASSERT((traits::is_view
<adapted::point
>));
83 ns::point
basep(123, 456);
84 adapted::point
p(basep
);
86 std::cout
<< at_c
<0>(p
) << std::endl
;
87 std::cout
<< at_c
<1>(p
) << std::endl
;
88 std::cout
<< p
<< std::endl
;
89 BOOST_TEST(p
== make_vector(123, 456));
93 BOOST_TEST(p
== make_vector(6, 9));
95 BOOST_STATIC_ASSERT(boost::fusion::result_of::size
<adapted::point
>::value
== 2);
96 BOOST_STATIC_ASSERT(!boost::fusion::result_of::empty
<adapted::point
>::value
);
98 BOOST_TEST(front(p
) == 6);
99 BOOST_TEST(back(p
) == 9);
103 boost::fusion::vector
<int, float> v1(4, 2.f
);
104 ns::point
basev2(5, 3);
105 adapted::point
v2(basev2
);
106 boost::fusion::vector
<long, double> v3(5, 4.);
108 BOOST_TEST(v1
<= v2
);
110 BOOST_TEST(v2
>= v1
);
112 BOOST_TEST(v2
<= v3
);
114 BOOST_TEST(v3
>= v2
);
118 // conversion from adapted::point to vector
119 ns::point
basep(5, 3);
120 adapted::point
p(basep
);
121 boost::fusion::vector
<int, long> v(p
);
126 // conversion from adated::point to list
127 ns::point
basep(5, 3);
128 adapted::point
p(basep
);
129 boost::fusion::list
<int, long> l(p
);
134 BOOST_MPL_ASSERT((boost::mpl::is_sequence
<adapted::point
>));
135 BOOST_MPL_ASSERT((boost::is_same
<
136 boost::fusion::result_of::value_at_c
<adapted::point
,0>::type
137 , boost::mpl::front
<adapted::point
>::type
>));
142 BOOST_MPL_ASSERT((boost::fusion::result_of::has_key
<adapted::point
, ns::x_member
>));
143 BOOST_MPL_ASSERT((boost::fusion::result_of::has_key
<adapted::point
, ns::y_member
>));
144 BOOST_MPL_ASSERT((boost::mpl::not_
<boost::fusion::result_of::has_key
<adapted::point
, ns::z_member
> >));
146 BOOST_MPL_ASSERT((boost::is_same
<boost::fusion::result_of::value_at_key
<adapted::point
, ns::x_member
>::type
, int>));
147 BOOST_MPL_ASSERT((boost::is_same
<boost::fusion::result_of::value_at_key
<adapted::point
, ns::y_member
>::type
, int>));
149 ns::point
basep(5, 3);
150 adapted::point
p(basep
);
152 BOOST_TEST(at_key
<ns::x_member
>(p
) == 5);
153 BOOST_TEST(at_key
<ns::y_member
>(p
) == 3);
156 return boost::report_errors();