From 1cefade73444d4670d9ae7c06e8f9cc55492fd79 Mon Sep 17 00:00:00 2001 From: ticktock35 Date: Mon, 15 Dec 2008 05:29:50 +0000 Subject: [PATCH] opkg: making hash_table_insert works as real hash_table. solving the update_file_ownership misbehaviour issue, and redundent installed files issue. git-svn-id: http://opkg.googlecode.com/svn/trunk@159 e8e0d7a0-c8d9-11dd-a880-a1081c7ac358 --- libopkg/hash_table.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/libopkg/hash_table.c b/libopkg/hash_table.c index b03dd74..e7f5a92 100644 --- a/libopkg/hash_table.c +++ b/libopkg/hash_table.c @@ -139,8 +139,13 @@ int hash_table_insert(hash_table_t *hash, const char *key, void *value) * before we can hook up the value */ if (0) opkg_message(NULL, OPKG_DEBUG2, "Function: %s. Value already in hash by collision for '%s' \n", __FUNCTION__, key); - while (hash_entry->next) + while (hash_entry->next) { hash_entry = hash_entry->next; + if (strcmp(hash_entry->key, key) == 0) { + hash_entry->data = value; + return 0; + } + } hash_entry->next = (hash_entry_t *)malloc(sizeof(hash_entry_t)); if (!hash_entry->next) { return -ENOMEM; -- 2.25.1