Sha256: 124d57d44d9b43fff63549252fd923df8793315baa3ac79c39be4bf2a854abc8

Contents?: true

Size: 923 Bytes

Versions: 18

Compression:

Stored size: 923 Bytes

Contents

module Lograge
  module Formatters
    class LTSV
      def call(data)
        fields = fields_to_display(data)

        event = fields.map { |key| format(key, data[key]) }
        event.join("\t")
      end

      def fields_to_display(data)
        data.keys
      end

      def format(key, value)
        if key == :error
          # Exactly preserve the previous output
          # Parsing this can be ambigious if the error messages contains
          # a single quote
          value = "'#{escape value}'"
        elsif value.is_a? Float
          value = Kernel.format('%.2f', value)
        end

        "#{key}:#{value}"
      end

      private

      def escape(string)
        value = string.is_a?(String) ? string.dup : string.to_s

        value.gsub!('\\', '\\\\')
        value.gsub!('\n', '\\n')
        value.gsub!('\r', '\\r')
        value.gsub!('\t', '\\t')

        value
      end
    end
  end
end

Version data entries

18 entries across 18 versions & 1 rubygems

Version Path
lograge-0.11.2 lib/lograge/formatters/ltsv.rb
lograge-0.11.1 lib/lograge/formatters/ltsv.rb
lograge-0.11.0 lib/lograge/formatters/ltsv.rb
lograge-0.10.0 lib/lograge/formatters/ltsv.rb
lograge-0.9.0 lib/lograge/formatters/ltsv.rb
lograge-0.8.0 lib/lograge/formatters/ltsv.rb
lograge-0.7.1 lib/lograge/formatters/ltsv.rb
lograge-0.7.0 lib/lograge/formatters/ltsv.rb
lograge-0.6.0 lib/lograge/formatters/ltsv.rb
lograge-0.5.1 lib/lograge/formatters/ltsv.rb
lograge-0.5.0 lib/lograge/formatters/ltsv.rb
lograge-0.5.0.rc2 lib/lograge/formatters/ltsv.rb
lograge-0.5.0.rc1 lib/lograge/formatters/ltsv.rb
lograge-0.4.1 lib/lograge/formatters/ltsv.rb
lograge-0.4.0 lib/lograge/formatters/ltsv.rb
lograge-0.4.0.rc2 lib/lograge/formatters/ltsv.rb
lograge-0.4.0.rc1 lib/lograge/formatters/ltsv.rb
lograge-0.4.0.pre4 lib/lograge/formatters/ltsv.rb