X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=src%2FSDCChasht.c;h=dd6322d451c632b5a70231f1ed0f57b6f979e628;hb=fd94924a3d743c1c82f4b370d9401d7239172789;hp=d7551c04ac30a53b002e03ed940bb5e1fc60885a;hpb=35b2268330964fce85f91c0f4caade091d0915f6;p=fw%2Fsdcc diff --git a/src/SDCChasht.c b/src/SDCChasht.c index d7551c04..dd6322d4 100644 --- a/src/SDCChasht.c +++ b/src/SDCChasht.c @@ -62,7 +62,7 @@ newHashTable (int size) if (!(htab->table = Safe_alloc ((size + 1) * sizeof (hashtItem *)))) { fprintf (stderr, "out of virtual memory %s %d\n", - __FILE__, (size + 1) * sizeof (hashtItem *)); + __FILE__, (size + 1) * (int) sizeof (hashtItem *)); exit (1); } htab->minKey = htab->size = size; @@ -561,11 +561,21 @@ _hash (const char *sz) void shash_add (hTab ** h, const char *szKey, const char *szValue) { + char *val; int key = _hash (szKey); - /* First, delete any that currently exist */ - hTabDeleteByKey (h, key, szKey, _compare); + + /* Find value of the item */ + val = (char *)hTabFindByKey(*h, key, szKey, _compare); + /* Delete any that currently exist */ + hTabDeleteByKey(h, key, szKey, _compare); + /* Deallocate old value in not NULL */ + if (val != NULL) + Safe_free(val); + /* Duplicate new value if not NULL */ + if (szValue != NULL) + szValue = Safe_strdup(szValue); /* Now add in ours */ - hTabAddItemLong (h, key, Safe_strdup (szKey), Safe_strdup (szValue)); + hTabAddItemLong (h, key, Safe_strdup (szKey), (void *)szValue); } const char *