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 |