File: clock.rb

package info (click to toggle)
ruby-dry-logger 1.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 156 kB
  • sloc: ruby: 802; makefile: 4
file content (47 lines) | stat: -rw-r--r-- 784 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# frozen_string_literal: true

module Dry
  module Logger
    # @since 1.0.0
    # @api private
    class Clock
      # @since 1.0.0
      # @api private
      attr_reader :unit

      # @since 1.0.0
      # @api private
      def initialize(unit: :nanosecond)
        @unit = unit
      end

      # @since 1.0.0
      # @api private
      def now
        Time.now
      end

      # @since 1.0.0
      # @api private
      def now_utc
        now.getutc
      end

      # @since 1.0.0
      # @api private
      def measure
        start = current
        result = yield
        [result, current - start]
      end

      private

      # @since 1.0.0
      # @api private
      def current
        Process.clock_gettime(Process::CLOCK_MONOTONIC, unit)
      end
    end
  end
end