blob: ee43dee1f008882094ca9c85f6b28b86ec88fdf6 [file] [log] [blame]
Linus Torvaldsa59b2762007-04-16 16:03:15 -07001#ifndef DECORATE_H
2#define DECORATE_H
3
Jonathan Tanddd3e312017-12-07 16:14:24 -08004/*
5 * A data structure that associates Git objects to void pointers. See
6 * t/helper/test-example-decorate.c for a demonstration of how to use these
7 * functions.
8 */
9
10/*
11 * An entry in the data structure.
12 */
13struct decoration_entry {
Jeff King54988bd2008-08-20 13:55:33 -040014 const struct object *base;
Linus Torvaldsa59b2762007-04-16 16:03:15 -070015 void *decoration;
16};
17
Jonathan Tanddd3e312017-12-07 16:14:24 -080018/*
19 * The data structure.
20 *
21 * This data structure must be zero-initialized.
22 */
Linus Torvaldsa59b2762007-04-16 16:03:15 -070023struct decoration {
Jonathan Tanddd3e312017-12-07 16:14:24 -080024 /*
25 * Not used by the decoration mechanism. Clients may use this for
26 * whatever they want.
27 */
Linus Torvaldsa59b2762007-04-16 16:03:15 -070028 const char *name;
Jonathan Tanddd3e312017-12-07 16:14:24 -080029
30 /*
31 * The capacity of "entries".
32 */
33 unsigned int size;
34
35 /*
36 * The number of real Git objects (that is, entries with non-NULL
37 * "base").
38 */
39 unsigned int nr;
40
41 /*
42 * The entries. This is an array of size "size", containing nr entries
43 * with non-NULL "base" and (size - nr) entries with NULL "base".
44 */
45 struct decoration_entry *entries;
Linus Torvaldsa59b2762007-04-16 16:03:15 -070046};
47
Jonathan Tanddd3e312017-12-07 16:14:24 -080048/*
49 * Add an association from the given object to the given pointer (which may be
50 * NULL), returning the previously associated pointer. If there is no previous
51 * association, this function returns NULL.
52 */
Denton Liu55454422019-04-29 04:28:14 -040053void *add_decoration(struct decoration *n, const struct object *obj, void *decoration);
Jonathan Tanddd3e312017-12-07 16:14:24 -080054
55/*
56 * Return the pointer associated to the given object. If there is no
57 * association, this function returns NULL.
58 */
Denton Liu55454422019-04-29 04:28:14 -040059void *lookup_decoration(struct decoration *n, const struct object *obj);
Linus Torvaldsa59b2762007-04-16 16:03:15 -070060
61#endif