diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2021-07-21 13:20:34 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2021-07-21 13:20:34 +0900 |
| commit | e42f192827102a6aa7a398d0360e310ed2ae20d2 (patch) | |
| tree | 0a1acdc15f99a9dc59b7875b09be01de300f5b78 | |
| parent | 2ef6e944896072687bdd28c846a62e5be37eec48 (diff) | |
| download | mruby-e42f192827102a6aa7a398d0360e310ed2ae20d2.tar.gz mruby-e42f192827102a6aa7a398d0360e310ed2ae20d2.zip | |
codegen.c: skip `-@` call if the argument is a literal integer.
| -rw-r--r-- | mrbgems/mruby-compiler/core/codegen.c | 19 | ||||
| -rw-r--r-- | mrbgems/mruby-compiler/core/parse.y | 12 | ||||
| -rw-r--r-- | mrbgems/mruby-compiler/core/y.tab.c | 12 |
3 files changed, 29 insertions, 14 deletions
diff --git a/mrbgems/mruby-compiler/core/codegen.c b/mrbgems/mruby-compiler/core/codegen.c index b173a83c5..57b722cbf 100644 --- a/mrbgems/mruby-compiler/core/codegen.c +++ b/mrbgems/mruby-compiler/core/codegen.c @@ -858,6 +858,21 @@ gen_int(codegen_scope *s, uint16_t dst, mrb_int i) } } +static void +gen_uminus(codegen_scope *s, uint16_t dst) +{ + struct mrb_insn_data data = mrb_last_insn(s); + int32_t n; + + if (get_int_operand(&data, &n)) { + s->pc = s->lastpc; + gen_int(s, dst, -n); + } + else { + genop_3(s, OP_SEND, dst, new_sym(s, MRB_OPSYM_2(s->mrb, minus)), 0); + } +} + static int node_len(node *tree) { @@ -2695,10 +2710,10 @@ codegen(codegen_scope *s, node *tree, int val) default: if (val) { - int sym = new_sym(s, MRB_OPSYM_2(s->mrb, minus)); codegen(s, tree, VAL); pop(); - genop_3(s, OP_SEND, cursp(), sym, 0); + push_n(2);pop_n(2); /* space for receiver&block */ + gen_uminus(s, cursp()); push(); } else { diff --git a/mrbgems/mruby-compiler/core/parse.y b/mrbgems/mruby-compiler/core/parse.y index 7d9db4a2b..00d40ec64 100644 --- a/mrbgems/mruby-compiler/core/parse.y +++ b/mrbgems/mruby-compiler/core/parse.y @@ -1248,7 +1248,7 @@ call_with_block(parser_state *p, node *a, node *b) } static node* -negate_lit(parser_state *p, node *n) +new_negate(parser_state *p, node *n) { return cons((node*)NODE_NEGATE, n); } @@ -2292,11 +2292,11 @@ arg : lhs '=' arg_rhs } | tUMINUS_NUM tINTEGER tPOW arg { - $$ = call_uni_op(p, call_bin_op(p, $2, "**", $4), "-@"); + $$ = new_negate(p, call_bin_op(p, $2, "**", $4)); } | tUMINUS_NUM tFLOAT tPOW arg { - $$ = call_uni_op(p, call_bin_op(p, $2, "**", $4), "-@"); + $$ = new_negate(p, call_bin_op(p, $2, "**", $4)); } | tUPLUS arg { @@ -2304,7 +2304,7 @@ arg : lhs '=' arg_rhs } | tUMINUS arg { - $$ = call_uni_op(p, $2, "-@"); + $$ = new_negate(p, $2); } | arg '|' arg { @@ -3463,11 +3463,11 @@ numeric : tINTEGER | tFLOAT | tUMINUS_NUM tINTEGER %prec tLOWEST { - $$ = negate_lit(p, $2); + $$ = new_negate(p, $2); } | tUMINUS_NUM tFLOAT %prec tLOWEST { - $$ = negate_lit(p, $2); + $$ = new_negate(p, $2); } ; diff --git a/mrbgems/mruby-compiler/core/y.tab.c b/mrbgems/mruby-compiler/core/y.tab.c index 9cd36ec7b..4b1fabbf5 100644 --- a/mrbgems/mruby-compiler/core/y.tab.c +++ b/mrbgems/mruby-compiler/core/y.tab.c @@ -1311,7 +1311,7 @@ call_with_block(parser_state *p, node *a, node *b) } static node* -negate_lit(parser_state *p, node *n) +new_negate(parser_state *p, node *n) { return cons((node*)NODE_NEGATE, n); } @@ -7376,7 +7376,7 @@ yyreduce: case 219: #line 2294 "mrbgems/mruby-compiler/core/parse.y" { - (yyval.nd) = call_uni_op(p, call_bin_op(p, (yyvsp[-2].nd), "**", (yyvsp[0].nd)), "-@"); + (yyval.nd) = new_negate(p, call_bin_op(p, (yyvsp[-2].nd), "**", (yyvsp[0].nd))); } #line 7382 "mrbgems/mruby-compiler/core/y.tab.c" break; @@ -7384,7 +7384,7 @@ yyreduce: case 220: #line 2298 "mrbgems/mruby-compiler/core/parse.y" { - (yyval.nd) = call_uni_op(p, call_bin_op(p, (yyvsp[-2].nd), "**", (yyvsp[0].nd)), "-@"); + (yyval.nd) = new_negate(p, call_bin_op(p, (yyvsp[-2].nd), "**", (yyvsp[0].nd))); } #line 7390 "mrbgems/mruby-compiler/core/y.tab.c" break; @@ -7400,7 +7400,7 @@ yyreduce: case 222: #line 2306 "mrbgems/mruby-compiler/core/parse.y" { - (yyval.nd) = call_uni_op(p, (yyvsp[0].nd), "-@"); + (yyval.nd) = new_negate(p, (yyvsp[0].nd)); } #line 7406 "mrbgems/mruby-compiler/core/y.tab.c" break; @@ -9183,7 +9183,7 @@ yyreduce: case 477: #line 3465 "mrbgems/mruby-compiler/core/parse.y" { - (yyval.nd) = negate_lit(p, (yyvsp[0].nd)); + (yyval.nd) = new_negate(p, (yyvsp[0].nd)); } #line 9189 "mrbgems/mruby-compiler/core/y.tab.c" break; @@ -9191,7 +9191,7 @@ yyreduce: case 478: #line 3469 "mrbgems/mruby-compiler/core/parse.y" { - (yyval.nd) = negate_lit(p, (yyvsp[0].nd)); + (yyval.nd) = new_negate(p, (yyvsp[0].nd)); } #line 9197 "mrbgems/mruby-compiler/core/y.tab.c" break; |
