Sha256: af70f6035a1e3c9f0e4162795e6e4f7a45f5ef281e5a193e4c5b07eb97db6b37
Contents?: true
Size: 1.19 KB
Versions: 2
Compression:
Stored size: 1.19 KB
Contents
# frozen_string_literal: true module Facter module Util module ApiDebugger 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 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 end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
facter-4.6.1 | lib/facter/util/api_debugger.rb |
facter-4.6.0 | lib/facter/util/api_debugger.rb |