//===----------------------------------------------------------------------===// // // 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: no-threads // // // class future_error // // const error_code& code() const noexcept; #include #include #include #include "test_macros.h" int main(int, char**) { ASSERT_NOEXCEPT(std::declval().code()); ASSERT_SAME_TYPE(decltype(std::declval().code()), std::error_code const&); // Before C++17, we can't construct std::future_error directly in a standards-conforming way #if TEST_STD_VER >= 17 { std::future_error const f(std::future_errc::broken_promise); std::error_code const& code = f.code(); assert(code == std::make_error_code(std::future_errc::broken_promise)); } { std::future_error const f(std::future_errc::future_already_retrieved); std::error_code const& code = f.code(); assert(code == std::make_error_code(std::future_errc::future_already_retrieved)); } { std::future_error const f(std::future_errc::promise_already_satisfied); std::error_code const& code = f.code(); assert(code == std::make_error_code(std::future_errc::promise_already_satisfied)); } { std::future_error const f(std::future_errc::no_state); std::error_code const& code = f.code(); assert(code == std::make_error_code(std::future_errc::no_state)); } #endif return 0; }