Sha256: c0cad5178c7caf33e195222c12b30d86a5259b75b1b717dbf98ed0636bcd40f0

Contents?: true

Size: 1.45 KB

Versions: 5

Compression:

Stored size: 1.45 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'
    autoload :Fluentd,          'semantic_logger/formatters/fluentd'
    # @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

5 entries across 5 versions & 1 rubygems

Version Path
semantic_logger-4.6.1 lib/semantic_logger/formatters.rb
semantic_logger-4.6.0 lib/semantic_logger/formatters.rb
semantic_logger-4.6.0.beta1 lib/semantic_logger/formatters.rb
semantic_logger-4.5.0 lib/semantic_logger/formatters.rb
semantic_logger-4.4.0 lib/semantic_logger/formatters.rb