aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBen Pfaff <blp@nicira.com>2010-06-07 16:58:57 -0700
committerBen Pfaff <blp@nicira.com>2010-06-17 10:30:19 -0700
commita90b56b7708a17e8bd689d4a3558348f04cb8dcb (patch)
treec41442b00cc9975b4b13985d0aab589c387c1235
parente3648418c4bf028e6bca38bcbfc5a5ed493447fb (diff)
shash: New functions shash_destroy_free_data() and shash_clear_free_data().
-rw-r--r--lib/shash.c24
-rw-r--r--lib/shash.h2
2 files changed, 26 insertions, 0 deletions
diff --git a/lib/shash.c b/lib/shash.c
index 1a85b792..c4d3ccb8 100644
--- a/lib/shash.c
+++ b/lib/shash.c
@@ -40,6 +40,16 @@ shash_destroy(struct shash *sh)
}
}
+/* Like shash_destroy(), but also free() each node's 'data'. */
+void
+shash_destroy_free_data(struct shash *sh)
+{
+ if (sh) {
+ shash_clear_free_data(sh);
+ hmap_destroy(&sh->map);
+ }
+}
+
void
shash_swap(struct shash *a, struct shash *b)
{
@@ -64,6 +74,20 @@ shash_clear(struct shash *sh)
}
}
+/* Like shash_clear(), but also free() each node's 'data'. */
+void
+shash_clear_free_data(struct shash *sh)
+{
+ struct shash_node *node, *next;
+
+ SHASH_FOR_EACH_SAFE (node, next, sh) {
+ hmap_remove(&sh->map, &node->node);
+ free(node->data);
+ free(node->name);
+ free(node);
+ }
+}
+
bool
shash_is_empty(const struct shash *shash)
{
diff --git a/lib/shash.h b/lib/shash.h
index de850452..f97e6616 100644
--- a/lib/shash.h
+++ b/lib/shash.h
@@ -44,9 +44,11 @@ struct shash {
void shash_init(struct shash *);
void shash_destroy(struct shash *);
+void shash_destroy_free_data(struct shash *);
void shash_swap(struct shash *, struct shash *);
void shash_moved(struct shash *);
void shash_clear(struct shash *);
+void shash_clear_free_data(struct shash *);
bool shash_is_empty(const struct shash *);
size_t shash_count(const struct shash *);
struct shash_node *shash_add(struct shash *, const char *, const void *);