decorate.hon commit treewide: rename tree to maybe_tree (891435d)
   1#ifndef DECORATE_H
   2#define DECORATE_H
   3
   4/*
   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 {
  14        const struct object *base;
  15        void *decoration;
  16};
  17
  18/*
  19 * The data structure.
  20 *
  21 * This data structure must be zero-initialized.
  22 */
  23struct decoration {
  24        /*
  25         * Not used by the decoration mechanism. Clients may use this for
  26         * whatever they want.
  27         */
  28        const char *name;
  29
  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;
  46};
  47
  48/*
  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 */
  53extern void *add_decoration(struct decoration *n, const struct object *obj, void *decoration);
  54
  55/*
  56 * Return the pointer associated to the given object. If there is no
  57 * association, this function returns NULL.
  58 */
  59extern void *lookup_decoration(struct decoration *n, const struct object *obj);
  60
  61#endif