diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-09-30 00:21:14 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-09-30 00:21:14 +0000 |
commit | f83ff724cad84bed1e887c2653d9f03563879719 (patch) | |
tree | 5b1d006f36a07e0200a12c26309b6659639ec997 /eval.c | |
parent | 9b8d9ed92b3d1ba145f12b01ed0f70fe94d06549 (diff) | |
download | ruby-f83ff724cad84bed1e887c2653d9f03563879719.tar.gz ruby-f83ff724cad84bed1e887c2653d9f03563879719.tar.xz ruby-f83ff724cad84bed1e887c2653d9f03563879719.zip |
* eval.c (rb_eval): while/until should not capture break unless
they are destination of the break.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@4629 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r-- | eval.c | 14 |
1 files changed, 10 insertions, 4 deletions
@@ -2650,8 +2650,11 @@ rb_eval(self, n) state = 0; goto while_next; case TAG_BREAK: - state = 0; - result = prot_tag->retval; + if (TAG_DST()) { + state = 0; + result = prot_tag->retval; + } + /* fall through */ default: break; } @@ -2682,8 +2685,11 @@ rb_eval(self, n) state = 0; goto until_next; case TAG_BREAK: - state = 0; - result = prot_tag->retval; + if (TAG_DST()) { + state = 0; + result = prot_tag->retval; + } + /* fall through */ default: break; } |