gcc-3.3 issues
Jacques A. Vidrine
nectar at FreeBSD.org
Fri Jul 18 08:34:03 PDT 2003
[cc: list trimmed]
On Fri, Jul 18, 2003 at 10:32:51AM +0200, Michael Nottebrock wrote:
> I've tried to come up with a less obscure testcase:
>
> #include <string>
> #include <iostream>
> using namespace std;
>
> int main ()
> {
>
> string astring="Hello World";
> cout << astring << endl;
> }
>
> Now, if I compile this on 5.1-RELEASE with
>
> c++ -Wnon-virtual-dtor -Wno-long-long -Wall -pedantic -W -Wpointer-arith
> -Wmissing-prototypes -Wwrite-strings -DNDEBUG -DNO_DEBUG -O -pipe
> -mcpu=pentiumpro -fno-check-new -L/usr/local/lib -I/usr/local/include
> -I/usr/local/include -I/usr/X11R6/include -D_GETOPT_H -o helloworld
> helloworld.cc
>
> I get a plethora of warnings:
>
> In file included from /usr/include/g++/memory:55,
> from /usr/include/g++/string:48,
> from helloworld.cc:1:
> /usr/include/g++/bits/stl_alloc.h:979: warning: ISO C++ forbids the use of `
> extern' on explicit instantiations
> /usr/include/g++/bits/stl_alloc.h:980: warning: ISO C++ forbids the use of `
> extern' on explicit instantiations
> /usr/include/g++/bits/stl_alloc.h:981: warning: ISO C++ forbids the use of `
> extern' on explicit instantiations
> /usr/include/g++/bits/stl_alloc.h:981: warning: ISO C++ forbids the use of `
> extern' on explicit instantiations
> /usr/include/g++/bits/stl_alloc.h:981: warning: ISO C++ forbids the use of `
> extern' on explicit instantiations
>
> [and many, many more]
>
> but it will compile. If I omit -pedantic, none of these warnings occur. The
> thing is, in -CURRENT with the new gcc, all these warnings for some reason
> become errors. The other thing is, if I try this with with a ports-compiled
> g++32 on 4-STABLE, I don't get warnings at all, no matter if -pedantic is
> specified or not.
>
> So here's the questions for the experts:
>
> - Why errors instead of warnings?
> - Why do gcc's own bits seem to not conform to some kind of standard that it
> tries to adhere to in 5-CURRENT but not in 4-STABLE?
> - Who's to blame?
I haven't looked recently, but I seem to recall that the STL and other
C++ header bits that we install in /usr/include are from an older GCC
release than the compiler. On my pre-GCC 3.3 -CURRENT system:
System compiler:
% g++ -c -Wall -pedantic hello.cc
<many warnings>
GCC 3.2 from ports:
% g++32 -c -Wall -pedantic hello.cc
<no warnings>
GCC 3.3 from ports:
% g++33 -c -Wall -pedantic hello.cc
<no warnings>
I also recall lots of missing `typename's in the system headers that were
resolved in the actual GCC distribution.
Alexander, do the STL headers et. al. get updated with the rest of the
compiler chain?
Cheers,
--
Jacques Vidrine . NTT/Verio SME . FreeBSD UNIX . Heimdal
nectar at celabo.org . jvidrine at verio.net . nectar at freebsd.org . nectar at kth.se
More information about the freebsd-current
mailing list