From 72eb10386ddf1c698a54b56efa3468a9e7a57639 Mon Sep 17 00:00:00 2001 From: Bruno Haible Date: Fri, 21 Nov 1997 20:51:30 +0000 Subject: [PATCH] * stmt.c (expand_end_bindings): Allow jump into block with cleanups. From-SVN: r16654 --- gcc/ChangeLog | 4 ++++ gcc/stmt.c | 8 ++++---- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index a1369c8b5dc..06d0b70b808 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +Fri Nov 21 12:49:56 1997 Bruno Haible + + * stmt.c (expand_end_bindings): Allow jump into block with cleanups. + Fri Nov 21 12:18:51 1997 Jason Merrill * except.h: Add outer_context_label_stack. diff --git a/gcc/stmt.c b/gcc/stmt.c index 97a8d48a079..a99da39346f 100644 --- a/gcc/stmt.c +++ b/gcc/stmt.c @@ -3411,10 +3411,10 @@ expand_end_bindings (vars, mark_ends, dont_jump_in) emit_label (afterward); } - /* Don't allow jumping into a block that has cleanups or a stack level. */ + /* Don't allow jumping into a block that has a stack level. + Cleanups are allowed, though. */ if (dont_jump_in - || thisblock->data.block.stack_level != 0 - || thisblock->data.block.cleanups != 0) + || thisblock->data.block.stack_level != 0) { struct label_chain *chain; @@ -3425,7 +3425,7 @@ expand_end_bindings (vars, mark_ends, dont_jump_in) DECL_TOO_LATE (chain->label) = 1; /* If any goto without a fixup came to this label, that must be an error, because gotos without fixups - come from outside all saved stack-levels and all cleanups. */ + come from outside all saved stack-levels. */ if (TREE_ADDRESSABLE (chain->label)) error_with_decl (chain->label, "label `%s' used before containing binding contour");