aboutsummaryrefslogtreecommitdiffstats
path: root/src/mesa/program/hash_table.c
diff options
context:
space:
mode:
authorEric Anholt <[email protected]>2011-03-23 12:05:56 -0700
committerEric Anholt <[email protected]>2011-04-26 12:20:02 -0700
commitb061b5ffb055c64ffc45e506bad877f47942ba01 (patch)
treec47250ca0738edd91efdacdf866eb9c3945a6a49 /src/mesa/program/hash_table.c
parentb943b9b1a696cf51adfb2a18bcb9cf503fb2737f (diff)
hash_table: Add an iterator for doing things like cleanup of the HT.
Without this, consumers often have to keep linked lists of the entries, at additional malloc cost. Reviewed-by: Kenneth Graunke <[email protected]>
Diffstat (limited to 'src/mesa/program/hash_table.c')
-rw-r--r--src/mesa/program/hash_table.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/src/mesa/program/hash_table.c b/src/mesa/program/hash_table.c
index f7ef366c1a0..877a9e2ffc3 100644
--- a/src/mesa/program/hash_table.c
+++ b/src/mesa/program/hash_table.c
@@ -160,6 +160,25 @@ hash_table_remove(struct hash_table *ht, const void *key)
}
}
+void
+hash_table_call_foreach(struct hash_table *ht,
+ void (*callback)(const void *key,
+ void *data,
+ void *closure),
+ void *closure)
+{
+ int bucket;
+
+ for (bucket = 0; bucket < ht->num_buckets; bucket++) {
+ struct node *node, *temp;
+ foreach_s(node, temp, &ht->buckets[bucket]) {
+ struct hash_node *hn = (struct hash_node *) node;
+
+ callback(hn->key, hn->data, closure);
+ }
+ }
+}
+
unsigned
hash_table_string_hash(const void *key)
{