louismullie/treat

View on GitHub
lib/treat/helpers/object.rb

Summary

Maintainability
A
0 mins
Test Coverage
# Methods related to object reflection.
class Treat::Helpers::Object
  
  # Allow introspection onto what method called
  # another one at runtime (useful for debugging).
  module CallerMethod
    # Pattern to match method from trace.
    CMPattern = /^(.+?):(\d+)(?::in `(.*)')?/
    # Return the name of the method that 
    # called the method that calls this method.
    def caller_method(n = 3)
      at = caller(n).first
      CMPattern =~ at
      Regexp.last_match[3].
      gsub('block in ', '').intern
    end
  end

  # Retrieve the last name of a class/module
  # (i.e. the part after the last "::").
  module ModuleName
    def module_name; self.to_s.split('::')[-1]; end
    alias :mn :module_name
  end
  
  module Verbosity
    # Runs a block of code without warnings.
    def silence_warnings(&block)
      warn_level = $VERBOSE; $VERBOSE = nil
      result = block.call; $VERBOSE = warn_level
      result
    end
    # Runs a block of code while blocking stdout.
    def silence_stdout(log = '/dev/null')
      unless Treat.core.verbosity.silence
        yield; return
      end
      file, old, ret = File.new(log, 'w'), 
      $stdout.dup, nil; $stdout.reopen(file)
      ret = yield; $stdout = old; return ret
    end
  end
  
  # Allow getting the caller method in any context.
  Object.class_eval do
    include Treat::Helpers::Object::CallerMethod
    include Treat::Helpers::Object::Verbosity
  end
  
  # Allow getting the last name of any module/class.
  Module.class_eval do
    include Treat::Helpers::Object::ModuleName
  end
  
end