drop_front.hpp 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. // Copyright Louis Dionne 2013-2017
  2. // Distributed under the Boost Software License, Version 1.0.
  3. // (See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt)
  4. #ifndef BOOST_HANA_TEST_AUTO_DROP_FRONT_HPP
  5. #define BOOST_HANA_TEST_AUTO_DROP_FRONT_HPP
  6. #include <boost/hana/assert.hpp>
  7. #include <boost/hana/drop_front.hpp>
  8. #include <boost/hana/drop_front_exactly.hpp>
  9. #include <boost/hana/equal.hpp>
  10. #include <boost/hana/integral_constant.hpp>
  11. #include <laws/base.hpp>
  12. #include "test_case.hpp"
  13. TestCase test_drop_front{[]{
  14. namespace hana = boost::hana;
  15. using hana::test::ct_eq;
  16. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  17. hana::drop_front(MAKE_TUPLE(), hana::size_c<0>),
  18. MAKE_TUPLE()
  19. ));
  20. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  21. hana::drop_front(MAKE_TUPLE(), hana::size_c<1>),
  22. MAKE_TUPLE()
  23. ));
  24. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  25. hana::drop_front(MAKE_TUPLE(), hana::size_c<2>),
  26. MAKE_TUPLE()
  27. ));
  28. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  29. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}), hana::size_c<0>),
  30. MAKE_TUPLE(ct_eq<0>{})
  31. ));
  32. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  33. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}), hana::size_c<1>),
  34. MAKE_TUPLE()
  35. ));
  36. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  37. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}), hana::size_c<2>),
  38. MAKE_TUPLE()
  39. ));
  40. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  41. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), hana::size_c<0>),
  42. MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{})
  43. ));
  44. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  45. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), hana::size_c<1>),
  46. MAKE_TUPLE(ct_eq<1>{})
  47. ));
  48. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  49. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), hana::size_c<2>),
  50. MAKE_TUPLE()
  51. ));
  52. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  53. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}), hana::size_c<0>),
  54. MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{})
  55. ));
  56. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  57. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}), hana::size_c<1>),
  58. MAKE_TUPLE(ct_eq<1>{}, ct_eq<2>{})
  59. ));
  60. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  61. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}), hana::size_c<2>),
  62. MAKE_TUPLE(ct_eq<2>{})
  63. ));
  64. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  65. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}), hana::size_c<3>),
  66. MAKE_TUPLE()
  67. ));
  68. // make sure hana::drop_front(xs) == hana::drop_front(xs, size_c<1>)
  69. BOOST_HANA_CHECK(hana::equal(
  70. hana::drop_front(MAKE_TUPLE()),
  71. hana::drop_front(MAKE_TUPLE(), hana::size_c<1>)
  72. ));
  73. BOOST_HANA_CHECK(hana::equal(
  74. hana::drop_front(MAKE_TUPLE(ct_eq<0>{})),
  75. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}), hana::size_c<1>)
  76. ));
  77. BOOST_HANA_CHECK(hana::equal(
  78. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{})),
  79. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), hana::size_c<1>)
  80. ));
  81. BOOST_HANA_CHECK(hana::equal(
  82. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<2>{})),
  83. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<2>{}), hana::size_c<1>)
  84. ));
  85. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  86. hana::drop_front(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}, ct_eq<3>{})),
  87. MAKE_TUPLE(ct_eq<1>{}, ct_eq<2>{}, ct_eq<3>{})
  88. ));
  89. }};
  90. TestCase test_drop_front_exactly{[]{
  91. namespace hana = boost::hana;
  92. using hana::test::ct_eq;
  93. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  94. hana::drop_front_exactly(MAKE_TUPLE(), hana::size_c<0>),
  95. MAKE_TUPLE()
  96. ));
  97. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  98. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{}), hana::size_c<0>),
  99. MAKE_TUPLE(ct_eq<0>{})
  100. ));
  101. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  102. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{}), hana::size_c<1>),
  103. MAKE_TUPLE()
  104. ));
  105. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  106. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), hana::size_c<0>),
  107. MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{})
  108. ));
  109. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  110. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), hana::size_c<1>),
  111. MAKE_TUPLE(ct_eq<1>{})
  112. ));
  113. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  114. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), hana::size_c<2>),
  115. MAKE_TUPLE()
  116. ));
  117. BOOST_HANA_CONSTANT_CHECK(hana::equal(
  118. hana::drop_front_exactly(
  119. MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}, ct_eq<2>{}, ct_eq<3>{},
  120. ct_eq<4>{}, ct_eq<5>{}, ct_eq<6>{}, ct_eq<7>{}), hana::size_c<4>),
  121. MAKE_TUPLE(ct_eq<4>{}, ct_eq<5>{}, ct_eq<6>{}, ct_eq<7>{})
  122. ));
  123. // make sure drop_front_exactly(xs) == drop_front_exactly(xs, size_c<1>)
  124. BOOST_HANA_CHECK(hana::equal(
  125. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{})),
  126. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{}), hana::size_c<1>)
  127. ));
  128. BOOST_HANA_CHECK(hana::equal(
  129. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{})),
  130. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{}, ct_eq<1>{}), hana::size_c<1>)
  131. ));
  132. BOOST_HANA_CHECK(hana::equal(
  133. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{}, ct_eq<2>{})),
  134. hana::drop_front_exactly(MAKE_TUPLE(ct_eq<0>{}, ct_eq<2>{}), hana::size_c<1>)
  135. ));
  136. }};
  137. #endif // !BOOST_HANA_TEST_AUTO_DROP_FRONT_HPP