Skip to content

Commit b961f92

Browse files
committed
fix: do not mutate std.removeAt parameters
Resolves #807
1 parent bfa7272 commit b961f92

File tree

4 files changed

+13
-1
lines changed

4 files changed

+13
-1
lines changed

builtins.go

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2485,6 +2485,7 @@ func builtinRemove(i *interpreter, arrv value, ev value) (value, error) {
24852485
}
24862486

24872487
func builtinRemoveAt(i *interpreter, arrv value, idxv value) (value, error) {
2488+
var newArr []*cachedThunk
24882489
arr, err := i.getArray(arrv)
24892490
if err != nil {
24902491
return nil, err
@@ -2494,7 +2495,8 @@ func builtinRemoveAt(i *interpreter, arrv value, idxv value) (value, error) {
24942495
return nil, err
24952496
}
24962497

2497-
newArr := append(arr.elements[:idx], arr.elements[idx+1:]...)
2498+
newArr = append(newArr, arr.elements[:idx]...)
2499+
newArr = append(newArr, arr.elements[idx+1:]...)
24982500
return makeValueArray(newArr), nil
24992501
}
25002502

testdata/builtinRemoveAt2.golden

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
[
2+
"quux",
3+
"foo",
4+
"bar",
5+
"foo",
6+
"bar"
7+
]

testdata/builtinRemoveAt2.jsonnet

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
local a = ['quux','foo','bar'];
2+
local b = std.removeAt(a,0);
3+
a+b

testdata/builtinRemoveAt2.linter.golden

Whitespace-only changes.

0 commit comments

Comments
 (0)