blob: 4e5fe6540b54f9a41c580a62a5f87b36182e370a (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
// MIT License, Copyright (c) 2020 Marvin Borner
#ifndef LIST_H
#define LIST_H
#include <def.h>
struct list {
struct node *head;
};
struct node {
void *data;
int nonce;
struct node *next;
struct node *prev;
};
struct list *list_new(void);
void list_destroy(struct list *list) NONNULL;
struct node *list_add(struct list *list, void *data) NONNULL;
struct list *list_remove(struct list *list, struct node *node) NONNULL;
struct node *list_last(struct list *list) NONNULL;
struct list *list_swap(struct list *list, struct node *a, struct node *b) NONNULL;
struct node *list_first_data(struct list *list, void *data) NONNULL;
#endif
|