[RISCV] Fix mgather -> riscv.masked.strided.load combine not extending indices (...
[llvm-project.git] / libcxx / test / std / utilities / function.objects / range.cmp / greater_equal.pass.cpp
blobad24a98a168cf19dc593ff15b32d07a9c28e7587
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 // UNSUPPORTED: c++03, c++11, c++14, c++17
11 // <functional>
13 // ranges::greater_equal
15 #include <cassert>
16 #include <functional>
17 #include <type_traits>
18 #include <utility>
20 #include "test_macros.h"
21 #include "compare_types.h"
22 #include "MoveOnly.h"
23 #include "pointer_comparison_test_helper.h"
25 struct NotTotallyOrdered {
26 friend bool operator<(const NotTotallyOrdered&, const NotTotallyOrdered&);
29 static_assert(!std::is_invocable_v<std::ranges::greater_equal, NotTotallyOrdered, NotTotallyOrdered>);
30 static_assert(!std::is_invocable_v<std::ranges::greater_equal, int, MoveOnly>);
31 static_assert(std::is_invocable_v<std::ranges::greater_equal, explicit_operators, explicit_operators>);
33 static_assert(requires { typename std::ranges::greater_equal::is_transparent; });
35 constexpr bool test() {
36 auto fn = std::ranges::greater_equal();
38 assert(fn(MoveOnly(42), MoveOnly(42)));
40 ForwardingTestObject a;
41 ForwardingTestObject b;
42 assert(fn(a, b));
43 assert(!fn(std::move(a), std::move(b)));
45 assert(fn(2, 2));
46 assert(fn(2, 1));
47 assert(!fn(1, 2));
49 assert(fn(2, 1L));
51 return true;
54 int main(int, char**) {
56 test();
57 static_assert(test());
59 // test total ordering of int* for greater_equal<int*> and greater_equal<void>.
60 do_pointer_comparison_test(std::ranges::greater_equal());
62 return 0;