Local lightweight repo-to-wiki generator inspired by zread.
Project description
yread
Turn a local source repository into an architecture-first Markdown wiki.
yread is a lightweight, installable Python CLI — turn a local repository into an architecture-first Markdown wiki, powered by LLMs. Inspired by zread.
Why
Zread popularized the idea of generating a developer guide from a GitHub repository. yread keeps the same core idea, but narrows the scope:
- Local repositories only
- Direct OpenAI-compatible provider calls
- A small, readable Python implementation
- Markdown output focused on human architectural understanding
This is not a hosted wiki platform. It is a local project-understanding tool.
How It Works
yread runs two LLM-driven phases:
Phase 1: Catalog Agent
Inspect the repository
Build a lightweight project profile
Plan architecture-first topics with evidence paths
Phase 2: Page Agents
Start one fresh conversation per topic
Inspect evidence files
Write human-oriented architecture and maintenance guidance
Agents only receive three read-only tools:
| Tool | Purpose |
|---|---|
get_dir_structure |
Show a filtered directory tree |
view_file_in_detail |
Read source files by line range |
run_bash |
Run conservative read-only commands; disable with ENABLE_SHELL=0 |
Install and Run
Install from PyPI:
uv tool install yread # or: pipx install yread, pip install yread
generate defaults to the current directory:
cd /path/to/repo
yread generate # or: yread generate /path/to/repo
From a checkout, run without installing:
uv run yread generate /path/to/repo
Output defaults to:
<repo>/.yread/
├── wiki/
│ └── <slug>.md
├── wiki.json
├── manifest.json
└── SUMMARY.md
Provider Configuration
yread can use minimax-cn, deepseek, or any OpenAI Chat Completions compatible endpoint.
For a generic OpenAI-compatible provider:
cp .env.yread.example .env.yread
$EDITOR .env.yread
uv run yread generate /path/to/repo --env-file .env.yread
All tunables (provider, model, language, depth, concurrency, output) live in config rather than on the generate command, keeping the command surface lean.
Persistent config lives at:
~/.yread/config.env
Set it up interactively:
yread config init
Or manage individual keys:
yread config path
yread config set PROVIDER openai-compatible
yread config set BASE_URL https://api.example.com/v1
yread config set API_KEY sk-...
yread config set MODEL your-model
yread config set DOC_LANG en
yread config set DOC_DEPTH standard
yread config show
Config precedence is:
process environment > --env-file > ~/.yread/config.env > defaults
| Key | Default | Description |
|---|---|---|
PROVIDER |
minimax-cn |
minimax-cn, deepseek, or openai-compatible |
BASE_URL |
auto-resolved | OpenAI-compatible /v1 endpoint |
API_KEY |
auto-resolved | Provider API key |
MODEL |
provider default | Model name |
DOC_LANG |
en |
Documentation language code, e.g. zh, en |
DOC_DEPTH |
auto |
auto, brief, standard, or deep; controls topic budget and page breadth |
MAX_STEPS |
24 |
Max tool-call rounds per agent |
MAX_TOPICS |
30 |
Catalog topic cap |
CONCURRENCY |
1 |
Parallel page agents |
ENABLE_SHELL |
1 |
Expose run_bash to agents |
OUTPUT_DIR |
<repo>/.yread |
Default export directory |
For minimax-cn and deepseek, missing credentials are resolved from ~/.pi/agent/models.json and ~/.pi/agent/auth.json when available.
Export to Obsidian
Set OUTPUT_DIR to a directory inside your vault:
yread config set OUTPUT_DIR "/path/to/Obsidian Vault/Code Wikis/yread"
yread generate /path/to/repo
Overwrite and Resume
A plain yread generate rebuilds the catalog and overwrites the current output
under .yread/. Markdown pages live in .yread/wiki/; wiki.json,
manifest.json, and SUMMARY.md live directly under .yread/.
If a previous run was interrupted or left failed pages, explicitly resume the current output, regenerating only missing, failed, or source-affected pages:
yread generate /path/to/repo --resume
Resume and browse require the current v2 wiki schema.
Regenerate one page by slug, title, or Markdown filename:
yread generate /path/to/repo --page 1-overview
Disable shell access for agents (config-only):
yread config set ENABLE_SHELL 0
Browse Locally
The source repository is recorded in wiki.json at generation time, so source
citations resolve automatically — from inside the repo, just run:
yread browse # serves ./.yread
Or point at a wiki explicitly; --repo overrides the recorded source root:
uv run yread browse /path/to/repo/.yread --host localhost --port 8000
Codex Skill
A companion Codex skill is available at skills/yread/SKILL.md.
Install it for local discovery:
cp -R skills/yread "${CODEX_HOME:-$HOME/.codex}/skills/"
Example Output
See examples/sample-wiki for a static sample of the v2 output layout. It demonstrates wiki.json, manifest.json, and Markdown page files; it is not a real model-generated run.
Development
uv run --dev pytest -q
uv build
Privacy
yread runs locally, but source snippets read by its tools are sent to the configured LLM provider. Do not run it on private or sensitive repositories unless that provider is acceptable for the code.
The file-reading tools block common secret files such as .env, private keys, and credential files. run_bash uses an allowlist and does not invoke a shell.
Design Notes
- No hosted service: output is local Markdown.
- No AST parser: repository understanding is LLM-driven.
- Architecture-first pages: source paths are evidence, not the page structure.
- No symbolic incremental engine: resume uses a file-level manifest plus per-page evidence paths.
- Standard package layout:
src/yread/core.pyfor generation,src/yread/cli.pyfor CLI/config, andsrc/yread/viewer.pyfor the local browser.
Related Projects
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file yread-0.2.2.tar.gz.
File metadata
- Download URL: yread-0.2.2.tar.gz
- Upload date:
- Size: 65.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.26 {"installer":{"name":"uv","version":"0.11.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a6797e253cd98b5a3dc9427b89e830fd5a4c5ad972accde0305dd23829929cff
|
|
| MD5 |
6f38c7440b54e14e6faa738dce4d2809
|
|
| BLAKE2b-256 |
ca2da28d143dc7d06503bf1dfb040bc6af0fd8a6c166581452d0106d9d631da8
|
File details
Details for the file yread-0.2.2-py3-none-any.whl.
File metadata
- Download URL: yread-0.2.2-py3-none-any.whl
- Upload date:
- Size: 29.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.26 {"installer":{"name":"uv","version":"0.11.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1b12604673b6fc494ee07b324a97ddd8ae0eb3a1f56ccb3c8bb41986d5915100
|
|
| MD5 |
cc6f64d273f5e9234973785626c946df
|
|
| BLAKE2b-256 |
fa7901d806be5dbc2576fab9bca97dfd89548a03cf11708f38dc3e8010593f2a
|