mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/mutex_m.rb: Add rdoc for Mutex_m module
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@39328 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
75eb6cc98e
commit
2d112d2c78
2 changed files with 41 additions and 21 deletions
|
@ -1,3 +1,7 @@
|
||||||
|
Wed Feb 20 11:50:00 2013 Zachary Scott <zachary@zacharyscott.net>
|
||||||
|
|
||||||
|
* lib/mutex_m.rb: Add rdoc for Mutex_m module
|
||||||
|
|
||||||
Wed Feb 20 09:34:43 2013 Eric Hodel <drbrain@segment7.net>
|
Wed Feb 20 09:34:43 2013 Eric Hodel <drbrain@segment7.net>
|
||||||
|
|
||||||
* lib/rubygems/commands/update_command.rb: Create the installer after
|
* lib/rubygems/commands/update_command.rb: Create the installer after
|
||||||
|
|
|
@ -8,25 +8,36 @@
|
||||||
# patched by akira yamada
|
# patched by akira yamada
|
||||||
#
|
#
|
||||||
# --
|
# --
|
||||||
# Usage:
|
|
||||||
# require "mutex_m.rb"
|
|
||||||
# obj = Object.new
|
|
||||||
# obj.extend Mutex_m
|
|
||||||
# ...
|
|
||||||
# extended object can be handled like Mutex
|
|
||||||
# or
|
|
||||||
# class Foo
|
|
||||||
# include Mutex_m
|
|
||||||
# ...
|
|
||||||
# end
|
|
||||||
# obj = Foo.new
|
|
||||||
# this obj can be handled like Mutex
|
|
||||||
#
|
|
||||||
|
|
||||||
require 'thread'
|
require 'thread'
|
||||||
|
|
||||||
|
# = mutex_m.rb
|
||||||
|
#
|
||||||
|
# When 'mutex_m' is required, any object that extends or includes Mutex_m will
|
||||||
|
# be treated like a Mutex.
|
||||||
|
#
|
||||||
|
# Start by requiring the standard library Mutex_m:
|
||||||
|
#
|
||||||
|
# require "mutex_m.rb"
|
||||||
|
#
|
||||||
|
# From here you can extend an object with Mutex instance methods:
|
||||||
|
#
|
||||||
|
# obj = Object.new
|
||||||
|
# obj.extend Mutex_m
|
||||||
|
#
|
||||||
|
# Or mixin Mutex_m into your module to your class inherit Mutex instance
|
||||||
|
# methods.
|
||||||
|
#
|
||||||
|
# class Foo
|
||||||
|
# include Mutex_m
|
||||||
|
# # ...
|
||||||
|
# end
|
||||||
|
# obj = Foo.new
|
||||||
|
# # this obj can be handled like Mutex
|
||||||
|
#
|
||||||
module Mutex_m
|
module Mutex_m
|
||||||
def Mutex_m.define_aliases(cl)
|
def Mutex_m.define_aliases(cl) # :nodoc:
|
||||||
cl.module_eval %q{
|
cl.module_eval %q{
|
||||||
alias locked? mu_locked?
|
alias locked? mu_locked?
|
||||||
alias lock mu_lock
|
alias lock mu_lock
|
||||||
|
@ -36,17 +47,17 @@ module Mutex_m
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
def Mutex_m.append_features(cl)
|
def Mutex_m.append_features(cl) # :nodoc:
|
||||||
super
|
super
|
||||||
define_aliases(cl) unless cl.instance_of?(Module)
|
define_aliases(cl) unless cl.instance_of?(Module)
|
||||||
end
|
end
|
||||||
|
|
||||||
def Mutex_m.extend_object(obj)
|
def Mutex_m.extend_object(obj) # :nodoc:
|
||||||
super
|
super
|
||||||
obj.mu_extended
|
obj.mu_extended
|
||||||
end
|
end
|
||||||
|
|
||||||
def mu_extended
|
def mu_extended # :nodoc:
|
||||||
unless (defined? locked? and
|
unless (defined? locked? and
|
||||||
defined? lock and
|
defined? lock and
|
||||||
defined? unlock and
|
defined? unlock and
|
||||||
|
@ -57,38 +68,43 @@ module Mutex_m
|
||||||
mu_initialize
|
mu_initialize
|
||||||
end
|
end
|
||||||
|
|
||||||
# locking
|
# See Mutex#synchronize
|
||||||
def mu_synchronize(&block)
|
def mu_synchronize(&block)
|
||||||
@_mutex.synchronize(&block)
|
@_mutex.synchronize(&block)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# See Mutex#locked?
|
||||||
def mu_locked?
|
def mu_locked?
|
||||||
@_mutex.locked?
|
@_mutex.locked?
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# See Mutex#try_lock
|
||||||
def mu_try_lock
|
def mu_try_lock
|
||||||
@_mutex.try_lock
|
@_mutex.try_lock
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# See Mutex#lock
|
||||||
def mu_lock
|
def mu_lock
|
||||||
@_mutex.lock
|
@_mutex.lock
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# See Mutex#unlock
|
||||||
def mu_unlock
|
def mu_unlock
|
||||||
@_mutex.unlock
|
@_mutex.unlock
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# See Mutex#sleep
|
||||||
def sleep(timeout = nil)
|
def sleep(timeout = nil)
|
||||||
@_mutex.sleep(timeout)
|
@_mutex.sleep(timeout)
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def mu_initialize
|
def mu_initialize # :nodoc:
|
||||||
@_mutex = Mutex.new
|
@_mutex = Mutex.new
|
||||||
end
|
end
|
||||||
|
|
||||||
def initialize(*args)
|
def initialize(*args) # :nodoc:
|
||||||
mu_initialize
|
mu_initialize
|
||||||
super
|
super
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue