diff options
author | Michael I. Bushnell <mib@gnu.org> | 1994-06-24 21:32:36 +0000 |
---|---|---|
committer | Michael I. Bushnell <mib@gnu.org> | 1994-06-24 21:32:36 +0000 |
commit | 461e61630aae5ce7ff17a6714ed93f30c2c3d998 (patch) | |
tree | 0d41b9dfb663adb2330bf9c36764b69df88ac5ba | |
parent | 17008799405f94f21fdd87874096141f7f5f8e47 (diff) |
Formerly hash.c.~4~
-rw-r--r-- | proc/hash.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/proc/hash.c b/proc/hash.c index 52d7620d..89638331 100644 --- a/proc/hash.c +++ b/proc/hash.c @@ -35,6 +35,7 @@ struct htable { void **tab; int *ids; + void ****locps; int size; }; #define HASH_DEL ((void *) -1) @@ -53,6 +54,7 @@ addhash (struct htable *ht, { int h, firsth = -1; void **oldlist; + void ****oldlocps; int *oldids; int oldsize; int i; @@ -69,6 +71,7 @@ addhash (struct htable *ht, { ht->tab[h] = item; ht->ids[h] = id; + ht->locps[h] = locp; *locp = &ht->tab[h]; return; } @@ -78,9 +81,11 @@ addhash (struct htable *ht, oldlist = ht->tab; oldsize = ht->size; oldids = ht->ids; - + oldlocps = ht->locps; + ht->size = nextprime (2 * ht->size); ht->tab = malloc (ht->size * sizeof (void *)); + ht->locps = malloc (ht->size * sizeof (void ***)); ht->ids = malloc (ht->size * sizeof (int)); bzero (ht->tab, (ht->size * sizeof (void *))); @@ -88,13 +93,14 @@ addhash (struct htable *ht, for (i = 0; i < oldsize; i++) if (oldlist[i] != 0 && oldlist[i] != HASH_DEL) - addhash (ht, oldlist[i], locp, oldids[i]); + addhash (ht, oldlist[i], oldlocps[i], oldids[i]); addhash (ht, item, locp, id); if (oldlist) { free (oldlist); free (oldids); + free (oldlocps); } } |