[前][次][番号順一覧][スレッド一覧]

ruby-changes:47280

From: nagachika <ko1@a...>
Date: Sun, 23 Jul 2017 16:02:45 +0900 (JST)
Subject: [ruby-changes:47280] nagachika:r59395 (ruby_2_4): merge revision(s) 59080, 59082: [Backport #13656]

nagachika	2017-07-23 16:02:29 +0900 (Sun, 23 Jul 2017)

  New Revision: 59395

  https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=59395

  Log:
    merge revision(s) 59080,59082: [Backport #13656]
    
    proc.c: skip prepended modules
    
    * proc.c (method_super_method): skip prepended modules and
      continue from the super class of the original class.
      [ruby-core:81666] [Bug #13656]
    test/ruby/test_method.rb: refined  [ruby-core:81666] [Bug #13656]

  Modified directories:
    branches/ruby_2_4/
  Modified files:
    branches/ruby_2_4/proc.c
    branches/ruby_2_4/test/ruby/test_method.rb
    branches/ruby_2_4/version.h
Index: ruby_2_4/proc.c
===================================================================
--- ruby_2_4/proc.c	(revision 59394)
+++ ruby_2_4/proc.c	(revision 59395)
@@ -2654,7 +2654,7 @@ method_super_method(VALUE method) https://github.com/ruby/ruby/blob/trunk/ruby_2_4/proc.c#L2654
     const rb_method_entry_t *me;
 
     TypedData_Get_Struct(method, struct METHOD, &method_data_type, data);
-    super_class = RCLASS_SUPER(method_entry_defined_class(data->me));
+    super_class = RCLASS_SUPER(RCLASS_ORIGIN(method_entry_defined_class(data->me)));
     if (!super_class) return Qnil;
     me = (rb_method_entry_t *)rb_callable_method_entry_without_refinements(super_class, data->me->called_id);
     if (!me) return Qnil;
Index: ruby_2_4/version.h
===================================================================
--- ruby_2_4/version.h	(revision 59394)
+++ ruby_2_4/version.h	(revision 59395)
@@ -1,10 +1,10 @@ https://github.com/ruby/ruby/blob/trunk/ruby_2_4/version.h#L1
 #define RUBY_VERSION "2.4.2"
-#define RUBY_RELEASE_DATE "2017-07-18"
-#define RUBY_PATCHLEVEL 146
+#define RUBY_RELEASE_DATE "2017-07-23"
+#define RUBY_PATCHLEVEL 147
 
 #define RUBY_RELEASE_YEAR 2017
 #define RUBY_RELEASE_MONTH 7
-#define RUBY_RELEASE_DAY 18
+#define RUBY_RELEASE_DAY 23
 
 #include "ruby/version.h"
 
Index: ruby_2_4/test/ruby/test_method.rb
===================================================================
--- ruby_2_4/test/ruby/test_method.rb	(revision 59394)
+++ ruby_2_4/test/ruby/test_method.rb	(revision 59395)
@@ -901,6 +901,18 @@ class TestMethod < Test::Unit::TestCase https://github.com/ruby/ruby/blob/trunk/ruby_2_4/test/ruby/test_method.rb#L901
     assert_nil(m)
   end
 
+  def test_super_method_with_prepended_module
+    bug = '[ruby-core:81666] [Bug #13656] should be the method of the parent'
+    c1 = EnvUtil.labeled_class("C1") {def m; end}
+    c2 = EnvUtil.labeled_class("C2", c1) {def m; end}
+    c2.prepend(EnvUtil.labeled_module("M"))
+    m1 = c1.instance_method(:m)
+    m2 = c2.instance_method(:m).super_method
+    assert_equal(m1, m2, bug)
+    assert_equal(c1, m2.owner, bug)
+    assert_equal(m1.source_location, m2.source_location, bug)
+  end
+
   def rest_parameter(*rest)
     rest
   end
Index: ruby_2_4
===================================================================
--- ruby_2_4	(revision 59394)
+++ ruby_2_4	(revision 59395)

Property changes on: ruby_2_4
___________________________________________________________________
Modified: svn:mergeinfo
## -0,0 +0,1 ##
   Merged /trunk:r59080,59082

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]