bisect: use string arguments to feed internal diff-tree

Commit e22278c0a0 (bisect: display first bad commit without forking a
new process, 2009-05-28) converted our external call to diff-tree to
an internal use of the log_tree_commit(). But rather than individually
setting options in the rev_info struct (and explaining in comments how
they map to command-line options), we can just pass the command-line
options to setup_revisions().

This is shorter, easier to change, and less likely to break if
revision.c internals change.

Note that we unconditionally set the output format to "raw". The
conditional in the original code didn't actually do anything useful,
since nobody had an opportunity to set the format to anything.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2019-02-22 01:20:37 -05:00 committed by Junio C Hamano
parent 8104ec994e
commit 2008f29093

View File

@ -896,24 +896,15 @@ static void show_diff_tree(struct repository *r,
const char *prefix, const char *prefix,
struct commit *commit) struct commit *commit)
{ {
const char *argv[] = {
"diff-tree", "--pretty", "--no-abbrev", "--raw", NULL
};
struct rev_info opt; struct rev_info opt;
/* diff-tree init */
repo_init_revisions(r, &opt, prefix); repo_init_revisions(r, &opt, prefix);
git_config(git_diff_basic_config, NULL); /* no "diff" UI options */ git_config(git_diff_basic_config, NULL); /* no "diff" UI options */
opt.abbrev = 0;
opt.diff = 1;
/* This is what "--pretty" does */ setup_revisions(ARRAY_SIZE(argv) - 1, argv, &opt, NULL);
opt.verbose_header = 1;
opt.use_terminator = 0;
opt.commit_format = CMIT_FMT_DEFAULT;
/* diff-tree init */
if (!opt.diffopt.output_format)
opt.diffopt.output_format = DIFF_FORMAT_RAW;
setup_revisions(0, NULL, &opt, NULL);
log_tree_commit(&opt, commit); log_tree_commit(&opt, commit);
} }