#github #io #version #history #entries #fill #changelog

bin+lib retrospective-crate-version-tagging

Fill in GitHub release history from existing changlog entries and crates.io versions

2 releases

0.1.1 Oct 17, 2024
0.1.0 Oct 17, 2024

#1292 in Development tools

MIT/Apache

28KB
237 lines

Retrospective Crate Version Tagging

Workflows like like release-please can manage the entire release cycle for you, but they only work if you manage everything from there. If you have a more conmplex release scheme (e.g. - multiple released crates in one repository) or if you didn't use release-please from the beginning and want to generate the release history, these workflows can't help you. You need something a bit more manual.

retrospective-crate-version-tagging is a CLI tool for generating GitHub releases for Rust projects based on the already existing release information:

retrospective-crate-version-tagging takes the release notes from the changelog and the commit hash from crates.io, and combines them to create GitHub releases.

Requirements

  • The GitHub CLI (gh) must be installed and in the PATH.
  • The authentication token used by the GitHub CLI must have the workflow scope.
    • To verify it has that scope, run gh auth status and look for 'workflow' in the Token scopes list.
    • If it's not there, run gh auth refresh --scopes workflow and follow the instructions.

Installing

Install from crates.io using:

$ cargo install retrospective-crate-version-tagging

Usage

retrospective-crate-version-tagging has two commands:

  • retrospective-crate-version-tagging detect - read the changelog and query crates.io to generate a YAML with information required to create the releases.
  • retrospective-crate-version-tagging create-releases - receive (via STDIN) the YAML created by the first command and use gh to create GitHub releases from it.

The output of the first command can be redirected directly into the second command, or it can be stored in a file that can manually be inspected and edited before creating the versions.

License

Licensed under either of

at your option.

Contribution

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.

Dependencies

~30–45MB
~735K SLoC