summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorocean <ocean@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-12-29 16:08:44 +0000
committerocean <ocean@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-12-29 16:08:44 +0000
commit0cb24bf1b90372951967b1b1e2d7982d6354aa72 (patch)
tree1d8ea6f225ef9091674932921c8873ae3ad57bef /lib
parent84dd69741722b11f836f7473a28f20a5a460ff7b (diff)
* lib/generator.rb: should work with another thread. (more robust code)
[ruby-dev:28177] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@9763 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib')
-rw-r--r--lib/generator.rb19
1 files changed, 12 insertions, 7 deletions
diff --git a/lib/generator.rb b/lib/generator.rb
index 5b13bb9656..1086e0fbe4 100644
--- a/lib/generator.rb
+++ b/lib/generator.rb
@@ -73,14 +73,12 @@ class Generator
@queue = []
@loop_thread = Thread.new do
Thread.stop
- Thread.critical = true
begin
@block.call(self) # exception safe?
rescue
@main_thread.raise $!
ensure
@main_thread.wakeup
- Thread.critical = false
end
end
self
@@ -89,21 +87,28 @@ class Generator
# Yields an element to the generator.
def yield(value)
if Thread.current != @loop_thread
- raise RuntimeError.new("Generator#yield must be called in Generator.new{|g| ... }")
+ raise "should be called in Generator.new{|g| ... }"
end
- @queue << value
- @main_thread.wakeup
- Thread.stop
Thread.critical = true
+ begin
+ @queue << value
+ @main_thread.wakeup
+ Thread.stop
+ ensure
+ Thread.critical = false
+ end
self
end
# Returns true if the generator has reached the end.
def end?
if @queue.empty?
+ if @main_thread
+ raise "should not be called in Generator.new{|g| ... }"
+ end
Thread.critical = true
- @main_thread = Thread.current
begin
+ @main_thread = Thread.current
@loop_thread.wakeup
Thread.stop
rescue ThreadError