shash: New function shash_replace().
authorBen Pfaff <blp@nicira.com>
Wed, 30 Jun 2010 20:26:42 +0000 (13:26 -0700)
committerBen Pfaff <blp@nicira.com>
Wed, 30 Jun 2010 23:49:01 +0000 (16:49 -0700)
To be used in an upcoming commit.

lib/shash.c
lib/shash.h

index e2b1fe2c723bb302423f84b01d8d9a68ab523b9e..1664baf62e55fd3833302fd120b326dc651a3568 100644 (file)
@@ -147,6 +147,26 @@ shash_add_assert(struct shash *sh, const char *name, const void *data)
     assert(added);
 }
 
+/* Searches for 'name' in 'sh'.  If it does not already exist, adds it along
+ * with 'data' and returns NULL.  If it does already exist, replaces its data
+ * by 'data' and returns the data that it formerly contained. */
+void *
+shash_replace(struct shash *sh, const char *name, const void *data)
+{
+    size_t hash = hash_name(name);
+    struct shash_node *node;
+
+    node = shash_find__(sh, name, hash);
+    if (!node) {
+        shash_add_nocopy__(sh, xstrdup(name), data, hash);
+        return NULL;
+    } else {
+        void *old_data = node->data;
+        node->data = (void *) data;
+        return old_data;
+    }
+}
+
 void
 shash_delete(struct shash *sh, struct shash_node *node)
 {
index f97e6616d09c70087122841e775c4f742a108024..19e4c5d63b2a8a1f916261bebfb00d3064a400c8 100644 (file)
@@ -55,6 +55,7 @@ struct shash_node *shash_add(struct shash *, const char *, const void *);
 struct shash_node *shash_add_nocopy(struct shash *, char *, const void *);
 bool shash_add_once(struct shash *, const char *, const void *);
 void shash_add_assert(struct shash *, const char *, const void *);
+void *shash_replace(struct shash *, const char *, const void *data);
 void shash_delete(struct shash *, struct shash_node *);
 struct shash_node *shash_find(const struct shash *, const char *);
 void *shash_find_data(const struct shash *, const char *);