Sha256: f51215baa7f40cb15cc6b7e1673753e57e2b8cb380378c5e92c58252b37b60e5

Contents?: true

Size: 785 Bytes

Versions: 120

Compression:

Stored size: 785 Bytes

Contents

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

120 entries across 120 versions & 1 rubygems

Version Path
puppet-7.34.0 lib/puppet/util/profiler/wall_clock.rb
puppet-7.34.0-x86-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-7.34.0-x64-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-7.34.0-universal-darwin lib/puppet/util/profiler/wall_clock.rb
puppet-7.33.0 lib/puppet/util/profiler/wall_clock.rb
puppet-7.33.0-x86-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-7.33.0-x64-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-7.33.0-universal-darwin lib/puppet/util/profiler/wall_clock.rb
puppet-7.32.1 lib/puppet/util/profiler/wall_clock.rb
puppet-7.32.1-x86-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-7.32.1-x64-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-7.32.1-universal-darwin lib/puppet/util/profiler/wall_clock.rb
puppet-7.31.0 lib/puppet/util/profiler/wall_clock.rb
puppet-7.31.0-x86-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-7.31.0-x64-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-7.31.0-universal-darwin lib/puppet/util/profiler/wall_clock.rb
puppet-7.30.0 lib/puppet/util/profiler/wall_clock.rb
puppet-7.30.0-x86-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-7.30.0-x64-mingw32 lib/puppet/util/profiler/wall_clock.rb
puppet-7.30.0-universal-darwin lib/puppet/util/profiler/wall_clock.rb