From b4ad174b7f5f87bfbae18a1e1e9321414aef4643 Mon Sep 17 00:00:00 2001 From: yuyi Date: Fri, 12 Jun 2020 17:42:26 +0800 Subject: [PATCH] array: fix multiple array.repeat index error --- vlib/builtin/array.v | 9 ++++++++- vlib/builtin/array_test.v | 4 ++++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/vlib/builtin/array.v b/vlib/builtin/array.v index 7cead83589..aedba056e6 100644 --- a/vlib/builtin/array.v +++ b/vlib/builtin/array.v @@ -119,7 +119,14 @@ pub fn (a array) repeat(count int) array { cap: count * a.len } for i in 0..count { - C.memcpy(byteptr(arr.data) + i * a.len * a.element_size, byteptr(a.data), a.len * a.element_size) + if a.len > 0 && a.element_size == sizeof(array) { + ary := array{} + C.memcpy(&ary, a.data, sizeof(array)) + ary_clone := ary.clone() + C.memcpy(byteptr(arr.data) + i * a.len * a.element_size, &ary_clone, a.len * a.element_size) + } else { + C.memcpy(byteptr(arr.data) + i * a.len * a.element_size, byteptr(a.data), a.len * a.element_size) + } } return arr } diff --git a/vlib/builtin/array_test.v b/vlib/builtin/array_test.v index c7ebd82f46..f6f8fab9f3 100644 --- a/vlib/builtin/array_test.v +++ b/vlib/builtin/array_test.v @@ -821,4 +821,8 @@ fn test_mutli_array_index() { mut a := [][]int{len:2, init: []int{len:3, init:0}} a[0][0] = 1 assert '$a' == '[[1, 0, 0], [0, 0, 0]]' + + mut b := [[0].repeat(3)].repeat(2) + b[0][0] = 1 + assert '$b' == '[[1, 0, 0], [0, 0, 0]]' }