c++: template template parm pack expansion [PR100372]
authorJason Merrill <jason@redhat.com>
Tue, 18 May 2021 21:12:37 +0000 (17:12 -0400)
committerJason Merrill <jason@redhat.com>
Wed, 19 May 2021 00:26:28 +0000 (20:26 -0400)
Here we have a pack expansion of a template template parameter pack, of
which the pattern is a TEMPLATE_DECL, which strip_typedefs doesn't want to
see.

PR c++/100372

gcc/cp/ChangeLog:

* tree.c (strip_typedefs): Only look at the pattern of a
TYPE_PACK_EXPANSION if it's a type.

gcc/testsuite/ChangeLog:

* g++.dg/cpp0x/alias-decl-ttp1.C: New test.

gcc/cp/tree.c
gcc/testsuite/g++.dg/cpp0x/alias-decl-ttp1.C [new file with mode: 0644]

index 35faeff..72f498f 100644 (file)
@@ -1741,13 +1741,18 @@ strip_typedefs (tree t, bool *remove_attributes, unsigned int flags)
       result = finish_underlying_type (type);
       break;
     case TYPE_PACK_EXPANSION:
-      type = strip_typedefs (PACK_EXPANSION_PATTERN (t),
-                            remove_attributes, flags);
-      if (type != PACK_EXPANSION_PATTERN (t))
-       {
-         result = copy_node (t);
-         PACK_EXPANSION_PATTERN (result) = type;
-       }
+      {
+       tree pat = PACK_EXPANSION_PATTERN (t);
+       if (TYPE_P (pat))
+         {
+           type = strip_typedefs (pat, remove_attributes, flags);
+           if (type != pat)
+             {
+               result = copy_node (t);
+               PACK_EXPANSION_PATTERN (result) = type;
+             }
+         }
+      }
       break;
     default:
       break;
diff --git a/gcc/testsuite/g++.dg/cpp0x/alias-decl-ttp1.C b/gcc/testsuite/g++.dg/cpp0x/alias-decl-ttp1.C
new file mode 100644 (file)
index 0000000..d1af8d1
--- /dev/null
@@ -0,0 +1,6 @@
+// PR c++/100372
+// { dg-do compile { target c++14 } }
+
+template <bool> using enable_if_t = int;
+template <class> bool has_P_match_v;
+template <template <class> class... List> enable_if_t<has_P_match_v<List...>> a;