Memory management tool for vibe-coding agents using Weaviate and optional Chroma cache
Project description
VibeMem (vibemem)
VibeMem is a pip-installable CLI tool to manage reusable “memories” (findings / recipes / gotchas / preferences) for vibe-coding agents.
- Canonical storage: Weaviate (single collection:
VibeMemMemory) - Optional local cache: Chroma persisted under
~/.vibemem/chroma/(per-repo subdirectory) - Works from any directory: derives repo root + scope from your current working directory (override via flags)
- Default output: JSON (agent-friendly). Use
--humanfor pretty output.
Install
From PyPI:
python -m pip install -U vibemem
Editable install from this repo:
python -m pip install -e .
Optional cache support (Chroma):
python -m pip install -e ".[cache]"
Dev tools/tests:
python -m pip install -e ".[dev]"
pytest
Install troubleshooting
If pip install -U vibemem fails with an OSError: [Errno 2] No such file or directory, it usually means pip fell back to building a dependency from source and a build tool is missing on your machine.
Try:
python -m pip install -U pip setuptools wheel
python -m pip install -U vibemem -v
If it still fails, paste the full -v output (it should include the missing executable/file), and try a clean reinstall:
python -m pip uninstall -y vibemem
python -m pip install -U --no-cache-dir vibemem
Configuration
VibeMem reads connection settings from environment variables first, then falls back to a JSON config file at ~/.vibemem/config.
Config file (optional)
Show where the config file lives:
vibemem config path
Create an empty config file:
vibemem config init
Set values via the CLI (writes to ~/.vibemem/config):
vibemem config set --weaviate-url http://localhost:8080 --weaviate-grpc-url http://localhost:50051
Optional: configure a hosted embedding service so VibeMem can store vectors (for semantic/hybrid search) even when the Weaviate collection has vectorizer = none:
vibemem config set --embedding-host 127.0.0.1 --embedding-port 7071 --embedding-model "your-model-id"
The embedding service must expose either an OpenAI-compatible POST /v1/embeddings endpoint, or a TEI-compatible POST /embed endpoint.
Note: environment variables (below) override values in the config file.
Env vars
VIBEMEM_WEAVIATE_URL(required for Weaviate operations)- Examples:
http://localhost:8080orhttps://YOUR_CLUSTER.weaviate.cloud
- Examples:
VIBEMEM_WEAVIATE_API_KEY(optional; required for Weaviate Cloud URLs)VIBEMEM_WEAVIATE_GRPC_URL(optional)- Example:
http://localhost:50051
- Example:
VIBEMEM_EMBEDDING_HOST(optional; enables client-side embeddings)VIBEMEM_EMBEDDING_PORT(optional; enables client-side embeddings)VIBEMEM_EMBEDDING_MODEL(optional; used for OpenAI-compatible/v1/embeddings)VIBEMEM_WEAVIATE_COLLECTION(default:VibeMemMemory)VIBEMEM_CACHE_MODE(default:auto) —auto|on|off
Show effective config
vibemem config show
Scope model
VibeMem derives scope from your current directory:
- Repo root is detected by searching upwards for
.git/first; fallback markers:pyproject.toml,package.json,go.mod repo_slug = basename(repo_root)rel_path = path from repo_root to cwd(empty at repo root)
Scope ID derivation is controlled by --granularity:
repo(default):scope_id = repo_slugcwd:scope_id = repo_slug::<rel_path>path:N:scope_id = repo_slug::<first N path parts>
Show current derived scope:
vibemem scope
Commands
Search
Search returns ranked memories with scope-aware bubbling (current scope → parent scopes → repo-level; and optionally global).
vibemem search "TypeError: ..." --top 8
Options:
--include-global/--no-include-global--include-parents/--no-include-parents--cache auto|on|off
When Weaviate is unreachable and cache is ON (and built), search will fall back to Chroma.
Add a memory
vibemem add --type recipe --text "Use X to fix Y" --tags "python,typing" --confidence high --verification "ran pytest"
Add structured metadata:
vibemem add --type gotcha --text "Chroma where filters differ by version" --error "ModuleNotFoundError: chromadb" --file "vibemem/store/chroma_cache.py" --cmd "pip install -e '.[cache]'"
Edit / remove
vibemem edit <uuid> --text "updated text" --tags "a,b"
vibemem rm <uuid>
List
vibemem list --scope project --limit 20
vibemem list --scope global --type gotcha
vibemem list --scope all --tag python
Sync (pull)
Rebuild local cache from Weaviate:
vibemem sync --pull --limit 200
Notes:
- “Push/offline queue” is a TODO stub (not implemented).
Output modes
Default output is JSON:
vibemem scope
Pretty output:
vibemem --human scope
Python API
VibeMem is also importable as a Python library. It uses the same config + scope model as the CLI, but the API lets you override scope explicitly when you want.
import vibemem
# Recommended: a stateful client (reuses config + default scope)
vm = vibemem.VibeMem()
vm.add_memory(mem_type="recipe", text="Use X to fix Y", tags=["python", "typing"])
hits = vm.search_hits("TypeError: ...", top=8)
# Write to the global knowledge base (instead of the derived project scope)
vm.add_memory(mem_type="recipe", scope="global", text="Use X to fix Y", tags=["python", "typing"])
Scope and granularity (what to pass when)
Scope basics
- Scope types:
"project"or"global". - Project scope IDs look like
repo_slugorrepo_slug::path/from/repo/root(use forward slashes). - Global scope ID is typically
"global".
Example (explicit scope targeting):
# Assumes you already have a client:
# import vibemem
# vm = vibemem.VibeMem()
# Write to a specific project scope (not your current repo)
vm.add_memory(mem_type="recipe", scope="project", scope_id="otherrepo::a/b", text="Use X", tags="python")
# Search only that exact scope (no parent bubbling)
memories = vm.search_memories("TypeError", scope="project", scope_id="otherrepo::a/b", include_parents=False)
Deriving a project scope ID
If you don’t pass an explicit scope_id, VibeMem derives it from cwd (or repo_root):
granularity="repo"(default):myrepogranularity="cwd":myrepo::a/b(the full relative path)granularity="path:N":myrepo::a(firstNpath parts)
Per-call scope override parameters (client methods)
These parameters apply to vm.search*() and vm.add_memory():
scope="global"|"project": force the scope type for this call.scope_id="...": explicitly target a specific scope ID (useful for “any repo/any path” scripts).cwd=Path(...)/repo_root=Path(...): derive scope from a directory that isn’t your current working directory.granularity="repo"|"cwd"|"path:N": affects derived projectscope_idonly (ignored ifscope_idis provided).
Search-only parameters:
scope_ids=[...]: search exactly these project scope IDs (no automatic parent bubbling).include_parents=True|False: whenscope_idsis not provided, search current scope + parent scopes (default:True).include_global=True|False: when searching project scope, also include global results (default:True).
Other common parameters:
cache="auto"|"on"|"off": controls Chroma fallback/caching forsearchand cache updates foradd/edit/delete(usepython -m pip install -U "vibemem[cache]"for"on").tags=["a","b"]ortags="a,b": both forms are accepted byadd_memory()/edit_memory().
Quick reference (client methods)
vm.search(query, ...) -> SearchResult: includesresult.scope(derived/overridden scope) andresult.hits(scoredSearchHits).vm.search_hits(query, ...) -> list[SearchHit]: convenience wrapper returning just the hits.vm.search_memories(query, ...) -> list[Memory]: convenience wrapper returning just theMemoryobjects.vm.add_memory(..., scope=..., scope_id=...) -> Memory: create a memory in a specific scope.vm.edit_memory(memory_id, ...) -> Memory: edit by UUID (scope params are optional; the UUID identifies the memory).vm.delete_memory(memory_id, ...) -> None: delete by UUID.vm.list_memories(scope="project|global|all", ...) -> list[Memory]: list memories with server-side filters (scope here is a filter, not derived).vm.scope_info() -> ScopeInfo: show the derived default scope for the client.
Convenience functions
For one-off scripts, module-level helpers create a temporary client under the hood (they accept the constructor-style parameters like cwd=..., scope_type=..., scope_id=..., granularity=...; scope_type= is the same idea as the per-call scope= on client methods):
import vibemem
result = vibemem.search("TypeError: ...", top=8, granularity="cwd")
memories = vibemem.search_memories("TypeError: ...", top=8)
Example agent prompt
Use something like this with your AI vibe coder to propose memories for your review before writing anything:
You have access to this repository’s files. I want you to propose a list of “memories” for me to authorize before creating them.
1) Scan the repo for important environment information and setup details that would help in other projects (env vars, required services, ports, build tools, OS-specific steps, CI quirks, etc.).
2) Scan the repo for anything unusual, surprising, or easy to forget (non-obvious defaults, tricky edge cases, sharp corners, gotchas).
3) Output a list of candidate memories for approval. For each item, include:
- type (recipe|gotcha|preference|note)
- text (1–3 sentences)
- suggested tags
- scope suggestion (global vs project) and why
4) Do not create or write anything until I approve each memory.
Notes
- The Weaviate collection will be auto-created on first use if it doesn’t exist.
- If the Weaviate instance doesn’t have a text vectorizer module configured, VibeMem will use a non-vectorized collection. Configure
VIBEMEM_EMBEDDING_HOST/PORTto store vectors for semantic search; otherwisesearchfalls back to BM25 keyword search.
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 vibemem-0.2.5.tar.gz.
File metadata
- Download URL: vibemem-0.2.5.tar.gz
- Upload date:
- Size: 57.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5ec3803ec98393678a4121e82546d2ac1d5dc47cb67cd6da8084556508bc9d9f
|
|
| MD5 |
34cd06f05f405fc36d656f86a565a473
|
|
| BLAKE2b-256 |
ba84e1f55a81ef14dafe453b788fe2c50d3d2e45be5982868731f1ce64340440
|
File details
Details for the file vibemem-0.2.5-py3-none-any.whl.
File metadata
- Download URL: vibemem-0.2.5-py3-none-any.whl
- Upload date:
- Size: 54.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
30cb4dae73732b1394cb0ec06b82d5dee02a0a3c565faaa18ff44436e6228f6b
|
|
| MD5 |
38e4c2a007e0ef735b4fe77a3785481d
|
|
| BLAKE2b-256 |
8d97f8464ce511ac2b22e228fbd90e64ddb0beb574674227d04dd34623c6bf2b
|