diff options
author | Eric N. Vander Weele <ericvw@gmail.com> | 2023-03-20 13:51:31 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-03-20 18:51:31 +0100 |
commit | da7833c68bd8a3fea4b380e2a0e84753812450fe (patch) | |
tree | 653b80af266c62f0e57e4659b018c8772df66857 /tests/stdlib | |
parent | 285ea3c48e7b01fe6beecf794e9e8cc904c27889 (diff) | |
download | Nim-da7833c68bd8a3fea4b380e2a0e84753812450fe.tar.gz |
fixes #21538; expand len template parameter once in newSeqWith (#21543)
`len` could contain side effects and may result in different values when substituted twice in the template expansion. Instead, capture the result of substituting `len` once. closes: #21538
Diffstat (limited to 'tests/stdlib')
-rw-r--r-- | tests/stdlib/tsequtils.nim | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/tests/stdlib/tsequtils.nim b/tests/stdlib/tsequtils.nim index 176c00214..2b9ef5d6e 100644 --- a/tests/stdlib/tsequtils.nim +++ b/tests/stdlib/tsequtils.nim @@ -388,6 +388,11 @@ block: # newSeqWith tests seq2D[0][1] = true doAssert seq2D == @[@[true, true], @[true, false], @[false, false], @[false, false]] +block: # bug #21538 + var x: seq[int] = @[2, 4] + var y = newSeqWith(x.pop(), true) + doAssert y == @[true, true, true, true] + block: # mapLiterals tests let x = mapLiterals([0.1, 1.2, 2.3, 3.4], int) doAssert x is array[4, int] |