Sha256: ffc653f6b956b806bfa16641401faf3ce5bec3756f08972b4fa234b69ec6dd3e

Contents?: true

Size: 1.03 KB

Versions: 3

Compression:

Stored size: 1.03 KB

Contents

require 'logger'
require 'pdk'

module PDK
  class Logger < ::Logger
    WRAP_COLUMN_LIMIT = 78

    def initialize
      super($stderr)
      @sent_messages = {}

      # TODO: Decide on output format.
      self.formatter = proc do |severity, _datetime, _progname, msg|
        prefix = "pdk (#{severity}): "
        if msg.is_a?(Hash)
          if msg.fetch(:wrap, false)
            wrap_pattern = /(.{1,#{WRAP_COLUMN_LIMIT - prefix.length}})(\s+|\Z)/
            "#{prefix}#{msg[:text].gsub(wrap_pattern, "\\1\n#{' ' * prefix.length}")}\n"
          else
            "#{prefix}#{msg[:text]}\n"
          end
        else
          "#{prefix}#{msg}\n"
        end
      end

      self.level = ::Logger::INFO
    end

    def warn_once(*args)
      hash = args.inspect.hash
      return if (@sent_messages[::Logger::WARN] ||= {}).key?(hash)

      @sent_messages[::Logger::WARN][hash] = true
      warn(*args)
    end

    def enable_debug_output
      self.level = ::Logger::DEBUG
    end

    def debug?
      level == ::Logger::DEBUG
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
pdk-3.3.0 lib/pdk/logger.rb
pdk-3.0.1 lib/pdk/logger.rb
pdk-3.0.0 lib/pdk/logger.rb