Sha256: 998e79bece2f6f0ddc387b12422833f7e717cc40bb02f333a5e432846a0c2057

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.7.4 lib/semantic_logger/formatters.rb
semantic_logger-4.7.3 lib/semantic_logger/formatters.rb
semantic_logger-4.7.2 lib/semantic_logger/formatters.rb
semantic_logger-4.7.1 lib/semantic_logger/formatters.rb
semantic_logger-4.7.0 lib/semantic_logger/formatters.rb