diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/irb/context.rb | 12 | ||||
-rw-r--r-- | lib/irb/inspector.rb | 122 |
2 files changed, 67 insertions, 67 deletions
diff --git a/lib/irb/context.rb b/lib/irb/context.rb index cd191d253e..43d5364b4f 100644 --- a/lib/irb/context.rb +++ b/lib/irb/context.rb @@ -286,7 +286,7 @@ module IRB # +nil+:: inspect mode in non-math mode, # non-inspect mode in math mode # - # See IRB::INSPECTORS for more information. + # See IRB::Inspector for more information. # # Can also be set using the +--inspect+ and +--noinspect+ command line # options. @@ -294,16 +294,16 @@ module IRB # See IRB@Command+line+options for more command line options. def inspect_mode=(opt) - if i = INSPECTORS[opt] + if i = Inspector::INSPECTORS[opt] @inspect_mode = opt @inspect_method = i i.init else case opt when nil - if INSPECTORS.keys_with_inspector(INSPECTORS[true]).include?(@inspect_mode) + if Inspector.keys_with_inspector(Inspector::INSPECTORS[true]).include?(@inspect_mode) self.inspect_mode = false - elsif INSPECTORS.keys_with_inspector(INSPECTORS[false]).include?(@inspect_mode) + elsif Inspector.keys_with_inspector(Inspector::INSPECTORS[false]).include?(@inspect_mode) self.inspect_mode = true else puts "Can't switch inspect mode." @@ -322,10 +322,10 @@ module IRB when Inspector prefix = "usr%d" i = 1 - while INSPECTORS[format(prefix, i)]; i += 1; end + while Inspector::INSPECTORS[format(prefix, i)]; i += 1; end @inspect_mode = format(prefix, i) @inspect_method = opt - INSPECTORS.def_inspector(format(prefix, i), @inspect_method) + Inspector.def_inspector(format(prefix, i), @inspect_method) else puts "Can't switch inspect mode(#{opt})." return diff --git a/lib/irb/inspector.rb b/lib/irb/inspector.rb index 94f42d5217..121309f3c6 100644 --- a/lib/irb/inspector.rb +++ b/lib/irb/inspector.rb @@ -41,6 +41,62 @@ module IRB # :nodoc: # irb(main):001:0> "what?" #=> omg! what? # class Inspector + # Default inspectors available to irb, this includes: + # + # +:pp+:: Using Kernel#pretty_inspect + # +:yaml+:: Using YAML.dump + # +:marshal+:: Using Marshal.dump + INSPECTORS = {} + + # Determines the inspector to use where +inspector+ is one of the keys passed + # during inspector definition. + def self.keys_with_inspector(inspector) + select{|k,v| v == inspector}.collect{|k, v| k} + end + + # Example + # + # Inspector.def_inspector(key, init_p=nil){|v| v.inspect} + # Inspector.def_inspector([key1,..], init_p=nil){|v| v.inspect} + # Inspector.def_inspector(key, inspector) + # Inspector.def_inspector([key1,...], inspector) + def self.def_inspector(key, arg=nil, &block) + # if !block_given? + # case arg + # when nil, Proc + # inspector = IRB::Inspector(init_p) + # when Inspector + # inspector = init_p + # else + # IRB.Raise IllegalParameter, init_p + # end + # init_p = nil + # else + # inspector = IRB::Inspector(block, init_p) + # end + + if block_given? + inspector = IRB::Inspector(block, arg) + else + inspector = arg + end + + case key + when Array + for k in key + def_inspector(k, inspector) + end + when Symbol + INSPECTORS[key] = inspector + INSPECTORS[key.to_s] = inspector + when String + INSPECTORS[key] = inspector + INSPECTORS[key.intern] = inspector + else + INSPECTORS[key] = inspector + end + end + # Creates a new inspector object, using the given +inspect_proc+ when # output return values in irb. def initialize(inspect_proc, init_proc = nil) @@ -60,72 +116,16 @@ module IRB # :nodoc: end end - # Default inspectors available to irb, this includes: - # - # +:pp+:: Using Kernel#pretty_inspect - # +:yaml+:: Using YAML.dump - # +:marshal+:: Using Marshal.dump - INSPECTORS = {} - - # Determines the inspector to use where +inspector+ is one of the keys passed - # during inspector definition. - def INSPECTORS.keys_with_inspector(inspector) - select{|k,v| v == inspector}.collect{|k, v| k} - end - - # Example - # - # INSPECTORS.def_inspector(key, init_p=nil){|v| v.inspect} - # INSPECTORS.def_inspector([key1,..], init_p=nil){|v| v.inspect} - # INSPECTORS.def_inspector(key, inspector) - # INSPECTORS.def_inspector([key1,...], inspector) - def INSPECTORS.def_inspector(key, arg=nil, &block) -# if !block_given? -# case arg -# when nil, Proc -# inspector = IRB::Inspector(init_p) -# when Inspector -# inspector = init_p -# else -# IRB.Raise IllegalParameter, init_p -# end -# init_p = nil -# else -# inspector = IRB::Inspector(block, init_p) -# end - - if block_given? - inspector = IRB::Inspector(block, arg) - else - inspector = arg - end - - case key - when Array - for k in key - def_inspector(k, inspector) - end - when Symbol - self[key] = inspector - self[key.to_s] = inspector - when String - self[key] = inspector - self[key.intern] = inspector - else - self[key] = inspector - end - end - - INSPECTORS.def_inspector([false, :to_s, :raw]){|v| v.to_s} - INSPECTORS.def_inspector([true, :p, :inspect]){|v| + Inspector.def_inspector([false, :to_s, :raw]){|v| v.to_s} + Inspector.def_inspector([true, :p, :inspect]){|v| begin v.inspect rescue NoMethodError puts "(Object doesn't support #inspect)" end } - INSPECTORS.def_inspector([:pp, :pretty_inspect], proc{require "pp"}){|v| v.pretty_inspect.chomp} - INSPECTORS.def_inspector([:yaml, :YAML], proc{require "yaml"}){|v| + Inspector.def_inspector([:pp, :pretty_inspect], proc{require "pp"}){|v| v.pretty_inspect.chomp} + Inspector.def_inspector([:yaml, :YAML], proc{require "yaml"}){|v| begin YAML.dump(v) rescue @@ -134,7 +134,7 @@ module IRB # :nodoc: end } - INSPECTORS.def_inspector([:marshal, :Marshal, :MARSHAL, Marshal]){|v| + Inspector.def_inspector([:marshal, :Marshal, :MARSHAL, Marshal]){|v| Marshal.dump(v) } end |