llvm-project/libcxx/test/std/ranges/range.req/range.refinements/forward_range.compile.pass.cpp
Louis Dionne b8cb1dc9ea [libc++] Make <ranges> non-experimental
When we ship LLVM 16, <ranges> won't be considered experimental anymore.
We might as well do this sooner rather than later.

Differential Revision: https://reviews.llvm.org/D132151
2022-08-18 16:59:58 -04:00

56 lines
2.5 KiB
C++

//===----------------------------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
// UNSUPPORTED: c++03, c++11, c++14, c++17
// template<class R>
// concept forward_range;
#include <ranges>
#include "test_iterators.h"
#include "test_range.h"
template <template <class...> class I>
constexpr bool check_forward_range() {
constexpr bool result = std::ranges::forward_range<test_range<I> >;
static_assert(std::ranges::forward_range<test_range<I> const> == result);
static_assert(std::ranges::forward_range<test_non_const_common_range<I> > == result);
static_assert(std::ranges::forward_range<test_non_const_range<I> > == result);
static_assert(std::ranges::forward_range<test_common_range<I> > == result);
static_assert(std::ranges::forward_range<test_common_range<I> const> == result);
static_assert(!std::ranges::forward_range<test_non_const_common_range<I> const>);
static_assert(!std::ranges::forward_range<test_non_const_range<I> const>);
return result;
}
static_assert(!check_forward_range<cpp17_input_iterator>());
static_assert(!check_forward_range<cpp20_input_iterator>());
static_assert(check_forward_range<forward_iterator>());
static_assert(check_forward_range<bidirectional_iterator>());
static_assert(check_forward_range<random_access_iterator>());
static_assert(check_forward_range<contiguous_iterator>());
// Test ADL-proofing.
struct Incomplete;
template<class T> struct Holder { T t; };
static_assert(!std::ranges::forward_range<Holder<Incomplete>*>);
static_assert(!std::ranges::forward_range<Holder<Incomplete>*&>);
static_assert(!std::ranges::forward_range<Holder<Incomplete>*&&>);
static_assert(!std::ranges::forward_range<Holder<Incomplete>* const>);
static_assert(!std::ranges::forward_range<Holder<Incomplete>* const&>);
static_assert(!std::ranges::forward_range<Holder<Incomplete>* const&&>);
static_assert( std::ranges::forward_range<Holder<Incomplete>*[10]>);
static_assert( std::ranges::forward_range<Holder<Incomplete>*(&)[10]>);
static_assert( std::ranges::forward_range<Holder<Incomplete>*(&&)[10]>);
static_assert( std::ranges::forward_range<Holder<Incomplete>* const[10]>);
static_assert( std::ranges::forward_range<Holder<Incomplete>* const(&)[10]>);
static_assert( std::ranges::forward_range<Holder<Incomplete>* const(&&)[10]>);