Module: Kernel

Defined in:
lib/active_support/core_ext/kernel/concern.rb,
lib/active_support/core_ext/kernel/debugger.rb,
lib/active_support/core_ext/kernel/reporting.rb,
lib/active_support/core_ext/kernel/singleton_class.rb

Instance Method Summary collapse

Instance Method Details

#capture(stream) ⇒ Object Also known as: silence

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"


89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 89

def capture(stream)
  ActiveSupport::Deprecation.warn(
    "`#capture(stream)` is deprecated and will be removed in the next release."
  ) #not thread-safe
  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

#class_eval(*args, &block) ⇒ Object

class_eval on an object acts like singleton_class.class_eval.



3
4
5
# File 'lib/active_support/core_ext/kernel/singleton_class.rb', line 3

def class_eval(*args, &block)
  singleton_class.class_eval(*args, &block)
end

#concern(topic, &module_definition) ⇒ Object

A shortcut to define a toplevel concern, not within a module.

See Module::Concerning for more.



7
8
9
# File 'lib/active_support/core_ext/kernel/concern.rb', line 7

def concern(topic, &module_definition)
  Object.concern topic, &module_definition
end

#debuggerObject Also known as: breakpoint

Starts a debugging session if the debugger gem 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
  message = "\n***** Debugger requested, but was not available (ensure the debugger gem is listed in Gemfile/installed as gem): Start server with --debugger to enable *****\n"
  defined?(Rails.logger) ? Rails.logger.info(message) : $stderr.puts(message)
end

#enable_warningsObject

Sets $VERBOSE to true for the duration of the block and back to its original value afterwards.



20
21
22
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 20

def enable_warnings
  with_warnings(true) { yield }
end

#quietlyObject

Silences both STDOUT and STDERR, even for subprocesses.

quietly { system 'bundle install' }

This method is not thread-safe.



115
116
117
118
119
120
121
122
123
124
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 115

def quietly
  ActiveSupport::Deprecation.warn(
    "`#quietly` is deprecated and will be removed in the next release."
  ) #not thread-safe
  silence_stream(STDOUT) do
    silence_stream(STDERR) do
      yield
    end
  end
end

#silence_stderrObject

For compatibility



34
35
36
37
38
39
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 34

def silence_stderr #:nodoc:
  ActiveSupport::Deprecation.warn(
    "`#silence_stderr` is deprecated and will be removed in the next release."
  ) #not thread-safe
  silence_stream(STDERR) { yield }
end

#silence_stream(stream) ⇒ Object

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.



51
52
53
54
55
56
57
58
59
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 51

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_warningsObject

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


14
15
16
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 14

def silence_warnings
  with_warnings(nil) { yield }
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'


69
70
71
72
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 69

def suppress(*exception_classes)
  yield
rescue *exception_classes
end

#with_warnings(flag) ⇒ Object

Sets $VERBOSE for the duration of the block and back to its original value afterwards.



26
27
28
29
30
31
# File 'lib/active_support/core_ext/kernel/reporting.rb', line 26

def with_warnings(flag)
  old_verbose, $VERBOSE = $VERBOSE, flag
  yield
ensure
  $VERBOSE = old_verbose
end