aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--proc.c1
-rw-r--r--test/ruby/test_method.rb3
3 files changed, 6 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 0de1d664ed..d8e33b7aed 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Tue Mar 5 20:29:25 2013 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * proc.c (mnew): revert r39224. [ruby-core:53038] [Bug #7988]
+
Tue Mar 5 20:23:54 2013 Nobuyoshi Nakada <nobu@ruby-lang.org>
* include/ruby/intern.h (rb_check_arity): make a static inline
diff --git a/proc.c b/proc.c
index ad53982b16..c86cb1c3ac 100644
--- a/proc.c
+++ b/proc.c
@@ -949,7 +949,6 @@ mnew(VALUE klass, VALUE obj, ID id, VALUE mclass, int scope)
rb_method_flag_t flag = NOEX_UNDEF;
again:
- if (klass) klass = RCLASS_ORIGIN(klass);
me = rb_method_entry_without_refinements(klass, id, &defined_class);
if (UNDEFINED_METHOD_ENTRY_P(me)) {
ID rmiss = rb_intern("respond_to_missing?");
diff --git a/test/ruby/test_method.rb b/test/ruby/test_method.rb
index 7de4479a2b..ef4943c345 100644
--- a/test/ruby/test_method.rb
+++ b/test/ruby/test_method.rb
@@ -550,6 +550,7 @@ class TestMethod < Test::Unit::TestCase
def test_prepended
bug7836 = '[ruby-core:52160] [Bug #7836]'
+ bug7988 = '[ruby-core:53038] [Bug #7988]'
m = Module.new {
def foo
end
@@ -559,7 +560,7 @@ class TestMethod < Test::Unit::TestCase
end
prepend m
}
- assert_equal(c, c.instance_method(:foo).owner, bug7836)
+ assert_raise(NameError, bug7988) {Module.new{prepend m}.instance_method(:bar)}
end
def test_gced_bmethod