summaryrefslogtreecommitdiffhomepage
path: root/src/state.c
diff options
context:
space:
mode:
authorYukihiro Matz Matsumoto <[email protected]>2013-03-26 21:07:20 +0900
committerYukihiro Matz Matsumoto <[email protected]>2013-03-26 21:07:20 +0900
commit5c6be2e518db9500c10db3ed2614499444936904 (patch)
tree5540d4fdc9bc14138a64570a1a4a5e6269e56a86 /src/state.c
parent471ad60688be5ea8834fe4aaa404ef67cc8a9977 (diff)
parent930e4c71c01562dc6ff03af87486acc2de81cc9b (diff)
downloadmruby-5c6be2e518db9500c10db3ed2614499444936904.tar.gz
mruby-5c6be2e518db9500c10db3ed2614499444936904.zip
Merge branch 'selftopiv' of https://github.com/carsonmcdonald/mruby into carsonmcdonald-selftopiv
Diffstat (limited to 'src/state.c')
-rw-r--r--src/state.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/src/state.c b/src/state.c
index cf0f9dee0..070237434 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);
}