Sha256: 2429b46025e203fe801260d43ffc082872f1b56699124ea96743a504f8f2fc0d

Contents?: true

Size: 1.02 KB

Versions: 10

Compression:

Stored size: 1.02 KB

Contents

# typed: ignore

# 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

10 entries across 10 versions & 1 rubygems

Version Path
sqreen-1.25.1 lib/sqreen/formatter_with_tid.rb
sqreen-1.25.0 lib/sqreen/formatter_with_tid.rb
sqreen-1.24.3 lib/sqreen/formatter_with_tid.rb
sqreen-1.24.2 lib/sqreen/formatter_with_tid.rb
sqreen-1.24.1 lib/sqreen/formatter_with_tid.rb
sqreen-1.24.0 lib/sqreen/formatter_with_tid.rb
sqreen-1.23.2 lib/sqreen/formatter_with_tid.rb
sqreen-1.23.1 lib/sqreen/formatter_with_tid.rb
sqreen-1.23.0 lib/sqreen/formatter_with_tid.rb
sqreen-1.22.1 lib/sqreen/formatter_with_tid.rb