Sha256: 910cca3ca11a27f5c8fec5cd938f28dec751f1f589422196143b3f3cd4ba1ab5
Contents?: true
Size: 1.07 KB
Versions: 8
Compression:
Stored size: 1.07 KB
Contents
require 'logger' module Datadog # A custom logger with minor enhancements: # - progname defaults to ddtrace to clearly identify Datadog dd-trace-rb related messages # - adds last caller stack-trace info to know where the message comes from class Logger < ::Logger PREFIX = 'ddtrace'.freeze def initialize(*args, &block) super self.progname = PREFIX self.level = ::Logger::INFO end def add(severity, message = nil, progname = nil, &block) where = '' # We are in debug mode, or this is an error, add stack trace to help debugging if debug? || severity >= ::Logger::ERROR c = caller where = "(#{c[1]}) " if c.length > 1 end if message.nil? if block_given? super(severity, message, progname) do "[#{self.progname}] #{where}#{yield}" end else super(severity, message, "[#{self.progname}] #{where}#{progname}") end else super(severity, "[#{self.progname}] #{where}#{message}") end end alias log add end end
Version data entries
8 entries across 8 versions & 2 rubygems