ruby-changes:31149
From: nagachika <ko1@a...>
Date: Thu, 10 Oct 2013 01:04:26 +0900 (JST)
Subject: [ruby-changes:31149] nagachika:r43228 (ruby_2_0_0): merge revision(s) 42040, 42041, 42047: [Backport #8654]
nagachika 2013-10-10 01:04:12 +0900 (Thu, 10 Oct 2013) New Revision: 43228 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=43228 Log: merge revision(s) 42040,42041,42047: [Backport #8654] * array.c (rb_ary_count): iterate items appropriately. [Bug #8654] * array.c (rb_ary_count): check length to avoid SEGV while iterating. Remove other pointer loop when arg is given. * test/ruby/test_array.rb (test_count): add test for bug. [ruby-core:56072] [Bug #8654] * test/ruby/test_array.rb (test_count): add a test case for #count with an argument. See Bug #8654. Modified directories: branches/ruby_2_0_0/ Modified files: branches/ruby_2_0_0/ChangeLog branches/ruby_2_0_0/array.c branches/ruby_2_0_0/test/ruby/test_array.rb branches/ruby_2_0_0/version.h Index: ruby_2_0_0/array.c =================================================================== --- ruby_2_0_0/array.c (revision 43227) +++ ruby_2_0_0/array.c (revision 43228) @@ -4113,27 +4113,28 @@ rb_ary_compact(VALUE ary) https://github.com/ruby/ruby/blob/trunk/ruby_2_0_0/array.c#L4113 static VALUE rb_ary_count(int argc, VALUE *argv, VALUE ary) { - long n = 0; + long i, n = 0; if (argc == 0) { - VALUE *p, *pend; + VALUE v; if (!rb_block_given_p()) return LONG2NUM(RARRAY_LEN(ary)); - for (p = RARRAY_PTR(ary), pend = p + RARRAY_LEN(ary); p < pend; p++) { - if (RTEST(rb_yield(*p))) n++; + for (i = 0; i < RARRAY_LEN(ary); i++) { + v = RARRAY_PTR(ary)[i]; + if (RTEST(rb_yield(v))) n++; } } else { - VALUE obj, *p, *pend; + VALUE obj; rb_scan_args(argc, argv, "1", &obj); if (rb_block_given_p()) { rb_warn("given block not used"); } - for (p = RARRAY_PTR(ary), pend = p + RARRAY_LEN(ary); p < pend; p++) { - if (rb_equal(*p, obj)) n++; + for (i = 0; i < RARRAY_LEN(ary); i++) { + if (rb_equal(RARRAY_PTR(ary)[i], obj)) n++; } } Index: ruby_2_0_0/ChangeLog =================================================================== --- ruby_2_0_0/ChangeLog (revision 43227) +++ ruby_2_0_0/ChangeLog (revision 43228) @@ -1,3 +1,21 @@ https://github.com/ruby/ruby/blob/trunk/ruby_2_0_0/ChangeLog#L1 +Thu Oct 10 00:58:39 2013 Benoit Daloze <eregontp@g...> + + * test/ruby/test_array.rb (test_count): add a test case for #count + with an argument. See Bug #8654. + +Thu Oct 10 00:58:39 2013 Benoit Daloze <eregontp@g...> + + * array.c (rb_ary_count): check length to avoid SEGV + while iterating. Remove other pointer loop when arg is given. + + * test/ruby/test_array.rb (test_count): add test for bug. + [ruby-core:56072] [Bug #8654] + +Thu Oct 10 00:58:39 2013 Masaki Matsushita <glass.saga@g...> + + * array.c (rb_ary_count): iterate items appropriately. + [Bug #8654] + Thu Oct 10 00:44:28 2013 Nobuyoshi Nakada <nobu@r...> * process.c (rb_fork_internal): remove cloexec setting on pipes Index: ruby_2_0_0/version.h =================================================================== --- ruby_2_0_0/version.h (revision 43227) +++ ruby_2_0_0/version.h (revision 43228) @@ -1,6 +1,6 @@ https://github.com/ruby/ruby/blob/trunk/ruby_2_0_0/version.h#L1 #define RUBY_VERSION "2.0.0" #define RUBY_RELEASE_DATE "2013-10-10" -#define RUBY_PATCHLEVEL 331 +#define RUBY_PATCHLEVEL 332 #define RUBY_RELEASE_YEAR 2013 #define RUBY_RELEASE_MONTH 10 Index: ruby_2_0_0/test/ruby/test_array.rb =================================================================== --- ruby_2_0_0/test/ruby/test_array.rb (revision 43227) +++ ruby_2_0_0/test/ruby/test_array.rb (revision 43228) @@ -576,6 +576,28 @@ class TestArray < Test::Unit::TestCase https://github.com/ruby/ruby/blob/trunk/ruby_2_0_0/test/ruby/test_array.rb#L576 assert_equal(3, a.count {|x| x % 2 == 1 }) assert_equal(2, a.count(1) {|x| x % 2 == 1 }) assert_raise(ArgumentError) { a.count(0, 1) } + + bug8654 = '[ruby-core:56072]' + assert_in_out_err [], <<-EOS, ["0"], [], bug8654 + a1 = [] + a2 = Array.new(100) { |i| i } + r = a2.count do |i| + p i + a2.replace(a1) if i == 0 + end + EOS + + assert_in_out_err [], <<-EOS, ["[]", "0"], [], bug8654 + ARY = Array.new(100) { |i| i } + class Fixnum + def == other + ARY.replace([]) if self.equal?(0) + p ARY + self.equal?(other) + end + end + p ARY.count(42) + EOS end def test_delete Property changes on: ruby_2_0_0 ___________________________________________________________________ Modified: svn:mergeinfo Merged /trunk:r42040-42041,42047 -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/