summaryrefslogtreecommitdiffstats
path: root/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation
diff options
context:
space:
mode:
authorEric Fiselier <eric@efcs.ca>2014-12-20 01:40:03 +0000
committerEric Fiselier <eric@efcs.ca>2014-12-20 01:40:03 +0000
commit5a83710e371fe68a06e6e3876c6a2c8b820a8976 (patch)
treeafde4c82ad6704681781c5cd49baa3fbd05c85db /libcxx/test/utilities/tuple/tuple.tuple/tuple.creation
parentf11e8eab527fba316c64112f6e05de1a79693a3e (diff)
downloadbcm5719-llvm-5a83710e371fe68a06e6e3876c6a2c8b820a8976.tar.gz
bcm5719-llvm-5a83710e371fe68a06e6e3876c6a2c8b820a8976.zip
Move test into test/std subdirectory.
llvm-svn: 224658
Diffstat (limited to 'libcxx/test/utilities/tuple/tuple.tuple/tuple.creation')
-rw-r--r--libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/forward_as_tuple.pass.cpp83
-rw-r--r--libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/make_tuple.pass.cpp50
-rw-r--r--libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/tie.pass.cpp39
-rw-r--r--libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/tuple_cat.pass.cpp230
4 files changed, 0 insertions, 402 deletions
diff --git a/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/forward_as_tuple.pass.cpp b/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/forward_as_tuple.pass.cpp
deleted file mode 100644
index 5e84ff8e882..00000000000
--- a/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/forward_as_tuple.pass.cpp
+++ /dev/null
@@ -1,83 +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.
-//
-//===----------------------------------------------------------------------===//
-
-// <tuple>
-
-// template<class... Types>
-// tuple<Types&&...> forward_as_tuple(Types&&... t);
-
-#include <tuple>
-#include <cassert>
-
-template <class Tuple>
-void
-test0(const Tuple& t)
-{
- static_assert(std::tuple_size<Tuple>::value == 0, "");
-}
-
-template <class Tuple>
-void
-test1a(const Tuple& t)
-{
- static_assert(std::tuple_size<Tuple>::value == 1, "");
- static_assert(std::is_same<typename std::tuple_element<0, Tuple>::type, int&&>::value, "");
- assert(std::get<0>(t) == 1);
-}
-
-template <class Tuple>
-void
-test1b(const Tuple& t)
-{
- static_assert(std::tuple_size<Tuple>::value == 1, "");
- static_assert(std::is_same<typename std::tuple_element<0, Tuple>::type, int&>::value, "");
- assert(std::get<0>(t) == 2);
-}
-
-template <class Tuple>
-void
-test2a(const Tuple& t)
-{
- static_assert(std::tuple_size<Tuple>::value == 2, "");
- static_assert(std::is_same<typename std::tuple_element<0, Tuple>::type, double&>::value, "");
- static_assert(std::is_same<typename std::tuple_element<1, Tuple>::type, char&>::value, "");
- assert(std::get<0>(t) == 2.5);
- assert(std::get<1>(t) == 'a');
-}
-
-#if _LIBCPP_STD_VER > 11
-template <class Tuple>
-constexpr int
-test3(const Tuple& t)
-{
- return std::tuple_size<Tuple>::value;
-}
-#endif
-
-int main()
-{
- {
- test0(std::forward_as_tuple());
- }
- {
- test1a(std::forward_as_tuple(1));
- }
- {
- int i = 2;
- test1b(std::forward_as_tuple(i));
- }
- {
- double i = 2.5;
- char c = 'a';
- test2a(std::forward_as_tuple(i, c));
-#if _LIBCPP_STD_VER > 11
- static_assert ( test3 (std::forward_as_tuple(i, c)) == 2, "" );
-#endif
- }
-}
diff --git a/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/make_tuple.pass.cpp b/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/make_tuple.pass.cpp
deleted file mode 100644
index 5b33d1a23f8..00000000000
--- a/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/make_tuple.pass.cpp
+++ /dev/null
@@ -1,50 +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.
-//
-//===----------------------------------------------------------------------===//
-
-// <tuple>
-
-// template <class... Types> class tuple;
-
-// template<class... Types>
-// tuple<VTypes...> make_tuple(Types&&... t);
-
-#include <tuple>
-#include <functional>
-#include <cassert>
-
-int main()
-{
- {
- int i = 0;
- float j = 0;
- std::tuple<int, int&, float&> t = std::make_tuple(1, std::ref(i),
- std::ref(j));
- assert(std::get<0>(t) == 1);
- assert(std::get<1>(t) == 0);
- assert(std::get<2>(t) == 0);
- i = 2;
- j = 3.5;
- assert(std::get<0>(t) == 1);
- assert(std::get<1>(t) == 2);
- assert(std::get<2>(t) == 3.5);
- std::get<1>(t) = 0;
- std::get<2>(t) = 0;
- assert(i == 0);
- assert(j == 0);
- }
-#if _LIBCPP_STD_VER > 11
- {
- constexpr auto t1 = std::make_tuple(0, 1, 3.14);
- constexpr int i1 = std::get<1>(t1);
- constexpr double d1 = std::get<2>(t1);
- static_assert (i1 == 1, "" );
- static_assert (d1 == 3.14, "" );
- }
-#endif
-}
diff --git a/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/tie.pass.cpp b/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/tie.pass.cpp
deleted file mode 100644
index e6ebf958e6f..00000000000
--- a/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/tie.pass.cpp
+++ /dev/null
@@ -1,39 +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.
-//
-//===----------------------------------------------------------------------===//
-
-// <tuple>
-
-// template <class... Types> class tuple;
-
-// template<class... Types>
-// tuple<Types&...> tie(Types&... t);
-
-#include <tuple>
-#include <string>
-#include <cassert>
-
-int main()
-{
- {
- int i = 0;
- std::string s;
- std::tie(i, std::ignore, s) = std::make_tuple(42, 3.14, "C++");
- assert(i == 42);
- assert(s == "C++");
- }
-#if _LIBCPP_STD_VER > 11
- {
- static constexpr int i = 42;
- static constexpr double f = 1.1;
- constexpr std::tuple<const int &, const double &> t = std::tie(i, f);
- static_assert ( std::get<0>(t) == 42, "" );
- static_assert ( std::get<1>(t) == 1.1, "" );
- }
-#endif
-}
diff --git a/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/tuple_cat.pass.cpp b/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/tuple_cat.pass.cpp
deleted file mode 100644
index 3fca5738929..00000000000
--- a/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/tuple_cat.pass.cpp
+++ /dev/null
@@ -1,230 +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.
-//
-//===----------------------------------------------------------------------===//
-
-// <tuple>
-
-// template <class... Types> class tuple;
-
-// template <class... Tuples> tuple<CTypes...> tuple_cat(Tuples&&... tpls);
-
-#include <tuple>
-#include <utility>
-#include <array>
-#include <string>
-#include <cassert>
-
-#include "../MoveOnly.h"
-
-int main()
-{
- {
- std::tuple<> t = std::tuple_cat();
- }
- {
- std::tuple<> t1;
- std::tuple<> t2 = std::tuple_cat(t1);
- }
- {
- std::tuple<> t = std::tuple_cat(std::tuple<>());
- }
- {
- std::tuple<> t = std::tuple_cat(std::array<int, 0>());
- }
- {
- std::tuple<int> t1(1);
- std::tuple<int> t = std::tuple_cat(t1);
- assert(std::get<0>(t) == 1);
- }
-
-#if _LIBCPP_STD_VER > 11
- {
- constexpr std::tuple<> t = std::tuple_cat();
- }
- {
- constexpr std::tuple<> t1;
- constexpr std::tuple<> t2 = std::tuple_cat(t1);
- }
- {
- constexpr std::tuple<> t = std::tuple_cat(std::tuple<>());
- }
- {
- constexpr std::tuple<> t = std::tuple_cat(std::array<int, 0>());
- }
- {
- constexpr std::tuple<int> t1(1);
- constexpr std::tuple<int> t = std::tuple_cat(t1);
- static_assert(std::get<0>(t) == 1, "");
- }
- {
- constexpr std::tuple<int> t1(1);
- constexpr std::tuple<int, int> t = std::tuple_cat(t1, t1);
- static_assert(std::get<0>(t) == 1, "");
- static_assert(std::get<1>(t) == 1, "");
- }
-#endif
- {
- std::tuple<int, MoveOnly> t =
- std::tuple_cat(std::tuple<int, MoveOnly>(1, 2));
- assert(std::get<0>(t) == 1);
- assert(std::get<1>(t) == 2);
- }
- {
- std::tuple<int, int, int> t = std::tuple_cat(std::array<int, 3>());
- assert(std::get<0>(t) == 0);
- assert(std::get<1>(t) == 0);
- assert(std::get<2>(t) == 0);
- }
- {
- std::tuple<int, MoveOnly> t = std::tuple_cat(std::pair<int, MoveOnly>(2, 1));
- assert(std::get<0>(t) == 2);
- assert(std::get<1>(t) == 1);
- }
-
- {
- std::tuple<> t1;
- std::tuple<> t2;
- std::tuple<> t3 = std::tuple_cat(t1, t2);
- }
- {
- std::tuple<> t1;
- std::tuple<int> t2(2);
- std::tuple<int> t3 = std::tuple_cat(t1, t2);
- assert(std::get<0>(t3) == 2);
- }
- {
- std::tuple<> t1;
- std::tuple<int> t2(2);
- std::tuple<int> t3 = std::tuple_cat(t2, t1);
- assert(std::get<0>(t3) == 2);
- }
- {
- std::tuple<int*> t1;
- std::tuple<int> t2(2);
- std::tuple<int*, int> t3 = std::tuple_cat(t1, t2);
- assert(std::get<0>(t3) == nullptr);
- assert(std::get<1>(t3) == 2);
- }
- {
- std::tuple<int*> t1;
- std::tuple<int> t2(2);
- std::tuple<int, int*> t3 = std::tuple_cat(t2, t1);
- assert(std::get<0>(t3) == 2);
- assert(std::get<1>(t3) == nullptr);
- }
- {
- std::tuple<int*> t1;
- std::tuple<int, double> t2(2, 3.5);
- std::tuple<int*, int, double> t3 = std::tuple_cat(t1, t2);
- assert(std::get<0>(t3) == nullptr);
- assert(std::get<1>(t3) == 2);
- assert(std::get<2>(t3) == 3.5);
- }
- {
- std::tuple<int*> t1;
- std::tuple<int, double> t2(2, 3.5);
- std::tuple<int, double, int*> t3 = std::tuple_cat(t2, t1);
- assert(std::get<0>(t3) == 2);
- assert(std::get<1>(t3) == 3.5);
- assert(std::get<2>(t3) == nullptr);
- }
- {
- std::tuple<int*, MoveOnly> t1(nullptr, 1);
- std::tuple<int, double> t2(2, 3.5);
- std::tuple<int*, MoveOnly, int, double> t3 =
- std::tuple_cat(std::move(t1), t2);
- assert(std::get<0>(t3) == nullptr);
- assert(std::get<1>(t3) == 1);
- assert(std::get<2>(t3) == 2);
- assert(std::get<3>(t3) == 3.5);
- }
- {
- std::tuple<int*, MoveOnly> t1(nullptr, 1);
- std::tuple<int, double> t2(2, 3.5);
- std::tuple<int, double, int*, MoveOnly> t3 =
- std::tuple_cat(t2, std::move(t1));
- assert(std::get<0>(t3) == 2);
- assert(std::get<1>(t3) == 3.5);
- assert(std::get<2>(t3) == nullptr);
- assert(std::get<3>(t3) == 1);
- }
- {
- std::tuple<MoveOnly, MoveOnly> t1(1, 2);
- std::tuple<int*, MoveOnly> t2(nullptr, 4);
- std::tuple<MoveOnly, MoveOnly, int*, MoveOnly> t3 =
- std::tuple_cat(std::move(t1), std::move(t2));
- assert(std::get<0>(t3) == 1);
- assert(std::get<1>(t3) == 2);
- assert(std::get<2>(t3) == nullptr);
- assert(std::get<3>(t3) == 4);
- }
-
- {
- std::tuple<MoveOnly, MoveOnly> t1(1, 2);
- std::tuple<int*, MoveOnly> t2(nullptr, 4);
- std::tuple<MoveOnly, MoveOnly, int*, MoveOnly> t3 =
- std::tuple_cat(std::tuple<>(),
- std::move(t1),
- std::move(t2));
- assert(std::get<0>(t3) == 1);
- assert(std::get<1>(t3) == 2);
- assert(std::get<2>(t3) == nullptr);
- assert(std::get<3>(t3) == 4);
- }
- {
- std::tuple<MoveOnly, MoveOnly> t1(1, 2);
- std::tuple<int*, MoveOnly> t2(nullptr, 4);
- std::tuple<MoveOnly, MoveOnly, int*, MoveOnly> t3 =
- std::tuple_cat(std::move(t1),
- std::tuple<>(),
- std::move(t2));
- assert(std::get<0>(t3) == 1);
- assert(std::get<1>(t3) == 2);
- assert(std::get<2>(t3) == nullptr);
- assert(std::get<3>(t3) == 4);
- }
- {
- std::tuple<MoveOnly, MoveOnly> t1(1, 2);
- std::tuple<int*, MoveOnly> t2(nullptr, 4);
- std::tuple<MoveOnly, MoveOnly, int*, MoveOnly> t3 =
- std::tuple_cat(std::move(t1),
- std::move(t2),
- std::tuple<>());
- assert(std::get<0>(t3) == 1);
- assert(std::get<1>(t3) == 2);
- assert(std::get<2>(t3) == nullptr);
- assert(std::get<3>(t3) == 4);
- }
- {
- std::tuple<MoveOnly, MoveOnly> t1(1, 2);
- std::tuple<int*, MoveOnly> t2(nullptr, 4);
- std::tuple<MoveOnly, MoveOnly, int*, MoveOnly, int> t3 =
- std::tuple_cat(std::move(t1),
- std::move(t2),
- std::tuple<int>(5));
- assert(std::get<0>(t3) == 1);
- assert(std::get<1>(t3) == 2);
- assert(std::get<2>(t3) == nullptr);
- assert(std::get<3>(t3) == 4);
- assert(std::get<4>(t3) == 5);
- }
- {
- // See bug #19616.
- auto t1 = std::tuple_cat(
- std::make_tuple(std::make_tuple(1)),
- std::make_tuple()
- );
- assert(t1 == std::make_tuple(std::make_tuple(1)));
-
- auto t2 = std::tuple_cat(
- std::make_tuple(std::make_tuple(1)),
- std::make_tuple(std::make_tuple(2))
- );
- assert(t2 == std::make_tuple(std::make_tuple(1), std::make_tuple(2)));
- }
-}
OpenPOWER on IntegriCloud