Code context for AI dev tools — graph-grounded, pack-scoped retrieval over MCP. 60% fewer tokens, audit-grade citations.
Project description
karst
Code context for AI dev tools. karst sits between your repo and any AI
tool — Cursor, Claude Desktop, a custom agent — and feeds it the right slice
of the codebase: graph-grounded, pack-scoped, and cited to file:line. The
result is ~60% fewer input tokens per question, answers you can verify, and a
blast-radius check before you change anything.
It runs locally, returns context (not answers) over MCP, and never calls an LLM itself — so you don't give karst an API key. Your IDE already has the model; karst just makes what it reads sharp and cheap.
uv tool install karst # recommended — fast, and puts `karst` on PATH for you
# or
pipx install karst # isolated install, also handles PATH
# or
pip install karst # if `karst` isn't found after, use `python -m karst …`
uvandpipxare the cleanest because they put thekarstcommand on your PATH automatically. With plainpip --user(notably Microsoft Store Python) the command may not be on PATH — in that casepython -m karst …always works, no PATH setup required.
Why
Most "chat with your codebase" tools dump tens of thousands of vaguely-related tokens into the model on every question. You can't see what was loaded, you can't scope it, and the bill arrives at the end of the month. karst inverts that:
- Scopes — pack-filtered retrieval reads ~200 chunks, not 5,000.
- Cites — every chunk carries an exact
file:line. Verify, don't trust. - Predicts — a real call/import graph answers "what else breaks if I change this?" — which embeddings alone can't.
Measured on a real 246-file NestJS + Next.js repo: 906 chunks indexed, re-index 343s → 2.3s incremental, ~$0.019 per question on Sonnet 4.6 (shown before the call), 60% fewer tokens with packs attached.
Quickstart (CLI)
karstcommand not found? Your Python Scripts dir isn't on PATH (common with Microsoft Store Python). Everything below works the same withpython -m karst …— no PATH setup. (Or install viauv/pipx, which putkarston PATH for you.)
cd your-project
# one command: index + call/import graph + suggested packs
karst quickstart # or: python -m karst quickstart
# ask questions about the code (defaults to this folder's index)
karst ask "how does checkout charge the user?" --no-llm # cited code, no API key
karst ask -i # interactive: ask many questions
# what breaks if I change a function?
karst impact --target checkout --graph-path ~/.karst/indexes/your-project/graph.pkl
# review a diff with severity-tagged, cited findings
karst review --staged --storage ~/.karst/indexes/your-project
karst examples # a copy-paste cheatsheet of everything
karst quickstart prints the exact follow-up commands with your index path
filled in. karst ask writes an LLM answer when ANTHROPIC_API_KEY /
OPENAI_API_KEY is set; otherwise add --no-llm for cited chunks (no key). The
MCP server below needs no key either — your IDE supplies the model.
Use it from your IDE (MCP)
karst ships an MCP server (karst-mcp) exposing five tools — search_code,
find_impact, list_packs, index_status, index_repository — over stdio.
Claude Desktop (claude_desktop_config.json) or Cursor
(.cursor/mcp.json) — pick whichever launcher you have:
{
"mcpServers": {
"karst": { "command": "uvx", "args": ["--from", "karst", "karst-mcp"] }
}
}
uvx needs nothing pre-installed — it fetches and runs karst on demand. Already
installed it? { "command": "karst-mcp" } works too. No PATH at all? Use
{ "command": "python", "args": ["-m", "karst.mcp_server"] }.
Restart the host, then ask normally — it calls karst's tools when useful and gets back scoped, cited context. Full setup is in docs/MCP.md.
Guides
New here? Start with whichever fits you:
- Why karst? — what it is and what it's for, in plain language. Read this first if you're not sure what problem it solves.
- Quickstart — zero to asking real questions in 5 minutes, no API key, with real output.
- For vibe coders — use karst from Cursor / Claude Desktop with no CLI commands — you just chat.
- Connect your AI tool — copy-paste MCP setup for every client: Claude Desktop, Claude Code, Cursor, Windsurf, VS Code, Zed, JetBrains, plus the web apps.
- Cookbook — real scenarios (onboarding, blast radius, cutting token cost, reviewing a diff) with copy-paste commands.
- MCP setup · Architecture — reference and internals.
How it works
- Index — tree-sitter splits every function, class and method into an AST-aware chunk (Python, JS, TS, Go, Rust, Java); chunks are embedded into a local Qdrant store. Incremental: a SHA manifest + embedding cache skip unchanged files.
- Graph — a NetworkX knowledge graph of
CALLS/IMPORTS/CONTAINSedges powers impact analysis ("what depends on this?"). - Pack — related files become named, attachable context packs (
auth,billing). A query loads only its pack. - Serve — the MCP server returns ranked,
file:line-cited chunks; your host's model reasons over them.
Everything is local and offline-capable (FastEmbed/ONNX embeddings, Qdrant local mode, sqlite caches — no Docker, no daemon).
Status
Live: AST chunking (6 languages), call/import graph + impact analysis,
pack-scoped retrieval, token + cost meter, incremental indexing + embedding
cache, diff code review with inline PR posting (review --pr --post-to-pr), and
the MCP server over both stdio and remote Streamable-HTTP (karst-mcp --http).
Coming next: hosted indexing, team-shared pack libraries, an autonomous GitHub
PR review bot, and OAuth for browser connectors (claude.ai / ChatGPT).
License
Apache-2.0. See LICENSE.
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 karst-0.2.5.tar.gz.
File metadata
- Download URL: karst-0.2.5.tar.gz
- Upload date:
- Size: 87.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bbe7837d8984e7d8498f01c620c966578e2573008ce9c9b8ecd07aa62d48fc45
|
|
| MD5 |
19ca3dd3d90db8356a0fe8aa21379998
|
|
| BLAKE2b-256 |
99563c995d5f697c88fe781165462562b100de86445bf1f08461802d3de79514
|
Provenance
The following attestation bundles were made for karst-0.2.5.tar.gz:
Publisher:
publish.yml on Moin105/upgraded-garbanzo
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
karst-0.2.5.tar.gz -
Subject digest:
bbe7837d8984e7d8498f01c620c966578e2573008ce9c9b8ecd07aa62d48fc45 - Sigstore transparency entry: 1907862474
- Sigstore integration time:
-
Permalink:
Moin105/upgraded-garbanzo@3ca5e80599b6ba1991af4dac4a292b6f73859e26 -
Branch / Tag:
refs/tags/v0.2.5 - Owner: https://github.com/Moin105
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@3ca5e80599b6ba1991af4dac4a292b6f73859e26 -
Trigger Event:
push
-
Statement type:
File details
Details for the file karst-0.2.5-py3-none-any.whl.
File metadata
- Download URL: karst-0.2.5-py3-none-any.whl
- Upload date:
- Size: 88.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a887c2c2b44e008e28a10a20452bb52d292a3c2b429e5ff3f6f73225cdb170c8
|
|
| MD5 |
4e5307b833946cc407063d85674dda0e
|
|
| BLAKE2b-256 |
24ff4dfc954f14179e1698e43e45cb667bd7bbbd44aafaa738c8ed3facabaca9
|
Provenance
The following attestation bundles were made for karst-0.2.5-py3-none-any.whl:
Publisher:
publish.yml on Moin105/upgraded-garbanzo
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
karst-0.2.5-py3-none-any.whl -
Subject digest:
a887c2c2b44e008e28a10a20452bb52d292a3c2b429e5ff3f6f73225cdb170c8 - Sigstore transparency entry: 1907862587
- Sigstore integration time:
-
Permalink:
Moin105/upgraded-garbanzo@3ca5e80599b6ba1991af4dac4a292b6f73859e26 -
Branch / Tag:
refs/tags/v0.2.5 - Owner: https://github.com/Moin105
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@3ca5e80599b6ba1991af4dac4a292b6f73859e26 -
Trigger Event:
push
-
Statement type: