blob: 9099b85d13eb853fa2b74201465b3c155f573bf4 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
import "all.hff";
extern fn malloc(n usize) *void;
struct Vec<T> {
dat *T,
len uint,
cap uint,
fn push(vec *Vec, x T) void {
if vec.len >= vec.cap {
vec.cap = (vec.len + 1) > 8 ? (vec.len + 1) * 2 : 8;
if vec.dat == #null {
vec.dat = malloc(vec.cap * sizeof T);
assert(vec.dat != #null, "malloc");
} else {
vec.dat = realloc(vec.dat, vec.cap * sizeof T);
assert(vec.dat != #null, "realloc");
}
}
vec.dat[vec.len++] = x;
}
fn clear(vec *Vec) void {
free(vec.dat);
vec.len = 0;
vec.cap = 0;
}
fn compact(vec *Vec) [#]T {
if vec.dat {
vec.cap = vec.len;
vec.dat = realloc(vec.dat, vec.cap * sizeof T);
}
return vec.dat[0::vec.len];
}
}
defmacro vec_each(x, i, v, ...body) [
{
let $v = v;
for let i = 0; i < $v.len; ++i {
let x = $v.dat[i];
{ body }
}
}
]
|