Skip to main content

The topological memory and architecture layer for AI coding agents.

Project description

Topolox

The topological memory and architecture layer for AI coding agents.

CI Python License: MIT Status

Topolox gives AI coding agents (Claude Code, Cursor) instant, deep understanding of large codebases. Instead of burning tokens reading thousands of files, it feeds an agent exactly the context it needs using an embedded hybrid graph + vector engine — kept live by a background daemon and exposed over MCP and an optional terminal cockpit.

⚠️ Pre-alpha but usable. The engine — multiprocessing parser, Kùzu + LanceDB index, query layer, MCP server, daemon, and 14-language support — is built and on PyPI. The TUI and benchmarks are next; see ROADMAP.md.

Why

On a big repo, an AI agent is smart but blind: it either reads dozens of files (slow, expensive) or misses a downstream caller and breaks something. Topolox is the memory + map the agent reads from — deterministic, instantly rebuildable, and zero-token to build.

How it works

discover → parse (multiprocessing tree-sitter) → ParseResult
        → index → Kùzu (graph) + LanceDB (vectors)
        → query (dependencies · context pruner · blast radius)
        → MCP tools  +  CLI  +  Textual TUI
   ┌ watchdog daemon patches the graph live on every file save ┐

Topolox vs. Graphify

Graphify pioneered "drop in a folder, get a knowledge graph." Topolox takes that idea in a different direction: an always-on, agent-native engine for code. They're built for different jobs.

Graphify Topolox
Form factor A Claude Code skill (/graphify) A standalone service: CLI + MCP server + daemon
Graph build AST + LLM extraction (Claude subagents / Gemini) Pure deterministic AST (multiprocessing tree-sitter)
When the LLM runs At build time — spends tokens on every build Only at query time (the consuming agent); build is zero-token
Storage Static graph.json + in-memory NetworkX Embedded Kùzu (graph) + LanceDB (vectors), on disk
Retrieval Lexical substring + IDF + BFS/DFS traversal Vector semantic search + graph traversal (hybrid)
Live updates Opt-in --watch / git hook / manual --update watchdog daemon, ms-level incremental patches
Agent access Optional MCP (7 read-only tools) + Markdown reports MCP-native (4 tools), mcp install for every agent
Inputs Code + docs + papers + images + video Code — 14 languages richly, 300+ at the file level
Signature features Community detection, "god nodes", multi-modal RAG Blast radius, dependency maps, context pruner
Concurrency Single graph, in-memory Multiprocessing + asyncio, embedded DBs

In short: Graphify is a broad, multi-modal, LLM-enriched knowledge-graph builder you invoke as a skill — its graph is richer on inferred relationships. Topolox is a narrow, deterministic, zero-token, always-live code engine that any MCP agent reads from — faster, cheaper, and instantly rebuildable. That's the trade Topolox makes to be an always-on backend.

Two ways to use it

  1. Invisible backend (MCP). Index once, register with your agent, and any MCP client silently pulls grounded, cheap context.

    topolox index .
    topolox mcp install      # registers with Claude Code, Cursor, Codex, Gemini CLI, VS Code, ...
    

    Then connect your agent — its MCP server reads the index read-only, so several agents (Claude Code, Cursor, …) can connect at once. Re-run topolox index to refresh.

    ⚠️ One writer at a time. Kùzu lets only one process write the database, so don't run topolox daemon while an agent is connected — they'd fight over the lock (MCP error -32000: Connection closed). A combined always-live server (one process that watches and serves over HTTP) is on the roadmap.

  2. The TUI cockpit (planned — Phase 3). A 3-pane terminal dashboard (agent chat · live knowledge graph · daemon log), topolox ui. See ROADMAP.md.

Supported languages & agents

Languages — symbol + import extraction for Python, JavaScript/JSX, TypeScript/TSX, Go, Rust, Java, C, C++, C#, Ruby, PHP, Kotlin, Swift, and Scala; any other tree-sitter-language-pack grammar (300+) is still parsed and indexed at the file level.

Agentstopolox mcp install registers the MCP server with Claude Code, Cursor, OpenAI Codex CLI, Gemini CLI, VS Code, Windsurf, and Claude Desktop (and any other MCP client — it's a standard stdio MCP server).

The four tools your agent gets

Tool Use it for
get_file_dependencies(path, depth) what a file imports, and what imports it
analyze_blast_radius(changed_files, max_depth) which files/tests a change would impact
prune_context(prompt, token_budget) the most relevant symbols/files for a prompt
search_architecture_graph(query, limit) semantic + structural search over the codebase

Nudge the agent with "Using topolox, …" so it reaches for these instead of grepping. deps and blast are graph-based and most reliable; search/prune ranking improves with the [embeddings] extra.

CLI

topolox index .                 # build / refresh the index in .topolox/
topolox index --dry-run .       # preview what gets parsed (no writes)
topolox deps   <file>           # dependencies + dependents of a file
topolox blast  <file...>        # blast radius of changing file(s)
topolox prune  "<question>"     # pruned, token-budgeted context
topolox mcp install [--client claude-code|cursor|codex|gemini|vscode|windsurf|claude-desktop|all]
topolox mcp serve               # run the MCP server over stdio (agents usually spawn this)

Install

pip install topolox                 # from PyPI  (or: uv tool install topolox)
pip install 'topolox[embeddings]'   # optional — local embeddings for semantic search / prune

From source:

git clone https://github.com/Karnav018/topolox.git
cd topolox && uv sync && uv run topolox --help

Development

uv sync                       # create the env + install dev tools
uv run ruff check .           # lint
uv run ruff format .          # format
uv run mypy src               # type-check (strict)
uv run pytest                 # tests

See CONTRIBUTING.md. Contributions welcome once the engine lands.

Tech stack

Python 3.11+ · Kùzu (graph) · LanceDB (vectors) · tree-sitter (AST) · FastMCP (MCP server) · watchdog (daemon) · Textual (TUI) · Typer (CLI). Optional: fastembed (local embeddings), anthropic (TUI chat).

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

topolox-0.1.4.tar.gz (221.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

topolox-0.1.4-py3-none-any.whl (46.1 kB view details)

Uploaded Python 3

File details

Details for the file topolox-0.1.4.tar.gz.

File metadata

  • Download URL: topolox-0.1.4.tar.gz
  • Upload date:
  • Size: 221.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","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

Hashes for topolox-0.1.4.tar.gz
Algorithm Hash digest
SHA256 9792e2d0c49fa8bd12e8440518f0b71174af73265bd34f23f17730f1e3bc81f4
MD5 b46783d271578736adaf0a0aee057bc2
BLAKE2b-256 db96931ea82b1f707020c9729b75040bbec53a24183870bd33441cb4006f5375

See more details on using hashes here.

File details

Details for the file topolox-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: topolox-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 46.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","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

Hashes for topolox-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 9dd29c9837d52468c197bec0bd7454ce00db43bba9f61aa6fdd0ab60d47ad3e5
MD5 c7b5c1fed1949479ed7140f6a06b8fe5
BLAKE2b-256 ce3ab915cf594c8f0f4b24bb2199c33e674bd5f0dcd38a9c7c8beb46b73020b0

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page