summaryrefslogtreecommitdiff
path: root/midx.c
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2022-05-04 16:51:29 (GMT)
committerJunio C Hamano <gitster@pobox.com>2022-05-04 16:51:29 (GMT)
commit8b28e2e2e4abd0e9cffe0d85afd6f0c0346bb948 (patch)
tree1d26582328b9c1075f8e84a401e76f1262eb0b0d /midx.c
parentdcf1ac24a2ffd9014779fe5504e8f66539fff4bc (diff)
parent11f9e8de3d1a3d484c452141f1fcdbd707457ec0 (diff)
downloadgit-8b28e2e2e4abd0e9cffe0d85afd6f0c0346bb948.zip
git-8b28e2e2e4abd0e9cffe0d85afd6f0c0346bb948.tar.gz
git-8b28e2e2e4abd0e9cffe0d85afd6f0c0346bb948.tar.bz2
Merge branch 'ds/midx-normalize-pathname-before-comparison'
The path taken by "git multi-pack-index" command from the end user was compared with path internally prepared by the tool withut first normalizing, which lead to duplicated paths not being noticed, which has been corrected. * ds/midx-normalize-pathname-before-comparison: cache: use const char * for get_object_directory() multi-pack-index: use --object-dir real path midx: use real paths in lookup_multi_pack_index()
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 107365d..3db0e47 100644
--- a/midx.c
+++ b/midx.c
@@ -1132,17 +1132,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,