00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032 #ifndef LIST_NODE_H
00033 #define LIST_NODE_H
00034
00035 #include <stdlib.h>
00036
00038 typedef struct _listNode ListNode;
00039
00041 struct _listNode {
00042 void *data;
00043 void (*delete) (void *);
00044 ListNode *next;
00045 ListNode *prev;
00046 };
00047
00048 void listNode_Init(void *(*ln_allocate)(size_t size), void (*ln_deallocate)(void *ptr));
00049
00050 extern ListNode *listNode_Create (void);
00051
00052
00053
00054
00055
00056
00057 extern void listNode_Destroy (ListNode *);
00058
00059
00060
00061
00062
00063 extern ListNode *listNode_Copy (ListNode *lnode);
00064
00065 extern int listNode_AttachAhead (ListNode *, ListNode *);
00066 extern int listNode_AttachBehind (ListNode *, ListNode *);
00067
00068 extern ListNode *listNode_AttachData (ListNode *lnode, void *data, void (*delete)(void *));
00069
00070 extern int listNode_Detach (ListNode *);
00071
00072 extern void listNode_Print (ListNode *listNode);
00073
00074 #define listNode_IsNodeAttached(lnode) ((lnode->next || lnode->prev) ? 1 : 0)
00075
00076 #define listNode_GetNodeAhead(lnode) (lnode->next);
00077 #define listNode_GetNodeBehind(lnode) (lnode->prev);
00078
00079 #define listNode_GetNextNode(lnode) (lnode->next)
00080 #define listNode_GetPrevNode(lnode) (lnode->prev)
00081
00082 #define listNode_GetData(a) (((ListNode *) (a))->data)
00083 #define listNode_GetDelete(a) (((ListNode *) (a))->delete)
00084 #endif