summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2002-06-06 02:43:02 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2002-06-06 02:43:02 +0000
commitf0661f41ab51cadb3c348a14791d52bba19d9cfa (patch)
tree88e1c3ad651a50f282277931a3e0596b1bf98be5 /lib
parent9676f70b0cc7ecb9b6255a785f60fb7cbba4a596 (diff)
downloadruby-f0661f41ab51cadb3c348a14791d52bba19d9cfa.tar.gz
ruby-f0661f41ab51cadb3c348a14791d52bba19d9cfa.tar.xz
ruby-f0661f41ab51cadb3c348a14791d52bba19d9cfa.zip
* lib/thread.rb (Queue::pop): get rid of race condition.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@2527 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib')
-rw-r--r--lib/thread.rb22
1 files changed, 7 insertions, 15 deletions
diff --git a/lib/thread.rb b/lib/thread.rb
index a39831746..7666bccec 100644
--- a/lib/thread.rb
+++ b/lib/thread.rb
@@ -173,22 +173,14 @@ class Queue
alias enq push
def pop(non_block=false)
- Thread.critical = true
- begin
- loop do
- if @que.empty?
- if non_block
- raise ThreadError, "queue empty"
- end
- @waiting.push Thread.current
- Thread.stop
- else
- return @que.shift
- end
- end
- ensure
- Thread.critical = false
+ while (Thread.critical = true; @que.empty?)
+ raise ThreadError, "queue empty" if non_block
+ @waiting.push Thread.current
+ Thread.stop
end
+ @que.shift
+ ensure
+ Thread.critical = false
end
alias shift pop
alias deq pop