2020-05-08 23:05:33 -04:00
|
|
|
Release Checklist
|
|
|
|
-----------------
|
2021-06-12 07:59:47 -04:00
|
|
|
* Ensure local `master` is up to date with respect to `origin/master`.
|
2020-05-08 23:05:33 -04:00
|
|
|
* Run `cargo update` and review dependency updates. Commit updated
|
|
|
|
`Cargo.lock`.
|
2020-05-09 10:26:00 -04:00
|
|
|
* Run `cargo outdated` and review semver incompatible updates. Unless there is
|
2021-06-12 07:54:51 -04:00
|
|
|
a strong motivation otherwise, review and update every dependency. Also
|
|
|
|
run `--aggressive`, but don't update to crates that are still in beta.
|
2020-05-08 23:05:33 -04:00
|
|
|
* Review changes for every crate in `crates` since the last ripgrep release.
|
2020-05-09 10:59:22 -04:00
|
|
|
If the set of changes is non-empty, issue a new release for that crate. Check
|
|
|
|
crates in the following order. After updating a crate, ensure minimal
|
|
|
|
versions are updated as appropriate in dependents. If an update is required,
|
|
|
|
run `cargo-up --no-push crates/{CRATE}/Cargo.toml`.
|
|
|
|
* crates/globset
|
|
|
|
* crates/ignore
|
|
|
|
* crates/cli
|
|
|
|
* crates/matcher
|
|
|
|
* crates/regex
|
|
|
|
* crates/pcre2
|
|
|
|
* crates/searcher
|
|
|
|
* crates/printer
|
|
|
|
* crates/grep (bump minimal versions as necessary)
|
|
|
|
* crates/core (do **not** bump version, but update dependencies as needed)
|
2020-05-29 09:21:19 -04:00
|
|
|
* Update the CHANGELOG as appropriate.
|
2020-05-08 23:05:33 -04:00
|
|
|
* Edit the `Cargo.toml` to set the new ripgrep version. Run
|
|
|
|
`cargo update -p ripgrep` so that the `Cargo.lock` is updated. Commit the
|
2020-05-09 11:43:37 -04:00
|
|
|
changes and create a new signed tag. Alternatively, use
|
|
|
|
`cargo-up --no-push --no-release Cargo.toml {VERSION}` to automate this.
|
2021-06-12 08:40:48 -04:00
|
|
|
* Push changes to GitHub, NOT including the tag. (But do not publish new
|
|
|
|
version of ripgrep to crates.io yet.)
|
|
|
|
* Once CI for `master` finishes successfully, push the version tag. (Trying to
|
|
|
|
do this in one step seems to result in GitHub Actions not seeing the tag
|
|
|
|
push and thus not running the release workflow.)
|
2020-05-08 23:05:33 -04:00
|
|
|
* Wait for CI to finish creating the release. If the release build fails, then
|
|
|
|
delete the tag from GitHub, make fixes, re-tag, delete the release and push.
|
|
|
|
* Copy the relevant section of the CHANGELOG to the tagged release notes.
|
2020-05-09 11:43:37 -04:00
|
|
|
Include this blurb describing what ripgrep is:
|
|
|
|
> In case you haven't heard of it before, ripgrep is a line-oriented search
|
2021-05-30 03:03:40 -04:00
|
|
|
> tool that recursively searches the current directory for a regex pattern.
|
|
|
|
> By default, ripgrep will respect gitignore rules and automatically skip
|
|
|
|
> hidden files/directories and binary files.
|
2020-05-08 23:05:33 -04:00
|
|
|
* Run `ci/build-deb` locally and manually upload the deb package to the
|
|
|
|
release.
|
|
|
|
* Run `cargo publish`.
|
2020-05-09 11:43:37 -04:00
|
|
|
* Run `ci/sha256-releases {VERSION} >> pkg/brew/ripgrep-bin.rb`. Then edit
|
|
|
|
`pkg/brew/ripgrep-bin.rb` to update the version number and sha256 hashes.
|
2020-05-08 23:05:33 -04:00
|
|
|
Remove extraneous stuff added by `ci/sha256-releases`. Commit changes.
|
2020-05-29 09:49:45 -04:00
|
|
|
* Add TBD section to the top of the CHANGELOG:
|
|
|
|
```
|
|
|
|
TBD
|
|
|
|
===
|
|
|
|
Unreleased changes. Release notes have not yet been written.
|
|
|
|
```
|
2020-05-09 11:43:37 -04:00
|
|
|
|
|
|
|
Note that
|
|
|
|
[`cargo-up` can be found in BurntSushi's dotfiles](https://github.com/BurntSushi/dotfiles/blob/master/bin/cargo-up).
|