diff --git a/README.md b/README.md index f924f6073..12d57bfcc 100644 --- a/README.md +++ b/README.md @@ -313,6 +313,26 @@ If you do not want to have any tag prefix you can use the `-t` flag and provide > Note: simply -t or --tag-prefix without any value will fallback to the default 'v' +### Parser Options + +If you need to include custom parser options to read your commits, you can use the `--parser-opts` to indicate the path to a .js file that exports the options. + +```sh +standard-version --parser-opts ./parser-opts.js +``` + +This can be useful in cases like Azure DevOps that uses custom merge pull request titles. The `parser-opts.js` could look like this: + +```js +/** @type {import("conventional-commits-parser").Options} */ +module.exports = { + mergePattern: /^Merged PR (\d+): (\w*)(?:\(([\w\$\.\-\* ]*)\))?\: (.*)$/, + mergeCorrespondence: ['id', 'type', 'scope', 'subject'] +} +``` + +For more informantion on what parser options are available, reference to [documentation](https://github.com/conventional-changelog/conventional-changelog/tree/master/packages/conventional-commits-parser). + ### CLI Help ```sh diff --git a/command.js b/command.js index d65d5ea06..5d44798e3 100755 --- a/command.js +++ b/command.js @@ -99,6 +99,10 @@ const yargs = require('yargs') default: defaults.preset, describe: 'Commit message guideline preset' }) + .option('parser-opts', { + type: 'string', + describe: 'Path to file with Conventional Commits Parser Options' + }) .option('lerna-package', { type: 'string', describe: 'Name of the package from which the tags will be extracted' diff --git a/index.js b/index.js index 56f3106b3..281f7dacf 100755 --- a/index.js +++ b/index.js @@ -37,6 +37,15 @@ module.exports = async function standardVersion (argv) { throw Error(`custom changelog header must not match ${changelog.START_OF_LAST_RELEASE_PATTERN}`) } + if (typeof argv.parserOpts === 'string') { + const parserOptsPath = path.resolve(argv.parserOpts) + try { + argv.parserOpts = require(parserOptsPath) + } catch(err) { + argv.parserOpts = null + } + } + /** * If an argument for `packageFiles` provided, we include it as a "default" `bumpFile`. */ diff --git a/lib/lifecycles/bump.js b/lib/lifecycles/bump.js index 370fbff03..f13641e5a 100644 --- a/lib/lifecycles/bump.js +++ b/lib/lifecycles/bump.js @@ -122,7 +122,7 @@ function bumpVersion (releaseAs, currentVersion, args) { path: args.path, tagPrefix: args.tagPrefix, lernaPackage: args.lernaPackage - }, function (err, release) { + }, args.parserOpts, function (err, release) { if (err) return reject(err) else return resolve(release) }) diff --git a/lib/lifecycles/changelog.js b/lib/lifecycles/changelog.js index f3977f9a8..11d443067 100644 --- a/lib/lifecycles/changelog.js +++ b/lib/lifecycles/changelog.js @@ -35,7 +35,7 @@ function outputChangelog (args, newVersion) { debug: args.verbose && console.info.bind(console, 'conventional-changelog'), preset: presetLoader(args), tagPrefix: args.tagPrefix - }, context, { merges: null, path: args.path }) + }, context, { merges: null, path: args.path }, args.parserOpts) .on('error', function (err) { return reject(err) })