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

Version Path
simple-cli-0.2.15 lib/simple/cli/logger/adapter.rb
simple-cli-0.2.14 lib/simple/cli/logger/adapter.rb
simple-cli-0.2.13 lib/simple/cli/logger/adapter.rb
simple-cli-0.2.12 lib/simple/cli/logger/adapter.rb