mirror of
https://github.com/git/git
synced 2024-11-05 01:58:18 +00:00
bundle-uri: plug leak in unbundle_from_file()
The function `unbundle_from_file()` has two memory leaks: - We do not release the `struct bundle_header header` when hitting errors because we return early without any cleanup. - We do not release the `struct strbuf bundle_ref` at all. Plug these leaks by creating a common exit path where both of these variables are released. While at it, refactor the code such that the variable assignments do not happen inside the conditional statement itself according to our coding style. Signed-off-by: Toon Claes <toon@iotcl.com> Acked-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
777489f9e0
commit
6dab49b9fb
1 changed files with 13 additions and 5 deletions
18
bundle-uri.c
18
bundle-uri.c
|
@ -368,17 +368,23 @@ static int unbundle_from_file(struct repository *r, const char *file)
|
|||
struct strbuf bundle_ref = STRBUF_INIT;
|
||||
size_t bundle_prefix_len;
|
||||
|
||||
if ((bundle_fd = read_bundle_header(file, &header)) < 0)
|
||||
return 1;
|
||||
bundle_fd = read_bundle_header(file, &header);
|
||||
if (bundle_fd < 0) {
|
||||
result = 1;
|
||||
goto cleanup;
|
||||
}
|
||||
|
||||
/*
|
||||
* Skip the reachability walk here, since we will be adding
|
||||
* a reachable ref pointing to the new tips, which will reach
|
||||
* the prerequisite commits.
|
||||
*/
|
||||
if ((result = unbundle(r, &header, bundle_fd, NULL,
|
||||
VERIFY_BUNDLE_QUIET | (fetch_pack_fsck_objects() ? VERIFY_BUNDLE_FSCK : 0))))
|
||||
return 1;
|
||||
result = unbundle(r, &header, bundle_fd, NULL,
|
||||
VERIFY_BUNDLE_QUIET | (fetch_pack_fsck_objects() ? VERIFY_BUNDLE_FSCK : 0));
|
||||
if (result) {
|
||||
result = 1;
|
||||
goto cleanup;
|
||||
}
|
||||
|
||||
/*
|
||||
* Convert all refs/heads/ from the bundle into refs/bundles/
|
||||
|
@ -407,6 +413,8 @@ static int unbundle_from_file(struct repository *r, const char *file)
|
|||
0, UPDATE_REFS_MSG_ON_ERR);
|
||||
}
|
||||
|
||||
cleanup:
|
||||
strbuf_release(&bundle_ref);
|
||||
bundle_header_release(&header);
|
||||
return result;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue