ActionsLike0
Bug #17048
closedCalling initialize_copy on live modules leads to crashes
Status:
Closed
Assignee:
-
Target version:
-
ruby -v:
ruby 2.8.0dev (2020-07-23T14:44:25Z master 098e8c2873) [x86_64-linux]
Description
Here's a repro script
loop do
m = Module.new do
prepend Module.new
def hello
end
end
klass = Class.new { include m }
m.send(:initialize_copy, Module.new)
GC.start
klass.new.hello rescue nil
end
Here's a script that shows that it has broken semantics even
when it happens to not crash.
module A
end
class B
include A
end
module C
Const = :C
end
module D
Const = :D
end
A.send(:initialize_copy, C)
p B::Const # :C, makes sense
A.send(:initialize_copy, D)
p B::Const # :D, makes sense
A.send(:initialize_copy, Module.new)
p (begin B::Const rescue NameError; 'NameError' end) # NameError, makes sense
A.send(:initialize_copy, C)
p B::Const # still NameErorr. Weird
This example shows that the problem exists as far back as 2.0.0.
I think the easiest way to fix this is to forbid calling :initialize_copy
on modules that have children. Another option is to try to decide on
the semantics of this. Though I don't think it's worth the effort as this
has been broken for a long time and people don't seem to to be using it.
Thoughts?
Added by nobu (Nobuyoshi Nakada) over 3 years ago
Added by nobu (Nobuyoshi Nakada) over 3 years ago
Removed Module.allocate [Bug #17048]
ActionsLike0
Already initialized modules cannot be replaced [Bug #17048]