# Copyright, 2017, by Samuel G. D. Williams. <http://www.codeotaku.com># # Permission is hereby granted, free of charge, to any person obtaining a copy# of this software and associated documentation files (the "Software"), to deal# in the Software without restriction, including without limitation the rights# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell# copies of the Software, and to permit persons to whom the Software is# furnished to do so, subject to the following conditions:# # The above copyright notice and this permission notice shall be included in# all copies or substantial portions of the Software.# # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN# THE SOFTWARE.require_relative'buffer'moduleConsoleUNKNOWN='unknown'classFilterdefself.[]**levelsklass=Class.new(self)klass.instance_execdoconst_set(:LEVELS,levels)const_set(:MAXIMUM_LEVEL,levels.values.max)levels.eachdo|name,level|const_set(name.to_s.upcase,level)define_method(name)do|subject=nil,*arguments,**options,&block|enabled=@subjects[subject.class]ifenabled==trueor(enabled!=falseandlevel>=@level)self.call(subject,*arguments,severity: name,**options,**@options,&block)endenddefine_method("#{name}!")do@level=levelenddefine_method("#{name}?")do@level>=levelendendendreturnklassenddefinitialize(output,verbose: true,level: self.class::DEFAULT_LEVEL,**options)@output=output@verbose=verbose@level=level@subjects={}@options=optionsenddefwith(level: @level,verbose: @verbose,**options)dup.tapdo|logger|logger.level=levellogger.verbose!ifverboselogger.options=@options.merge(options)endendattr_accessor:outputattr:verboseattr:levelattr:subjectsattr_accessor:optionsdeflevel=leveliflevel.is_a?Symbol@level=self.class::LEVELS[level]else@level=levelendenddefverbose!(value=true)@verbose=value@output.verbose!(value)enddefoff!@level=-1enddefall!@level=self.class::MAXIMUM_LEVELenddefenabled?(subject)@subjects[subject.class]==trueenddefenable(subject)@subjects[subject.class]=trueenddefdisable(subject)@subjects[subject.class]=falseenddefcall(*arguments,&block)@output.call(*arguments,&block)endendend