diff options
author | J"orn Rennecke <amylaar@cygnus.co.uk> | 1999-07-14 15:47:26 +0000 |
---|---|---|
committer | Joern Rennecke <amylaar@gcc.gnu.org> | 1999-07-14 16:47:26 +0100 |
commit | 9bbecbc4852a1fba2b6433f7d4ec99b3cd2c57ed (patch) | |
tree | 8a190932da534975c2ab0ac6119d573526508f79 /gcc | |
parent | 5937a6f93a56beddfde2c2ae0e14a2ec79d96283 (diff) | |
download | gcc-9bbecbc4852a1fba2b6433f7d4ec99b3cd2c57ed.zip gcc-9bbecbc4852a1fba2b6433f7d4ec99b3cd2c57ed.tar.gz gcc-9bbecbc4852a1fba2b6433f7d4ec99b3cd2c57ed.tar.bz2 |
c-typeck.c (output_init_element, [...]): When advancing constructor_unfilled_fields for a RECORD_TYPE...
* c-typeck.c (output_init_element, process_init_element):
When advancing constructor_unfilled_fields for a RECORD_TYPE,
check for nameless bit fields.
From-SVN: r28098
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/c-typeck.c | 17 |
2 files changed, 22 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index d708c5d..d921095 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +Wed Jul 14 23:45:48 1999 J"orn Rennecke <amylaar@cygnus.co.uk> + + * c-typeck.c (output_init_element, process_init_element): + When advancing constructor_unfilled_fields for a RECORD_TYPE, + check for nameless bit fields. + Wed Jul 14 01:57:39 1999 Richard Henderson <rth@cygnus.com> * regclass.c (scan_one_insn): Notice subregs that change the diff --git a/gcc/c-typeck.c b/gcc/c-typeck.c index d4749cd..18b8210 100644 --- a/gcc/c-typeck.c +++ b/gcc/c-typeck.c @@ -6150,7 +6150,16 @@ output_init_element (value, type, field, pending) = TREE_INT_CST_HIGH (tem); } else if (TREE_CODE (constructor_type) == RECORD_TYPE) - constructor_unfilled_fields = TREE_CHAIN (constructor_unfilled_fields); + { + constructor_unfilled_fields = + TREE_CHAIN (constructor_unfilled_fields); + /* Skip any nameless bit fields. */ + while (constructor_unfilled_fields != 0 + && DECL_C_BIT_FIELD (constructor_unfilled_fields) + && DECL_NAME (constructor_unfilled_fields) == 0) + constructor_unfilled_fields = + TREE_CHAIN (constructor_unfilled_fields); + } else if (TREE_CODE (constructor_type) == UNION_TYPE) constructor_unfilled_fields = 0; @@ -6485,6 +6494,12 @@ process_init_element (value) = TREE_INT_CST_HIGH (temp); constructor_unfilled_fields = TREE_CHAIN (constructor_fields); + /* Skip any nameless bit fields. */ + while (constructor_unfilled_fields != 0 + && DECL_C_BIT_FIELD (constructor_unfilled_fields) + && DECL_NAME (constructor_unfilled_fields) == 0) + constructor_unfilled_fields = + TREE_CHAIN (constructor_unfilled_fields); } constructor_fields = TREE_CHAIN (constructor_fields); |