summaryrefslogtreecommitdiffstats
path: root/hash.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2009-11-09 18:05:43 -0800
committerKaz Kylheku <kaz@kylheku.com>2009-11-09 18:05:43 -0800
commit42fdb7eb02593476b5030ce4a7dc471d4b01a49e (patch)
tree42848bdc2481b0b715e592064da5a171c2ae2807 /hash.c
parent6ce701137e44f06b68e772d2b8cbaef72800cd31 (diff)
downloadtxr-42fdb7eb02593476b5030ce4a7dc471d4b01a49e.tar.gz
txr-42fdb7eb02593476b5030ce4a7dc471d4b01a49e.tar.bz2
txr-42fdb7eb02593476b5030ce4a7dc471d4b01a49e.zip
Add hash removal.
Diffstat (limited to 'hash.c')
-rw-r--r--hash.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/hash.c b/hash.c
index 7516a128..d583862f 100644
--- a/hash.c
+++ b/hash.c
@@ -246,6 +246,16 @@ obj_t *gethash(obj_t *hash, obj_t *key)
return cdr(found);
}
+obj_t *remhash(obj_t *hash, obj_t *key)
+{
+ struct hash *h = (struct hash *) hash->co.handle;
+ obj_t **pchain = vecref_l(h->table, num(ll_hash(key) % h->modulus));
+ *pchain = alist_remove1(*pchain, key);
+ h->count--;
+ bug_unless (h->count >= 0);
+ return nil;
+}
+
/*
* Called from garbage collector. Hash module must process all weak tables
* that were visited during the marking phase, maintained in the list