//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // UNSUPPORTED: c++98, c++03, c++11, c++14 // // template // optional(const optional& rhs); #include #include #include #include "test_macros.h" using std::optional; template void test(const optional& rhs, bool is_going_to_throw = false) { bool rhs_engaged = static_cast(rhs); #ifndef TEST_HAS_NO_EXCEPTIONS try { optional lhs = rhs; assert(is_going_to_throw == false); assert(static_cast(lhs) == rhs_engaged); if (rhs_engaged) assert(*lhs == *rhs); } catch (int i) { assert(i == 6); } #else if (is_going_to_throw) return; optional lhs = rhs; assert(static_cast(lhs) == rhs_engaged); if (rhs_engaged) assert(*lhs == *rhs); #endif } class X { int i_; public: X(int i) : i_(i) {} X(const X& x) : i_(x.i_) {} ~X() {i_ = 0;} friend bool operator==(const X& x, const X& y) {return x.i_ == y.i_;} }; class Y { int i_; public: Y(int i) : i_(i) {} friend constexpr bool operator==(const Y& x, const Y& y) {return x.i_ == y.i_;} }; int count = 0; class Z { int i_; public: Z(int i) : i_(i) {TEST_THROW(6);} friend constexpr bool operator==(const Z& x, const Z& y) {return x.i_ == y.i_;} }; int main() { { typedef short U; typedef int T; optional rhs; test(rhs); } { typedef short U; typedef int T; optional rhs(U{3}); test(rhs); } { typedef X T; typedef int U; optional rhs; test(rhs); } { typedef X T; typedef int U; optional rhs(U{3}); test(rhs); } { typedef Y T; typedef int U; optional rhs; test(rhs); } { typedef Y T; typedef int U; optional rhs(U{3}); test(rhs); } { typedef Z T; typedef int U; optional rhs; test(rhs); } { typedef Z T; typedef int U; optional rhs(U{3}); test(rhs, true); } static_assert(!(std::is_constructible, const optional&>::value), ""); }