2022-10-12 02:01:37 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <inttypes.h>
|
|
|
|
|
|
|
|
typedef struct ListNode {
|
|
|
|
void* data;
|
2022-10-13 14:00:20 +00:00
|
|
|
struct ListNode* next;
|
2022-10-12 02:01:37 +00:00
|
|
|
} ListNode;
|
|
|
|
|
2022-10-13 14:00:20 +00:00
|
|
|
ListNode* list_init_head(void* data);
|
|
|
|
ListNode* list_add(
|
|
|
|
ListNode* head,
|
|
|
|
void* data); /* adds element with specified data to the end of the list and returns new head node. */
|
|
|
|
ListNode* list_find(
|
|
|
|
ListNode* head,
|
|
|
|
void* data); /* returns pointer of element with specified data in list. */
|
|
|
|
ListNode* list_element_at(
|
|
|
|
ListNode* head,
|
|
|
|
uint16_t index); /* returns pointer of element with specified index in list. */
|
|
|
|
ListNode* list_remove(
|
|
|
|
ListNode* head,
|
|
|
|
ListNode* ep); /* removes element from the list and returns new head node. */
|
|
|
|
void list_free(ListNode* head); /* deletes all elements of the list. */
|