2019-08-21 23:07:37 +03:00
|
|
|
#ifndef LIST_H
|
|
|
|
#define LIST_H
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
|
2019-09-12 11:39:06 +03:00
|
|
|
struct liftoff_list {
|
|
|
|
struct liftoff_list *prev;
|
|
|
|
struct liftoff_list *next;
|
2019-08-21 23:07:37 +03:00
|
|
|
};
|
|
|
|
|
2019-09-12 11:39:06 +03:00
|
|
|
void liftoff_list_init(struct liftoff_list *list);
|
|
|
|
void liftoff_list_insert(struct liftoff_list *list, struct liftoff_list *elm);
|
|
|
|
void liftoff_list_remove(struct liftoff_list *elm);
|
|
|
|
size_t liftoff_list_length(const struct liftoff_list *list);
|
|
|
|
bool liftoff_list_empty(const struct liftoff_list *list);
|
2019-08-21 23:07:37 +03:00
|
|
|
|
2019-09-12 11:39:06 +03:00
|
|
|
#define liftoff_container_of(ptr, sample, member) \
|
2019-08-21 23:07:37 +03:00
|
|
|
(__typeof__(sample))((char *)(ptr) - \
|
|
|
|
offsetof(__typeof__(*sample), member))
|
|
|
|
|
2019-09-12 11:39:06 +03:00
|
|
|
#define liftoff_list_for_each(pos, head, member) \
|
|
|
|
for (pos = liftoff_container_of((head)->next, pos, member); \
|
2019-08-21 23:07:37 +03:00
|
|
|
&pos->member != (head); \
|
2019-09-12 11:39:06 +03:00
|
|
|
pos = liftoff_container_of(pos->member.next, pos, member))
|
2019-08-21 23:07:37 +03:00
|
|
|
|
2019-09-12 11:39:06 +03:00
|
|
|
#define liftoff_list_for_each_safe(pos, tmp, head, member) \
|
|
|
|
for (pos = liftoff_container_of((head)->next, pos, member), \
|
|
|
|
tmp = liftoff_container_of(pos->member.next, tmp, member); \
|
2019-08-21 23:07:37 +03:00
|
|
|
&pos->member != (head); \
|
|
|
|
pos = tmp, \
|
2019-09-12 11:39:06 +03:00
|
|
|
tmp = liftoff_container_of(pos->member.next, tmp, member))
|
2019-08-21 23:07:37 +03:00
|
|
|
|
|
|
|
#endif
|