Sha256: 36da408cd8f30e1f61474f33bcbf4ecdabfbc618f35801f62d6215bd514e0b28

Contents?: true

Size: 1.38 KB

Versions: 4

Compression:

Stored size: 1.38 KB

Contents

module SemanticLogger
  module Formatters
    # @formatter:off
    autoload :Base,             'semantic_logger/formatters/base'
    autoload :Color,            'semantic_logger/formatters/color'
    autoload :Default,          'semantic_logger/formatters/default'
    autoload :Json,             'semantic_logger/formatters/json'
    autoload :Raw,              'semantic_logger/formatters/raw'
    autoload :OneLine,          'semantic_logger/formatters/one_line'
    autoload :Signalfx,         'semantic_logger/formatters/signalfx'
    autoload :Syslog,           'semantic_logger/formatters/syslog'
    # @formatter:on

    # Return formatter that responds to call.
    #
    # Supports formatter supplied as:
    # - Symbol
    # - Hash ( Symbol => { options })
    # - Instance of any of SemanticLogger::Formatters
    # - Proc
    # - Any object that responds to :call
    def self.factory(formatter)
      if formatter.is_a?(Symbol)
        SemanticLogger::Utils.constantize_symbol(formatter, 'SemanticLogger::Formatters').new
      elsif formatter.is_a?(Hash) && formatter.size.positive?
        fmt, options = formatter.first
        SemanticLogger::Utils.constantize_symbol(fmt.to_sym, 'SemanticLogger::Formatters').new(options)
      elsif formatter.respond_to?(:call)
        formatter
      else
        raise(ArgumentError, "Unknown formatter: #{formatter.inspect}")
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
semantic_logger-4.3.1 lib/semantic_logger/formatters.rb
semantic_logger-4.3.0 lib/semantic_logger/formatters.rb
semantic_logger-4.2.2 lib/semantic_logger/formatters.rb
semantic_logger-4.2.1 lib/semantic_logger/formatters.rb