Why mdr?
Built for the LLM era. AI tools generate Markdown constantly — code documentation, technical specs, analysis reports — packed with diagrams, tables, and structured content. You need a fast way to read them.
Most developers end up previewing Markdown in VS Code, pasting into a browser, or squinting at raw text in the terminal. None of these handle Mermaid diagrams. None are instant. mdr is.
- One command —
mdr file.mdand you're reading, not editing - Native Rust binary — no Electron, no Node.js, no npm, starts in milliseconds
- Mermaid diagrams — flowcharts, sequence diagrams, pie charts rendered as SVG natively (no headless browser)
- Three backends — full GUI (egui), native webview (WebKit/WebView2), or terminal UI (TUI) over SSH
- Live reload — edit your file or let your AI tool regenerate it, see changes instantly
- In-document search — Ctrl+F /
/to find text across all backends
Backends
mdr offers multiple rendering backends, selectable at runtime:
| Backend | Stack | Strengths |
|---|---|---|
| egui (default) | Pure Rust GPU rendering | Single static binary, fast startup, cross-platform |
| webview | OS native WebView (WebKit/WebView2) | GitHub-quality HTML/CSS rendering, full CSS support |
| tui | Terminal UI (ratatui + crossterm) | Works over SSH, no GUI needed, keyboard-driven |
Install
From source
Build with specific backends only
# egui only (smaller binary, no WebView dependency)
# webview only
Homebrew (macOS/Linux)
Snap (Linux)
Note: The snap command is
mdr-markdown-renderer, notmdr. You can create an alias:sudo snap alias mdr-markdown-renderer mdr
Scoop (Windows)
scoop bucket add clevercloud https://github.com/CleverCloud/scoop-bucket
scoop install mdr
Chocolatey (Windows)
choco install mdr
WinGet (Windows)
winget install CleverCloud.mdr
Nix
Pre-built binaries
Download from the Releases page for macOS, Linux, and Windows.
Usage
# Open with default backend (egui)
# Open with webview backend
# Open in terminal (TUI)
# Show help
TUI keybindings
| Key | Action |
|---|---|
q / Esc |
Quit |
j / ↓ |
Scroll down |
k / ↑ |
Scroll up |
Space / PgDn |
Page down |
PgUp |
Page up |
g / Home |
Go to top |
G / End |
Go to bottom |
Tab |
Switch focus between TOC and content |
Enter |
Navigate to selected TOC heading |
/ or Ctrl+F |
Open search |
n |
Next search match |
N |
Previous search match |
Features
- Full GFM support — tables, task lists, strikethrough, footnotes, autolinks
- Syntax highlighting — code blocks with language detection (via syntect)
- Mermaid diagrams — flowcharts, sequence diagrams, pie charts, and more (via mermaid-rs-renderer)
- Table of Contents — auto-generated sidebar from headings with click-to-navigate
- Live reload — file watching with 300ms debounce, updates on save
- Dark/Light theme — follows OS theme (webview backend)
Mermaid Support
Mermaid code fences are rendered as SVG diagrams:
```mermaid
graph TD
```
Supported diagram types: flowchart, sequence, pie, class, state, ER, gantt.
Note: Diamond/decision nodes (
{text}) are not yet supported by the underlying renderer. Use square brackets as a workaround.
Architecture
src/
├── main.rs # CLI (clap), backend dispatch
├── core/
│ ├── markdown.rs # GFM parsing (comrak) + CSS
│ ├── mermaid.rs # Mermaid → SVG rendering
│ ├── toc.rs # Heading extraction for TOC
│ ├── search.rs # In-document search
│ └── watcher.rs # File watching (notify, 300ms debounce)
└── backend/
├── egui.rs # egui/eframe backend
├── tui.rs # ratatui/crossterm TUI backend
└── webview.rs # wry/tao WebView backend
Building
Requires Rust 1.75+.
# All backends (default)
# Run tests
# Run clippy
Linux dependencies
Releases
Pre-built binaries are available on the Releases page for:
- macOS (Apple Silicon + Intel)
- Linux (x86_64)
- Windows (x86_64)
To create a release, push a version tag:
License
MIT
Contributing
Issues and PRs welcome at github.com/CleverCloud/mdr.