blob: e0d7457808b8d4e590535e168ad238edd1d42c57 [file]
//===----------------------------------------------------------------------===//
//
// 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<class T2> friend constexpr bool operator==(const expected& x, const T2& v);
#include <cassert>
#include <concepts>
#include <expected>
#include <type_traits>
#include <utility>
#include "test_comparisons.h"
#include "test_macros.h"
#if TEST_STD_VER >= 26
// https://wg21.link/P3379R0
static_assert(HasOperatorEqual<std::expected<int, int>, int>);
static_assert(HasOperatorEqual<std::expected<int, int>, EqualityComparable>);
static_assert(!HasOperatorEqual<std::expected<int, int>, NonComparable>);
#endif
constexpr bool test() {
// x.has_value()
{
const std::expected<EqualityComparable, int> e1(std::in_place, 5);
int i2 = 10;
int i3 = 5;
assert(e1 != i2);
assert(e1 == i3);
}
// !x.has_value()
{
const std::expected<EqualityComparable, int> e1(std::unexpect, 5);
int i2 = 10;
int i3 = 5;
assert(e1 != i2);
assert(e1 != i3);
}
#if TEST_STD_VER >= 26
// Regression test for https://llvm.org/PR160431: the constraint of this overload
// would recurse when ADL on the comparison found the same hidden friend through a
// type whose associated namespaces reach std::expected.
{
std::pair<int, std::expected<int, int>> p1, p2;
assert(p1 == p2);
}
#endif
// LWG4366
{ // x.has_value()
const std::expected<ImplicitBool::E1, int> e1(ImplicitBool::E1{1});
assert(e1 == ImplicitBool::E2{1});
assert(e1 != ImplicitBool::E2{3});
}
{ // !x.has_value()
const std::expected<ImplicitBool::E1, int> e1(std::unexpect, 1);
assert(e1 != ImplicitBool::E2{1});
assert(e1 != ImplicitBool::E2{2});
}
return true;
}
int main(int, char**) {
test();
static_assert(test());
return 0;
}