]>
git.ipfire.org Git - thirdparty/git.git/blob - strmap.h
8 unsigned int strdup_strings
:1;
12 struct hashmap_entry ent
;
17 int cmp_strmap_entry(const void *hashmap_cmp_fn_data
,
18 const struct hashmap_entry
*entry1
,
19 const struct hashmap_entry
*entry2
,
22 #define STRMAP_INIT { \
23 .map = HASHMAP_INIT(cmp_strmap_entry, NULL), \
24 .strdup_strings = 1, \
26 #define STRINTMAP_INIT { \
30 #define STRSET_INIT { .map = STRMAP_INIT }
33 * Initialize the members of the strmap. Any keys added to the strmap will
34 * be strdup'ed with their memory managed by the strmap.
36 void strmap_init(struct strmap
*map
);
39 * Same as strmap_init, but for those who want to control the memory management
40 * carefully instead of using the default of strdup_strings=1.
42 void strmap_init_with_options(struct strmap
*map
,
46 * Remove all entries from the map, releasing any allocated resources.
48 void strmap_clear(struct strmap
*map
, int free_values
);
51 * Similar to strmap_clear() but leaves map->map->table allocated and
52 * pre-sized so that subsequent uses won't need as many rehashings.
54 void strmap_partial_clear(struct strmap
*map
, int free_values
);
57 * Insert "str" into the map, pointing to "data".
59 * If an entry for "str" already exists, its data pointer is overwritten, and
60 * the original data pointer returned. Otherwise, returns NULL.
62 void *strmap_put(struct strmap
*map
, const char *str
, void *data
);
65 * Return the strmap_entry mapped by "str", or NULL if there is not such
68 struct strmap_entry
*strmap_get_entry(struct strmap
*map
, const char *str
);
71 * Return the data pointer mapped by "str", or NULL if the entry does not
74 void *strmap_get(struct strmap
*map
, const char *str
);
77 * Return non-zero iff "str" is present in the map. This differs from
78 * strmap_get() in that it can distinguish entries with a NULL data pointer.
80 int strmap_contains(struct strmap
*map
, const char *str
);
83 * Remove the given entry from the strmap. If the string isn't in the
84 * strmap, the map is not altered.
86 void strmap_remove(struct strmap
*map
, const char *str
, int free_value
);
89 * Return how many entries the strmap has.
91 static inline unsigned int strmap_get_size(struct strmap
*map
)
93 return hashmap_get_size(&map
->map
);
97 * Return whether the strmap is empty.
99 static inline int strmap_empty(struct strmap
*map
)
101 return strmap_get_size(map
) == 0;
105 * iterate through @map using @iter, @var is a pointer to a type strmap_entry
107 #define strmap_for_each_entry(mystrmap, iter, var) \
108 hashmap_for_each_entry(&(mystrmap)->map, iter, var, ent)
113 * A map of string -> int, typecasting the void* of strmap to an int.
115 * Primary differences:
116 * 1) Since the void* value is just an int in disguise, there is no value
117 * to free. (Thus one fewer argument to strintmap_clear)
118 * 2) strintmap_get() returns an int, or returns the default_value if the
119 * key is not found in the strintmap.
120 * 3) No strmap_put() equivalent; strintmap_set() and strintmap_incr()
129 #define strintmap_for_each_entry(mystrmap, iter, var) \
130 strmap_for_each_entry(&(mystrmap)->map, iter, var)
132 static inline void strintmap_init(struct strintmap
*map
, int default_value
)
134 strmap_init(&map
->map
);
135 map
->default_value
= default_value
;
138 static inline void strintmap_init_with_options(struct strintmap
*map
,
142 strmap_init_with_options(&map
->map
, strdup_strings
);
143 map
->default_value
= default_value
;
146 static inline void strintmap_clear(struct strintmap
*map
)
148 strmap_clear(&map
->map
, 0);
151 static inline void strintmap_partial_clear(struct strintmap
*map
)
153 strmap_partial_clear(&map
->map
, 0);
156 static inline int strintmap_contains(struct strintmap
*map
, const char *str
)
158 return strmap_contains(&map
->map
, str
);
161 static inline void strintmap_remove(struct strintmap
*map
, const char *str
)
163 return strmap_remove(&map
->map
, str
, 0);
166 static inline int strintmap_empty(struct strintmap
*map
)
168 return strmap_empty(&map
->map
);
171 static inline unsigned int strintmap_get_size(struct strintmap
*map
)
173 return strmap_get_size(&map
->map
);
177 * Returns the value for str in the map. If str isn't found in the map,
178 * the map's default_value is returned.
180 static inline int strintmap_get(struct strintmap
*map
, const char *str
)
182 struct strmap_entry
*result
= strmap_get_entry(&map
->map
, str
);
184 return map
->default_value
;
185 return (intptr_t)result
->value
;
188 static inline void strintmap_set(struct strintmap
*map
, const char *str
,
191 strmap_put(&map
->map
, str
, (void *)v
);
195 * Increment the value for str by amt. If str isn't in the map, add it and
196 * set its value to default_value + amt.
198 void strintmap_incr(struct strintmap
*map
, const char *str
, intptr_t amt
);
204 * Primary differences with strmap:
205 * 1) The value is always NULL, and ignored. As there is no value to free,
206 * there is one fewer argument to strset_clear
207 * 2) No strset_get() because there is no value.
208 * 3) No strset_put(); use strset_add() instead.
215 #define strset_for_each_entry(mystrset, iter, var) \
216 strmap_for_each_entry(&(mystrset)->map, iter, var)
218 static inline void strset_init(struct strset
*set
)
220 strmap_init(&set
->map
);
223 static inline void strset_init_with_options(struct strset
*set
,
226 strmap_init_with_options(&set
->map
, strdup_strings
);
229 static inline void strset_clear(struct strset
*set
)
231 strmap_clear(&set
->map
, 0);
234 static inline void strset_partial_clear(struct strset
*set
)
236 strmap_partial_clear(&set
->map
, 0);
239 static inline int strset_contains(struct strset
*set
, const char *str
)
241 return strmap_contains(&set
->map
, str
);
244 static inline void strset_remove(struct strset
*set
, const char *str
)
246 return strmap_remove(&set
->map
, str
, 0);
249 static inline int strset_empty(struct strset
*set
)
251 return strmap_empty(&set
->map
);
254 static inline unsigned int strset_get_size(struct strset
*set
)
256 return strmap_get_size(&set
->map
);
259 /* Returns 1 if str is added to the set; returns 0 if str was already in set */
260 int strset_add(struct strset
*set
, const char *str
);
262 #endif /* STRMAP_H */