summaryrefslogtreecommitdiff
path: root/lib/pp.rb
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-02-01 16:57:47 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-02-01 16:57:47 +0000
commitd837280dc8fff1518655c63a45966e3fda87fa3e (patch)
tree64f011c1693a462cca6007caa02e729167ed6aef /lib/pp.rb
parent678e4ea5b495893e2e9a7a6cf0045085623622f8 (diff)
* lib/pp.rb (Struct#pretty_print): make it 1.8 style.
(Numeric#pretty_print, FalseClass#pretty_print) (TrueClass#pretty_print, Module#pretty_print): fix pp for objects with instance variables. [ruby-talk:91157] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@5607 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/pp.rb')
-rw-r--r--lib/pp.rb16
1 files changed, 14 insertions, 2 deletions
diff --git a/lib/pp.rb b/lib/pp.rb
index c366e25932..a9491f62d2 100644
--- a/lib/pp.rb
+++ b/lib/pp.rb
@@ -309,7 +309,7 @@ end
class Struct
def pretty_print(q)
- q.object_group(self) {
+ q.group(1, '#<struct ' + self.class.name, '>') {
self.members.each {|member|
q.text "," unless q.first?
q.breakable
@@ -440,6 +440,14 @@ end
}
}
+[Numeric, FalseClass, TrueClass, Module].each {|c|
+ c.class_eval {
+ def pretty_print(q)
+ q.text inspect
+ end
+ }
+}
+
if __FILE__ == $0
require 'test/unit'
@@ -534,6 +542,10 @@ if __FILE__ == $0
result = PP.pp(a, '')
assert_equal("#{a.inspect}\n", result)
assert_match(/\A#<Object.*>\n\z/m, result)
+ a = 1
+ a.instance_eval { @a = nil }
+ result = PP.pp(a, '')
+ assert_equal("#{a.inspect}\n", result)
end
def test_to_s_without_iv
@@ -562,7 +574,7 @@ if __FILE__ == $0
def test_struct
a = S.new(1,2)
a.b = a
- assert_equal("#<Struct::S a=1, b=#<Struct::S:...>>\n", PP.pp(a, ''))
+ assert_equal("#<struct Struct::S a=1, b=#<Struct::S:...>>\n", PP.pp(a, ''))
end
def test_object