Skip to main content

AI memory that survives across sessions, teammates, and vendors.

Project description

luplo

Documentation Status License: AGPL v3 Python 3.12+

AI memory that survives across sessions, teammates, and vendors.

Last month I explained a decision to Claude Code. Today, back from vacation, a teammate's Codex already knew.

lp items search recall demo

What luplo does

Your engineering decisions — structured, searchable, and cited by typed edges — so three weeks later you (or your teammate, or their AI) can answer "why is X like that?" and "what else depends on it?" without reading the codebase cold.

  • Git for decisions. Append-only, typed edges, contradiction-aware.
  • lp impact tells you what breaks when you change something. Traverses depends / blocks / supersedes / conflicts edges up to five hops.
  • MCP-native, vendor-neutral. Ships an MCP server on stdio — works with Claude Code, Claude Desktop, Cursor, Zed, or any MCP-compatible client. Also usable as a plain CLI with no AI at all.
  • Full-text first. Vectors only rerank. PostgreSQL tsquery with glossary expansion does retrieval; optional pgvector reorders candidates. If it's not there, we say so.

lp impact blast radius demo

Quickstart

# Install
git clone https://github.com/luplo-io/luplo.git
cd luplo
uv sync

# Database
createdb luplo
uv run lp init --project myapp --email you@example.com

# Record a decision
uv run lp work open "Auth rework"
uv run lp items add "Use JWT over session cookies" \
    --type decision \
    --rationale "Stateless auth scales; session store is an extra dep."

# Recall
uv run lp brief
uv run lp items search "auth"
uv run lp impact <decision-id>     # blast radius

See the Quickstart for the full five-minute walkthrough including uv install, Postgres setup, and MCP wiring.

What luplo doesn't do

luplo is opinionated about what it will not become. The Philosophy page has the long version; the short one:

  • Not a vector database. Vectors rerank tsquery candidates. They never lead retrieval and never invent candidates of their own.
  • Not a general-purpose AI memory. Engineering decisions only — not chatbot user profiles, conversation history, or arbitrary facts.
  • Not an editable store. Decisions are immutable. They get superseded, never edited. Your mistakes are your most valuable data.
  • Not a graph database. Edges are typed; traversal stops at five hops. If your project needs more, you're modeling it wrong.
  • Not a plugin platform. luplo is a tool, not a framework. Integrate via webhook, sync worker, or MCP — not in-process Python.

If any of these make luplo a worse fit than a chatbot memory, a wiki, or a ticket queue, use that tool instead. Positioning explains where luplo does and doesn't fit.

Connect an MCP client

{
  "mcpServers": {
    "luplo": {
      "command": "uv",
      "args": [
        "run", "--directory", "/absolute/path/to/luplo",
        "python", "-m", "luplo.mcp"
      ],
      "env": {
        "LUPLO_DB_URL": "postgresql://localhost/luplo"
      }
    }
  }
}

Drop this into .mcp.json (Claude Code), claude_desktop_config.json (Claude Desktop), .cursor/mcp.json (Cursor), or your client's equivalent. See the MCP client guide for details.

Architecture

PostgreSQL (tsquery + glossary expansion + pgvector reranking), typed edges (depends / blocks / supersedes / conflicts), and three interfaces sharing one core: lp CLI, MCP server on stdio, and a FastAPI HTTP server.

Documentation

Full docs at luplo.readthedocs.io:

  • Concepts — philosophy, positioning, architecture, data model, search pipeline.
  • Guides — work units, tasks & QA, MCP clients, Remote server, worker.
  • Reference — CLI, MCP tools, configuration, semantic impact categories.
  • Roadmap — what we're building next.
  • API reference — auto-generated from source.

Contributing

See CONTRIBUTING.md. Short version: English everywhere, Google-style docstrings, ruff + pyright strict + pytest, Conventional Commits. Large architectural PRs should open an issue first — the shape of luplo is a curated decision.

License

AGPL-3.0-or-later. A CLA will be required for external contributions (not yet set up).

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

luplo-0.6.0.tar.gz (309.9 kB view details)

Uploaded Source

Built Distribution

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

luplo-0.6.0-py3-none-any.whl (130.8 kB view details)

Uploaded Python 3

File details

Details for the file luplo-0.6.0.tar.gz.

File metadata

  • Download URL: luplo-0.6.0.tar.gz
  • Upload date:
  • Size: 309.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for luplo-0.6.0.tar.gz
Algorithm Hash digest
SHA256 8fd709773bba39fc5d63843a3d504a7966b04861738eb3358fad28f8411aa702
MD5 44399651cab87cd1ada937cf67db4477
BLAKE2b-256 612eaede5617882ca0c858eeed1c74c2fd5f70ab4837ca1d3303c533fc9118da

See more details on using hashes here.

Provenance

The following attestation bundles were made for luplo-0.6.0.tar.gz:

Publisher: release.yml on luplo-io/luplo

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file luplo-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: luplo-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 130.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for luplo-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 006118b7caf6a5960a5bda1393aa34810df9fcd8d88a5a968e75bf1dbe353601
MD5 e11b1fed61f3dd2b3e76ba6c94cbd6c1
BLAKE2b-256 f3125252c5753c4049b86c05b268f852a9351104154d13f0d36471ca70d1ff02

See more details on using hashes here.

Provenance

The following attestation bundles were made for luplo-0.6.0-py3-none-any.whl:

Publisher: release.yml on luplo-io/luplo

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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