Class: Loggerman::Logger

Inherits:
Logger
  • Object
show all
Defined in:
lib/loggerman/logger.rb

Instance Method Summary collapse

Instance Method Details

#logger_by_level(level) ⇒ Object



12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
# File 'lib/loggerman/logger.rb', line 12

def logger_by_level(level)
  @logger_by_level ||= {}
  return @logger_by_level[level] if @logger_by_level[level]
  @logger_by_level[level] ||= defined?(Rails) ? Rails.logger : nil
  unless Loggerman.log_files[level.to_sym].blank?
    file = Loggerman.log_files.fetch(level.to_sym)
    logfile = File.open(defined?(Rails) ? "#{Rails.root}/log/#{file}" : "log/#{file}", 'a')
    logfile.sync = true
    @logger_by_level[level] = ActiveSupport::Logger.new(logfile)
    @logger_by_level[level].formatter = Loggerman::LoggerFormatter.new
    @logger_by_level[level].level = Loggerman::level
    @logger_by_level[level].progname = Loggerman::progname
  end
  @logger_by_level[level]
end