Open-source DeepWiki alternative — generate comprehensive wiki documentation for any codebase from your terminal or browser.
| DeepWiki | deepwiki-open | RepoWiki | |
|---|---|---|---|
| Deploy | SaaS only | Docker Compose | pip install repowiki |
| Local repos | No | No | Yes |
| CLI | No | No | Yes |
| Web UI | Yes | Yes | Yes |
| Export | Web only | Web only | Markdown / JSON / HTML |
| Reading guide | No | No | PageRank + guided path |
| Terminal Q&A | No | No | repowiki chat |
| Dependencies | N/A | Docker + PostgreSQL | Python + SQLite |
pip install repowiki
# set your API key (DeepSeek, OpenAI, Anthropic, etc.)
export DEEPSEEK_API_KEY=sk-xxx
# or
repowiki config set api_key sk-xxx
# scan a local project
repowiki scan ./my-project
# scan a GitHub repo
repowiki scan https://github.com/pallets/flask
# generate self-contained HTML
repowiki scan ./my-project --format html --open
# start the web interface
pip install repowiki[web]
repowiki serveAutomatically generates structured documentation for any codebase:
- Project overview — what it does, tech stack, setup instructions
- Module documentation — purpose, key files, relationships, important functions
- Architecture diagrams — auto-detected architecture type with Mermaid visualizations
- Reading guide — "start here" path based on PageRank file importance ranking
- Markdown — directory of
.mdfiles, ready to commit to your repo - JSON — structured data for API consumption or custom rendering
- HTML — self-contained single file, share with anyone (Mermaid diagrams included)
Three-column wiki viewer with sidebar navigation, Mermaid diagram rendering, and an AI-powered Q&A chat about the codebase.
Everything works from the terminal. No Docker, no database server, no web browser required.
repowiki scan . # generate wiki
repowiki scan . -f html --open # open in browser
repowiki scan . -l zh # Chinese output
repowiki chat . # ask questions (coming soon)
repowiki config list # show configurationPython, JavaScript, TypeScript, Go, Rust, Java, Kotlin, C/C++, C#, Ruby, PHP, Swift, Dart, Vue, Svelte, and 30+ more.
Powered by litellm, RepoWiki works with 100+ LLM providers:
| Provider | Model | Alias |
|---|---|---|
| Anthropic | Claude Opus 4.6 | opus |
| Anthropic | Claude Sonnet 4.6 | claude |
| OpenAI | GPT-5.4 | gpt |
| OpenAI | GPT-5.4 Mini | gpt-mini |
| Gemini 3.1 Pro | gemini |
|
| Gemini 2.5 Flash | gemini-flash |
|
| DeepSeek | DeepSeek V3.2 | deepseek |
| Alibaba | Qwen3.5 Plus | qwen |
| Moonshot | Kimi K2.6 | kimi |
| Zhipu | GLM-5 | glm |
| MiniMax | M2.7 | minimax |
repowiki config set model deepseek # use alias
repowiki scan . -m gpt # or pass directlyRepoWiki looks for config in this order:
- CLI flags (
-m,-l,-o) - Environment variables (
REPOWIKI_MODEL,REPOWIKI_API_KEY) - Config file (
~/.repowiki/config.json) - Provider-specific env vars (
DEEPSEEK_API_KEY,OPENAI_API_KEY,ANTHROPIC_API_KEY)
RepoWiki/
├── src/repowiki/
│ ├── cli.py # Click CLI with scan/serve/chat/config commands
│ ├── config.py # Configuration management
│ ├── core/
│ │ ├── scanner.py # File scanning with language detection
│ │ ├── analyzer.py # Multi-step LLM analysis pipeline
│ │ ├── graph.py # Dependency graph + PageRank
│ │ ├── wiki_builder.py # Wiki page assembly
│ │ ├── rag.py # TF-IDF retrieval for Q&A
│ │ └── cache.py # SQLite caching
│ ├── llm/
│ │ ├── client.py # litellm async wrapper
│ │ └── prompts.py # Structured prompt templates
│ ├── ingest/
│ │ ├── local.py # Local directory ingestion
│ │ └── github.py # Git clone with caching
│ ├── export/
│ │ ├── markdown.py # Markdown directory export
│ │ ├── json_export.py # JSON export
│ │ └── html.py # Self-contained HTML export
│ └── server/ # FastAPI web backend
├── frontend/ # React + Vite + TailwindCSS
├── pyproject.toml
└── LICENSE
- Scan — Walk the directory tree, filter out binaries and generated files, detect languages and entry points
- Graph — Parse import statements across 6 languages, build a dependency graph, run PageRank to rank file importance
- Analyze — Send file tree + key files to LLM in 4 structured passes (overview, modules, architecture, reading guide)
- Cache — Store results in SQLite keyed by content hash, skip unchanged files on re-scan
- Export — Assemble wiki pages with Mermaid diagrams and source links, output in chosen format
git clone https://github.com/he-yufeng/RepoWiki.git
cd RepoWiki
# backend
python -m venv .venv && source .venv/bin/activate
pip install -e ".[dev,web]"
# frontend
cd frontend && npm install && npm run dev
# run backend
repowiki serve --port 8000MIT