# namespace module TeeLogger # main # @see http://www.rubydoc.info/stdlib/logger/Logger Logger class TeeLoggerBase class << self # @!macro [attach] logging_methods # @!method $1(progname = nil, *options, &block) # logging $1 level message. # @param progname see also Logger # @param options [Array] # @option options [Fixnum] indent_level # @option options [Symbol] enabling_target # valid values => [:console, :logfile] # @param &block see also Logger # @return true # @see Logger def define_logging_methods(name) define_method(name) do |progname = nil, *options, &block| logdev_name, indent_level = extract_options(options).values progname, block = indentation(progname, block, indent_level) logging(name, progname, logdev_name, &block) end end private :define_logging_methods # @!macro [attach] loglevel_check_methods # @!method $1(name) # @return [Boolean] def define_loglevel_check_methods(name) define_method(name) do @console.send(name) @logfile.send(name) end end private :define_loglevel_check_methods end include Utils # attr_reader :level, :progname, :formatter, :datetime_format attr_reader(*CONFIGURED_ATTRIBUTES) # @param logdev [String] # @param shift_age [Integer] # @param shift_size [Integer] # @see Logger#initialize def initialize(logdev = nil, shift_age = 0, shift_size = 1_048_576) @console = Logger.new($stdout) @logfile = Logger.new(logdev || TeeLogger.logdev, shift_age, shift_size) @level, @progname, @formatter, @datetime_format = nil configuration end define_logging_methods :debug define_logging_methods :info define_logging_methods :warn define_logging_methods :error define_logging_methods :fatal define_loglevel_check_methods :debug? define_loglevel_check_methods :info? define_loglevel_check_methods :warn? define_loglevel_check_methods :error? define_loglevel_check_methods :fatal? # @param level [Integer] def level=(level) @console.level = @logfile.level = @level = level end alias sev_threshold level alias sev_threshold= level= # @param name [String, Symbol] def progname=(name = nil) @console.progname = @logfile.progname = @progname = name end # @param formatter def formatter=(formatter) @console.formatter = @logfile.formatter = @formatter = formatter end # @param datetime_format def datetime_format=(datetime_format) @console.datetime_format = @logfile.datetime_format = @datetime_format = datetime_format end # @param logdev_name [String, Symbol] # @yield before logdev_name disable, after logdev_name enable. def disable(logdev_name) correct_name?(logdev_name) if block_given? disable(logdev_name) yield enable(logdev_name) else logdev_instance(logdev_name).formatter = FORMATTER_FOR_DISABLING end end # @param logdev_name [String, Symbol] def enable(logdev_name) correct_name?(logdev_name) logdev_instance(logdev_name).formatter = @formatter end private def configuration CONFIGURED_ATTRIBUTES.each do |method_name| value = TeeLogger.send(method_name) send("#{method_name}=", value) unless value.nil? end end def logging(name, progname, logdev_name = nil, &block) if logdev_name disable(logdev_name) { logging(name, progname, &block) } else @console.send(name, progname, &block) @logfile.send(name, progname, &block) end end end end