//===----------------------------------------------------------------------===// // // 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_comparisons.h" #include "test_macros.h" struct Foo{}; static_assert(!HasOperatorEqual); static_assert(HasOperatorEqual, std::expected>); static_assert(HasOperatorEqual, std::expected>); #if TEST_STD_VER >= 26 // https://wg21.link/P3379R0 static_assert(!HasOperatorEqual, std::expected>); static_assert(HasOperatorEqual, std::expected>); static_assert(HasOperatorEqual, std::expected>); static_assert(!HasOperatorEqual, std::expected>); static_assert(!HasOperatorEqual, std::expected>); static_assert(!HasOperatorEqual, std::expected>); #else // Note this is true because other overloads in expected are unconstrained static_assert(HasOperatorEqual, std::expected>); #endif constexpr bool test() { // x.has_value() && y.has_value() { const std::expected e1; const std::expected e2; assert(e1 == e2); } // !x.has_value() && y.has_value() { const std::expected e1(std::unexpect, 5); const std::expected e2; assert(e1 != e2); } // x.has_value() && !y.has_value() { const std::expected e1; 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; }