Class: Imap::Backup::Logger

Inherits:
Object
  • Object
show all
Includes:
Singleton
Defined in:
lib/imap/backup/logger.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeLogger

Returns a new instance of Logger.



47
48
49
50
# File 'lib/imap/backup/logger.rb', line 47

def initialize
  @logger = ::Logger.new($stdout)
  $stdout.sync = true
end

Instance Attribute Details

#loggerObject (readonly)

Returns the value of attribute logger.



45
46
47
# File 'lib/imap/backup/logger.rb', line 45

def logger
  @logger
end

Class Method Details

.loggerObject



11
12
13
# File 'lib/imap/backup/logger.rb', line 11

def self.logger
  Logger.instance.logger
end

.sanitize_stderrObject



35
36
37
38
39
40
41
42
43
# File 'lib/imap/backup/logger.rb', line 35

def self.sanitize_stderr
  sanitizer = Text::Sanitizer.new($stdout)
  previous_stderr = $stderr
  $stderr = sanitizer
  yield
ensure
  sanitizer.flush
  $stderr = previous_stderr
end

.setup_logging(options = {}) ⇒ Object



15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# File 'lib/imap/backup/logger.rb', line 15

def self.setup_logging(options = {})
  copy = options.clone
  quiet = copy.delete(:quiet)
  verbose = copy.delete(:verbose)
  level =
    case
    when quiet
      ::Logger::Severity::UNKNOWN
    when verbose
      ::Logger::Severity::DEBUG
    else
      ::Logger::Severity::INFO
    end
  logger.level = level
  debug = level == ::Logger::Severity::DEBUG
  Net::IMAP.debug = debug

  copy
end