Sha256: c8557831e834181bc468d217849b4fd37bd3c99541d8ae9b4234b2a3875f5448

Contents?: true

Size: 983 Bytes

Versions: 2

Compression:

Stored size: 983 Bytes

Contents

# frozen_string_literal: true

module DDTelemetry
  class Stopwatch
    class AlreadyRunningError < StandardError
      def message
        'Cannot start, because stopwatch is already running'
      end
    end

    class NotRunningError < StandardError
      def message
        'Cannot stop, because stopwatch is not running'
      end
    end

    class StillRunningError < StandardError
      def message
        'Cannot get duration, because stopwatch is still running'
      end
    end

    def initialize
      @duration = 0.0
      @last_start = nil
    end

    def start
      raise AlreadyRunningError if running?
      @last_start = Time.now
    end

    def stop
      raise NotRunningError unless running?
      @duration += (Time.now - @last_start)
      @last_start = nil
    end

    def duration
      raise StillRunningError if running?
      @duration
    end

    def running?
      !@last_start.nil?
    end

    def stopped?
      !running?
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
ddtelemetry-1.0.0a3 lib/ddtelemetry/stopwatch.rb
ddtelemetry-1.0.0a2 lib/ddtelemetry/stopwatch.rb