AFAICT, Cpp17InputIterators are not required to be default constructible, since that requirement is added in Cpp17ForwardIterator. Hence, our archetype for Cpp17InputIterator should not be default constructible. Removing that constructor has a ripple effect on a couple of tests that were making incorrect assumptions. Notably: - Some tests were using cpp17_input_iterator as a sentinel for itself. That is not valid, because a cpp17_input_iterator is not semiregular anymore after the change (and hence it doesn't satisfy sentinel_for). - Some tests were using a stride-counted cpp17_input_iterator as the sentinel for a range. This doesn't work anymore because of the problem above, so these tests were changed not to check stride counts for input iterators. - Some tests were default constructing cpp17_input_iterator when a simple alternative was available -- those have been changed to use that alternative. Differential Revision: https://reviews.llvm.org/D115806
46 lines
2.0 KiB
C++
46 lines
2.0 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
|
|
// UNSUPPORTED: libcpp-no-concepts
|
|
// UNSUPPORTED: libcpp-has-no-incomplete-ranges
|
|
|
|
// template<class R>
|
|
// concept input_range;
|
|
|
|
#include <ranges>
|
|
|
|
#include "test_iterators.h"
|
|
#include "test_range.h"
|
|
|
|
|
|
|
|
static_assert(std::ranges::input_range<test_range<cpp17_input_iterator> >);
|
|
static_assert(std::ranges::input_range<test_range<cpp17_input_iterator> const>);
|
|
|
|
static_assert(std::ranges::input_range<test_range<cpp20_input_iterator> >);
|
|
static_assert(std::ranges::input_range<test_range<cpp20_input_iterator> const>);
|
|
|
|
static_assert(std::ranges::input_range<test_non_const_range<cpp17_input_iterator> >);
|
|
static_assert(std::ranges::input_range<test_non_const_range<cpp20_input_iterator> >);
|
|
|
|
static_assert(!std::ranges::input_range<test_non_const_range<cpp17_input_iterator> const>);
|
|
static_assert(!std::ranges::input_range<test_non_const_range<cpp20_input_iterator> const>);
|
|
|
|
static_assert(std::ranges::input_range<test_common_range<forward_iterator> >);
|
|
static_assert(!std::ranges::input_range<test_common_range<cpp20_input_iterator> >);
|
|
|
|
static_assert(std::ranges::input_range<test_common_range<forward_iterator> const>);
|
|
static_assert(!std::ranges::input_range<test_common_range<cpp20_input_iterator> const>);
|
|
|
|
static_assert(std::ranges::input_range<test_non_const_common_range<forward_iterator> >);
|
|
static_assert(!std::ranges::input_range<test_non_const_common_range<cpp20_input_iterator> >);
|
|
|
|
static_assert(!std::ranges::input_range<test_non_const_common_range<forward_iterator> const>);
|
|
static_assert(!std::ranges::input_range<test_non_const_common_range<cpp20_input_iterator> const>);
|