diff options
author | Jeff King <peff@peff.net> | 2014-07-13 02:42:08 -0400 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-07-13 18:59:05 -0700 |
commit | 94d5a22cf651174f91d40a140593628a04fdacf3 (patch) | |
tree | e07d447848193680f33a628cad544c0b5cdfe540 | |
parent | 8ff226a9d5ee065fe52752e6032f63cb6e4beccb (diff) | |
download | git-94d5a22cf651174f91d40a140593628a04fdacf3.tar.gz |
alloc: factor out commit index
We keep a static counter to set the commit index on newly
allocated objects. However, since we also need to set the
index on any_objects which are converted to commits, let's
make the counter available as a public function.
While we're moving it, let's make sure the counter is
allocated as an unsigned integer to match the index field in
"struct commit".
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r-- | alloc.c | 9 | ||||
-rw-r--r-- | cache.h | 1 |
2 files changed, 8 insertions, 2 deletions
@@ -82,12 +82,17 @@ void *alloc_object_node(void) static struct alloc_state commit_state; +unsigned int alloc_commit_index(void) +{ + static unsigned int count; + return count++; +} + void *alloc_commit_node(void) { - static int commit_count; struct commit *c = alloc_node(&commit_state, sizeof(struct commit)); c->object.type = OBJ_COMMIT; - c->index = commit_count++; + c->index = alloc_commit_index(); return c; } @@ -1376,6 +1376,7 @@ extern void *alloc_commit_node(void); extern void *alloc_tag_node(void); extern void *alloc_object_node(void); extern void alloc_report(void); +extern unsigned int alloc_commit_index(void); /* trace.c */ __attribute__((format (printf, 1, 2))) |