blob: 0b82b488e9ab14e113f03e8765a729e9ff08a5b6 (
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);
/* 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);
struct list *list_remove(struct list *list, struct node *node);
struct node *list_last(struct list *list);
struct list *list_swap(struct list *list, struct node *a, struct node *b);
struct node *list_first_data(struct list *list, void *data);
#endif
|