Skip to content

Commit 930e4c7

Browse files
Make mrb_top_self return a real instance.
1 parent 84161ed commit 930e4c7

5 files changed

Lines changed: 17 additions & 6 deletions

File tree

include/mruby.h

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -74,6 +74,7 @@ typedef struct mrb_state {
7474

7575
mrb_value *stack;
7676
mrb_value *stbase, *stend;
77+
mrb_value *top_self;
7778

7879
mrb_callinfo *ci;
7980
mrb_callinfo *cibase, *ciend;
@@ -138,6 +139,7 @@ typedef struct mrb_state {
138139
struct RClass *eStandardError_class;
139140

140141
void *ud; /* auxiliary data */
142+
141143
} mrb_state;
142144

143145
typedef mrb_value (*mrb_func_t)(mrb_state *mrb, mrb_value);
@@ -238,11 +240,11 @@ int mrb_gc_arena_save(mrb_state*);
238240
void mrb_gc_arena_restore(mrb_state*,int);
239241
void mrb_gc_mark(mrb_state*,struct RBasic*);
240242
#define mrb_gc_mark_value(mrb,val) do {\
241-
if (mrb_type(val) >= MRB_TT_OBJECT) mrb_gc_mark((mrb), mrb_basic_ptr(val));\
243+
if (mrb_type(val) >= MRB_TT_MAIN) mrb_gc_mark((mrb), mrb_basic_ptr(val));\
242244
} while (0)
243245
void mrb_field_write_barrier(mrb_state *, struct RBasic*, struct RBasic*);
244246
#define mrb_field_write_barrier_value(mrb, obj, val) do{\
245-
if ((val.tt >= MRB_TT_OBJECT)) mrb_field_write_barrier((mrb), (obj), mrb_basic_ptr(val));\
247+
if ((val.tt >= MRB_TT_MAIN)) mrb_field_write_barrier((mrb), (obj), mrb_basic_ptr(val));\
246248
} while (0)
247249
void mrb_write_barrier(mrb_state *, struct RBasic*);
248250

src/gc.c

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -392,6 +392,7 @@ gc_mark_children(mrb_state *mrb, struct RBasic *obj)
392392
}
393393
/* fall through */
394394

395+
case MRB_TT_MAIN:
395396
case MRB_TT_OBJECT:
396397
case MRB_TT_DATA:
397398
mrb_gc_mark_iv(mrb, (struct RObject*)obj);
@@ -478,6 +479,7 @@ obj_free(mrb_state *mrb, struct RBasic *obj)
478479
/* cannot happen */
479480
return;
480481

482+
case MRB_TT_MAIN:
481483
case MRB_TT_OBJECT:
482484
mrb_gc_free_iv(mrb, (struct RObject*)obj);
483485
break;
@@ -618,6 +620,7 @@ gc_gray_mark(mrb_state *mrb, struct RBasic *obj)
618620
}
619621
break;
620622

623+
case MRB_TT_MAIN:
621624
case MRB_TT_OBJECT:
622625
case MRB_TT_DATA:
623626
children += mrb_gc_mark_iv_size(mrb, (struct RObject*)obj);

src/kernel.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -306,6 +306,7 @@ init_copy(mrb_state *mrb, mrb_value dest, mrb_value obj)
306306
case MRB_TT_SCLASS:
307307
case MRB_TT_HASH:
308308
case MRB_TT_DATA:
309+
case MRB_TT_MAIN:
309310
mrb_iv_copy(mrb, dest, obj);
310311
break;
311312

src/state.c

Lines changed: 8 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77
#include "mruby.h"
88
#include "mruby/irep.h"
99
#include "mruby/variable.h"
10+
#include "mruby/class.h"
1011
#include <stdlib.h>
1112
#include <string.h>
1213

@@ -160,8 +161,11 @@ mrb_add_irep(mrb_state *mrb)
160161
mrb_value
161162
mrb_top_self(mrb_state *mrb)
162163
{
163-
mrb_value v;
164-
165-
MRB_SET_VALUE(v, MRB_TT_MAIN, value.i, 0);
166-
return v;
164+
if(mrb->top_self == NULL)
165+
{
166+
mrb->top_self = (mrb_value *)mrb_calloc(mrb, 1, sizeof(mrb_value));
167+
*(mrb->top_self) = mrb_class_new_instance(mrb, 0, NULL, mrb->object_class);
168+
mrb->top_self->tt = MRB_TT_MAIN;
169+
}
170+
return *(mrb->top_self);
167171
}

src/variable.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -419,6 +419,7 @@ obj_iv_p(mrb_value obj)
419419
case MRB_TT_SCLASS:
420420
case MRB_TT_HASH:
421421
case MRB_TT_DATA:
422+
case MRB_TT_MAIN:
422423
return TRUE;
423424
default:
424425
return FALSE;

0 commit comments

Comments
 (0)