summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/gc.c3
-rw-r--r--src/kernel.c1
-rw-r--r--src/state.c12
-rw-r--r--src/variable.c1
4 files changed, 13 insertions, 4 deletions
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 <stdlib.h>
#include <string.h>
@@ -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;