//===----------------------------------------------------------------------===// // // 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 // //===----------------------------------------------------------------------===// // // template class tuple; // template // tuple& operator=(const pair& u); // UNSUPPORTED: c++03 #include #include #include #include #include struct NothrowCopyAssignable { NothrowCopyAssignable(NothrowCopyAssignable const&) = delete; NothrowCopyAssignable& operator=(NothrowCopyAssignable const&) noexcept { return *this; } }; struct PotentiallyThrowingCopyAssignable { PotentiallyThrowingCopyAssignable(PotentiallyThrowingCopyAssignable const&) = delete; PotentiallyThrowingCopyAssignable& operator=(PotentiallyThrowingCopyAssignable const&) { return *this; } }; #include "test_macros.h" TEST_CONSTEXPR_CXX20 bool test() { { typedef std::pair T0; typedef std::tuple T1; T0 t0(2, 'a'); T1 t1; t1 = t0; assert(std::get<0>(t1) == 2); assert(std::get<1>(t1) == short('a')); } return true; } int main(int, char**) { test(); #if TEST_STD_VER >= 20 static_assert(test()); #endif { // test that the implicitly generated copy assignment operator // is properly deleted using T = std::tuple; using P = std::tuple, std::unique_ptr>; static_assert(!std::is_assignable::value, ""); } { typedef std::tuple Tuple; typedef std::pair Pair; static_assert(std::is_nothrow_assignable::value, ""); static_assert(std::is_nothrow_assignable::value, ""); static_assert(std::is_nothrow_assignable::value, ""); } { typedef std::tuple Tuple; typedef std::pair Pair; static_assert(std::is_assignable::value, ""); static_assert(!std::is_nothrow_assignable::value, ""); static_assert(std::is_assignable::value, ""); static_assert(!std::is_nothrow_assignable::value, ""); static_assert(std::is_assignable::value, ""); static_assert(!std::is_nothrow_assignable::value, ""); } return 0; }