htils 1
A small set of utilities for C programming.
Loading...
Searching...
No Matches
darray.h
Go to the documentation of this file.
1#ifndef HTILS_DARRAY
2#define HTILS_DARRAY
3
4#include <htils/arena.h>
5#include <htils/assert.h>
6#include <htils/basictypes.h>
7
18
19//
20//
21//
22
24#define DA_HEADER_SIZE \
25 ((sizeof(da_header_t) + _Alignof(max_align_t) - 1) & \
26 ~(_Alignof(max_align_t) - 1))
27
28//
29//
30//
31
44static inline da_header_t *da__hdr(void *da) {
45 return (da_header_t *)((cstr *)da - DA_HEADER_SIZE);
46}
47
49#define da_len(darray) ((darray) ? da__hdr(darray)->len : 0)
50
52#define da_cap(darray) ((darray) ? da__hdr(darray)->cap : 0)
53
72#define da_new(arena, darray, intitial_capacity) \
73 do { \
74 htils_assert(arena != null && "Arena cannot be null."); \
75 htils_assert(intitial_capacity > 0 && \
76 "Initial capacity must be greater than 0"); \
77 \
78 u64 capacity = (intitial_capacity); \
79 u64 alloc_size = DA_HEADER_SIZE + capacity; \
80 \
81 da_header_t *header = arena_alloc((arena), darray, alloc_size); \
82 header->cap = capacity; \
83 (darray) = (void *)(header + 1); \
84 } while (0)
85
86//
87//
88//
89
105#define da_append(arena, darray, item) \
106 do { \
107 htils_assert(arena != null && "Arena cannot be null."); \
108 htils_assert(darray != null && "Darray cannot be null."); \
109 htils_assert(item != null && "Item cannot be null."); \
110 \
111 if (!(darray) || da__hdr(darray)->len >= da__hdr(darray)->cap) { \
112 u64 old_capacity = da__hdr(darray)->cap; \
113 u64 new_capacity = old_capacity ? old_capacity * 2 : 8; \
114 u64 old_len = da__hdr(darray)->len; \
115 u64 alloc_size = DA_HEADER_SIZE + new_capacity; \
116 \
117 da_header_t *header = arena_alloc((arena), darray, alloc_size); \
118 \
119 header->cap = new_capacity; \
120 header->len = old_len; \
121 \
122 if (darray) \
123 memcpy(header + 1, (darray), old_len * sizeof(*(darray))); \
124 \
125 (darray) = (void *)(header + 1); \
126 } \
127 \
128 (darray)[da__hdr(darray)->len++] = (item); \
129 } while (0)
130
139#define da_pop(darray) \
140 do { \
141 if (darray && da__hdr(darray)->len > 0) \
142 da__hdr(darray)->len--; \
143 } while (0)
144
153#define da_last(darray) \
154 (htils_assert(da__hdr(darray)->len > 0), (darray)[da__hdr(darray)->len - 1])
155
164#define da_clear(darray) \
165 do { \
166 if (darray) \
167 da__hdr(darray)->len = 0; \
168 } while (0)
169
170#endif // !HTILS_DARRAY
uint64_t u64
Definition basictypes.h:17
char cstr
Definition basictypes.h:50
#define DA_HEADER_SIZE
Definition darray.h:24
static da_header_t * da__hdr(void *da)
Get the da_header.
Definition darray.h:44
struct da_header da_header_t
The header of a dynamic array.
The header of a dynamic array.
Definition darray.h:14
u64 len
Definition darray.h:16
u64 cap
Definition darray.h:15