You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
cryptcheck/lib/cryptcheck/logger.rb

39 lines
848 B

8 years ago
module CryptCheck
class Logger
6 years ago
LEVELS = %i(trace debug info warning error fatal none)
8 years ago
def self.level=(level)
@@level = level.to_sym
8 years ago
end
self.level = ENV.fetch 'LOG', :info
8 years ago
def self.log(level, string=nil, output: $stdout, &block)
return unless enabled? level
output.puts(string ? string : block.call)
end
6 years ago
if Object.respond_to? :ai
def self.ap(name, object)
self.debug { "#{name} : #{object.ai}" }
end
else
def self.ap(name, object)
self.debug { "#{name} : #{object}" }
end
end
8 years ago
LEVELS.each do |level|
class_eval <<-RUBY_EVAL, __FILE__, __LINE__ + 1
def self.#{level}(string=nil, output: $stdout, &block)
self.log :#{level}, string, output: output, &block
end
RUBY_EVAL
end
private
def self.enabled?(level)
LEVELS.index(level) >= LEVELS.index(@@level)
end
end
end