Sha256: cfbaffe559c698ad3b8aceb0ecdf705bc4c2fa452f200068f081afdbe9823241

Contents?: true

Size: 717 Bytes

Versions: 8

Compression:

Stored size: 717 Bytes

Contents

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

        event = fields.map { |key| format(key, data[key]) }
        event.join(' ')
      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 = "'#{value}'"
        else
          # Ensure that we always have exactly two decimals
          value = Kernel.format('%.2f', value) if value.is_a? Float
        end

        "#{key}=#{value}"
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
lograge-0.4.0.pre2 lib/lograge/formatters/key_value.rb
lograge-0.4.0.pre lib/lograge/formatters/key_value.rb
lograge-0.3.6 lib/lograge/formatters/key_value.rb
lograge-0.3.5 lib/lograge/formatters/key_value.rb
lograge-0.3.4 lib/lograge/formatters/key_value.rb
lograge-0.3.3 lib/lograge/formatters/key_value.rb
lograge-0.3.2 lib/lograge/formatters/key_value.rb
lograge-0.3.1 lib/lograge/formatters/key_value.rb