memory-system
Memory System
Operational reference for the joelclaw memory pipeline (session signal → durable recall → curated MEMORY.md).
When to use
Use this skill when working on memory capture, write gates, Typesense-backed recall, reflection/promote flows, or nightly maintenance.
Canonical flow
sessions → observe → write-gate → store → decay/rank → retrieve → inject
↑ ↓
└──── nightly maintenance (dedup + stale pruning + stats) ─────┘
↓
observe → reflect → propose → triage → MEMORY.md
Guiding filter: “will this fact still be true and useful next month?”
1) Write gate states (allow / hold / discard)
| State | Persist | Default retrieval | Rules |
|---|---|---|---|
allow |
yes | yes | Durable, reusable facts (constraints, architecture truths, operational fixes, explicit user rules). |
hold |
yes | no (unless explicitly requested) | Ambiguous/contextual signal worth keeping but not auto-injecting. |
discard |
no | no | Noise, tool traces, instruction artifacts, ephemeral chatter. |
Rules to enforce:
- Very short/low-information observations (e.g. <12 chars) →
discard. - Instruction-edit artifacts/raw tool traces (
<toolCall>, command dumps, “replace X with Y”) →discard. - Facts with ADR IDs, concrete file paths, or explicit runnable commands bias toward
allow. - If gate annotation parsing fails, mark
write_gate_fallback=trueand track drift (high fallback rate is a health smell).
2) Vector store schema (Typesense only)
Backend: memory_observations in Typesense. Qdrant is retired (per slog, 2026-02-28).
Minimum operational fields:
- Identity/source:
id,session_id,source,timestamp,updated_at - Content:
observation,observation_type,embedding - Write gate:
write_verdict,write_confidence,write_reason,write_gate_version,write_gate_fallback - Taxonomy:
category_id,category_confidence,category_source,taxonomy_version - Ranking/lifecycle:
merged_count,recall_count,retrieval_priority,stale,stale_tagged_at,last_used_at,superseded_by,supersedes
3) Category taxonomy (7 categories)
Use taxonomy v1 IDs:
jc:preferencesjc:rules-conventionsjc:system-architecturejc:operationsjc:memory-systemjc:projectsjc:people-relationships
4) Retrieval pipeline
- Query rewrite (fast model, hard timeout, fail-open to original query).
- Hybrid search (keyword + vector over
memory_observations). - Time decay ranking:
final_score = raw_score × exp(-0.01 × days_since_created)- stale memories get extra downweight.
- Cap results before injection (protect context budget).
- Budget profile:
lean: 2–3 hits, no rewrite, low-latency checksbalanced: 5–7 hits, default interactive modedeep: 10–15 hits, complex debugging/researchauto: choose profile from query complexity/context
5) Reflection cycle
observe → reflect → propose → triage (3 tiers) → promote to MEMORY.md
Triage tiers:
- Tier 1 auto-action: auto-promote / auto-reject / auto-merge using deterministic rules.
- Tier 2 LLM batch review: batch adjudication for undecided proposals.
- Tier 3 human review: only ambiguous/risky proposals; then promote/edit/reject.
Goal: keep MEMORY.md small, durable, and high-signal.
6) Nightly maintenance
Run idempotent maintenance to keep recall quality high:
- Dedup sweep (semantic similarity merge; maintain supersession chain).
- Stale pruning (mark old never-recalled observations stale; prune very old stale records conservatively).
- Stats emission (observation count, merges, stale volume, category distribution).
7) ADR map (read before changing architecture)
- ADR-0021 — memory system foundation.
- ADR-0068 — auto-triage pipeline.
- ADR-0077 — next phase (reflection + maintenance).
- ADR-0082 — Typesense as memory backend (Qdrant replaced).
- ADR-0094 → ADR-0100 — proposed evolution (write gate governance, taxonomy/budgets, forward triggers, graph/dual-search roadmap).
8) Writing observations (mandatory at session end)
Every session that produces a durable pattern, operational fix, or architectural insight MUST write observations before closing.
joelclaw send "memory/observation.submitted" -d '{
"observation": "<what was learned — concrete, reusable, future-tense useful>",
"category": "jc:operations",
"source": "pi-session",
"tags": ["stripe", "payout"]
}'
Use one send call per distinct observation. Batch is fine — fire them in a loop.
Category cheatsheet
| Category | Use for |
|---|---|
jc:operations |
How things work, API quirks, CLI patterns, operational fixes |
jc:rules-conventions |
Conventions, SOPs, team/project rules |
jc:system-architecture |
Topology, wiring, how components connect |
jc:projects |
Per-project facts, payout rates, product catalogs |
jc:preferences |
Joel's explicit preferences |
jc:people-relationships |
People, contacts, roles |
jc:memory-system |
Memory system itself |
What makes a good observation
- Concrete: "Stripe Report Run requires explicit
payment_metadata[product]column incolumnsparam or it returns blank" — not "Stripe has metadata" - Reusable: will this still be true next month?
- Actionable: an agent reading this cold should know what to do differently
- Not a transcript: no "the user asked me to", no raw tool output, no "I discovered that"
What to skip
- Instruction artifacts, tool traces, ephemeral command outputs
- Facts already in skills or ADRs (skills are the durable home; observations are for recall/search)
- Anything under 12 chars — the write gate discards it
9) Operations commands (slog + recall)
# Record memory-system changes
slog write --action configure --tool memory-system --detail "<what changed>" --reason "<why>"
# Inspect recent operational history
slog tail --count 50
# Default recall
joelclaw recall "<query>" --budget balanced --limit 7
# Deep recall for hard debugging
joelclaw recall "<query>" --budget deep --limit 10
# Inspect memory-system category specifically
joelclaw recall "<query>" --category jc:memory-system --limit 10
# Include held memories when needed
joelclaw recall "<query>" --include-hold --raw
9) Canonical code paths
- Observe:
packages/system-bus/src/inngest/functions/observe.ts - Write gate:
packages/system-bus/src/memory/write-gate.ts - Taxonomy:
packages/system-bus/src/memory/taxonomy-v1.ts - Recall adapter:
packages/cli/src/capabilities/adapters/typesense-recall.ts - Reflect/propose:
packages/system-bus/src/inngest/functions/reflect.ts,promote.ts - Nightly maintenance:
packages/system-bus/src/inngest/functions/memory/nightly-maintenance.ts
10) Non-negotiables
- Memory stores patterns, not transcript noise.
- No silent failure paths: emit telemetry on every transition.
- Keep retrieval bounded; never flood context windows.
- Keep
MEMORY.mdcurated; do not auto-append raw observations.
More from joelhooks/joelclaw
cli-design
Design and build agent-first CLIs with HATEOAS JSON responses, context-protecting output, and self-documenting command trees. Use when creating new CLI tools, adding commands to existing CLIs (joelclaw, slog), or reviewing CLI design for agent-friendliness. Triggers on 'build a CLI', 'add a command', 'CLI design', 'agent-friendly output', or any task involving command-line tool creation.
129k8s
>-
88docker-sandbox
Create, manage, and execute agent tools (claude, codex) inside Docker sandboxes for isolated code execution. Use when running agent loops, spawning tool subprocesses, or any task requiring process isolation. Triggers on "sandbox", "isolated execution", "docker sandbox", "safe agent execution", or when working on agent loop infrastructure.
86joel-writing-style
Joel's writing voice and style guide for joelclaw.com content. Use when writing, editing, or reviewing any blog post, essay, book chapter, or prose content for joelclaw.com. Also use when asked to 'write like Joel,' 'match Joel's voice,' 'draft a post,' 'write content for the blog,' or 'review this for voice.' This skill captures Joel's specific writing patterns derived from ~90,000 words of published content spanning 2012–2026. Cross-reference with copy-editing and copywriting skills for marketing-specific copy.
81task-management
Manage Joel's task system in Todoist. Triggers on: 'add a task', 'create a todo', 'what's on my list', 'today's tasks', 'what do I need to do', 'remind me to', 'inbox', 'complete', 'mark done', 'weekly review', 'groom tasks', 'what's next', or when actionable items emerge from other work. Also triggers when Joel mentions something he needs to do in passing — capture it.
54skill-review
Audit and maintain the joelclaw skill inventory. Use when checking skill health, fixing broken symlinks, finding stale skills, or running the skill garden. Triggers: 'skill audit', 'check skills', 'stale skills', 'skill health', 'skill garden', 'broken skill', 'skill review', 'fix skills', 'garden skills', or any task involving skill inventory maintenance.
49