This plugin reads and/or writes version/manifest files.
npm install --save-dev @release-it/bumper
In release-it config:
"plugins": {
"@release-it/bumper": {
"in": "composer.json",
"out": "composer.json",
}
}
- Use only the
in
option to read the version from this file in the release-it process. - Use only the
out
option to write the version that was determined by release-it to this file. - Use both to read and write the
version
property from/to this file.
The version
from the in
file will take precedence over the latest Git tag (and the version
from package.json
if
it exists) in release-it to determine the latest version.
Note that using package.json
as out
file may conflict with the npm plugin in release-it. Remove it from the out
file(s), or use
--npm.allowSameVersion
.
The supported file types are:
Type | Extension(s) | Mime-type |
---|---|---|
JSON | .json |
application/json |
YAML | .yaml or .yml |
text/yaml or application-x-yaml or application/yaml |
TOML | .toml |
text/toml or application/toml |
INI | .ini |
text/x-properties |
XML | .xml |
text/xml or application/xml |
HTML | .html |
text/html or application/xhtml+xml |
TEXT | .txt |
text/* |
Explicitly providing the (mime) type
takes precedence over the file extension.
The fallback type is text
if the file extension and/or type
is not known (e.g. index.php
).
"plugins": {
"@release-it/bumper": {
"in": {
"file": "VERSION",
"type": "text/plain"
},
"out": {
"file": "VERSION",
"type": "text/plain"
}
}
}
To replace all occurences of the current version with the new version in any text file:
"plugins": {
"@release-it/bumper": {
"out": {
"file": "file.php",
"type": "text/php"
}
}
}
To instead always consume the entire file, that is, the whole and only content of the file is the version number, set consumeWholeFile: true
for the out
option:
"plugins": {
"@release-it/bumper": {
"out": {
"file": "VERSION",
"type": "text/plain",
"consumeWholeFile": true
}
}
}
The version number is then written to the output file, overwriting it completely instead of a search-and-replace.
💡 Setting consumeWholeFile: true
precludes the use of prefixes, such as v1.0.1
in the output file.
The out
option can also be an array of files:
"plugins": {
"@release-it/bumper": {
"out": ["manifest.json", "bower.json"]
}
}
The out
option is parsed with fast-glob, so glob patterns can be used to match
files to write to:
"plugins": {
"@release-it/bumper": {
"out": "dist/*.json"
}
}
The path
option (default: "version"
) can be used to change a different property. The following example will set the
current.version
property to the new version in manifest.json
:
"plugins": {
"@release-it/bumper": {
"out": {
"file": "manifest.json",
"path": "current.version"
}
}
}
For the
xml
type, thepath
option must be in the form of a unique css selector. The following example will set theproject > version
property to the new version inpom.xml
:
"plugins": {
"@release-it/bumper": {
"out": {
"file": "pom.xml",
"path": "project > version",
"type": "application/xml"
}
}
}
For the
html
type, thepath
option must be in the form of a unique css selector. The following example will set the element text content with the css attribute#version
to the new version infoo.html
:
"plugins": {
"@release-it/bumper": {
"out": {
"file": "foo.html",
"path": "#version",
"type": "text/html"
}
}
}
Multiple paths can be provided using an array.
The versionPrefix
option (default: ''
) can be used in cases where you'd like to maintain a specific prefix for your version number (for example, in package.json
where you might want versions like ^1.0.0
). This will prepend the specified prefix to the bumped version:
"plugins": {
"@release-it/bumper": {
"out": {
"file": "package.json",
"path": "version",
"prefix": "^"
}
}
}
With the above configuration, if release-it determines the new version to be 1.0.0
, it'll be saved as ^1.0.0
in the targeted file.
Options for this plugin can be set from the command line. Some examples:
release-it --plugins.@release-it/bumper.in=composer.json
release-it --plugins.@release-it/bumper.out=composer.json --plugins.@release-it/bumper.out=manifest.json
- Keys are separated by dots.
- Values can be negated by prefixing the key with
no-
. - Arguments may need to be single-quoted (
'
) such as--'deep.key=value'
or'--deep.key=value'
Depending on your shell or OS this may differ.