summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2014-05-30 15:25:58 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2014-05-30 15:25:58 +0900
commit6bf1ee78c8cdc5c1b0265694c404ada0ec32cb28 (patch)
tree67d486cb32408c2a579796eca0bfa8401a4f7506
parentf38e53eccacbd413bf567a97e6e0ec2941e2e85c (diff)
downloadmruby-6bf1ee78c8cdc5c1b0265694c404ada0ec32cb28.tar.gz
mruby-6bf1ee78c8cdc5c1b0265694c404ada0ec32cb28.zip
add internal function mrb_toplevel_run_keep() to keep stack contents; close #2326
-rw-r--r--include/mruby/compile.h2
-rw-r--r--src/parse.y4
-rw-r--r--src/vm.c12
3 files changed, 14 insertions, 4 deletions
diff --git a/include/mruby/compile.h b/include/mruby/compile.h
index 9af9c39c6..7f896e1fd 100644
--- a/include/mruby/compile.h
+++ b/include/mruby/compile.h
@@ -35,6 +35,8 @@ void mrbc_context_free(mrb_state *mrb, mrbc_context *cxt);
const char *mrbc_filename(mrb_state *mrb, mrbc_context *c, const char *s);
void mrbc_partial_hook(mrb_state *mrb, mrbc_context *c, int (*partial_hook)(struct mrb_parser_state*), void*data);
+mrb_value mrb_toplevel_run_keep(mrb_state*, struct RProc*, unsigned int);
+
/* AST node structure */
typedef struct mrb_ast_node {
struct mrb_ast_node *car, *cdr;
diff --git a/src/parse.y b/src/parse.y
index b3f5f6664..c6795fb65 100644
--- a/src/parse.y
+++ b/src/parse.y
@@ -5522,6 +5522,7 @@ load_exec(mrb_state *mrb, parser_state *p, mrbc_context *c)
struct RClass *target = mrb->object_class;
struct RProc *proc;
mrb_value v;
+ unsigned int keep = 0;
if (!p) {
return mrb_undef_value();
@@ -5555,12 +5556,13 @@ load_exec(mrb_state *mrb, parser_state *p, mrbc_context *c)
if (c->target_class) {
target = c->target_class;
}
+ keep = c->slen + 1;
}
proc->target_class = target;
if (mrb->c->ci) {
mrb->c->ci->target_class = target;
}
- v = mrb_toplevel_run(mrb, proc);
+ v = mrb_toplevel_run_keep(mrb, proc, keep);
if (mrb->exc) return mrb_nil_value();
return v;
}
diff --git a/src/vm.c b/src/vm.c
index 649596713..d604e5d9e 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -2402,19 +2402,25 @@ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self)
}
mrb_value
-mrb_toplevel_run(mrb_state *mrb, struct RProc *proc)
+mrb_toplevel_run_keep(mrb_state *mrb, struct RProc *proc, unsigned int stack_keep)
{
mrb_callinfo *ci;
mrb_value v;
if (!mrb->c->cibase || mrb->c->ci == mrb->c->cibase) {
- return mrb_context_run(mrb, proc, mrb_top_self(mrb), 0);
+ return mrb_context_run(mrb, proc, mrb_top_self(mrb), stack_keep);
}
ci = cipush(mrb);
ci->acc = CI_ACC_SKIP;
ci->target_class = mrb->object_class;
- v = mrb_context_run(mrb, proc, mrb_top_self(mrb), 0);
+ v = mrb_context_run(mrb, proc, mrb_top_self(mrb), stack_keep);
cipop(mrb);
return v;
}
+
+mrb_value
+mrb_toplevel_run(mrb_state *mrb, struct RProc *proc)
+{
+ return mrb_toplevel_run_keep(mrb, proc, 0);
+}