Commit 0e70e83d authored by Joe Perches's avatar Joe Perches Committed by Linus Torvalds

scripts/get_maintainer.pl: better email routines, use perl not shell where possible

Added format_email and parse_email routines to reduce inline use.

Added email_address_inuse to eliminate multiple maintainer entries
for the same email address, the first name encountered is used.

Used internal perl equivalents of shell cmd use of grep|cut|sort|uniq
Signed-off-by: default avatarJoe Perches <joe@perches.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 3fb55652
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
use strict; use strict;
my $P = $0; my $P = $0;
my $V = '0.19'; my $V = '0.20';
use Getopt::Long qw(:config no_auto_abbrev); use Getopt::Long qw(:config no_auto_abbrev);
...@@ -258,11 +258,8 @@ if ($email) { ...@@ -258,11 +258,8 @@ if ($email) {
foreach my $chief (@penguin_chief) { foreach my $chief (@penguin_chief) {
if ($chief =~ m/^(.*):(.*)/) { if ($chief =~ m/^(.*):(.*)/) {
my $email_address; my $email_address;
if ($email_usename) {
$email_address = format_email($1, $2); $email_address = format_email($1, $2);
} else {
$email_address = $2;
}
if ($email_git_penguin_chiefs) { if ($email_git_penguin_chiefs) {
push(@email_to, $email_address); push(@email_to, $email_address);
} else { } else {
...@@ -400,21 +397,57 @@ sub top_of_kernel_tree { ...@@ -400,21 +397,57 @@ sub top_of_kernel_tree {
return 0; return 0;
} }
sub format_email { sub parse_email {
my ($name, $email) = @_; my ($formatted_email) = @_;
my $name = "";
my $address = "";
if ($formatted_email =~ /^([^<]+)<(.*\@.*)>$/) {
$name = $1;
$address = $2;
} elsif ($formatted_email =~ /^<(.*\@.*)>$/) {
$address = $1;
} elsif ($formatted_email =~ /^(.*\@.*)$/) {
$address = $1;
}
$name =~ s/^\s+|\s+$//g; $name =~ s/^\s+|\s+$//g;
$name =~ s/^\"|\"$//g; $name =~ s/^\"|\"$//g;
$email =~ s/^\s+|\s+$//g; $address =~ s/^\s+|\s+$//g;
if ($name =~ /[^a-z0-9 \.\-]/i) { ##has "must quote" chars
$name =~ s/(?<!\\)"/\\"/g; ##escape quotes
$name = "\"$name\"";
}
return ($name, $address);
}
sub format_email {
my ($name, $address) = @_;
my $formatted_email = ""; my $formatted_email;
$name =~ s/^\s+|\s+$//g;
$name =~ s/^\"|\"$//g;
$address =~ s/^\s+|\s+$//g;
if ($name =~ /[^a-z0-9 \.\-]/i) { ##has "must quote" chars if ($name =~ /[^a-z0-9 \.\-]/i) { ##has "must quote" chars
$name =~ s/(?<!\\)"/\\"/g; ##escape quotes $name =~ s/(?<!\\)"/\\"/g; ##escape quotes
$formatted_email = "\"${name}\"\ \<${email}\>"; $name = "\"$name\"";
}
if ($email_usename) {
if ("$name" eq "") {
$formatted_email = "$address";
} else {
$formatted_email = "$name <${address}>";
}
} else { } else {
$formatted_email = "${name} \<${email}\>"; $formatted_email = $address;
} }
return $formatted_email; return $formatted_email;
} }
...@@ -444,19 +477,18 @@ sub add_categories { ...@@ -444,19 +477,18 @@ sub add_categories {
} }
} }
} elsif ($ptype eq "M") { } elsif ($ptype eq "M") {
my $p_used = 0; my ($name, $address) = parse_email($pvalue);
if ($name eq "") {
if ($index >= 0) { if ($index >= 0) {
my $tv = $typevalue[$index - 1]; my $tv = $typevalue[$index - 1];
if ($tv =~ m/^(\C):\s*(.*)/) { if ($tv =~ m/^(\C):\s*(.*)/) {
if ($1 eq "P") { if ($1 eq "P") {
if ($email_usename) { $name = $2;
push_email_address(format_email($2, $pvalue));
$p_used = 1;
} }
} }
} }
} }
if (!$p_used) { if ($email_maintainer) {
push_email_addresses($pvalue); push_email_addresses($pvalue);
} }
} elsif ($ptype eq "T") { } elsif ($ptype eq "T") {
...@@ -475,26 +507,24 @@ sub add_categories { ...@@ -475,26 +507,24 @@ sub add_categories {
} }
} }
sub push_email_address { sub email_address_inuse {
my ($email_address) = @_; my ($test_address) = @_;
my $email_name = ""; foreach my $line (@email_to) {
my ($name, $address) = parse_email($line);
if ($email_maintainer) { return 1 if ($address eq $test_address);
if ($email_address =~ m/([^<]+)<(.*\@.*)>$/) {
$email_name = $1;
$email_address = $2;
if ($email_usename) {
push(@email_to, format_email($email_name, $email_address));
} else {
push(@email_to, $email_address);
}
} elsif ($email_address =~ m/<(.+)>/) {
$email_address = $1;
push(@email_to, $email_address);
} else {
push(@email_to, $email_address);
} }
return 0;
}
sub push_email_address {
my ($line) = @_;
my ($name, $address) = parse_email($line);
if (!email_address_inuse($address)) {
push(@email_to, format_email($name, $address));
} }
} }
...@@ -535,6 +565,7 @@ sub recent_git_signoffs { ...@@ -535,6 +565,7 @@ sub recent_git_signoffs {
my $output = ""; my $output = "";
my $count = 0; my $count = 0;
my @lines = (); my @lines = ();
my %hash;
my $total_sign_offs; my $total_sign_offs;
if (which("git") eq "") { if (which("git") eq "") {
...@@ -548,25 +579,31 @@ sub recent_git_signoffs { ...@@ -548,25 +579,31 @@ sub recent_git_signoffs {
} }
$cmd = "git log --since=${email_git_since} -- ${file}"; $cmd = "git log --since=${email_git_since} -- ${file}";
$cmd .= " | grep -Ei \"^[-_ a-z]+by:.*\\\@.*\$\"";
if (!$email_git_penguin_chiefs) {
$cmd .= " | grep -Ev \"${penguin_chiefs}\"";
}
$cmd .= " | cut -f2- -d\":\"";
$cmd .= " | sort | uniq -c | sort -rn";
$output = `${cmd}`; $output = `${cmd}`;
$output =~ s/^\s*//gm; $output =~ s/^\s*//gm;
@lines = split("\n", $output); @lines = split("\n", $output);
$total_sign_offs = 0; @lines = grep(/^[-_ a-z]+by:.*\@.*$/i, @lines);
if (!$email_git_penguin_chiefs) {
@lines = grep(!/${penguin_chiefs}/i, @lines);
}
# cut -f2- -d":"
s/.*:\s*(.+)\s*/$1/ for (@lines);
@lines = mailmap(@lines);
$total_sign_offs = @lines;
@lines = sort(@lines);
# uniq -c
foreach my $line (@lines) { foreach my $line (@lines) {
if ($line =~ m/([0-9]+)\s+(.*)/) { $hash{$line}++;
$total_sign_offs += $1;
} else {
die("$P: Unexpected git output: ${line}\n");
} }
# sort -rn
@lines = ();
foreach my $line (sort {$hash{$b} <=> $hash{$a}} keys %hash) {
push(@lines,"$hash{$line} $line");
} }
foreach my $line (@lines) { foreach my $line (@lines) {
...@@ -579,9 +616,9 @@ sub recent_git_signoffs { ...@@ -579,9 +616,9 @@ sub recent_git_signoffs {
$sign_offs * 100 / $total_sign_offs < $email_git_min_percent) { $sign_offs * 100 / $total_sign_offs < $email_git_min_percent) {
last; last;
} }
}
push_email_address($line); push_email_address($line);
} }
}
} }
sub save_commits { sub save_commits {
...@@ -632,15 +669,18 @@ sub git_assign_blame { ...@@ -632,15 +669,18 @@ sub git_assign_blame {
@commits = uniq(@commits); @commits = uniq(@commits);
foreach my $commit (@commits) { foreach my $commit (@commits) {
$cmd = "git log -1 ${commit}"; $cmd = "git log -1 ${commit}";
$cmd .= " | grep -Ei \"^[-_ a-z]+by:.*\\\@.*\$\"";
if (!$email_git_penguin_chiefs) {
$cmd .= " | grep -Ev \"${penguin_chiefs}\"";
}
$cmd .= " | cut -f2- -d\":\"";
$output = `${cmd}`; $output = `${cmd}`;
$output =~ s/^\s*//gm; $output =~ s/^\s*//gm;
@lines = split("\n", $output); @lines = split("\n", $output);
@lines = grep(/^[-_ a-z]+by:.*\@.*$/i, @lines);
if (!$email_git_penguin_chiefs) {
@lines = grep(!/${penguin_chiefs}/i, @lines);
}
# cut -f2- -d":"
s/.*:\s*(.+)\s*/$1/ for (@lines);
$hash{$_}++ for @lines; $hash{$_}++ for @lines;
$total_sign_offs += @lines; $total_sign_offs += @lines;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment