diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-06-21 15:36:06 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-06-21 15:36:06 +0000 |
commit | 4adfd770e62aea26e36154b27fac95d50b3ab1d6 (patch) | |
tree | 5e27602804e97f5c59cd0d161a13bebb37508b12 /eval.c | |
parent | cc1e0c834890b7532f84f2cb40733828d38c4b21 (diff) | |
download | ruby-4adfd770e62aea26e36154b27fac95d50b3ab1d6.tar.gz ruby-4adfd770e62aea26e36154b27fac95d50b3ab1d6.tar.xz ruby-4adfd770e62aea26e36154b27fac95d50b3ab1d6.zip |
* eval.c (proc_invoke): should not propagate distination tag if
tag is already handled in this level. (ruby-bugs-ja PR#501)
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@3976 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r-- | eval.c | 6 |
1 files changed, 2 insertions, 4 deletions
@@ -7000,13 +7000,11 @@ proc_invoke(proc, args, self, klass) state == TAG_BREAK ? "break" : "return"); localjump_error(mesg, prot_tag->retval, state); } - else { + else if (state == incoming_state) { ruby_block->tag->dst = incoming_state; - JUMP_TAG(incoming_state); } - break; default: - JUMP_TAG(incoming_state); + JUMP_TAG(state); } return result; } |