From 5e1a6a2cc296dfbe9e311870d24dfcbc0aee1fad Mon Sep 17 00:00:00 2001 From: "Yukihiro \"Matz\" Matsumoto" Date: Thu, 25 May 2017 12:40:49 +0900 Subject: Make `gen_assignment()` to support `NODE_SCALL`; ref #3658 --- mrbgems/mruby-compiler/core/codegen.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'mrbgems/mruby-compiler/core/codegen.c') diff --git a/mrbgems/mruby-compiler/core/codegen.c b/mrbgems/mruby-compiler/core/codegen.c index d04ff44ba..7acbdaee3 100644 --- a/mrbgems/mruby-compiler/core/codegen.c +++ b/mrbgems/mruby-compiler/core/codegen.c @@ -956,7 +956,7 @@ gen_assignment(codegen_scope *s, node *tree, int sp, int val) int type = (intptr_t)tree->car; tree = tree->cdr; - switch ((intptr_t)type) { + switch (type) { case NODE_GVAR: idx = new_sym(s, sym(tree)); genop_peep(s, MKOP_ABx(OP_SETGLOBAL, sp, idx), val); @@ -1006,8 +1006,10 @@ gen_assignment(codegen_scope *s, node *tree, int sp, int val) break; case NODE_CALL: + case NODE_SCALL: push(); - gen_call(s, tree, attrsym(s, sym(tree->cdr->car)), sp, NOVAL, 0); + gen_call(s, tree, attrsym(s, sym(tree->cdr->car)), sp, NOVAL, + type == NODE_SCALL); pop(); if (val) { genop_peep(s, MKOP_AB(OP_MOVE, cursp(), sp), val); -- cgit v1.2.3