Sha256: d1712c4690f6917b72ab87e4ffbe237ea698754b53918d35e8b25e8f6d90a9a7
Contents?: true
Size: 946 Bytes
Versions: 4
Compression:
Stored size: 946 Bytes
Contents
# rubocop:disable Metrics/AbcSize # rubocop:disable Metrics/MethodLength require "forwardable" class Simple::CLI::Logger::Adapter def initialize(logger) @logger = logger end LOGGER_METHODS = [ :debug, :info, :warn, :error, :fatal, :level, :level= ] extend Forwardable delegate LOGGER_METHODS => :@logger def success(msg, *args, &block) if @logger.respond_to?(:success) @logger.send :success, msg, *args, &block else info "success: #{msg}", *args, &block end end def benchmark(msg, *args, &block) _ = block severity = :warn if msg.is_a?(Symbol) severity, msg = msg, args.shift end start = Time.now r = yield msg += ": #{(1000 * (Time.now - start)).to_i} msecs." send severity, msg, *args r rescue StandardError msg += "raises #{$!.class.name} after #{(1000 * (Time.now - start)).to_i} msecs." send severity, msg, *args raise $! end end
Version data entries
4 entries across 4 versions & 1 rubygems