diff options
author | Jason Merrill <jason@redhat.com> | 2020-04-02 23:40:46 -0400 |
---|---|---|
committer | Jason Merrill <jason@redhat.com> | 2020-04-03 13:49:45 -0400 |
commit | bcafd8748cf9eb83a9e71bf67c4e2a7c5c8f513c (patch) | |
tree | 2992d35e98d772b8e3557802b1cedf3ff59c48c7 /gcc/dce.c | |
parent | b8020a5aafd02af1ccf99372d3d8052c40b59725 (diff) | |
download | gcc-bcafd8748cf9eb83a9e71bf67c4e2a7c5c8f513c.zip gcc-bcafd8748cf9eb83a9e71bf67c4e2a7c5c8f513c.tar.gz gcc-bcafd8748cf9eb83a9e71bf67c4e2a7c5c8f513c.tar.bz2 |
c++: alias template and parameter packs (PR91966).
In this testcase, when we do a pack expansion of count_better_mins<nums>,
nums appears both in the definition of count_better_mins and as its template
argument. The intent is that we get a expansion over pairs of elements of
the pack, i.e. less<2,2>, less<2,7>, less<7,2>, .... But if we substitute
into the definition of count_better_mins when parsing the template, we end
up with sum<less<nums,nums>...>, which never gives us less<2,7>. We could
deal with this by somehow marking up the use of 'nums' as an argument for
'num', but it's simpler to mark the alias as complex, so we need to
instantiate it later with all its arguments rather than replace it early
with its expansion.
gcc/cp/ChangeLog
2020-04-03 Jason Merrill <jason@redhat.com>
PR c++/91966
* pt.c (complex_pack_expansion_r): New.
(complex_alias_template_p): Use it.
Diffstat (limited to 'gcc/dce.c')
0 files changed, 0 insertions, 0 deletions