OSDN Git Service

Handle anonymous unions at the tree level.
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 19 Dec 2002 17:43:54 +0000 (17:43 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 19 Dec 2002 17:43:54 +0000 (17:43 +0000)
        C++ ABI change: Mangle anonymous unions using the name of their
        first named field (by depth-first search).  Should not cause
        binary compatibility problems, though, as the compiler previously
        didn't emit anything for affected unions.
        * cp-tree.def (ALIAS_DECL): New tree code.
        * decl2.c (build_anon_union_vars): Build ALIAS_DECLs.  Return the
        first field, not the largest.
        (finish_anon_union): Don't mess with RTL.  Do set DECL_ASSEMBLER_NAME,
        push the decl, and write it out at namespace scope.
        * decl.c (lookup_name_real): See through an ALIAS_DECL.
        (pushdecl): Add namespace bindings for ALIAS_DECLs.
        * rtti.c (unemitted_tinfo_decl_p): Don't try to look at the name
        of a decl which doesn't have one.
        * typeck.c (build_class_member_access_expr): Don't recurse if
        we already have the type we want.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@60315 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/testsuite/g++.old-deja/g++.brendan/union1.C

index ca78146..6ae0605 100644 (file)
@@ -3,7 +3,6 @@
 // the DECL_SIZE of the decls, instead of comparing the DECL_SIZE nodes.
 
 // The compiler currently fails to allocate space for the static union.
-// excess errors test - XFAIL *-*-*
 
      unsigned
      hash(const double d)