Release Procedure
-
The latest archive from Crowdin should already be in the repository, if not make sure to merge any automated Pull Request from Crowdin (e.g. https://github.com/rizinorg/cutter-translations/pull/9)
Update submodule in cutter
If there is a desire to keep working in the master branch, create branch for the release and do all the following work there.
Lock rzghidra and rzdec versions downloaded by packaging scripts. Specify a tag or commit hash.
Update version
appveyor.yml
docs/sourc/conf.py
docs/source/index.rst
CMakeLists.txt
Cutter.appdata.xml
Create a tag for the release candidate. For example, for the v1.11.0 release you’d do something like this:
Create a GitHub release, mark it as pre-release save draft, set the tag to v1.11.0-rc1
Wait for packages to build
On all operating systems do the to ensure nothing badly broken.
If any major problems are found, open an issue and fix them. If a release branch is used fix them in master and cherry pick into release branch. If the amount of changes is sufficiently large repeat from step 3. increasing rc number by one.
Update version to 1.11.0
Create tag
Create release * Fill the release notes in the Release description. Preparing release notes can begin earlier. Compare current master or release branch against previous release to find all the changes. Choose the most important ones. Don’t duplicate the commit log. Release notes should be a summary for people who don’t want to read whole commit log. Group related changes together under titles such as “New features”, “Bug Fixes”, “Decompiler”, “Rizin” and similar.
Prepare announcement tweets and messages to send in the Telegram group, reddit, and others.
Close milestone if there was one
The process for bugfix release is similar no normal release procedure described above with some differences.
Create the branch from the last tag instead of master or reuse the branch from x.y.0 release if it was already created.
Increase the third version number x.y.n into x.y.(n+1) .
Basic testing procedure
Open a simple executable like or
Make sure that the upgraded layout isn’t completely broken
The Disassembly widget shows proper disassembly.
Bundled plugins work
Open decompiler and select ghidra, it shows some C code at least for some functions
Open rzdec in decompiler widget, make sure it shows code
Test that sample python plugin works
Try debugger
Insert breakpoint in main
Start debugging
Go to main using function widget, make sure relocation was done correctly and you see code instead of unmapped memory and breakpoint is where you placed
Click continue until you hit breakpoint in main