summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-20 23:33:32 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-20 23:33:32 +0000
commitbb1719875c357f8e1d58c430727973de810cb66c (patch)
treef5ff70f25d525ccd49b089fd3b00e343297d7fb1
parent0df7297f1275eb78f33ef39e1355a2c293767936 (diff)
* enumerator.c (enumerator_next): should call next_init() if fiber
is dead already. [ruby-dev:32459] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@14374 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--enumerator.c2
2 files changed, 6 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index f2352eca86..bc567f53a7 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Fri Dec 21 08:07:35 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
+
+ * enumerator.c (enumerator_next): should call next_init() if fiber
+ is dead already. [ruby-dev:32459]
+
Fri Dec 21 01:21:49 2007 GOTOU Yuuzou <gotoyuzo@notwork.org>
* ext/openssl/lib/openssl/ssl.rb (OpenSSL::SSL::SSLContext.build):
diff --git a/enumerator.c b/enumerator.c
index e348e68aa0..366c64c28a 100644
--- a/enumerator.c
+++ b/enumerator.c
@@ -408,7 +408,7 @@ enumerator_next(VALUE obj)
VALUE curr, v;
curr = rb_fiber_current();
- if (!e->fib) {
+ if (!e->fib || !rb_fiber_alive_p(e->fib)) {
next_init(obj, e);
}