1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
|
//===----------------------------------------------------------------------===//
//
// 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
// friend constexpr bool operator==(const outer-iterator& x, const outer-iterator& y)
// requires forward_range<Base>;
//
// friend constexpr bool operator==(const outer-iterator& x, default_sentinel_t);
#include <ranges>
#include <concepts>
#include <string_view>
#include "../types.h"
template <class Iter>
concept CanCallEquals = requires(const Iter& i) {
i == i;
i != i;
};
constexpr bool test() {
// Forward range supports both overloads of `operator==`.
{
// outer-iterator == outer-iterator
{
SplitViewForward v("abc def", " ");
auto b = v.begin(), e = v.end();
assert(b == b);
assert(!(b != b));
assert(e == e);
assert(!(e != e));
assert(!(b == e));
assert(b != e);
}
// outer-iterator == default_sentinel
{
SplitViewForward v("abc def", " ");
auto b = v.begin(), e = v.end();
assert(!(b == std::default_sentinel));
assert(b != std::default_sentinel);
assert(e == std::default_sentinel);
assert(!(e != std::default_sentinel));
}
// Default-constructed `outer-iterator`s compare equal.
{
OuterIterForward i1, i2;
assert(i1 == i2);
assert(!(i1 != i2));
}
}
// Input range only supports comparing an `outer-iterator` to the default sentinel.
{
using namespace std::string_view_literals;
SplitViewInput v("abc def"sv, ' ');
auto b = v.begin();
std::same_as<std::default_sentinel_t> decltype(auto) e = v.end();
static_assert(!CanCallEquals<decltype(b)>);
assert(!(b == std::default_sentinel));
assert(b != std::default_sentinel);
assert(!(b == e));
assert(b != e);
}
return true;
}
int main(int, char**) {
test();
static_assert(test());
return 0;
}
|