summaryrefslogtreecommitdiff
path: root/imemo.c
diff options
context:
space:
mode:
Diffstat (limited to 'imemo.c')
-rw-r--r--imemo.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/imemo.c b/imemo.c
index 3ecee05652..088185b195 100644
--- a/imemo.c
+++ b/imemo.c
@@ -130,7 +130,7 @@ rb_imemo_memsize(VALUE obj)
size_t size = 0;
switch (imemo_type(obj)) {
case imemo_ast:
- size += rb_ast_memsize((rb_ast_t *)obj);
+ rb_bug("imemo_ast is obsolete");
break;
case imemo_callcache:
@@ -273,7 +273,7 @@ rb_imemo_mark_and_move(VALUE obj, bool reference_updating)
{
switch (imemo_type(obj)) {
case imemo_ast:
- // TODO: Make AST decoupled from IMEMO
+ rb_bug("imemo_ast is obsolete");
break;
case imemo_callcache: {
@@ -316,6 +316,7 @@ rb_imemo_mark_and_move(VALUE obj, bool reference_updating)
else {
if (vm_cc_super_p(cc) || vm_cc_refinement_p(cc)) {
rb_gc_mark_movable((VALUE)cc->cme_);
+ rb_gc_mark_movable((VALUE)cc->klass);
}
}
@@ -357,7 +358,9 @@ rb_imemo_mark_and_move(VALUE obj, bool reference_updating)
((VALUE *)env->ep)[VM_ENV_DATA_INDEX_ENV] = rb_gc_location(env->ep[VM_ENV_DATA_INDEX_ENV]);
}
else {
- VM_ENV_FLAGS_SET(env->ep, VM_ENV_FLAG_WB_REQUIRED);
+ if (!VM_ENV_FLAGS(env->ep, VM_ENV_FLAG_WB_REQUIRED)) {
+ VM_ENV_FLAGS_SET(env->ep, VM_ENV_FLAG_WB_REQUIRED);
+ }
rb_gc_mark_movable( (VALUE)rb_vm_env_prev_env(env));
}
}
@@ -513,8 +516,7 @@ rb_imemo_free(VALUE obj)
{
switch (imemo_type(obj)) {
case imemo_ast:
- rb_ast_free((rb_ast_t *)obj);
- RB_DEBUG_COUNTER_INC(obj_imemo_ast);
+ rb_bug("imemo_ast is obsolete");
break;
case imemo_callcache: