From f13ba3a9a854ae7a92a7c0bd5f07005324a74b9b Mon Sep 17 00:00:00 2001 From: yuyi Date: Thu, 21 Jan 2021 19:44:22 +0800 Subject: [PATCH] cgen: fix for_in_mut_val for maps (#8221) --- vlib/v/gen/cgen.v | 12 +++++++++++- vlib/v/tests/for_in_mut_val_test.v | 9 +++++++++ 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/vlib/v/gen/cgen.v b/vlib/v/gen/cgen.v index d2c897d17d..076a041703 100644 --- a/vlib/v/gen/cgen.v +++ b/vlib/v/gen/cgen.v @@ -1362,11 +1362,21 @@ fn (mut g Gen) for_in(it ast.ForInStmt) { g.write(' = (*(voidptr*)') } else { val_styp := g.typ(it.val_type) - g.write('\t$val_styp ${c_name(it.val_var)} = (*($val_styp*)') + if it.val_type.is_ptr() { + g.write('\t$val_styp ${c_name(it.val_var)} = &(*($val_styp)') + } else { + g.write('\t$val_styp ${c_name(it.val_var)} = (*($val_styp*)') + } } g.writeln('DenseArray_value(&$atmp${arw_or_pt}key_values, $idx));') } + if it.val_is_mut { + g.for_in_mul_val_name = it.val_var + } g.stmts(it.stmts) + if it.val_is_mut { + g.for_in_mul_val_name = '' + } if it.key_type == table.string_type && !g.is_builtin_mod { // g.writeln('string_free(&$key);') } diff --git a/vlib/v/tests/for_in_mut_val_test.v b/vlib/v/tests/for_in_mut_val_test.v index ab4fa869f1..7ad6053fe6 100644 --- a/vlib/v/tests/for_in_mut_val_test.v +++ b/vlib/v/tests/for_in_mut_val_test.v @@ -49,3 +49,12 @@ fn test_for_in_mut_val_of_map() { println(m) assert '$m' == "{'hello': [2, 4, 6]}" } + +fn test_for_in_mut_val_of_map_direct() { + mut m := {'foo': 1, 'bar': 2} + for _, mut j in m { + j = 3 + } + println(m) + assert '$m' == "{'foo': 3, 'bar': 3}" +}