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.3.1.tar.gz (103.7 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.3.1-py3-none-any.whl (32.2 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for mdreview-0.3.1.tar.gz
Algorithm Hash digest
SHA256 1cf5d458b28623359fecb6a4d3503015a351c9f4d2ca2f6035df175b4cf265d3
MD5 1ff7a646ae5ae6953825569b76921320
BLAKE2b-256 1ab545bca63ed30db14ce0310263fdb77d331203154e363aaf7b9e00e9db62f3

See more details on using hashes here.

Provenance

The following attestation bundles were made for mdreview-0.3.1.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.3.1-py3-none-any.whl.

File metadata

  • Download URL: mdreview-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 32.2 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.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 77e94c32e61bed009c5c854a3aade44dde67becc2b380dda51c729a5709b8995
MD5 7b20d439f9a76d16dcf942ef5001d23a
BLAKE2b-256 421ad7533b7efad34e785d1c5ec5c2719195f8e9725f765539e564a411fad0fc

See more details on using hashes here.

Provenance

The following attestation bundles were made for mdreview-0.3.1-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