Sha256: b31fb248c13da82ab4ef11c36b34cef208f2cd3740464ba0a8479a5891d194e8

Contents?: true

Size: 818 Bytes

Versions: 20

Compression:

Stored size: 818 Bytes

Contents

# frozen_string_literal: true

require_relative '../../../puppet/util/profiler/logging'

# A profiler implementation that measures the number of seconds a segment of
# code takes to execute and provides a callback with a string representation of
# the profiling information.
#
# @api private
class Puppet::Util::Profiler::WallClock < Puppet::Util::Profiler::Logging
  def do_start(description, metric_id)
    Timer.new
  end

  def do_finish(context, description, metric_id)
    { :time => context.stop,
      :msg => _("took %{context} seconds") % { context: context } }
  end

  class Timer
    FOUR_DECIMAL_DIGITS = '%0.4f'

    def initialize
      @start = Time.now
    end

    def stop
      @time = Time.now - @start
      @time
    end

    def to_s
      format(FOUR_DECIMAL_DIGITS, @time)
    end
  end
end

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
puppet-8.8.1 lib/puppet/util/profiler/wall_clock.rb
puppet-8.8.1-x86-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-8.8.1-x64-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-8.8.1-universal-darwin lib/puppet/util/profiler/wall_clock.rb
puppet-8.7.0 lib/puppet/util/profiler/wall_clock.rb
puppet-8.7.0-x86-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-8.7.0-x64-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-8.7.0-universal-darwin lib/puppet/util/profiler/wall_clock.rb
puppet-8.6.0 lib/puppet/util/profiler/wall_clock.rb
puppet-8.6.0-x86-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-8.6.0-x64-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-8.6.0-universal-darwin lib/puppet/util/profiler/wall_clock.rb
puppet-8.5.1 lib/puppet/util/profiler/wall_clock.rb
puppet-8.5.1-x86-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-8.5.1-x64-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-8.5.1-universal-darwin lib/puppet/util/profiler/wall_clock.rb
puppet-8.5.0 lib/puppet/util/profiler/wall_clock.rb
puppet-8.5.0-x86-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-8.5.0-x64-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-8.5.0-universal-darwin lib/puppet/util/profiler/wall_clock.rb