diff options
author | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-06-10 21:52:43 +0000 |
---|---|---|
committer | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-06-10 21:52:43 +0000 |
commit | 188fc74c700cec58eb6d341fd8802c6deff2dfca (patch) | |
tree | e96c6ba2da0a81abca5e5d61581b7a0628b3c73a | |
parent | 6fff0335f84b4fbc80fe510b02694c2bb4c2d73b (diff) | |
download | gcc-188fc74c700cec58eb6d341fd8802c6deff2dfca.tar.gz |
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.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@54466 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/c-decl.c | 7 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 2 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/20020527-1.c | 54 |
4 files changed, 67 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 347b5bacc13..f92ef9b762c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,11 @@ 2002-06-10 Jakub Jelinek <jakub@redhat.com> + 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 <jakub@redhat.com> + PR c/6809 * print-rtl.c (print_mem_expr): Don't crash on unnamed fields. 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 <roger@eyesopen.com> * 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; +} |