blob: fea98dc678b0ebc1e5659e40c8f0b05a388b1370 (
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
28
29
|
// 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_new_node(); */ // TODO: Make node-specific things static/private?
/* void list_add_node(struct list *list, struct node *node); */
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
|