diff options
| author | Yukihiro Matz Matsumoto <[email protected]> | 2013-03-26 21:07:20 +0900 |
|---|---|---|
| committer | Yukihiro Matz Matsumoto <[email protected]> | 2013-03-26 21:07:20 +0900 |
| commit | 5c6be2e518db9500c10db3ed2614499444936904 (patch) | |
| tree | 5540d4fdc9bc14138a64570a1a4a5e6269e56a86 /src/state.c | |
| parent | 471ad60688be5ea8834fe4aaa404ef67cc8a9977 (diff) | |
| parent | 930e4c71c01562dc6ff03af87486acc2de81cc9b (diff) | |
| download | mruby-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.c | 12 |
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); } |
