init
Some checks failed
Docker. / Ubuntu (push) Has been cancelled
User-agent updater. / User-agent (push) Failing after 15s
Lock Threads / lock (push) Failing after 10s
Waiting for answer. / waiting-for-answer (push) Failing after 22s
Needs user action. / needs-user-action (push) Failing after 8s
Can't reproduce. / cant-reproduce (push) Failing after 8s
Close stale issues and PRs / stale (push) Has been cancelled

This commit is contained in:
allhaileris
2026-02-16 15:50:16 +03:00
commit afb81b8278
13816 changed files with 3689732 additions and 0 deletions

View File

@@ -0,0 +1,193 @@
// 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();
}