Skip to main content

Terminal UI for reviewing markdown documents with inline comments

Project description

mdreview

Terminal UI for reviewing markdown documents with inline comments. Built with Python and Textual.

Features

  • Inline comments — select line ranges and add comments, stored in sidecar .review.json files
  • Review workflow — approve or request changes on each file, with exit codes for CI integration
  • Diff between rounds — see what changed since your last review decision
  • Mermaid diagrams — ASCII rendering in the terminal, or open in mermaid.live
  • Anchor drift — comments follow content when lines are added, removed, or moved
  • Live reload — files reload automatically when modified externally
  • Multi-file — review multiple files or an entire directory in one session

Installation

# From PyPI
pip install mdreview

# Or with uv
uv tool install mdreview

# Or with pipx
pipx install mdreview

# From source
uv tool install git+https://github.com/lazyoft/mdreview.git

Usage

# Review a single file
mdreview document.md

# Review multiple files
mdreview chapter1.md chapter2.md chapter3.md

# Review all markdown files in a directory
mdreview --dir docs/

Keybindings

Key Action
Up/Down Move cursor between blocks
Left/Right Previous/next file
c Start/confirm line selection for comment
Shift+Up/Down Extend selection
Ctrl+S Submit comment (in modal)
Esc Cancel selection or input
d Delete comment (when popover visible)
D Delete all comments on file
e Edit comment
A Approve file
R Request changes
v Toggle diff view
f Open file selector
m Toggle Mermaid ASCII/raw
o Open Mermaid diagram in browser
? Show help
q Quit

Customizing Keybindings

All keybindings can be customized via a TOML config file. Run:

mdreview --config

This creates ~/.config/mdreview/keys.toml (pre-populated with all defaults) and opens it in your $EDITOR. Edit any key and save — changes take effect next time you launch mdreview.

Example customization:

[keys]
quit = "x"
approve = "a"
cursor_up = "k"
cursor_down = "j"

Exit Codes

Code Meaning
0 All files approved
1 Changes requested on one or more files
2 Incomplete — unreviewed files remain

Development

# Clone and install in dev mode
git clone https://github.com/lazyoft/mdreview.git
cd mdreview
uv venv && uv pip install -e ".[test]"

# Run tests
uv run pytest

# Lint
uv run ruff check src/

See CONTRIBUTING.md for more details.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mdreview-0.2.0.tar.gz (98.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mdreview-0.2.0-py3-none-any.whl (30.1 kB view details)

Uploaded Python 3

File details

Details for the file mdreview-0.2.0.tar.gz.

File metadata

  • Download URL: mdreview-0.2.0.tar.gz
  • Upload date:
  • Size: 98.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mdreview-0.2.0.tar.gz
Algorithm Hash digest
SHA256 eabe00d259108f23723b6e120b205d0e2bd8169f6008649f4a9a23966cc74096
MD5 ced93eb42ff6e0b43221f2be28259b74
BLAKE2b-256 60b3a5ea83e7410488ec34d648e9cbd41be290b08ccdfc758f10dcb925b7f3e8

See more details on using hashes here.

Provenance

The following attestation bundles were made for mdreview-0.2.0.tar.gz:

Publisher: publish.yml on lazyoft/mdreview

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mdreview-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: mdreview-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 30.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mdreview-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d3f0eb9e74c5c4a92ab2254bc20f4e455a0aaec12459389940a7334acc20c6eb
MD5 a3d875783ef7c66f5b25fb2855a17142
BLAKE2b-256 43f8993c76a230a313ecfd02c5c6b73c558bfffb81affe7dab855f2c3333e576

See more details on using hashes here.

Provenance

The following attestation bundles were made for mdreview-0.2.0-py3-none-any.whl:

Publisher: publish.yml on lazyoft/mdreview

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page