1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 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 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
module Logging::Appenders
# Accessor / Factory for the Stdout appender.
#
def self.stdout( *args )
if args.empty?
return self['stdout'] || ::Logging::Appenders::Stdout.new
end
::Logging::Appenders::Stdout.new(*args)
end
# This class provides an Appender that can write to STDOUT.
#
class Stdout < ::Logging::Appenders::IO
# call-seq:
# Stdout.new( name = 'stdout' )
# Stdout.new( :layout => layout )
# Stdout.new( name = 'stdout', :level => 'info' )
#
# Creates a new Stdout Appender. The name 'stdout' will be used unless
# another is given. Optionally, a layout can be given for the appender
# to use (otherwise a basic appender will be created) and a log level
# can be specified.
#
# Options:
#
# :layout => the layout to use when formatting log events
# :level => the level at which to log
#
def initialize( *args )
opts = Hash === args.last ? args.pop : {}
name = args.empty? ? 'stdout' : args.shift
opts[:encoding] = STDOUT.external_encoding if STDOUT.respond_to? :external_encoding
super(name, STDOUT, opts)
end
end # Stdout
# Accessor / Factory for the Stderr appender.
#
def self.stderr( *args )
if args.empty?
return self['stderr'] || ::Logging::Appenders::Stderr.new
end
::Logging::Appenders::Stderr.new(*args)
end
# This class provides an Appender that can write to STDERR.
#
class Stderr < ::Logging::Appenders::IO
# call-seq:
# Stderr.new( name = 'stderr' )
# Stderr.new( :layout => layout )
# Stderr.new( name = 'stderr', :level => 'warn' )
#
# Creates a new Stderr Appender. The name 'stderr' will be used unless
# another is given. Optionally, a layout can be given for the appender
# to use (otherwise a basic appender will be created) and a log level
# can be specified.
#
# Options:
#
# :layout => the layout to use when formatting log events
# :level => the level at which to log
#
def initialize( *args )
opts = Hash === args.last ? args.pop : {}
name = args.empty? ? 'stderr' : args.shift
opts[:encoding] = STDERR.external_encoding if STDERR.respond_to? :external_encoding
super(name, STDERR, opts)
end
end # Stderr
end # Logging::Appenders
|