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