![show/hide quicksearch [+]](./images/find.png)
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 — remember to call super() in your class initialize method.
class Foo include Mutex_m def initialize # ... super() end # ... end obj = Foo.new # this obj can be handled like Mutex
 
               # File ruby-3.1.2/lib/mutex_m.rb, line 93
def mu_lock
  @_mutex.lock
end
             
             
               # File ruby-3.1.2/lib/mutex_m.rb, line 83
def mu_locked?
  @_mutex.locked?
end
             
             
               # File ruby-3.1.2/lib/mutex_m.rb, line 78
def mu_synchronize(&block)
  @_mutex.synchronize(&block)
end
             
             
               # File ruby-3.1.2/lib/mutex_m.rb, line 88
def mu_try_lock
  @_mutex.try_lock
end
             
             
               # File ruby-3.1.2/lib/mutex_m.rb, line 98
def mu_unlock
  @_mutex.unlock
end