mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
class.c: cyclic prepend
* class.c (include_modules_at): detect cyclic prepend with original method table. [ruby-core:52205] [Bug #7841] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@39236 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
bd255c4686
commit
632ab19c4d
3 changed files with 19 additions and 3 deletions
|
@ -1,3 +1,8 @@
|
|||
Thu Feb 14 11:08:15 2013 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* class.c (include_modules_at): detect cyclic prepend with original
|
||||
method table. [ruby-core:52205] [Bug #7841]
|
||||
|
||||
Thu Feb 14 10:30:41 2013 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* vm_method.c: call method_removed hook on called class, not on
|
||||
|
|
7
class.c
7
class.c
|
@ -681,7 +681,7 @@ rb_include_class_new(VALUE module, VALUE super)
|
|||
return (VALUE)klass;
|
||||
}
|
||||
|
||||
static int include_modules_at(VALUE klass, VALUE c, VALUE module);
|
||||
static int include_modules_at(const VALUE klass, VALUE c, VALUE module);
|
||||
|
||||
void
|
||||
rb_include_module(VALUE klass, VALUE module)
|
||||
|
@ -713,17 +713,18 @@ add_refined_method_entry_i(st_data_t key, st_data_t value, st_data_t data)
|
|||
}
|
||||
|
||||
static int
|
||||
include_modules_at(VALUE klass, VALUE c, VALUE module)
|
||||
include_modules_at(const VALUE klass, VALUE c, VALUE module)
|
||||
{
|
||||
VALUE p;
|
||||
int changed = 0;
|
||||
const st_table *const klass_m_tbl = RCLASS_M_TBL(RCLASS_ORIGIN(klass));
|
||||
|
||||
while (module) {
|
||||
int superclass_seen = FALSE;
|
||||
|
||||
if (RCLASS_ORIGIN(module) != module)
|
||||
goto skip;
|
||||
if (RCLASS_M_TBL(klass) && RCLASS_M_TBL(klass) == RCLASS_M_TBL(module))
|
||||
if (klass_m_tbl && klass_m_tbl == RCLASS_M_TBL(module))
|
||||
return -1;
|
||||
/* ignore if the module included already in superclasses */
|
||||
for (p = RCLASS_SUPER(klass); p; p = RCLASS_SUPER(p)) {
|
||||
|
|
|
@ -1465,6 +1465,16 @@ class TestModule < Test::Unit::TestCase
|
|||
assert_equal([:m1], Class.new(Class.new{def m2;end}){ prepend Module.new; def m1; end }.instance_methods(false), bug6660)
|
||||
end
|
||||
|
||||
def test_cyclic_prepend
|
||||
bug7841 = '[ruby-core:52205] [Bug #7841]'
|
||||
m1 = Module.new
|
||||
m2 = Module.new
|
||||
m1.instance_eval { prepend(m2) }
|
||||
assert_raise(ArgumentError, bug7841) do
|
||||
m2.instance_eval { prepend(m1) }
|
||||
end
|
||||
end
|
||||
|
||||
def test_class_variables
|
||||
m = Module.new
|
||||
m.class_variable_set(:@@foo, 1)
|
||||
|
|
Loading…
Reference in a new issue