mirror of
https://github.com/status-im/nim-ranges.git
synced 2025-01-15 07:14:27 +00:00
5145020c30
* the length is stored as int32 * negative indexing is now supported with arr[^idx] * toOpenArray supports slicing * raise operations extracted in procs in order to reduce code bloat A large disclaimer has been added warning about the possible risks of using the StackArray type.
37 lines
843 B
Nim
37 lines
843 B
Nim
import
|
|
unittest, math,
|
|
../ranges/[stackarrays, ptr_arith]
|
|
|
|
suite "Stack arrays":
|
|
test "Basic operations work as expected":
|
|
var arr = allocStackArray(int, 10)
|
|
check:
|
|
type(arr[0]) is int
|
|
arr.len == 10
|
|
|
|
# all items should be initially zero
|
|
for i in arr: check i == 0
|
|
for i in 0 .. arr.high: check arr[i] == 0
|
|
|
|
arr[0] = 3
|
|
arr[5] = 10
|
|
arr[9] = 6
|
|
|
|
check:
|
|
sum(arr.toOpenArray) == 19
|
|
arr[5] == 10
|
|
arr[^1] == 6
|
|
cast[ptr int](shift(addr arr[0], 5))[] == 10
|
|
|
|
test "Allocating with a negative size throws a RangeError":
|
|
expect RangeError:
|
|
var arr = allocStackArray(string, -1)
|
|
|
|
test "The array access is bounds-checked":
|
|
var arr = allocStackArray(string, 3)
|
|
arr[2] = "test"
|
|
check arr[2] == "test"
|
|
expect RangeError:
|
|
arr[3] = "another test"
|
|
|