From 5a83710e371fe68a06e6e3876c6a2c8b820a8976 Mon Sep 17 00:00:00 2001 From: Eric Fiselier Date: Sat, 20 Dec 2014 01:40:03 +0000 Subject: Move test into test/std subdirectory. llvm-svn: 224658 --- .../tuple/tuple.tuple/tuple.cnstr/move.pass.cpp | 69 ---------------------- 1 file changed, 69 deletions(-) delete mode 100644 libcxx/test/utilities/tuple/tuple.tuple/tuple.cnstr/move.pass.cpp (limited to 'libcxx/test/utilities/tuple/tuple.tuple/tuple.cnstr/move.pass.cpp') diff --git a/libcxx/test/utilities/tuple/tuple.tuple/tuple.cnstr/move.pass.cpp b/libcxx/test/utilities/tuple/tuple.tuple/tuple.cnstr/move.pass.cpp deleted file mode 100644 index 8dc7d21ec28..00000000000 --- a/libcxx/test/utilities/tuple/tuple.tuple/tuple.cnstr/move.pass.cpp +++ /dev/null @@ -1,69 +0,0 @@ -//===----------------------------------------------------------------------===// -// -// 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; - -// tuple(tuple&& u); - -#include -#include - -#include "../MoveOnly.h" - -struct ConstructsWithTupleLeaf -{ - ConstructsWithTupleLeaf() {} - - ConstructsWithTupleLeaf(ConstructsWithTupleLeaf const &) { assert(false); } - ConstructsWithTupleLeaf(ConstructsWithTupleLeaf &&) {} - - template - ConstructsWithTupleLeaf(T t) - { assert(false); } -}; - -int main() -{ - { - typedef std::tuple<> T; - T t0; - T t = std::move(t0); - } - { - typedef std::tuple T; - T t0(MoveOnly(0)); - T t = std::move(t0); - assert(std::get<0>(t) == 0); - } - { - typedef std::tuple T; - T t0(MoveOnly(0), MoveOnly(1)); - T t = std::move(t0); - assert(std::get<0>(t) == 0); - assert(std::get<1>(t) == 1); - } - { - typedef std::tuple T; - T t0(MoveOnly(0), MoveOnly(1), MoveOnly(2)); - T t = std::move(t0); - assert(std::get<0>(t) == 0); - assert(std::get<1>(t) == 1); - assert(std::get<2>(t) == 2); - } - // A bug in tuple caused __tuple_leaf to use its explicit converting constructor - // as its move constructor. This tests that ConstructsWithTupleLeaf is not called - // (w/ __tuple_leaf) - { - typedef std::tuple d_t; - d_t d((ConstructsWithTupleLeaf())); - d_t d2(static_cast(d)); - } -} -- cgit v1.2.3