Commit a8b3eb65 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

No, Insert() does not need to be recursive

parent 8d2e90de
...@@ -154,8 +154,7 @@ time_ops = { CmpTime, DupDummy, FreeDummy, }; ...@@ -154,8 +154,7 @@ time_ops = { CmpTime, DupDummy, FreeDummy, };
*****************************************************************************/ *****************************************************************************/
static void WaitUnused ( vlc_object_t *, variable_t * ); static void WaitUnused ( vlc_object_t *, variable_t * );
static uint32_t HashString ( const char * ); static uint32_t HashString ( const char * );
static int Insert ( variable_t **, int, const char * ); static size_t Insert ( variable_t **, size_t, const char * );
static int InsertInner ( variable_t **, int, uint32_t );
static int Lookup ( vlc_object_t *, const char * ); static int Lookup ( vlc_object_t *, const char * );
static void CheckValue ( variable_t *, vlc_value_t * ); static void CheckValue ( variable_t *, vlc_value_t * );
...@@ -1182,54 +1181,35 @@ static uint32_t HashString( const char *psz_string ) ...@@ -1182,54 +1181,35 @@ static uint32_t HashString( const char *psz_string )
} }
/***************************************************************************** /*****************************************************************************
* Insert: find an empty slot to insert a new variable * Insert: find the slot where to insert a variable
*****************************************************************************
* We use a recursive inner function indexed on the hash. This function does
* nothing in the rare cases where a collision may occur, see Lookup()
* to see how we handle them.
* XXX: does this really need to be written recursively?
*****************************************************************************/ *****************************************************************************/
static int Insert( variable_t **pp_vars, int i_count, const char *psz_name ) static size_t Insert( variable_t **pp_vars, size_t n, const char *psz_name )
{
if( i_count == 0 )
{
return 0;
}
return InsertInner( pp_vars, i_count, HashString( psz_name ) );
}
static int InsertInner( variable_t **pp_vars, int i_count, uint32_t i_hash )
{ {
int i_middle; size_t offset = 0;
uint32_t hash = HashString( psz_name );
if( i_hash <= pp_vars[0]->i_hash ) if( n == 0 )
{
return 0; return 0;
}
if( i_hash >= pp_vars[i_count - 1]->i_hash ) while( n > 1 )
{ {
return i_count; size_t middle = n / 2;
}
i_middle = i_count / 2;
/* We know that 0 < i_middle */ if( hash < pp_vars[middle]->i_hash )
if( i_hash < pp_vars[i_middle]->i_hash )
{ {
return InsertInner( pp_vars, i_middle, i_hash ); n = middle;
} }
else
/* We know that i_middle + 1 < i_count */
if( i_hash > pp_vars[i_middle + 1]->i_hash )
{ {
return i_middle + 1 + InsertInner( pp_vars + i_middle + 1, pp_vars += middle;
i_count - i_middle - 1, offset += middle;
i_hash ); n -= middle;
}
} }
return i_middle + 1; if( hash >= pp_vars[0]->i_hash )
offset++;
return offset;
} }
static int u32cmp( const void *key, const void *data ) static int u32cmp( const void *key, const void *data )
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment