If git-send-email is configured with sendemail.from, we will not prompt the user for the "From" address of the emails. If it is not configured, we prompt the user, but provide the repo author or committer as a default. Even though we probably have a sensible value for the default, the prompt is a safety check in case git generated an incorrect implicit ident string. Now that Git.pm will tell us whether the ident is implicit or explicit, we can stop prompting in the explicit case, saving most users from having to see the prompt at all. The test scripts need to be adjusted to not expect a prompt for the sender, since they always have the author explicitly defined in the environment. Unfortunately, we cannot reliably test that prompting still happens in the implicit case, as send-email will produce inconsistent results depending on the machine config (if we cannot find a FQDN, "git var" will barf, causing us to exit early; if we can, send-email will continue but prompt). Signed-off-by: Jeff King <peff@xxxxxxxx> --- git-send-email.perl | 22 +++++++++++++--------- t/t9001-send-email.sh | 5 ++--- 2 files changed, 15 insertions(+), 12 deletions(-) diff --git a/git-send-email.perl b/git-send-email.perl index 5a7c29d..0c49b32 100755 --- a/git-send-email.perl +++ b/git-send-email.perl @@ -436,9 +436,8 @@ if (0) { } } -my ($repoauthor, $repocommitter); -($repoauthor) = Git::ident_person(@repo, 'author'); -($repocommitter) = Git::ident_person(@repo, 'committer'); +my ($repoauthor, $author_explicit) = Git::ident_person(@repo, 'author'); +my ($repocommitter, $committer_explicit) = Git::ident_person(@repo, 'committer'); # Verify the user input @@ -755,12 +754,17 @@ if (!$force) { my $prompting = 0; if (!defined $sender) { - $sender = $repoauthor || $repocommitter || ''; - $sender = ask("Who should the emails appear to be from? [$sender] ", - default => $sender, - valid_re => qr/\@.*\./, confirm_only => 1); - print "Emails will be sent from: ", $sender, "\n"; - $prompting++; + ($sender, my $explicit) = + defined $repoauthor ? ($repoauthor, $author_explicit) : + defined $repocommitter ? ($repocommitter, $committer_explicit) : + ('', 0); + if (!$explicit) { + $sender = ask("Who should the emails appear to be from? [$sender] ", + default => $sender, + valid_re => qr/\@.*\./, confirm_only => 1); + print "Emails will be sent from: ", $sender, "\n"; + $prompting++; + } } if (!@initial_to && !defined $to_cmd) { diff --git a/t/t9001-send-email.sh b/t/t9001-send-email.sh index 6c6af7d..c5d66cf 100755 --- a/t/t9001-send-email.sh +++ b/t/t9001-send-email.sh @@ -191,14 +191,13 @@ test_expect_success $PREREQ 'Show all headers' ' test_expect_success $PREREQ 'Prompting works' ' clean_fake_sendmail && - (echo "Example <from@xxxxxxxxxxx>" - echo "to@xxxxxxxxxxx" + (echo "to@xxxxxxxxxxx" echo "" ) | GIT_SEND_EMAIL_NOTTY=1 git send-email \ --smtp-server="$(pwd)/fake.sendmail" \ $patches \ 2>errors && - grep "^From: Example <from@xxxxxxxxxxx>\$" msgtxt1 && + grep "^From: A U Thor <author@xxxxxxxxxxx>\$" msgtxt1 && grep "^To: to@xxxxxxxxxxx\$" msgtxt1 ' -- 1.8.0.207.gdf2154c -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html