adapt_assoc_struct_named.cpp 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. /*=============================================================================
  2. Copyright (c) 2010 Christopher Schmidt
  3. Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. ==============================================================================*/
  6. #include <boost/detail/lightweight_test.hpp>
  7. #include <boost/fusion/sequence.hpp>
  8. #include <boost/fusion/support.hpp>
  9. #include <boost/fusion/container/list.hpp>
  10. #include <boost/fusion/container/vector.hpp>
  11. #include <boost/fusion/container/generation/make_vector.hpp>
  12. #include <boost/fusion/adapted/struct/adapt_assoc_struct_named.hpp>
  13. #include <boost/mpl/assert.hpp>
  14. #include <boost/mpl/not.hpp>
  15. #include <boost/type_traits/is_same.hpp>
  16. #include <boost/static_assert.hpp>
  17. #include <iostream>
  18. #include <string>
  19. namespace ns
  20. {
  21. struct x_member;
  22. struct y_member;
  23. struct z_member;
  24. struct point
  25. {
  26. int x;
  27. int y;
  28. };
  29. }
  30. #if BOOST_PP_VARIADICS
  31. BOOST_FUSION_ADAPT_ASSOC_STRUCT_NAMED(
  32. ns::point,
  33. point,
  34. (x, ns::x_member)
  35. (auto, y, ns::y_member)
  36. )
  37. #else // BOOST_PP_VARIADICS
  38. BOOST_FUSION_ADAPT_ASSOC_STRUCT_NAMED(
  39. ns::point,
  40. point,
  41. (int, x, ns::x_member)
  42. (auto, y, ns::y_member)
  43. )
  44. #endif
  45. struct empty_struct {};
  46. BOOST_FUSION_ADAPT_ASSOC_STRUCT_NAMED(empty_struct, renamed_empty_struct,)
  47. int
  48. main()
  49. {
  50. using namespace boost::fusion;
  51. std::cout << tuple_open('[');
  52. std::cout << tuple_close(']');
  53. std::cout << tuple_delimiter(", ");
  54. {
  55. BOOST_MPL_ASSERT((traits::is_view<adapted::point>));
  56. BOOST_STATIC_ASSERT(traits::is_view<adapted::point>::value);
  57. ns::point basep = {123, 456};
  58. adapted::point p(basep);
  59. std::cout << at_c<0>(p) << std::endl;
  60. std::cout << at_c<1>(p) << std::endl;
  61. std::cout << p << std::endl;
  62. BOOST_TEST(p == make_vector(123, 456));
  63. at_c<0>(p) = 6;
  64. at_c<1>(p) = 9;
  65. BOOST_TEST(p == make_vector(6, 9));
  66. BOOST_STATIC_ASSERT(boost::fusion::result_of::size<adapted::point>::value == 2);
  67. BOOST_STATIC_ASSERT(!boost::fusion::result_of::empty<adapted::point>::value);
  68. BOOST_TEST(front(p) == 6);
  69. BOOST_TEST(back(p) == 9);
  70. }
  71. {
  72. vector<int, float> v1(4, 2.f);
  73. ns::point basev2 = {5, 3};
  74. adapted::point v2(basev2);
  75. vector<long, double> v3(5, 4.);
  76. BOOST_TEST(v1 < v2);
  77. BOOST_TEST(v1 <= v2);
  78. BOOST_TEST(v2 > v1);
  79. BOOST_TEST(v2 >= v1);
  80. BOOST_TEST(v2 < v3);
  81. BOOST_TEST(v2 <= v3);
  82. BOOST_TEST(v3 > v2);
  83. BOOST_TEST(v3 >= v2);
  84. }
  85. {
  86. // conversion from adapted::point to vector
  87. ns::point basep = {5, 3};
  88. adapted::point p(basep);
  89. vector<int, long> v(p);
  90. v = p;
  91. }
  92. {
  93. // conversion from adapted::point to list
  94. ns::point basep = {5, 3};
  95. adapted::point p(basep);
  96. list<int, long> l(p);
  97. l = p;
  98. }
  99. {
  100. // assoc stuff
  101. BOOST_MPL_ASSERT((boost::fusion::result_of::has_key<adapted::point, ns::x_member>));
  102. BOOST_MPL_ASSERT((boost::fusion::result_of::has_key<adapted::point, ns::y_member>));
  103. BOOST_MPL_ASSERT((boost::mpl::not_<boost::fusion::result_of::has_key<adapted::point, ns::z_member> >));
  104. BOOST_MPL_ASSERT((boost::is_same<boost::fusion::result_of::value_at_key<adapted::point, ns::x_member>::type, int>));
  105. BOOST_MPL_ASSERT((boost::is_same<boost::fusion::result_of::value_at_key<adapted::point, ns::y_member>::type, int>));
  106. ns::point basep = {5, 3};
  107. adapted::point p(basep);
  108. BOOST_TEST(at_key<ns::x_member>(p) == 5);
  109. BOOST_TEST(at_key<ns::y_member>(p) == 3);
  110. }
  111. return boost::report_errors();
  112. }