5 months ago
cx_tree_add_iter() - optimize check for empty trees
relates to #390
src/tree.c | file | annotate | diff | comparison | revisions |
--- a/src/tree.c Tue Aug 20 11:02:54 2024 +0200 +++ b/src/tree.c Tue Aug 20 12:39:35 2024 +0200 @@ -531,27 +531,31 @@ ptrdiff_t loc_prev, ptrdiff_t loc_next ) { + // iter not valid? cancel... + if (!iter->valid(iter)) return 0; + size_t processed = 0; void *current_node = *root; + void *elem; + + // if there is no root, yet - process the first node from the iter + // as the new root node + if (current_node == NULL) { + elem = *(void **) (iter->current(iter)); + // no node in tree, yet - add a new one + current_node = cfunc(elem, NULL, cdata); + // node creation failed - stop processing + if (current_node == NULL) return 0; + cx_tree_zero_pointers(current_node, cx_tree_ptr_locations); + *root = current_node; + processed++; + iter->next(iter); + } + for (void **eptr; iter->valid(iter) && (eptr = iter->current(iter)) != NULL; iter->next(iter)) { - void *elem = *eptr; - - if (current_node == NULL) { - // no node in tree, yet - add a new one - current_node = cfunc(elem, NULL, cdata); - // node creation failed - stop processing - if (current_node == NULL) { - // but honestly... nothing should have been processed - assert(processed == 0); - return 0; - } - cx_tree_zero_pointers(current_node, cx_tree_ptr_locations); - *root = current_node; - processed++; - continue; - } + elem = *eptr; // start searching from current node void *match;