## Checklist Helix releases are versioned in the Calendar Versioning scheme: `YY.0M(.MICRO)`, for example, `22.05` for May of 2022, or in a patch release, `22.05.1`. In these instructions we'll use `` as a placeholder for the tag being published. * Merge the PR with the release updates. That branch should: * Update the version: * Update the `workspace.package.version` key in `Cargo.toml`. Cargo only accepts SemVer versions so a CalVer version of `22.07` for example must be formatted as `22.7.0`. Patch/bugfix releases should increment the SemVer patch number. A patch release for 22.07 would be `22.7.1`. * Run `cargo check` and commit the resulting change to `Cargo.lock` * Add changelog notes to `CHANGELOG.md` * Add new `` entry in `contrib/Helix.appdata.xml` with release information according to the [AppStream spec](https://www.freedesktop.org/software/appstream/docs/sect-Metadata-Releases.html) * Tag and push * Switch to master and pull * `git tag -s -m "" -a && git push origin ` (note the `-s` which signs the tag) * Wait for the Release CI to finish * It will automatically turn the git tag into a GitHub release when it uploads artifacts * Edit the new release * Use `` as the title * Link to the changelog and release notes * Merge the release notes PR * Download the macos and linux binaries and update the `sha256`s in the [homebrew formula] * Use `sha256sum` on the downloaded `.tar.xz` files to determine the hash * Link to the release notes in this-week-in-rust * [Example PR](https://github.com/rust-lang/this-week-in-rust/pull/3300) * Post to reddit * [Example post](https://www.reddit.com/r/rust/comments/uzp5ze/helix_editor_2205_released/) [homebrew formula]: https://github.com/Homebrew/homebrew-core/blob/master/Formula/h/helix.rb ## Changelog Curation The changelog is currently created manually by reading through commits in the log since the last release. GitHub's compare view is a nice way to approach this. For example, when creating the 22.07 release notes, this compare link may be used ``` https://github.com/helix-editor/helix/compare/22.05...master ``` Either side of the triple-dot may be replaced with an exact revision, so if you wish to incrementally compile the changelog, you can tackle a weeks worth or so, record the revision where you stopped, and use that as a starting point next week: ``` https://github.com/helix-editor/helix/compare/7706a4a0d8b67b943c31d0c5f7b00d357b5d838d...master ``` A work-in-progress commit for a changelog might look like [this example](https://github.com/helix-editor/helix/commit/831adfd4c709ca16b248799bfef19698d5175e55). Not every PR or commit needs a blurb in the changelog. Each release section tends to have a blurb that links to a GitHub comparison between release versions for convenience: > As usual, the following is a summary of each of the changes since the last > release. For the full log, check out the git log. Typically, small changes like dependencies or documentation updates, refactors, or meta changes like GitHub Actions work are left out.