diff options
author | NARUSE, Yui <naruse@airemix.jp> | 2022-01-30 19:08:49 +0900 |
---|---|---|
committer | NARUSE, Yui <naruse@airemix.jp> | 2022-01-30 19:08:49 +0900 |
commit | 28ec24db4a8201fa624692cdc1cbef9b00489412 (patch) | |
tree | 0a9b473c0e202f54358bd666fa6be523cfacc3e5 /object.c | |
parent | 1a1737530bff683041b8f45e7acac8c5c85c4163 (diff) |
merge revision(s) a79c59472df38297c246b27713c277f2edaefa7a: [Backport #18292]
Allow include before calling Module#initialize
This is to allow Module subclasses that include modules before
calling super in the subclass's initialize.
Remove rb_module_check_initializable from Module#initialize.
Module#initialize only calls module_exec if a block is passed,
it doesn't have other issues that would cause problems if
called multiple times or with an already initialized module.
Move initialization of super to Module#allocate, though I'm not
sure it is required there. However, it's needed to be removed
from Module#initialize for this to work.
Fixes [Bug #18292]
---
class.c | 1 +
object.c | 1 -
test/ruby/test_module.rb | 10 ++++++++++
3 files changed, 11 insertions(+), 1 deletion(-)
Diffstat (limited to 'object.c')
-rw-r--r-- | object.c | 1 |
1 files changed, 0 insertions, 1 deletions
@@ -1800,7 +1800,6 @@ static VALUE rb_mod_initialize_exec(VALUE module); static VALUE rb_mod_initialize(VALUE module) { - rb_module_check_initializable(module); return rb_mod_initialize_exec(module); } |