summaryrefslogtreecommitdiffhomepage
path: root/mrbgems
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2013-11-05 00:13:01 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2013-11-05 00:13:01 +0900
commitf80401de6c9b7dd9e0676c4414aae7a6e033ac5f (patch)
tree27663cfee57ca8652671087e01b99d69f814a32a /mrbgems
parente386760cc7b7958a8948b0a23b35b3a9df30c354 (diff)
parent82c5b486e0d788aa7a391574c59959da2216990e (diff)
downloadmruby-f80401de6c9b7dd9e0676c4414aae7a6e033ac5f.tar.gz
mruby-f80401de6c9b7dd9e0676c4414aae7a6e033ac5f.zip
resolved conflicts and updated to latest return value change of mrb_generate_code()
Diffstat (limited to 'mrbgems')
-rw-r--r--mrbgems/mruby-bin-mirb/tools/mirb/mirb.c12
-rw-r--r--mrbgems/mruby-bin-mruby/tools/mruby/mruby.c2
2 files changed, 10 insertions, 4 deletions
diff --git a/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c b/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c
index c300f3d35..f5e5900f0 100644
--- a/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c
+++ b/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c
@@ -255,6 +255,8 @@ main(int argc, char **argv)
int n;
int code_block_open = FALSE;
int ai;
+ int first_command = 1;
+ unsigned int nregs;
/* new interpreter instance */
mrb = mrb_open();
@@ -363,10 +365,13 @@ main(int argc, char **argv)
/* generate bytecode */
struct RProc *proc = mrb_generate_code(mrb, parser);
+ /* pass a proc for evaulation */
+ nregs = first_command ? 0: proc->body.irep->nregs;
/* evaluate the bytecode */
- result = mrb_run(mrb,
- /* pass a proc for evaulation */
- proc, mrb_top_self(mrb));
+ result = mrb_context_run(mrb,
+ proc,
+ mrb_top_self(mrb),
+ nregs);
/* did an exception occur? */
if (mrb->exc) {
p(mrb, mrb_obj_value(mrb->exc), 0);
@@ -386,6 +391,7 @@ main(int argc, char **argv)
}
mrb_parser_free(parser);
cxt->lineno++;
+ first_command = 0;
}
mrbc_context_free(mrb, cxt);
mrb_close(mrb);
diff --git a/mrbgems/mruby-bin-mruby/tools/mruby/mruby.c b/mrbgems/mruby-bin-mruby/tools/mruby/mruby.c
index baeb95993..290f9e25d 100644
--- a/mrbgems/mruby-bin-mruby/tools/mruby/mruby.c
+++ b/mrbgems/mruby-bin-mruby/tools/mruby/mruby.c
@@ -203,7 +203,7 @@ main(int argc, char **argv)
fprintf(stderr, "failed to load mrb file: %s\n", args.cmdline);
}
else if (!args.check_syntax) {
- mrb_run(mrb, mrb_proc_new(mrb, mrb->irep[n]), mrb_top_self(mrb));
+ mrb_context_run(mrb, mrb_proc_new(mrb, mrb->irep[n]), mrb_top_self(mrb), 0);
n = 0;
if (mrb->exc) {
mrb_print_error(mrb);