This plugin requires Grunt ~0.4.0
If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:
npm install grunt-changelog --save-dev
One the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
grunt.loadNpmTasks('grunt-changelog');
In your project's Gruntfile, add a section named changelog
to the data object passed into grunt.initConfig()
. The task, by default, will go through the last 7 days of commit messages, looking for issues that were closed or fixed. It will then generate a template-based changelog with those changes and write them to a destination file.
grunt.initConfig({
changelog: {
options: {
// Task-specific options go here.
}
},
})
NEW:
- Feature 1
- Feature 2
- Feature 3
FIXES:
- Fix 1
- Fix 2
Type: String
Default value: 7 days ago
An ISO-8601 date string that the git log will start at.
Type: String
Default value: now
An ISO-8601 date string that the git log will end at.
Type: RegEx
Default value: /^(.*)closes #\d+:?(.*)$/gim
The regular expression used to match feature changes.
Type: RegEx
Default value: /^(.*)fixes #\d+:?(.*)$/gim
The regular expression used to match bug fix changes.
Type: String
Default value: undefined
The log file to parse for changes. If nothing is set, a git log command will be run.
Type: String
Default value: changelog
The file path to write the changelog to.
Type: String
Default value: NEW:\n\n{{features}}\nFIXES:\n\n{{fixes}}
The main template used for creating the changelog.
Type: String
Default value: - {{change}}\n
The template used for creating each individual change.
Type: String
Default value: (none)\n
The template used when no changes are found.
In this example, the default options are used to create the changelog. A git log command will run for logs starting 7 days ago until now and the changelog will be generated matching commit messages with fixes and closes.
grunt.initConfig({
changelog: {
options: {}
},
})
changelog.txt
NEW:
- Feature 1
- Feature 2
- Feature 3
FIXES:
- Fix 1
- Fix 2
In this example, a custom date range is used to only show changes between March 1st and March 14th.
grunt.initConfig({
changelog: {
options: {
after: '2013-03-01',
before: '2013-03-14'
}
},
})
In this example, a custom destination is used to write the changelog to a different location.
grunt.initConfig({
changelog: {
options: {
dest: 'release-notes/1.0.0.txt'
}
},
})
In this example, custom formatting is used to create a simple changelog with the list of features and fixes.
grunt.initConfig({
changelog: {
options: {
dest: 'release-notes/1.0.0.txt',
templates: {
main: '{{date}}\n\n{{features}}{{fixes}}',
change: ' - {{change}}\n',
empty: ''
}
}
},
})
release-notes/1.0.0.txt
2013-05-01
- Feature 1
- Feature 2
- Feature 3
- Fix 1
- Fix 2
In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using Grunt.