Sha256: 5dcfc86f5dc3dfaf72e4f5af7374f2f41c74511784efbfee7af5de4a696e051c

Contents?: true

Size: 1.84 KB

Versions: 20

Compression:

Stored size: 1.84 KB

Contents

# frozen_string_literal: true

# Released under the MIT License.
# Copyright, 2019-2022, by Samuel Williams.
# Copyright, 2021, by Bryan Powell.
# Copyright, 2021, by Robert Schulze.

require_relative 'output'
require_relative 'filter'
require_relative 'progress'

require_relative 'resolver'
require_relative 'terminal/logger'
require_relative 'serialized/logger'

require 'fiber/local'

module Console
	class Logger < Filter[debug: 0, info: 1, warn: 2, error: 3, fatal: 4]
		extend Fiber::Local
		
		# Set the default log level based on `$DEBUG` and `$VERBOSE`.
		# You can also specify CONSOLE_LEVEL=debug or CONSOLE_LEVEL=info in environment.
		# https://mislav.net/2011/06/ruby-verbose-mode/ has more details about how it all fits together.
		def self.default_log_level(env = ENV)
			if level = env['CONSOLE_LEVEL']
				LEVELS[level.to_sym] || level.to_i
			elsif $DEBUG
				DEBUG
			elsif $VERBOSE.nil?
				WARN
			else
				INFO
			end
		end
		
		# Controls verbose output using `$VERBOSE`.
		def self.verbose?(env = ENV)
			!$VERBOSE.nil? || env['CONSOLE_VERBOSE']
		end
		
		def self.default_logger(output = $stderr, env = ENV, **options)
			if options[:verbose].nil?
				options[:verbose] = self.verbose?(env)
			end
			
			if options[:level].nil?
				options[:level] = self.default_log_level(env)
			end
			
			output = Output.new(output, env, **options)
			logger = self.new(output, **options)
			
			Resolver.default_resolver(logger)
			
			return logger
		end
		
		def self.local
			self.default_logger
		end
		
		DEFAULT_LEVEL = 1
		
		def initialize(output, **options)
			super(output, **options)
		end
		
		def progress(subject, total, **options)
			Progress.new(self, subject, total, **options)
		end
		
		# @deprecated Use `fatal` instead.
		def failure(subject, exception, *arguments, &block)
			self.fatal(subject, exception, *arguments, &block)
		end
	end
end

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
console-1.24.0 lib/console/logger.rb
console-1.23.7 lib/console/logger.rb
console-1.23.6 lib/console/logger.rb
console-1.23.5 lib/console/logger.rb
console-1.23.4 lib/console/logger.rb
console-1.23.3 lib/console/logger.rb
console-1.23.2 lib/console/logger.rb
console-1.23.1 lib/console/logger.rb
console-1.23.0 lib/console/logger.rb
console-1.22.0 lib/console/logger.rb
console-1.21.0 lib/console/logger.rb
console-1.20.0 lib/console/logger.rb
console-1.19.0 lib/console/logger.rb
console-1.18.0 lib/console/logger.rb
console-1.17.4 lib/console/logger.rb
console-1.17.3 lib/console/logger.rb
console-1.17.2 lib/console/logger.rb
console-1.17.1 lib/console/logger.rb
console-1.17.0 lib/console/logger.rb
console-1.16.2 lib/console/logger.rb