The git-log-reader is a simple module for reading and parsing a git log. Each commit is parsed into an object with git fields becoming properties. Pattern matchers may be run against any field. Capture groups from the matcher's regular expression can be added as additional custom fields.
var gitlog = require('git-log-reader');
// commits is an array of commit objects
var commits = gitlog.read({
// git fields to extract
fields: ['abbrevHash', 'subject', 'body'],
// Optional patterns that can match data in git fields. Capture groups in the
// matchers regular expression can overwrite existing fields or create new custom fields
matchers: [{
// Run this pattern on the default git field "subject".
// Match an issue number like #123 and add field { issue: 123 }
pattern: "#(\\d+)",
fields: ['issue']
}, {
// Use the Angular commit format in the subject field.
regexp: /^(\w*)(?:\(([\w\$\.]*)\))?\: (.*)$/,
fields: ['type', 'scope', 'subject']
}, {
// Filter on author name.
sourceField: 'authorName',
regexp: /Ryan/
}]
});
An optional array of git fields to add to commit objects.
Default value: ['abbrevHash', 'subject']
Valid fields:
- hash
- abbrevHash
- treeHash
- abbrevTreeHash
- parentHashes
- abbrevParentHashes
- authorName
- authorEmail
- authorDate
- committerName
- committerEmail
- committerDate
- refNames
- encoding
- subject
- sanitizedSubject
- body
- commitNotes
The optional directory that contains the git repository.
An optional array of objects that define regular expressions that can be run against any of the git fields to add additional custom fields. The new fields can also overwrite the original git field.
Matchers are run in order until a match is found. If no matches are found the commit gets filtered out.
If you specify a pattern make sure you escape backslash characters.