Release Procedure

      1. 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)

      2. Update submodule in cutter

    1. If there is a desire to keep working in the master branch, create branch for the release and do all the following work there.

    2. Lock rzghidra and rzdec versions downloaded by packaging scripts. Specify a tag or commit hash.

    3. Update version

      1. appveyor.yml

      2. docs/sourc/conf.py

      3. docs/source/index.rst

      4. CMakeLists.txt

      5. Cutter.appdata.xml

    4. Create a tag for the release candidate. For example, for the v1.11.0 release you’d do something like this:

    5. Create a GitHub release, mark it as pre-release save draft, set the tag to v1.11.0-rc1

    6. Wait for packages to build

    7. On all operating systems do the to ensure nothing badly broken.

    8. 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.

    9. Update version to 1.11.0

    10. Create tag

    11. 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.

    12. Prepare announcement tweets and messages to send in the Telegram group, reddit, and others.

    13. 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