Squashed 'third_party/git/' content from commit cb71568594
git-subtree-dir: third_party/git git-subtree-split: cb715685942260375e1eb8153b0768a376e4ece7
This commit is contained in:
commit
1b593e1ea4
3629 changed files with 1139935 additions and 0 deletions
91
oidmap.h
Normal file
91
oidmap.h
Normal file
|
|
@ -0,0 +1,91 @@
|
|||
#ifndef OIDMAP_H
|
||||
#define OIDMAP_H
|
||||
|
||||
#include "cache.h"
|
||||
#include "hashmap.h"
|
||||
|
||||
/*
|
||||
* struct oidmap_entry is a structure representing an entry in the hash table,
|
||||
* which must be used as first member of user data structures.
|
||||
*
|
||||
* Users should set the oid field. oidmap_put() will populate the
|
||||
* internal_entry field.
|
||||
*/
|
||||
struct oidmap_entry {
|
||||
/* For internal use only */
|
||||
struct hashmap_entry internal_entry;
|
||||
|
||||
struct object_id oid;
|
||||
};
|
||||
|
||||
struct oidmap {
|
||||
struct hashmap map;
|
||||
};
|
||||
|
||||
#define OIDMAP_INIT { { NULL } }
|
||||
|
||||
/*
|
||||
* Initializes an oidmap structure.
|
||||
*
|
||||
* `map` is the oidmap to initialize.
|
||||
*
|
||||
* If the total number of entries is known in advance, the `initial_size`
|
||||
* parameter may be used to preallocate a sufficiently large table and thus
|
||||
* prevent expensive resizing. If 0, the table is dynamically resized.
|
||||
*/
|
||||
void oidmap_init(struct oidmap *map, size_t initial_size);
|
||||
|
||||
/*
|
||||
* Frees an oidmap structure and allocated memory.
|
||||
*
|
||||
* If `free_entries` is true, each oidmap_entry in the map is freed as well
|
||||
* using stdlibs free().
|
||||
*/
|
||||
void oidmap_free(struct oidmap *map, int free_entries);
|
||||
|
||||
/*
|
||||
* Returns the oidmap entry for the specified oid, or NULL if not found.
|
||||
*/
|
||||
void *oidmap_get(const struct oidmap *map,
|
||||
const struct object_id *key);
|
||||
|
||||
/*
|
||||
* Adds or replaces an oidmap entry.
|
||||
*
|
||||
* ((struct oidmap_entry *) entry)->internal_entry will be populated by this
|
||||
* function.
|
||||
*
|
||||
* Returns the replaced entry, or NULL if not found (i.e. the entry was added).
|
||||
*/
|
||||
void *oidmap_put(struct oidmap *map, void *entry);
|
||||
|
||||
/*
|
||||
* Removes an oidmap entry matching the specified oid.
|
||||
*
|
||||
* Returns the removed entry, or NULL if not found.
|
||||
*/
|
||||
void *oidmap_remove(struct oidmap *map, const struct object_id *key);
|
||||
|
||||
|
||||
struct oidmap_iter {
|
||||
struct hashmap_iter h_iter;
|
||||
};
|
||||
|
||||
static inline void oidmap_iter_init(struct oidmap *map, struct oidmap_iter *iter)
|
||||
{
|
||||
hashmap_iter_init(&map->map, &iter->h_iter);
|
||||
}
|
||||
|
||||
static inline void *oidmap_iter_next(struct oidmap_iter *iter)
|
||||
{
|
||||
return hashmap_iter_next(&iter->h_iter);
|
||||
}
|
||||
|
||||
static inline void *oidmap_iter_first(struct oidmap *map,
|
||||
struct oidmap_iter *iter)
|
||||
{
|
||||
oidmap_iter_init(map, iter);
|
||||
return oidmap_iter_next(iter);
|
||||
}
|
||||
|
||||
#endif
|
||||
Loading…
Add table
Add a link
Reference in a new issue