2019-03-06 Jonathan Wakely <jwakely@redhat.com>
+ * include/std/type_traits [C++20] (is_bounded_array)
+ (is_unbounded_array, is_bounded_array_v, is_unbounded_array_v):
+ Define.
+ * testsuite/20_util/is_bounded_array/requirements/
+ explicit_instantiation.cc: New test.
+ * testsuite/20_util/is_bounded_array/requirements/typedefs.cc: New
+ test.
+ * testsuite/20_util/is_bounded_array/value.cc: New test.
+ * testsuite/20_util/is_unbounded_array/requirements/
+ explicit_instantiation.cc: New test.
+ * testsuite/20_util/is_unbounded_array/requirements/typedefs.cc: New
+ * test.
+ * testsuite/20_util/is_unbounded_array/value.cc: New test.
+
* include/bits/ptr_traits.h [C++20] (pointer_traits<T*>::pointer_to):
Add constexpr.
* testsuite/20_util/pointer_traits/pointer_to_constexpr.cc: New test.
template<typename _Tp>
using unwrap_ref_decay_t = typename unwrap_ref_decay<_Tp>::type;
+ /// True for a type that is an array of known bound.
+ template<typename _Tp>
+ struct is_bounded_array
+ : public __is_array_known_bounds<_Tp>
+ { };
+
+ /// True for a type that is an array of unknown bound.
+ template<typename _Tp>
+ struct is_unbounded_array
+ : public __is_array_unknown_bounds<_Tp>
+ { };
+
+ template<typename _Tp>
+ inline constexpr bool is_bounded_array_v
+ = is_bounded_array<_Tp>::value;
+
+ template<typename _Tp>
+ inline constexpr bool is_unbounded_array_v
+ = is_unbounded_array<_Tp>::value;
+
#ifdef _GLIBCXX_HAVE_BUILTIN_IS_CONSTANT_EVALUATED
#define __cpp_lib_is_constant_evaluated 201811L
--- /dev/null
+// { dg-options "-std=gnu++2a" }
+// { dg-do compile { target c++2a } }
+
+// Copyright (C) 2019 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING3. If not see
+// <http://www.gnu.org/licenses/>.
+
+// NB: This file is for testing type_traits with NO OTHER INCLUDES.
+
+#include <type_traits>
+
+namespace std
+{
+ typedef short test_type;
+ template struct is_bounded_array<test_type>;
+}
--- /dev/null
+// { dg-options "-std=gnu++2a" }
+// { dg-do compile { target c++2a } }
+
+// Copyright (C) 2019 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING3. If not see
+// <http://www.gnu.org/licenses/>.
+
+// NB: This file is for testing type_traits with NO OTHER INCLUDES.
+
+#include <type_traits>
+
+void test01()
+{
+ // Check for required typedefs
+ typedef std::is_bounded_array<int> test_type;
+ typedef test_type::value_type value_type;
+ typedef test_type::type type;
+ typedef test_type::type::value_type type_value_type;
+ typedef test_type::type::type type_type;
+}
--- /dev/null
+// { dg-options "-std=gnu++2a" }
+// { dg-do compile { target c++2a } }
+
+// Copyright (C) 2019 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING3. If not see
+// <http://www.gnu.org/licenses/>.
+
+#include <type_traits>
+#include <testsuite_tr1.h>
+
+void test01()
+{
+ using std::is_bounded_array;
+ using namespace __gnu_test;
+
+ static_assert(test_category<is_bounded_array, int[2]>(true), "");
+ static_assert(test_category<is_bounded_array, int[]>(false), "");
+ static_assert(test_category<is_bounded_array, int[2][3]>(true), "");
+ static_assert(test_category<is_bounded_array, int[][3]>(false), "");
+ static_assert(test_category<is_bounded_array, float*[2]>(true), "");
+ static_assert(test_category<is_bounded_array, float*[]>(false), "");
+ static_assert(test_category<is_bounded_array, float*[2][3]>(true), "");
+ static_assert(test_category<is_bounded_array, float*[][3]>(false), "");
+ static_assert(test_category<is_bounded_array, ClassType[2]>(true), "");
+ static_assert(test_category<is_bounded_array, ClassType[]>(false), "");
+ static_assert(test_category<is_bounded_array, ClassType[2][3]>(true), "");
+ static_assert(test_category<is_bounded_array, ClassType[][3]>(false), "");
+ static_assert(test_category<is_bounded_array, int(*)[2]>(false), "");
+ static_assert(test_category<is_bounded_array, int(*)[]>(false), "");
+ static_assert(test_category<is_bounded_array, int(&)[2]>(false), "");
+ static_assert(test_category<is_bounded_array, int(&)[]>(false), "");
+
+ // Sanity check.
+ static_assert(test_category<is_bounded_array, ClassType>(false), "");
+ static_assert(test_category<is_bounded_array, void()>(false), "");
+}
+
+template <class... T> void pos()
+{
+ static_assert((std::is_bounded_array_v<T> &&...));
+}
+
+template <class... T> void neg()
+{
+ static_assert((!std::is_bounded_array_v<T> &&...));
+}
+
+void test02()
+{
+ using namespace __gnu_test;
+ pos<int[2], int[2][3], float*[2], float*[2][3], ClassType[2],
+ ClassType[2][3]>();
+ neg<int[], int[][3], float*[], float*[][3], ClassType[],
+ ClassType[][3], int(*)[2], int(&)[], int(*)[2], int(&)[], ClassType>();
+}
--- /dev/null
+// { dg-options "-std=gnu++2a" }
+// { dg-do compile { target c++2a } }
+
+// Copyright (C) 2019 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING3. If not see
+// <http://www.gnu.org/licenses/>.
+
+// NB: This file is for testing type_traits with NO OTHER INCLUDES.
+
+#include <type_traits>
+
+namespace std
+{
+ typedef short test_type;
+ template struct is_unbounded_array<test_type>;
+}
--- /dev/null
+// { dg-options "-std=gnu++2a" }
+// { dg-do compile { target c++2a } }
+
+// Copyright (C) 2019 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING3. If not see
+// <http://www.gnu.org/licenses/>.
+
+// NB: This file is for testing type_traits with NO OTHER INCLUDES.
+
+#include <type_traits>
+
+void test01()
+{
+ // Check for required typedefs
+ typedef std::is_bounded_array<int> test_type;
+ typedef test_type::value_type value_type;
+ typedef test_type::type type;
+ typedef test_type::type::value_type type_value_type;
+ typedef test_type::type::type type_type;
+}
--- /dev/null
+// { dg-options "-std=gnu++2a" }
+// { dg-do compile { target c++2a } }
+
+// Copyright (C) 2019 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING3. If not see
+// <http://www.gnu.org/licenses/>.
+
+#include <type_traits>
+#include <testsuite_tr1.h>
+
+void test01()
+{
+ using std::is_unbounded_array;
+ using namespace __gnu_test;
+
+ static_assert(test_category<is_unbounded_array, int[2]>(false), "");
+ static_assert(test_category<is_unbounded_array, int[]>(true), "");
+ static_assert(test_category<is_unbounded_array, int[2][3]>(false), "");
+ static_assert(test_category<is_unbounded_array, int[][3]>(true), "");
+ static_assert(test_category<is_unbounded_array, float*[2]>(false), "");
+ static_assert(test_category<is_unbounded_array, float*[]>(true), "");
+ static_assert(test_category<is_unbounded_array, float*[2][3]>(false), "");
+ static_assert(test_category<is_unbounded_array, float*[][3]>(true), "");
+ static_assert(test_category<is_unbounded_array, ClassType[2]>(false), "");
+ static_assert(test_category<is_unbounded_array, ClassType[]>(true), "");
+ static_assert(test_category<is_unbounded_array, ClassType[2][3]>(false), "");
+ static_assert(test_category<is_unbounded_array, ClassType[][3]>(true), "");
+ static_assert(test_category<is_unbounded_array, int(*)[2]>(false), "");
+ static_assert(test_category<is_unbounded_array, int(*)[]>(false), "");
+ static_assert(test_category<is_unbounded_array, int(&)[2]>(false), "");
+ static_assert(test_category<is_unbounded_array, int(&)[]>(false), "");
+
+ // Sanity check.
+ static_assert(test_category<is_unbounded_array, ClassType>(false), "");
+}
+
+template <class... T> void pos()
+{
+ static_assert((std::is_unbounded_array_v<T> &&...));
+}
+
+template <class... T> void neg()
+{
+ static_assert((!std::is_unbounded_array_v<T> &&...));
+}
+
+void test02()
+{
+ using namespace __gnu_test;
+ pos<int[], int[][3], float*[], float*[][3], ClassType[],
+ ClassType[][3]>();
+ neg<int[2], int[2][3], float*[2], float*[2][3], ClassType[2],
+ ClassType[2][3], int(*)[2], int(&)[], int(*)[2], int(&)[], ClassType>();
+}