mirror of
https://github.com/git/git.git
synced 2026-01-11 13:23:12 +09:00
revision: export commit_stack
Dynamic arrays of commit pointers are used in several places. Some of them use a custom struct to hold array, item count and capacity, others have them as separate variables linked by a common name part. Pick one succinct, clean implementation -- commit_stack -- and convert the different variants to it to reduce code duplication. Signed-off-by: René Scharfe <l.s.r@web.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
66ce5f8e88
commit
d8a17ef09b
17
commit.c
17
commit.c
@ -1981,3 +1981,20 @@ int run_commit_hook(int editor_is_used, const char *index_file,
|
||||
opt.invoked_hook = invoked_hook;
|
||||
return run_hooks_opt(the_repository, name, &opt);
|
||||
}
|
||||
|
||||
void commit_stack_push(struct commit_stack *stack, struct commit *commit)
|
||||
{
|
||||
ALLOC_GROW(stack->items, stack->nr + 1, stack->alloc);
|
||||
stack->items[stack->nr++] = commit;
|
||||
}
|
||||
|
||||
struct commit *commit_stack_pop(struct commit_stack *stack)
|
||||
{
|
||||
return stack->nr ? stack->items[--stack->nr] : NULL;
|
||||
}
|
||||
|
||||
void commit_stack_clear(struct commit_stack *stack)
|
||||
{
|
||||
FREE_AND_NULL(stack->items);
|
||||
stack->nr = stack->alloc = 0;
|
||||
}
|
||||
|
||||
10
commit.h
10
commit.h
@ -381,4 +381,14 @@ int parse_buffer_signed_by_header(const char *buffer,
|
||||
const struct git_hash_algo *algop);
|
||||
int add_header_signature(struct strbuf *buf, struct strbuf *sig, const struct git_hash_algo *algo);
|
||||
|
||||
struct commit_stack {
|
||||
struct commit **items;
|
||||
size_t nr, alloc;
|
||||
};
|
||||
#define COMMIT_STACK_INIT { 0 }
|
||||
|
||||
void commit_stack_push(struct commit_stack *, struct commit *);
|
||||
struct commit *commit_stack_pop(struct commit_stack *);
|
||||
void commit_stack_clear(struct commit_stack *);
|
||||
|
||||
#endif /* COMMIT_H */
|
||||
|
||||
23
revision.c
23
revision.c
@ -250,29 +250,6 @@ void mark_trees_uninteresting_sparse(struct repository *r,
|
||||
paths_and_oids_clear(&map);
|
||||
}
|
||||
|
||||
struct commit_stack {
|
||||
struct commit **items;
|
||||
size_t nr, alloc;
|
||||
};
|
||||
#define COMMIT_STACK_INIT { 0 }
|
||||
|
||||
static void commit_stack_push(struct commit_stack *stack, struct commit *commit)
|
||||
{
|
||||
ALLOC_GROW(stack->items, stack->nr + 1, stack->alloc);
|
||||
stack->items[stack->nr++] = commit;
|
||||
}
|
||||
|
||||
static struct commit *commit_stack_pop(struct commit_stack *stack)
|
||||
{
|
||||
return stack->nr ? stack->items[--stack->nr] : NULL;
|
||||
}
|
||||
|
||||
static void commit_stack_clear(struct commit_stack *stack)
|
||||
{
|
||||
FREE_AND_NULL(stack->items);
|
||||
stack->nr = stack->alloc = 0;
|
||||
}
|
||||
|
||||
static void mark_one_parent_uninteresting(struct rev_info *revs, struct commit *commit,
|
||||
struct commit_stack *pending)
|
||||
{
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user