summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorCarson McDonald <[email protected]>2013-03-25 00:23:22 -0400
committerCarson McDonald <[email protected]>2013-03-25 00:23:22 -0400
commit930e4c71c01562dc6ff03af87486acc2de81cc9b (patch)
treed9b34ceb3b70a2c4f813dba5f8663cc6db3b23df
parent84161ed7934ee4c31d09150952e422688b591b9f (diff)
downloadmruby-930e4c71c01562dc6ff03af87486acc2de81cc9b.tar.gz
mruby-930e4c71c01562dc6ff03af87486acc2de81cc9b.zip
Make mrb_top_self return a real instance.
-rw-r--r--include/mruby.h6
-rw-r--r--src/gc.c3
-rw-r--r--src/kernel.c1
-rw-r--r--src/state.c12
-rw-r--r--src/variable.c1
5 files changed, 17 insertions, 6 deletions
diff --git a/include/mruby.h b/include/mruby.h
index c5c607893..1c26be1ea 100644
--- a/include/mruby.h
+++ b/include/mruby.h
@@ -74,6 +74,7 @@ typedef struct mrb_state {
mrb_value *stack;
mrb_value *stbase, *stend;
+ mrb_value *top_self;
mrb_callinfo *ci;
mrb_callinfo *cibase, *ciend;
@@ -138,6 +139,7 @@ typedef struct mrb_state {
struct RClass *eStandardError_class;
void *ud; /* auxiliary data */
+
} mrb_state;
typedef mrb_value (*mrb_func_t)(mrb_state *mrb, mrb_value);
@@ -238,11 +240,11 @@ int mrb_gc_arena_save(mrb_state*);
void mrb_gc_arena_restore(mrb_state*,int);
void mrb_gc_mark(mrb_state*,struct RBasic*);
#define mrb_gc_mark_value(mrb,val) do {\
- if (mrb_type(val) >= MRB_TT_OBJECT) mrb_gc_mark((mrb), mrb_basic_ptr(val));\
+ if (mrb_type(val) >= MRB_TT_MAIN) mrb_gc_mark((mrb), mrb_basic_ptr(val));\
} while (0)
void mrb_field_write_barrier(mrb_state *, struct RBasic*, struct RBasic*);
#define mrb_field_write_barrier_value(mrb, obj, val) do{\
- if ((val.tt >= MRB_TT_OBJECT)) mrb_field_write_barrier((mrb), (obj), mrb_basic_ptr(val));\
+ if ((val.tt >= MRB_TT_MAIN)) mrb_field_write_barrier((mrb), (obj), mrb_basic_ptr(val));\
} while (0)
void mrb_write_barrier(mrb_state *, struct RBasic*);
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;