c++/10146: [3.4 regression] [new parser] template function lookup failure(s)
Richard Guenther
rguenth@tat.physik.uni-tuebingen.de
Wed Mar 19 12:56:00 GMT 2003
The following reply was made to PR c++/10146; it has been noted by GNATS.
From: Richard Guenther <rguenth@tat.physik.uni-tuebingen.de>
To: Gabriel Dos Reis <gdr@integrable-solutions.net>
Cc: Giovanni Bajo <giovannibajo@libero.it>, <gcc-gnats@gcc.gnu.org>,
<gcc-bugs@gcc.gnu.org>
Subject: Re: c++/10146: [3.4 regression] [new parser] template function lookup
failure(s)
Date: Wed, 19 Mar 2003 13:47:40 +0100 (CET)
On 19 Mar 2003, Gabriel Dos Reis wrote:
> Richard Guenther <rguenth@tat.physik.uni-tuebingen.de> writes:
>
> | On 19 Mar 2003, Gabriel Dos Reis wrote:
> |
> | > Richard Guenther <rguenth@tat.physik.uni-tuebingen.de> writes:
> | >
> | > | On Wed, 19 Mar 2003, Giovanni Bajo wrote:
> | > |
> | > | >
> | > | > http://gcc.gnu.org/cgi-bin/gnatsweb.pl?cmd=view%20audit-trail&database=gcc&p
> | > | > r=10146
> | > | >
> | > | > To sum it up:
> | > | >
> | > | > >Foo<int>().template foo<U>(u); // does not work
> | > | > >Foo<int>().template bar<U>(u); // does not work
> | > | >
> | > | > These should compile.
> | > | >
> | > | > >Foo<int>().foo(u); // does work ??
> | > | > >Foo<int>::foo(u); // does work ??
> | > | > >Foo<int>().bar(u); // does work ??
> | > | >
> | > | > Yes, because the template parameter of the template member function is
> | > | > deduced from the call. What's wrong with them?
> | > |
> | > | I think foo() and bar() needs to be qualified with the template keyword
> | > | due to two-stage namelookup. But I may be wrong (dont have a standard
> | > | to look at).
> | >
> | > Two-phase name lookup has nothing to do here. The Foo<int> part is
> | > -not- dependent, therefore there need not be any extra "template"
> | > qualifier.
> |
> | Ah, ok - only for Foo<T>:: it would be dependent, yes?
>
> Yes. (Any dependent expression would do also).
If I exchange Foo<int> with Foo<T> only
Foo<T>().foo<U>(u);
and
Foo<T>().bar<U>(u);
do not work (as expected), but f.i. Foo<T>::foo<U>(u); (while
Foo<int>::foo<U>(u) is rejected) is ok?
Well, I'll leave it now up to Mark to check&fix all relevant cases
after 3.3 is out.
Richard.
--
Richard Guenther <richard.guenther@uni-tuebingen.de>
WWW: http://www.tat.physik.uni-tuebingen.de/~rguenth/
More information about the Gcc-prs
mailing list