libflint/include/lflinkedlist.h

41 lines
902 B
C
Raw Normal View History

2021-02-01 14:06:37 -08:00
#ifndef LIBFLINT_LL_H
#define LIBFLINT_LL_H
#include <stddef.h>
2021-02-01 14:27:01 -08:00
typedef struct ListNode {
2022-03-28 10:52:16 -07:00
void *data;
struct ListNode *next;
struct ListNode *prev;
2021-02-01 14:27:01 -08:00
} ListNode;
2021-02-01 14:06:37 -08:00
2021-02-01 14:27:01 -08:00
typedef struct {
2021-02-01 14:06:37 -08:00
size_t size;
2022-03-28 10:52:16 -07:00
void (*destroy)(void *data);
2021-02-01 14:06:37 -08:00
2022-03-28 10:52:16 -07:00
int (*match)(const void *a, const void *b);
struct ListNode *head;
struct ListNode *tail;
2021-02-01 14:27:01 -08:00
} List;
2021-02-01 14:06:37 -08:00
2022-03-28 10:52:16 -07:00
void ll_init(List *list, void (*destroy)(void *data));
void ll_destroy(List *list);
int ll_ins_next(List *list, ListNode *node, const void *data);
int ll_ins_prev(List *list, ListNode *node, const void *data);
int ll_remove(List *list, ListNode *node, void **data);
int ll_remove_next(List *list, ListNode *node, void **data);
int ll_remove_prev(List *list, ListNode *node, void **data);
/* Provides ListNode *node for the iteration loop */
#define LL_ITER(list) for(ListNode *node = (list)->head; node != NULL; node = node->next)
2021-02-01 14:06:37 -08:00
#endif