summaryrefslogtreecommitdiffhomepage
path: root/src/nxt_list.h
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/nxt_list.h131
1 files changed, 131 insertions, 0 deletions
diff --git a/src/nxt_list.h b/src/nxt_list.h
new file mode 100644
index 00000000..4d14f4d9
--- /dev/null
+++ b/src/nxt_list.h
@@ -0,0 +1,131 @@
+
+/*
+ * Copyright (C) Igor Sysoev
+ * Copyright (C) NGINX, Inc.
+ */
+
+#ifndef _NXT_LIST_H_INCLUDED_
+#define _NXT_LIST_H_INCLUDED_
+
+
+typedef struct nxt_list_part_s nxt_list_part_t;
+
+struct nxt_list_part_s {
+ nxt_list_part_t *next;
+ uintptr_t nelts;
+};
+
+
+typedef struct {
+ nxt_list_part_t *last;
+#if (NXT_64BIT)
+ uint32_t size;
+ uint32_t nalloc;
+#else
+ uint16_t size;
+ uint16_t nalloc;
+#endif
+ nxt_mem_pool_t *mem_pool;
+ nxt_list_part_t part;
+} nxt_list_t;
+
+
+typedef struct {
+ nxt_list_part_t *part;
+ uintptr_t elt;
+} nxt_list_next_t;
+
+
+#define \
+nxt_list_part(list) \
+ (&(list)->part)
+
+
+#define \
+nxt_list_data(part) \
+ ((char *) (part) + sizeof(nxt_list_part_t))
+
+
+#define \
+nxt_list_first(list) \
+ (void *) nxt_list_data(nxt_list_part(list))
+
+
+nxt_inline void *
+nxt_list_elt(nxt_list_t *list, nxt_uint_t n)
+{
+ nxt_list_part_t *part;
+
+ if (nxt_fast_path((list) != NULL)) {
+ part = nxt_list_part(list);
+
+ while (part != NULL) {
+ if (n < (nxt_uint_t) part->nelts) {
+ return ((void *) (nxt_list_data(part) + n * (list)->size));
+ }
+
+ n -= (nxt_uint_t) part->nelts;
+ part = part->next;
+ }
+ }
+
+ return NULL;
+}
+
+
+#define nxt_list_each(elt, list) \
+ do { \
+ if (nxt_fast_path((list) != NULL)) { \
+ void *_end; \
+ nxt_list_part_t *_part = nxt_list_part(list); \
+ \
+ do { \
+ elt = (void *) nxt_list_data(_part); \
+ \
+ for (_end = (elt + _part->nelts); elt != _end; elt++) { \
+
+#define nxt_list_loop \
+ } \
+ \
+ _part = _part->next; \
+ \
+ } while (_part != NULL); \
+ } \
+ } while (0)
+
+
+NXT_EXPORT nxt_list_t *nxt_list_create(nxt_mem_pool_t *mp, nxt_uint_t n,
+ size_t size);
+NXT_EXPORT void *nxt_list_add(nxt_list_t *list);
+NXT_EXPORT void *nxt_list_zero_add(nxt_list_t *list);
+
+NXT_EXPORT void *nxt_list_next(nxt_list_t *list, nxt_list_next_t *next);
+
+
+#define \
+nxt_list_next_value(list, next) \
+ ((void *) (nxt_list_data((next)->part) + (next)->elt * (list)->size))
+
+
+nxt_inline nxt_uint_t
+nxt_list_nelts(nxt_list_t *list)
+{
+ nxt_uint_t n;
+ nxt_list_part_t *part;
+
+ n = 0;
+
+ if (nxt_fast_path((list) != NULL)) {
+ part = nxt_list_part(list);
+
+ do {
+ n += (nxt_uint_t) part->nelts;
+ part = part->next;
+ } while (part != NULL);
+ }
+
+ return n;
+}
+
+
+#endif /* _NXT_LIST_H_INCLUDED_ */