ruby-changes:52350
From: usa <ko1@a...>
Date: Mon, 27 Aug 2018 22:47:52 +0900 (JST)
Subject: [ruby-changes:52350] usa:r64558 (ruby_2_4): merge revision(s) 62731, 62735: [Backport #14495]
usa 2018-08-27 22:47:40 +0900 (Mon, 27 Aug 2018) New Revision: 64558 https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=64558 Log: merge revision(s) 62731,62735: [Backport #14495] Bug Fix Enumerator::Lazy#uniq state for multiple call * enumerator.c (lazy_uniq_i): create new hash for each calls. [Fix GH-1820] Currently 2.5.0-preview1 :001 > arr = (0..100).lazy.uniq{|i| i % 10} => #<Enumerator::Lazy: #<Enumerator::Lazy: 0..100>:uniq> 2.5.0-preview1 :002 > arr.to_a => [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 2.5.0-preview1 :003 > arr.to_a => [] Expected arr.to_a to always return same output From: Anmol Chopra <anmolchopra@r...> test_enumerator.rb: duplicate assertions * test/ruby/test_enumerator.rb (test_uniq): remove assertions which ared duplicate of lazy enumerator tests in test_lazy_enumerator.rb. Modified directories: branches/ruby_2_4/ Modified files: branches/ruby_2_4/enumerator.c branches/ruby_2_4/test/ruby/test_enumerator.rb branches/ruby_2_4/test/ruby/test_lazy_enumerator.rb branches/ruby_2_4/version.h Index: ruby_2_4/enumerator.c =================================================================== --- ruby_2_4/enumerator.c (revision 64557) +++ ruby_2_4/enumerator.c (revision 64558) @@ -2233,27 +2233,35 @@ lazy_drop_while(VALUE obj) https://github.com/ruby/ruby/blob/trunk/ruby_2_4/enumerator.c#L2233 } static VALUE -lazy_uniq_i(VALUE i, VALUE hash, int argc, const VALUE *argv, VALUE yielder) +lazy_uniq_i(VALUE i, int argc, const VALUE *argv, VALUE yielder) { + VALUE hash; + + hash = rb_attr_get(yielder, id_memo); + if (NIL_P(hash)) { + hash = rb_obj_hide(rb_hash_new()); + rb_ivar_set(yielder, id_memo, hash); + } + if (rb_hash_add_new_element(hash, i, Qfalse)) return Qnil; return rb_funcallv(yielder, id_yield, argc, argv); } static VALUE -lazy_uniq_func(RB_BLOCK_CALL_FUNC_ARGLIST(i, hash)) +lazy_uniq_func(RB_BLOCK_CALL_FUNC_ARGLIST(i, m)) { VALUE yielder = (--argc, *argv++); i = rb_enum_values_pack(argc, argv); - return lazy_uniq_i(i, hash, argc, argv, yielder); + return lazy_uniq_i(i, argc, argv, yielder); } static VALUE -lazy_uniq_iter(RB_BLOCK_CALL_FUNC_ARGLIST(i, hash)) +lazy_uniq_iter(RB_BLOCK_CALL_FUNC_ARGLIST(i, m)) { VALUE yielder = (--argc, *argv++); i = rb_yield_values2(argc, argv); - return lazy_uniq_i(i, hash, argc, argv, yielder); + return lazy_uniq_i(i, argc, argv, yielder); } static VALUE @@ -2261,9 +2269,8 @@ lazy_uniq(VALUE obj) https://github.com/ruby/ruby/blob/trunk/ruby_2_4/enumerator.c#L2269 { rb_block_call_func *const func = rb_block_given_p() ? lazy_uniq_iter : lazy_uniq_func; - VALUE hash = rb_obj_hide(rb_hash_new()); return lazy_set_method(rb_block_call(rb_cLazy, id_new, 1, &obj, - func, hash), + func, 0), 0, 0); } Index: ruby_2_4/version.h =================================================================== --- ruby_2_4/version.h (revision 64557) +++ ruby_2_4/version.h (revision 64558) @@ -1,10 +1,10 @@ https://github.com/ruby/ruby/blob/trunk/ruby_2_4/version.h#L1 #define RUBY_VERSION "2.4.5" -#define RUBY_RELEASE_DATE "2018-07-31" -#define RUBY_PATCHLEVEL 315 +#define RUBY_RELEASE_DATE "2018-08-27" +#define RUBY_PATCHLEVEL 316 #define RUBY_RELEASE_YEAR 2018 -#define RUBY_RELEASE_MONTH 7 -#define RUBY_RELEASE_DAY 31 +#define RUBY_RELEASE_MONTH 8 +#define RUBY_RELEASE_DAY 27 #include "ruby/version.h" Index: ruby_2_4/test/ruby/test_enumerator.rb =================================================================== --- ruby_2_4/test/ruby/test_enumerator.rb (revision 64557) +++ ruby_2_4/test/ruby/test_enumerator.rb (revision 64558) @@ -657,8 +657,9 @@ class TestEnumerator < Test::Unit::TestC https://github.com/ruby/ruby/blob/trunk/ruby_2_4/test/ruby/test_enumerator.rb#L657 end def test_uniq - assert_equal([1, 2, 3, 4, 5, 10], - (1..Float::INFINITY).lazy.uniq{|x| (x**2) % 10 }.first(6)) + u = [0, 1, 0, 1].to_enum.lazy.uniq + assert_equal([0, 1], u.force) + assert_equal([0, 1], u.force) end end Index: ruby_2_4/test/ruby/test_lazy_enumerator.rb =================================================================== --- ruby_2_4/test/ruby/test_lazy_enumerator.rb (revision 64557) +++ ruby_2_4/test/ruby/test_lazy_enumerator.rb (revision 64558) @@ -569,4 +569,13 @@ EOS https://github.com/ruby/ruby/blob/trunk/ruby_2_4/test/ruby/test_lazy_enumerator.rb#L569 [1, 2, 3].lazy.map(&:undefined).map(&:to_s).force end end + + def test_uniq + u = (1..Float::INFINITY).lazy.uniq do |x| + raise "too big" if x > 10000 + (x**2) % 10 + end + assert_equal([1, 2, 3, 4, 5, 10], u.first(6)) + assert_equal([1, 2, 3, 4, 5, 10], u.first(6)) + end end Index: ruby_2_4 =================================================================== --- ruby_2_4 (revision 64557) +++ ruby_2_4 (revision 64558) Property changes on: ruby_2_4 ___________________________________________________________________ Modified: svn:mergeinfo ## -0,0 +0,1 ## Merged /trunk:r62731,62735 -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/