X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=lib%2Fshash.h;h=471918b270242681475fcfc92318011c1cd3fd81;hb=67a4917b07031b387beafaedce413b4207214059;hp=72d8302007462fb74f1d10066e04e77406182b3e;hpb=78299b0a6871a31c8b0cce5ef3f67ab465ab094f;p=openvswitch diff --git a/lib/shash.h b/lib/shash.h index 72d83020..471918b2 100644 --- a/lib/shash.h +++ b/lib/shash.h @@ -19,6 +19,10 @@ #include "hmap.h" +#ifdef __cplusplus +extern "C" { +#endif + struct shash_node { struct hmap_node node; char *name; @@ -31,6 +35,13 @@ struct shash { #define SHASH_INITIALIZER(SHASH) { HMAP_INITIALIZER(&(SHASH)->map) } +#define SHASH_FOR_EACH(SHASH_NODE, SHASH) \ + HMAP_FOR_EACH (SHASH_NODE, struct shash_node, node, &(SHASH)->map) + +#define SHASH_FOR_EACH_SAFE(SHASH_NODE, NEXT, SHASH) \ + HMAP_FOR_EACH_SAFE (SHASH_NODE, NEXT, struct shash_node, node, \ + &(SHASH)->map) + void shash_init(struct shash *); void shash_destroy(struct shash *); void shash_clear(struct shash *); @@ -41,4 +52,8 @@ struct shash_node *shash_find(const struct shash *, const char *); void *shash_find_data(const struct shash *, const char *); struct shash_node *shash_first(const struct shash *); +#ifdef __cplusplus +} +#endif + #endif /* shash.h */