3 #ifndef GIRARA_DATASTRUCTURES_H 4 #define GIRARA_DATASTRUCTURES_H 244 #define GIRARA_LIST_FOREACH(list, type, iter, data) \ 246 girara_list_iterator_t* iter = girara_list_iterator(list); \ 247 while (girara_list_iterator_is_valid(iter)) { \ 248 type data = (type)girara_list_iterator_data(iter); 250 #define GIRARA_LIST_FOREACH_END(list, type, iter, data) \ 251 girara_list_iterator_next(iter); \ 253 girara_list_iterator_free(iter); \ 256 #define GIRARA_LIST_FOREACH_BODY_WITH_ITER(list, type, iter, data, ...) \ 257 GIRARA_LIST_FOREACH(list, type, iter, data) \ 259 GIRARA_LIST_FOREACH_END(list, type, iter, data) 261 #define GIRARA_LIST_FOREACH_BODY(list, type, data, ...) \ 262 GIRARA_LIST_FOREACH(list, type, girara_list_foreach_iterator, data) \ 264 GIRARA_LIST_FOREACH_END(list, type, girara_list_foreach_iterator, data) girara_tree_node_t * girara_node_new(void *data)
bool girara_list_iterator_is_valid(girara_list_iterator_t *iter)
void girara_list_clear(girara_list_t *list)
void girara_list_iterator_free(girara_list_iterator_t *iter)
void girara_list_set_free_function(girara_list_t *list, girara_free_function_t gfree)
struct girara_tree_node_s girara_tree_node_t
girara_list_iterator_t * girara_list_iterator(girara_list_t *list)
void girara_node_append(girara_tree_node_t *parent, girara_tree_node_t *child)
girara_list_iterator_t * girara_list_iterator_next(girara_list_iterator_t *iter)
girara_list_t * girara_list_merge(girara_list_t *list, girara_list_t *other)
girara_list_iterator_t * girara_list_iterator_copy(girara_list_iterator_t *iter)
girara_tree_node_t * girara_node_get_parent(girara_tree_node_t *node)
girara_list_t * girara_sorted_list_new(girara_compare_function_t cmp)
bool girara_list_contains(girara_list_t *list, void *data)
void * girara_list_nth(girara_list_t *list, size_t n)
void girara_list_sort(girara_list_t *list, girara_compare_function_t compare)
void girara_node_free(girara_tree_node_t *node)
void girara_list_foreach(girara_list_t *list, girara_list_callback_t callback, void *data)
girara_list_t * girara_node_get_children(girara_tree_node_t *node)
bool girara_list_iterator_has_next(girara_list_iterator_t *iter)
void(* girara_list_callback_t)(void *data, void *userdata)
void girara_list_prepend(girara_list_t *list, void *data)
void girara_list_remove(girara_list_t *list, void *data)
void girara_list_iterator_remove(girara_list_iterator_t *iter)
struct girara_list_iterator_s girara_list_iterator_t
girara_tree_node_t * girara_node_append_data(girara_tree_node_t *parent, void *data)
girara_tree_node_t * girara_node_get_root(girara_tree_node_t *node)
void * girara_list_iterator_data(girara_list_iterator_t *iter)
girara_list_iterator_t * girara_list_iterator_previous(girara_list_iterator_t *iter)
girara_list_t * girara_list_new2(girara_free_function_t gfree)
int(* girara_compare_function_t)(const void *data1, const void *data2)
bool girara_list_iterator_has_previous(girara_list_iterator_t *iter)
girara_list_t * girara_list_new(void)
void girara_list_append(girara_list_t *list, void *data)
void girara_list_iterator_set(girara_list_iterator_t *iter, void *data)
size_t girara_list_size(girara_list_t *list)
void girara_node_set_data(girara_tree_node_t *node, void *data)
girara_list_t * girara_sorted_list_new2(girara_compare_function_t cmp, girara_free_function_t gfree)
size_t girara_node_get_num_children(girara_tree_node_t *node)
void(* girara_free_function_t)(void *data)
void girara_list_free(girara_list_t *list)
ssize_t girara_list_position(girara_list_t *list, void *data)
void * girara_list_find(girara_list_t *list, girara_compare_function_t compare, const void *data)
struct girara_list_s girara_list_t
void * girara_node_get_data(girara_tree_node_t *node)
void girara_node_set_free_function(girara_tree_node_t *node, girara_free_function_t gfree)