Method: PDK::Logger#initialize

Defined in:
lib/pdk/logger.rb

#initializeLogger

Returns a new instance of Logger.



11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# File 'lib/pdk/logger.rb', line 11

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 = %r{(.{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