From faa55b46dee3b24f655289a4ccee4a3c4cbeec70 Mon Sep 17 00:00:00 2001 From: yuyi Date: Sat, 2 Apr 2022 23:00:59 +0800 Subject: [PATCH] cgen: fix array of fixed array (fix #13895) (#13901) --- vlib/v/gen/c/infix_expr.v | 11 ++++++++--- vlib/v/tests/array_of_fixed_array_test.v | 15 +++++++++++++++ 2 files changed, 23 insertions(+), 3 deletions(-) create mode 100644 vlib/v/tests/array_of_fixed_array_test.v diff --git a/vlib/v/gen/c/infix_expr.v b/vlib/v/gen/c/infix_expr.v index 61a47508da..04140453e2 100644 --- a/vlib/v/gen/c/infix_expr.v +++ b/vlib/v/gen/c/infix_expr.v @@ -613,9 +613,8 @@ fn (mut g Gen) infix_expr_left_shift_op(node ast.InfixExpr) { // push a single element elem_type_str := g.typ(array_info.elem_type) elem_sym := g.table.sym(array_info.elem_type) + elem_is_array_var := elem_sym.kind in [.array, .array_fixed] && node.right is ast.Ident g.write('array_push${noscan}((array*)') - if node.left_type.has_flag(.shared_f) && !node.left_type.deref().is_ptr() { - } if !left.typ.is_ptr() || (node.left_type.has_flag(.shared_f) && !node.left_type.deref().is_ptr()) { g.write('&') @@ -626,6 +625,8 @@ fn (mut g Gen) infix_expr_left_shift_op(node ast.InfixExpr) { } if elem_sym.kind == .function { g.write(', _MOV((voidptr[]){ ') + } else if elem_is_array_var { + g.write(', &') } else { g.write(', _MOV(($elem_type_str[]){ ') } @@ -638,7 +639,11 @@ fn (mut g Gen) infix_expr_left_shift_op(node ast.InfixExpr) { if needs_clone { g.write(')') } - g.write(' }))') + if elem_is_array_var { + g.write(')') + } else { + g.write(' }))') + } } } else { g.gen_plain_infix_expr(node) diff --git a/vlib/v/tests/array_of_fixed_array_test.v b/vlib/v/tests/array_of_fixed_array_test.v new file mode 100644 index 0000000000..3d396724ac --- /dev/null +++ b/vlib/v/tests/array_of_fixed_array_test.v @@ -0,0 +1,15 @@ +fn test_array_of_fixed_array() { + mut arr := [][3]int{} + + fixed_arr1 := [3]int{} + arr << fixed_arr1 + + fixed_arr2 := [1, 2, 3]! + arr << fixed_arr2 + + println(arr) + + assert arr.len == 2 + assert '${arr[0]}' == '[0, 0, 0]' + assert '${arr[1]}' == '[1, 2, 3]' +}