Arthur O'Dwyer d4853e638b [libc++] [ranges] Permit std::mergeable and std::sortable with HAS_NO_INCOMPLETE_RANGES.
This follows the general direction of D118736 that
`_LIBCPP_HAS_NO_INCOMPLETE_RANGES` does *not* guard anything outside
of the `std::ranges::` namespace itself. This means we must permit
`ranges::less` etc. in no-ranges mode; that seems fine to me.

Differential Revision: https://reviews.llvm.org/D120139
2022-02-28 14:56:01 -05:00

64 lines
1.6 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
// <functional>
// ranges::greater
#include <functional>
#include <type_traits>
#include <cassert>
#include "test_macros.h"
#include "compare_types.h"
#include "MoveOnly.h"
#include "pointer_comparison_test_helper.h"
struct NotTotallyOrdered {
friend bool operator<(const NotTotallyOrdered&, const NotTotallyOrdered&);
};
static_assert(!std::is_invocable_v<std::ranges::greater, NotTotallyOrdered, NotTotallyOrdered>);
static_assert(!std::is_invocable_v<std::ranges::greater, int, MoveOnly>);
static_assert(std::is_invocable_v<std::ranges::greater, explicit_operators, explicit_operators>);
static_assert(requires { typename std::ranges::greater::is_transparent; });
constexpr bool test() {
auto fn = std::ranges::greater();
assert(fn(MoveOnly(42), MoveOnly(41)));
ForwardingTestObject a;
ForwardingTestObject b;
assert(!fn(a, b));
assert(fn(std::move(a), std::move(b)));
assert(!fn(2, 2));
assert(!fn(1, 2));
assert(fn(2, 1));
assert(fn(2, 1L));
return true;
}
int main(int, char**) {
test();
static_assert(test());
// test total ordering of int* for greater<int*> and greater<void>.
do_pointer_comparison_test(std::ranges::greater());
return 0;
}