From 930e4c71c01562dc6ff03af87486acc2de81cc9b Mon Sep 17 00:00:00 2001 From: Carson McDonald Date: Mon, 25 Mar 2013 00:23:22 -0400 Subject: Make mrb_top_self return a real instance. --- src/gc.c | 3 +++ src/kernel.c | 1 + src/state.c | 12 ++++++++---- src/variable.c | 1 + 4 files changed, 13 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/gc.c b/src/gc.c index f8d25e5ec..53a5eb3ed 100644 --- a/src/gc.c +++ b/src/gc.c @@ -392,6 +392,7 @@ gc_mark_children(mrb_state *mrb, struct RBasic *obj) } /* fall through */ + case MRB_TT_MAIN: case MRB_TT_OBJECT: case MRB_TT_DATA: mrb_gc_mark_iv(mrb, (struct RObject*)obj); @@ -478,6 +479,7 @@ obj_free(mrb_state *mrb, struct RBasic *obj) /* cannot happen */ return; + case MRB_TT_MAIN: case MRB_TT_OBJECT: mrb_gc_free_iv(mrb, (struct RObject*)obj); break; @@ -618,6 +620,7 @@ gc_gray_mark(mrb_state *mrb, struct RBasic *obj) } break; + case MRB_TT_MAIN: case MRB_TT_OBJECT: case MRB_TT_DATA: children += mrb_gc_mark_iv_size(mrb, (struct RObject*)obj); diff --git a/src/kernel.c b/src/kernel.c index 083309d3e..ce96b902a 100644 --- a/src/kernel.c +++ b/src/kernel.c @@ -306,6 +306,7 @@ init_copy(mrb_state *mrb, mrb_value dest, mrb_value obj) case MRB_TT_SCLASS: case MRB_TT_HASH: case MRB_TT_DATA: + case MRB_TT_MAIN: mrb_iv_copy(mrb, dest, obj); break; diff --git a/src/state.c b/src/state.c index 7b5bd1002..1278249b1 100644 --- a/src/state.c +++ b/src/state.c @@ -7,6 +7,7 @@ #include "mruby.h" #include "mruby/irep.h" #include "mruby/variable.h" +#include "mruby/class.h" #include #include @@ -160,8 +161,11 @@ mrb_add_irep(mrb_state *mrb) mrb_value mrb_top_self(mrb_state *mrb) { - mrb_value v; - - MRB_SET_VALUE(v, MRB_TT_MAIN, value.i, 0); - return v; + if(mrb->top_self == NULL) + { + mrb->top_self = (mrb_value *)mrb_calloc(mrb, 1, sizeof(mrb_value)); + *(mrb->top_self) = mrb_class_new_instance(mrb, 0, NULL, mrb->object_class); + mrb->top_self->tt = MRB_TT_MAIN; + } + return *(mrb->top_self); } diff --git a/src/variable.c b/src/variable.c index 5bacd5141..669a86fc2 100644 --- a/src/variable.c +++ b/src/variable.c @@ -419,6 +419,7 @@ obj_iv_p(mrb_value obj) case MRB_TT_SCLASS: case MRB_TT_HASH: case MRB_TT_DATA: + case MRB_TT_MAIN: return TRUE; default: return FALSE; -- cgit v1.2.3