mirror of
https://github.com/ruby/ruby.git
synced 2025-09-23 20:44:00 +02:00
proc.c, vm_method.c: fix super and alias
* proc.c (method_owner): return the class where alias is defined, not the class original method is defined. * vm_method.c (rb_method_entry_make, rb_alias): store the originally defined class in me. [Bug #7993] [Bug #7842] [Bug #9236] * vm_method.c (rb_method_entry_get_without_cache): cache included module but not iclass. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@44175 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
f1f609bc22
commit
b71956d12b
5 changed files with 97 additions and 11 deletions
|
@ -1587,6 +1587,57 @@ class TestModule < Test::Unit::TestCase
|
|||
assert_include(im, mixin, bug8025)
|
||||
end
|
||||
|
||||
def test_prepend_super_in_alias
|
||||
bug7842 = '[Bug #7842]'
|
||||
|
||||
p = labeled_module("P") do
|
||||
def m; "P"+super; end
|
||||
end
|
||||
a = labeled_class("A") do
|
||||
def m; "A"; end
|
||||
end
|
||||
b = labeled_class("B", a) do
|
||||
def m; "B"+super; end
|
||||
alias m2 m
|
||||
prepend p
|
||||
alias m3 m
|
||||
end
|
||||
assert_equal("BA", b.new.m2, bug7842)
|
||||
assert_equal("PBA", b.new.m3, bug7842)
|
||||
end
|
||||
|
||||
def test_include_super_in_alias
|
||||
bug9236 = '[Bug #9236]'
|
||||
|
||||
fun = labeled_module("Fun") do
|
||||
def hello
|
||||
orig_hello
|
||||
end
|
||||
end
|
||||
|
||||
m1 = labeled_module("M1") do
|
||||
def hello
|
||||
'hello!'
|
||||
end
|
||||
end
|
||||
|
||||
m2 = labeled_module("M2") do
|
||||
def hello
|
||||
super
|
||||
end
|
||||
end
|
||||
|
||||
foo = labeled_class("Foo") do
|
||||
include m1
|
||||
include m2
|
||||
|
||||
alias orig_hello hello
|
||||
include fun
|
||||
end
|
||||
|
||||
assert_equal('hello!', foo.new.hello, bug9236)
|
||||
end
|
||||
|
||||
def test_class_variables
|
||||
m = Module.new
|
||||
m.class_variable_set(:@@foo, 1)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue