mirror of
https://github.com/git/git.git
synced 2026-01-10 01:56:42 +00:00
Merge branch 'tc/diff-tree-max-depth'
"git diff-tree" learned "--max-depth" option. * tc/diff-tree-max-depth: diff: teach tree-diff a max-depth parameter within_depth: fix return for empty path combine-diff: zero memory used for callback filepairs
This commit is contained in:
24
diff.c
24
diff.c
@@ -5004,6 +5004,9 @@ void diff_setup_done(struct diff_options *options)
|
||||
options->filter = ~filter_bit[DIFF_STATUS_FILTER_AON];
|
||||
options->filter &= ~options->filter_not;
|
||||
}
|
||||
|
||||
if (options->pathspec.has_wildcard && options->max_depth_valid)
|
||||
die("max-depth cannot be used with wildcard pathspecs");
|
||||
}
|
||||
|
||||
int parse_long_opt(const char *opt, const char **argv,
|
||||
@@ -5638,6 +5641,23 @@ static int diff_opt_rotate_to(const struct option *opt, const char *arg, int uns
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int diff_opt_max_depth(const struct option *opt,
|
||||
const char *arg, int unset)
|
||||
{
|
||||
struct diff_options *options = opt->value;
|
||||
|
||||
BUG_ON_OPT_NEG(unset);
|
||||
|
||||
if (!git_parse_int(arg, &options->max_depth))
|
||||
return error(_("invalid value for '%s': '%s'"),
|
||||
"--max-depth", arg);
|
||||
|
||||
options->flags.recursive = 1;
|
||||
options->max_depth_valid = options->max_depth >= 0;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* Consider adding new flags to __git_diff_common_options
|
||||
* in contrib/completion/git-completion.bash
|
||||
@@ -5910,6 +5930,10 @@ struct option *add_diff_options(const struct option *opts,
|
||||
OPT_CALLBACK_F(0, "diff-filter", options, N_("[(A|C|D|M|R|T|U|X|B)...[*]]"),
|
||||
N_("select files by diff type"),
|
||||
PARSE_OPT_NONEG, diff_opt_diff_filter),
|
||||
OPT_CALLBACK_F(0, "max-depth", options, N_("<depth>"),
|
||||
N_("maximum tree depth to recurse"),
|
||||
PARSE_OPT_NONEG, diff_opt_max_depth),
|
||||
|
||||
{
|
||||
.type = OPTION_CALLBACK,
|
||||
.long_name = "output",
|
||||
|
||||
Reference in New Issue
Block a user