Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / libcxx / test / std / utilities / optional / optional.object / optional.object.observe / value_const.pass.cpp
blob9349f1de0d53ca2c248ecda47786b9f02f650a3f
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
11 // XFAIL: availability-bad_optional_access-missing && !no-exceptions
13 // <optional>
15 // constexpr const T& optional<T>::value() const &;
17 #include <optional>
18 #include <type_traits>
19 #include <cassert>
21 #include "test_macros.h"
23 using std::optional;
24 using std::in_place_t;
25 using std::in_place;
26 using std::bad_optional_access;
28 struct X
30 X() = default;
31 X(const X&) = delete;
32 constexpr int test() const & {return 3;}
33 int test() & {return 4;}
34 constexpr int test() const && {return 5;}
35 int test() && {return 6;}
38 int main(int, char**)
41 const optional<X> opt; ((void)opt);
42 ASSERT_NOT_NOEXCEPT(opt.value());
43 ASSERT_SAME_TYPE(decltype(opt.value()), X const&);
46 constexpr optional<X> opt(in_place);
47 static_assert(opt.value().test() == 3, "");
50 const optional<X> opt(in_place);
51 assert(opt.value().test() == 3);
53 #ifndef TEST_HAS_NO_EXCEPTIONS
55 const optional<X> opt;
56 try
58 (void)opt.value();
59 assert(false);
61 catch (const bad_optional_access&)
65 #endif
67 return 0;