Class: Yell::Logger
- Inherits:
-
Object
- Object
- Yell::Logger
- Defined in:
- lib/yell/logger.rb
Overview
The Logger
is your entrypoint. Anything onwards is derived from here.
Instance Method Summary collapse
-
#adapter(type = :file, *args, &block) ⇒ Object
Define an adapter to be used for logging.
-
#close(now = false) ⇒ Object
Convenience method for resetting all adapters of the Logger.
-
#initialize(*args, &block) ⇒ Logger
constructor
Creates a new Logger instance.
-
#level(val = nil) ⇒ Object
Set the minimum log level.
Constructor Details
#initialize(*args, &block) ⇒ Logger
Creates a new Logger instance
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/yell/logger.rb', line 30 def initialize( *args, &block ) @adapters = [] # extract options @options = args.last.is_a?(Hash) ? args.pop : {} # set the log level when given # level @options[:level] if @options[:level] level @options[:level] # default # check if filename was given as argument and put it into the @options if args.last.is_a?( String ) @options[:filename] = args.pop unless @options[:filename] end # extract adapter adapter args.pop if args.any? # set the log level when given level @options[:level] if @options[:level] # eval the given block instance_eval &block if block define! end |
Instance Method Details
#adapter(type = :file, *args, &block) ⇒ Object
Define an adapter to be used for logging.
79 80 81 82 83 84 85 86 87 |
# File 'lib/yell/logger.rb', line 79 def adapter( type = :file, *args, &block ) = [@options, *args].inject( Hash.new ) do |h,c| h.merge( c.is_a?(String) ? {:filename => c} : c ) end @adapters << Yell::Adapters[ type, , &block ] rescue NameError => e raise Yell::NoSuchAdapter, type end |
#close(now = false) ⇒ Object
Convenience method for resetting all adapters of the Logger.
102 103 104 |
# File 'lib/yell/logger.rb', line 102 def close( now = false ) @adapters.each(&:close) end |