tuicr
A code review TUI with vim keybindings. Export to GitHub or clipboard.

[!TIP] Pronounced "tweaker".
What it does
- GitHub-style continuous diff in the terminal. Scroll through every changed file in one stream.
- PR-style comments at the line, range, file, and review level, with classifications like
issue,suggestion,note, andpraise. - Three export targets: push a real PR review to GitHub, copy structured markdown to your clipboard, or pipe to stdout.
- Works with git, jj, and mercurial. Reviews uncommitted changes, commit ranges, or any GitHub PR.
Install
|
# or
# Cargo
# Mise
# Nix
Pre-built binaries: GitHub Releases
From source:
Quick start
Inside tuicr, navigate with j/k, press c to comment, then y to copy the review or
:submit to push it to GitHub. Auto-detects git, jj, or mercurial.
How it compares
| tuicr | hunk | lumen | gh pr review |
git diff |
|
|---|---|---|---|---|---|
| TUI diff viewer | ✅ | ✅ | ✅ | ❌ | ❌ |
| Write comments in the TUI | ✅ | agent-only¹ | ✅ | ❌ | ❌ |
| Vim keybindings | ✅ | ❌ | partial² | ❌ | ❌ |
| Push inline review to GitHub | ✅ | ❌ | ❌ | partial³ | ❌ |
| Agent-ready markdown export | ✅ | via CLI skill | ❌ | ❌ | ❌ |
| git | ✅ | ✅ | ✅ | ❌ | ✅ |
| jj | ✅ | ✅ | ✅ | ❌ | ❌ |
| Mercurial (hg) | ✅ | ❌ | ❌ | ❌ | ❌ |
| Single static binary | ✅ | (needs Node) | ✅ | ✅ | ✅ |
¹ Hunk has a hunk session comment add CLI for agents to inject notes into a live TUI session.
No in-TUI commenting keybinding.
² Lumen has j/k navigation but no broader vim model (visual mode, {N}G, Ctrl-d/Ctrl-u,
etc.).
³ gh pr review posts approve/comment/request-changes at the review level only. No inline line
comments.
Export your review
When you're done reviewing, send your comments wherever the work continues.
To GitHub
:submit opens a picker for Comment, Approve, Request changes, or Draft. Inline comments land
on the right lines as a real PR review; review-level comments become the review summary.
Requires gh authenticated to the repo.
To your coding agent
y or :clip copies a structured markdown block to your clipboard. Each comment has a number,
a classification, and a file/line anchor:
I reviewed your code and have the following comments. Please address them.
Comment types: ISSUE (problems to fix), SUGGESTION (improvements), NOTE (observations), PRAISE (positive feedback)
1. 2.3.
Paste it back to any coding agent (Claude, Codex, Cursor, etc).
For an agent-driven workflow where your agent opens tuicr in a tmux split pane, see skills/tuicr/SKILL.md.
To stdout
Run with --stdout to pipe the markdown to another process:
|
Configuration
Path: ~/.config/tuicr/config.toml on Linux/macOS, %APPDATA%\tuicr\config.toml on Windows.
= "catppuccin-mocha"
= "side-by-side" # or "unified"
= "system" # or "dark" / "light"
= true
= ";" # configurable prefix for leader shortcuts
[[]]
= "issue"
= "red"
= "must fix before merge"
Themes: dark, light, ayu-light, ayu-mirage, onedark, github-light, github-dark,
catppuccin-latte, catppuccin-frappe, catppuccin-macchiato, catppuccin-mocha,
everforest-dark, everforest-light, gruvbox-dark, gruvbox-light, nord-dark,
nord-light, nord-dark-high-contrast, nord-light-high-contrast, solarized-light,
solarized-dark, tokyo-night-storm.
Full options, theme resolution precedence, comment_types semantics, and .tuicrignore rules in
docs/CONFIG.md.
Keybindings
A first-session cheatsheet. Press ? inside tuicr for the full reference.
| Key | Action |
|---|---|
j / k |
Down / up |
Ctrl-d / Ctrl-u |
Half-page down / up |
g / G |
Top / bottom |
{ / } |
Previous / next file |
[ / ] |
Previous / next hunk |
/ |
Search |
c / C |
Add line / file comment |
v / V |
Visual mode (range comment) |
r |
Toggle file reviewed |
y |
Copy review to clipboard |
:submit |
Push review to GitHub |
? |
Toggle full help |
Full reference in docs/KEYBINDINGS.md.
Sponsors
Thanks to the folks below for keeping tuicr development going, it means a lot to have the work I'm doing here appreciated!
License
MIT licensed. Contribution notes in CONTRIBUTING.md.