5 #define VectorDef(name, type, defcap) \
6 struct Vector ## name { \
11 typedef struct Vector ## name Vector ## name; \
12 Vector ## name * allocVector ## name(uint capacity); \
13 Vector ## name * allocDefVector ## name(); \
14 Vector ## name * allocVectorArray ## name(type * array, uint capacity); \
15 void pushVector ## name(Vector ## name *vector, type item); \
16 type getVector ## name(Vector ## name *vector, uint index); \
17 void setVector ## name(Vector ## name *vector, uint index, type item); \
18 uint getSize ##name(Vector ##name *vector); \
19 void freeVector ##name(Vector ##name *vector);
21 #define VectorImpl(name, type, defcap) \
22 Vector ## name * allocDefVector ## name() { \
23 return allocVector ## name(defcap); \
25 Vector ## name * allocVector ## name(uint capacity) { \
26 Vector ## name * tmp = (Vector ## name *) ourmalloc(sizeof(type)); \
28 tmp->capacity = capacity; \
29 tmp->array = (type *) ourcalloc(1, sizeof(type) * capacity); \
32 Vector ## name * allocVectorArray ## name(uint capacity, type * array) { \
33 Vector ## name * tmp = allocVector ## name(capacity); \
34 memcpy(tmp->array, array, capacity * sizeof(type)); \
37 void pushVector ## name(Vector ## name *vector, type item) { \
38 if (vector->size >= vector->capacity) { \
39 uint newcap=vector->capacity * 2; \
40 vector->array=(type *)ourrealloc(vector->array, newcap); \
42 vector->array[vector->size++] = item; \
44 type getVector ## name(Vector ## name * vector, uint index) { \
45 return vector->array[index]; \
47 void setVector ## name(Vector ## name * vector, uint index, type item) { \
48 vector->array[index]=item; \
50 uint getSize ## name(Vector ## name *vector) { \
51 return vector->size; \
53 void freeVector ##name(Vector ##name *vector) { \
54 ourfree(vector->array); \