-
Set the environment variable
TAG
, which should be of the formv{VERSION}
, whereVERSION
is the target version of the release. -
Change version in all subcrate
Cargo.toml
files and in the rootCargo.toml
to the target version. Also change the version of the subcrate dependencies in the rootCargo.toml
. All versions should now match the target version. -
Update the CHANGELOG by creating a new release section header right the
## Unreleased
header. -
Commit and push these changes:
git commit -a -m "(cargo-release) $TAG" && git push
-
Add a tag in git to mark the release:
git tag "$TAG" -m "Adds tag $TAG for release" && git push --tags
-
Find the tag you just pushed on GitHub, click edit, then copy over the output of:
python scripts/generate_release_notes.py
On a Mac, for example, you can just pipe the above command into
pbcopy
. -
Check the box "This is a pre-release" if the release is a release candidate (ending with
-rc*
). Otherwise leave it unchecked. -
Finally, click "Publish Release". GitHub Actions will then build and publish to crates.io.
If for some reason the GitHub Actions release workflow failed with an error that needs to be fixed, you'll have to delete both the tag and corresponding release from GitHub. After you've pushed a fix, delete the tag from your local clone with
git tag -l | xargs git tag -d && git fetch -t
Then repeat the steps above.