Sha256: 437060d8b4be021182f0fdbca355c1add7c28cfc85bc20c58eaf4ae5eb0c9c41

Contents?: true

Size: 1.52 KB

Versions: 3

Compression:

Stored size: 1.52 KB

Contents

# typed: true
module Datadog
  module Utils
    # Common database-related utility functions.
    module Time
      include Kernel # Ensure that kernel methods are always available (https://sorbet.org/docs/error-reference#7003)

      module_function

      # Current monotonic time
      #
      # @param unit [Symbol] unit for the resulting value, same as ::Process#clock_gettime, defaults to :float_second
      # @return [Numeric] timestamp in the requested unit, since some unspecified starting point
      def get_time(unit = :float_second)
        Process.clock_gettime(Process::CLOCK_MONOTONIC, unit)
      end

      # Current wall time.
      #
      # @return [Time] current time object
      def now
        ::Time.now
      end

      # Overrides the implementation of `#now
      # with the provided callable.
      #
      # Overriding the method `#now` instead of
      # indirectly calling `block` removes
      # one level of method call overhead.
      #
      # @param block [Proc] block that returns a `Time` object representing the current wall time
      def now_provider=(block)
        define_singleton_method(:now, &block)
      end

      def measure
        before = get_time
        yield
        after = get_time
        after - before
      end

      def as_utc_epoch_ns(time)
        # we use #to_r instead of #to_f because Float doesn't have enough precision to represent exact nanoseconds, see
        # https://rubyapi.org/3.0/o/time#method-i-to_f
        (time.to_r * 1_000_000_000).to_i
      end
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
ddtrace-0.54.2 lib/ddtrace/utils/time.rb
ddtrace-0.54.1 lib/ddtrace/utils/time.rb
ddtrace-0.54.0 lib/ddtrace/utils/time.rb