diff options
| author | Daniel Bovensiepen <[email protected]> | 2013-08-01 15:17:34 +0800 |
|---|---|---|
| committer | Daniel Bovensiepen <[email protected]> | 2013-08-01 15:17:34 +0800 |
| commit | 16a162ec45c8ad7827e4c771c35782a9bf9a320c (patch) | |
| tree | b37ecec53147d4bee632dfbad369650f6818e18d /src/parse.y | |
| parent | 6f95cd36bbec2b5b6ed9439178c27b8196a21e4e (diff) | |
| parent | d16edc11ca9b4754a79f0fb4f481c3bd46077bac (diff) | |
| download | mruby-16a162ec45c8ad7827e4c771c35782a9bf9a320c.tar.gz mruby-16a162ec45c8ad7827e4c771c35782a9bf9a320c.zip | |
Merge remote-tracking branch 'upstream/master' into lang-doc
Diffstat (limited to 'src/parse.y')
| -rw-r--r-- | src/parse.y | 12 |
1 files changed, 11 insertions, 1 deletions
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; } |
