diff options
Diffstat (limited to 'list/include')
-rw-r--r-- | list/include/list.h | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/list/include/list.h b/list/include/list.h new file mode 100644 index 0000000..b00b48b --- /dev/null +++ b/list/include/list.h | |||
@@ -0,0 +1,21 @@ | |||
1 | /// A doubly linked list. | ||
2 | /// | ||
3 | /// This list does not hold user data. Instead, the list can be used as an | ||
4 | /// intrusive list or as part as a more complex data structure. | ||
5 | #pragma once | ||
6 | |||
7 | #include <stddef.h> | ||
8 | |||
9 | typedef struct list list; | ||
10 | |||
11 | typedef struct list { | ||
12 | list* prev; | ||
13 | list* next; | ||
14 | } list; | ||
15 | |||
16 | /// Create a new list from an array of `size` items. | ||
17 | void list_make(list* list, size_t size); | ||
18 | |||
19 | /// Iterates over all the items in the list. | ||
20 | #define list_foreach(LIST, iter) \ | ||
21 | for (struct list* iter = LIST; iter; iter = iter->next) | ||