From 85d490584b173dd86e67af37a277a6b5fe823422 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Mon, 10 Jun 2002 23:52:43 +0200 Subject: [PATCH] re PR c/6660 (Typedeffed unnamed structs/unions do not compile with gcc-3.1) PR c/6660 * c-decl.c (grokfield): Allow user defined types if they declare structs or unions for unnamed fields. * gcc.dg/20020527-1.c: New test. From-SVN: r54466 --- gcc/ChangeLog | 6 ++++ gcc/c-decl.c | 7 ++-- gcc/testsuite/ChangeLog | 2 ++ gcc/testsuite/gcc.dg/20020527-1.c | 54 +++++++++++++++++++++++++++++++ 4 files changed, 67 insertions(+), 2 deletions(-) create mode 100644 gcc/testsuite/gcc.dg/20020527-1.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 347b5bacc13..f92ef9b762c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2002-06-10 Jakub Jelinek + + PR c/6660 + * c-decl.c (grokfield): Allow user defined types if they declare + structs or unions for unnamed fields. + 2002-06-10 Jakub Jelinek PR c/6809 diff --git a/gcc/c-decl.c b/gcc/c-decl.c index 819e26e9596..075ac6d0bb0 100644 --- a/gcc/c-decl.c +++ b/gcc/c-decl.c @@ -5361,8 +5361,11 @@ grokfield (filename, line, declarator, declspecs, width) { /* This is an unnamed decl. We only support unnamed structs/unions, so check for other things and refuse them. */ - if (TREE_CODE (TREE_VALUE (declspecs)) != RECORD_TYPE - && TREE_CODE (TREE_VALUE (declspecs)) != UNION_TYPE) + tree type = TREE_VALUE (declspecs); + + if (TREE_CODE (type) == TYPE_DECL) + type = TREE_TYPE (type); + if (TREE_CODE (type) != RECORD_TYPE && TREE_CODE (type) != UNION_TYPE) { error ("unnamed fields of type other than struct or union are not allowed"); return NULL_TREE; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 91db3bc36ab..1d8229c615e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -8,6 +8,8 @@ * gcc.dg/20020530-1.c: New test. + * gcc.dg/20020527-1.c: New test. + 2002-06-07 Roger Sayle * gcc.dg/20020607-2.c: New test case. diff --git a/gcc/testsuite/gcc.dg/20020527-1.c b/gcc/testsuite/gcc.dg/20020527-1.c new file mode 100644 index 00000000000..f480d7b7bb8 --- /dev/null +++ b/gcc/testsuite/gcc.dg/20020527-1.c @@ -0,0 +1,54 @@ +/* PR c/6660 + Test whether an unnamed field with user defined type - struct or union is + accepted. */ +/* { dg-do compile } */ +/* { dg-options "" } */ + +typedef struct { + unsigned short a; + unsigned short b; +} __attribute__ ((__packed__)) A; + +typedef struct B_ { + unsigned int c; + unsigned int d; +} B; + +typedef struct C_ { + B; + unsigned int e; + unsigned int f; +} C; + +typedef C D; + +typedef struct { + A; + D; + struct { + unsigned short g; + unsigned short h; + } __attribute__ ((__packed__)); + union { + int i; + long j; + }; + int k; +} __attribute__ ((__packed__)) E; + +E x; + +void foo (void) +{ + x.a = 1; + x.b = 2; + x.c = 3; + x.d = 4; + x.e = 5; + x.f = 6; + x.g = 7; + x.h = 8; + x.i = 9; + x.j = 10; + x.k = 11; +} -- 2.30.2