mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/irb/inspector.rb, lib/irb/context.rb: Move IRB::INSPECTORS and
class methods to IRB::Inspector [ruby-core:51067][Bug #7598] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@38542 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
75584a1d86
commit
4da6fa28f8
3 changed files with 72 additions and 67 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
Sat Dec 22 02:05:00 2012 Zachary Scott <zachary@zacharyscott.net>
|
||||||
|
|
||||||
|
* lib/irb/inspector.rb, lib/irb/context.rb: Move IRB::INSPECTORS and
|
||||||
|
class methods to IRB::Inspector [ruby-core:51067][Bug #7598]
|
||||||
|
|
||||||
Sat Dec 22 00:28:46 2012 NAKAMURA Usaku <usa@ruby-lang.org>
|
Sat Dec 22 00:28:46 2012 NAKAMURA Usaku <usa@ruby-lang.org>
|
||||||
|
|
||||||
* object.c (rb_obj_hash): shouldn't assume object_id can be long.
|
* object.c (rb_obj_hash): shouldn't assume object_id can be long.
|
||||||
|
|
|
@ -286,7 +286,7 @@ module IRB
|
||||||
# +nil+:: inspect mode in non-math mode,
|
# +nil+:: inspect mode in non-math mode,
|
||||||
# non-inspect mode in 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
|
# Can also be set using the +--inspect+ and +--noinspect+ command line
|
||||||
# options.
|
# options.
|
||||||
|
@ -294,16 +294,16 @@ module IRB
|
||||||
# See IRB@Command+line+options for more command line options.
|
# See IRB@Command+line+options for more command line options.
|
||||||
def inspect_mode=(opt)
|
def inspect_mode=(opt)
|
||||||
|
|
||||||
if i = INSPECTORS[opt]
|
if i = Inspector::INSPECTORS[opt]
|
||||||
@inspect_mode = opt
|
@inspect_mode = opt
|
||||||
@inspect_method = i
|
@inspect_method = i
|
||||||
i.init
|
i.init
|
||||||
else
|
else
|
||||||
case opt
|
case opt
|
||||||
when nil
|
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
|
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
|
self.inspect_mode = true
|
||||||
else
|
else
|
||||||
puts "Can't switch inspect mode."
|
puts "Can't switch inspect mode."
|
||||||
|
@ -322,10 +322,10 @@ module IRB
|
||||||
when Inspector
|
when Inspector
|
||||||
prefix = "usr%d"
|
prefix = "usr%d"
|
||||||
i = 1
|
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_mode = format(prefix, i)
|
||||||
@inspect_method = opt
|
@inspect_method = opt
|
||||||
INSPECTORS.def_inspector(format(prefix, i), @inspect_method)
|
Inspector.def_inspector(format(prefix, i), @inspect_method)
|
||||||
else
|
else
|
||||||
puts "Can't switch inspect mode(#{opt})."
|
puts "Can't switch inspect mode(#{opt})."
|
||||||
return
|
return
|
||||||
|
|
|
@ -41,6 +41,62 @@ module IRB # :nodoc:
|
||||||
# irb(main):001:0> "what?" #=> omg! what?
|
# irb(main):001:0> "what?" #=> omg! what?
|
||||||
#
|
#
|
||||||
class Inspector
|
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
|
# Creates a new inspector object, using the given +inspect_proc+ when
|
||||||
# output return values in irb.
|
# output return values in irb.
|
||||||
def initialize(inspect_proc, init_proc = nil)
|
def initialize(inspect_proc, init_proc = nil)
|
||||||
|
@ -60,72 +116,16 @@ module IRB # :nodoc:
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Default inspectors available to irb, this includes:
|
Inspector.def_inspector([false, :to_s, :raw]){|v| v.to_s}
|
||||||
#
|
Inspector.def_inspector([true, :p, :inspect]){|v|
|
||||||
# +: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|
|
|
||||||
begin
|
begin
|
||||||
v.inspect
|
v.inspect
|
||||||
rescue NoMethodError
|
rescue NoMethodError
|
||||||
puts "(Object doesn't support #inspect)"
|
puts "(Object doesn't support #inspect)"
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
INSPECTORS.def_inspector([:pp, :pretty_inspect], proc{require "pp"}){|v| v.pretty_inspect.chomp}
|
Inspector.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([:yaml, :YAML], proc{require "yaml"}){|v|
|
||||||
begin
|
begin
|
||||||
YAML.dump(v)
|
YAML.dump(v)
|
||||||
rescue
|
rescue
|
||||||
|
@ -134,7 +134,7 @@ module IRB # :nodoc:
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
|
|
||||||
INSPECTORS.def_inspector([:marshal, :Marshal, :MARSHAL, Marshal]){|v|
|
Inspector.def_inspector([:marshal, :Marshal, :MARSHAL, Marshal]){|v|
|
||||||
Marshal.dump(v)
|
Marshal.dump(v)
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue