2008-09-23 23:38:53 +04:00
|
|
|
#!/usr/bin/env perl
|
|
|
|
#
|
2016-08-18 15:29:18 +03:00
|
|
|
# Copyright (c) 2008-2016 Cisco Systems, Inc. All rights reserved.
|
2008-09-23 23:38:53 +04:00
|
|
|
#
|
|
|
|
|
|
|
|
use strict;
|
2016-08-18 15:29:18 +03:00
|
|
|
|
2008-09-23 23:38:53 +04:00
|
|
|
use Data::Dumper;
|
|
|
|
|
2014-10-02 23:31:46 +04:00
|
|
|
# Ensure that we're in the root of a writeable Git clone
|
|
|
|
my $in_git_clone = 1;
|
2008-09-23 23:38:53 +04:00
|
|
|
|
2014-10-02 23:31:46 +04:00
|
|
|
$in_git_clone = 0
|
|
|
|
if (! -d ".git" || ! -f "AUTHORS");
|
2008-09-23 23:38:53 +04:00
|
|
|
|
|
|
|
######################################################################
|
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
my $header_sep = "-----";
|
|
|
|
my $unknown_org = "********* NO ORGANIZATION SET ********";
|
|
|
|
|
|
|
|
my $people;
|
|
|
|
|
|
|
|
######################################################################
|
|
|
|
|
2014-10-02 23:31:46 +04:00
|
|
|
# Run git log to get a list of committers
|
2008-09-23 23:38:53 +04:00
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
open (GIT, "git log --format=tformat:'%aN <%aE>'|") || die "Can't run 'git log'.";
|
2014-10-02 23:31:46 +04:00
|
|
|
while (<GIT>) {
|
|
|
|
chomp;
|
2016-08-18 15:29:18 +03:00
|
|
|
m/^\s*(.+)\s+<(.+)>\s*$/;
|
|
|
|
|
|
|
|
if (!exists($people->{$1})) {
|
|
|
|
# The person doesn't exist, so save a new entry
|
|
|
|
$people->{$1} = {
|
|
|
|
name => $1,
|
|
|
|
org => $unknown_org,
|
|
|
|
emails => {
|
|
|
|
lc($2) => 1,
|
|
|
|
}
|
|
|
|
};
|
2008-09-23 23:38:53 +04:00
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
|
|
|
|
print "Found Git committer: $1 <$2>\n";
|
|
|
|
} else {
|
|
|
|
# The person already exists, so just add (or overwrite) this
|
|
|
|
# email address
|
|
|
|
$people->{$1}->{emails}->{$2} = 1;
|
2008-09-23 23:38:53 +04:00
|
|
|
}
|
|
|
|
}
|
2014-10-02 23:31:46 +04:00
|
|
|
close(GIT);
|
2008-09-23 23:38:53 +04:00
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
######################################################################
|
|
|
|
|
|
|
|
# Read the existing AUTHORS file
|
2008-09-23 23:38:53 +04:00
|
|
|
|
|
|
|
my $header;
|
|
|
|
|
2014-10-02 23:31:46 +04:00
|
|
|
print "Matching Git emails to existing names/affiliations...\n";
|
2008-09-23 23:38:53 +04:00
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
sub save {
|
|
|
|
my $current = shift;
|
|
|
|
|
|
|
|
print "Saving person from AUTHORS: $current->{name}\n";
|
|
|
|
|
|
|
|
# We may overwrite an entry written from the git log, but that's
|
|
|
|
# ok
|
|
|
|
$people->{$current->{name}} = $current;
|
|
|
|
}
|
|
|
|
|
2008-09-23 23:38:53 +04:00
|
|
|
open (AUTHORS, "AUTHORS") || die "Can't open AUTHORS file";
|
|
|
|
my $in_header = 1;
|
2016-08-18 15:29:18 +03:00
|
|
|
my $current = undef;
|
2008-09-23 23:38:53 +04:00
|
|
|
while (<AUTHORS>) {
|
|
|
|
chomp;
|
|
|
|
my $line = $_;
|
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
# Slurp down header lines until we hit a line that begins with
|
|
|
|
# $header_sep
|
2008-09-23 23:38:53 +04:00
|
|
|
if ($in_header) {
|
2016-08-18 15:29:18 +03:00
|
|
|
$header .= "$line\n";
|
|
|
|
|
|
|
|
if ($_ =~ /^$header_sep/) {
|
|
|
|
$in_header = 0;
|
|
|
|
|
|
|
|
# There should be a blank line after this, too
|
|
|
|
$header .= "\n";
|
2008-09-23 23:38:53 +04:00
|
|
|
}
|
2016-08-18 15:29:18 +03:00
|
|
|
next;
|
2008-09-23 23:38:53 +04:00
|
|
|
}
|
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
# Skip blank lines
|
|
|
|
next
|
|
|
|
if ($line =~ /^\s*$/);
|
|
|
|
|
|
|
|
# Format of body:
|
|
|
|
#
|
|
|
|
# NAME, Affiliation 1[, Affiliation 2[...]]
|
|
|
|
# Email address 1
|
|
|
|
# [Email address 2]
|
|
|
|
# [...]
|
|
|
|
# NAME, Affiliation 1[, Affiliation 2[...]]
|
|
|
|
# Email address 1
|
|
|
|
# [Email address 2]
|
|
|
|
# [...]
|
|
|
|
|
|
|
|
# Found a new email address for an existing person
|
|
|
|
if ($line =~ /^ /) {
|
|
|
|
m/^ (.+)$/;
|
|
|
|
$current->{emails}->{lc($1)} = 1;
|
|
|
|
|
|
|
|
next;
|
|
|
|
} else {
|
|
|
|
# Found a new person; save the old entry
|
|
|
|
save($current)
|
|
|
|
if (defined($current));
|
|
|
|
|
|
|
|
$current = undef;
|
|
|
|
$current->{org} = $unknown_org;
|
|
|
|
if ($line =~ m/^(.+?),\s+(.+)$/) {
|
|
|
|
$current->{name} = $1;
|
|
|
|
$current->{org} = $2;
|
2008-09-23 23:38:53 +04:00
|
|
|
} else {
|
2016-08-18 15:29:18 +03:00
|
|
|
$current->{name} = $line;
|
2008-09-23 23:38:53 +04:00
|
|
|
}
|
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
next;
|
2008-09-23 23:38:53 +04:00
|
|
|
}
|
|
|
|
}
|
2016-08-18 15:29:18 +03:00
|
|
|
|
|
|
|
save($current)
|
|
|
|
if (defined($current));
|
|
|
|
|
2008-09-23 23:38:53 +04:00
|
|
|
close(AUTHORS);
|
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
######################################################################
|
2014-10-02 23:31:46 +04:00
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
# Output a new AUTHORS file
|
2008-09-23 23:38:53 +04:00
|
|
|
|
|
|
|
open (AUTHORS, ">AUTHORS.new") || die "Can't write to AUTHORS file";
|
2016-08-18 15:29:18 +03:00
|
|
|
|
2008-09-23 23:38:53 +04:00
|
|
|
print AUTHORS $header;
|
2016-08-18 15:29:18 +03:00
|
|
|
|
|
|
|
my @people_with_unknown_orgs;
|
|
|
|
my $email_dups;
|
|
|
|
|
|
|
|
my @sorted_people = sort(keys(%{$people}));
|
|
|
|
foreach my $p (@sorted_people) {
|
|
|
|
print AUTHORS $p;
|
|
|
|
if (exists($people->{$p}->{org})) {
|
2016-12-14 21:20:56 +03:00
|
|
|
my $org = $people->{$p}->{org};
|
|
|
|
if ($org ne $unknown_org) {
|
|
|
|
print AUTHORS ", $org";
|
|
|
|
} else {
|
|
|
|
# Record this so that we can warn about it
|
|
|
|
push(@people_with_unknown_orgs, $p);
|
|
|
|
}
|
2008-09-23 23:38:53 +04:00
|
|
|
}
|
2016-08-18 15:29:18 +03:00
|
|
|
print AUTHORS "\n";
|
|
|
|
|
|
|
|
foreach my $e (sort(keys(%{$people->{$p}->{emails}}))) {
|
|
|
|
# Sanity check: make sure this email address does not show up
|
|
|
|
# with any other person/name
|
|
|
|
my $dup;
|
|
|
|
foreach my $p2 (@sorted_people) {
|
|
|
|
next
|
|
|
|
if ($p eq $p2);
|
|
|
|
|
|
|
|
foreach my $e2 (keys(%{$people->{$p2}->{emails}})) {
|
|
|
|
if ($e eq $e2) {
|
|
|
|
$dup = $p2;
|
|
|
|
|
|
|
|
# Record this so that we can warn about it
|
|
|
|
if ($p le $p2) {
|
|
|
|
$email_dups->{$p} = $p2;
|
|
|
|
} else {
|
|
|
|
$email_dups->{$p2} = $p;
|
|
|
|
}
|
|
|
|
last;
|
|
|
|
}
|
|
|
|
}
|
2014-10-02 23:31:46 +04:00
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
last
|
|
|
|
if (defined($dup));
|
2008-09-23 23:38:53 +04:00
|
|
|
}
|
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
print AUTHORS " $e";
|
|
|
|
print AUTHORS " (**** DUPLICATE EMAIL ADDRESS WITH $dup ***)"
|
|
|
|
if (defined($dup));
|
|
|
|
print AUTHORS "\n";
|
2008-09-23 23:38:53 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
close(AUTHORS);
|
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
# We have a new AUTHORS file! Replace the old one.
|
2008-09-23 23:38:53 +04:00
|
|
|
unlink("AUTHORS");
|
|
|
|
rename("AUTHORS.new", "AUTHORS");
|
|
|
|
|
|
|
|
print "New AUTHORS file written.\n";
|
2016-08-18 15:29:18 +03:00
|
|
|
|
|
|
|
######################################################################
|
|
|
|
|
|
|
|
# Output any relevant warnings
|
|
|
|
|
|
|
|
my $warned = 0;
|
|
|
|
if ($#people_with_unknown_orgs >= 0) {
|
|
|
|
$warned = 1;
|
|
|
|
print "\n*** WARNING: The following people have unspecified organiations:\n";
|
|
|
|
foreach my $p (@people_with_unknown_orgs) {
|
|
|
|
print "*** $p\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
my @k = sort(keys(%{$email_dups}));
|
|
|
|
if ($#k >= 0) {
|
|
|
|
$warned = 1;
|
|
|
|
print "\n*** WARNING: The following people had the same email address:\n";
|
|
|
|
foreach my $p (@k) {
|
|
|
|
print "*** $p, $email_dups->{$p}\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($warned) {
|
|
|
|
print "
|
|
|
|
*******************************************************************************
|
|
|
|
*** YOU SHOULD EDIT THE .mailmap AND/OR AUTHORS FILE TO RESOLVE THESE WARNINGS!
|
|
|
|
*******************************************************************************\n";
|
2008-09-23 23:38:53 +04:00
|
|
|
}
|
|
|
|
|
2016-08-18 15:29:18 +03:00
|
|
|
exit($warned);
|