module Kernel
Public Instance Methods
capture(stream) { || ... }
click to toggle source
Captures the given stream and returns it:
stream = capture(:stdout) { puts 'notice' } stream # => "notice\n" stream = capture(:stderr) { warn 'error' } stream # => "error\n"
even for subprocesses:
stream = capture(:stdout) { system('echo notice') } stream # => "notice\n" stream = capture(:stderr) { system('echo error 1>&2') } stream # => "error\n"
# File lib/fedux_org_stdlib/core_ext/kernel/reporting.rb, line 85 def capture(stream) stream = stream.to_s captured_stream = Tempfile.new(stream) stream_io = eval("$#{stream}") origin_stream = stream_io.dup stream_io.reopen(captured_stream) yield stream_io.rewind return captured_stream.read ensure captured_stream.close captured_stream.unlink stream_io.reopen(origin_stream) end
Also aliased as: silence
enable_warnings() { || ... }
click to toggle source
Sets $VERBOSE to true
for the duration of the block and back to its original value afterwards.
# File lib/fedux_org_stdlib/core_ext/kernel/reporting.rb, line 19 def enable_warnings with_warnings(true) { yield } end
quietly() { || ... }
click to toggle source
Silences both STDOUT and STDERR, even for subprocesses.
quietly { system 'bundle install' }
This method is not thread-safe.
# File lib/fedux_org_stdlib/core_ext/kernel/reporting.rb, line 108 def quietly silence_stream(STDOUT) do silence_stream(STDERR) do yield end end end
silence_stream(stream) { || ... }
click to toggle source
Deprecated : this method is not thread safe Silences any stream for the duration of the block.
silence_stream(STDOUT) do puts 'This will never be seen' end puts 'But this will'
This method is not thread-safe.
# File lib/fedux_org_stdlib/core_ext/kernel/reporting.rb, line 47 def silence_stream(stream) old_stream = stream.dup stream.reopen(RbConfig::CONFIG['host_os'] =~ /mswin|mingw/ ? 'NUL:' : '/dev/null') stream.sync = true yield ensure stream.reopen(old_stream) old_stream.close end
silence_warnings() { || ... }
click to toggle source
Sets $VERBOSE to nil for the duration of the block and back to its original value afterwards.
silence_warnings do value = noisy_call # no warning voiced end noisy_call # warning voiced
# File lib/fedux_org_stdlib/core_ext/kernel/reporting.rb, line 13 def silence_warnings with_warnings(nil) { yield } end
suppress(*exception_classes) { || ... }
click to toggle source
Blocks and ignores any exception passed as argument if raised within the block.
suppress(ZeroDivisionError) do 1/0 puts 'This code is NOT reached' end puts 'This code gets executed and nothing related to ZeroDivisionError was seen'
# File lib/fedux_org_stdlib/core_ext/kernel/reporting.rb, line 65 def suppress(*exception_classes) yield rescue *exception_classes end
with_warnings(flag) { || ... }
click to toggle source
Sets $VERBOSE for the duration of the block and back to its original value afterwards.
# File lib/fedux_org_stdlib/core_ext/kernel/reporting.rb, line 25 def with_warnings(flag) old_verbose, $VERBOSE = $VERBOSE, flag yield ensure $VERBOSE = old_verbose end