From 450d430f55f9ef5cf8ce1a4ae440f441873e152b Mon Sep 17 00:00:00 2001 From: Marshall Clow Date: Tue, 21 Oct 2014 15:05:31 +0000 Subject: LWG #2212 (not yet adopted) mandates that tuple_size/tuple_element are available if or are included (not just ). We already do this. Add some tests to make sure that this remains true. llvm-svn: 220295 --- .../tuple.helper/tuple.include.array.pass.cpp | 52 ++++++++++++++++++++++ .../tuple.helper/tuple.include.utility.pass.cpp | 49 ++++++++++++++++++++ 2 files changed, 101 insertions(+) create mode 100644 libcxx/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.array.pass.cpp create mode 100644 libcxx/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.utility.pass.cpp (limited to 'libcxx/test') diff --git a/libcxx/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.array.pass.cpp b/libcxx/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.array.pass.cpp new file mode 100644 index 00000000000..d8a72c617cb --- /dev/null +++ b/libcxx/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.array.pass.cpp @@ -0,0 +1,52 @@ +//===----------------------------------------------------------------------===// +// +// 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 +// class tuple_element > +// { +// public: +// typedef Ti type; +// }; +// +// LWG #2212 says that tuple_size and tuple_element must be +// available after including + +#include +#include + +template +void test() +{ + static_assert((std::is_base_of, + std::tuple_size >::value), ""); + static_assert((std::is_base_of, + std::tuple_size >::value), ""); + static_assert((std::is_base_of, + std::tuple_size >::value), ""); + static_assert((std::is_base_of, + std::tuple_size >::value), ""); + static_assert((std::is_same::type, U>::value), ""); + static_assert((std::is_same::type, const U>::value), ""); + static_assert((std::is_same::type, volatile U>::value), ""); + static_assert((std::is_same::type, const volatile U>::value), ""); +} + +int main() +{ + test, 5, int, 0>(); + test, 5, int, 1>(); + test, 4, const char *, 3>(); + test, 4, volatile int, 3>(); + test, 3, char *, 1>(); + test, 3, char *, 2>(); +} diff --git a/libcxx/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.utility.pass.cpp b/libcxx/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.utility.pass.cpp new file mode 100644 index 00000000000..8c8357d95d9 --- /dev/null +++ b/libcxx/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.utility.pass.cpp @@ -0,0 +1,49 @@ +//===----------------------------------------------------------------------===// +// +// 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 +// class tuple_size> +// : public integral_constant { }; +// +// LWG #2212 says that tuple_size and tuple_element must be +// available after including + +#include +#include + +template +void test() +{ + static_assert((std::is_base_of, + std::tuple_size >::value), ""); + static_assert((std::is_base_of, + std::tuple_size >::value), ""); + static_assert((std::is_base_of, + std::tuple_size >::value), ""); + static_assert((std::is_base_of, + std::tuple_size >::value), ""); + static_assert((std::is_same::type, U>::value), ""); + static_assert((std::is_same::type, const U>::value), ""); + static_assert((std::is_same::type, volatile U>::value), ""); + static_assert((std::is_same::type, const volatile U>::value), ""); +} + +int main() +{ + test, 2, int, 0>(); + test, 2, int, 1>(); + test, 2, int, 1>(); + test, 2, volatile int, 1>(); + test, 2, char *, 0>(); + test, 2, int, 1>(); +} -- cgit v1.2.3