list.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. #ifndef _faux_list_h
  2. #define _faux_list_h
  3. #include <stddef.h>
  4. #include "types.h"
  5. typedef struct faux_list_node_s faux_list_node_t;
  6. typedef struct faux_list_s faux_list_t;
  7. typedef int faux_list_compare_fn(const void *first, const void *second);
  8. typedef void faux_list_free_fn(void *data);
  9. typedef int faux_list_match_fn(const void *key, const void *data);
  10. C_DECL_BEGIN
  11. // list_node_t methods
  12. faux_list_node_t *faux_list_prev_node(const faux_list_node_t *node);
  13. faux_list_node_t *faux_list_next_node(const faux_list_node_t *node);
  14. void *faux_list_data(const faux_list_node_t *node);
  15. faux_list_node_t *faux_list_each_node(faux_list_node_t **iter);
  16. void *faux_list_each(faux_list_node_t **iter);
  17. // list_t methods
  18. faux_list_t *faux_list_new(faux_list_compare_fn compareFn,
  19. faux_list_free_fn freeFn);
  20. void faux_list_free(faux_list_t *list);
  21. faux_list_node_t *faux_list_head(const faux_list_t *list);
  22. faux_list_node_t *faux_list_tail(const faux_list_t *list);
  23. size_t faux_list_len(const faux_list_t *list);
  24. faux_list_node_t *faux_list_add(faux_list_t *list, void *data);
  25. faux_list_node_t *faux_list_add_uniq(faux_list_t *list, void *data);
  26. faux_list_node_t *faux_list_find_add(faux_list_t *list, void *data);
  27. void *faux_list_takeaway(faux_list_t *list, faux_list_node_t *node);
  28. int faux_list_del(faux_list_t *list, faux_list_node_t *node);
  29. faux_list_node_t *faux_list_match_node(const faux_list_t *list,
  30. faux_list_match_fn matchFn, const void *userkey,
  31. faux_list_node_t **saveptr);
  32. void *faux_list_match(const faux_list_t *list,
  33. faux_list_match_fn matchFn, const void *userkey,
  34. faux_list_node_t **saveptr);
  35. faux_list_node_t *faux_list_find_node(const faux_list_t *list,
  36. faux_list_match_fn matchFn, const void *userkey);
  37. void *faux_list_find(const faux_list_t *list,
  38. faux_list_match_fn matchFn, const void *userkey);
  39. C_DECL_END
  40. #endif /* _faux_list_h */