]>
git.proxmox.com Git - mirror_ovs.git/blob - lib/sset.h
2 * Copyright (c) 2011, 2012, 2013, 2015, 2016 Nicira, Inc.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at:
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
20 #include "openvswitch/hmap.h"
28 struct hmap_node hmap_node
;
32 /* A set of strings. */
37 #define SSET_INITIALIZER(SSET) { HMAP_INITIALIZER(&(SSET)->map) }
40 void sset_init(struct sset
*);
41 void sset_destroy(struct sset
*);
42 void sset_clone(struct sset
*, const struct sset
*);
43 void sset_swap(struct sset
*, struct sset
*);
44 void sset_moved(struct sset
*);
46 /* String parsing and formatting. */
47 void sset_from_delimited_string(struct sset
*, const char *s
,
48 const char *delimiters
);
49 char *sset_join(const struct sset
*,
50 const char *delimiter
, const char *terminator
);
53 bool sset_is_empty(const struct sset
*);
54 size_t sset_count(const struct sset
*);
57 struct sset_node
*sset_add(struct sset
*, const char *);
58 struct sset_node
*sset_add_and_free(struct sset
*, char *);
59 void sset_add_assert(struct sset
*, const char *);
60 void sset_add_array(struct sset
*, char **, size_t n
);
63 void sset_clear(struct sset
*);
64 void sset_delete(struct sset
*, struct sset_node
*);
65 bool sset_find_and_delete(struct sset
*, const char *);
66 void sset_find_and_delete_assert(struct sset
*, const char *);
67 char *sset_pop(struct sset
*);
70 struct sset_node
*sset_find(const struct sset
*, const char *);
71 bool sset_contains(const struct sset
*, const char *);
72 bool sset_equals(const struct sset
*, const struct sset
*);
74 struct sset_position
{
75 struct hmap_position pos
;
78 struct sset_node
*sset_at_position(const struct sset
*,
79 struct sset_position
*);
82 void sset_intersect(struct sset
*, const struct sset
*);
84 /* Iteration macros. */
85 #define SSET_FOR_EACH(NAME, SSET) \
86 for ((NAME) = SSET_FIRST(SSET); \
88 (NAME) = SSET_NEXT(SSET, NAME))
90 #define SSET_FOR_EACH_SAFE(NAME, NEXT, SSET) \
91 for ((NAME) = SSET_FIRST(SSET); \
93 ? (NEXT) = SSET_NEXT(SSET, NAME), true \
97 const char **sset_array(const struct sset
*);
98 const char **sset_sort(const struct sset
*);
100 /* Implementation helper macros. */
102 #define SSET_NODE_FROM_HMAP_NODE(HMAP_NODE) \
103 CONTAINER_OF(HMAP_NODE, struct sset_node, hmap_node)
104 #define SSET_NAME_FROM_HMAP_NODE(HMAP_NODE) \
107 : (CONST_CAST(const char *, (SSET_NODE_FROM_HMAP_NODE(HMAP_NODE)->name)))
108 #define SSET_NODE_FROM_NAME(NAME) CONTAINER_OF(NAME, struct sset_node, name)
109 #define SSET_FIRST(SSET) \
110 (BUILD_ASSERT_TYPE(SSET, struct sset *), \
111 SSET_NAME_FROM_HMAP_NODE(hmap_first(&(SSET)->map)))
112 #define SSET_NEXT(SSET, NAME) \
113 (BUILD_ASSERT_TYPE(SSET, struct sset *), \
114 SSET_NAME_FROM_HMAP_NODE( \
115 hmap_next(&(SSET)->map, &SSET_NODE_FROM_NAME(NAME)->hmap_node)))