Sha256: 4f371f9d8d7adc6b54f303ae864868a4dc624ca3629d4f2cffe94faf7e79049c

Contents?: true

Size: 1.95 KB

Versions: 2

Compression:

Stored size: 1.95 KB

Contents

require_relative 'timeasure/version'
require_relative 'timeasure/configuration'
require_relative 'timeasure/class_methods'
require_relative 'timeasure/measurement'
require_relative 'timeasure/profiling/manager'

module Timeasure
  class << self
    def configure
      yield(configuration)
    end

    def configuration
      @configuration ||= Configuration.new
    end

    def included(base_class)
      base_class.extend ClassMethods

      instance_interceptor = const_set(instance_interceptor_name_for(base_class), interceptor_module_for(base_class))
      class_interceptor = const_set(class_interceptor_name_for(base_class), interceptor_module_for(base_class))

      return unless timeasure_enabled?

      base_class.prepend instance_interceptor
      base_class.singleton_class.prepend class_interceptor
    end

    def measure(klass_name: nil, method_name: nil, segment: nil, metadata: nil)
      t0 = Process.clock_gettime(Process::CLOCK_MONOTONIC)
      block_return_value = yield if block_given?
      t1 = Process.clock_gettime(Process::CLOCK_MONOTONIC)

      begin
        measurement = Timeasure::Measurement.new(klass_name: klass_name.to_s, method_name: method_name.to_s,
                                                 segment: segment, metadata: metadata, t0: t0, t1: t1)
        Timeasure.configuration.post_measuring_proc.call(measurement)
      rescue => e
        Timeasure.configuration.rescue_proc.call(e, klass_name)
      end

      block_return_value
    end

    private

    def instance_interceptor_name_for(base_class)
      "#{base_class.timeasure_name}InstanceInterceptor"
    end

    def class_interceptor_name_for(base_class)
      "#{base_class.timeasure_name}ClassInterceptor"
    end

    def interceptor_module_for(base_class)
      Module.new do
        @klass_name = base_class

        def self.klass_name
          @klass_name
        end
      end
    end

    def timeasure_enabled?
      configuration.enable_timeasure_proc.call
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
timeasure-0.2.1 lib/timeasure.rb
timeasure-0.2.0 lib/timeasure.rb