list.h 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  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/faux.h>
  8. typedef enum {
  9. FAUX_LIST_SORTED = BOOL_TRUE,
  10. FAUX_LIST_UNSORTED = BOOL_FALSE
  11. } faux_list_sorted_e;
  12. typedef enum {
  13. FAUX_LIST_UNIQUE = BOOL_TRUE,
  14. FAUX_LIST_NONUNIQUE = BOOL_FALSE
  15. } faux_list_unique_e;
  16. typedef struct faux_list_node_s faux_list_node_t;
  17. typedef struct faux_list_s faux_list_t;
  18. typedef int (*faux_list_cmp_fn)(const void *new_item, const void *list_item);
  19. typedef int (*faux_list_kcmp_fn)(const void *key, const void *list_item);
  20. typedef void (*faux_list_free_fn)(void *list_item);
  21. C_DECL_BEGIN
  22. // list_node_t methods
  23. faux_list_node_t *faux_list_prev_node(const faux_list_node_t *node);
  24. faux_list_node_t *faux_list_next_node(const faux_list_node_t *node);
  25. void *faux_list_data(const faux_list_node_t *node);
  26. faux_list_node_t *faux_list_each_node(faux_list_node_t **iter);
  27. faux_list_node_t *faux_list_eachr_node(faux_list_node_t **iter);
  28. void *faux_list_each(faux_list_node_t **iter);
  29. void *faux_list_eachr(faux_list_node_t **iter);
  30. // list_t methods
  31. faux_list_t *faux_list_new(faux_list_sorted_e sorted, faux_list_unique_e unique,
  32. faux_list_cmp_fn cmpFn, faux_list_kcmp_fn kcmpFn,
  33. faux_list_free_fn freeFn);
  34. void faux_list_free(faux_list_t *list);
  35. faux_list_node_t *faux_list_head(const faux_list_t *list);
  36. faux_list_node_t *faux_list_tail(const faux_list_t *list);
  37. size_t faux_list_len(const faux_list_t *list);
  38. bool_t faux_list_is_empty(const faux_list_t *list);
  39. faux_list_node_t *faux_list_add(faux_list_t *list, void *data);
  40. faux_list_node_t *faux_list_add_find(faux_list_t *list, void *data);
  41. void *faux_list_takeaway(faux_list_t *list, faux_list_node_t *node);
  42. bool_t faux_list_del(faux_list_t *list, faux_list_node_t *node);
  43. bool_t faux_list_kdel(faux_list_t *list, const void *userkey);
  44. ssize_t faux_list_del_all(faux_list_t *list);
  45. faux_list_node_t *faux_list_match_node(const faux_list_t *list,
  46. faux_list_kcmp_fn matchFn, const void *userkey,
  47. faux_list_node_t **iter);
  48. faux_list_node_t *faux_list_kmatch_node(const faux_list_t *list,
  49. const void *userkey, faux_list_node_t **iter);
  50. void *faux_list_match(const faux_list_t *list,
  51. faux_list_kcmp_fn matchFn, const void *userkey,
  52. faux_list_node_t **iter);
  53. void *faux_list_kmatch(const faux_list_t *list,
  54. const void *userkey, faux_list_node_t **iter);
  55. faux_list_node_t *faux_list_find_node(const faux_list_t *list,
  56. faux_list_kcmp_fn matchFn, const void *userkey);
  57. faux_list_node_t *faux_list_kfind_node(const faux_list_t *list,
  58. const void *userkey);
  59. void *faux_list_find(const faux_list_t *list,
  60. faux_list_kcmp_fn matchFn, const void *userkey);
  61. void *faux_list_kfind(const faux_list_t *list,
  62. const void *userkey);
  63. faux_list_node_t *faux_list_index_node(const faux_list_t *list, size_t index);
  64. void *faux_list_index(const faux_list_t *list, size_t index);
  65. C_DECL_END
  66. #endif /* _faux_list_h */