remerge-diff: lazily prepare temporary objdir on demand

It is error prone for each caller that sets revs.remerge_diff bit
to be responsible for preparing a temporary object directory and
rotate it into the list of alternate object stores, making it the
primary object store.

Instead, remove the code to set up and arrange the temporary object
directory from the current callers and implement it in the code that
runs remerge-diff logic.  The code to undo the futzing of the list
of alternate object store is still spread across the callers, but we
will deal with it in future steps.

Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Junio C Hamano 2024-08-09 15:30:51 -07:00
parent a77554ea09
commit 245cac5c33
3 changed files with 12 additions and 18 deletions

View File

@ -168,13 +168,6 @@ int cmd_diff_tree(int argc, const char **argv, const char *prefix)

opt->diffopt.rotate_to_strict = 1;

if (opt->remerge_diff) {
opt->remerge_objdir = tmp_objdir_create("remerge-diff");
if (!opt->remerge_objdir)
die(_("unable to create temporary object directory"));
tmp_objdir_replace_primary_odb(opt->remerge_objdir, 1);
}

/*
* NOTE! We expect "a..b" to expand to "^a b" but it is
* perfectly valid for revision range parser to yield "b ^a",

View File

@ -494,13 +494,6 @@ static int cmd_log_walk_no_free(struct rev_info *rev)
int saved_nrl = 0;
int saved_dcctc = 0;

if (rev->remerge_diff) {
rev->remerge_objdir = tmp_objdir_create("remerge-diff");
if (!rev->remerge_objdir)
die(_("unable to create temporary object directory"));
tmp_objdir_replace_primary_odb(rev->remerge_objdir, 1);
}

if (rev->early_output)
setup_early_output();


View File

@ -1019,6 +1019,17 @@ static int do_remerge_diff(struct rev_info *opt,
struct strbuf parent1_desc = STRBUF_INIT;
struct strbuf parent2_desc = STRBUF_INIT;

/*
* Lazily prepare a temporary object directory and rotate it
* into the alternative object store list as the primary.
*/
if (opt->remerge_diff && !opt->remerge_objdir) {
opt->remerge_objdir = tmp_objdir_create("remerge-diff");
if (!opt->remerge_objdir)
return error(_("unable to create temporary object directory"));
tmp_objdir_replace_primary_odb(opt->remerge_objdir, 1);
}

/* Setup merge options */
init_merge_options(&o, the_repository);
o.show_rename_progress = 0;
@ -1053,10 +1064,7 @@ static int do_remerge_diff(struct rev_info *opt,
merge_finalize(&o, &res);

/* Clean up the contents of the temporary object directory */
if (opt->remerge_objdir)
tmp_objdir_discard_objects(opt->remerge_objdir);
else
BUG("did a remerge diff without remerge_objdir?!?");
tmp_objdir_discard_objects(opt->remerge_objdir);

return !opt->loginfo;
}