| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193 |
- // Range v3 library
- //
- // Copyright Eric Niebler 2014-present
- //
- // Use, modification and distribution is subject to the
- // Boost Software License, Version 1.0. (See accompanying
- // file LICENSE_1_0.txt or copy at
- // http://www.boost.org/LICENSE_1_0.txt)
- //
- // Project home: https://github.com/ericniebler/range-v3
- #include <list>
- #include <vector>
- #include <sstream>
- #include <range/v3/core.hpp>
- #include <range/v3/view/istream.hpp>
- #include <range/v3/view/move.hpp>
- #include <range/v3/view/partial_sum.hpp>
- #include <range/v3/view/reverse.hpp>
- #include <range/v3/view/stride.hpp>
- #include <range/v3/view/iota.hpp>
- #include <range/v3/algorithm/copy.hpp>
- #include <range/v3/iterator/operations.hpp>
- #include <range/v3/iterator/insert_iterators.hpp>
- #include <range/v3/iterator/stream_iterators.hpp>
- #include <range/v3/numeric.hpp>
- #include "../simple_test.hpp"
- #include "../test_utils.hpp"
- #include "../test_iterators.hpp"
- // https://github.com/ericniebler/range-v3/issues/1291
- void bug_1291()
- {
- std::vector<int> vec;
- auto tx = vec | ranges::views::stride( 2 ) | ranges::views::partial_sum;
- ranges::accumulate( tx, 0 );
- }
- int main()
- {
- using namespace ranges;
- auto const v = []
- {
- std::vector<int> vec(50);
- iota(vec, 0);
- return vec;
- }();
- {
- auto rng = v | views::stride(3);
- using R = decltype(rng);
- CPP_assert(random_access_range<R> && view_<R>);
- CPP_assert(!contiguous_range<R>);
- CPP_assert(common_range<R>);
- CPP_assert(sized_range<R>);
- CPP_assert(range<R const>);
- ::check_equal(rng | views::reverse,
- {48, 45, 42, 39, 36, 33, 30, 27, 24, 21, 18, 15, 12, 9, 6, 3, 0});
- }
- {
- std::stringstream str;
- copy(v, ostream_iterator<int>{str, " "});
- auto rng = istream<int>(str) | views::stride(3);
- using R = decltype(rng);
- CPP_assert(input_range<R> && view_<R>);
- CPP_assert(!forward_range<R>);
- CPP_assert(!common_range<R>);
- CPP_assert(!sized_range<R>);
- CPP_assert(!range<R const>);
- check_equal(rng, {0, 3, 6, 9, 12, 15, 18, 21, 24, 27, 30, 33, 36, 39, 42, 45, 48});
- }
- {
- std::list<int> li;
- copy(v, back_inserter(li));
- auto rng = li | views::stride(3);
- using R = decltype(rng);
- CPP_assert(bidirectional_range<R> && view_<R>);
- CPP_assert(!random_access_range<R>);
- CPP_assert(common_range<R>);
- CPP_assert(sized_range<R>);
- CPP_assert(range<R const>);
- ::check_equal(rng,
- {0, 3, 6, 9, 12, 15, 18, 21, 24, 27, 30, 33, 36, 39, 42, 45, 48});
- ::check_equal(rng | views::reverse,
- {48, 45, 42, 39, 36, 33, 30, 27, 24, 21, 18, 15, 12, 9, 6, 3, 0});
- for(int i : rng | views::reverse)
- std::cout << i << ' ';
- std::cout << '\n';
- }
- {
- auto x2 = v | views::stride(3);
- CHECK(ranges::distance(x2) == 17);
- auto it0 = x2.begin();
- auto it1 = std::next(it0, 10);
- CHECK((it1 - it0) == 10);
- CHECK((it0 - it1) == -10);
- CHECK((it0 - it0) == 0);
- CHECK((it1 - it1) == 0);
- }
- {
- const auto n = 4;
- auto rng = v | views::move | views::stride(2);
- CHECK((next(begin(rng), n) - begin(rng)) == n);
- }
- {
- // Regression test #368
- int n = 42;
- (void)ranges::views::stride(n);
- }
- {
- int const some_ints[] = {0,1,2,3,4,5,6,7};
- auto rng = debug_input_view<int const>{some_ints} | views::stride(2);
- using R = decltype(rng);
- CPP_assert(input_range<R> && view_<R>);
- CPP_assert(!forward_range<R>);
- CPP_assert(!common_range<R>);
- CPP_assert(sized_range<R>);
- CPP_assert(!range<R const>);
- ::check_equal(rng, {0,2,4,6});
- }
- {
- std::list<int> li;
- copy(v, back_inserter(li));
- subrange<std::list<int>::const_iterator> tmp{li.begin(), li.end()};
- auto rng = tmp | views::stride(3);
- using R = decltype(rng);
- CPP_assert(bidirectional_range<R> && view_<R>);
- CPP_assert(!random_access_range<R>);
- CPP_assert(!common_range<R>);
- CPP_assert(!sized_range<R>);
- CPP_assert(!range<R const>);
- ::check_equal(rng,
- {0, 3, 6, 9, 12, 15, 18, 21, 24, 27, 30, 33, 36, 39, 42, 45, 48});
- ::check_equal(rng | views::reverse,
- {48, 45, 42, 39, 36, 33, 30, 27, 24, 21, 18, 15, 12, 9, 6, 3, 0});
- }
- {
- std::list<int> li;
- copy(v, back_inserter(li));
- using CLI = std::list<int>::const_iterator;
- subrange<CLI, CLI, subrange_kind::sized> tmp{li};
- auto rng = tmp | views::stride(3);
- using R = decltype(rng);
- CPP_assert(bidirectional_range<R> && view_<R>);
- CPP_assert(!random_access_range<R>);
- CPP_assert(common_range<R>);
- CPP_assert(sized_range<R>);
- CPP_assert(range<R const>);
- CHECK((*--rng.end()) == 48);
- ::check_equal(rng,
- {0, 3, 6, 9, 12, 15, 18, 21, 24, 27, 30, 33, 36, 39, 42, 45, 48});
- ::check_equal(rng | views::reverse,
- {48, 45, 42, 39, 36, 33, 30, 27, 24, 21, 18, 15, 12, 9, 6, 3, 0});
- }
- // https://github.com/ericniebler/range-v3/issues/901
- {
- auto r = views::iota( 0, 12 );
- // Evenly divisible stride:
- auto strided1 = r | views::stride(3);
- ::check_equal(strided1, {0, 3, 6, 9});
- CHECK(strided1.size() == 4u);
- CHECK(strided1.front() == 0);
- CHECK(strided1[0] == 0);
- CHECK(strided1.back() == 9);
- CHECK(strided1[3] == 9);
- CHECK(strided1[(int)strided1.size() - 1] == 9);
- // Not evenly divisible stride:
- auto strided2 = r | views::stride(5);
- ::check_equal(strided2, {0, 5, 10});
- CHECK(strided2.size() == 3u);
- CHECK(strided2.front() == 0);
- CHECK(strided2[0] == 0);
- CHECK(strided2.back() == 10);
- CHECK(strided2[2] == 10);
- CHECK(strided2[(int)strided2.size() - 1] == 10);
- }
- return ::test_result();
- }
|