Class: Flickrage::Log

Inherits:
Object
  • Object
show all
Defined in:
lib/flickrage/log.rb

Overview

Shared logger

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(options = {}) ⇒ Log

Returns a new instance of Log.



12
13
14
15
16
17
# File 'lib/flickrage/log.rb', line 12

def initialize(options = {})
  @verbose = Flickrage.config.verbose
  @quiet   = Flickrage.config.quiet
  options.each { |key, option| instance_variable_set(:"@#{key}", option) }
  instance.level = Flickrage.config.logger_level if instance
end

Instance Attribute Details

#bufferObject



23
24
25
# File 'lib/flickrage/log.rb', line 23

def buffer
  @buffer ||= %w()
end

#instanceObject



19
20
21
# File 'lib/flickrage/log.rb', line 19

def instance
  @instance ||= Flickrage.config.logger
end

#quietObject

Returns the value of attribute quiet.



9
10
11
# File 'lib/flickrage/log.rb', line 9

def quiet
  @quiet
end

#shellObject

Returns the value of attribute shell.



8
9
10
# File 'lib/flickrage/log.rb', line 8

def shell
  @shell
end

#verboseObject

Returns the value of attribute verbose.



9
10
11
# File 'lib/flickrage/log.rb', line 9

def verbose
  @verbose
end

Instance Method Details

#add_paddingObject



54
55
56
# File 'lib/flickrage/log.rb', line 54

def add_padding
  shell.say_status('', '') if shell
end

#ask(statement, color: :green, path: false) ⇒ Object



50
51
52
# File 'lib/flickrage/log.rb', line 50

def ask(statement, color: :green, path: false)
  shell.ask(statement, color, path: path) if shell
end

#closeObject



31
32
33
# File 'lib/flickrage/log.rb', line 31

def close
  instance.close if instance
end

#log(severity, message = nil, progname = nil, &block) ⇒ Object



58
59
60
61
62
63
# File 'lib/flickrage/log.rb', line 58

def log(severity, message = nil, progname = nil, &block)
  buffer << message
  instance.add(severity, message, progname, &block) if instance.respond_to?(:add)

  say(message, color(severity)) unless print?(severity)
end


45
46
47
48
# File 'lib/flickrage/log.rb', line 45

def print_table(*args)
  args[0]&.each { |row| instance.info(row) } if instance
  shell.print_table(*args) if shell
end