trim.cpp 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. // Range v3 library
  2. //
  3. // Copyright Johel Guerrero 2019
  4. //
  5. // Use, modification and distribution is subject to the
  6. // Boost Software License, Version 1.0. (See accompanying
  7. // file LICENSE_1_0.txt or copy at
  8. // http://www.boost.org/LICENSE_1_0.txt)
  9. //
  10. // Project home: https://github.com/ericniebler/range-v3
  11. //
  12. #include <concepts/concepts.hpp>
  13. #include <range/v3/iterator/operations.hpp>
  14. #include <range/v3/range/operations.hpp>
  15. #include <range/v3/range/primitives.hpp>
  16. #include <range/v3/range_fwd.hpp>
  17. #include <range/v3/utility/copy.hpp>
  18. #include <range/v3/view/addressof.hpp>
  19. #include <range/v3/view/drop.hpp>
  20. #include <range/v3/view/drop_while.hpp>
  21. #include <range/v3/view/reverse.hpp>
  22. #include <range/v3/view/subrange.hpp>
  23. #include <range/v3/view/tail.hpp>
  24. #include <range/v3/view/trim.hpp>
  25. #include "../test_iterators.hpp"
  26. #include "../test_utils.hpp"
  27. int main()
  28. {
  29. using namespace ranges;
  30. int ia[] = {0, 1, 2, 3, 4, 3, 2, 1, 2, 3, 4, 3, 2, 1, 0};
  31. int ib[] = {4, 3, 2, 1, 2, 3, 4};
  32. constexpr auto bs = distance(ib);
  33. auto p = [](int i) { return i < 4; };
  34. auto rng = views::trim(ia, p);
  35. static_assert(same_as<iterator_t<decltype(rng)>, iterator_t<decltype(ia)>>, "");
  36. CPP_assert(view_<decltype(rng)>);
  37. CPP_assert(contiguous_range<decltype(rng)>);
  38. CPP_assert(common_range<decltype(rng)>);
  39. CPP_assert(!sized_range<decltype(rng)>);
  40. check_equal(rng, ib);
  41. auto && rng2 = views::trim(ib, p);
  42. check_equal(views::addressof(rng2), views::addressof(ib));
  43. auto rng3 = ia | views::drop(4) | views::trim(p);
  44. static_assert(same_as<iterator_t<decltype(rng3)>, iterator_t<decltype(rng3.base())>>, "");
  45. CPP_assert(view_<decltype(rng3)>);
  46. CPP_assert(contiguous_range<decltype(rng3)>);
  47. CPP_assert(common_range<decltype(rng3)>);
  48. CPP_assert(!sized_range<decltype(rng3)>);
  49. check_equal(rng3, ib);
  50. auto rng4 = ia | views::reverse | views::drop(4) | views::trim(p);
  51. static_assert(same_as<iterator_t<decltype(rng4)>, iterator_t<decltype(rng4.base())>>, "");
  52. CPP_assert(view_<decltype(rng4)>);
  53. CPP_assert(random_access_range<decltype(rng4)>);
  54. CPP_assert(common_range<decltype(rng4)>);
  55. CPP_assert(!sized_range<decltype(rng4)>);
  56. check_equal(rng4, ib);
  57. check_equal(views::trim(ia, p), ia | views::drop_while(p) | views::reverse | views::drop_while(p));
  58. auto rng5 = make_subrange(ib + 1, ib + bs - 1) | views::trim(p);
  59. static_assert(same_as<iterator_t<decltype(rng5)>, iterator_t<decltype(rng5.base())>>, "");
  60. CPP_assert(view_<decltype(rng5)>);
  61. CPP_assert(contiguous_range<decltype(rng5)>);
  62. CPP_assert(common_range<decltype(rng5)>);
  63. CPP_assert(!sized_range<decltype(rng5)>);
  64. CHECK(empty(rng5));
  65. auto rng6 = make_subrange(ib, ib + bs - 1) | views::trim(p);
  66. CHECK(distance(rng6) == 1);
  67. check_equal(&front(rng6), ib);
  68. auto rng7 = ib | views::tail | views::trim(p);
  69. static_assert(same_as<iterator_t<decltype(rng7)>, iterator_t<decltype(rng7.base())>>, "");
  70. CPP_assert(view_<decltype(rng7)>);
  71. CPP_assert(contiguous_range<decltype(rng7)>);
  72. CPP_assert(common_range<decltype(rng7)>);
  73. CPP_assert(!sized_range<decltype(rng7)>);
  74. CHECK(distance(rng7) == 1);
  75. check_equal(&front(rng7), ib + bs - 1);
  76. auto rng8 = make_subrange(BidirectionalIterator<const int*>(ia),
  77. BidirectionalIterator<const int*>(ia + distance(ia))) | views::trim(p);
  78. static_assert(same_as<iterator_t<decltype(rng8)>, iterator_t<decltype(rng8.base())>>, "");
  79. CPP_assert(view_<decltype(rng8)>);
  80. CPP_assert(bidirectional_range<decltype(rng8)>);
  81. CPP_assert(common_range<decltype(rng8)>);
  82. CPP_assert(!sized_range<decltype(rng8)>);
  83. return test_result();
  84. }