Skip to content

Commit

Permalink
git-send-email: Do not make @-less message ID
Browse files Browse the repository at this point in the history
When the original $from address fails to yield a valid-looking
e-mail address, we created a bogus looking message ID, formatted
like this:

	Message-Id: <11823357623688-git-send-email->

This commit fixes it by moving call to make_message_id() to
where it matters, namely, before the $message_id is needed to be
placed in the generated e-mail header; this has an important
side effect of making it clear that $from is already available.

Also throw in Sys::Hostname::hostname() just for fun, although I
suspect that the code would never trigger due to the modified
call sequence that makes sure $from is always available.  This
is based on a suggestion by Michael Hendricks.

Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Junio C Hamano committed Jun 24, 2007
1 parent 0d351e9 commit aeb5932
Showing 1 changed file with 12 additions and 4 deletions.
16 changes: 12 additions & 4 deletions git-send-email.perl
Original file line number Diff line number Diff line change
Expand Up @@ -412,13 +412,21 @@ sub extract_valid_address {
# 1 second since the last time we were called.

# We'll setup a template for the message id, using the "from" address:
my $message_id_from = extract_valid_address($from);
my $message_id_template = "<%s-git-send-email-$message_id_from>";

sub make_message_id
{
my $date = time;
my $pseudo_rand = int (rand(4200));
my $du_part;
for ($from, $committer, $author) {
$du_part = extract_valid_address($_);
last if ($du_part ne '');
}
if ($du_part eq '') {
use Sys::Hostname qw();
$du_part = 'user@' . Sys::Hostname::hostname();
}
my $message_id_template = "<%s-git-send-email-$du_part>";
$message_id = sprintf $message_id_template, "$date$pseudo_rand";
#print "new message id = $message_id\n"; # Was useful for debugging
}
Expand Down Expand Up @@ -467,6 +475,8 @@ sub send_message
$ccline = "\nCc: $cc";
}
$from = sanitize_address_rfc822($from);
make_message_id();

my $header = "From: $from
To: $to${ccline}
Subject: $subject
Expand Down Expand Up @@ -533,7 +543,6 @@ sub send_message

$reply_to = $initial_reply_to;
$references = $initial_reply_to || '';
make_message_id();
$subject = $initial_subject;

foreach my $t (@files) {
Expand Down Expand Up @@ -627,7 +636,6 @@ sub send_message
$references = "$message_id";
}
}
make_message_id();
}

if ($compose) {
Expand Down

0 comments on commit aeb5932

Please sign in to comment.