109 assert(retCode == 0);
150 bnode->next = newNode;
151 newNode->prev = bnode;
152 newNode->next = temp;
153 temp->prev = newNode;
173 anode->prev = newNode;
174 newNode->next = anode;
175 newNode->prev = temp;
176 temp->next = newNode;
189 assert(dnode != &list->
head);
190 assert(dnode != &list->
tail);
192 if (!list || dnode == &list->
head || dnode == &list->
tail || !dnode)
195 dnode->prev->next = dnode->next;
196 dnode->next->prev = dnode->prev;
214 for (dnode = list->
head.next; dnode != &list->
tail;) {
234 return list->
head.next;
246 return list->
tail.prev;
255 if (node->next == &list->
tail)
268 if (node->prev == &list->
head)
284 finger = start->next;
288 while (finger != &list->
tail) {
290 if (list->
cmp_func(item, finger->item))
293 if (item == finger->item)
296 finger = finger->next;
int FreeListInit(FreeList *free_list, size_t elementSize, int maxFreeListLength)
Initializes Free List.
int FreeListFree(FreeList *free_list, void *element)
Returns an item to the Free List.
void * FreeListAlloc(FreeList *free_list)
Allocates chunk of set size.
int FreeListDestroy(FreeList *free_list)
Releases the resources stored with the free list.
long ListSize(LinkedList *list)
Returns the size of the list.
int ListDestroy(LinkedList *list, int freeItem)
Removes all memory associated with list nodes. Does not free LinkedList *list.
ListNode * ListPrev(LinkedList *list, ListNode *node)
Returns the previous item in the list.
void * ListDelNode(LinkedList *list, ListNode *dnode, int freeItem)
Removes a node from the list. The memory for the node is freed.
ListNode * ListAddBefore(LinkedList *list, void *item, ListNode *anode)
Adds a node before the specified node. Node gets added immediately before anode.
ListNode * ListNext(LinkedList *list, ListNode *node)
Returns the next item in the list.
ListNode * ListAddAfter(LinkedList *list, void *item, ListNode *bnode)
Adds a node after the specified node. Node gets added immediately after bnode.
ListNode * ListHead(LinkedList *list)
Returns the head of the list.
ListNode * ListAddHead(LinkedList *list, void *item)
Adds a node to the head of the list. Node gets immediately after list head.
ListNode * ListAddTail(LinkedList *list, void *item)
Adds a node to the tail of the list. Node gets added immediately before list.tail.
ListNode * ListTail(LinkedList *list)
Returns the tail of the list.
ListNode * ListFind(LinkedList *list, ListNode *start, void *item)
Finds the specified item in the list.
int ListInit(LinkedList *list, cmp_routine cmp_func, free_function free_func)
Initializes LinkedList. Must be called first and only once for List.
constexpr int FREELISTSIZE
Size of a free list.
Manage a linked list (for internal use only).
cmp_routine cmp_func
compare function to use
ListNode head
head, first item is stored at: head->next
free_function free_func
free function to use
FreeList freeNodeList
free list to use
void(* free_function)(void *arg)
Function for freeing list items.
ListNode tail
tail, last item is stored at: tail->prev
int(* cmp_routine)(void *itemA, void *itemB)
Function for comparing list items. Returns 1 if itemA==itemB.
Linked list node. Stores generic item and pointers to next and prev.
Linked list (no protection).
int freeListNode(ListNode *node, LinkedList *list)
Free list node.
ListNode * CreateListNode(void *item, LinkedList *list)
Dynamically creates a list node.