diff options
author | Derrick Stolee <derrickstolee@github.com> | 2022-04-25 20:27:12 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2022-04-25 20:31:11 +0200 |
commit | eafcc6de5296f6afc67fdc98101ae51959203ad8 (patch) | |
tree | 53cd3c70d6e8a99219b61939e65d2c8256eb25ea /midx.c | |
parent | Git 2.35.3 (diff) | |
download | git-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.c | 17 |
1 files changed, 13 insertions, 4 deletions
@@ -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, |