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.
11 * Users should set the oid field. oidmap_put() will populate the
12 * internal_entry field.
15 /* For internal use only */
16 struct hashmap_entry internal_entry
;
25 #define OIDMAP_INIT { { NULL } }
28 * Initializes an oidmap structure.
30 * `map` is the oidmap to initialize.
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.
36 void oidmap_init(struct oidmap
*map
, size_t initial_size
);
39 * Frees an oidmap structure and allocated memory.
41 * If `free_entries` is true, each oidmap_entry in the map is freed as well
42 * using stdlibs free().
44 void oidmap_free(struct oidmap
*map
, int free_entries
);
47 * Returns the oidmap entry for the specified oid, or NULL if not found.
49 void *oidmap_get(const struct oidmap
*map
,
50 const struct object_id
*key
);
53 * Adds or replaces an oidmap entry.
55 * ((struct oidmap_entry *) entry)->internal_entry will be populated by this
58 * Returns the replaced entry, or NULL if not found (i.e. the entry was added).
60 void *oidmap_put(struct oidmap
*map
, void *entry
);
63 * Removes an oidmap entry matching the specified oid.
65 * Returns the removed entry, or NULL if not found.
67 void *oidmap_remove(struct oidmap
*map
, const struct object_id
*key
);
71 struct hashmap_iter h_iter
;
74 static inline void oidmap_iter_init(struct oidmap
*map
, struct oidmap_iter
*iter
)
76 hashmap_iter_init(&map
->map
, &iter
->h_iter
);
79 static inline void *oidmap_iter_next(struct oidmap_iter
*iter
)
81 /* TODO: this API could be reworked to do compile-time type checks */
82 return (void *)hashmap_iter_next(&iter
->h_iter
);
85 static inline void *oidmap_iter_first(struct oidmap
*map
,
86 struct oidmap_iter
*iter
)
88 oidmap_iter_init(map
, iter
);
89 /* TODO: this API could be reworked to do compile-time type checks */
90 return (void *)oidmap_iter_next(iter
);