]>
Commit | Line | Data |
---|---|---|
064af421 | 1 | /* |
37e7f427 | 2 | * Copyright (c) 2009, 2010 Nicira Networks. |
064af421 | 3 | * |
a14bc59f BP |
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: | |
064af421 | 7 | * |
a14bc59f BP |
8 | * http://www.apache.org/licenses/LICENSE-2.0 |
9 | * | |
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. | |
064af421 BP |
15 | */ |
16 | ||
17 | #ifndef SHASH_H | |
18 | #define SHASH_H 1 | |
19 | ||
20 | #include "hmap.h" | |
21 | ||
fbfffdbb BP |
22 | #ifdef __cplusplus |
23 | extern "C" { | |
24 | #endif | |
25 | ||
064af421 BP |
26 | struct shash_node { |
27 | struct hmap_node node; | |
28 | char *name; | |
29 | void *data; | |
30 | }; | |
31 | ||
32 | struct shash { | |
33 | struct hmap map; | |
34 | }; | |
35 | ||
36 | #define SHASH_INITIALIZER(SHASH) { HMAP_INITIALIZER(&(SHASH)->map) } | |
37 | ||
4e8e4213 BP |
38 | #define SHASH_FOR_EACH(SHASH_NODE, SHASH) \ |
39 | HMAP_FOR_EACH (SHASH_NODE, node, &(SHASH)->map) | |
fd30311c | 40 | |
4e8e4213 BP |
41 | #define SHASH_FOR_EACH_SAFE(SHASH_NODE, NEXT, SHASH) \ |
42 | HMAP_FOR_EACH_SAFE (SHASH_NODE, NEXT, node, &(SHASH)->map) | |
fd30311c | 43 | |
064af421 BP |
44 | void shash_init(struct shash *); |
45 | void shash_destroy(struct shash *); | |
a90b56b7 | 46 | void shash_destroy_free_data(struct shash *); |
37e7f427 | 47 | void shash_swap(struct shash *, struct shash *); |
baa8f41b | 48 | void shash_moved(struct shash *); |
064af421 | 49 | void shash_clear(struct shash *); |
a90b56b7 | 50 | void shash_clear_free_data(struct shash *); |
732dcb37 | 51 | bool shash_is_empty(const struct shash *); |
c01da229 | 52 | size_t shash_count(const struct shash *); |
55213fd5 | 53 | struct shash_node *shash_add(struct shash *, const char *, const void *); |
ce5a3e38 | 54 | struct shash_node *shash_add_nocopy(struct shash *, char *, const void *); |
76343538 | 55 | bool shash_add_once(struct shash *, const char *, const void *); |
4a1ee6ae | 56 | void shash_add_assert(struct shash *, const char *, const void *); |
79903dd1 | 57 | void *shash_replace(struct shash *, const char *, const void *data); |
064af421 | 58 | void shash_delete(struct shash *, struct shash_node *); |
4f222648 | 59 | char *shash_steal(struct shash *, struct shash_node *); |
064af421 BP |
60 | struct shash_node *shash_find(const struct shash *, const char *); |
61 | void *shash_find_data(const struct shash *, const char *); | |
837e8097 | 62 | void *shash_find_and_delete(struct shash *, const char *); |
4a1ee6ae | 63 | void *shash_find_and_delete_assert(struct shash *, const char *); |
7efc68eb | 64 | struct shash_node *shash_first(const struct shash *); |
07423999 | 65 | const struct shash_node **shash_sort(const struct shash *); |
37e7f427 | 66 | bool shash_equal_keys(const struct shash *, const struct shash *); |
f2f7be86 | 67 | struct shash_node *shash_random_node(struct shash *); |
064af421 | 68 | |
c56d226f BP |
69 | /* Working with "smaps": shashes used as string-to-string maps. */ |
70 | void smap_destroy(struct shash *); | |
71 | bool smap_equal(const struct shash *, const struct shash *); | |
72 | void smap_clone(struct shash *, const struct shash *); | |
73 | void smap_add(struct shash *, const char *key, const char *value); | |
74 | ||
fbfffdbb BP |
75 | #ifdef __cplusplus |
76 | } | |
77 | #endif | |
78 | ||
064af421 | 79 | #endif /* shash.h */ |