adapt_adt_named_empty.cpp 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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/adt/adapt_adt_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_adt{};
  29. BOOST_FUSION_ADAPT_ADT_NAMED(::empty_adt,empty_adt,)
  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_adt empty;
  39. {
  40. BOOST_MPL_ASSERT((traits::is_view<adapted::empty_adt>));
  41. BOOST_STATIC_ASSERT(traits::is_view<adapted::empty_adt>::value);
  42. adapted::empty_adt e(empty);
  43. std::cout << e << std::endl;
  44. BOOST_TEST(e == make_vector());
  45. BOOST_STATIC_ASSERT(fusion::result_of::size<adapted::empty_adt>::value == 0);
  46. BOOST_MPL_ASSERT((fusion::result_of::empty<adapted::empty_adt>));
  47. BOOST_MPL_ASSERT((fusion::result_of::equal_to<
  48. fusion::result_of::begin<adapted::empty_adt>::type,
  49. fusion::result_of::end<adapted::empty_adt>::type>));
  50. }
  51. {
  52. fusion::vector<> v;
  53. adapted::empty_adt e(empty);
  54. BOOST_TEST(v == e);
  55. BOOST_TEST_NOT(v != e);
  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_adt e(empty);
  63. // conversion from empty_adt to vector
  64. fusion::vector<> v(e);
  65. v = e;
  66. // FIXME
  67. // conversion from empty_adt to list
  68. //fusion::list<> l(e);
  69. //l = e;
  70. }
  71. BOOST_MPL_ASSERT((mpl::is_sequence<adapted::empty_adt>));
  72. return boost::report_errors();
  73. }