Skip to content

Latest commit

 

History

History
143 lines (117 loc) · 10.3 KB

reference.md

File metadata and controls

143 lines (117 loc) · 10.3 KB

cargo-release Reference

CLI Arguments

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

Bump level

  • 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, and rc: 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.

Configuration

Sources

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

Config Fields

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

Supported Environment Variables

  • PUBLISH_GRACE_SLEEP: sleep timeout between crates publish when releasing from workspace. This is a workaround to make previous crate discoverable on crates.io.

{Pre,Post}-release Replacements

This field is an array of tables with the following

  • file: the file to search and replace
  • search: regex that matches string you want to replace
  • replace: the replacement string; you can use the any of the placeholders mentioned below.
  • min (default is 1): Minimum occurrences of search.
  • max (optional): Maximum occurrences of search.
  • exactly (optional): Number of occurrences of search.
  • prerelease (default is false): Run the replacement when bumping to a pre-release level.

See release.toml for example.

Placeholders

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 before cargo-release was executed (before any version bump).
  • {{prev_metadata}}: The version's metadata before cargo-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 for post-release-{commit-message,replacements}): The crate version for starting development.
  • {{next_metadata}} (only valid for post-release-{commit-message,replacements}): The crate version's metadata field for starting development.
  • {{crate_name}}: The name of the current crate in Cargo.toml.
  • {{date}}: The current date in %Y-%m-%d format.
  • {{prefix}} (only valid for tag-name / tag-message): The value prepended to the tag name.
  • {{tag_name}} (only valid for tag-message): The name of the git tag.

Hook Environment Variables.

The following environment variables are made available to pre-release-hook:

  • PREV_VERSION: The version before cargo-release was executed (before any version bump).
  • PREV_METADATA: The version's metadata field before cargo-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.