summaryrefslogtreecommitdiffstats
path: root/commit-graph.c
diff options
context:
space:
mode:
authorKleber Tarcísio <klebertarcisio@yahoo.com.br>2022-04-18 19:13:27 +0200
committerJunio C Hamano <gitster@pobox.com>2022-04-20 22:56:24 +0200
commitc0befa0c033b2754b93a666fe0e925c080b7d64b (patch)
tree83d0313388a53a054de5cc9161ca3a59726e55a5 /commit-graph.c
parentGit 2.36 (diff)
downloadgit-c0befa0c033b2754b93a666fe0e925c080b7d64b.tar.xz
git-c0befa0c033b2754b93a666fe0e925c080b7d64b.zip
commit-graph: close file before returning NULL
There are two reasons that we could return NULL early within load_commit_graph_chain(): 1. The file does not exist, so the file pointer is NULL. 2. The file exists, but is too small to contain a single hash. These were grouped together when the function was first written in 5c84b3396 (commit-graph: load commit-graph chains, 2019-06-18) in order to simplify how the 'chain_name' string is freed. However, the current code leaves a narrow window where the file pointer is not closed when the file exists, but is rejected for being too small. Split out these cases separately to ensure we close the file in this case. Signed-off-by: Kleber Tarcísio <klebertarcisio@yahoo.com.br> Signed-off-by: Derrick Stolee <derrickstolee@github.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'commit-graph.c')
-rw-r--r--commit-graph.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/commit-graph.c b/commit-graph.c
index 441b36016b..06107beedc 100644
--- a/commit-graph.c
+++ b/commit-graph.c
@@ -523,10 +523,13 @@ static struct commit_graph *load_commit_graph_chain(struct repository *r,
stat_res = stat(chain_name, &st);
free(chain_name);
- if (!fp ||
- stat_res ||
- st.st_size <= the_hash_algo->hexsz)
+ if (!fp)
return NULL;
+ if (stat_res ||
+ st.st_size <= the_hash_algo->hexsz) {
+ fclose(fp);
+ return NULL;
+ }
count = st.st_size / (the_hash_algo->hexsz + 1);
CALLOC_ARRAY(oids, count);