mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-12 23:46:17 +01:00
insert/replace were identical except for a single line. Replace both with
2007-11-27 Ryan Lortie <desrt@desrt.ca> * glib/ghash.c (g_hash_table_insert, g_hash_table_replace, g_hash_table_insert_internal): insert/replace were identical except for a single line. Replace both with a common function. svn path=/trunk/; revision=5964
This commit is contained in:
parent
53e58aafb7
commit
0adbacbff9
@ -1,3 +1,9 @@
|
|||||||
|
2007-11-27 Ryan Lortie <desrt@desrt.ca>
|
||||||
|
|
||||||
|
* glib/ghash.c (g_hash_table_insert, g_hash_table_replace,
|
||||||
|
g_hash_table_insert_internal): insert/replace were identical except
|
||||||
|
for a single line. Replace both with a common function.
|
||||||
|
|
||||||
2007-11-27 Alexander Larsson <alexl@redhat.com>
|
2007-11-27 Alexander Larsson <alexl@redhat.com>
|
||||||
|
|
||||||
* gio/Makefile.am:
|
* gio/Makefile.am:
|
||||||
|
94
glib/ghash.c
94
glib/ghash.c
@ -322,6 +322,43 @@ g_hash_table_lookup_extended (GHashTable *hash_table,
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
g_hash_table_insert_internal (GHashTable *hash_table,
|
||||||
|
gpointer key,
|
||||||
|
gpointer value,
|
||||||
|
gboolean keep_new_key)
|
||||||
|
{
|
||||||
|
GHashNode **node;
|
||||||
|
guint key_hash;
|
||||||
|
|
||||||
|
g_return_if_fail (hash_table != NULL);
|
||||||
|
g_return_if_fail (hash_table->ref_count > 0);
|
||||||
|
|
||||||
|
node = g_hash_table_lookup_node (hash_table, key, &key_hash);
|
||||||
|
|
||||||
|
if (*node)
|
||||||
|
{
|
||||||
|
if (hash_table->key_destroy_func)
|
||||||
|
{
|
||||||
|
if (keep_new_key)
|
||||||
|
hash_table->key_destroy_func ((*node)->key);
|
||||||
|
else
|
||||||
|
hash_table->key_destroy_func (key);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hash_table->value_destroy_func)
|
||||||
|
hash_table->value_destroy_func ((*node)->value);
|
||||||
|
|
||||||
|
(*node)->value = value;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
*node = g_hash_node_new (key, value, key_hash);
|
||||||
|
hash_table->nnodes++;
|
||||||
|
G_HASH_TABLE_RESIZE (hash_table);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* g_hash_table_insert:
|
* g_hash_table_insert:
|
||||||
* @hash_table: a #GHashTable.
|
* @hash_table: a #GHashTable.
|
||||||
@ -341,36 +378,7 @@ g_hash_table_insert (GHashTable *hash_table,
|
|||||||
gpointer key,
|
gpointer key,
|
||||||
gpointer value)
|
gpointer value)
|
||||||
{
|
{
|
||||||
GHashNode **node;
|
return g_hash_table_insert_internal (hash_table, key, value, FALSE);
|
||||||
guint key_hash;
|
|
||||||
|
|
||||||
g_return_if_fail (hash_table != NULL);
|
|
||||||
g_return_if_fail (hash_table->ref_count > 0);
|
|
||||||
|
|
||||||
node = g_hash_table_lookup_node (hash_table, key, &key_hash);
|
|
||||||
|
|
||||||
if (*node)
|
|
||||||
{
|
|
||||||
/* do not reset node->key in this place, keeping
|
|
||||||
* the old key is the intended behaviour.
|
|
||||||
* g_hash_table_replace() can be used instead.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* free the passed key */
|
|
||||||
if (hash_table->key_destroy_func)
|
|
||||||
hash_table->key_destroy_func (key);
|
|
||||||
|
|
||||||
if (hash_table->value_destroy_func)
|
|
||||||
hash_table->value_destroy_func ((*node)->value);
|
|
||||||
|
|
||||||
(*node)->value = value;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*node = g_hash_node_new (key, value, key_hash);
|
|
||||||
hash_table->nnodes++;
|
|
||||||
G_HASH_TABLE_RESIZE (hash_table);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -391,31 +399,7 @@ g_hash_table_replace (GHashTable *hash_table,
|
|||||||
gpointer key,
|
gpointer key,
|
||||||
gpointer value)
|
gpointer value)
|
||||||
{
|
{
|
||||||
GHashNode **node;
|
return g_hash_table_insert_internal (hash_table, key, value, TRUE);
|
||||||
guint key_hash;
|
|
||||||
|
|
||||||
g_return_if_fail (hash_table != NULL);
|
|
||||||
g_return_if_fail (hash_table->ref_count > 0);
|
|
||||||
|
|
||||||
node = g_hash_table_lookup_node (hash_table, key, &key_hash);
|
|
||||||
|
|
||||||
if (*node)
|
|
||||||
{
|
|
||||||
if (hash_table->key_destroy_func)
|
|
||||||
hash_table->key_destroy_func ((*node)->key);
|
|
||||||
|
|
||||||
if (hash_table->value_destroy_func)
|
|
||||||
hash_table->value_destroy_func ((*node)->value);
|
|
||||||
|
|
||||||
(*node)->key = key;
|
|
||||||
(*node)->value = value;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*node = g_hash_node_new (key, value, key_hash);
|
|
||||||
hash_table->nnodes++;
|
|
||||||
G_HASH_TABLE_RESIZE (hash_table);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user