list.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /** @file list.h
  2. * @brief Public interface for a bidirectional list.
  3. */
  4. #ifndef _faux_list_h
  5. #define _faux_list_h
  6. #include <stddef.h>
  7. #include "faux.h"
  8. typedef struct faux_list_node_s faux_list_node_t;
  9. typedef struct faux_list_s faux_list_t;
  10. typedef int (*faux_list_cmp_fn)(const void *new_item, const void *list_item);
  11. typedef int (*faux_list_kcmp_fn)(const void *key, const void *list_item);
  12. typedef void (*faux_list_free_fn)(void *list_item);
  13. C_DECL_BEGIN
  14. // list_node_t methods
  15. faux_list_node_t *faux_list_prev_node(const faux_list_node_t *node);
  16. faux_list_node_t *faux_list_next_node(const faux_list_node_t *node);
  17. void *faux_list_data(const faux_list_node_t *node);
  18. faux_list_node_t *faux_list_each_node(faux_list_node_t **iter);
  19. faux_list_node_t *faux_list_eachr_node(faux_list_node_t **iter);
  20. void *faux_list_each(faux_list_node_t **iter);
  21. void *faux_list_eachr(faux_list_node_t **iter);
  22. // list_t methods
  23. faux_list_t *faux_list_new(bool_t sorted, bool_t unique,
  24. faux_list_cmp_fn cmpFn, faux_list_kcmp_fn kcmpFn,
  25. faux_list_free_fn freeFn);
  26. void faux_list_free(faux_list_t *list);
  27. faux_list_node_t *faux_list_head(const faux_list_t *list);
  28. faux_list_node_t *faux_list_tail(const faux_list_t *list);
  29. size_t faux_list_len(const faux_list_t *list);
  30. faux_list_node_t *faux_list_add(faux_list_t *list, void *data);
  31. faux_list_node_t *faux_list_add_find(faux_list_t *list, void *data);
  32. void *faux_list_takeaway(faux_list_t *list, faux_list_node_t *node);
  33. int faux_list_del(faux_list_t *list, faux_list_node_t *node);
  34. faux_list_node_t *faux_list_match_node(const faux_list_t *list,
  35. faux_list_kcmp_fn matchFn, const void *userkey,
  36. faux_list_node_t **saveptr);
  37. void *faux_list_match(const faux_list_t *list,
  38. faux_list_kcmp_fn matchFn, const void *userkey,
  39. faux_list_node_t **saveptr);
  40. faux_list_node_t *faux_list_find_node(const faux_list_t *list,
  41. faux_list_kcmp_fn matchFn, const void *userkey);
  42. void *faux_list_find(const faux_list_t *list,
  43. faux_list_kcmp_fn matchFn, const void *userkey);
  44. C_DECL_END
  45. #endif /* _faux_list_h */