A harness primitive for AI coding agents: one connected graph over code, intent, plan, and memory — legible (token-cheap retrieval) and enforceable (intent↔code drift checks).
Project description
yigraf
yigraf — "Why I Graph?" A tool for AI coding agents, not for humans. It answers, for the agent, the why's and what-for's of its current state — the questions an agent can't recover from source alone and loses on every
/clear. A human is the principal whose intent it carries; the agent is the operator and the audience.
What is yigraf?
yigraf is a harness primitive for AI coding agents: it projects your repo into one connected graph over four kinds of knowledge —
- structure — the code itself (what is this?)
- intent — specs/requirements (what is it for?)
- plan — goals and tasks (what's left?)
- memory — decisions and their reasoning (why is it this way?)
— and keeps them linked, so the right slice of an agent's work is both legible (scoped, token-cheap
retrieval instead of re-reading files) and enforceable (an intent↔code drift check that fires when
code and the thing governing it diverge). It retrofits onto an existing repo — yigraf init and go.
The problem it solves: an agent's working memory is wiped on every /clear, and source code doesn't
record why it's the way it is or what it's supposed to do. yigraf persists that context as a
queryable graph and re-surfaces the relevant piece exactly when the agent needs it.
Capabilities
- Structure index — tree-sitter parsing into file/module/symbol nodes with a reformatting-stable
content hash, across 16 languages (see
docs/language-support.md). - Intent & plan — author specs and task plans as Markdown; link a task to the symbols that implement it, anchored to their current content.
- Drift detection — when anchored code changes, yigraf surfaces "re-verify this still holds, then re-link or supersede." A pure rename re-anchors automatically; a body change is honest drift. (This is the part that makes yigraf governance, not just an index.)
- Memory — capture decisions + the reasoning behind them; recall by meaning (optional embeddings)
or lexically; a decision earns
settledafter surviving K commits un-superseded;gcarchives churn. - Token-cheap retrieval —
yigraf context "<topic>"returns a scoped, budgeted slice (locators + signatures, not file dumps) — measured ≈2.5× cheaper than reading the file. - Agent integration — Claude Code hooks inject governing intent + drift on edit and re-inject the
plan after
/clear; a skill teaches the rituals. TheyigrafCLI works with any agent.
Requirements (and what each is for)
| Requirement | Why |
|---|---|
| Python ≥ 3.11 | yigraf runs as a Python CLI |
| A git repo | drift anchoring and git-derived maturity read git history (degrades gracefully without git) |
| Tree-sitter grammars | structure extraction — bundled, no setup |
| An agent harness | Claude Code gets hooks + a skill out of the box; any other agent can drive the CLI |
An embeddings backend (optional, [embeddings] extra) |
semantic recall of memory/intent by meaning; falls back to lexical retrieval if absent — never required |
Quickstart
# 1. install (see Installation for per-platform setup)
uv tool install git+https://github.com/mansilla/yigraf.git
# 2. in your repo: create the workspace and index the code
cd your-repo
yigraf init
yigraf build
# 3. wire it into Claude Code (hooks + skill)
yigraf install-claude-hooks
# 4. use it
yigraf context "session expiry" # a scoped, token-cheap slice for a topic
yigraf intent session-expiry -s "The system SHALL expire a session after 30m idle."
yigraf link task:auth/1 sym:src/auth/session.py#refresh # anchor a task to its code
yigraf remember "chose monotonic clock" --why "wall-clock skews under NTP"
yigraf drift # report any intent↔code drift
Installation
yigraf installs from source (not yet on PyPI). It needs Python ≥ 3.11; the tree-sitter grammars are bundled, so there's nothing else to set up. Installing as an isolated tool (uv or pipx) is recommended.
Any platform — pick one:
uv tool install git+https://github.com/mansilla/yigraf.git # uv
pipx install "git+https://github.com/mansilla/yigraf.git" # pipx
# with semantic recall (numpy + sentence-transformers):
uv tool install "yigraf[embeddings] @ git+https://github.com/mansilla/yigraf.git"
macOS
brew install uv # or: brew install pipx ; and Python 3.11+ via `brew install python@3.12`
uv tool install git+https://github.com/mansilla/yigraf.git
Linux
# Debian/Ubuntu — ensure Python 3.11+ and git
sudo apt-get update && sudo apt-get install -y python3 python3-venv git
curl -LsSf https://astral.sh/uv/install.sh | sh # install uv (or: pipx via your package manager)
uv tool install git+https://github.com/mansilla/yigraf.git
Windows
winget install astral-sh.uv # install uv
winget install Git.Git # drift anchoring uses git; install Git for Windows
# (Python 3.11+ via `winget install Python.Python.3.12` if you don't have it)
uv tool install git+https://github.com/mansilla/yigraf.git
From source (development)
git clone https://github.com/mansilla/yigraf.git
cd yigraf
uv sync # create the venv + install deps (incl. dev tools)
uv run yigraf --help
uv run pytest
How yigraf works
yigraf projects your repo into one graph and keeps it in sync with the why:
- Index —
yigraf buildparses your code into file/module/symbol nodes, each with an AST-normalized content hash (so reformatting and comments don't count as change). - Author — write intents (specs) and plans (tasks) as Markdown; capture memory
(a decision + its reasoning) with
yigraf remember. - Link —
yigraf link <task> <symbol>records which code implements a task and anchors the link to that symbol's current content hash. - Retrieve —
yigraf context "<topic>"returns a scoped, token-budgeted slice: the governing intents, the implementing symbols (as locators + signatures), prior decisions, open tasks, and any drift — a small map, not a pile of file dumps. - Enforce — when a symbol's anchored content changes, yigraf reports drift so the change gets re-verified against what governs it (or the link re-anchored / the decision superseded).
With Claude Code wired up (yigraf install-claude-hooks), steps 4–5 happen automatically: a
PostToolUse hook injects governing intent + drift the moment the agent edits a governed file, and a
SessionStart hook re-injects the active plan after a /clear — so a flow interrupted by a context
reset resumes instead of restarting. The hook stays silent on ungoverned, undrifted edits (no nagging).
Files yigraf creates
yigraf init lays down a yigraf/ workspace at your repo root:
yigraf/
├── config.yaml # committed — enabled languages, ignore globs, retrieval tunables
├── intents/<slug>.md # committed — requirement / goal / capability specs
├── plans/{active,completed}/ # committed — plans + tasks (the filesystem is the state)
├── memory/<id>-<slug>.md # committed — decisions / constraints + the "why"
├── graph.json # committed — the graph projection (recomputable state only)
├── index/ # gitignored — embedding index (rebuildable)
├── cache/ # gitignored — extraction cache
└── .local/ # gitignored — volatile telemetry (usage / last_seen)
The committed artifacts (intents/, plans/, memory/, graph.json, config.yaml) are the
shareable record — they travel with the repo, so the next agent or teammate inherits the why. Derived
and volatile state stays gitignored and rebuilds from source. yigraf also writes a self-contained
yigraf/.gitignore, so nothing extra needs to be added to your repo's ignore rules.
Two opt-in installers wire yigraf into your tooling:
yigraf install-claude-hooks— writes.claude/settings.local.json(machine-local hooks, not committed) and.claude/skills/yigraf/SKILL.md.yigraf install-hooks— adds a git post-commit hook that keepsgraph.jsonsynced toHEAD.
Language support
16 languages, indexed at two depths (bespoke extractors for Python/Go/JS-TS, a generic tags-query tier
for the rest). The full tested capability matrix — symbols / calls / imports / inheritance / drift,
per language — is in docs/language-support.md.
Project details
Release history Release notifications | RSS feed
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 yigraf-0.1.0.tar.gz.
File metadata
- Download URL: yigraf-0.1.0.tar.gz
- Upload date:
- Size: 438.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
515c9e10a5bae8ee8ca0f03aeae6874def655257354fc3abc5c19b20814fa6f9
|
|
| MD5 |
98748f43e415241f19d85cde42c11606
|
|
| BLAKE2b-256 |
30d6eb439b7187b9388fc5d7a896618daada970129e73f3439185bd664c2d48f
|
File details
Details for the file yigraf-0.1.0-py3-none-any.whl.
File metadata
- Download URL: yigraf-0.1.0-py3-none-any.whl
- Upload date:
- Size: 96.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
20596cae30919777ba4630337e718da04f8cf6127645120f1b124a192ea2a6dc
|
|
| MD5 |
23b7c5c890cb0ae2f32ffd06295f392d
|
|
| BLAKE2b-256 |
59d808615484217ec8f0a35226c9461991ae46a18cab149fb013bfea24db78d3
|