Skip to content

Commit ccc3ae7

Browse files
committed
Merge branch 'jk/mailmap-cleanup' into maint
* jk/mailmap-cleanup: contrib: update stats/mailmap script .mailmap: normalize emails for Linus Torvalds .mailmap: normalize emails for Jeff King .mailmap: fix broken entry for Martin Langhoff .mailmap: match up some obvious names/emails
2 parents 66afe50 + 53474eb commit ccc3ae7

File tree

2 files changed

+82
-33
lines changed

2 files changed

+82
-33
lines changed

.mailmap

Lines changed: 18 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,9 @@ Alex Bennée <[email protected]>
99
Alexander Gavrilov <[email protected]>
1010
Aneesh Kumar K.V <[email protected]>
1111
Brian M. Carlson <[email protected]>
12+
Cheng Renquan <[email protected]>
1213
Chris Shoemaker <[email protected]>
14+
Dan Johnson <[email protected]>
1315
Dana L. How <[email protected]>
1416
Dana L. How <[email protected]>
1517
Daniel Barkalow <[email protected]>
@@ -18,14 +20,18 @@ David Kågedal <[email protected]>
1820
David S. Miller <[email protected]>
1921
Deskin Miller <[email protected]>
2022
Dirk Süsserott <[email protected]>
23+
Eric S. Raymond <[email protected]>
2124
2225
Fredrik Kuivinen <[email protected]>
26+
Frédéric Heitzmann <[email protected]>
2327
H. Peter Anvin <[email protected]>
2428
H. Peter Anvin <[email protected]>
2529
H. Peter Anvin <[email protected]>
2630
Horst H. von Brand <[email protected]>
2731
İsmail Dönmez <[email protected]>
32+
Jakub Narębski <[email protected]>
2833
Jay Soffian <[email protected]>
34+
2935
Joachim Berdal Haga <[email protected]>
3036
3137
@@ -41,12 +47,21 @@ Junio C Hamano <[email protected]> <[email protected]>
4147
4248
4349
Karl Hasselström <[email protected]>
50+
Kevin Leung <[email protected]>
4451
Kent Engstrom <[email protected]>
4552
Lars Doelle <lars.doelle@on-line ! de>
4653
Lars Doelle <[email protected]>
4754
55+
56+
57+
58+
59+
60+
Linus Torvalds <[email protected]> <[email protected].(none)>
4861
Lukas Sandström <[email protected]>
49-
Martin Langhoff <[email protected]>
62+
Marc-André Lureau <[email protected]>
63+
Mark Rada <[email protected]>
64+
5065
Martin von Zweigbergk <[email protected]> <[email protected]>
5166
Michael Coleman <[email protected]>
5267
@@ -63,11 +78,13 @@ Ralf Thielow <[email protected]> <[email protected]>
6378
Ramsay Allan Jones <[email protected]>
6479
René Scharfe <[email protected]>
6580
Robert Fitzsimons <[email protected]>
81+
Robert Zeh <[email protected]>
6682
Sam Vilain <[email protected]>
6783
Santi Béjar <[email protected]>
6884
Sean Estabrooks <[email protected]>
6985
Shawn O. Pearce <[email protected]>
7086
Steven Grimm <[email protected]>
87+
Tay Ray Chuan <[email protected]>
7188
Theodore Ts'o <[email protected]>
7289
7390
Tony Luck <[email protected]>

contrib/stats/mailmap.pl

Lines changed: 64 additions & 32 deletions
Original file line numberDiff line numberDiff line change
@@ -1,38 +1,70 @@
1-
#!/usr/bin/perl -w
2-
my %mailmap = ();
3-
open I, "<", ".mailmap";
4-
while (<I>) {
5-
chomp;
6-
next if /^#/;
7-
if (my ($author, $mail) = /^(.*?)\s+<(.+)>$/) {
8-
$mailmap{$mail} = $author;
9-
}
1+
#!/usr/bin/perl
2+
3+
use warnings 'all';
4+
use strict;
5+
use Getopt::Long;
6+
7+
my $match_emails;
8+
my $match_names;
9+
my $order_by = 'count';
10+
Getopt::Long::Configure(qw(bundling));
11+
GetOptions(
12+
'emails|e!' => \$match_emails,
13+
'names|n!' => \$match_names,
14+
'count|c' => sub { $order_by = 'count' },
15+
'time|t' => sub { $order_by = 'stamp' },
16+
) or exit 1;
17+
$match_emails = 1 unless $match_names;
18+
19+
my $email = {};
20+
my $name = {};
21+
22+
open(my $fh, '-|', "git log --format='%at <%aE> %aN'");
23+
while(<$fh>) {
24+
my ($t, $e, $n) = /(\S+) <(\S+)> (.*)/;
25+
mark($email, $e, $n, $t);
26+
mark($name, $n, $e, $t);
1027
}
11-
close I;
12-
13-
my %mail2author = ();
14-
open I, "git log --pretty='format:%ae %an' |";
15-
while (<I>) {
16-
chomp;
17-
my ($mail, $author) = split(/\t/, $_);
18-
next if exists $mailmap{$mail};
19-
$mail2author{$mail} ||= {};
20-
$mail2author{$mail}{$author} ||= 0;
21-
$mail2author{$mail}{$author}++;
28+
close($fh);
29+
30+
if ($match_emails) {
31+
foreach my $e (dups($email)) {
32+
foreach my $n (vals($email->{$e})) {
33+
show($n, $e, $email->{$e}->{$n});
34+
}
35+
print "\n";
36+
}
2237
}
23-
close I;
24-
25-
while (my ($mail, $authorcount) = each %mail2author) {
26-
# %$authorcount is ($author => $count);
27-
# sort and show the names from the most frequent ones.
28-
my @names = (map { $_->[0] }
29-
sort { $b->[1] <=> $a->[1] }
30-
map { [$_, $authorcount->{$_}] }
31-
keys %$authorcount);
32-
if (1 < @names) {
33-
for (@names) {
34-
print "$_ <$mail>\n";
38+
if ($match_names) {
39+
foreach my $n (dups($name)) {
40+
foreach my $e (vals($name->{$n})) {
41+
show($n, $e, $name->{$n}->{$e});
3542
}
43+
print "\n";
3644
}
3745
}
46+
exit 0;
3847

48+
sub mark {
49+
my ($h, $k, $v, $t) = @_;
50+
my $e = $h->{$k}->{$v} ||= { count => 0, stamp => 0 };
51+
$e->{count}++;
52+
$e->{stamp} = $t unless $t < $e->{stamp};
53+
}
54+
55+
sub dups {
56+
my $h = shift;
57+
return grep { keys($h->{$_}) > 1 } keys($h);
58+
}
59+
60+
sub vals {
61+
my $h = shift;
62+
return sort {
63+
$h->{$b}->{$order_by} <=> $h->{$a}->{$order_by}
64+
} keys($h);
65+
}
66+
67+
sub show {
68+
my ($n, $e, $h) = @_;
69+
print "$n <$e> ($h->{$order_by})\n";
70+
}

0 commit comments

Comments
 (0)