[libc++] <type_traits>: Avoid instantiating a pointer type.
authorJohn Baldwin <jhb@FreeBSD.org>
Mon, 21 Nov 2022 22:34:07 +0000 (14:34 -0800)
committerJohn Baldwin <jhb@FreeBSD.org>
Mon, 21 Nov 2022 22:34:08 +0000 (14:34 -0800)
GCC expands the pointer type in this conditional expression even for
template types _Up that are not arrays.  This raises an error when
std::decay<> is used with reference types (as is done in LLVM's
sources).  Using add_pointer<> causes GCC to only instantiate a
pointer type for array types.

Reviewed By: #libc, philnik, ldionne

Differential Revision: https://reviews.llvm.org/D135469

libcxx/include/__type_traits/decay.h
libcxx/test/std/utilities/meta/meta.trans/meta.trans.other/decay.pass.cpp

index c38bbde..f45d33b 100644 (file)
@@ -42,7 +42,7 @@ public:
     typedef _LIBCPP_NODEBUG typename conditional
                      <
                          is_array<_Up>::value,
-                         __remove_extent_t<_Up>*,
+                         __add_pointer_t<__remove_extent_t<_Up> >,
                          typename conditional
                          <
                               is_function<_Up>::value,
index af99154..d07a136 100644 (file)
@@ -29,10 +29,14 @@ int main(int, char**)
     test_decay<int, int>();
     test_decay<const volatile int, int>();
     test_decay<int*, int*>();
+    test_decay<int&, int>();
+    test_decay<const volatile int&, int>();
     test_decay<int[3], int*>();
     test_decay<const int[3], const int*>();
     test_decay<void(), void (*)()>();
 #if TEST_STD_VER > 11
+    test_decay<int&&, int>();
+    test_decay<const volatile int&&, int>();
     test_decay<int(int) const, int(int) const>();
     test_decay<int(int) volatile, int(int) volatile>();
     test_decay<int(int)  &, int(int)  &>();