//===----------------------------------------------------------------------===// // // 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=(pair&& u); // UNSUPPORTED: c++03 #include #include #include #include #include "test_macros.h" struct B { int id_; explicit B(int i = 0) : id_(i) {} virtual ~B() {} }; struct D : B { explicit D(int i) : B(i) {} }; struct NonAssignable { NonAssignable& operator=(NonAssignable const&) = delete; NonAssignable& operator=(NonAssignable&&) = delete; }; struct NothrowMoveAssignable { NothrowMoveAssignable& operator=(NothrowMoveAssignable&&) noexcept { return *this; } }; struct PotentiallyThrowingMoveAssignable { PotentiallyThrowingMoveAssignable& operator=(PotentiallyThrowingMoveAssignable&&) { return *this; } }; int main(int, char**) { { typedef std::pair> T0; typedef std::tuple> T1; T0 t0(2, std::unique_ptr(new D(3))); T1 t1; t1 = std::move(t0); assert(std::get<0>(t1) == 2); assert(std::get<1>(t1)->id_ == 3); } { using T = std::tuple; using P = std::pair; static_assert(!std::is_assignable::value, ""); } { using T = std::tuple; using P = std::pair; 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_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, ""); } return 0; }