Sha256: bd78b6738e1b8e298377fdc7da6cfa535e16679fd31373bb97af612262aa1a0d

Contents?: true

Size: 1.02 KB

Versions: 29

Compression:

Stored size: 1.02 KB

Contents

# typed: true

# Copyright (c) 2015 Sqreen. All Rights Reserved.
# Please refer to our terms for more information: https://www.sqreen.com/terms.html

require 'sqreen/log'

module Sqreen
  # Ruby default formatter modified to display current thread_id
  class FormatterWithTid
    # TODO: constant name
    Format = "%s, [%s#%d.%s] %5s -- %s: %s\n".freeze
    DatetimeFormat = '%Y-%m-%dT%H:%M:%S.%6N '.freeze

    attr_accessor :datetime_format

    def initialize
      @datetime_format = nil
    end

    def call(severity, time, progname, msg)
      format(
        Format,
        severity[0..0], format_datetime(time), $$,
        Thread.current.object_id.to_s(36),
        severity, progname, msg2str(msg),
      )
    end

    private

    def format_datetime(time)
      time.strftime(DatetimeFormat)
    end

    def msg2str(msg)
      case msg
      when ::String
        msg
      when ::Exception
        "#{msg.message} (#{msg.class})\n" << (msg.backtrace || []).join("\n")
      else
        msg.inspect
      end
    end
  end
end

Version data entries

29 entries across 29 versions & 1 rubygems

Version Path
sqreen-1.22.0-java lib/sqreen/formatter_with_tid.rb
sqreen-1.22.0 lib/sqreen/formatter_with_tid.rb
sqreen-1.21.1-java lib/sqreen/formatter_with_tid.rb
sqreen-1.21.1 lib/sqreen/formatter_with_tid.rb
sqreen-1.21.0-java lib/sqreen/formatter_with_tid.rb
sqreen-1.21.0 lib/sqreen/formatter_with_tid.rb
sqreen-1.20.4-java lib/sqreen/formatter_with_tid.rb
sqreen-1.20.4 lib/sqreen/formatter_with_tid.rb
sqreen-1.21.0.beta3-java lib/sqreen/formatter_with_tid.rb
sqreen-1.21.0.beta3 lib/sqreen/formatter_with_tid.rb
sqreen-1.20.4.beta1 lib/sqreen/formatter_with_tid.rb
sqreen-1.19.4 lib/sqreen/formatter_with_tid.rb
sqreen-1.20.3 lib/sqreen/formatter_with_tid.rb
sqreen-1.20.2 lib/sqreen/formatter_with_tid.rb
sqreen-1.21.0.beta2 lib/sqreen/formatter_with_tid.rb
sqreen-1.21.0.beta1 lib/sqreen/formatter_with_tid.rb
sqreen-1.20.1-java lib/sqreen/formatter_with_tid.rb
sqreen-1.20.1 lib/sqreen/formatter_with_tid.rb
sqreen-1.20.0-java lib/sqreen/formatter_with_tid.rb
sqreen-1.20.0 lib/sqreen/formatter_with_tid.rb