Sha256: 7bc9dbe2e507b932e782c666c479f5079814f1fb9d100ac7355ca68b6600069c

Contents?: true

Size: 1.91 KB

Versions: 1

Compression:

Stored size: 1.91 KB

Contents

require 'active_support/core_ext/string'
require 'logger'

module Tailog
  module WatchMethods
    def self.logger
      @logger ||= Logger.new(File.join Tailog.log_path, "watch_methods.log")
    end

    def inject_methods targets
      targets.each do |target|
        if target.include? "#"
          inject_instance_method target
        else
          inject_class_method target
        end
      end
    end

    private

    def inject_class_method target
      klass, _, method = if target.include? "."
          target.rpartition(".")
        else
          target.rpartition("::")
        end
      klass.constantize.class_eval <<-EOS, __FILE__, __LINE__
        class << self
          #{build_watch_method target, method}
        end
      EOS
    rescue => error
      WatchMethods.logger.error "Inject class method `#{target}' failed: #{error.class}: #{error.message}"
    end

    def inject_instance_method target
      klass, _, method = target.rpartition("#")
      klass.constantize.class_eval <<-EOS, __FILE__, __LINE__
        #{build_watch_method target, method}
      EOS
    rescue => error
      WatchMethods.logger.error "Inject instance method `#{target}' failed: #{error.class}: #{error.message}"
    end

    def build_watch_method target, method
      raw_method = "watch_method_raw_#{method}"
      return <<-EOS
        alias_method :#{raw_method}, :#{method}
        def #{method} *args
          Tailog::WatchMethods.logger.info "Method called: #{target} \#{self} with \#{args}"
          start = Time.now
          result = send :#{raw_method}, *args
          Tailog::WatchMethods.logger.info "Method finished: #{target} with \#{result} in \#{(Time.now - start) * 1000} ms"
          result
        rescue => error
          Tailog::WatchMethods.logger.error "Method failed: #{target} raises \#{error.class}: \#{error.message}\\n\#{error.backtrace.join("\\n")}"
          raise error
        end
      EOS
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
tailog-0.3.1 lib/tailog/watch_methods.rb