//===----------------------------------------------------------------------===// // // 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. // //===----------------------------------------------------------------------===// // // template class tuple; // template // tuple& operator=(const tuple& u); // UNSUPPORTED: c++98, c++03 #include #include #include struct B { int id_; explicit B(int i = 0) : id_(i) {} }; struct D : B { explicit D(int i = 0) : B(i) {} }; int main() { { typedef std::tuple T0; typedef std::tuple T1; T0 t0(2); T1 t1; t1 = t0; assert(std::get<0>(t1) == 2); } { typedef std::tuple T0; typedef std::tuple T1; T0 t0(2, 'a'); T1 t1; t1 = 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; t1 = t0; assert(std::get<0>(t1) == 2); assert(std::get<1>(t1) == int('a')); assert(std::get<2>(t1).id_ == 3); } { D d(3); D d2(2); typedef std::tuple T0; typedef std::tuple T1; T0 t0(2, 'a', d2); T1 t1(1, 'b', d); t1 = t0; assert(std::get<0>(t1) == 2); assert(std::get<1>(t1) == int('a')); assert(std::get<2>(t1).id_ == 2); } { // Test that tuple evaluates correctly applies an lvalue reference // before evaluating is_assignable (ie 'is_assignable') // instead of evaluating 'is_assignable' which is false. int x = 42; int y = 43; std::tuple t(std::move(x)); std::tuple t2(y); t = t2; assert(std::get<0>(t) == 43); assert(&std::get<0>(t) == &x); } }