ruby-changes:34664
From: usa <ko1@a...>
Date: Mon, 7 Jul 2014 12:58:07 +0900 (JST)
Subject: [ruby-changes:34664] usa:r46747 (ruby_2_0_0): merge revision(s) 45642, 45643: [Backport #9646] [Backport #9729]
usa 2014-07-07 12:58:01 +0900 (Mon, 07 Jul 2014) New Revision: 46747 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=46747 Log: merge revision(s) 45642,45643: [Backport #9646] [Backport #9729] * st.c (st_foreach_check): chnage start point of search at check from top to current. [ruby-dev:48047] [Bug #9646] * st.c (st_foreach_check): change start point of search at check Modified directories: branches/ruby_2_0_0/ Modified files: branches/ruby_2_0_0/ChangeLog branches/ruby_2_0_0/st.c branches/ruby_2_0_0/test/ruby/test_hash.rb branches/ruby_2_0_0/version.h Index: ruby_2_0_0/ChangeLog =================================================================== --- ruby_2_0_0/ChangeLog (revision 46746) +++ ruby_2_0_0/ChangeLog (revision 46747) @@ -1,3 +1,8 @@ https://github.com/ruby/ruby/blob/trunk/ruby_2_0_0/ChangeLog#L1 +Mon Jul 7 12:57:26 2014 Masaya Tarui <tarui@r...> + + * st.c (st_foreach_check): change start point of search at check + from top to current. [ruby-dev:48047] [Bug #9646] + Mon Jul 7 12:53:45 2014 Zachary Scott <e@z...> * lib/gserver.rb: [DOC] Fixed typo in example by @stomar [Bug #9543] Index: ruby_2_0_0/st.c =================================================================== --- ruby_2_0_0/st.c (revision 46746) +++ ruby_2_0_0/st.c (revision 46747) @@ -393,9 +393,8 @@ find_entry(st_table *table, st_data_t ke https://github.com/ruby/ruby/blob/trunk/ruby_2_0_0/st.c#L393 } static inline st_index_t -find_packed_index(st_table *table, st_index_t hash_val, st_data_t key) +find_packed_index_from(st_table *table, st_index_t hash_val, st_data_t key, st_index_t i) { - st_index_t i = 0; while (i < table->real_entries && (PHASH(table, i) != hash_val || !EQUAL(table, key, PKEY(table, i)))) { i++; @@ -403,6 +402,12 @@ find_packed_index(st_table *table, st_in https://github.com/ruby/ruby/blob/trunk/ruby_2_0_0/st.c#L402 return i; } +static inline st_index_t +find_packed_index(st_table *table, st_index_t hash_val, st_data_t key) +{ + return find_packed_index_from(table, hash_val, key, 0); +} + #define collision_check 0 int @@ -934,9 +939,10 @@ st_foreach_check(st_table *table, int (* https://github.com/ruby/ruby/blob/trunk/ruby_2_0_0/st.c#L939 if (PHASH(table, i) == 0 && PKEY(table, i) == never) { break; } - i = find_packed_index(table, hash, key); - if (i == table->real_entries) { - goto deleted; + i = find_packed_index_from(table, hash, key, i); + if (i >= table->real_entries) { + i = find_packed_index(table, hash, key); + if (i >= table->real_entries) goto deleted; } /* fall through */ case ST_CONTINUE: Index: ruby_2_0_0/version.h =================================================================== --- ruby_2_0_0/version.h (revision 46746) +++ ruby_2_0_0/version.h (revision 46747) @@ -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 "2014-07-07" -#define RUBY_PATCHLEVEL 529 +#define RUBY_PATCHLEVEL 530 #define RUBY_RELEASE_YEAR 2014 #define RUBY_RELEASE_MONTH 7 Index: ruby_2_0_0/test/ruby/test_hash.rb =================================================================== --- ruby_2_0_0/test/ruby/test_hash.rb (revision 46746) +++ ruby_2_0_0/test/ruby/test_hash.rb (revision 46747) @@ -951,6 +951,17 @@ class TestHash < Test::Unit::TestCase https://github.com/ruby/ruby/blob/trunk/ruby_2_0_0/test/ruby/test_hash.rb#L951 assert_predicate(h.dup, :compare_by_identity?, bug8703) end + def test_same_key + bug9646 = '[ruby-dev:48047] [Bug #9646] Infinite loop at Hash#each' + h = @cls[a=[], 1] + a << 1 + h[[]] = 2 + a.clear + cnt = 0 + r = h.each{ break nil if (cnt+=1) > 100 } + assert_not_nil(r,bug9646) + end + class ObjWithHash def initialize(value, hash) @value = value Property changes on: ruby_2_0_0 ___________________________________________________________________ Modified: svn:mergeinfo Merged /trunk:r45642-45643 -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/