X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fsvec.h;h=341e26989801e5de54fcf2e26132bd08bcb190ee;hb=28c5588e8e1a8d091c5d2275232c35f2968a97fa;hp=7d8777fa8cc5f884a14e09873cb73a034ac6c6cb;hpb=34e63086edddcae06d7c1a4fa84fec0861e50758;p=sliver-openvswitch.git diff --git a/lib/svec.h b/lib/svec.h index 7d8777fa8..341e26989 100644 --- a/lib/svec.h +++ b/lib/svec.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2009 Nicira Networks. + * Copyright (c) 2008, 2009, 2011 Nicira, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -20,6 +20,10 @@ #include #include +#ifdef __cplusplus +extern "C" { +#endif + struct svec { char **names; size_t n; @@ -32,6 +36,7 @@ void svec_init(struct svec *); void svec_clone(struct svec *, const struct svec *); void svec_destroy(struct svec *); void svec_clear(struct svec *); +bool svec_is_empty(const struct svec *); void svec_add(struct svec *, const char *); void svec_add_nocopy(struct svec *, char *); void svec_del(struct svec *, const char *); @@ -57,4 +62,17 @@ char *svec_join(const struct svec *, const char *svec_back(const struct svec *); void svec_pop_back(struct svec *); +/* Iterates over the names in SVEC, assigning each name in turn to NAME and its + * index to INDEX. */ +#define SVEC_FOR_EACH(INDEX, NAME, SVEC) \ + for ((INDEX) = 0; \ + ((INDEX) < (SVEC)->n \ + ? (NAME) = (SVEC)->names[INDEX], 1 \ + : 0); \ + (INDEX)++) + +#ifdef __cplusplus +} +#endif + #endif /* svec.h */