Commit 5c6be2e5 authored by Yukihiro Matz Matsumoto's avatar Yukihiro Matz Matsumoto

Merge branch 'selftopiv' of https://github.com/carsonmcdonald/mruby into carsonmcdonald-selftopiv

parents 471ad606 930e4c71
...@@ -74,6 +74,7 @@ typedef struct mrb_state { ...@@ -74,6 +74,7 @@ typedef struct mrb_state {
mrb_value *stack; mrb_value *stack;
mrb_value *stbase, *stend; mrb_value *stbase, *stend;
mrb_value *top_self;
mrb_callinfo *ci; mrb_callinfo *ci;
mrb_callinfo *cibase, *ciend; mrb_callinfo *cibase, *ciend;
...@@ -138,6 +139,7 @@ typedef struct mrb_state { ...@@ -138,6 +139,7 @@ typedef struct mrb_state {
struct RClass *eStandardError_class; struct RClass *eStandardError_class;
void *ud; /* auxiliary data */ void *ud; /* auxiliary data */
} mrb_state; } mrb_state;
typedef mrb_value (*mrb_func_t)(mrb_state *mrb, mrb_value); typedef mrb_value (*mrb_func_t)(mrb_state *mrb, mrb_value);
...@@ -238,11 +240,11 @@ int mrb_gc_arena_save(mrb_state*); ...@@ -238,11 +240,11 @@ int mrb_gc_arena_save(mrb_state*);
void mrb_gc_arena_restore(mrb_state*,int); void mrb_gc_arena_restore(mrb_state*,int);
void mrb_gc_mark(mrb_state*,struct RBasic*); void mrb_gc_mark(mrb_state*,struct RBasic*);
#define mrb_gc_mark_value(mrb,val) do {\ #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) } while (0)
void mrb_field_write_barrier(mrb_state *, struct RBasic*, struct RBasic*); void mrb_field_write_barrier(mrb_state *, struct RBasic*, struct RBasic*);
#define mrb_field_write_barrier_value(mrb, obj, val) do{\ #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) } while (0)
void mrb_write_barrier(mrb_state *, struct RBasic*); void mrb_write_barrier(mrb_state *, struct RBasic*);
......
...@@ -392,6 +392,7 @@ gc_mark_children(mrb_state *mrb, struct RBasic *obj) ...@@ -392,6 +392,7 @@ gc_mark_children(mrb_state *mrb, struct RBasic *obj)
} }
/* fall through */ /* fall through */
case MRB_TT_MAIN:
case MRB_TT_OBJECT: case MRB_TT_OBJECT:
case MRB_TT_DATA: case MRB_TT_DATA:
mrb_gc_mark_iv(mrb, (struct RObject*)obj); mrb_gc_mark_iv(mrb, (struct RObject*)obj);
...@@ -478,6 +479,7 @@ obj_free(mrb_state *mrb, struct RBasic *obj) ...@@ -478,6 +479,7 @@ obj_free(mrb_state *mrb, struct RBasic *obj)
/* cannot happen */ /* cannot happen */
return; return;
case MRB_TT_MAIN:
case MRB_TT_OBJECT: case MRB_TT_OBJECT:
mrb_gc_free_iv(mrb, (struct RObject*)obj); mrb_gc_free_iv(mrb, (struct RObject*)obj);
break; break;
...@@ -618,6 +620,7 @@ gc_gray_mark(mrb_state *mrb, struct RBasic *obj) ...@@ -618,6 +620,7 @@ gc_gray_mark(mrb_state *mrb, struct RBasic *obj)
} }
break; break;
case MRB_TT_MAIN:
case MRB_TT_OBJECT: case MRB_TT_OBJECT:
case MRB_TT_DATA: case MRB_TT_DATA:
children += mrb_gc_mark_iv_size(mrb, (struct RObject*)obj); children += mrb_gc_mark_iv_size(mrb, (struct RObject*)obj);
......
...@@ -306,6 +306,7 @@ init_copy(mrb_state *mrb, mrb_value dest, mrb_value obj) ...@@ -306,6 +306,7 @@ init_copy(mrb_state *mrb, mrb_value dest, mrb_value obj)
case MRB_TT_SCLASS: case MRB_TT_SCLASS:
case MRB_TT_HASH: case MRB_TT_HASH:
case MRB_TT_DATA: case MRB_TT_DATA:
case MRB_TT_MAIN:
mrb_iv_copy(mrb, dest, obj); mrb_iv_copy(mrb, dest, obj);
break; break;
......
...@@ -7,6 +7,7 @@ ...@@ -7,6 +7,7 @@
#include "mruby.h" #include "mruby.h"
#include "mruby/irep.h" #include "mruby/irep.h"
#include "mruby/variable.h" #include "mruby/variable.h"
#include "mruby/class.h"
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
...@@ -160,8 +161,11 @@ mrb_add_irep(mrb_state *mrb) ...@@ -160,8 +161,11 @@ mrb_add_irep(mrb_state *mrb)
mrb_value mrb_value
mrb_top_self(mrb_state *mrb) mrb_top_self(mrb_state *mrb)
{ {
mrb_value v; if(mrb->top_self == NULL)
{
MRB_SET_VALUE(v, MRB_TT_MAIN, value.i, 0); mrb->top_self = (mrb_value *)mrb_calloc(mrb, 1, sizeof(mrb_value));
return v; *(mrb->top_self) = mrb_class_new_instance(mrb, 0, NULL, mrb->object_class);
mrb->top_self->tt = MRB_TT_MAIN;
}
return *(mrb->top_self);
} }
...@@ -419,6 +419,7 @@ obj_iv_p(mrb_value obj) ...@@ -419,6 +419,7 @@ obj_iv_p(mrb_value obj)
case MRB_TT_SCLASS: case MRB_TT_SCLASS:
case MRB_TT_HASH: case MRB_TT_HASH:
case MRB_TT_DATA: case MRB_TT_DATA:
case MRB_TT_MAIN:
return TRUE; return TRUE;
default: default:
return FALSE; return FALSE;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment