summaryrefslogtreecommitdiffhomepage
path: root/src/codegen.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2013-02-26 18:10:02 -0800
committerYukihiro "Matz" Matsumoto <[email protected]>2013-02-26 18:10:02 -0800
commitced8fea305806cb955677d87a574098afc4e2143 (patch)
tree5d0b79aef366bdc022e31fd385695cfbcf1abc84 /src/codegen.c
parent2a932441379f242a08e6f3783f2cd2f6204e8193 (diff)
parentf413e6881c2e325d10c041d03da695ad00b91830 (diff)
downloadmruby-ced8fea305806cb955677d87a574098afc4e2143.tar.gz
mruby-ced8fea305806cb955677d87a574098afc4e2143.zip
Merge pull request #898 from masamitsu-murase/modify_return_value
Modify handling of NODE_RETURN and NODE_NEXT.
Diffstat (limited to 'src/codegen.c')
-rw-r--r--src/codegen.c14
1 files changed, 11 insertions, 3 deletions
diff --git a/src/codegen.c b/src/codegen.c
index ce9967f89..59fde4cb8 100644
--- a/src/codegen.c
+++ b/src/codegen.c
@@ -1570,15 +1570,20 @@ codegen(codegen_scope *s, node *tree, int val)
break;
case NODE_RETURN:
- codegen(s, tree, VAL);
- pop();
+ if (tree) {
+ codegen(s, tree, VAL);
+ pop();
+ }
+ else {
+ genop(s, MKOP_A(OP_LOADNIL, cursp()));
+ }
if (s->loop) {
genop(s, MKOP_AB(OP_RETURN, cursp(), OP_R_RETURN));
}
else {
genop_peep(s, MKOP_AB(OP_RETURN, cursp(), OP_R_NORMAL), NOVAL);
}
- push();
+ if (val) push();
break;
case NODE_YIELD:
@@ -1630,6 +1635,9 @@ codegen(codegen_scope *s, node *tree, int val)
codegen(s, tree, VAL);
pop();
}
+ else {
+ genop(s, MKOP_A(OP_LOADNIL, cursp()));
+ }
genop_peep(s, MKOP_AB(OP_RETURN, cursp(), OP_R_NORMAL), NOVAL);
}
if (val) push();