From: Jason Merrill Date: Tue, 18 May 2021 21:12:37 +0000 (-0400) Subject: c++: template template parm pack expansion [PR100372] X-Git-Tag: releases/gcc-11.2.0~369 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=74ad5558d2acddcf4f5e96129ec29dd2f3d47d3a;p=thirdparty%2Fgcc.git c++: template template parm pack expansion [PR100372] 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. --- diff --git a/gcc/cp/tree.c b/gcc/cp/tree.c index a8bfd5fc0531..ced7cb5e9774 100644 --- a/gcc/cp/tree.c +++ b/gcc/cp/tree.c @@ -1723,13 +1723,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 index 000000000000..d1af8d1bbb20 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/alias-decl-ttp1.C @@ -0,0 +1,6 @@ +// PR c++/100372 +// { dg-do compile { target c++14 } } + +template using enable_if_t = int; +template bool has_P_match_v; +template