commit-graph.c: prevent overflow in merge_commit_graph()
When merging two commit graphs, ensure that we don't attempt to merge two graphs which, when combined, have more total commits than the 32-bit unsigned maximum. Signed-off-by: Taylor Blau <me@ttaylorr.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
19565d093d
commit
d76e0a744d
@ -2179,6 +2179,11 @@ static void merge_commit_graph(struct write_commit_graph_context *ctx,
|
||||
uint32_t i;
|
||||
uint32_t offset = g->num_commits_in_base;
|
||||
|
||||
if (unsigned_add_overflows(ctx->commits.nr, g->num_commits))
|
||||
die(_("cannot merge graph %s, too many commits: %"PRIuMAX),
|
||||
oid_to_hex(&g->oid),
|
||||
(uintmax_t)st_add(ctx->commits.nr, g->num_commits));
|
||||
|
||||
ALLOC_GROW(ctx->commits.list, ctx->commits.nr + g->num_commits, ctx->commits.alloc);
|
||||
|
||||
for (i = 0; i < g->num_commits; i++) {
|
||||
|
Reference in New Issue
Block a user