This a script standardize release process of cargo project for you.
Basically it runs following tasks:
cargo publish
git push
cargo install cargo-release
cargo release
Use -l [level]
or --level [level]
to specify a release level.
patch
and current version is a prerelease, it behaves
like default; if current version has no extension, it bumps patch
version (0.1.0 -> 0.1.1)minor
, it bumps minor version (0.1.0-pre -> 0.2.0)major
, it bumps major version (0.1.0-pre -> 1.0.0)Use --sign
option to GPG sign your release commits and
tags. Further
information
By using --upload-doc
option, cargo-release will generate rustdoc
during release process, and commit the doc directory to gh-pages
branch. So you can access your rust doc at
https://YOUR-GITHUB-USERNAME.github.io/YOUR-REPOSITORY-NAME/YOUR-CRATE-NAME
If your hosting service uses different branch for pages, you can use
--doc-branch
to customize the branch we push docs to.
This option will override your existed doc branch, use it at your own risk.
For single-crate repository, we will use version number as git tag name.
For multi-crate repository, the subdirectory name will be used as tag
name. For example, when releasing serde_macros 0.7.0 in serde-rs/serde
repo, a tag named as serde_macros-0.7.0
will be created.
You can always override this behavior by using --tag-prefix <prefix>
option.
In case your origin
is not writable, you can specify custom remote
by --push-remote
to set the remote to push.
Use --skip-push
if you do not plan to push to anywhere for now.
Licensed under either of
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.