diff options
| author | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2008-12-05 21:10:16 +0000 |
|---|---|---|
| committer | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2008-12-05 21:10:16 +0000 |
| commit | a3efadc73059be2ec4dc420e2b1d1614ef882916 (patch) | |
| tree | cee1b2906941519dc567d0b6dc148a9e80a5d21b | |
| parent | c938d9eb3c070db75100f4a1d3f4aedaea9068fe (diff) | |
| download | ppe42-gcc-a3efadc73059be2ec4dc420e2b1d1614ef882916.tar.gz ppe42-gcc-a3efadc73059be2ec4dc420e2b1d1614ef882916.zip | |
PR c++/35336
* c-pretty-print.c (pp_c_postfix_expression): Handle BIT_FIELD_REF.
(pp_c_expression): Likewise.
* error.c (dump_expr): Handle BIT_FIELD_REF.
* g++.dg/other/error30.C: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@142497 138bc75d-0d04-0410-961f-82ee72b054a4
| -rw-r--r-- | gcc/ChangeLog | 6 | ||||
| -rw-r--r-- | gcc/c-pretty-print.c | 31 | ||||
| -rw-r--r-- | gcc/cp/ChangeLog | 5 | ||||
| -rw-r--r-- | gcc/cp/error.c | 1 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
| -rw-r--r-- | gcc/testsuite/g++.dg/other/error30.C | 14 |
6 files changed, 62 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index f86e4f7fdbd..5318c3e41da 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2008-12-05 Jakub Jelinek <jakub@redhat.com> + + PR c++/35336 + * c-pretty-print.c (pp_c_postfix_expression): Handle BIT_FIELD_REF. + (pp_c_expression): Likewise. + 2008-12-05 Michael Meissner <meissner@linux.vnet.ibm.com> PR c/38416 diff --git a/gcc/c-pretty-print.c b/gcc/c-pretty-print.c index 9ee2738ca82..cf1c6c3f52c 100644 --- a/gcc/c-pretty-print.c +++ b/gcc/c-pretty-print.c @@ -1444,6 +1444,36 @@ pp_c_postfix_expression (c_pretty_printer *pp, tree e) } break; + case BIT_FIELD_REF: + { + tree type = TREE_TYPE (e); + + type = signed_or_unsigned_type_for (TYPE_UNSIGNED (type), type); + if (type + && tree_int_cst_equal (TYPE_SIZE (type), TREE_OPERAND (e, 1))) + { + HOST_WIDE_INT bitpos = tree_low_cst (TREE_OPERAND (e, 2), 0); + HOST_WIDE_INT size = tree_low_cst (TYPE_SIZE (type), 0); + if ((bitpos % size) == 0) + { + pp_c_left_paren (pp); + pp_c_left_paren (pp); + pp_type_id (pp, type); + pp_c_star (pp); + pp_c_right_paren (pp); + pp_c_ampersand (pp); + pp_expression (pp, TREE_OPERAND (e, 0)); + pp_c_right_paren (pp); + pp_c_left_bracket (pp); + pp_wide_integer (pp, bitpos / size); + pp_c_right_bracket (pp); + break; + } + } + pp_unsupported_tree (pp, e); + } + break; + case COMPLEX_CST: case VECTOR_CST: pp_c_compound_literal (pp, e); @@ -1955,6 +1985,7 @@ pp_c_expression (c_pretty_printer *pp, tree e) case ARRAY_REF: case CALL_EXPR: case COMPONENT_REF: + case BIT_FIELD_REF: case COMPLEX_CST: case COMPLEX_EXPR: case VECTOR_CST: diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index c70307ca2f8..dab6ed0def0 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2008-12-05 Jakub Jelinek <jakub@redhat.com> + + PR c++/35336 + * error.c (dump_expr): Handle BIT_FIELD_REF. + 2008-12-05 Sebastian Pop <sebastian.pop@amd.com> PR bootstrap/38262 diff --git a/gcc/cp/error.c b/gcc/cp/error.c index a2db1575fe7..4a63f1df813 100644 --- a/gcc/cp/error.c +++ b/gcc/cp/error.c @@ -2071,6 +2071,7 @@ dump_expr (tree t, int flags) case UNEQ_EXPR: case LTGT_EXPR: case COMPLEX_EXPR: + case BIT_FIELD_REF: pp_expression (cxx_pp, t); break; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index f4843d5b507..b841930c2c6 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2008-12-05 Jakub Jelinek <jakub@redhat.com> + + PR c++/35336 + * g++.dg/other/error30.C: New test. + 2008-12-05 Janis Johnson <janis187@us.ibm.com> * lib/target-supports.exp (check_effective_target_hard_dfp): New. diff --git a/gcc/testsuite/g++.dg/other/error30.C b/gcc/testsuite/g++.dg/other/error30.C new file mode 100644 index 00000000000..2df0e64075c --- /dev/null +++ b/gcc/testsuite/g++.dg/other/error30.C @@ -0,0 +1,14 @@ +// PR c++/35336 +// { dg-do compile } +// { dg-bogus "not supported by" "" { target *-*-* } 0 } + +struct A +{ + int i : 2; +}; + +void foo (bool b) +{ + A a; + (a.i || b) (); // { dg-error "cannot be used as" } +} |

