// 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 "../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::take(6); has_type(*begin(rng0)); CPP_assert(view_); CPP_assert(common_range); CPP_assert(sized_range); CPP_assert(random_access_iterator); CPP_assert(range); check_equal(rng0, {0, 1, 2, 3, 4, 5}); CHECK(size(rng0) == 6u); auto rng0b = rgi | views::take(20); has_type(*begin(rng0b)); CPP_assert(view_); CPP_assert(common_range); CPP_assert(sized_range); CPP_assert(random_access_iterator); CPP_assert(range); check_equal(rng0b, {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}); CHECK(size(rng0b) == 11u); 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); CPP_assert(range); check_equal(rng1, {5, 4, 3, 2, 1, 0}); std::vector v{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; auto rng2 = v | views::take(6) | views::reverse; has_type(*begin(rng2)); CPP_assert(view_); CPP_assert(common_range); CPP_assert(sized_range); CPP_assert(random_access_iterator); CPP_assert(range); check_equal(rng2, {5, 4, 3, 2, 1, 0}); std::list l{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; auto rng3 = l | views::take(6); has_type(*begin(rng3)); CPP_assert(view_); CPP_assert(!common_range); CPP_assert(sized_range); CPP_assert(bidirectional_iterator); CPP_assert(!random_access_iterator); CPP_assert(range); ::check_equal(rng3, {0, 1, 2, 3, 4, 5}); CHECK(size(rng3) == 6u); auto rng3b = l | views::take(20); has_type(*begin(rng3b)); CPP_assert(view_); CPP_assert(!common_range); CPP_assert(sized_range); CPP_assert(bidirectional_iterator); CPP_assert(!random_access_iterator); CPP_assert(range); check_equal(rng3b, {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}); CHECK(size(rng3b) == 11u); auto rng4 = views::iota(10) | views::take(10); CPP_assert(view_); CPP_assert(!common_range); CPP_assert(sized_range); CPP_assert(range); static_assert(!ranges::is_infinite::value, ""); check_equal(rng4, {10, 11, 12, 13, 14, 15, 16, 17, 18, 19}); CHECK(size(rng4) == 10u); auto rng5 = views::iota(10) | views::take(10) | views::reverse; CPP_assert(view_); CPP_assert(common_range); CPP_assert(sized_range); CPP_assert(!range); static_assert(!ranges::is_infinite::value, ""); check_equal(rng5, {19, 18, 17, 16, 15, 14, 13, 12, 11, 10}); CHECK(size(rng5) == 10u); auto c_str = views::delimit("hello world", '\0'); CPP_assert(random_access_range); CPP_assert(!sized_range); auto rng6 = c_str | views::take(5); CPP_assert(view_); CPP_assert(random_access_range); CPP_assert(!common_range); CPP_assert(!sized_range); CPP_assert(range); check_equal(rng6, {'h','e','l','l','o'}); auto rng7 = c_str | views::take(20); check_equal(rng7, {'h','e','l','l','o',' ','w','o','r','l','d'}); subrange::iterator> rl{l.begin(), l.end()}; CPP_assert(view_); CPP_assert(bidirectional_range); CPP_assert(common_range); CPP_assert(!sized_range); CPP_assert(range); auto rng8 = rl | views::take(5); CPP_assert(view_); CPP_assert(bidirectional_range); CPP_assert(!common_range); CPP_assert(!sized_range); CPP_assert(range); check_equal(rng8, {0, 1, 2, 3, 4}); auto rng9 = rl | views::take(20); CPP_assert(view_); CPP_assert(bidirectional_range); CPP_assert(!common_range); CPP_assert(!sized_range); CPP_assert(range); check_equal(rng9, {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}); { auto rng = debug_input_view{rgi} | views::take(6); CPP_assert(!range); check_equal(rng, {0, 1, 2, 3, 4, 5}); } return test_result(); }