module Facter::Util::ApiDebugger
Public Class Methods
parse_options(options)
click to toggle source
# File lib/facter/util/api_debugger.rb, line 31 def self.parse_options(options) exclude = [] print_caller = [] options.split(',').each do |option| if option.start_with?('-') exclude << option[1..].to_sym elsif option.start_with?('+') print_caller << option[1..].to_sym end end [exclude, print_caller] end
prepended(receiver)
click to toggle source
Calls superclass method
# File lib/facter/util/api_debugger.rb, line 6 def self.prepended(receiver) exclude, print_caller = parse_options(ENV['API_DEBUG']) receiver_methods = receiver.instance_methods - Object.methods receiver_methods.each do |meth| ApiDebugger.class_eval do define_method(meth) do |*args| method_call = super(*args) unless exclude.include?(meth) puts '#' * 80 puts "Method call: #{meth}" puts "Called with: #{args.inspect}" if print_caller.include?(meth) puts '-' * 80 puts caller end puts '#' * 80 end method_call end end end end