From bb5034f3fece4dcaf2a84538629a5e6af790c446 Mon Sep 17 00:00:00 2001 From: Joe Conigliaro Date: Thu, 12 Mar 2020 20:07:42 +1100 Subject: [PATCH] cgen: fix fixed array init assignment --- vlib/v/gen/cgen.v | 51 ++++++++++++++++++++++++++++------------------- 1 file changed, 30 insertions(+), 21 deletions(-) diff --git a/vlib/v/gen/cgen.v b/vlib/v/gen/cgen.v index da5aee96f0..26826959d5 100644 --- a/vlib/v/gen/cgen.v +++ b/vlib/v/gen/cgen.v @@ -360,12 +360,21 @@ fn (g mut Gen) gen_assign_stmt(assign_stmt ast.AssignStmt) { } } else { + mut is_fixed_array_init := false + match val { + ast.ArrayInit { + is_fixed_array_init = g.table.get_type_symbol(it.typ).kind == .array_fixed + } + else {} + } if assign_stmt.op == .decl_assign { g.write('$styp ') } g.expr(ident) - g.write(' = ') - g.expr(val) + if !is_fixed_array_init { + g.write(' = ') + g.expr(val) + } } g.writeln(';') } @@ -852,13 +861,13 @@ fn (g mut Gen) expr(node ast.Expr) { } } -fn (g mut Gen) infix_expr(it ast.InfixExpr) { +fn (g mut Gen) infix_expr(node ast.InfixExpr) { // if it.left_type == table.string_type_idx { - // g.write('/*$it.left_type str*/') + // g.write('/*$node.left_type str*/') // } // string + string, string == string etc - if it.left_type == table.string_type_idx { - fn_name := match it.op { + if node.left_type == table.string_type_idx { + fn_name := match node.op { .plus{ 'string_add(' } @@ -881,42 +890,42 @@ fn (g mut Gen) infix_expr(it ast.InfixExpr) { 'string_ge(' } else { - '/*infix_expr error*/'} + '/*node error*/'} } g.write(fn_name) - g.expr(it.left) + g.expr(node.left) g.write(', ') - g.expr(it.right) + g.expr(node.right) g.write(')') } - else if it.op == .key_in { - styp := g.typ(it.left_type) + else if node.op == .key_in { + styp := g.typ(node.left_type) g.write('_IN($styp, ') - g.expr(it.left) + g.expr(node.left) g.write(', ') - g.expr(it.right) + g.expr(node.right) g.write(')') } // arr << val - else if it.op == .left_shift && g.table.get_type_symbol(it.left_type).kind == .array { - sym := g.table.get_type_symbol(it.left_type) + else if node.op == .left_shift && g.table.get_type_symbol(node.left_type).kind == .array { + sym := g.table.get_type_symbol(node.left_type) info := sym.info as table.Array elem_type_str := g.typ(info.elem_type) // g.write('array_push(&') tmp := g.new_tmp_var() g.write('_PUSH(&') - g.expr(it.left) + g.expr(node.left) g.write(', (') - g.expr(it.right) + g.expr(node.right) g.write('), $tmp, $elem_type_str)') } else { - // if it.op == .dot { + // if node.op == .dot { // println('!! dot') // } - g.expr(it.left) - g.write(' $it.op.str() ') - g.expr(it.right) + g.expr(node.left) + g.write(' $node.op.str() ') + g.expr(node.right) } }