]> git.ipfire.org Git - thirdparty/gcc.git/commit
c++: member vs global template [PR106310]
authorJason Merrill <jason@redhat.com>
Wed, 26 Jul 2023 14:39:34 +0000 (10:39 -0400)
committerJason Merrill <jason@redhat.com>
Wed, 26 Jul 2023 16:45:13 +0000 (12:45 -0400)
commit51b997ea1d07465cb0208c711975b545872a2d2b
treed3f8d8c06fe7e37c9022df3f86a678adc09e98a6
parentdb189d02ef150517e955d0d7a913168dd48f21cd
c++: member vs global template [PR106310]

For backward compatibility we still want to allow patterns like
this->A<T>::foo, but the template keyword in a qualified name is
specifically to specify that a dependent name is a template, so don't look
in the enclosing scope at all.

Also fix handling of dependent bases: if member lookup in the current
instantiation fails and we have dependent bases, the lookup is dependent.
We were already handling that for the case where lookup in the enclosing
scope also fails, but we also want it to affect that lookup itself.

PR c++/106310

gcc/cp/ChangeLog:

* parser.cc (cp_parser_template_name): Skip non-member
lookup after the template keyword.
(cp_parser_lookup_name): Pass down template_keyword_p.

gcc/testsuite/ChangeLog:

* g++.dg/template/template-keyword4.C: New test.
gcc/cp/parser.cc
gcc/testsuite/g++.dg/template/template-keyword4.C [new file with mode: 0644]