Module: SimpleDebugLogging::ClassMethodLogger

Defined in:
lib/simple_debug_logging.rb

Instance Method Summary collapse

Instance Method Details

#logged(*methods_to_log) ⇒ Object



18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# File 'lib/simple_debug_logging.rb', line 18

def logged(*methods_to_log)
  methods_to_log.each do |method_to_log|
    original_method = method(method_to_log)
    (class << self; self; end).class_eval do
      define_method(method_to_log.to_sym) do |*args|
        method_return_value = nil
        invocation_id = " ~#{args.object_id}@#{Time.now.to_i}~" if args
        puts "#{self}.#{method_to_log}(#{args.map {|x| x.inspect}.join(", ")})#{invocation_id}"
        elapsed = Benchmark.realtime do
          method_return_value = original_method.call(*args)
        end
        puts "#{self}.#{method_to_log} ~#{args.hash}~ complete in #{elapsed}s#{invocation_id}"
        method_return_value
      end
    end
  end
end