diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-01-20 14:18:26 -0800 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-01-20 14:18:26 -0800 |
| commit | f53d5ee73c9da4c1296df640a3563cd5f42673b1 (patch) | |
| tree | b28e3d29b613ae058e3f90ef59d8a2d7ad750ade /src | |
| parent | 583983385b81c21f82704b116eab52d606a609f4 (diff) | |
| parent | 8f8d9fd41a57c8356b92d5e1d5b91ce0f6264b5c (diff) | |
| download | mruby-f53d5ee73c9da4c1296df640a3563cd5f42673b1.tar.gz mruby-f53d5ee73c9da4c1296df640a3563cd5f42673b1.zip | |
Merge pull request #751 from masamitsu-murase/modify_block_copy_of_op_enter
Modify handling of OP_ENTER.
Diffstat (limited to 'src')
| -rw-r--r-- | src/vm.c | 5 |
1 files changed, 4 insertions, 1 deletions
@@ -1121,6 +1121,7 @@ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self) } else { if (argv0 != argv) { + regs[len+1] = *blk; /* move block */ memmove(®s[1], argv, sizeof(mrb_value)*(m1+o)); /* m1 + o */ } if (r) { /* r */ @@ -1129,7 +1130,9 @@ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self) if (m2) { memmove(®s[m1+o+r+1], &argv[argc-m2], sizeof(mrb_value)*m2); } - regs[len+1] = *blk; /* move block */ + if (argv0 == argv) { + regs[len+1] = *blk; /* move block */ + } pc += o + 1; } JUMP; |
