|
/// Dynamic memory-chunk, with (1) datatype size, (2/3) initialized / allocated chunk, (4) content
|
|
typedef struct { uint8_t const elSize; uint32_t init, alloc; char* content; } DynamicArray;
|
|
#define UTF8_ARRAY {4, 0, 0, NULL}
|
|
|
|
static inline int p_alloc(DynamicArray *s, uint32_t amount) {
|
|
uint32_t const diff=s->init+s->elSize*amount-s->alloc, nas=s->alloc+max(diff,15)*s->elSize;
|
|
if (s->alloc < s->init + s->elSize * amount) {
|
|
char* tmp = realloc(s->content, nas);
|
|
if (!tmp) return 0;
|
|
s->alloc = nas, s->content = tmp;
|
|
}
|
|
return 1;
|
|
}
|
|
static inline char *view(DynamicArray * s, uint32_t i) { return s->content + i*s->elSize; }
|
|
static inline char *end(DynamicArray *s, uint32_t i) { return s->content +s->init-(i+1)*s->elSize; }
|
|
static inline uint32_t getU32(DynamicArray* s, uint32_t i, int b) { return *((uint32_t*) (b ?view(s,i) :end(s,i))); }
|
|
static char *expand(DynamicArray *s) { if (!p_alloc(s, 1)) return NULL; s->init += s->elSize; return end(s, 0); }
|
|
static inline void pop(DynamicArray* s) { s->init -= s->elSize; }
|
|
static inline void empty(DynamicArray* s) { s->init = 0; }
|
|
static inline int size(DynamicArray const * s) { return s->init / s->elSize; }
|
|
static inline void assign(DynamicArray* s, DynamicArray const *o) {
|
|
if (p_alloc(s, size(o))) memcpy(s->content, o->content, (s->init=o->init));
|
|
}
|