Class: Bridgetown::LogWriter

Inherits:
Logger
  • Object
show all
Defined in:
lib/bridgetown-core/log_writer.rb

Direct Known Subclasses

Rack::Logger

Instance Method Summary collapse

Constructor Details

#initializeLogWriter

rubocop:disable Lint/MissingSuper



5
6
7
8
9
10
11
12
13
# File 'lib/bridgetown-core/log_writer.rb', line 5

def initialize # rubocop:disable Lint/MissingSuper
  @progname = nil
  @level = DEBUG
  @default_formatter = Formatter.new
  @logdev = $stdout
  @formatter = proc do |_, _, _, msg|
    msg.to_s
  end
end

Instance Method Details

#add(severity, message = nil, progname = nil) ⇒ Object



21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# File 'lib/bridgetown-core/log_writer.rb', line 21

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

#closeObject



52
53
54
# File 'lib/bridgetown-core/log_writer.rb', line 52

def close
  # No LogDevice in use
end

#enable_prefixObject



15
16
17
18
19
# File 'lib/bridgetown-core/log_writer.rb', line 15

def enable_prefix
  @formatter = proc do |_, _, _, msg|
    "\e[32m[Bridgetown]\e[0m #{msg}"
  end
end

#error(progname = nil, &block) ⇒ Object

Log an ERROR message



48
49
50
# File 'lib/bridgetown-core/log_writer.rb', line 48

def error(progname = nil, &block)
  add(ERROR, nil, progname.red, &block)
end

#warn(progname = nil, &block) ⇒ Object

Log a WARN message



43
44
45
# File 'lib/bridgetown-core/log_writer.rb', line 43

def warn(progname = nil, &block)
  add(WARN, nil, progname.yellow, &block)
end