summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--class.c4
-rw-r--r--test/ruby/test_box.rb16
2 files changed, 19 insertions, 1 deletions
diff --git a/class.c b/class.c
index 840bdeb0c2..8c773125e1 100644
--- a/class.c
+++ b/class.c
@@ -491,6 +491,7 @@ rb_class_duplicate_classext(rb_classext_t *orig, VALUE klass, const rb_box_t *bo
while (subclass_entry) {
if (subclass_entry->klass && RB_TYPE_P(subclass_entry->klass, T_ICLASS)) {
iclass = subclass_entry->klass;
+ VM_ASSERT(RB_TYPE_P(iclass, T_ICLASS));
if (RBASIC_CLASS(iclass) == klass) {
// Is the subclass an ICLASS including this module into another class
// If so we need to re-associate it under our box with the new ext
@@ -819,7 +820,8 @@ class_alloc0(enum ruby_value_type type, VALUE klass, bool boxable)
static VALUE
class_alloc(enum ruby_value_type type, VALUE klass)
{
- return class_alloc0(type, klass, false);
+ bool boxable = BOX_ROOT_P(rb_current_box());
+ return class_alloc0(type, klass, boxable);
}
static VALUE
diff --git a/test/ruby/test_box.rb b/test/ruby/test_box.rb
index a531afa679..cfd21ac0aa 100644
--- a/test/ruby/test_box.rb
+++ b/test/ruby/test_box.rb
@@ -854,4 +854,20 @@ class TestBox < Test::Unit::TestCase
assert_empty(Dir.children(tmpdir))
end
end
+
+ def test_root_box_iclasses_should_be_boxable
+ assert_separately([ENV_ENABLE_BOX], __FILE__, __LINE__, "#{<<~"begin;"}\n#{<<~'end;'}", ignore_stderr: true)
+ begin;
+ Ruby::Box.root.eval("class IMath; include Math; end") # (*)
+ module Math
+ def foo = :foo
+ end
+ # This test crashes here if iclasses (created at the line (*) is not boxable)
+ class IMath2; include Math; end
+ assert_equal :foo, IMath2.new.foo
+ assert_raise NoMethodError do
+ Ruby::Box.root.eval("IMath.new.foo")
+ end
+ end;
+ end
end