зеркало из https://github.com/microsoft/git.git
format-patch: teach --interdiff to respect -v/--reroll-count
The --interdiff option introduces the embedded interdiff generically as "Interdiff:", however, we can do better when --reroll-count is specified by emitting "Interdiff against v{n}:" instead. Signed-off-by: Eric Sunshine <sunshine@sunshineco.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
126facf821
Коммит
5ac290f9c0
|
@ -1085,7 +1085,7 @@ static void make_cover_letter(struct rev_info *rev, int use_stdout,
|
||||||
show_diffstat(rev, origin, head);
|
show_diffstat(rev, origin, head);
|
||||||
|
|
||||||
if (rev->idiff_oid1) {
|
if (rev->idiff_oid1) {
|
||||||
fprintf_ln(rev->diffopt.file, "%s", _("Interdiff:"));
|
fprintf_ln(rev->diffopt.file, "%s", rev->idiff_title);
|
||||||
show_interdiff(rev);
|
show_interdiff(rev);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1427,6 +1427,16 @@ static void print_bases(struct base_tree_info *bases, FILE *file)
|
||||||
oidclr(&bases->base_commit);
|
oidclr(&bases->base_commit);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *diff_title(struct strbuf *sb, int reroll_count,
|
||||||
|
const char *generic, const char *rerolled)
|
||||||
|
{
|
||||||
|
if (reroll_count <= 0)
|
||||||
|
strbuf_addstr(sb, generic);
|
||||||
|
else /* RFC may be v0, so allow -v1 to diff against v0 */
|
||||||
|
strbuf_addf(sb, rerolled, reroll_count - 1);
|
||||||
|
return sb->buf;
|
||||||
|
}
|
||||||
|
|
||||||
int cmd_format_patch(int argc, const char **argv, const char *prefix)
|
int cmd_format_patch(int argc, const char **argv, const char *prefix)
|
||||||
{
|
{
|
||||||
struct commit *commit;
|
struct commit *commit;
|
||||||
|
@ -1455,6 +1465,7 @@ int cmd_format_patch(int argc, const char **argv, const char *prefix)
|
||||||
int show_progress = 0;
|
int show_progress = 0;
|
||||||
struct progress *progress = NULL;
|
struct progress *progress = NULL;
|
||||||
struct oid_array idiff_prev = OID_ARRAY_INIT;
|
struct oid_array idiff_prev = OID_ARRAY_INIT;
|
||||||
|
struct strbuf idiff_title = STRBUF_INIT;
|
||||||
|
|
||||||
const struct option builtin_format_patch_options[] = {
|
const struct option builtin_format_patch_options[] = {
|
||||||
{ OPTION_CALLBACK, 'n', "numbered", &numbered, NULL,
|
{ OPTION_CALLBACK, 'n', "numbered", &numbered, NULL,
|
||||||
|
@ -1758,6 +1769,9 @@ int cmd_format_patch(int argc, const char **argv, const char *prefix)
|
||||||
die(_("--interdiff requires --cover-letter"));
|
die(_("--interdiff requires --cover-letter"));
|
||||||
rev.idiff_oid1 = &idiff_prev.oid[idiff_prev.nr - 1];
|
rev.idiff_oid1 = &idiff_prev.oid[idiff_prev.nr - 1];
|
||||||
rev.idiff_oid2 = get_commit_tree_oid(list[0]);
|
rev.idiff_oid2 = get_commit_tree_oid(list[0]);
|
||||||
|
rev.idiff_title = diff_title(&idiff_title, reroll_count,
|
||||||
|
_("Interdiff:"),
|
||||||
|
_("Interdiff against v%d:"));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!signature) {
|
if (!signature) {
|
||||||
|
@ -1880,6 +1894,7 @@ int cmd_format_patch(int argc, const char **argv, const char *prefix)
|
||||||
|
|
||||||
done:
|
done:
|
||||||
oid_array_clear(&idiff_prev);
|
oid_array_clear(&idiff_prev);
|
||||||
|
strbuf_release(&idiff_title);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -215,6 +215,7 @@ struct rev_info {
|
||||||
/* interdiff */
|
/* interdiff */
|
||||||
const struct object_id *idiff_oid1;
|
const struct object_id *idiff_oid1;
|
||||||
const struct object_id *idiff_oid2;
|
const struct object_id *idiff_oid2;
|
||||||
|
const char *idiff_title;
|
||||||
|
|
||||||
/* commit counts */
|
/* commit counts */
|
||||||
int count_left;
|
int count_left;
|
||||||
|
|
|
@ -1734,4 +1734,9 @@ test_expect_success 'interdiff: cover-letter' '
|
||||||
test_cmp expect actual
|
test_cmp expect actual
|
||||||
'
|
'
|
||||||
|
|
||||||
|
test_expect_success 'interdiff: reroll-count' '
|
||||||
|
git format-patch --cover-letter --interdiff=boop~2 -v2 -1 boop &&
|
||||||
|
test_i18ngrep "^Interdiff ..* v1:$" v2-0000-cover-letter.patch
|
||||||
|
'
|
||||||
|
|
||||||
test_done
|
test_done
|
||||||
|
|
Загрузка…
Ссылка в новой задаче