48 "LIST(<type>).base and LIST(<type>).impl.base will not alias each other");
70#define LIST_DTOR_FREE ((void *)1)
80#define LIST_SIZE(list) gv_list_size_((list)->impl)
90#define LIST_IS_EMPTY(list) (LIST_SIZE(list) == 0)
106#define LIST_TRY_APPEND(list, item) \
107 (((list)->impl.size < (list)->impl.capacity || \
108 gv_list_try_reserve_( \
110 (list)->impl.capacity == 0 ? 1 : ((list)->impl.capacity * 2), \
111 sizeof((list)->base[0])) || \
112 gv_list_try_reserve_(&(list)->impl, (list)->impl.capacity + 1, \
113 sizeof((list)->base[0]))) && \
114 (((list)->base[gv_list_append_slot_(&(list)->impl, \
115 sizeof((list)->base[0]))] = (item)), \
132#define LIST_APPEND(list, item) \
134 const size_t slot_ = \
135 gv_list_append_slot_(&(list)->impl, sizeof((list)->base[0])); \
136 (list)->base[slot_] = (item); \
149#define LIST_PREPEND(list, item) \
151 const size_t slot_ = \
152 gv_list_prepend_slot_(&(list)->impl, sizeof((list)->base[0])); \
153 (list)->base[slot_] = (item); \
165#define LIST_GET(list, index) \
166 ((list)->base[gv_list_get_((list)->impl, (index))])
178#define LIST_AT(list, index) \
179 (&(list)->base[gv_list_get_((list)->impl, (index))])
190#define LIST_FRONT(list) LIST_AT((list), 0)
201#define LIST_BACK(list) LIST_AT((list), LIST_SIZE(list) - 1)
212#define LIST_SET(list, index, item) \
214 const size_t slot_ = gv_list_get_((list)->impl, (index)); \
215 LIST_DTOR_((list), slot_); \
216 (list)->base[slot_] = (item); \
227#define LIST_REMOVE(list, item) \
230 (list)->scratch = (item); \
232 const size_t found_ = gv_list_find_((list)->impl, &(list)->scratch, \
233 sizeof((list)->base[0])); \
234 if (found_ == SIZE_MAX) { \
238 LIST_DTOR_((list), found_); \
239 gv_list_remove_(&(list)->impl, found_, sizeof((list)->base[0])); \
249#define LIST_CLEAR(list) \
251 for (size_t i_ = 0; i_ < LIST_SIZE(list); ++i_) { \
252 const size_t slot_ = gv_list_get_((list)->impl, i_); \
253 LIST_DTOR_((list), slot_); \
255 gv_list_clear_(&(list)->impl, sizeof((list)->base[0])); \
266#define LIST_RESERVE(list, capacity) \
267 gv_list_reserve_(&(list)->impl, capacity, sizeof((list)->base[0]))
282#define LIST_CONTAINS(list, needle) \
283 gv_list_contains_((list)->impl, \
284 ((void)((list)->base == &(needle)), &(needle)), \
285 sizeof((list)->base[0]))
295#define LIST_COPY(dst, src) \
297 (void)((dst)->base == (src)->base); \
298 memset((dst), 0, sizeof(*(dst))); \
299 (dst)->impl = gv_list_copy_((src)->impl, sizeof((src)->base[0])); \
300 (dst)->dtor = (src)->dtor; \
324#define LIST_IS_CONTIGUOUS(list) gv_list_is_contiguous_((list)->impl);
336#define LIST_SYNC(list) gv_list_sync_(&(list)->impl, sizeof((list)->base[0]))
347#define LIST_SORT(list, cmp) \
348 gv_list_sort_(&(list)->impl, (cmp), sizeof((list)->base[0]))
357#define LIST_REVERSE(list) \
358 gv_list_reverse_(&(list)->impl, sizeof((list)->base[0]))
367#define LIST_SHRINK_TO_FIT(list) \
368 gv_list_shrink_to_fit_(&(list)->impl, sizeof((list)->base[0]))
379#define LIST_FREE(list) \
382 gv_list_free_(&(list)->impl); \
393#define LIST_PUSH_BACK(list, item) LIST_APPEND((list), (item))
403#define LIST_POP_FRONT(list) \
404 (gv_list_pop_front_(&(list)->impl, &(list)->scratch, \
405 sizeof((list)->base[0])), \
416#define LIST_POP_BACK(list) \
417 (gv_list_pop_back_(&(list)->impl, &(list)->scratch, \
418 sizeof((list)->base[0])), \
434#define LIST_DETACH(list, datap, sizep) \
436 *(datap) = (list)->base; \
437 *(sizep) = (list)->impl.size; \
439 (list)->impl = (list_t_){0}; \
internal implementation details of list.h