list.h 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. #ifndef _lub_list_h
  2. #define _lub_list_h
  3. #include <stddef.h>
  4. #include "lub/c_decl.h"
  5. typedef struct lub_list_node_s lub_list_node_t;
  6. typedef int lub_list_compare_fn(const void *first, const void *second);
  7. typedef void lub_list_free_fn(void *data);
  8. typedef struct lub_list_s lub_list_t;
  9. typedef struct lub_list_node_s lub_list_iterator_t;
  10. _BEGIN_C_DECL
  11. lub_list_node_t *lub_list_node_new(void *data);
  12. lub_list_node_t *lub_list_node__get_prev(lub_list_node_t *node);
  13. lub_list_node_t *lub_list_node__get_next(lub_list_node_t *node);
  14. void *lub_list_node__get_data(lub_list_node_t *node);
  15. void lub_list_node_free(lub_list_node_t *node);
  16. void lub_list_node_copy(lub_list_node_t *dst, lub_list_node_t *src);
  17. lub_list_t *lub_list_new(lub_list_compare_fn compareFn,
  18. lub_list_free_fn freeFn);
  19. void lub_list_free(lub_list_t *list);
  20. void lub_list_free_all(lub_list_t *list);
  21. lub_list_node_t *lub_list__get_head(lub_list_t *list);
  22. lub_list_node_t *lub_list__get_tail(lub_list_t *list);
  23. lub_list_node_t *lub_list_iterator_init(lub_list_t *list);
  24. lub_list_node_t *lub_list_iterator_next(lub_list_node_t *node);
  25. lub_list_node_t *lub_list_iterator_prev(lub_list_node_t *node);
  26. lub_list_node_t *lub_list_add(lub_list_t *list, void *data);
  27. void lub_list_del(lub_list_t *list, lub_list_node_t *node);
  28. lub_list_node_t *lub_list_search_node(lub_list_t *list, void *data);
  29. void *lub_list_search(lub_list_t *list, void *data);
  30. unsigned int lub_list_len(lub_list_t *list);
  31. _END_C_DECL
  32. #endif /* _lub_list_h */