mirror of
https://github.com/git/git.git
synced 2026-02-28 18:48:50 +00:00
Merge branch 'mf/format-patch-honor-from-for-cover-letter'
"git format-patch --from=<me>" did not honor the command line option when writing out the cover letter, which has been corrected. * mf/format-patch-honor-from-for-cover-letter: format-patch: fix From header in cover letter
This commit is contained in:
@@ -282,11 +282,12 @@ e.g., `--rfc='-(WIP)'` results in "PATCH (WIP)".
|
||||
|
||||
--from::
|
||||
--from=<ident>::
|
||||
Use `ident` in the `From:` header of each commit email. If the
|
||||
author ident of the commit is not textually identical to the
|
||||
provided `ident`, place a `From:` header in the body of the
|
||||
message with the original author. If no `ident` is given, use
|
||||
the committer ident.
|
||||
Use `ident` in the `From:` header of each email. In case of a
|
||||
commit email, if the author ident of the commit is not textually
|
||||
identical to the provided `ident`, place a `From:` header in the
|
||||
body of the message with the original author. If no `ident` is
|
||||
given, or if the option is not passed at all, use the ident of
|
||||
the current committer.
|
||||
+
|
||||
Note that this option is only useful if you are actually sending the
|
||||
emails and want to identify yourself as the sender, but retain the
|
||||
|
||||
@@ -1331,7 +1331,7 @@ static void make_cover_letter(struct rev_info *rev, int use_separate_file,
|
||||
int quiet,
|
||||
const struct format_config *cfg)
|
||||
{
|
||||
const char *committer;
|
||||
const char *from;
|
||||
struct shortlog log;
|
||||
struct strbuf sb = STRBUF_INIT;
|
||||
int i;
|
||||
@@ -1344,7 +1344,7 @@ static void make_cover_letter(struct rev_info *rev, int use_separate_file,
|
||||
if (!cmit_fmt_is_mail(rev->commit_format))
|
||||
die(_("cover letter needs email format"));
|
||||
|
||||
committer = git_committer_info(0);
|
||||
from = cfg->from ? cfg->from : git_committer_info(0);
|
||||
|
||||
if (use_separate_file &&
|
||||
open_next_file(NULL, rev->numbered_files ? NULL : "cover-letter", rev, quiet))
|
||||
@@ -1367,7 +1367,7 @@ static void make_cover_letter(struct rev_info *rev, int use_separate_file,
|
||||
pp.date_mode.type = DATE_RFC2822;
|
||||
pp.rev = rev;
|
||||
pp.encode_email_headers = rev->encode_email_headers;
|
||||
pp_user_info(&pp, NULL, &sb, committer, encoding);
|
||||
pp_user_info(&pp, NULL, &sb, from, encoding);
|
||||
prepare_cover_text(&pp, description_file, branch_name, &sb,
|
||||
encoding, need_8bit_cte, cfg);
|
||||
fprintf(rev->diffopt.file, "%s\n", sb.buf);
|
||||
|
||||
@@ -1472,6 +1472,14 @@ test_expect_success '--from uses committer ident' '
|
||||
test_cmp expect patch.head
|
||||
'
|
||||
|
||||
test_expect_success '--from applies to cover letter' '
|
||||
test_when_finished "rm -rf patches" &&
|
||||
git format-patch -1 --cover-letter --from="Foo Bar <author@example.com>" -o patches &&
|
||||
echo "From: Foo Bar <author@example.com>" >expect &&
|
||||
grep "^From:" patches/0000-cover-letter.patch >patch.head &&
|
||||
test_cmp expect patch.head
|
||||
'
|
||||
|
||||
test_expect_success '--from omits redundant in-body header' '
|
||||
git format-patch -1 --stdout --from="A U Thor <author@example.com>" >patch &&
|
||||
cat >expect <<-\EOF &&
|
||||
|
||||
Reference in New Issue
Block a user