[ovs-dev] [QoS v2 16/17] shash: New functions shash_destroy_free_data() and shash_clear_free_data().
Justin Pettit
jpettit at nicira.com
Wed Jun 9 22:35:37 UTC 2010
Looks good.
--Justin
On Jun 8, 2010, at 1:41 PM, Ben Pfaff wrote:
> ---
> lib/shash.c | 24 ++++++++++++++++++++++++
> lib/shash.h | 2 ++
> 2 files changed, 26 insertions(+), 0 deletions(-)
>
> diff --git a/lib/shash.c b/lib/shash.c
> index 1a85b79..c4d3ccb 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 de85045..f97e661 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 *);
> --
> 1.7.1
>
>
> _______________________________________________
> dev mailing list
> dev at openvswitch.org
> http://openvswitch.org/mailman/listinfo/dev_openvswitch.org
More information about the dev
mailing list