return m->packs[local_pack_int_id];
}
+const char *nth_midxed_pack_name(struct multi_pack_index *m,
+ uint32_t pack_int_id)
+{
+ uint32_t local_pack_int_id = midx_for_pack(&m, pack_int_id);
+ return m->pack_names[local_pack_int_id];
+}
+
#define MIDX_CHUNK_BITMAPPED_PACKS_WIDTH (2 * sizeof(uint32_t))
int nth_bitmapped_pack(struct repository *r, struct multi_pack_index *m,
int prepare_midx_pack(struct repository *r, struct multi_pack_index *m, uint32_t pack_int_id);
struct packed_git *nth_midxed_pack(struct multi_pack_index *m,
uint32_t pack_int_id);
+const char *nth_midxed_pack_name(struct multi_pack_index *m,
+ uint32_t pack_int_id);
int nth_bitmapped_pack(struct repository *r, struct multi_pack_index *m,
struct bitmapped_pack *bp, uint32_t pack_int_id);
int bsearch_one_midx(const struct object_id *oid, struct multi_pack_index *m,
for (i = 0; i < bitmap_git->midx->num_packs + bitmap_git->midx->num_packs_in_base; i++) {
if (prepare_midx_pack(bitmap_repo(bitmap_git), bitmap_git->midx, i)) {
warning(_("could not open pack %s"),
- bitmap_git->midx->pack_names[i]);
+ nth_midxed_pack_name(bitmap_git->midx, i));
goto cleanup;
}
}
struct bitmapped_pack pack;
if (nth_bitmapped_pack(r, bitmap_git->midx, &pack, i) < 0) {
warning(_("unable to load pack: '%s', disabling pack-reuse"),
- bitmap_git->midx->pack_names[i]);
+ nth_midxed_pack_name(bitmap_git->midx, i));
free(packs);
return;
}
printf("\nnum_objects: %d\n", m->num_objects);
printf("packs:\n");
- for (i = 0; i < m->num_packs; i++)
- printf("%s\n", m->pack_names[i]);
+ for (i = m->num_packs_in_base; i < m->num_packs + m->num_packs_in_base;
+ i++)
+ printf("%s\n", nth_midxed_pack_name(m, i));
printf("object-dir: %s\n", m->object_dir);
return 1;
}
- printf("%s\n", midx->pack_names[preferred_pack]);
+ printf("%s\n", nth_midxed_pack_name(midx, preferred_pack));
close_midx(midx);
return 0;
}