aboutsummaryrefslogtreecommitdiff
path: root/src/vec.hff
blob: fb44196e4b5574ba56853f0b3f1f8c7bceb08005 (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 }
      }
   }
]