Class: Codebeacon::Tracer::Logger

Inherits:
Object
  • Object
show all
Defined in:
lib/codebeacon/tracer/src/logger.rb

Constant Summary collapse

FILENAME =
"codebeacon_tracer.log"

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(level = nil) ⇒ Logger

Returns a new instance of Logger.



9
10
11
12
# File 'lib/codebeacon/tracer/src/logger.rb', line 9

def initialize(level = nil)
  level ||= Codebeacon::Tracer.config.debug? ? ::Logger::DEBUG : ::Logger::INFO
  @logger ||= ::Logger.new(File.join(Codebeacon::Tracer.config.data_dir, FILENAME), 3, 104857600, level: level)
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(method, *args, &block) ⇒ Object



23
24
25
26
27
28
29
# File 'lib/codebeacon/tracer/src/logger.rb', line 23

def method_missing(method, *args, &block)
  if @logger.respond_to?(method)
    @logger.send(method, *args, &block)
  else
    super
  end
end

Instance Attribute Details

#loggerObject (readonly)

Returns the value of attribute logger.



7
8
9
# File 'lib/codebeacon/tracer/src/logger.rb', line 7

def logger
  @logger
end

Instance Method Details

#debug(message, *args, &block) ⇒ Object



18
19
20
21
# File 'lib/codebeacon/tracer/src/logger.rb', line 18

def debug(message, *args, &block)
  return unless Codebeacon::Tracer.config.debug?
  @logger.debug(message, *args, &block)
end

#newProgressLogger(*args) ⇒ Object



14
15
16
# File 'lib/codebeacon/tracer/src/logger.rb', line 14

def newProgressLogger(*args)
  ProgressLogger.new(@logger, *args)
end

#respond_to_missing?(method, include_private = false) ⇒ Boolean

Returns:

  • (Boolean)


31
32
33
# File 'lib/codebeacon/tracer/src/logger.rb', line 31

def respond_to_missing?(method, include_private = false)
  @logger.respond_to?(method, include_private) || super
end