Class: Maze::Logger

Inherits:
Logger
  • Object
show all
Includes:
Singleton
Defined in:
lib/maze/logger.rb

Overview

A logger, with level configured according to the environment

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeLogger

Returns a new instance of Logger.



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

def initialize
  if ENV['VERBOSE'] || ENV['DEBUG']
    super(STDOUT, level: Logger::DEBUG)
  elsif ENV['QUIET']
    super(STDOUT, level: Logger::ERROR)
  else
    super(STDOUT, level: Logger::INFO)
  end

  @datetime_format = '%H:%M:%S'

  @formatter = proc do |severity, time, _name, message|
    formatted_time = time.strftime(@datetime_format)

    "\e[2m[#{formatted_time}]\e[0m #{severity.rjust(5)}: #{message}\n"
  end
end

Instance Attribute Details

#datetime_formatObject

Returns the value of attribute datetime_format.



12
13
14
# File 'lib/maze/logger.rb', line 12

def datetime_format
  @datetime_format
end