Module: Kernel
- Defined in:
- lib/active_support/core_ext/kernel/debugger.rb,
lib/active_support/core_ext/kernel/requires.rb,
lib/active_support/core_ext/kernel/reporting.rb,
lib/active_support/core_ext/kernel/singleton_class.rb
Instance Method Summary collapse
- #breakpoint ⇒ Object
-
#capture(stream) ⇒ Object
(also: #silence)
Captures the given stream and returns it:.
-
#class_eval(*args, &block) ⇒ Object
class_eval on an object acts like singleton_class.class_eval.
-
#debugger ⇒ Object
Starts a debugging session if ruby-debug has been loaded (call rails server –debugger to do load it).
-
#enable_warnings ⇒ Object
Sets $VERBOSE to true for the duration of the block and back to its original value afterwards.
-
#quietly ⇒ Object
Silences both STDOUT and STDERR, even for subprocesses.
-
#require_library_or_gem(library_name) ⇒ Object
Require a library with fallback to RubyGems.
-
#silence_stderr ⇒ Object
For compatibility.
-
#silence_stream(stream) ⇒ Object
Silences any stream for the duration of the block.
-
#silence_warnings ⇒ Object
Sets $VERBOSE to nil for the duration of the block and back to its original value afterwards.
-
#singleton_class ⇒ Object
Returns the object’s singleton class.
-
#suppress(*exception_classes) ⇒ Object
Blocks and ignores any exception passed as argument if raised within the block.
-
#with_warnings(flag) ⇒ Object
Sets $VERBOSE for the duration of the block and back to its original value afterwards.
Instance Method Details
#breakpoint ⇒ Object
11 12 13 14 15 |
# File 'lib/active_support/core_ext/kernel/debugger.rb', line 11 def breakpoint = "\n***** The 'breakpoint' command has been renamed 'debugger' -- please change *****\n" defined?(Rails) ? Rails.logger.info() : $stderr.puts() debugger end |
#capture(stream) ⇒ Object Also known as: silence
Captures the given stream and returns it:
stream = capture(:stdout) { puts "Cool" }
stream # => "Cool\n"
68 69 70 71 72 73 74 75 76 77 78 79 |
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 68 def capture(stream) begin stream = stream.to_s eval "$#{stream} = StringIO.new" yield result = eval("$#{stream}").string ensure eval("$#{stream} = #{stream.upcase}") end result end |
#class_eval(*args, &block) ⇒ Object
class_eval on an object acts like singleton_class.class_eval.
10 11 12 |
# File 'lib/active_support/core_ext/kernel/singleton_class.rb', line 10 def class_eval(*args, &block) singleton_class.class_eval(*args, &block) end |
#debugger ⇒ Object
Starts a debugging session if ruby-debug has been loaded (call rails server –debugger to do load it).
4 5 6 7 |
# File 'lib/active_support/core_ext/kernel/debugger.rb', line 4 def debugger = "\n***** Debugger requested, but was not available (ensure ruby-debug is listed in Gemfile/installed as gem): Start server with --debugger to enable *****\n" defined?(Rails) ? Rails.logger.info() : $stderr.puts() end |
#enable_warnings ⇒ Object
Sets $VERBOSE to true for the duration of the block and back to its original value afterwards.
15 16 17 |
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 15 def enable_warnings with_warnings(true) { yield } end |
#quietly ⇒ Object
Silences both STDOUT and STDERR, even for subprocesses.
quietly { system 'bundle install' }
86 87 88 89 90 91 92 |
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 86 def quietly silence_stream(STDOUT) do silence_stream(STDERR) do yield end end end |
#require_library_or_gem(library_name) ⇒ Object
Require a library with fallback to RubyGems. Warnings during library loading are silenced to increase signal/noise for application warnings.
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
# File 'lib/active_support/core_ext/kernel/requires.rb', line 7 def require_library_or_gem(library_name) silence_warnings do begin require library_name rescue LoadError => cannot_require # 1. Requiring the module is unsuccessful, maybe it's a gem and nobody required rubygems yet. Try. begin require 'rubygems' rescue LoadError # => rubygems_not_installed raise cannot_require end # 2. Rubygems is installed and loaded. Try to load the library again begin require library_name rescue LoadError # => gem_not_installed raise cannot_require end end end end |
#silence_stderr ⇒ Object
For compatibility
28 29 30 |
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 28 def silence_stderr #:nodoc: silence_stream(STDERR) { yield } end |
#silence_stream(stream) ⇒ Object
Silences any stream for the duration of the block.
silence_stream(STDOUT) do
puts 'This will never be seen'
end
puts 'But this will'
39 40 41 42 43 44 45 46 |
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 39 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) end |
#silence_warnings ⇒ Object
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
10 11 12 |
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 10 def silence_warnings with_warnings(nil) { yield } end |
#singleton_class ⇒ Object
Returns the object’s singleton class.
3 4 5 6 7 |
# File 'lib/active_support/core_ext/kernel/singleton_class.rb', line 3 def singleton_class class << self self end end |
#suppress(*exception_classes) ⇒ Object
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"
56 57 58 59 60 61 |
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 56 def suppress(*exception_classes) begin yield rescue Exception => e raise unless exception_classes.any? { |cls| e.kind_of?(cls) } end end |
#with_warnings(flag) ⇒ Object
Sets $VERBOSE for the duration of the block and back to its original value afterwards.
20 21 22 23 24 25 |
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 20 def with_warnings(flag) old_verbose, $VERBOSE = $VERBOSE, flag yield ensure $VERBOSE = old_verbose end |