class Jekyll::Stevenson

def add(severity, message = nil, progname = nil)

def add(severity, message = nil, progname = nil)
  severity ||= UNKNOWN
  @logdev = logdevice(severity)
  return true if @logdev.nil? || severity < @level
  progname ||= @progname
  if message.nil?
    if block_given?
      message = yield
    else
      message = progname
      progname = @progname
    end
  end
  @logdev.puts(
    format_message(format_severity(severity), Time.now, progname, message)
  )
  true
end

def close

def close
  # No LogDevice in use
end

def error(progname = nil, &block)

Log an +ERROR+ message
def error(progname = nil, &block)
  add(ERROR, nil, progname.red, &block)
end

def initialize

def initialize
  formatter = proc do |_, _, _, msg|
    msg.to_s
  end
  super($stdout, :formatter => formatter)
end

def logdevice(severity)

def logdevice(severity)
  if severity > INFO
    $stderr
  else
    $stdout
  end
end

def warn(progname = nil, &block)

Log a +WARN+ message
def warn(progname = nil, &block)
  add(WARN, nil, progname.yellow, &block)
end