Sha256: aa187f517ecbfd1924515e9006601f92e4af833440ee7ba070df4e203d4d3977
Contents?: true
Size: 1.26 KB
Versions: 3
Compression:
Stored size: 1.26 KB
Contents
# frozen_string_literal: true # Released under the MIT License. # Copyright, 2019-2024, by Samuel Williams. require_relative 'filter' module Console # A general sink which captures all events into a buffer. class Capture def initialize @buffer = [] @verbose = false end attr :buffer attr :verbose def last @buffer.last end def include?(pattern) JSON.dump(@buffer).include?(pattern) end def clear @buffer.clear end def empty? @buffer.empty? end def verbose!(value = true) @verbose = value end def verbose? @verbose end def call(subject = nil, *arguments, severity: UNKNOWN, event: nil, **options, &block) message = { time: ::Time.now.iso8601, severity: severity, **options, } if subject message[:subject] = subject end if event message[:event] = event.to_hash end if arguments.any? message[:arguments] = arguments end if annotation = Fiber.current.annotation message[:annotation] = annotation end if block_given? if block.arity.zero? message[:message] = yield else buffer = StringIO.new yield buffer message[:message] = buffer.string end end @buffer << message end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
console-1.25.2 | lib/console/capture.rb |
console-1.25.1 | lib/console/capture.rb |
console-1.25.0 | lib/console/capture.rb |