adapt_assoc_struct_named_empty.cpp 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. /*=============================================================================
  2. Copyright (c) 2016 Kohei Takahashi
  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/adapted/struct/adapt_assoc_struct_named.hpp>
  8. #include <boost/fusion/sequence/intrinsic/size.hpp>
  9. #include <boost/fusion/sequence/intrinsic/empty.hpp>
  10. #include <boost/fusion/sequence/intrinsic/begin.hpp>
  11. #include <boost/fusion/sequence/intrinsic/end.hpp>
  12. #include <boost/fusion/sequence/io/out.hpp>
  13. #include <boost/fusion/iterator/equal_to.hpp>
  14. #include <boost/fusion/container/vector/vector.hpp>
  15. #include <boost/fusion/container/list/list.hpp>
  16. #include <boost/fusion/container/generation/make_vector.hpp>
  17. #include <boost/fusion/sequence/comparison/equal_to.hpp>
  18. #include <boost/fusion/sequence/comparison/not_equal_to.hpp>
  19. #include <boost/fusion/sequence/comparison/less.hpp>
  20. #include <boost/fusion/sequence/comparison/less_equal.hpp>
  21. #include <boost/fusion/sequence/comparison/greater.hpp>
  22. #include <boost/fusion/sequence/comparison/greater_equal.hpp>
  23. #include <boost/fusion/mpl.hpp>
  24. #include <boost/fusion/support/is_view.hpp>
  25. #include <boost/mpl/is_sequence.hpp>
  26. #include <boost/mpl/assert.hpp>
  27. #include <iostream>
  28. class empty_struct{};
  29. BOOST_FUSION_ADAPT_ASSOC_STRUCT_NAMED(::empty_struct,empty_struct,)
  30. int
  31. main()
  32. {
  33. using namespace boost::fusion;
  34. using namespace boost;
  35. std::cout << tuple_open('[');
  36. std::cout << tuple_close(']');
  37. std::cout << tuple_delimiter(", ");
  38. empty_struct empty;
  39. {
  40. BOOST_MPL_ASSERT((traits::is_view<adapted::empty_struct>));
  41. BOOST_STATIC_ASSERT(traits::is_view<adapted::empty_struct>::value);
  42. adapted::empty_struct e(empty);
  43. std::cout << e << std::endl;
  44. BOOST_TEST(e == make_vector());
  45. BOOST_STATIC_ASSERT(fusion::result_of::size<adapted::empty_struct>::value == 0);
  46. BOOST_MPL_ASSERT((fusion::result_of::empty<adapted::empty_struct>));
  47. BOOST_MPL_ASSERT((fusion::result_of::equal_to<
  48. fusion::result_of::begin<adapted::empty_struct>::type,
  49. fusion::result_of::end<adapted::empty_struct>::type>));
  50. }
  51. {
  52. fusion::vector<> v;
  53. adapted::empty_struct e(empty);
  54. BOOST_TEST(v <= e);
  55. BOOST_TEST_NOT(e > v);
  56. BOOST_TEST_NOT(v < e);
  57. BOOST_TEST(v <= e);
  58. BOOST_TEST_NOT(e > v);
  59. BOOST_TEST(e >= v);
  60. }
  61. {
  62. adapted::empty_struct e(empty);
  63. // conversion from empty_struct to vector
  64. fusion::vector<> v(e);
  65. v = e;
  66. // FIXME
  67. // conversion from empty_struct to list
  68. //fusion::list<> l(e);
  69. //l = e;
  70. }
  71. BOOST_MPL_ASSERT((mpl::is_sequence<adapted::empty_struct>));
  72. BOOST_MPL_ASSERT_NOT((fusion::result_of::has_key<adapted::empty_struct, void>));
  73. BOOST_MPL_ASSERT_NOT((fusion::result_of::has_key<adapted::empty_struct, int>));
  74. return boost::report_errors();
  75. }