diff options
author | kenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-07-01 19:32:27 +0000 |
---|---|---|
committer | kenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-07-01 19:32:27 +0000 |
commit | 1267d2b782711add2ee26e85752fb64b974f7e6e (patch) | |
tree | 2c0c104908c11178291f6e0b65211456f1d8da76 /gcc/tree-pretty-print.c | |
parent | 50f44d58119cc789e685eae84a257312efbe5ce9 (diff) | |
download | gcc-1267d2b782711add2ee26e85752fb64b974f7e6e.tar.gz |
* tree-pretty-print.c (dump_generic_node, case ARRAY_REF): Use
access functions for lower bound and element size and only output
if lower bound nonzero or element size not same as that of type.
(dump_generic_node, case COMPONENT_REF): Use access func. for offset.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@83997 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree-pretty-print.c')
-rw-r--r-- | gcc/tree-pretty-print.c | 24 |
1 files changed, 12 insertions, 12 deletions
diff --git a/gcc/tree-pretty-print.c b/gcc/tree-pretty-print.c index 9d415fa8873..188faff0219 100644 --- a/gcc/tree-pretty-print.c +++ b/gcc/tree-pretty-print.c @@ -611,12 +611,12 @@ dump_generic_node (pretty_printer *buffer, tree node, int spc, int flags, pp_character (buffer, ')'); pp_string (buffer, str); dump_generic_node (buffer, TREE_OPERAND (node, 1), spc, flags, false); - if (TREE_OPERAND (node, 2) - && TREE_CODE (TREE_OPERAND (node, 2)) != INTEGER_CST) + + op0 = component_ref_field_offset (node); + if (op0 && TREE_CODE (op0) != INTEGER_CST) { pp_string (buffer, "{off: "); - dump_generic_node (buffer, TREE_OPERAND (node, 2), - spc, flags, false); + dump_generic_node (buffer, op0, spc, flags, false); pp_character (buffer, '}'); } break; @@ -649,17 +649,17 @@ dump_generic_node (pretty_printer *buffer, tree node, int spc, int flags, pp_string (buffer, " ..."); pp_character (buffer, ']'); - if ((TREE_OPERAND (node, 2) - && TREE_CODE (TREE_OPERAND (node, 2)) != INTEGER_CST) - || (TREE_OPERAND (node, 3) - && TREE_CODE (TREE_OPERAND (node, 3)) != INTEGER_CST)) + op0 = array_ref_low_bound (node); + op1 = array_ref_element_size (node); + + if (!integer_zerop (op0) + || (TYPE_SIZE_UNIT (TREE_TYPE (node)) + && !operand_equal_p (op1, TYPE_SIZE_UNIT (TREE_TYPE (node)), 0))) { pp_string (buffer, "{lb: "); - dump_generic_node (buffer, TREE_OPERAND (node, 2), - spc, flags, false); + dump_generic_node (buffer, op0, spc, flags, false); pp_string (buffer, " sz: "); - dump_generic_node (buffer, TREE_OPERAND (node, 3), - spc, flags, false); + dump_generic_node (buffer, op1, spc, flags, false); pp_character (buffer, '}'); } break; |