NAME

Porting::updateAUTHORS - Library to automatically update AUTHORS and .mailmap based on commit data.

SYNOPSIS

use Porting::updateAUTHORS;

my $updater= Porting::updateAUTHORS->new(
    authors_file => "AUTHORS",
    mailmap_file => ".mailmap",
    exclude_file => "Porting/exclude_contrib.txt",
);
$updater->read_and_update();

DESCRIPTION

This the brain of the Porting/updateAUTHORS.pl script. It is expected to be used from that script and by that script. Most features and options are documented in the Porting/updateAUTHORS.pl and are not explicitly documented here, read the Porting/updateAUTHORS.pl manpage for more details.

METHODS

Porting::updateAUTHORS uses OO as way of managing its internal state. This documents the public methods it exposes.

add_new_mailmap_entries()

If any additions were identified while reading the commits this will inject them into the mailmap_hash so they can be written out. Returns a count of additions found.

check_fix_mailmap_hash()

Analyzes the data contained the in the .mailmap file and applies any automated fixes which are required and which it can automatically perform. Returns a hash of adjusted entries and a hash with additional metadata about the mailmap entries.

new(%opts)

Create a new object. Required parameters are

authors_file
mailmap_file
exclude_file

Other supported parameters are as follows:

verbose
commit_range

this list is not exhaustive. See the code implementing the main() function in Porting/updateAUTHORS.pl for an exhaustive list.

parse_orig_mailmap_hash()

Takes a mailmap_hash and parses it and returns it as an array of array records with the contents:

[ $preferred_name, $preferred_email,
  $other_name, $other_email,
  $line_num ]
read_and_update()

Wraps the other functions in this library and implements the logic and intent of this tool. Takes two arguments, the authors file name, and the mailmap file name. Returns nothing but may modify the AUTHORS file or the .mailmap file. Requires that both files are editable.

read_commit_log()

Read the commit log specified by the property "commit_range" and find any new names it contains.

Normally used via read_and_update and not called directly.

read_authors_file()

Read the AUTHORS file into the object, and return data about it.

Normally used via read_and_update and not called directly.

read_mailmap_file()

Read the .mailmap file into the object and return data about it.

Normally used via read_and_update and not called directly.

read_exclusion_file()

Read the exclusion file into the object and return data about it.

Normally used via read_and_update and not called directly.

update_authors_file()

Write out an updated AUTHORS file atomically if it has changed, returns 0 if the file was actually updated, 1 if it was not.

Normally used via read_and_update and not called directly.

update_mailmap_file()

Write out an updated .mailmap file atomically if it has changed, returns 0 if the file was actually updated, 1 if it was not.

Normally used via read_and_update and not called directly.

update_exclusion_file()

Write out an updated exclusion file atomically if it has changed, returns 0 if the file was actually update, 1 if it was not.

Normally used via read_and_update and not called directly.

TODO

More documentation and testing.

SEE ALSO

Porting/checkAUTHORS.pl

AUTHOR

Yves Orton <demerphq@gmail.com>