Class: OpenAISwarm::Logger
- Inherits:
-
Object
- Object
- OpenAISwarm::Logger
- Defined in:
- lib/ruby-openai-swarm/logger.rb
Constant Summary collapse
- SEVERITY_COLORS =
{ 'DEBUG' => "\e[36m", # Cyan 'INFO' => "\e[32m", # Green 'WARN' => "\e[33m", # Yellow 'ERROR' => "\e[31m", # Red 'FATAL' => "\e[35m", # Purple 'ANY' => "\e[0m" # Reset color }.freeze
Class Method Summary collapse
Instance Method Summary collapse
-
#initialize ⇒ Logger
constructor
A new instance of Logger.
- #logger(log_path = nil) ⇒ Object
Constructor Details
#initialize ⇒ Logger
Returns a new instance of Logger.
19 20 21 |
# File 'lib/ruby-openai-swarm/logger.rb', line 19 def initialize @loggers = {} end |
Class Method Details
.instance ⇒ Object
15 16 17 |
# File 'lib/ruby-openai-swarm/logger.rb', line 15 def self.instance @instance ||= new end |
Instance Method Details
#logger(log_path = nil) ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 |
# File 'lib/ruby-openai-swarm/logger.rb', line 23 def logger(log_path = nil) return OpenAISwarm.configuration.logger if OpenAISwarm.configuration.logger return @loggers[log_path] if @loggers[log_path] path = determine_log_path(log_path) ensure_log_directory(path) logger = ::Logger.new(path) logger.formatter = proc do |severity, datetime, progname, msg| color = SEVERITY_COLORS[severity] || SEVERITY_COLORS['ANY'] reset = SEVERITY_COLORS['ANY'] "[#{datetime}] #{color}#{severity}#{reset} OpenAISwarm: #{msg}\n" end @loggers[log_path] = logger end |