Skip to content

Commit

Permalink
diff: factor out src/dst prefix setup
Browse files Browse the repository at this point in the history
We directly manipulate diffopt's a_prefix and b_prefix to set up either
the default "a/foo" prefix or the "--no-prefix" variant. Although this
is only a few lines, it's worth pulling these into their own functions.
That lets us avoid one repetition already in this patch, but will also
give us a cleaner interface for callers which want to tweak this
setting.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
peff authored and gitster committed Mar 9, 2023
1 parent 725f570 commit 6799aad
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 5 deletions.
19 changes: 14 additions & 5 deletions diff.c
Expand Up @@ -3374,6 +3374,17 @@ void diff_set_mnemonic_prefix(struct diff_options *options, const char *a, const
options->b_prefix = b;
}

void diff_set_noprefix(struct diff_options *options)
{
options->a_prefix = options->b_prefix = "";
}

void diff_set_default_prefix(struct diff_options *options)
{
options->a_prefix = "a/";
options->b_prefix = "b/";
}

struct userdiff_driver *get_textconv(struct repository *r,
struct diff_filespec *one)
{
Expand Down Expand Up @@ -4674,10 +4685,9 @@ void repo_diff_setup(struct repository *r, struct diff_options *options)
options->flags.ignore_untracked_in_submodules = 1;

if (diff_no_prefix) {
options->a_prefix = options->b_prefix = "";
diff_set_noprefix(options);
} else if (!diff_mnemonic_prefix) {
options->a_prefix = "a/";
options->b_prefix = "b/";
diff_set_default_prefix(options);
}

options->color_moved = diff_color_moved_default;
Expand Down Expand Up @@ -5261,8 +5271,7 @@ static int diff_opt_no_prefix(const struct option *opt,

BUG_ON_OPT_NEG(unset);
BUG_ON_OPT_ARG(optarg);
options->a_prefix = "";
options->b_prefix = "";
diff_set_noprefix(options);
return 0;
}

Expand Down
2 changes: 2 additions & 0 deletions diff.h
Expand Up @@ -497,6 +497,8 @@ void diff_tree_combined(const struct object_id *oid, const struct oid_array *par
void diff_tree_combined_merge(const struct commit *commit, struct rev_info *rev);

void diff_set_mnemonic_prefix(struct diff_options *options, const char *a, const char *b);
void diff_set_noprefix(struct diff_options *options);
void diff_set_default_prefix(struct diff_options *options);

int diff_can_quit_early(struct diff_options *);

Expand Down

0 comments on commit 6799aad

Please sign in to comment.