define_assoc_struct.cpp 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  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/container.hpp>
  9. #include <boost/fusion/support.hpp>
  10. #include <boost/fusion/adapted/struct/define_assoc_struct.hpp>
  11. #include <boost/preprocessor/empty.hpp>
  12. #include <boost/mpl/assert.hpp>
  13. #include <boost/static_assert.hpp>
  14. #include <iostream>
  15. namespace ns
  16. {
  17. struct x_member;
  18. struct y_member;
  19. struct z_member;
  20. }
  21. BOOST_FUSION_DEFINE_ASSOC_STRUCT(
  22. (ns),
  23. point,
  24. (int, x, ns::x_member)
  25. (int, y, ns::y_member)
  26. )
  27. BOOST_FUSION_DEFINE_ASSOC_STRUCT(BOOST_PP_EMPTY(), empty_struct, )
  28. int
  29. main()
  30. {
  31. using namespace boost::fusion;
  32. std::cout << tuple_open('[');
  33. std::cout << tuple_close(']');
  34. std::cout << tuple_delimiter(", ");
  35. {
  36. BOOST_MPL_ASSERT_NOT((traits::is_view<ns::point>));
  37. BOOST_STATIC_ASSERT(!traits::is_view<ns::point>::value);
  38. ns::point p(123, 456);
  39. std::cout << at_c<0>(p) << std::endl;
  40. std::cout << at_c<1>(p) << std::endl;
  41. std::cout << p << std::endl;
  42. BOOST_TEST(p == make_vector(123, 456));
  43. at_c<0>(p) = 6;
  44. at_c<1>(p) = 9;
  45. BOOST_TEST(p == make_vector(6, 9));
  46. BOOST_STATIC_ASSERT(boost::fusion::result_of::size<ns::point>::value == 2);
  47. BOOST_STATIC_ASSERT(!boost::fusion::result_of::empty<ns::point>::value);
  48. BOOST_TEST(front(p) == 6);
  49. BOOST_TEST(back(p) == 9);
  50. }
  51. {
  52. vector<int, float> v1(4, 2.f);
  53. ns::point v2(5, 3);
  54. vector<long, double> v3(5, 4.);
  55. BOOST_TEST(v1 < v2);
  56. BOOST_TEST(v1 <= v2);
  57. BOOST_TEST(v2 > v1);
  58. BOOST_TEST(v2 >= v1);
  59. BOOST_TEST(v2 < v3);
  60. BOOST_TEST(v2 <= v3);
  61. BOOST_TEST(v3 > v2);
  62. BOOST_TEST(v3 >= v2);
  63. }
  64. {
  65. // conversion from ns::point to vector
  66. ns::point p(5, 3);
  67. vector<int, long> v(p);
  68. v = p;
  69. }
  70. {
  71. // conversion from ns::point to list
  72. ns::point p(5, 3);
  73. list<int, long> l(p);
  74. l = p;
  75. }
  76. {
  77. // assoc stuff
  78. BOOST_MPL_ASSERT((boost::fusion::result_of::has_key<ns::point, ns::x_member>));
  79. BOOST_MPL_ASSERT((boost::fusion::result_of::has_key<ns::point, ns::y_member>));
  80. BOOST_MPL_ASSERT((boost::mpl::not_<boost::fusion::result_of::has_key<ns::point, ns::z_member> >));
  81. BOOST_MPL_ASSERT((boost::is_same<boost::fusion::result_of::value_at_key<ns::point, ns::x_member>::type, int>));
  82. BOOST_MPL_ASSERT((boost::is_same<boost::fusion::result_of::value_at_key<ns::point, ns::y_member>::type, int>));
  83. ns::point p(5, 3);
  84. BOOST_TEST(at_key<ns::x_member>(p) == 5);
  85. BOOST_TEST(at_key<ns::y_member>(p) == 3);
  86. }
  87. {
  88. ns::point p = make_list(5,3);
  89. BOOST_TEST(p == make_vector(5,3));
  90. p = make_list(3,5);
  91. BOOST_TEST(p == make_vector(3,5));
  92. }
  93. return boost::report_errors();
  94. }