diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-03-30 09:19:06 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-03-30 09:19:06 +0000 |
commit | bbd6558ade327c2a9912454dadebba12c7c82db1 (patch) | |
tree | 96cd6c1c48263979d06a85f5c0d1d30ef3f6b175 | |
parent | 8cbea367df2d07ec7399011a405241a5a2b43b94 (diff) | |
download | ruby-bbd6558ade327c2a9912454dadebba12c7c82db1.tar.gz ruby-bbd6558ade327c2a9912454dadebba12c7c82db1.tar.xz ruby-bbd6558ade327c2a9912454dadebba12c7c82db1.zip |
* eval.c (rb_eval): fix SEGV at retry in iterator's receiver.
[ruby-dev:23227]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@6047 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | eval.c | 3 |
2 files changed, 6 insertions, 2 deletions
@@ -1,3 +1,8 @@ +Tue Mar 30 18:19:00 2004 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * eval.c (rb_eval): fix SEGV at retry in iterator's receiver. + [ruby-dev:23227] + Mon Mar 29 20:17:16 2004 Nobuyoshi Nakada <nobu@ruby-lang.org> * process.c (rb_exec): follow older behavior if close-on-exec is not @@ -2959,7 +2959,7 @@ rb_eval(self, n) result = prot_tag->retval; state = 0; } - else if (state == TAG_RETRY) { + else if (state == TAG_RETRY && ruby_block == &_block) { state = 0; goto iter_retry; } @@ -4537,7 +4537,6 @@ break_jump(retval) VALUE retval; { struct tag *tt = prot_tag; - int yield = Qfalse; if (retval == Qundef) retval = Qnil; while (tt) { |