summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2014-05-07 08:45:50 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2014-05-07 08:45:50 +0900
commit14e5c3732ed099c164d1bb23c8ff6bdae9f53f12 (patch)
treeacae276ce7c4169b084a209ee179f6a2ad003ee0 /src
parent12915f95777448b9d8173e24824641eb7da10068 (diff)
parent0c3226db0443972eb76bde5af3f9e14bdb4dbd85 (diff)
downloadmruby-14e5c3732ed099c164d1bb23c8ff6bdae9f53f12.tar.gz
mruby-14e5c3732ed099c164d1bb23c8ff6bdae9f53f12.zip
Merge pull request #2205 from ksss/proc-m2
OP_ENTER fix variable assignment
Diffstat (limited to 'src')
-rw-r--r--src/vm.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/src/vm.c b/src/vm.c
index ae19db0b6..317b5f6b1 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -1325,16 +1325,18 @@ RETRY_TRY_BLOCK:
pc += argc - m1 - m2 + 1;
}
else {
+ int rnum = 0;
if (argv0 != argv) {
regs[len+1] = *blk; /* move block */
value_move(&regs[1], argv, m1+o);
}
if (r) {
- regs[m1+o+1] = mrb_ary_new_from_values(mrb, argc-m1-o-m2, argv+m1+o);
+ rnum = argc-m1-o-m2;
+ regs[m1+o+1] = mrb_ary_new_from_values(mrb, rnum, argv+m1+o);
}
if (m2) {
if (argc-m2 > m1) {
- value_move(&regs[m1+o+r+1], &argv[argc-m2], m2);
+ value_move(&regs[m1+o+r+1], &argv[m1+o+rnum], m2);
}
}
if (argv0 == argv) {