2026-06-14 14:31:57 +02:00
---
include_toc: true
gitea: none
---
<h1 align="center">jj-cz: Conventional Commits for Jujutsu</h1>
<div align="center">
<strong>
An interactive CLI tool that guides Jujutsu users through creating <a href="https://www.conventionalcommits.org/" rel="noopener">conventional commit</a> messages.
</strong>
</div>
<br/>
<div align="center">
<!-- CI -->
<a href="https://labs.phundrak.com/phundrak/jj-cz/actions?workflow=action.yml&branch=develop">
<img src="https://labs.phundrak.com/phundrak/jj-cz/actions/workflows/action.yml/badge.svg?branch=develop" alt="actions status" />
</a>
<!-- Crates.io -->
<a href="https://crates.io/crates/sqlx">
<img src="https://img.shields.io/crates/v/jj-cz.svg" alt="Crates.io version"/>
</a>
<!-- License -->
<a href="#license ">
<img src="https://img.shields.io/badge/License-MIT-blue" alt="MIT License" />
</a>
<a href="#license ">
<img src="https://img.shields.io/badge/License-GPL--3.0--or--later-blue" alt="GPL License" />
</a>
<!-- Tools -->
<a href="https://www.gnu.org/software/emacs/" target="_blank">
<img src="https://img.shields.io/badge/Made%20with-GNU%2FEmacs-blueviolet.svg?logo=GNU%20Emacs&logoColor=white" alt="Made with GNU/Emacs" />
</a>
</div>
[](assets/demo.cast)
2026-03-23 13:36:45 +01:00
## Features
2026-06-14 14:31:57 +02:00
- Interactive prompts for type, scope, breaking changes, and description
2026-03-23 13:36:45 +01:00
- All 11 commit types with descriptions (feat, fix, docs, style,
refactor, perf, test, build, ci, chore, revert)
- Optional scope with validation
- 72-character first-line limit enforcement
- Preview before applying
- Clean cancellation with Ctrl+C
## Usage
No fancy tricks, just run `jj-cz` .
``` sh
jj-cz
```
The tool detects whether you're in a Jujutsu repository, guides you
through the commit message, and applies it to your current change.
2026-04-05 23:02:14 +02:00
You can also set the revision message of a few revisions at once, or
target a single revision other than the current one.
``` sh
2026-06-14 14:31:57 +02:00
jj-cz @- xs develop # assuming the revision xs and the bookmark develop exist
2026-04-05 23:02:14 +02:00
```
No explicit revision is simply the equivalent of `jj-cz @` , like
`jj desc` .
2026-06-14 14:31:57 +02:00
If you want to create a new revision after calling `jj-cz` on a single
revision, you can use the `-n` or `--new` flag.
``` sh
jj-cz -n # equivalent of `jj-cz && jj new`
jj-cz xs -n # equivalent of `jj-cz xs && jj new xs`
jj-cz -n xs # equivalent of `jj-cz xs && jj new xs`
```
You cannot, however, call `jj-cz` on multiple revisions with the `--new` flag active.
2026-03-23 13:36:45 +01:00
## Requirements
- A Jujutsu repository
- An interactive terminal
You don’ t need `jj` itself to be installed at all, though I’ m not sure
what `jj-cz` alone would be good for without `jj` .
## Exit Codes
| Code | Meaning |
|------|------------------------------------------------------|
| 0 | Success or clean cancellation |
| 1 | Error (invalid input, repository issues, jj failure) |
| 130 | Interrupted |
## Installation
2026-04-05 23:02:14 +02:00
### From crates.io
Simply run the following command:
```
cargo install jj-cz
```
Done! `jj-cz` is now available!
### With Nix Flakes
Notice how there’ s a `flake.nix` file? This means you can run the
project using this repository as one of your flakes inputs. In fact,
that’ s how I install it in my own NixOS configuration! Add this
repository to your configuration:
``` nix
{
inputs = {
nixpkgs . url = " g i t h u b : n i x o s / n i x p k g s ? r e f = n i x o s - u n s t a b l e " ;
jj-cz = {
url = " g i t + h t t p s : / / l a b s . p h u n d r a k . c o m / p h u n d r a k / j j - c z " ;
inputs . nixpkgs . follows = " n i x p k g s " ;
} ;
} ;
}
```
And tadah! you can now install
`inputs.jj-cz.packages.${pkgs.stdenv.hostPlatform.system}.default`
among your other packages. Take a look at my
[`jujutsu.nix` ](https://labs.phundrak.com/phundrak/nix-config/src/branch/main/users/modules/dev/vcs/jujutsu.nix )
module if you need some inspiration.
### From source
2026-03-23 13:36:45 +01:00
2026-04-05 23:02:14 +02:00
You can also install `jj-cz` with Cargo by building it from source.
Just make sure Rust is available on your machine (duh!).
2026-03-23 13:36:45 +01:00
``` sh
cargo install --path .
```
2026-06-14 14:31:57 +02:00
## Tips and questions
### Running `jj cz` instead of `jj-cz`
I do not actually use `jj-cz` , but `jj cz` . I just find it more
natural to treat it as its own jj subcommand. To achieve that, you can
simply add an alias to your jujutsu configuration.
``` toml
[ aliases ]
cz = [ "utils" , "exec" , "--" , "jj-cz" ]
```
### `$EDITOR` and editing the revision’ s body message
`jj-cz` relies on your `$EDITOR` variable to open a temporary file in
which you’ ll write the body of your commit. This body does not include
some footers `jj-cz` may include by itself, such as the breaking
change footer.
In some cases, you may not notice a new editor open. In this case,
check whether you already have an editor open, the file might be
there. In my case, if I already have an open Emacsclient, it will open
there.
## License
This project is licensed under either the [MIT ](LICENSE.MIT.md ) or [GPL-3.0 ](LICENSE.GPL.md ) licenses, as you prefer.