]> git.ipfire.org Git - thirdparty/git.git/blame - commit-slab-decl.h
Merge branch 'rj/add-i-leak-fix'
[thirdparty/git.git] / commit-slab-decl.h
CommitLineData
9892dc83
AK
1#ifndef COMMIT_SLAB_DECL_H
2#define COMMIT_SLAB_DECL_H
a9f1f1f9
NTND
3
4/* allocate ~512kB at once, allowing for malloc overhead */
5#ifndef COMMIT_SLAB_SIZE
6#define COMMIT_SLAB_SIZE (512*1024-32)
7#endif
8
9#define declare_commit_slab(slabname, elemtype) \
10 \
11struct slabname { \
12 unsigned slab_size; \
13 unsigned stride; \
14 unsigned slab_count; \
15 elemtype **slab; \
16}
17
18/*
19 * Statically initialize a commit slab named "var". Note that this
20 * evaluates "stride" multiple times! Example:
21 *
22 * struct indegree indegrees = COMMIT_SLAB_INIT(1, indegrees);
23 *
24 */
25#define COMMIT_SLAB_INIT(stride, var) { \
26 COMMIT_SLAB_SIZE / sizeof(**((var).slab)) / (stride), \
27 (stride), 0, NULL \
28}
29
878f0bb8
NTND
30#define declare_commit_slab_prototypes(slabname, elemtype) \
31 \
32void init_ ##slabname## _with_stride(struct slabname *s, unsigned stride); \
33void init_ ##slabname(struct slabname *s); \
34void clear_ ##slabname(struct slabname *s); \
1df15f8d 35void deep_clear_ ##slabname(struct slabname *s, void (*free_fn)(elemtype *ptr)); \
878f0bb8
NTND
36elemtype *slabname## _at_peek(struct slabname *s, const struct commit *c, int add_if_missing); \
37elemtype *slabname## _at(struct slabname *s, const struct commit *c); \
38elemtype *slabname## _peek(struct slabname *s, const struct commit *c)
39
40#define define_shared_commit_slab(slabname, elemtype) \
41 declare_commit_slab(slabname, elemtype); \
42 declare_commit_slab_prototypes(slabname, elemtype)
43
9892dc83 44#endif /* COMMIT_SLAB_DECL_H */