37 lines
683 B
C
37 lines
683 B
C
#ifndef LINKEDLIST_H
|
|
#define LINKEDLIST_H
|
|
|
|
#include "util.h"
|
|
|
|
/*General Purpose Linked List*/
|
|
typedef struct s_llist t_llist;
|
|
struct s_llist
|
|
{
|
|
void* dptr;
|
|
t_llist* next;
|
|
};
|
|
|
|
/***** Subroutines *****/
|
|
t_llist* create_llist(int len);
|
|
|
|
t_llist* insert_llist_node(t_llist* cur);
|
|
|
|
t_llist* insert_llist_node_before_head(t_llist* old_head);
|
|
|
|
void remove_llist_node(t_llist* cur);
|
|
|
|
t_llist* cat_llists(t_llist* head1,
|
|
t_llist* head2);
|
|
|
|
t_llist* search_llist_tail(t_llist* head);
|
|
|
|
int find_length_llist(t_llist* head);
|
|
|
|
boolean check_dptr_exist_in_llist(t_llist* head, void* data_ptr);
|
|
|
|
void free_llist(t_llist* head);
|
|
|
|
t_llist* reverse_llist(t_llist* head);
|
|
|
|
#endif
|