aboutsummaryrefslogtreecommitdiff
path: root/gcc/java
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2001-12-21 05:28:27 +0000
committerTom Tromey <tromey@gcc.gnu.org>2001-12-21 05:28:27 +0000
commit84a944b3cae32d3034bfe3360114464383419a36 (patch)
tree1a6248da57443147f39004ede5f9ef11ca3d7cde /gcc/java
parent2d93b92445219f257ccb6bee1c132f28677275fe (diff)
downloadgcc-84a944b3cae32d3034bfe3360114464383419a36.zip
gcc-84a944b3cae32d3034bfe3360114464383419a36.tar.gz
gcc-84a944b3cae32d3034bfe3360114464383419a36.tar.bz2
For PR java/4509:
* parse.y (java_complete_lhs) [COMPOUND_EXPR]: Correctly compute CAN_COMPLETE_NORMALLY for the node. * jcf-write.c (generate_bytecode_insns) [COMPOUND_EXPR]: Don't generate code for second branch if first branch can't complete normally. (generate_bytecode_insns) [LOOP_EXPR]: Don't generate `goto' to the loop head if the loop body can't complete normally. From-SVN: r48233
Diffstat (limited to 'gcc/java')
-rw-r--r--gcc/java/ChangeLog11
-rw-r--r--gcc/java/jcf-write.c9
-rw-r--r--gcc/java/parse.y6
3 files changed, 23 insertions, 3 deletions
diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog
index 1104546..09507d2 100644
--- a/gcc/java/ChangeLog
+++ b/gcc/java/ChangeLog
@@ -1,5 +1,16 @@
2001-12-20 Tom Tromey <tromey@redhat.com>
+ For PR java/4509:
+ * parse.y (java_complete_lhs) [COMPOUND_EXPR]: Correctly compute
+ CAN_COMPLETE_NORMALLY for the node.
+ * jcf-write.c (generate_bytecode_insns) [COMPOUND_EXPR]: Don't
+ generate code for second branch if first branch can't complete
+ normally.
+ (generate_bytecode_insns) [LOOP_EXPR]: Don't generate `goto' to
+ the loop head if the loop body can't complete normally.
+
+2001-12-20 Tom Tromey <tromey@redhat.com>
+
For PR java/4766:
* jcf-write.c (generate_bytecode_insns) [TRY_FINALLY_EXPR]: Handle
case where `finally' clause can't complete normally.
diff --git a/gcc/java/jcf-write.c b/gcc/java/jcf-write.c
index f6c0bfa..334465e 100644
--- a/gcc/java/jcf-write.c
+++ b/gcc/java/jcf-write.c
@@ -1483,7 +1483,11 @@ generate_bytecode_insns (exp, target, state)
break;
case COMPOUND_EXPR:
generate_bytecode_insns (TREE_OPERAND (exp, 0), IGNORE_TARGET, state);
- generate_bytecode_insns (TREE_OPERAND (exp, 1), target, state);
+ /* Normally the first operand to a COMPOUND_EXPR must complete
+ normally. However, in the special case of a do-while
+ statement this is not necessarily the case. */
+ if (CAN_COMPLETE_NORMALLY (TREE_OPERAND (exp, 0)))
+ generate_bytecode_insns (TREE_OPERAND (exp, 1), target, state);
break;
case EXPR_WITH_FILE_LOCATION:
{
@@ -1880,7 +1884,8 @@ generate_bytecode_insns (exp, target, state)
{
struct jcf_block *head_label = get_jcf_label_here (state);
generate_bytecode_insns (body, IGNORE_TARGET, state);
- emit_goto (head_label, state);
+ if (CAN_COMPLETE_NORMALLY (body))
+ emit_goto (head_label, state);
}
}
break;
diff --git a/gcc/java/parse.y b/gcc/java/parse.y
index aeec759..7c50c97 100644
--- a/gcc/java/parse.y
+++ b/gcc/java/parse.y
@@ -11776,8 +11776,12 @@ java_complete_lhs (node)
TREE_OPERAND (node, 1) = java_complete_tree (TREE_OPERAND (node, 1));
if (TREE_OPERAND (node, 1) == error_mark_node)
return error_mark_node;
+ /* Even though we might allow the case where the first
+ operand doesn't return normally, we still should compute
+ CAN_COMPLETE_NORMALLY correctly. */
CAN_COMPLETE_NORMALLY (node)
- = CAN_COMPLETE_NORMALLY (TREE_OPERAND (node, 1));
+ = (CAN_COMPLETE_NORMALLY (TREE_OPERAND (node, 0))
+ && CAN_COMPLETE_NORMALLY (TREE_OPERAND (node, 1)));
}
TREE_TYPE (node) = TREE_TYPE (TREE_OPERAND (node, 1));
break;