//===----------------------------------------------------------------------===// // // 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, c++20 // template requires (!is_void_v) // friend constexpr bool operator==(const expected& x, const expected& y); #include #include #include #include #include #include "test_macros.h" // Test constraint template concept CanCompare = requires(T1 t1, T2 t2) { t1 == t2; }; struct Foo{}; static_assert(!CanCompare); static_assert(CanCompare, std::expected>); static_assert(CanCompare, std::expected>); // Note this is true because other overloads are unconstrained static_assert(CanCompare, std::expected>); constexpr bool test() { // x.has_value() && y.has_value() { const std::expected e1(5); const std::expected e2(10); const std::expected e3(5); assert(e1 != e2); assert(e1 == e3); } // !x.has_value() && y.has_value() { const std::expected e1(std::unexpect, 5); const std::expected e2(10); const std::expected e3(5); assert(e1 != e2); assert(e1 != e3); } // x.has_value() && !y.has_value() { const std::expected e1(5); const std::expected e2(std::unexpect, 10); const std::expected e3(std::unexpect, 5); assert(e1 != e2); assert(e1 != e3); } // !x.has_value() && !y.has_value() { const std::expected e1(std::unexpect, 5); const std::expected e2(std::unexpect, 10); const std::expected e3(std::unexpect, 5); assert(e1 != e2); assert(e1 == e3); } return true; } int main(int, char**) { test(); static_assert(test()); return 0; }