diff options
author | shugo <shugo@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-07-23 07:14:54 +0000 |
---|---|---|
committer | shugo <shugo@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-07-23 07:14:54 +0000 |
commit | 8621d0908aa3db4524566fea7702a5556bb25501 (patch) | |
tree | 91e86141230c23aea6ab43361a54a3041d61dd85 | |
parent | 38c4242cf68091af5aaf474ef5ddc35569c56581 (diff) |
* lib/mutex_m.rb (sleep): added Mutex_m#sleep to support ConditionVariable.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@28731 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | lib/mutex_m.rb | 4 | ||||
-rw-r--r-- | test/test_mutex_m.rb | 25 |
3 files changed, 34 insertions, 0 deletions
@@ -1,3 +1,8 @@ +Fri Jul 23 16:07:32 2010 Shugo Maeda <[email protected]> + + * lib/mutex_m.rb (sleep): added Mutex_m#sleep to support + ConditionVariable. + Fri Jul 23 15:09:22 2010 Nobuyoshi Nakada <[email protected]> * configure.in (RUBY_MINGW32): ignore msvc suffix. diff --git a/lib/mutex_m.rb b/lib/mutex_m.rb index 081bb788e4..b9937b635d 100644 --- a/lib/mutex_m.rb +++ b/lib/mutex_m.rb @@ -78,6 +78,10 @@ module Mutex_m @_mutex.unlock end + def sleep(timeout = nil) + @_mutex.sleep(timeout) + end + private def mu_initialize diff --git a/test/test_mutex_m.rb b/test/test_mutex_m.rb new file mode 100644 index 0000000000..ab8927dd0f --- /dev/null +++ b/test/test_mutex_m.rb @@ -0,0 +1,25 @@ +require 'test/unit' +require 'thread' +require 'mutex_m' + +class TestMutexM < Test::Unit::TestCase + def test_cv_wait + o = Object.new + o.extend(Mutex_m) + c = ConditionVariable.new + t = Thread.start { + o.synchronize do + until foo = o.instance_variable_get(:@foo) + c.wait(o) + end + foo + end + } + sleep(0.0001) + o.synchronize do + o.instance_variable_set(:@foo, "abc") + end + c.signal + assert_equal "abc", t.value + end +end |