From 8148fdb5d2533cc57cefc874c46e00759df4d52f Mon Sep 17 00:00:00 2001 From: Marshall Clow Date: Tue, 21 Oct 2014 15:05:31 +0000 Subject: [PATCH] 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. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@220295 91177308-0d34-0410-b5e6-96231b3b80d8 --- .../tuple.helper/tuple.include.array.pass.cpp | 52 +++++++++++++++++++ .../tuple.include.utility.pass.cpp | 49 +++++++++++++++++ 2 files changed, 101 insertions(+) create mode 100644 test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.array.pass.cpp create mode 100644 test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.utility.pass.cpp diff --git a/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.array.pass.cpp b/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.array.pass.cpp new file mode 100644 index 00000000..d8a72c61 --- /dev/null +++ b/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/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.utility.pass.cpp b/test/utilities/tuple/tuple.tuple/tuple.helper/tuple.include.utility.pass.cpp new file mode 100644 index 00000000..8c8357d9 --- /dev/null +++ b/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>(); +}