aboutsummaryrefslogtreecommitdiffstats
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
commit058fd1101939461788e402600e6762c2acda8d8e (patch)
tree96cd6c1c48263979d06a85f5c0d1d30ef3f6b175
parent846f087a07dd148c07f111ac0483454dc9e756df (diff)
downloadruby-058fd1101939461788e402600e6762c2acda8d8e.tar.gz
* eval.c (rb_eval): fix SEGV at retry in iterator's receiver.
[ruby-dev:23227] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@6047 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--eval.c3
2 files changed, 6 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 12afe012ba..5b62831f8d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -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
diff --git a/eval.c b/eval.c
index 3adf63dfd7..7d3342f5a2 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) {