diff options
author | Jason Merrill <jason@redhat.com> | 2021-05-18 17:12:37 -0400 |
---|---|---|
committer | Jason Merrill <jason@redhat.com> | 2021-05-18 20:26:28 -0400 |
commit | 061fe8c58ac4d436906a404f7fb46b0a6e0d7b4f (patch) | |
tree | aaa69ab4a54696356145344f84aa6f08c550d006 /gcc | |
parent | a8daf9a19a5eae6b98acede14bb6c27b2e0038e0 (diff) | |
download | gcc-061fe8c58ac4d436906a404f7fb46b0a6e0d7b4f.zip gcc-061fe8c58ac4d436906a404f7fb46b0a6e0d7b4f.tar.gz gcc-061fe8c58ac4d436906a404f7fb46b0a6e0d7b4f.tar.bz2 |
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.
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/cp/tree.c | 19 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/cpp0x/alias-decl-ttp1.C | 6 |
2 files changed, 18 insertions, 7 deletions
diff --git a/gcc/cp/tree.c b/gcc/cp/tree.c index 35faeff..72f498f 100644 --- a/gcc/cp/tree.c +++ b/gcc/cp/tree.c @@ -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 index 0000000..d1af8d1 --- /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 <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; |