adapt_assoc_tpl_adt_empty.cpp 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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_assoc_adt.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. template <typename T>
  29. class empty_adt{};
  30. BOOST_FUSION_ADAPT_ASSOC_TPL_ADT((T), (empty_adt)(T),)
  31. int
  32. main()
  33. {
  34. using namespace boost::fusion;
  35. using namespace boost;
  36. std::cout << tuple_open('[');
  37. std::cout << tuple_close(']');
  38. std::cout << tuple_delimiter(", ");
  39. {
  40. BOOST_MPL_ASSERT_NOT((traits::is_view<empty_adt<void> >));
  41. empty_adt<void> e;
  42. std::cout << e << std::endl;
  43. BOOST_TEST(e == make_vector());
  44. BOOST_STATIC_ASSERT(fusion::result_of::size<empty_adt<void> >::value == 0);
  45. BOOST_MPL_ASSERT((fusion::result_of::empty<empty_adt<void> >));
  46. BOOST_MPL_ASSERT((fusion::result_of::equal_to<
  47. fusion::result_of::begin<empty_adt<void> >::type,
  48. fusion::result_of::end<empty_adt<void> >::type>));
  49. }
  50. {
  51. fusion::vector<> v;
  52. empty_adt<void> e;
  53. BOOST_TEST(v <= e);
  54. BOOST_TEST_NOT(e > v);
  55. BOOST_TEST_NOT(v < e);
  56. BOOST_TEST(v <= e);
  57. BOOST_TEST_NOT(e > v);
  58. BOOST_TEST(e >= v);
  59. }
  60. {
  61. empty_adt<void> e;
  62. // conversion from empty_adt to vector
  63. fusion::vector<> v(e);
  64. v = e;
  65. // FIXME
  66. // conversion from empty_adt to list
  67. //fusion::list<> l(e);
  68. //l = e;
  69. }
  70. BOOST_MPL_ASSERT((mpl::is_sequence<empty_adt<void> >));
  71. BOOST_MPL_ASSERT_NOT((fusion::result_of::has_key<empty_adt<void>, void>));
  72. BOOST_MPL_ASSERT_NOT((fusion::result_of::has_key<empty_adt<void>, int>));
  73. return boost::report_errors();
  74. }