Argument | Format | Description |
---|---|---|
--execute |
bool | Actually perform the release |
--no-confirm |
bool | Release the crate without the user verifying what will happen. |
--isolated |
bool | Do not search for config files |
--config |
string | Load a config file from disk |
<LEVEL> |
string | Bump specified version field. |
--metadata |
string | Populate the metadata field in the version. |
--token |
string | Token to use when running cargo publish |
--verbose |
bool | Show more detailed context, useful for debugging |
release
(default): Remove the pre-release extension; if any (0.1.0-dev.1 -> 0.1.0, 0.1.0 -> 0.1.0).patch
:- If version has a pre-release, then the pre-release extension is removed (0.1.0-dev.1 -> 0.1.0).
- Otherwise, bump the patch field (0.1.0 -> 0.1.1)
minor
: Bump minor version (0.1.0-pre -> 0.2.0)major
: Bump major version (0.1.0-pre -> 1.0.0)alpha
,beta
, andrc
: Add/increment pre-release to your version (1.0.0 -> 1.0.1-rc.1, 1.0.1-dev -> 1.0.1-rc.1, 1.0.1-rc.1 -> 1.0.1-rc.2)- [version]: bump version to given version. The version has to be a valid semver string and greater than current version as in semver spec.
Package configuration is read from the following (in precedence order)
- Command line arguments
- File specified via
--config PATH
$CRATE/Cargo.toml
([package.metadata.release]
table)$CRATE/release.toml
$WORKSPACE/Cargo.toml
([workspace.metadata.release]
table)$WORKSPACE/release.toml
$HOME/.config/cargo-release/release.toml
$HOME/.release.toml
Workspace configuration is read from the following (in precedence order)
- Command line arguments
- File specified via
--config PATH
$WORKSPACE/Cargo.toml
([workspace.metadata.release]
table)$WORKSPACE/release.toml
$HOME/.config/cargo-release/release.toml
$HOME/.release.toml
Field | Argument | Format | Defaults | Description |
---|---|---|---|---|
--prev-tag-name |
string | Last released tag; used for seeing what changed in the current release (default based on tag-name and current version in Cargo.toml ) |
||
allow-branch |
--allow-branch |
list of globs | [*, !HEAD] |
(workspace) Which branches are allowed to be released from |
sign-commit |
--sign-commit |
bool | false |
Use GPG to sign git commits generated by cargo-release. Further information. In 0.14 sign-commit is to control signing for commit only, use sign-tag for tag signing. |
sign-tag |
--sign-tag |
bool | false |
Use GPG to sign git tag generated by cargo-release. |
registry |
--registry |
string | - | Cargo registry name to publish to (default uses Rust's default, which goes to crates.io ) |
release |
--package |
bool | true |
Release this crate (usually disabled for internal crates in a workspace) |
push |
--no-push |
bool | true |
Don't do git push |
push-remote |
--push-remote |
string | origin |
Default git remote to push |
push-options |
- | list of strings | [] |
Flags to send to the server when doing a git push |
shared-version |
- | bool or string | false |
Ensure all crates with shared-version are the same version. May also be a string to create named subsets of shared versions |
consolidate-commits |
- | bool | true |
When releasing a workspace, use a single commit for the pre-release version bump and a single commit for the post-release version bump. Commit settings will be read from the workspace-config. |
pre-release-commit-message |
- | string | "(cargo-release) version {{version}}" |
A commit message template for release. For example: "release {{version}}" , where {{version}} will be replaced by actual version. |
post-release-commit-message |
- | string | "(cargo-release) start next development iteration {{next_version}}" |
A commit message template for bumping version after release. For example: Released {{version}}, starting {{next_version}} . The placeholder {{next_version}} (the version in git after release) is supported in addition to the global placeholders mentioned below. |
tag |
--no-tag |
bool | true |
Don't do git tag |
tag-message |
- | string | "(cargo-release) {{crate_name}} version {{version}}" |
A message template for an annotated tag (set to blank for lightweight tags). The placeholder {{tag_name}} and {{prefix}} (the tag prefix) is supported in addition to the global placeholders mentioned below. |
tag-prefix |
--tag-prefix |
string | depends | Prefix of git tag, note that this will override default prefix based on crate name. |
tag-name |
--tag-name |
string | "{{prefix}}v{{version}}" |
The name of the git tag. The placeholder {{prefix}} (the tag prefix) is supported in addition to the global placeholders mentioned below. |
pre-release-replacements |
- | array of tables (see below) | [] |
Specify files that cargo-release will search and replace with new version for the release commit |
post-release-replacements |
- | array of tables (see below) | [] |
Specify files that cargo-release will search and replace with new version for the post-release commit (the one starting development) |
pre-release-hook |
- | list of arguments | - | Provide a command to run before cargo-release commits version change. If the return code of hook command is greater than 0, the release process will be aborted. |
publish |
--no-publish |
bool | true |
Don't do cargo publish right now, see manifest publish field to permanently disable publish. See release for disabling the complete release process. |
verify |
--no-verify |
bool | true |
Don't verify the contents by building them |
enable-features |
--features |
list of names | [] |
Provide a set of feature flags that should be passed to cargo publish (requires rust 1.33+) |
enable-all-features |
--all-features |
bool | false |
Signal to cargo publish , that all features should be used (requires rust 1.33+) |
target |
- | string | - | Target triple to use for the verification build |
dependent-version |
- | upgrade , fix , error , warn , ignore |
upgrade |
Policy for upgrading path dependency versions within the workspace |
Note: fields are from the package-configuration unless otherwise specified.
Note:
package.publish
is interpreted the same as release = false
PUBLISH_GRACE_SLEEP
: sleep timeout between crates publish when releasing from workspace. This is a workaround to make previous crate discoverable on crates.io.
This field is an array of tables with the following
file
: the file to search and replacesearch
: regex that matches string you want to replacereplace
: the replacement string; you can use the any of the placeholders mentioned below.min
(default is1
): Minimum occurrences ofsearch
.max
(optional): Maximum occurrences ofsearch
.exactly
(optional): Number of occurrences ofsearch
.prerelease
(default isfalse
): Run the replacement when bumping to a pre-release level.
See release.toml for example.
The following fields support placeholders for information about your release:
pre-release-commit-message
post-release-commit-message
tag-message
tag-prefix
tag-name
pre-release-hook
The following placeholders are supported:
{{prev_version}}
: The version beforecargo-release
was executed (before any version bump).{{prev_metadata}}
: The version's metadata beforecargo-release
was executed (before any version bump).{{version}}
: The current (bumped) crate version.{{metadata}}
: The current (bumped) crate version's metadata field.{{next_version}}
(only valid forpost-release-{commit-message,replacements}
): The crate version for starting development.{{next_metadata}}
(only valid forpost-release-{commit-message,replacements}
): The crate version's metadata field for starting development.{{crate_name}}
: The name of the current crate inCargo.toml
.{{date}}
: The current date in%Y-%m-%d
format.{{prefix}}
(only valid fortag-name
/tag-message
): The value prepended to the tag name.{{tag_name}}
(only valid fortag-message
): The name of the git tag.
The following environment variables are made available to pre-release-hook
:
PREV_VERSION
: The version beforecargo-release
was executed (before any version bump).PREV_METADATA
: The version's metadata field beforecargo-release
was executed (before any version bump).NEW_VERSION
: The current (bumped) crate version.NEW_METADATA
: The current (bumped) crate version's metadata field.DRY_RUN
: Whether the release is actually happening (true
/false
)CRATE_NAME
: The name of the crate.WORKSPACE_ROOT
: The path to the workspace.CRATE_ROOT
: The path to the crate.