>Submitter-Id: net >Originator: Thomas Richter >Organization: >Confidential: no >Synopsis: g++-3.3 should warn about class/struct equivalence >Severity: non-critical >Priority: medium >Category: c++ >Class: change-request >Release: 3.3 20030509 (Debian prerelease) >Environment: System: Linux skywise 2.4.20 #7 Thu May 15 19:53:29 CEST 2003 i686 unknown Architecture: i686

<machine, os, target, libraries (multiple lines)>
host: i386-pc-linux-gnu
build: i386-pc-linux-gnu
target: i386-pc-linux-gnu
configured with: ../src/configure -v
--enable-languages=c,c++,java,f77,pascal,objc,ada,treelang --prefix=/usr
--mandir=/usr/share/man --infodir=/usr/share/info
--with-gxx-include-dir=/usr/include/c++/3.3 --enable-shared
--with-system-zlib --enable-nls --without-included-gettext
--enable-__cxa_atexit --enable-clocale=gnu --enable-debug
--enable-java-gc=boehm --enable-java-awt=xlib --enable-objc-gc i386-linux
>Description:
g++-3.3 should warn about an object declared as a class that is later on used as a "struct". This would simplify the generation of portable code as at least one other popular compiler will generate warnings for this case that could be easily avoided by this additional g++ warning. Besides, implementation seems to be simple for me.
>How-To-Repeat:
Save the following code as "foo.cpp"
/* snip */
class A {
int x;
};


int main(int,char)
{
  struct A a;

  return 0;
}
/* snip */
And compile with

$ g++-3.3 -Wall -pedantic foo.cpp

The resulting code works. (-; It would be nice if g++ could generate a warning that "class A" has been used as "struct A a;" in main(), instead of "class A a;" or rather "A a;".

>Fix:





Reply via email to