summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-03-27 01:51:37 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-03-27 01:51:37 +0000
commit3184af1a89e85d7914a2ae0b4971a13ceada7a5f (patch)
tree0a68b26e9e9af4b5245672e98daf91e8d95d36eb
parent4efc91fbfa9462787f1736b62564b7aca255543b (diff)
* (lib/pp.rb, lib/prettyprint.rb): define seplist in PP::PPMethods
instead of PrettyPrint. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@6033 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--lib/pp.rb46
-rw-r--r--lib/prettyprint.rb39
3 files changed, 51 insertions, 39 deletions
diff --git a/ChangeLog b/ChangeLog
index 7c3d12fa98..b02a41bb73 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Sat Mar 27 10:40:48 2004 Tanaka Akira <akr@m17n.org>
+
+ * (lib/pp.rb, lib/prettyprint.rb): define seplist in PP::PPMethods
+ instead of PrettyPrint.
+
Thu Mar 25 23:15:24 2004 Dave Thomas <dave@pragprog.com>
* lib/rdoc/ri/ri_options.rb (RI::Options::show_version):
diff --git a/lib/pp.rb b/lib/pp.rb
index 2279c984eb..6ddd4dd2eb 100644
--- a/lib/pp.rb
+++ b/lib/pp.rb
@@ -88,6 +88,32 @@ PP#pp to print the object.
text ','
breakable
+--- seplist(list[, separator_proc[, iter_method]]) {|elt| ... }
+ adds a separated list.
+ The list is separated by comma with breakable space, by default.
+
+ seplist iterates the ((|list|)) using ((|iter_method|)).
+ It yields each object to the block given for seplist.
+ The procedure ((|separator_proc|)) is called between each yields.
+
+ If the iteration is zero times, ((|separator_proc|)) is not called at all.
+
+ If ((|separator_proc|)) is nil or not given,
+ (({lambda { comma_breakable }})) is used.
+ If ((|iter_method|)) is not given, (({:each})) is used.
+
+ For example, following 3 code fragments has similar effect.
+
+ q.seplist([1,2,3]) {|v| xxx v }
+
+ q.seplist([1,2,3], lambda { comma_breakable }, :each) {|v| xxx v }
+
+ xxx 1
+ q.comma_breakable
+ xxx 2
+ q.comma_breakable
+ xxx 3
+
= Object
--- pretty_print(pp)
is a default pretty printing method for general objects.
@@ -201,6 +227,19 @@ class PP < PrettyPrint
breakable
end
+ def seplist(list, sep=nil, iter_method=:each)
+ sep ||= lambda { comma_breakable }
+ first = true
+ list.__send__(iter_method) {|*v|
+ if first
+ first = false
+ else
+ sep.call
+ end
+ yield(*v)
+ }
+ end
+
def pp_object(obj)
object_address_group(obj) {
seplist(obj.pretty_print_instance_variables, lambda { text ',' }) {|v|
@@ -603,4 +642,11 @@ if __FILE__ == $0
end
end
end
+
+ class PPSingleLineTest < Test::Unit::TestCase
+ def test_hash
+ assert_equal("{1=>1}", PP.singleline_pp({ 1 => 1}, '')) # [ruby-core:02699]
+ assert_equal("[1#{', 1'*99}]", PP.singleline_pp([1]*100, ''))
+ end
+ end
end
diff --git a/lib/prettyprint.rb b/lib/prettyprint.rb
index 25e24f6618..7b38cc0112 100644
--- a/lib/prettyprint.rb
+++ b/lib/prettyprint.rb
@@ -94,32 +94,6 @@ non-string formatting, etc.
--- flush
outputs buffered data.
---- seplist(list[, separator_proc[, iter_method]]) {|elt| ... }
- adds a separated list.
- The list is separated by comma with breakable space, by default.
-
- seplist iterates the ((|list|)) using ((|iter_method|)).
- It yields each object to the block given for seplist.
- The procedure ((|separator_proc|)) is called between each yields.
-
- If the iteration is zero times, ((|separator_proc|)) is not called at all.
-
- If ((|separator_proc|)) is nil or not given,
- (({lambda { comma_breakable }})) is used.
- If ((|iter_method|)) is not given, (({:each})) is used.
-
- For example, following 3 code fragments has similar effect.
-
- q.seplist([1,2,3]) {|v| xxx v }
-
- q.seplist([1,2,3], lambda { comma_breakable }, :each) {|v| xxx v }
-
- xxx 1
- q.comma_breakable
- xxx 2
- q.comma_breakable
- xxx 3
-
--- first?
first? is obsoleted at 1.8.2.
@@ -187,19 +161,6 @@ class PrettyPrint
@group_stack.last
end
- def seplist(list, sep=nil, iter_method=:each)
- sep ||= lambda { comma_breakable }
- first = true
- list.__send__(iter_method) {|*v|
- if first
- first = false
- else
- sep.call
- end
- yield(*v)
- }
- end
-
def first?
warn "PrettyPrint#first? is obsoleted at 1.8.2."
current_group.first?