// 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 #include #include #include #include #include #include #include #include #include #include "../simple_test.hpp" #include "../test_utils.hpp" int main() { using namespace ranges; int rgi[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; auto rng0 = rgi | views::slice(3, 9); has_type(*begin(rng0)); CPP_assert(view_); CPP_assert(common_range); CPP_assert(sized_range); CPP_assert(random_access_iterator); ::check_equal(rng0, {3, 4, 5, 6, 7, 8}); auto rng1 = rng0 | views::reverse; has_type(*begin(rng1)); CPP_assert(view_); CPP_assert(common_range); CPP_assert(sized_range); CPP_assert(random_access_iterator); ::check_equal(rng1, {8, 7, 6, 5, 4, 3}); std::vector v{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; auto rng2 = v | views::slice(3, 9) | views::reverse; has_type(*begin(rng2)); CPP_assert(view_); CPP_assert(common_range); CPP_assert(sized_range); CPP_assert(random_access_iterator); ::check_equal(rng2, {8, 7, 6, 5, 4, 3}); std::list l{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; auto rng3 = l | views::slice(3, 9); has_type(*begin(rng3)); CPP_assert(view_); CPP_assert(!common_range); CPP_assert(sized_range); CPP_assert(bidirectional_iterator); CPP_assert(!random_access_iterator); ::check_equal(rng3, {3, 4, 5, 6, 7, 8}); auto rng4 = views::iota(10) | views::slice(10, 20); CPP_assert(view_); CPP_assert(common_range); CPP_assert(sized_range); static_assert(!ranges::is_infinite::value, ""); ::check_equal(rng4, {20, 21, 22, 23, 24, 25, 26, 27, 28, 29}); auto rng5 = views::iota(10)[{10, 20}]; CPP_assert(view_); CPP_assert(common_range); CPP_assert(sized_range); static_assert(!ranges::is_infinite::value, ""); ::check_equal(rng5, {20, 21, 22, 23, 24, 25, 26, 27, 28, 29}); auto rng6 = views::all(l)[{3, 9}]; has_type(*begin(rng6)); CPP_assert(view_); CPP_assert(!common_range); CPP_assert(sized_range); CPP_assert(bidirectional_iterator); CPP_assert(!random_access_iterator); ::check_equal(rng6, {3, 4, 5, 6, 7, 8}); auto rng7 = views::all(l)[{3, end}]; has_type(*begin(rng7)); CPP_assert(view_); CPP_assert(common_range); CPP_assert(sized_range); CPP_assert(bidirectional_iterator); CPP_assert(!random_access_iterator); ::check_equal(rng7, {3, 4, 5, 6, 7, 8, 9, 10}); auto rng8 = views::all(l)[{end-5,end-2}]; has_type(*begin(rng8)); CPP_assert(view_); CPP_assert(!common_range); CPP_assert(sized_range); CPP_assert(bidirectional_iterator); CPP_assert(!random_access_iterator); ::check_equal(rng8, {6, 7, 8}); auto rng9 = views::iota(0)[{0,end}]; static_assert(is_infinite::value, "should be infinite"); { std::string str{"0 1 2 3 4 5 6 7 8 9"}; std::stringstream sin{str}; auto rng10 = istream(sin)[{3,9}]; ::check_equal(rng10, {3, 4, 5, 6, 7, 8}); } { std::string str{"0 1 2 3 4 5 6 7 8 9"}; std::stringstream sin{str}; auto rng11 = istream(sin)[{3,end}]; ::check_equal(rng11, {3, 4, 5, 6, 7, 8, 9}); } { auto letters = views::closed_iota('a','g'); static_assert(random_access_range && view_, ""); static_assert(common_range && view_, ""); ::check_equal(letters[{2,end-2}], {'c','d','e'}); } { int const some_ints[] = {0,1,2,3,4,5,6,7,8,9}; auto rng = debug_input_view{some_ints} | views::slice(3,10); ::check_equal(rng, {3, 4, 5, 6, 7, 8, 9}); } return test_result(); }