| #ifndef COMMIT_SLAB_H |
| #define COMMIT_SLAB_H |
| |
| #include "commit-slab-decl.h" |
| #include "commit-slab-impl.h" |
| |
| /* |
| * define_commit_slab(slabname, elemtype) creates boilerplate code to define |
| * a new struct (struct slabname) that is used to associate a piece of data |
| * of elemtype to commits, and a few functions to use that struct. |
| * |
| * After including this header file, using: |
| * |
| * define_commit_slab(indegree, int); |
| * |
| * will let you call the following functions: |
| * |
| * - int *indegree_at(struct indegree *, struct commit *); |
| * |
| * This function locates the data associated with the given commit in |
| * the indegree slab, and returns the pointer to it. The location to |
| * store the data is allocated as necessary. |
| * |
| * - int *indegree_peek(struct indegree *, struct commit *); |
| * |
| * This function is similar to indegree_at(), but it will return NULL |
| * if the location to store the data associated with the given commit |
| * has not been allocated yet. |
| * Note that the location to store the data might have already been |
| * allocated even if no indegree_at() call has been made for that commit |
| * yet; in this case this function returns a pointer to a |
| * zero-initialized location. |
| * |
| * - void init_indegree(struct indegree *); |
| * void init_indegree_with_stride(struct indegree *, int); |
| * |
| * Initializes the indegree slab that associates an array of integers |
| * to each commit. 'stride' specifies how big each array is. The slab |
| * that is initialized by the variant without "_with_stride" associates |
| * each commit with an array of one integer. |
| * |
| * - void clear_indegree(struct indegree *); |
| * |
| * Empties the slab. The slab can be reused with the same stride |
| * without calling init_indegree() again or can be reconfigured to a |
| * different stride by calling init_indegree_with_stride(). |
| * |
| * Call this function before the slab falls out of scope to avoid |
| * leaking memory. |
| * |
| * - void deep_clear_indegree(struct indegree *, void (*free_fn)(int*)) |
| * |
| * Empties the slab, similar to clear_indegree(), but in addition it |
| * calls the given 'free_fn' for each slab entry to release any |
| * additional memory that might be owned by the entry (but not the |
| * entry itself!). |
| * Note that 'free_fn' might be called even for entries for which no |
| * indegree_at() call has been made; in this case 'free_fn' is invoked |
| * with a pointer to a zero-initialized location. |
| */ |
| |
| #define define_commit_slab(slabname, elemtype) \ |
| declare_commit_slab(slabname, elemtype); \ |
| implement_static_commit_slab(slabname, elemtype) |
| |
| #endif /* COMMIT_SLAB_H */ |