]> git.ipfire.org Git - thirdparty/git.git/blame - oidmap.h
Merge branch 'sb/userdiff-dts'
[thirdparty/git.git] / oidmap.h
CommitLineData
9e6fabde
JT
1#ifndef OIDMAP_H
2#define OIDMAP_H
3
ef3ca954 4#include "cache.h"
9e6fabde
JT
5#include "hashmap.h"
6
7/*
8 * struct oidmap_entry is a structure representing an entry in the hash table,
9 * which must be used as first member of user data structures.
10 *
11 * Users should set the oid field. oidmap_put() will populate the
12 * internal_entry field.
13 */
14struct oidmap_entry {
15 /* For internal use only */
16 struct hashmap_entry internal_entry;
17
18 struct object_id oid;
19};
20
21struct oidmap {
22 struct hashmap map;
23};
24
25#define OIDMAP_INIT { { NULL } }
26
27/*
28 * Initializes an oidmap structure.
29 *
30 * `map` is the oidmap to initialize.
31 *
32 * If the total number of entries is known in advance, the `initial_size`
33 * parameter may be used to preallocate a sufficiently large table and thus
34 * prevent expensive resizing. If 0, the table is dynamically resized.
35 */
55454427 36void oidmap_init(struct oidmap *map, size_t initial_size);
9e6fabde
JT
37
38/*
39 * Frees an oidmap structure and allocated memory.
40 *
41 * If `free_entries` is true, each oidmap_entry in the map is freed as well
42 * using stdlibs free().
43 */
55454427 44void oidmap_free(struct oidmap *map, int free_entries);
9e6fabde
JT
45
46/*
47 * Returns the oidmap entry for the specified oid, or NULL if not found.
48 */
55454427 49void *oidmap_get(const struct oidmap *map,
ad6dad09 50 const struct object_id *key);
9e6fabde
JT
51
52/*
53 * Adds or replaces an oidmap entry.
54 *
55 * ((struct oidmap_entry *) entry)->internal_entry will be populated by this
56 * function.
57 *
58 * Returns the replaced entry, or NULL if not found (i.e. the entry was added).
59 */
55454427 60void *oidmap_put(struct oidmap *map, void *entry);
9e6fabde
JT
61
62/*
63 * Removes an oidmap entry matching the specified oid.
64 *
65 * Returns the removed entry, or NULL if not found.
66 */
55454427 67void *oidmap_remove(struct oidmap *map, const struct object_id *key);
9e6fabde 68
314f354e
JH
69
70struct oidmap_iter {
71 struct hashmap_iter h_iter;
72};
73
74static inline void oidmap_iter_init(struct oidmap *map, struct oidmap_iter *iter)
75{
76 hashmap_iter_init(&map->map, &iter->h_iter);
77}
78
79static inline void *oidmap_iter_next(struct oidmap_iter *iter)
80{
87571c3f
EW
81 /* TODO: this API could be reworked to do compile-time type checks */
82 return (void *)hashmap_iter_next(&iter->h_iter);
314f354e
JH
83}
84
85static inline void *oidmap_iter_first(struct oidmap *map,
86 struct oidmap_iter *iter)
87{
88 oidmap_iter_init(map, iter);
87571c3f
EW
89 /* TODO: this API could be reworked to do compile-time type checks */
90 return (void *)oidmap_iter_next(iter);
314f354e
JH
91}
92
9e6fabde 93#endif