summaryrefslogtreecommitdiffstats
path: root/midx.c
diff options
context:
space:
mode:
authorDerrick Stolee <derrickstolee@github.com>2022-04-25 20:27:12 +0200
committerJunio C Hamano <gitster@pobox.com>2022-04-25 20:31:11 +0200
commiteafcc6de5296f6afc67fdc98101ae51959203ad8 (patch)
tree53cd3c70d6e8a99219b61939e65d2c8256eb25ea /midx.c
parentGit 2.35.3 (diff)
downloadgit-eafcc6de5296f6afc67fdc98101ae51959203ad8.tar.xz
git-eafcc6de5296f6afc67fdc98101ae51959203ad8.zip
midx: use real paths in lookup_multi_pack_index()
This helper looks for a parsed multi-pack-index whose object directory matches the given object_dir. Before going into the loop over the parsed multi-pack-indexes, it calls find_odb() to ensure that the given object_dir is actually a known object directory. However, find_odb() uses real-path manipulations to compare the input to the alternate directories. This same real-path comparison is not used in the loop, leading to potential issues with the strcmp(). Update the method to use the real-path values instead. Signed-off-by: Derrick Stolee <derrickstolee@github.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'midx.c')
-rw-r--r--midx.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/midx.c b/midx.c
index 837b46b2af..04600c6981 100644
--- a/midx.c
+++ b/midx.c
@@ -1113,17 +1113,26 @@ cleanup:
static struct multi_pack_index *lookup_multi_pack_index(struct repository *r,
const char *object_dir)
{
+ struct multi_pack_index *result = NULL;
struct multi_pack_index *cur;
+ char *obj_dir_real = real_pathdup(object_dir, 1);
+ struct strbuf cur_path_real = STRBUF_INIT;
/* Ensure the given object_dir is local, or a known alternate. */
- find_odb(r, object_dir);
+ find_odb(r, obj_dir_real);
for (cur = get_multi_pack_index(r); cur; cur = cur->next) {
- if (!strcmp(object_dir, cur->object_dir))
- return cur;
+ strbuf_realpath(&cur_path_real, cur->object_dir, 1);
+ if (!strcmp(obj_dir_real, cur_path_real.buf)) {
+ result = cur;
+ goto cleanup;
+ }
}
- return NULL;
+cleanup:
+ free(obj_dir_real);
+ strbuf_release(&cur_path_real);
+ return result;
}
static int write_midx_internal(const char *object_dir,