replace.cpp 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. // Range v3 library
  2. //
  3. // Copyright Eric Niebler 2014-present
  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. #include <string>
  12. #include <sstream>
  13. #include <vector>
  14. #include <range/v3/core.hpp>
  15. #include <range/v3/view/istream.hpp>
  16. #include <range/v3/functional/reference_wrapper.hpp>
  17. #include <range/v3/utility/copy.hpp>
  18. #include <range/v3/view/iota.hpp>
  19. #include <range/v3/view/replace.hpp>
  20. #include <range/v3/view/common.hpp>
  21. #include <range/v3/view/take.hpp>
  22. #include "../simple_test.hpp"
  23. #include "../test_utils.hpp"
  24. int main()
  25. {
  26. using namespace ranges;
  27. std::string str{"1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 "};
  28. std::stringstream sin{str};
  29. {
  30. auto rng = istream<int>(sin) | views::replace(1, 42);
  31. CPP_assert(same_as<range_value_t<decltype((rng))>, int>);
  32. has_type<int const &>(*begin(rng));
  33. CPP_assert(view_<decltype(rng)>);
  34. CPP_assert(!sized_range<decltype(rng)>);
  35. CPP_assert(!common_range<decltype(rng)>);
  36. CPP_assert(input_iterator<decltype(begin(rng))>);
  37. CPP_assert(!forward_iterator<decltype(begin(rng))>);
  38. auto tmp = rng | views::common;
  39. CPP_assert(same_as<range_value_t<decltype((tmp))>, int>);
  40. has_type<int const &>(*begin(tmp));
  41. CPP_assert(view_<decltype(tmp)>);
  42. CPP_assert(common_range<decltype(tmp)>);
  43. CPP_assert(!sized_range<decltype(tmp)>);
  44. CPP_assert(input_iterator<decltype(begin(tmp))>);
  45. CPP_assert(!forward_iterator<decltype(begin(tmp))>);
  46. std::vector<int> actual{begin(tmp), end(tmp)};
  47. ::check_equal(actual, {42, 2, 3, 4, 5, 6, 7, 8, 9, 42, 2, 3, 4, 5, 6, 7, 8, 9, 42, 2, 3, 4, 5, 6, 7, 8, 9});
  48. }
  49. std::vector<int> rgi{1,2,3,4,5,6,7,8,9};
  50. {
  51. auto rng2 = rgi | views::replace(5, 42);
  52. CPP_assert(same_as<range_value_t<decltype((rng2))>, int>);
  53. has_type<int const &>(*begin(rng2));
  54. has_type<int const &>(iter_move(begin(rng2)));
  55. CPP_assert(view_<decltype(rng2)>);
  56. CPP_assert(sized_range<decltype(rng2)>);
  57. CPP_assert(common_range<decltype(rng2)>);
  58. CPP_assert(random_access_iterator<decltype(begin(rng2))>);
  59. ::check_equal(rng2, {1,2,3,4,42,6,7,8,9});
  60. }
  61. {
  62. int forty_two = 42;
  63. auto rng3 = rgi | views::replace(5, ref(forty_two));
  64. CPP_assert(same_as<range_value_t<decltype((rng3))>, int>);
  65. has_type<int &>(*begin(rng3));
  66. has_type<int const &>(iter_move(begin(rng3)));
  67. CPP_assert(view_<decltype(rng3)>);
  68. CPP_assert(sized_range<decltype(rng3)>);
  69. CPP_assert(common_range<decltype(rng3)>);
  70. CPP_assert(random_access_iterator<decltype(begin(rng3))>);
  71. ::check_equal(rng3, {1,2,3,4,42,6,7,8,9});
  72. }
  73. {
  74. auto rng4 = views::ints | views::replace(5,42) | views::take(10);
  75. CPP_assert(same_as<range_value_t<decltype((rng4))>, int>);
  76. has_type<int>(*begin(rng4));
  77. has_type<int>(iter_move(begin(rng4)));
  78. CPP_assert(view_<decltype(rng4)>);
  79. CPP_assert(sized_range<decltype(rng4)>);
  80. CPP_assert(!common_range<decltype(rng4)>);
  81. CPP_assert(random_access_iterator<decltype(begin(rng4))>);
  82. ::check_equal(rng4, {0,1,2,3,4,42,6,7,8,9});
  83. }
  84. {
  85. int const some_ints[] = {1,2,3,4,5,6,7,8,9,1,2,3,4,5,6,7,8,9,1,2,3,4,5,6,7,8,9};
  86. auto rng = debug_input_view<int const>{some_ints} | views::replace(1, 42);
  87. ::check_equal(rng, {42,2,3,4,5,6,7,8,9,42,2,3,4,5,6,7,8,9,42,2,3,4,5,6,7,8,9});
  88. }
  89. return test_result();
  90. }