ruby-changes:46756
From: nobu <ko1@a...>
Date: Wed, 24 May 2017 17:00:48 +0900 (JST)
Subject: [ruby-changes:46756] nobu:r58871 (trunk): enum.c: respect method visibility
nobu 2017-05-24 17:00:42 +0900 (Wed, 24 May 2017) New Revision: 58871 https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=58871 Log: enum.c: respect method visibility * enum.c (ary_inject_op): should respect method visibility, do not optimize uncallable method. [ruby-core:81349] [Bug #13592] Modified files: trunk/enum.c trunk/test/ruby/test_enum.rb Index: test/ruby/test_enum.rb =================================================================== --- test/ruby/test_enum.rb (revision 58870) +++ test/ruby/test_enum.rb (revision 58871) @@ -234,6 +234,25 @@ class TestEnumerable < Test::Unit::TestC https://github.com/ruby/ruby/blob/trunk/test/ruby/test_enum.rb#L234 end; end + def test_inject_array_op_private + assert_separately([], "#{<<~"end;"}\n""end") + all_assertions_foreach("", *%i[+ * / - %]) do |op| + bug = '[ruby-core:81349] [Bug #13592] should respect visibility' + assert_raise_with_message(NoMethodError, /private method/, bug) do + begin + Integer.class_eval do + private op + end + [1,2,3].inject(op) + ensure + Integer.class_eval do + public op + end + end + end + end; + end + def test_partition assert_equal([[1, 3, 1], [2, 2]], @obj.partition {|x| x % 2 == 1 }) cond = ->(x, i) { x % 2 == 1 } Index: enum.c =================================================================== --- enum.c (revision 58870) +++ enum.c (revision 58871) @@ -678,8 +678,9 @@ ary_inject_op(VALUE ary, VALUE init, VAL https://github.com/ruby/ruby/blob/trunk/enum.c#L678 id = SYM2ID(op); if (id == idPLUS) { - if ((FIXNUM_P(v) || RB_TYPE_P(v, T_BIGNUM)) && - rb_method_basic_definition_p(rb_cInteger, idPLUS)) { + if (RB_INTEGER_TYPE_P(v) && + rb_method_basic_definition_p(rb_cInteger, idPLUS) && + rb_obj_respond_to(v, idPLUS, FALSE)) { n = 0; for (; i < RARRAY_LEN(ary); i++) { e = RARRAY_AREF(ary, i); @@ -705,7 +706,7 @@ ary_inject_op(VALUE ary, VALUE init, VAL https://github.com/ruby/ruby/blob/trunk/enum.c#L706 } } for (; i < RARRAY_LEN(ary); i++) { - v = rb_funcall(v, id, 1, RARRAY_AREF(ary, i)); + v = rb_funcallv_public(v, id, 1, &RARRAY_CONST_PTR(ary)[i]); } return v; } -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/