diff options
| author | ksss <[email protected]> | 2014-05-10 00:11:51 +0900 |
|---|---|---|
| committer | ksss <[email protected]> | 2014-05-10 09:43:32 +0900 |
| commit | 7dbfe19fc67c60dad3b2347ae64ce13ffb79dbe4 (patch) | |
| tree | 980f9602e7b1d818bff45e1163e75d51619d80c7 /src/vm.c | |
| parent | e07a3731d1c7198eb5b443818c0f6a0601ca790d (diff) | |
| download | mruby-7dbfe19fc67c60dad3b2347ae64ce13ffb79dbe4.tar.gz mruby-7dbfe19fc67c60dad3b2347ae64ce13ffb79dbe4.zip | |
OP_ENTER fix segmentation fault
Diffstat (limited to 'src/vm.c')
| -rw-r--r-- | src/vm.c | 15 |
1 files changed, 9 insertions, 6 deletions
@@ -1306,16 +1306,19 @@ RETRY_TRY_BLOCK: } mrb->c->ci->argc = len; if (argc < len) { + int mlen = m2; + if (argc < m1+m2) { + if (m1 < argc) + mlen = argc - m1; + else + mlen = 0; + } regs[len+1] = *blk; /* move block */ SET_NIL_VALUE(regs[argc+1]); if (argv0 != argv) { - value_move(®s[1], argv, argc-m2); /* m1 + o */ + value_move(®s[1], argv, argc-mlen); /* m1 + o */ } - if (m2) { - int mlen = m2; - if (argc-m2 <= m1) { - mlen = argc - m1; - } + if (mlen) { value_move(®s[len-m2+1], &argv[argc-mlen], mlen); } if (r) { |
