Sha256: 984cb0c41b67e45a93d1e854d235d0ccbaa69366cdc654ec814aa54da067df4f

Contents?: true

Size: 893 Bytes

Versions: 24

Compression:

Stored size: 893 Bytes

Contents

require "cabin/namespace"
require "cabin/metrics/histogram"

class Cabin::Metrics::Timer < Cabin::Metrics::Histogram
  # Start timing something.
  #
  # If no block is given
  # If a block is given, the execution of that block is timed.
  #
  public
  def time(&block)
    return time_block(&block) if block_given?

    # Return an object we can .stop
    # Call record(...) when we stop.
    return TimerContext.new { |duration| record(duration) }
  end # def time

  private
  def time_block(&block)
    start = Time.now
    block.call
    record(Time.now - start)
  end # def time_block

  class TimerContext
    public
    def initialize(&stop_callback)
      @start = Time.now
      @callback = stop_callback
    end

    public
    def stop
      duration = Time.now - @start
      @callback.call(duration)
    end # def stop
  end # class TimerContext
end # class Cabin::Metrics::Timer

Version data entries

24 entries across 22 versions & 6 rubygems

Version Path
logstash-filter-zabbix-0.1.2 vendor/bundle/jruby/1.9/gems/cabin-0.8.1/lib/cabin/metrics/timer.rb
logstash-filter-zabbix-0.1.1 vendor/bundle/jruby/1.9/gems/cabin-0.8.1/lib/cabin/metrics/timer.rb
ivanvc-logstash-input-s3-3.1.1.4 vendor/local/gems/cabin-0.8.1/lib/cabin/metrics/timer.rb
ivanvc-logstash-input-s3-3.1.1.3 vendor/local/gems/cabin-0.8.1/lib/cabin/metrics/timer.rb
ivanvc-logstash-input-s3-3.1.1.2 vendor/local/gems/cabin-0.8.1/lib/cabin/metrics/timer.rb
cabin-0.9.0 lib/cabin/metrics/timer.rb
able-neo4j-1.0.0 vendor/bundle/jruby/1.9/gems/cabin-0.7.1/lib/cabin/metrics/timer.rb
cabin-0.8.1 lib/cabin/metrics/timer.rb
cabin-0.8.0 lib/cabin/metrics/timer.rb
logstash-input-beats-2.0.2 vendor/jruby/1.9/gems/logstash-codec-json-2.0.3/vendor/gems/cabin-0.7.2/lib/cabin/metrics/timer.rb
logstash-input-beats-2.0.2 vendor/jruby/1.9/gems/cabin-0.7.1/lib/cabin/metrics/timer.rb
logstash-input-beats-2.0.2 vendor/jruby/1.9/gems/cabin-0.7.2/lib/cabin/metrics/timer.rb
logstash-codec-json-2.0.3 vendor/gems/cabin-0.7.2/lib/cabin/metrics/timer.rb
cabin-0.7.2 lib/cabin/metrics/timer.rb
logstash-input-beats-0.9.2 vendor/jruby/1.9/gems/cabin-0.7.1/lib/cabin/metrics/timer.rb
logstash-input-beats-0.9.1 vendor/jruby/1.9/gems/cabin-0.7.1/lib/cabin/metrics/timer.rb
cabin-0.7.1 lib/cabin/metrics/timer.rb
cabin-0.6.1 lib/cabin/metrics/timer.rb
cabin-0.6.0 lib/cabin/metrics/timer.rb
cabin-0.5.0 lib/cabin/metrics/timer.rb