//===----------------------------------------------------------------------===// // // 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 // XFAIL: libcpp-no-exceptions // // optional& operator=(const optional& rhs); #include #include #include using std::optional; struct X {}; struct Y { Y() = default; Y& operator=(const Y&) { return *this; } }; struct Z1 { Z1() = default; Z1(Z1&&) = default; Z1(const Z1&) = default; Z1& operator=(Z1&&) = default; Z1& operator=(const Z1&) = delete; }; struct Z2 { Z2() = default; Z2(Z2&&) = default; Z2(const Z2&) = delete; Z2& operator=(Z2&&) = default; Z2& operator=(const Z2&) = default; }; #if __cplusplus >= 201402 template constexpr bool test() { optional opt; optional opt2; opt = opt2; return true; } #endif int main() { { using T = int; static_assert((std::is_trivially_copy_assignable>::value), ""); #if __cplusplus >= 201402 static_assert(test(), ""); #endif } { using T = X; static_assert((std::is_trivially_copy_assignable>::value), ""); #if __cplusplus >= 201402 static_assert(test(), ""); #endif } static_assert(!(std::is_trivially_copy_assignable>::value), ""); static_assert(!(std::is_trivially_copy_assignable>::value), ""); static_assert(!(std::is_copy_assignable>::value), ""); static_assert(!(std::is_copy_assignable>::value), ""); }