//===----------------------------------------------------------------------===// // // 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(tuple&& u); // UNSUPPORTED: c++98, c++03 #include #include #include #include #include "test_macros.h" struct Explicit { int value; explicit Explicit(int x) : value(x) {} }; struct Implicit { int value; Implicit(int x) : value(x) {} }; struct B { int id_; explicit B(int i) : id_(i) {} virtual ~B() {} }; struct D : B { explicit D(int i) : B(i) {} }; int main(int, char**) { { typedef std::tuple T0; typedef std::tuple T1; T0 t0(2); T1 t1 = std::move(t0); assert(std::get<0>(t1) == 2); } { typedef std::tuple T0; typedef std::tuple T1; T0 t0(2, 'a'); T1 t1 = std::move(t0); assert(std::get<0>(t1) == 2); assert(std::get<1>(t1) == int('a')); } { typedef std::tuple T0; typedef std::tuple T1; T0 t0(2, 'a', D(3)); T1 t1 = std::move(t0); assert(std::get<0>(t1) == 2); assert(std::get<1>(t1) == int('a')); assert(std::get<2>(t1).id_ == 3); } { D d(3); typedef std::tuple T0; typedef std::tuple T1; T0 t0(2, 'a', d); T1 t1 = std::move(t0); d.id_ = 2; assert(std::get<0>(t1) == 2); assert(std::get<1>(t1) == int('a')); assert(std::get<2>(t1).id_ == 2); } { typedef std::tuple> T0; typedef std::tuple> T1; T0 t0(2, 'a', std::unique_ptr(new D(3))); T1 t1 = std::move(t0); assert(std::get<0>(t1) == 2); assert(std::get<1>(t1) == int('a')); assert(std::get<2>(t1)->id_ == 3); } { std::tuple t1(42); std::tuple t2(std::move(t1)); assert(std::get<0>(t2).value == 42); } { std::tuple t1(42); std::tuple t2 = std::move(t1); assert(std::get<0>(t2).value == 42); } return 0; }