2 # irb/workspace-binding.rb -
3 # $Release Version: 0.9.5$
5 # by Keiju ISHITSUKA(keiju@ruby-lang.org)
13 # create new workspace. set self to main if specified, otherwise
14 # inherit main from TOPLEVEL_BINDING.
16 if main[0].kind_of?(Binding)
18 elsif IRB.conf[:SINGLE_IRB]
19 @binding = TOPLEVEL_BINDING
21 case IRB.conf[:CONTEXT_MODE]
22 when 0 # binding in proc on TOPLEVEL_BINDING
23 @binding = eval("proc{binding}.call",
27 when 1 # binding in loaded file
29 f = Tempfile.open("irb-binding")
37 when 2 # binding in loaded file(thread use)
38 unless defined? BINDING_QUEUE
41 IRB.const_set("BINDING_QUEUE", SizedQueue.new(1))
42 Thread.abort_on_exception = true
44 eval "require \"irb/ws-for-case-2\"", TOPLEVEL_BINDING, __FILE__, __LINE__
48 @binding = BINDING_QUEUE.pop
50 when 3 # binging in function on TOPLEVEL_BINDING(default)
51 @binding = eval("def irb_binding; binding; end; irb_binding",
58 @main = eval("self", @binding)
61 IRB.conf[:__MAIN__] = @main
64 @binding = eval("IRB.conf[:__MAIN__].module_eval('binding', __FILE__, __LINE__)", @binding, __FILE__, __LINE__)
67 @binding = eval("IRB.conf[:__MAIN__].instance_eval('binding', __FILE__, __LINE__)", @binding, __FILE__, __LINE__)
69 IRB.fail CantChangeBinding, @main.inspect
73 eval("_=nil", @binding)
79 def evaluate(context, statements, file = __FILE__, line = __LINE__)
80 eval(statements, @binding, file, line)
83 # error message manipulator
84 def filter_backtrace(bt)
85 case IRB.conf[:CONTEXT_MODE]
87 return nil if bt =~ /\(irb_local_binding\)/
89 if(bt =~ %r!/tmp/irb-binding! or
90 bt =~ %r!irb/.*\.rb! or
95 return nil if bt =~ /irb\/.*\.rb/
96 return nil if bt =~ /irb\.rb/
98 return nil if bt =~ /irb\/.*\.rb/
99 return nil if bt =~ /irb\.rb/
100 bt.sub!(/:\s*in `irb_binding'/, '')
105 def IRB.delete_caller