class Console::Serialized::Logger

def call(subject = nil, *arguments, severity: UNKNOWN, &block)

def call(subject = nil, *arguments, severity: UNKNOWN, &block)
	message = {
		time: Time.now.iso8601,
		severity: severity,
	}
	
	if subject
		message[:subject] = subject
	end
	
	if arguments.any?
		message[:arguments] = arguments
	end
	
	if block_given?
		if block.arity.zero?
			message[:message] = yield
		else
			buffer = StringIO.new
			yield buffer
			message[:message] = buffer.string
		end
	end
	
	@io.puts(@format.dump(message))
end

def initialize(io = $stderr, format: JSON)

def initialize(io = $stderr, format: JSON)
	@io = io
	@start = Time.now
	@format = format
end

def verbose!(value = true)

def verbose!(value = true)
end