ctx-memory
ctx-memory
Persistent memory for LLM coding agents — Claude Code, Codex, Gemini CLI, OpenCode.
When you start a new session, the agent already knows what you worked on last time: decisions made, files touched, errors hit, conventions learned. No cloud. No telemetry. Everything lives in a local SQLite database at ~/.ctx-memory/store.db.
How it works
Session starts
│
Shell wrapper intercepts 'claude' (or codex/gemini/opencode)
│
MCP server starts alongside — injects prior context, exposes memory tools
│
During session: hooks fire on every tool call, messages buffered
│
Session ends (clean exit / Ctrl-C / crash)
│
Layer 1 → Layer 2 → Layer 3 pipeline runs
│
├── Layer 1: extract weighted messages, events, decisions, errors, keywords
├── Layer 2: compress to ≤500-token digest, store in DB
└── Layer 3: merge digest into project memory doc (markdown)
Next session: agent reads prior context automaticallyInstall
npm install -g ctx-memory
ctx-memory setupThe setup wizard:
Detects which tools are installed (
claude,codex,gemini,opencode)Asks which ones to integrate
Writes hook configs for each tool
Creates wrapper symlinks in
~/.ctx-memory/bin/Adds
~/.ctx-memory/binto your PATH via~/.bashrc/~/.zshrc
Restart your shell (or source ~/.bashrc), then use your tools as normal — memory is automatic.
Commands
ctx-memory setup # interactive setup wizard
ctx-memory status # show configuration and stats
ctx-memory projects list # list all projects
ctx-memory projects show <name> # print full memory doc for a project
ctx-memory projects forget <name> # reset memory (keeps sessions)
ctx-memory projects forget <name> --hard # delete all sessions + dataMCP server
The MCP server runs as a sidecar alongside each tool session and exposes six tools:
Tool | Description |
| Buffer a conversation message for processing at session end |
| Record a tool call event (file edit, bash command, etc.) |
| Search past sessions by semantic similarity or keywords |
| Return the full project memory doc |
| List recent sessions with goals and outcomes |
| Finalize a session and run the Layer 1 → Layer 2 → Layer 3 pipeline |
To use the MCP server standalone with Claude Code, add to ~/.claude/settings.json:
{
"mcpServers": {
"ctx-memory": {
"command": "node",
"args": ["/path/to/ctx-memory/dist/src/mcp/index.js"]
}
}
}Architecture
src/
cli/ — setup wizard, status, projects commands
db/ — SQLite schema + CRUD (projects, sessions, events, digests, memory)
layer1/ — pure message/event processing → weighted Layer1Output
layer2/ — digest compression to ≤500 tokens → Layer2Digest
layer3/ — merge digest into ProjectMemory markdown
mcp/ — MCP server (handlers + stdio entry point)
wrapper/ — shell wrapper (intercepts tool invocation, manages session lifecycle)
hooks/ — hook config writers for Claude / Gemini / OpenCodeKey constraints:
All Layer 1/2/3 functions are pure — no I/O, never throw
Digests stay under 500 tokens
Vector search uses all-MiniLM-L6-v2 embeddings via
sqlite-vec(384-dim)Single SQLite DB, WAL mode, foreign keys on
Development
npm run build # tsc → dist/
npm run dev # tsc --watch
npm run test:run # vitest (single-shot, 476+ tests)
npm test # vitest (watch mode)DB path defaults to ~/.ctx-memory/store.db. Override with CTX_MEMORY_DB_PATH.
License
MIT
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/GhadiSaab/ctx-memory'
If you have feedback or need assistance with the MCP directory API, please join our Discord server