diff options
| author | René Scharfe <l.s.r@web.de> | 2025-12-24 18:03:22 +0100 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2025-12-25 08:29:28 +0900 |
| commit | 2ebaa2b45e752088fd03d03c484fe43a653deba8 (patch) | |
| tree | c7c2bde9001839d19fd13aa86a31c3b5b5363a09 | |
| parent | 64dbeefbd24e02eb05ae3250e118c9552b7690fb (diff) | |
| download | git-2ebaa2b45e752088fd03d03c484fe43a653deba8.tar.gz git-2ebaa2b45e752088fd03d03c484fe43a653deba8.zip | |
commit: add commit_stack_init()
Add a function for initializing a struct commit_stack, for when static
initialization is not possible or impractical.
Signed-off-by: René Scharfe <l.s.r@web.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | commit.c | 10 | ||||
| -rw-r--r-- | commit.h | 1 |
2 files changed, 9 insertions, 2 deletions
@@ -1982,6 +1982,12 @@ int run_commit_hook(int editor_is_used, const char *index_file, return run_hooks_opt(the_repository, name, &opt); } +void commit_stack_init(struct commit_stack *stack) +{ + stack->items = NULL; + stack->nr = stack->alloc = 0; +} + void commit_stack_push(struct commit_stack *stack, struct commit *commit) { ALLOC_GROW(stack->items, stack->nr + 1, stack->alloc); @@ -1995,6 +2001,6 @@ struct commit *commit_stack_pop(struct commit_stack *stack) void commit_stack_clear(struct commit_stack *stack) { - FREE_AND_NULL(stack->items); - stack->nr = stack->alloc = 0; + free(stack->items); + commit_stack_init(stack); } @@ -387,6 +387,7 @@ struct commit_stack { }; #define COMMIT_STACK_INIT { 0 } +void commit_stack_init(struct commit_stack *); void commit_stack_push(struct commit_stack *, struct commit *); struct commit *commit_stack_pop(struct commit_stack *); void commit_stack_clear(struct commit_stack *); |
