ruby-changes:5548
From: knu <ko1@a...>
Date: Mon, 9 Jun 2008 18:20:53 +0900 (JST)
Subject: [ruby-changes:5548] Ruby:r17051 (ruby_1_8_7): * lib/set.rb (Set#delete_if): Call to_a.
knu 2008-06-09 18:20:43 +0900 (Mon, 09 Jun 2008)
New Revision: 17051
Modified files:
branches/ruby_1_8_7/ChangeLog
branches/ruby_1_8_7/lib/set.rb
Log:
* lib/set.rb (Set#delete_if): Call to_a.
(SortedSet#delete_if, TC_SortedSet#test_sortedset): Use super to
yield elements in sorted order; [ruby-core:17144] by Arthur
Schreiber.
(SortedSet#each, SortedSet#each, TC_Set#test_each)
(TC_SortedSet#test_sortedset): Return self; [ruby-dev:35002] by
Arthur Schreiber.
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8_7/ChangeLog?r1=17051&r2=17050&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8_7/lib/set.rb?r1=17051&r2=17050&diff_format=u
Index: ruby_1_8_7/ChangeLog
===================================================================
--- ruby_1_8_7/ChangeLog (revision 17050)
+++ ruby_1_8_7/ChangeLog (revision 17051)
@@ -1,3 +1,13 @@
+Mon Jun 9 17:56:30 2008 Akinori MUSHA <knu@i...>
+
+ * lib/set.rb (Set#delete_if): Call to_a.
+ (SortedSet#delete_if, TC_SortedSet#test_sortedset): Use super to
+ yield elements in sorted order; [ruby-core:17144] by Arthur
+ Schreiber.
+ (SortedSet#each, SortedSet#each, TC_Set#test_each)
+ (TC_SortedSet#test_sortedset): Return self; [ruby-dev:35002] by
+ Arthur Schreiber.
+
Mon Jun 9 03:28:05 2008 Akinori MUSHA <knu@i...>
* ext/zlib/zlib.c (rb_deflate_initialize, Init_zlib): Fix up
Index: ruby_1_8_7/lib/set.rb
===================================================================
--- ruby_1_8_7/lib/set.rb (revision 17050)
+++ ruby_1_8_7/lib/set.rb (revision 17051)
@@ -234,7 +234,7 @@
# Deletes every element of the set for which block evaluates to
# true, and returns self.
def delete_if
- @hash.delete_if { |o,| yield(o) }
+ to_a.each { |o| @hash.delete(o) if yield(o) }
self
end
@@ -492,7 +492,7 @@
def delete_if
n = @hash.size
- @hash.delete_if { |o,| yield(o) }
+ super
@keys = nil if @hash.size != n
self
end
@@ -505,6 +505,7 @@
def each
block_given? or return enum_for(__method__)
to_a.each { |o| yield(o) }
+ self
end
def to_a
@@ -921,6 +922,9 @@
ary = [1,3,5,7,10,20]
set = Set.new(ary)
+ ret = set.each { |o| }
+ assert_same(set, ret)
+
e = set.each
assert_instance_of(Enumerable::Enumerator, e)
@@ -1167,11 +1171,33 @@
assert_equal([-10,-8,-6,-4,-2], s.to_a)
prev = nil
- s.each { |o| assert(prev < o) if prev; prev = o }
+ ret = s.each { |o| assert(prev < o) if prev; prev = o }
assert_not_nil(prev)
+ assert_same(s, ret)
s = SortedSet.new([2,1,3]) { |o| o * -2 }
assert_equal([-6,-4,-2], s.to_a)
+
+ s = SortedSet.new(['one', 'two', 'three', 'four'])
+ a = []
+ ret = s.delete_if { |o| a << o; o.start_with?('t') }
+ assert_same(s, ret)
+ assert_equal(['four', 'one'], s.to_a)
+ assert_equal(['four', 'one', 'three', 'two'], a)
+
+ s = SortedSet.new(['one', 'two', 'three', 'four'])
+ a = []
+ ret = s.reject! { |o| a << o; o.start_with?('t') }
+ assert_same(s, ret)
+ assert_equal(['four', 'one'], s.to_a)
+ assert_equal(['four', 'one', 'three', 'two'], a)
+
+ s = SortedSet.new(['one', 'two', 'three', 'four'])
+ a = []
+ ret = s.reject! { |o| a << o; false }
+ assert_same(nil, ret)
+ assert_equal(['four', 'one', 'three', 'two'], s.to_a)
+ assert_equal(['four', 'one', 'three', 'two'], a)
end
end
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/