diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2016-11-23 20:45:54 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2016-11-23 20:45:54 -0800 |
commit | 026acf026747478ed25f20671b43c084dd0cbff8 (patch) | |
tree | f9cf51f253ce4e572e3a5872d0700ff69bf03a2e | |
parent | 7394c87e3cc11fdb0b7df884603b183df1c41eda (diff) | |
download | txr-026acf026747478ed25f20671b43c084dd0cbff8.tar.gz txr-026acf026747478ed25f20671b43c084dd0cbff8.tar.bz2 txr-026acf026747478ed25f20671b43c084dd0cbff8.zip |
Adding clearhash function.
This is needed for an upcoming bugfix, so why not expose it as
an intrinsic.
* hash.c (clearhash): New function.
(hash_init): clearhash intrinsic registered.
* hash.h (clearhash): Declared.
* txr.1: Documented clearhash.
-rw-r--r-- | hash.c | 13 | ||||
-rw-r--r-- | hash.h | 1 | ||||
-rw-r--r-- | txr.1 | 21 |
3 files changed, 35 insertions, 0 deletions
@@ -754,6 +754,18 @@ val remhash(val hash, val key) return nil; } +val clearhash(val hash) +{ + struct hash *h = coerce(struct hash *, cobj_handle(hash, hash_s)); + val mod = num_fast(256); + val table = vector(mod, nil); + cnum oldcount = h->count; + h->modulus = c_num(mod); + h->count = 0; + h->table = table; + return oldcount ? num(oldcount) : nil; +} + val hash_count(val hash) { struct hash *h = coerce(struct hash *, cobj_handle(hash, hash_s)); @@ -1374,6 +1386,7 @@ void hash_init(void) reg_fun(intern(lit("sethash"), user_package), func_n3(sethash)); reg_fun(intern(lit("pushhash"), user_package), func_n3(pushhash)); reg_fun(intern(lit("remhash"), user_package), func_n2(remhash)); + reg_fun(intern(lit("clearhash"), user_package), func_n1(clearhash)); reg_fun(intern(lit("hash-count"), user_package), func_n1(hash_count)); reg_fun(intern(lit("get-hash-userdata"), user_package), ghu); reg_fun(intern(lit("hash-userdata"), user_package), ghu); @@ -39,6 +39,7 @@ val gethash_f(val hash, val key, loc found); val sethash(val hash, val key, val value); val pushhash(val hash, val key, val value); val remhash(val hash, val key); +val clearhash(val hash); val hash_count(val hash); val get_hash_userdata(val hash); val set_hash_userdata(val hash, val data); @@ -34998,6 +34998,27 @@ is returned. Otherwise .code nil is returned. +.coNP Function @ clearhash +.synb +.mets (clearhash << hash ) +.syne +.desc +The +.code clearhash +function removes all keys-value pairs from +.metn hash , +causing it to be empty. + +If +.meta hash +is already empty prior to the operation, then +.codn nil , +is returned. + +Otherwise an integer is returned indicating the number of entries +that were purged from +.metn hash . + .coNP Function @ hash-count .synb .mets (hash-count << hash ) |