2 #include "lfds700_hash_addonly_internal.h"
8 /****************************************************************************/
9 void lfds700_hash_a_iterate_init( struct lfds700_hash_a_state *has, struct lfds700_hash_a_iterate *hai )
11 LFDS700_PAL_ASSERT( has != NULL );
12 LFDS700_PAL_ASSERT( hai != NULL );
14 hai->baus = has->baus_array;
15 hai->baus_end = has->baus_array + has->array_size;
25 /****************************************************************************/
26 int lfds700_hash_a_iterate( struct lfds700_hash_a_iterate *hai, struct lfds700_hash_a_element **hae )
28 enum lfds700_misc_flag
29 finished_flag = LFDS700_MISC_FLAG_LOWERED;
34 LFDS700_PAL_ASSERT( hai != NULL );
35 LFDS700_PAL_ASSERT( hae != NULL );
37 while( finished_flag == LFDS700_MISC_FLAG_LOWERED )
39 lfds700_btree_au_get_by_absolute_position_and_then_by_relative_position( hai->baus, &hai->baue, LFDS700_BTREE_AU_ABSOLUTE_POSITION_SMALLEST_IN_TREE, LFDS700_BTREE_AU_RELATIVE_POSITION_NEXT_LARGER_ELEMENT_IN_ENTIRE_TREE );
41 if( hai->baue != NULL )
43 *hae = LFDS700_BTREE_AU_GET_VALUE_FROM_ELEMENT( *hai->baue );
44 finished_flag = LFDS700_MISC_FLAG_RAISED;
48 if( hai->baue == NULL )
49 if( ++hai->baus == hai->baus_end )
52 finished_flag = LFDS700_MISC_FLAG_RAISED;