diff options
author | Junio C Hamano <junkio@cox.net> | 2006-06-06 16:42:33 -0700 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2006-06-06 16:42:33 -0700 |
commit | ad0e0b0a31c4e7a7a893ea68fd4ee92aebb79988 (patch) | |
tree | 1bb4739962e8050dcd622d2563ba7ce0af31566d | |
parent | builtin-grep: pass ignore case option to external grep (diff) | |
parent | send-email: a bit more careful domain regexp. (diff) | |
download | tgif-ad0e0b0a31c4e7a7a893ea68fd4ee92aebb79988.tar.xz |
Merge branch 'vb/sendemail'
* vb/sendemail:
send-email: a bit more careful domain regexp.
send-email: be more lenient and just catch obvious mistakes.
Cleanup git-send-email.perl:extract_valid_email
-rwxr-xr-x | git-send-email.perl | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/git-send-email.perl b/git-send-email.perl index ed1d89b3f7..7b1cca70ab 100755 --- a/git-send-email.perl +++ b/git-send-email.perl @@ -312,20 +312,19 @@ our ($message_id, $cc, %mail, $subject, $reply_to, $references, $message); sub extract_valid_address { my $address = shift; + my $local_part_regexp = '[^<>"\s@]+'; + my $domain_regexp = '[^.<>"\s@]+(?:\.[^.<>"\s@]+)+'; # check for a local address: - return $address if ($address =~ /^([\w\-]+)$/); + return $address if ($address =~ /^($local_part_regexp)$/); if ($have_email_valid) { - return Email::Valid->address($address); + return scalar Email::Valid->address($address); } else { # less robust/correct than the monster regexp in Email::Valid, # but still does a 99% job, and one less dependency - my $cleaned_address; - if ($address =~ /([^\"<>\s]+@[^<>\s]+)/) { - $cleaned_address = $1; - } - return $cleaned_address; + $address =~ /($local_part_regexp\@$domain_regexp)/; + return $1; } } @@ -387,7 +386,7 @@ X-Mailer: git-send-email $gitversion defined $pid or die $!; if (!$pid) { exec($smtp_server,'-i', - map { scalar extract_valid_address($_) } + map { extract_valid_address($_) } @recipients) or die $!; } print $sm "$header\n$message"; |