Session-scoped knowledge graph engine for AI chat context compression
Project description
fish_bridge
Session-scoped knowledge graph engine for AI chat context compression.
Converts raw AI chat (40k+ tokens) into a compact typed knowledge graph (~300–800 tokens) and writes it to .github/copilot-instructions.md or CLAUDE.md — automatically included in every AI turn across all modes (ask, edit, agent). No MCP server required for the core workflow.
Raw session (40k tokens) → [fish_bridge] → Compressed graph (350 tokens)
written to copilot-instructions.md
picked up by every AI turn automatically
Install
Don't have
uv? Get it first:curl -LsSf https://astral.sh/uv/install.sh | sh(macOS/Linux) or see uv docs. It replaces pip + pipx + pyenv in one tool — no virtualenv management needed.
Recommended — uv tool install (installs both the fish-bridge CLI and fish-bridge-mcp MCP server on your PATH):
# Local Ollama backend — free, offline (requires Ollama running)
uv tool install fish-bridge-mcp
# Gemini backend (~$0.0002/turn, ~95% quality — recommended cloud option)
uv tool install "fish-bridge-mcp[gemini]"
export GEMINI_API_KEY=...
# Claude backend (~$0.002/turn, ~97% quality)
uv tool install "fish-bridge-mcp[claude]"
export ANTHROPIC_API_KEY=sk-ant-...
# OpenAI backend (~$0.0003/turn, ~93% quality)
uv tool install "fish-bridge-mcp[openai]"
export OPENAI_API_KEY=sk-...
# Everything
uv tool install "fish-bridge-mcp[all]"
After install, two commands are available on your PATH:
fish-bridge— the main CLI (ingest,compile,show,serve, ...)fish-bridge-mcp— the MCP server for VS Code agent mode
MCP config only (no permanent install needed): use uvx directly in your .vscode/mcp.json — it downloads and runs the MCP server on demand:
{ "command": "uvx", "args": ["fish-bridge-mcp"] }
See the MCP server section below for the full config.
Traditional pip install (for embedding fish-bridge as a library in your own Python project)
pip install fish-bridge-mcp
pip install "fish-bridge-mcp[gemini]" # with Gemini backend
pip install "fish-bridge-mcp[claude]" # with Claude backend
pip install "fish-bridge-mcp[all]" # everything
2-minute quickstart
# 1. Initialize for your project
fish-bridge init --tool copilot --project ./
# 2. Ingest the latest Copilot session (auto-discovers JSONL on macOS/Linux/Windows)
fish-bridge ingest --source copilot
# 3. View the graph
fish-bridge show
# 4. Compile to your instructions file (done automatically after ingest)
fish-bridge compile
That's it. .github/copilot-instructions.md now contains a ~350-token compressed summary of your session, replacing raw history in every future turn.
Backends
| Backend | Install extra | Model | Quality | Cost/turn |
|---|---|---|---|---|
local (Ollama) |
(none — requires Ollama) | qwen2.5:7b | ~85% | $0 |
gemini |
[gemini] |
gemini-2.5-flash | ~95% | ~$0.0002 |
openai |
[openai] |
gpt-4.1-mini | ~93% | ~$0.0003 |
claude |
[claude] |
claude-opus-4-7 | ~97% | ~$0.002 |
hybrid |
[claude] or [openai] |
local+cloud | best | mixed |
Configure with:
fish-bridge config --backend gemini
# or set GEMINI_API_KEY / ANTHROPIC_API_KEY / OPENAI_API_KEY as env vars
Full CLI reference
# --- Session init ---
fish-bridge init # create session for current project
fish-bridge init --tool claude # → writes to CLAUDE.md instead
# --- Ingest chat turns ---
fish-bridge ingest --source copilot # auto-discover latest VS Code Copilot session
fish-bridge ingest --source copilot --session <id> # target specific session
fish-bridge ingest --source paste # paste any chat text — opens $EDITOR (universal fallback)
fish-bridge ingest --source file --file export.json # from a saved export file
fish-bridge watch --source copilot # tail JSONL, auto-update on new turns
# --- Merge external knowledge ---
fish-bridge merge --source document --file HANDOVER.md
fish-bridge merge --source codebase --path ./ # git log + README
fish-bridge merge --source obsidian --vault ~/notes
fish-bridge merge --source deps --path ./ # package.json / pyproject.toml etc.
fish-bridge merge --source testout --file results.json # jest / pytest / JUnit
fish-bridge merge --source iac --path ./ # Terraform / CDK / CloudFormation
fish-bridge merge --source openapi --file openapi.yaml
fish-bridge merge --source session --file prior.chatgraph.json
# --- Compile & view ---
fish-bridge compile # update instruction file (runs after ingest by default)
fish-bridge compile --mode digest # full handover markdown
fish-bridge compile --mode focus --query "Redis caching"
fish-bridge show # pretty-print active nodes
fish-bridge show --all # include resolved/deferred items
fish-bridge serve # open Cytoscape.js graph viewer at localhost:8080
fish-bridge digest # generate handover digest
# --- Node management ---
fish-bridge resolve "DNC caching strategy"
fish-bridge defer "v16 index validation"
fish-bridge add "Use Redis for session cache" --type decision
fish-bridge conflict show
fish-bridge conflict resolve <node-id> --keep old
# --- Export / import / diff ---
fish-bridge export # save .chatgraph.json
fish-bridge import prior-session.chatgraph.json
fish-bridge diff session-a.chatgraph.json session-b.chatgraph.json
# --- Config ---
fish-bridge config --show
fish-bridge config --backend gemini
MCP server (optional — agent mode only)
The MCP server adds real-time record_turn capture when using VS Code agent mode. It is not required — the file-based workflow above works in all modes without it.
Add to .vscode/mcp.json (uses uvx — no prior install needed):
{
"servers": {
"fish-bridge": {
"command": "uvx",
"args": ["fish-bridge-mcp"],
"env": { "FISH_BRIDGE_BACKEND": "gemini", "GEMINI_API_KEY": "${env:GEMINI_API_KEY}" }
}
}
}
If you used uv tool install fish-bridge-mcp, you can also reference the installed binary directly:
{ "command": "fish-bridge-mcp" }
See examples/ for Claude Desktop, Cursor, and Windsurf configs.
MCP tools: record_turn, get_context, get_focus, mark_resolved, add_node, export_session, import_session, show_active, list_deferred
Ingest sources
| Source | Command | What it ingests |
|---|---|---|
| Copilot | ingest --source copilot |
VS Code Copilot JSONL transcript (auto-discovered) |
| Paste | ingest --source paste |
Any chat text — universal fallback |
| Document | merge --source document |
Markdown, JSON, YAML specs and ADRs |
| Codebase | merge --source codebase |
Git commits + README + HANDOVER |
| Obsidian | merge --source obsidian |
Vault notes with wikilinks and frontmatter |
| Session | merge --source session |
Prior .chatgraph.json export |
| Deps | merge --source deps |
package.json, pyproject.toml, Cargo.toml, go.mod, Gemfile, pom.xml |
| Test output | merge --source testout |
Jest JSON, pytest JSON, JUnit XML — error nodes per failing test |
| IaC | merge --source iac |
Terraform, CDK (synth output), CloudFormation, docker-compose |
| OpenAPI | merge --source openapi |
OpenAPI 3.x / Swagger 2.0 / AsyncAPI specs |
How it works
- Ingest — reads raw chat turns from JSONL (Copilot), paste, or any file format
- Extract — LLM extracts typed nodes (questions, decisions, errors, tasks, skills, files) and edges
- Dedup — semantic similarity merges near-duplicates; conflict detection flags status reversals
- Compile — graph is compressed to ~300–800 token XML/markdown block
- Write — block is written to
.github/copilot-instructions.md(orCLAUDE.md) - Deliver — AI tool reads the file automatically on the next turn — no injection, no agent required
Documentation
License
MIT — see LICENSE
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 fish_bridge_mcp-0.1.3.tar.gz.
File metadata
- Download URL: fish_bridge_mcp-0.1.3.tar.gz
- Upload date:
- Size: 277.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0a1e5852eb57536005a90d8de276cbecfe8df4a2a420c23f4962e79b80c3f421
|
|
| MD5 |
7bed0cc518d437716d276cfe1b33dde0
|
|
| BLAKE2b-256 |
a6cc4791ac4291e1d4cc755d5fdd89c90573d932e5e1180ce52c0be9f10ac150
|
Provenance
The following attestation bundles were made for fish_bridge_mcp-0.1.3.tar.gz:
Publisher:
publish.yml on MakeaMouse/fish-bridge-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
fish_bridge_mcp-0.1.3.tar.gz -
Subject digest:
0a1e5852eb57536005a90d8de276cbecfe8df4a2a420c23f4962e79b80c3f421 - Sigstore transparency entry: 1559979432
- Sigstore integration time:
-
Permalink:
MakeaMouse/fish-bridge-mcp@6cc9aaa580a31ae45fac705b725d69431a36c6cb -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/MakeaMouse
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@6cc9aaa580a31ae45fac705b725d69431a36c6cb -
Trigger Event:
push
-
Statement type:
File details
Details for the file fish_bridge_mcp-0.1.3-py3-none-any.whl.
File metadata
- Download URL: fish_bridge_mcp-0.1.3-py3-none-any.whl
- Upload date:
- Size: 263.2 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 |
b86832240111f1872f04456e6c1502c12055fcad6636654d5f82c34358ebf470
|
|
| MD5 |
0f5ba40960e8b5fe5f1101ae58d8721e
|
|
| BLAKE2b-256 |
760b410dd8f5e4114a210b1feae5dddaa2e96841188bf5e8db6e42350db6d14a
|
Provenance
The following attestation bundles were made for fish_bridge_mcp-0.1.3-py3-none-any.whl:
Publisher:
publish.yml on MakeaMouse/fish-bridge-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
fish_bridge_mcp-0.1.3-py3-none-any.whl -
Subject digest:
b86832240111f1872f04456e6c1502c12055fcad6636654d5f82c34358ebf470 - Sigstore transparency entry: 1559979552
- Sigstore integration time:
-
Permalink:
MakeaMouse/fish-bridge-mcp@6cc9aaa580a31ae45fac705b725d69431a36c6cb -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/MakeaMouse
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@6cc9aaa580a31ae45fac705b725d69431a36c6cb -
Trigger Event:
push
-
Statement type: