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 <h2o/memory.h>
5
6//
7//
8//
9
10#include <htils/assert.h>
11#include <htils/basictypes.h>
12
13//
14//
15//
16
27
28//
29//
30//
31
33#define H2O_DA_HEADER_SIZE \
34 ((sizeof(h2o_da_header_t) + _Alignof(max_align_t) - 1) & \
35 ~(_Alignof(max_align_t) - 1))
36
37//
38//
39//
40
53static inline h2o_da_header_t *h2o_da__hdr(void *h2o_da) {
54 return (h2o_da_header_t *)((cstr *)h2o_da - H2O_DA_HEADER_SIZE);
55}
56
58#define h2o_da_len(darray) ((darray) ? h2o_da__hdr(darray)->len : 0)
59
61#define h2o_da_cap(darray) ((darray) ? h2o_da__hdr(darray)->cap : 0)
62
78#define h2o_da_new(pool, darray, intitial_capacity) \
79 do { \
80 htils_assert(pool != null && "pool cannot be null."); \
81 htils_assert(intitial_capacity > 0 && \
82 "Initial capacity must be greater than 0"); \
83 \
84 u64 capacity = (intitial_capacity); \
85 u64 alloc_size = H2O_DA_HEADER_SIZE + capacity; \
86 \
87 h2o_da_header_t *header = h2o_mem_alloc_pool((pool), darray, alloc_size); \
88 header->cap = capacity; \
89 (darray) = (void *)(header + 1); \
90 } while (0)
91
92//
93//
94//
95
109#define h2o_da_append(pool, darray, item) \
110 do { \
111 htils_assert(pool != null && "Pool cannot be null."); \
112 htils_assert(darray != null && "Darray cannot be null."); \
113 htils_assert(item != null && "Item cannot be null."); \
114 \
115 if (!(darray) || h2o_da__hdr(darray)->len >= h2o_da__hdr(darray)->cap) { \
116 u64 old_capacity = h2o_da__hdr(darray)->cap; \
117 u64 new_capacity = old_capacity ? old_capacity * 2 : 8; \
118 u64 old_len = h2o_da__hdr(darray)->len; \
119 u64 alloc_size = H2O_DA_HEADER_SIZE + new_capacity; \
120 \
121 h2o_da_header_t *header = \
122 h2o_mem_alloc_pool((pool), darray, alloc_size); \
123 \
124 header->cap = new_capacity; \
125 header->len = old_len; \
126 \
127 if (darray) \
128 memcpy(header + 1, (darray), old_len * sizeof(*(darray))); \
129 \
130 (darray) = (void *)(header + 1); \
131 } \
132 \
133 (darray)[h2o_da__hdr(darray)->len++] = (item); \
134 } while (0)
135
144#define h2o_da_pop(darray) \
145 do { \
146 if (darray && h2o_da__hdr(darray)->len > 0) \
147 h2o_da__hdr(darray)->len--; \
148 } while (0)
149
158#define h2o_da_last(darray) \
159 (htils_assert(h2o_da__hdr(darray)->len > 0), \
160 (darray)[da__hdr(darray)->len - 1])
161
170#define h2o_da_clear(darray) \
171 do { \
172 if (darray) \
173 h2o_da__hdr(darray)->len = 0; \
174 } while (0)
175
176#endif // !HTILS_DARRAY
uint64_t u64
Definition basictypes.h:17
char cstr
Definition basictypes.h:50
#define H2O_DA_HEADER_SIZE
Definition darray.h:33
struct h2o_h2o_da_header h2o_da_header_t
The header of a dynamic array.
static h2o_da_header_t * h2o_da__hdr(void *h2o_da)
Get the dynamic array header.
Definition darray.h:53
The header of a dynamic array.
Definition darray.h:23
u64 len
Definition darray.h:25
u64 cap
Definition darray.h:24