ruby / 2.3.8 / mutex_m.html /

module Mutex_m

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

Public Instance Methods

mu_lock () Show source
# File lib/mutex_m.rb, line 88
def mu_lock
  @_mutex.lock
end

See Mutex#lock

mu_locked? () Show source
# File lib/mutex_m.rb, line 78
def mu_locked?
  @_mutex.locked?
end

See Mutex#locked?

mu_synchronize (&block) Show source
# File lib/mutex_m.rb, line 73
def mu_synchronize(&block)
  @_mutex.synchronize(&block)
end

See Mutex#synchronize

mu_try_lock () Show source
# File lib/mutex_m.rb, line 83
def mu_try_lock
  @_mutex.try_lock
end

See Mutex#try_lock

mu_unlock () Show source
# File lib/mutex_m.rb, line 93
def mu_unlock
  @_mutex.unlock
end

See Mutex#unlock

sleep (timeout = nil) Show source
# File lib/mutex_m.rb, line 98
def sleep(timeout = nil)
  @_mutex.sleep(timeout)
end

See Mutex#sleep

Ruby Core © 1993–2017 Yukihiro Matsumoto
Licensed under the Ruby License.
Ruby Standard Library © contributors
Licensed under their own licenses.