Class: IRB::WorkSpace
- Defined in:
- lib/irb/workspace.rb,
 lib/irb/ext/tracer.rb
Instance Attribute Summary collapse
- 
  
    
      #binding  ⇒ Object 
    
    
  
  
  
  
    
      readonly
    
    
  
  
  
  
  
  
    The Binding of this workspace. 
- 
  
    
      #main  ⇒ Object 
    
    
  
  
  
  
    
      readonly
    
    
  
  
  
  
  
  
    The top-level workspace of this context, also available as IRB.conf[:__MAIN__].
Instance Method Summary collapse
- 
  
    
      #__evaluate__  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Evaluate the given statementswithin the context of this workspace.
- #code_around_binding ⇒ Object
- 
  
    
      #evaluate(statements, file = __FILE__, line = __LINE__)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Evaluate the context of this workspace and use the Tracer library to output the exact lines of code are being executed in chronological order. 
- 
  
    
      #filter_backtrace(bt)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    error message manipulator WARN: Rails patches this method to filter its own backtrace. 
- 
  
    
      #initialize(*main)  ⇒ WorkSpace 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    Creates a new workspace. 
- #load_helper_methods_to_main ⇒ Object
- #local_variable_get(name) ⇒ Object
- #local_variable_set(name, value) ⇒ Object
Constructor Details
#initialize(*main) ⇒ WorkSpace
Creates a new workspace.
set self to main if specified, otherwise inherit main from TOPLEVEL_BINDING.
| 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 | # File 'lib/irb/workspace.rb', line 16 def initialize(*main) if Binding === main[0] @binding = main.shift elsif IRB.conf[:SINGLE_IRB] @binding = TOPLEVEL_BINDING else case IRB.conf[:CONTEXT_MODE] when 0 # binding in proc on TOPLEVEL_BINDING @binding = eval("proc{binding}.call", TOPLEVEL_BINDING, __FILE__, __LINE__) when 1 # binding in loaded file require "tempfile" f = Tempfile.open("irb-binding") f.print <<EOF $binding = binding EOF f.close load f.path @binding = $binding when 2 # binding in loaded file(thread use) unless defined? BINDING_QUEUE IRB.const_set(:BINDING_QUEUE, Thread::SizedQueue.new(1)) Thread.abort_on_exception = true Thread.start do eval "require \"irb/ws-for-case-2\"", TOPLEVEL_BINDING, __FILE__, __LINE__ end Thread.pass end @binding = BINDING_QUEUE.pop when 3 # binding in function on TOPLEVEL_BINDING @binding = eval("self.class.remove_method(:irb_binding) if defined?(irb_binding); private; def irb_binding; binding; end; irb_binding", TOPLEVEL_BINDING, __FILE__, __LINE__ - 3) when 4 # binding is a copy of TOPLEVEL_BINDING (default) # Note that this will typically be IRB::TOPLEVEL_BINDING # This is to avoid RubyGems' local variables (see issue #17623) @binding = TOPLEVEL_BINDING.dup end end if main.empty? @main = eval("self", @binding) else @main = main[0] end IRB.conf[:__MAIN__] = @main unless main.empty? case @main when Module @binding = eval("::IRB.conf[:__MAIN__].module_eval('::Kernel.binding', __FILE__, __LINE__)", @binding, __FILE__, __LINE__) else begin @binding = eval("::IRB.conf[:__MAIN__].instance_eval('::Kernel.binding', __FILE__, __LINE__)", @binding, __FILE__, __LINE__) rescue TypeError fail CantChangeBinding, @main.inspect end end end @binding.local_variable_set(:_, nil) end | 
Instance Attribute Details
#binding ⇒ Object (readonly)
The Binding of this workspace
| 85 86 87 | # File 'lib/irb/workspace.rb', line 85 def binding @binding end | 
#main ⇒ Object (readonly)
The top-level workspace of this context, also available as IRB.conf[:__MAIN__]
| 88 89 90 | # File 'lib/irb/workspace.rb', line 88 def main @main end | 
Instance Method Details
#__evaluate__ ⇒ Object
Evaluate the given statements within the  context of this workspace.
| 24 25 26 | # File 'lib/irb/ext/tracer.rb', line 24 def evaluate(statements, file = __FILE__, line = __LINE__) eval(statements, @binding, file, line) end | 
#code_around_binding ⇒ Object
| 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 | # File 'lib/irb/workspace.rb', line 128 def code_around_binding file, pos = @binding.source_location if defined?(::SCRIPT_LINES__[file]) && lines = ::SCRIPT_LINES__[file] code = ::SCRIPT_LINES__[file].join('') else begin code = File.read(file) rescue SystemCallError return end end lines = Color.colorize_code(code).lines pos -= 1 start_pos = [pos - 5, 0].max end_pos = [pos + 5, lines.size - 1].min line_number_fmt = Color.colorize("%#{end_pos.to_s.length}d", [:BLUE, :BOLD]) fmt = " %2s #{line_number_fmt}: %s" body = (start_pos..end_pos).map do |current_pos| sprintf(fmt, pos == current_pos ? '=>' : '', current_pos + 1, lines[current_pos]) end.join("") "\nFrom: #{file} @ line #{pos + 1} :\n\n#{body}#{Color.clear}\n" end | 
#evaluate(statements, file = __FILE__, line = __LINE__) ⇒ Object
Evaluate the context of this workspace and use the Tracer library to output the exact lines of code are being executed in chronological order.
See github.com/ruby/tracer for more information.
| 100 101 102 | # File 'lib/irb/workspace.rb', line 100 def evaluate(statements, file = __FILE__, line = __LINE__) eval(statements, @binding, file, line) end | 
#filter_backtrace(bt) ⇒ Object
error message manipulator WARN: Rails patches this method to filter its own backtrace. Be cautious when changing it. See: github.com/rails/rails/blob/main/railties/lib/rails/commands/console/console_command.rb#L8:~:text=def,filter_backtrace
| 115 116 117 118 119 120 121 122 123 124 125 126 | # File 'lib/irb/workspace.rb', line 115 def filter_backtrace(bt) return nil if bt =~ /\/irb\/.*\.rb/ return nil if bt =~ /\/irb\.rb/ return nil if bt =~ /tool\/lib\/.*\.rb|runner\.rb/ # for tests in Ruby repository case IRB.conf[:CONTEXT_MODE] when 1 return nil if bt =~ %r!/tmp/irb-binding! when 3 bt = bt.sub(/:\s*in `irb_binding'/, '') end bt end | 
#load_helper_methods_to_main ⇒ Object
| 90 91 92 93 94 95 96 97 | # File 'lib/irb/workspace.rb', line 90 def load_helper_methods_to_main # Do not load helper methods to frozen objects and BasicObject return unless Object === @main && !@main.frozen? ancestors = class<<main;ancestors;end main.extend ExtendCommandBundle if !ancestors.include?(ExtendCommandBundle) main.extend HelpersContainer if !ancestors.include?(HelpersContainer) end | 
#local_variable_get(name) ⇒ Object
| 108 109 110 | # File 'lib/irb/workspace.rb', line 108 def local_variable_get(name) @binding.local_variable_get(name) end | 
#local_variable_set(name, value) ⇒ Object
| 104 105 106 | # File 'lib/irb/workspace.rb', line 104 def local_variable_set(name, value) @binding.local_variable_set(name, value) end |