summaryrefslogtreecommitdiffstats
path: root/eval.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-03-30 09:19:06 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-03-30 09:19:06 +0000
commitbbd6558ade327c2a9912454dadebba12c7c82db1 (patch)
tree96cd6c1c48263979d06a85f5c0d1d30ef3f6b175 /eval.c
parent8cbea367df2d07ec7399011a405241a5a2b43b94 (diff)
downloadruby-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
Diffstat (limited to 'eval.c')
-rw-r--r--eval.c3
1 files changed, 1 insertions, 2 deletions
diff --git a/eval.c b/eval.c
index 3adf63dfd..7d3342f5a 100644
--- a/eval.c
+++ b/eval.c
@@ -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) {