Class: Imap::Backup::Logger
- Inherits:
-
Object
- Object
- Imap::Backup::Logger
- Includes:
- Singleton
- Defined in:
- lib/imap/backup/logger.rb
Instance Attribute Summary collapse
-
#logger ⇒ Object
readonly
Returns the value of attribute logger.
Class Method Summary collapse
- .count(verbose) ⇒ Object
- .logger ⇒ Object
- .sanitize_stderr ⇒ Object
- .setup_logging(options = {}) ⇒ Object
Instance Method Summary collapse
-
#initialize ⇒ Logger
constructor
A new instance of Logger.
Constructor Details
#initialize ⇒ Logger
Returns a new instance of Logger.
53 54 55 56 |
# File 'lib/imap/backup/logger.rb', line 53 def initialize @logger = ::Logger.new($stdout) $stdout.sync = true end |
Instance Attribute Details
#logger ⇒ Object (readonly)
Returns the value of attribute logger.
51 52 53 |
# File 'lib/imap/backup/logger.rb', line 51 def logger @logger end |
Class Method Details
.count(verbose) ⇒ Object
47 48 49 |
# File 'lib/imap/backup/logger.rb', line 47 def self.count(verbose) verbose.reduce(1) { |acc, v| acc + (v ? 1 : -1) } end |
.logger ⇒ Object
12 13 14 |
# File 'lib/imap/backup/logger.rb', line 12 def self.logger Logger.instance.logger end |
.sanitize_stderr ⇒ Object
37 38 39 40 41 42 43 44 45 |
# File 'lib/imap/backup/logger.rb', line 37 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
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/imap/backup/logger.rb', line 16 def self.setup_logging( = {}) copy = .clone quiet = copy.delete(:quiet) verbose = copy.delete(:verbose) || [] verbose_count = count(verbose) level = case when quiet ::Logger::Severity::UNKNOWN when verbose_count >= 2 ::Logger::Severity::DEBUG else ::Logger::Severity::INFO end logger.level = level Net::IMAP.debug = (verbose_count >= 3) copy end |