diff options
author | Patrick Palka <ppalka@redhat.com> | 2020-07-29 22:06:36 -0400 |
---|---|---|
committer | Patrick Palka <ppalka@redhat.com> | 2020-07-29 22:06:36 -0400 |
commit | f31dd9beb95f4beda1d2bd5c0526c42d0ce455c4 (patch) | |
tree | 10b1da7d264c52a9206d6565a2925bce6aba4c6e /gcc/tree-ssa-reassoc.c | |
parent | dc3d1e181445fafbbd146eb355a750c41c338794 (diff) | |
download | gcc-f31dd9beb95f4beda1d2bd5c0526c42d0ce455c4.zip gcc-f31dd9beb95f4beda1d2bd5c0526c42d0ce455c4.tar.gz gcc-f31dd9beb95f4beda1d2bd5c0526c42d0ce455c4.tar.bz2 |
c++: abbreviated function template friend matching [PR96106]
In the below testcase, duplicate_decls wasn't merging the tsubsted
friend declaration for 'void add(auto)' with its definition, because
reduce_template_parm_level (during tsubst_friend_function) lost the
DECL_VIRTUAL_P flag on the auto's invented template parameter, which
caused template_heads_equivalent_p to deem the two template heads as not
equivalent in C++20 mode.
This patch makes reduce_template_parm_level carry over the
DECL_VIRTUAL_P flag from the original TEMPLATE_PARM_DECL.
gcc/cp/ChangeLog:
PR c++/96106
* pt.c (reduce_template_parm_level): Propagate DECL_VIRTUAL_P
from the original TEMPLATE_PARM_DECL to the new lowered one.
gcc/testsuite/ChangeLog:
PR c++/96106
* g++.dg/concepts/abbrev7.C: New test.
Diffstat (limited to 'gcc/tree-ssa-reassoc.c')
0 files changed, 0 insertions, 0 deletions