bundle: unbundle promisor packs

In order to have a valid pack-file after unbundling a bundle that has
the 'filter' capability, we need to generate a .promisor file. The
bundle does not promise _where_ the objects can be found, but we can
expect that these bundles will be unbundled in repositories with
appropriate promisor remotes that can find those missing objects.

Use the 'git index-pack --promisor=<message>' option to create this
.promisor file. Add "from-bundle" as the message to help anyone diagnose
issues with these promisor packs.

Signed-off-by: Derrick Stolee <derrickstolee@github.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Derrick Stolee 2022-03-09 16:01:42 +00:00 committed by Junio C Hamano
parent f18b512bbb
commit 4f39eb031a
2 changed files with 6 additions and 0 deletions

View File

@ -620,6 +620,10 @@ int unbundle(struct repository *r, struct bundle_header *header,
struct child_process ip = CHILD_PROCESS_INIT; struct child_process ip = CHILD_PROCESS_INIT;
strvec_pushl(&ip.args, "index-pack", "--fix-thin", "--stdin", NULL); strvec_pushl(&ip.args, "index-pack", "--fix-thin", "--stdin", NULL);
/* If there is a filter, then we need to create the promisor pack. */
if (header->filter.choice)
strvec_push(&ip.args, "--promisor=from-bundle");
if (extra_index_pack_args) { if (extra_index_pack_args) {
strvec_pushv(&ip.args, extra_index_pack_args->v); strvec_pushv(&ip.args, extra_index_pack_args->v);
strvec_clear(extra_index_pack_args); strvec_clear(extra_index_pack_args);

View File

@ -521,6 +521,8 @@ do
git init unbundled && git init unbundled &&
git -C unbundled bundle unbundle ../partial.bdl >ref-list.txt && git -C unbundled bundle unbundle ../partial.bdl >ref-list.txt &&
ls unbundled/.git/objects/pack/pack-*.promisor >promisor &&
test_line_count = 1 promisor &&
# Count the same number of reachable objects. # Count the same number of reachable objects.
reflist=$(git for-each-ref --format="%(objectname)") && reflist=$(git for-each-ref --format="%(objectname)") &&