-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlist.h
40 lines (31 loc) · 991 Bytes
/
list.h
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
30
31
32
33
34
35
36
37
38
39
40
#ifndef LIST_H
#define LIST_H
#include <stddef.h>
typedef struct ListNode{
struct ListNode* pre;
struct ListNode* nxt;
void *val;
}ListNode;
typedef struct List{
ListNode* head;
ListNode* tail;
size_t len;
void (*free)(void *ptr);
}List;
#define listSetDupMethod(l,m) ((l)->dup = (m))
#define listSetFreeMethod(l,m) ((l)->free = (m))
#define listGetDupMethod(l) ((l)->dup)
#define listGetFreeMethod(l) ((l)->free)
List *listNew(void);
void listDel(List *list);
void listAddNodeHead(List *list, void *val);
void listAddNodeTail(List *list, void *val);
void listAddNodeAfter(List *list, void *val, ListNode *pre_node);
void listRemoveNode(List *list, ListNode *node);
void listForeach(List *list, void (*fun)(void *));
//符合要求的节点返回1 否则返回0
typedef int (*FilterFun)(ListNode*);
void listForeachFilter(List *list, FilterFun filter, void (*fun)(void *));
// first
ListNode* listFindNode(List *list, FilterFun filter);
#endif //LIST_H