summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorDaniel Bovensiepen <[email protected]>2013-08-01 15:17:34 +0800
committerDaniel Bovensiepen <[email protected]>2013-08-01 15:17:34 +0800
commit16a162ec45c8ad7827e4c771c35782a9bf9a320c (patch)
treeb37ecec53147d4bee632dfbad369650f6818e18d /src
parent6f95cd36bbec2b5b6ed9439178c27b8196a21e4e (diff)
parentd16edc11ca9b4754a79f0fb4f481c3bd46077bac (diff)
downloadmruby-16a162ec45c8ad7827e4c771c35782a9bf9a320c.tar.gz
mruby-16a162ec45c8ad7827e4c771c35782a9bf9a320c.zip
Merge remote-tracking branch 'upstream/master' into lang-doc
Diffstat (limited to 'src')
-rw-r--r--src/class.c1
-rw-r--r--src/codegen.c1
-rw-r--r--src/parse.y12
-rw-r--r--src/vm.c2
4 files changed, 12 insertions, 4 deletions
diff --git a/src/class.c b/src/class.c
index d67a4af3e..4994b0045 100644
--- a/src/class.c
+++ b/src/class.c
@@ -311,7 +311,6 @@ mrb_define_method_id(mrb_state *mrb, struct RClass *c, mrb_sym mid, mrb_func_t f
int ai = mrb_gc_arena_save(mrb);
p = mrb_proc_new_cfunc(mrb, func);
- p->target_class = c;
mrb_define_method_raw(mrb, c, mid, p);
mrb_gc_arena_restore(mrb, ai);
}
diff --git a/src/codegen.c b/src/codegen.c
index 5681ce03a..34ccd616f 100644
--- a/src/codegen.c
+++ b/src/codegen.c
@@ -1551,7 +1551,6 @@ codegen(codegen_scope *s, node *tree, int val)
// variable rhs
codegen(s, t, VAL);
gen_vmassignment(s, tree->car, rhs, val);
- if (!val) pop();
}
}
break;
diff --git a/src/parse.y b/src/parse.y
index 9a83d5cbd..4fa9e70de 100644
--- a/src/parse.y
+++ b/src/parse.y
@@ -5210,6 +5210,8 @@ mrb_parse_string(mrb_state *mrb, const char *s, mrbc_context *c)
static mrb_value
load_exec(mrb_state *mrb, parser_state *p, mrbc_context *c)
{
+ struct RClass *target = mrb->object_class;
+ struct RProc *proc;
int n;
mrb_value v;
@@ -5243,8 +5245,16 @@ load_exec(mrb_state *mrb, parser_state *p, mrbc_context *c)
if (c) {
if (c->dump_result) codedump_all(mrb, n);
if (c->no_exec) return mrb_fixnum_value(n);
+ if (c->target_class) {
+ target = c->target_class;
+ }
+ }
+ proc = mrb_proc_new(mrb, mrb->irep[n]);
+ proc->target_class = target;
+ if (mrb->c->ci) {
+ mrb->c->ci->target_class = target;
}
- v = mrb_run(mrb, mrb_proc_new(mrb, mrb->irep[n]), mrb_top_self(mrb));
+ v = mrb_run(mrb, proc, mrb_top_self(mrb));
if (mrb->exc) return mrb_nil_value();
return v;
}
diff --git a/src/vm.c b/src/vm.c
index 3cdf57551..4d99ad413 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -386,9 +386,9 @@ mrb_funcall_with_block(mrb_state *mrb, mrb_value self, mrb_sym mid, int argc, mr
if (MRB_PROC_CFUNC_P(p)) {
int ai = mrb_gc_arena_save(mrb);
val = p->body.func(mrb, self);
- mrb_gc_arena_restore(mrb, ai);
mrb->c->stack = mrb->c->stbase + mrb->c->ci->stackidx;
cipop(mrb);
+ mrb_gc_arena_restore(mrb, ai);
}
else {
val = mrb_run(mrb, p, self);