Package Exports
- 4part-version
- 4part-version/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (4part-version) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
4part-version
A fork of standard-version that supports 4-part versioning (x.y.z.a) instead of the standard semver 3-part versioning.
A utility for versioning using extended semver (supporting 4-part versions) and CHANGELOG generation powered by Conventional Commits.
Key Features
Supports 4-part versioning (x.y.z.a) where:
- x: Major version (breaking changes)
- y: Minor version (new features)
- z: Patch version (bug fixes)
- a: Revision/Build number
All the features of standard-version including:
- Automatic CHANGELOG generation
- Git tag creation
- Commit message convention enforcement
- Flexible configuration
Installation
npm install --save-dev 4part-versionUsage
NPM Scripts
Add these scripts to your package.json for easy version management:
{
"scripts": {
"release:major": "npx 4part-version --release-as major",
"release:minor": "npx 4part-version --release-as minor",
"release:patch": "npx 4part-version --release-as patch",
"release:revision": "npx 4part-version --release-as revision",
"release:match": "npx 4part-version --release-version",
"release:prerelease": "npx 4part-version --prerelease",
"release:prerelease-alpha": "npx 4part-version --release-as revision --prerelease alpha",
"release:prerelease-beta": "npx 4part-version --release-as revision --prerelease beta",
"release:prerelease-rc": "npx 4part-version --release-as revision --prerelease rc"
}
}Command Line Usage
# Bump major version (1.0.0.0 -> 2.0.0.0)
npm run release:major
# Bump minor version (1.0.0.0 -> 1.1.0.0)
npm run release:minor
# Bump patch version (1.0.0.0 -> 1.0.1.0)
npm run release:patch
# Bump revision number (1.0.0.0 -> 1.0.0.1)
npm run release:revision
# Set to a specific version
npm run release:match -- 2.0.0.0
# Create a prerelease version
npm run release:prerelease
# Create an alpha prerelease
npm run release:prerelease-alpha
# Create a beta prerelease
npm run release:prerelease-beta
# Create an RC prerelease
npm run release:prerelease-rcDirect Usage
You can also use the CLI directly:
# Using npx
npx 4part-version
# Or install globally
npm install -g 4part-versionVersion Commands
The package supports the following version commands:
--release-as <major|minor|patch|revision>: Specify which part of the version to bump--release-version <version>: Specify an exact version (e.g., 1.2.3.4)--prerelease [tag]: Create a prerelease version (e.g., 1.2.3.4-alpha.0)
Examples:
# Bump revision number (1.2.3.4 -> 1.2.3.5)
npx 4part-version --release-as revision
# Set specific version
npx 4part-version --release-version 1.2.3.4
# Using NPM script to set a specific version
# Note: the -- is required to pass the version as an argument
npm run release:match -- 1.2.3.4
# Create pre-release with revision
npx 4part-version --release-as revision --prerelease alphaHaving problems? Want to contribute? Join us on the node-tooling community Slack.
How It Works:
- Follow the Conventional Commits Specification in your repository.
- When you're ready to release, run
4part-version.
4part-version will then do the following:
- Retrieve the current version of your repository by looking at
packageFiles[1], falling back to the lastgit tag. bumpthe version inbumpFiles[1] based on your commits.- Generates a
changelogbased on your commits (uses conventional-changelog under the hood). - Creates a new
commitincluding yourbumpFiles[1] and updated CHANGELOG. - Creates a new
tagwith the new version number.
bumpFiles, packageFiles and updaters
4part-version uses a few key concepts for handling version bumping in your project.
packageFiles– User-defined files where versions can be read from and be "bumped".- Examples:
package.json,manifest.json - In most cases (including the default),
packageFilesare a subset ofbumpFiles.
- Examples:
bumpFiles– User-defined files where versions should be "bumped", but not explicitly read from.- Examples:
package-lock.json,npm-shrinkwrap.json
- Examples:
updaters– Simple modules used for readingpackageFilesand writing tobumpFiles.
By default, 4part-version assumes you're working in a NodeJS based project... because of this, for the majority of projects you might never need to interact with these options.
That said, if you find your self asking How can I use 4part-version for additional metadata files, languages or version files? – these configuration options will help!
Configuration
You can configure 4part-version either by:
- Placing a
4part-versionstanza in yourpackage.json(assuming your project is JavaScript). - Creating a
.versionrc,.versionrc.jsonor.versionrc.js.
- If you are using a
.versionrc.jsyour default export must be a configuration object, or a function returning a configuration object.
Any of the command line parameters accepted by 4part-version can instead
be provided via configuration. Please refer to the conventional-changelog-config-spec for details on available configuration options.
Customizing CHANGELOG Generation
By default (as of 6.0.0), 4part-version uses the conventionalcommits preset.
This preset:
- Adheres closely to the conventionalcommits.org specification.
- Is highly configurable, following the configuration specification
maintained here.
- We've documented these config settings as a recommendation to other tooling makers.
There are a variety of dials and knobs you can turn related to CHANGELOG generation.
As an example, suppose you're using GitLab, rather than GitHub, you might modify the following variables:
commitUrlFormat: the URL format of commit SHAs detected in commit messages.compareUrlFormat: the URL format used to compare two tags.issueUrlFormat: the URL format used to link to issues.
Making these URLs match GitLab's format, rather than GitHub's.
CLI Usage
NOTE: To pass nested configurations to the CLI without defining them in the
package.jsonuse dot notation as the parameterse.g. --skip.changelog.
First Release
To generate your changelog for your first release, simply do:
# npm run script
npm run release -- --first-release
# global bin
4part-version --first-release
# npx
npx 4part-version --first-releaseThis will tag a release without bumping the version bumpFiles1.
When you are ready, push the git tag and npm publish your first release. \o/
Cutting Releases
If you typically use npm version to cut a new release, do this instead:
# npm run script
npm run release
# or global bin
4part-versionAs long as your git commit messages are conventional and accurate, you no longer need to specify the semver type - and you get CHANGELOG generation for free! \o/
After you cut a release, you can push the new git tag and npm publish (or npm publish --tag next) when you're ready.
Release as a Pre-Release
Use the flag --prerelease to generate pre-releases:
Suppose the last version of your code is 1.2.3.4, and your code to be committed has patched changes. Run:
# npm run script
npm run release -- --prereleaseThis will tag your version as: 1.2.3.4-0.
If you want to name the pre-release, you specify the name via --prerelease <name>.
For example, suppose your pre-release should contain the alpha prefix:
# npm run script
npm run release -- --prerelease alphaThis will tag the version as: 1.2.3.4-alpha.0
Release as a Target Type Imperatively (npm version-like)
To forgo the automated version bump use --release-as with the argument major, minor or patch.
Suppose the last version of your code is 1.0.0.0, you've only landed fix: commits, but
you would like your next release to be a minor. Simply run the following:
# npm run script
npm run release -- --release-as minor
# Or
npm run release -- --release-as 1.1.0.0You will get version 1.1.0.0 rather than what would be the auto-generated version 1.0.0.1.
NOTE: you can combine
--release-asand--prereleaseto generate a release. This is useful when publishing experimental feature(s).
Prevent Git Hooks
If you use git hooks, like pre-commit, to test your code before committing, you can prevent hooks from being verified during the commit step by passing the --no-verify option:
# npm run script
npm run release -- --no-verify
# or global bin
4part-version --no-verifySigning Commits and Tags
If you have your GPG key set up, add the --sign or -s flag to your 4part-version command.
Lifecycle Scripts
4part-version supports lifecycle scripts. These allow you to execute your
own supplementary commands during the release. The following
hooks are available and execute in the order documented:
prerelease: executed before anything happens. If theprereleasescript returns a non-zero exit code, versioning will be aborted, but it has no other effect on the process.prebump/postbump: executed before and after the version is bumped. If theprebumpscript returns a version #, it will be used rather than the version calculated by4part-version.prechangelog/postchangelog: executes before and after the CHANGELOG is generated.precommit/postcommit: called before and after the commit step.pretag/posttag: called before and after the tagging step.
Simply add the following to your package.json to configure lifecycle scripts:
{
"4part-version": {
"scripts": {
"prebump": "echo 9.9.9.9"
}
}
}As an example to change from using GitHub to track your items to using your projects Jira use a
postchangelog script to replace the url fragment containing 'https://github.com/`myproject`/issues/'
with a link to your Jira - assuming you have already installed replace
{
"4part-version": {
"scripts": {
"postchangelog": "replace 'https://github.com/myproject/issues/' 'https://myjira/browse/' CHANGELOG.md"
}
}
}Skipping Lifecycle Steps
You can skip any of the lifecycle steps (bump, changelog, commit, tag),
by adding the following to your package.json:
{
"4part-version": {
"skip": {
"changelog": true
}
}
}Committing Generated Artifacts in the Release Commit
If you want to commit generated artifacts in the release commit, you can use the --commit-all or -a flag. You will need to stage the artifacts you want to commit, so your release command could look like this:
{
"4part-version": {
"scripts": {
"prerelease": "webpack -p --bail && git add <file(s) to commit>"
}
}
}{
"scripts": {
"release": "4part-version -a"
}
}Dry Run Mode
running 4part-version with the flag --dry-run allows you to see what
commands would be run, without committing to git or updating files.