From mboxrd@z Thu Jan 1 00:00:00 1970 From: lachaume@laog.obs.ujf.grenoble.fr To: gcc-gnats@gcc.gnu.org Subject: c++/3831: problem with forward declaration of function taking a reference to a generic member Date: Thu, 26 Jul 2001 05:56:00 -0000 Message-id: <20010726124543.20737.qmail@sourceware.cygnus.com> X-SW-Source: 2001-07/msg00710.html List-Id: >Number: 3831 >Category: c++ >Synopsis: problem with forward declaration of function taking a reference to a generic member >Confidential: no >Severity: serious >Priority: medium >Responsible: unassigned >State: open >Class: rejects-legal >Submitter-Id: net >Arrival-Date: Thu Jul 26 05:56:00 PDT 2001 >Closed-Date: >Last-Modified: >Originator: Régis Lachaume >Release: 3.0 (release) and prior versions >Organization: >Environment: gag237:cpp/bug $ uname -a Linux gag237 2.4.0-test10 #3 mer déc 6 11:59:57 CET 2000 i686 unknown gag237:cpp/bug $ ~/linux/bin/g++ -v Reading specs from /gagax6/ur3/lachaume/linux/lib/gcc-lib/i686-pc-linux-gnu/3.0/specs Configured with: ../configure --prefix=/gagax6/ur3/lachaume/indep --exec-prefix=/gagax6/ur3/lachaume/linux --enable-languages=c,c++ : (reconfigured) ../configure --prefix=/gagax6/ur3/lachaume/indep --exec-prefix=/gagax6/ur3/lachaume/linux --enable-languages=c++ --with-gxx-include-dir=/gagax6/ur3/lachaume/indep/include/g++ --with-local-prefix=/gagax6/ur3/lachaume/indep/ Thread model: single gcc version 3.0 gag237:cpp/bug $ g++ -v Reading specs from /usr/lib/gcc-lib/i586-mandrake-linux/2.95.3/specs gcc version 2.95.3 19991030 (prerelease) gag237:cpp/bug $ >Description: g++ considers the forward declaration of a function taking a reference to a generic member and the definition of this function as two different declarations. It issues the error ``call of overloaded ... is ambiguous''. Example with g++ 2.95.3, bug also reproduced with g++ 3.0 gag237:cpp/bug $ more typename-light.cpp template struct A; template void g(typename A::B&); template struct A { template struct B { }; }; template void g(typename A::B&); int main() { A::B b; g(b); } gag237:cpp/bug $ g++ -Wall -ansi -pedantic -W -O2 typename-light.cpp typename-light.cpp: In function `int main()': typename-light.cpp:12: call of overloaded `g (A::B &)' is ambiguous typename-light.cpp:2: candidates are: void g(A::B &) typename-light.cpp:8: void g(A::B &) gag237:cpp/bug $ g++ --version 2.95.3 gag237:cpp/bug $ ~//linux/bin/g++ -Wall -W -ansi -pedantic -O2 -static -I/gagax6/ur3/lachaume/indep/include/g++-3.0 -I/gagax6/ur3/lachaume/indep/include/g++-3.0/i686-pc-linux-gnu/ -o typename typename.cpp typename.cpp: In function `int main()': typename.cpp:26: call of overloaded `g(A::B&)' is ambiguous typename.cpp:13: candidates are: void g(typename A::B&) [with u = int, v = float] typename.cpp:20: void g(A::B&) [with u = int, v = float] typename.cpp:27: call of overloaded `h(A::B&)' is ambiguous typename.cpp:14: candidates are: void h(typename A::B&) [with u = int, v = float] typename.cpp:21: void h(const A::B&) [with u = int, v = float] gag237:cpp/bug $ ~/linux/bin/g++ --version 3.0 gag237:cpp/bug $ Other problems: * a missing typenames in the definition is not diagnosed with the -pedantic option. * g++ v >= 3.0 ignores an eventual const qualifier in the forward declaration when reporting the error, whereas g++ 2.95.3 does it correctly A full example file is attached. >How-To-Repeat: >Fix: No idea. >Release-Note: >Audit-Trail: >Unformatted: ----gnatsweb-attachment---- Content-Type: application/octet-stream; name="typename.cpp" Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="typename.cpp" Ly8gZm9yd2FyZCBkZWNsYXJhdGlvbiBvZiBhIGZ1bmN0aW9uIHRha2luZyBhIGdlbmVyaWMgbWVt YmVyCgovLyBQcm9ibGVtcyB3aXRoIGdjYyAzLjAKLy8gICAxLiBlcnJvciBgYGFtYmlndW91cyBv dmVybG9hZGVkIC4uLicnCi8vICAgMi4gbm8gd2FybmluZyB3aXRoIG1pc3NpbmcgdHlwZW5hbWUg aW4gZGVmaW5pdGlvbiBvZiBrICgtcGVkYW50aWMpCi8vICAgMy4gaW4gZXJyb3IgcmVwb3J0IHRo ZSBjb25zdCBxdWFsaWZpZXIgb2YgaCBpcyBzdXJwaXNpbmdseSBkaXNjYXJkZWQKLy8gUHJvYmxl bXMgd2l0aCBnY2MgMi45NS4zCi8vICAgLSBQcm9ibGVtcyAxLiAmIDIuIG9jY3VyLgovLyAgIC0g Y29uc3QgcXVhbGlmaWVyIGluIGggY29ycmVjdGx5IGFwcGVhcnMgaW4gdGhlIGVycm9yIG1lc3Nh Z2UKCgp0ZW1wbGF0ZSA8dHlwZW5hbWUgdT4gc3RydWN0IEE7CnRlbXBsYXRlIDx0eXBlbmFtZSB1 LCB0eXBlbmFtZSB2PiB2b2lkIGcodHlwZW5hbWUgQTx1Pjo6Qjx2PiYpOwp0ZW1wbGF0ZSA8dHlw ZW5hbWUgdSwgdHlwZW5hbWUgdj4gdm9pZCBoKGNvbnN0IHR5cGVuYW1lIEE8dT46OkI8dj4mKTsK CnRlbXBsYXRlIDx0eXBlbmFtZSB1PiBzdHJ1Y3QgQSB7CiAgIHRlbXBsYXRlIDx0eXBlbmFtZSB2 PiBzdHJ1Y3QgQiB7IH07Cn07Cgp0ZW1wbGF0ZSA8dHlwZW5hbWUgdSwgdHlwZW5hbWUgdj4gdm9p ZCBnKHR5cGVuYW1lIEE8dT46OkI8dj4mKSB7IH0KdGVtcGxhdGUgPHR5cGVuYW1lIHUsIHR5cGVu YW1lIHY+IHZvaWQgaChjb25zdCB0eXBlbmFtZSBBPHU+OjpCPHY+JikgeyB9CnRlbXBsYXRlIDx0 eXBlbmFtZSB1LCB0eXBlbmFtZSB2PiB2b2lkIGsoY29uc3QgQTx1Pjo6Qjx2PiYpIHsgfQoKaW50 IG1haW4oKSB7CiAgIEE8aW50Pjo6QjxmbG9hdD4gYjsKICAgZzxpbnQsIGZsb2F0PihiKTsKICAg aDxpbnQsIGZsb2F0PihiKTsKfQo=