From 79d8c99a62b6a6fa0b3c0dc3f761659f62f3f587 Mon Sep 17 00:00:00 2001 From: Marshall Clow Date: Sat, 5 Oct 2013 21:21:17 +0000 Subject: [PATCH] LWG Issue 2247: Implement type trait 'is_null_pointer' git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@192049 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/type_traits | 8 ++- .../meta.unary/meta.unary.cat/array.pass.cpp | 3 ++ .../meta.unary/meta.unary.cat/class.pass.cpp | 3 ++ .../meta.unary/meta.unary.cat/enum.pass.cpp | 3 ++ .../meta.unary.cat/floating_point.pass.cpp | 3 ++ .../meta.unary.cat/function.pass.cpp | 3 ++ .../meta.unary.cat/integral.pass.cpp | 3 ++ .../meta.unary.cat/lvalue_ref.pass.cpp | 3 ++ .../member_function_pointer.pass.cpp | 3 ++ .../member_object_pointer.pass.cpp | 3 ++ .../meta.unary.cat/nullptr.pass.cpp | 52 +++++++++++++++++++ .../meta.unary.cat/pointer.pass.cpp | 3 ++ .../meta.unary.cat/rvalue_ref.pass.cpp | 3 ++ .../meta.unary/meta.unary.cat/union.pass.cpp | 3 ++ .../meta.unary/meta.unary.cat/void.pass.cpp | 3 ++ 15 files changed, 98 insertions(+), 1 deletion(-) create mode 100644 test/utilities/meta/meta.unary/meta.unary.cat/nullptr.pass.cpp diff --git a/include/type_traits b/include/type_traits index 47cf2959..55fc7109 100644 --- a/include/type_traits +++ b/include/type_traits @@ -28,6 +28,7 @@ namespace std // Primary classification traits: template struct is_void; + template struct is_null_pointer; // C++14 template struct is_integral; template struct is_floating_point; template struct is_array; @@ -298,6 +299,11 @@ template <> struct ____is_nullptr_t : public true_type {}; template struct _LIBCPP_TYPE_VIS_ONLY __is_nullptr_t : public ____is_nullptr_t::type> {}; +#if _LIBCPP_STD_VER > 11 +template struct _LIBCPP_TYPE_VIS_ONLY is_null_pointer + : public ____is_nullptr_t::type> {}; +#endif + // is_integral template struct __is_integral : public false_type {}; @@ -422,7 +428,7 @@ template ::value || is_union<_Tp>::value || is_void<_Tp>::value || is_reference<_Tp>::value || - is_same<_Tp, nullptr_t>::value > + __is_nullptr_t<_Tp>::value > struct __is_function : public integral_constant(__is_function_imp::__source<_Tp>())) == 1> {}; diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/array.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/array.pass.cpp index 984a6c0b..f4dd3563 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/array.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/array.pass.cpp @@ -17,6 +17,9 @@ template void test_array_imp() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert( std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/class.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/class.pass.cpp index e83dcf0e..0de00485 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/class.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/class.pass.cpp @@ -17,6 +17,9 @@ template void test_class_imp() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/enum.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/enum.pass.cpp index 5e0c9612..7c9c78fc 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/enum.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/enum.pass.cpp @@ -17,6 +17,9 @@ template void test_enum_imp() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/floating_point.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/floating_point.pass.cpp index 88140049..28664496 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/floating_point.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/floating_point.pass.cpp @@ -17,6 +17,9 @@ template void test_floating_point_imp() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert( std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/function.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/function.pass.cpp index 7989b96d..82757f50 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/function.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/function.pass.cpp @@ -17,6 +17,9 @@ template void test_function_imp() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/integral.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/integral.pass.cpp index 752ab007..7d3b0f8b 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/integral.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/integral.pass.cpp @@ -17,6 +17,9 @@ template void test_integral_imp() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert( std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/lvalue_ref.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/lvalue_ref.pass.cpp index 9d8ddcb1..3b6ccade 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/lvalue_ref.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/lvalue_ref.pass.cpp @@ -17,6 +17,9 @@ template void test_lvalue_ref() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/member_function_pointer.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/member_function_pointer.pass.cpp index 210bbd7e..dc317c55 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/member_function_pointer.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/member_function_pointer.pass.cpp @@ -17,6 +17,9 @@ template void test_member_function_pointer_imp() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/member_object_pointer.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/member_object_pointer.pass.cpp index 25666fde..4e6699cc 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/member_object_pointer.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/member_object_pointer.pass.cpp @@ -17,6 +17,9 @@ template void test_member_object_pointer_imp() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/nullptr.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/nullptr.pass.cpp new file mode 100644 index 00000000..d619701d --- /dev/null +++ b/test/utilities/meta/meta.unary/meta.unary.cat/nullptr.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. +// +//===----------------------------------------------------------------------===// + +// type_traits + +// nullptr_t +// is_null_pointer + +#include + +#if _LIBCPP_STD_VER > 11 +template +void test_nullptr_imp() +{ + static_assert(!std::is_void::value, ""); + static_assert( std::is_null_pointer::value, ""); + static_assert(!std::is_integral::value, ""); + static_assert(!std::is_floating_point::value, ""); + static_assert(!std::is_array::value, ""); + static_assert(!std::is_pointer::value, ""); + static_assert(!std::is_lvalue_reference::value, ""); + static_assert(!std::is_rvalue_reference::value, ""); + static_assert(!std::is_member_object_pointer::value, ""); + static_assert(!std::is_member_function_pointer::value, ""); + static_assert(!std::is_enum::value, ""); + static_assert(!std::is_union::value, ""); + static_assert(!std::is_class::value, ""); + static_assert(!std::is_function::value, ""); +} + +template +void test_nullptr() +{ + test_nullptr_imp(); + test_nullptr_imp(); + test_nullptr_imp(); + test_nullptr_imp(); +} + +int main() +{ + test_nullptr(); +} +#else +int main() {} +#endif diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/pointer.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/pointer.pass.cpp index 6f6f1d30..7073c106 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/pointer.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/pointer.pass.cpp @@ -17,6 +17,9 @@ template void test_pointer_imp() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/rvalue_ref.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/rvalue_ref.pass.cpp index efc32941..79644240 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/rvalue_ref.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/rvalue_ref.pass.cpp @@ -17,6 +17,9 @@ template void test_rvalue_ref() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/union.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/union.pass.cpp index 127f9f94..6cabb717 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/union.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/union.pass.cpp @@ -17,6 +17,9 @@ template void test_union_imp() { static_assert(!std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, ""); diff --git a/test/utilities/meta/meta.unary/meta.unary.cat/void.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.cat/void.pass.cpp index d50a3762..f20bcf87 100644 --- a/test/utilities/meta/meta.unary/meta.unary.cat/void.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.cat/void.pass.cpp @@ -17,6 +17,9 @@ template void test_void_imp() { static_assert( std::is_void::value, ""); +#if _LIBCPP_STD_VER > 11 + static_assert(!std::is_null_pointer::value, ""); +#endif static_assert(!std::is_integral::value, ""); static_assert(!std::is_floating_point::value, ""); static_assert(!std::is_array::value, "");