manage-memory
关于
This skill maintains Claude Code's persistent memory by organizing MEMORY.md as a concise index and extracting detailed topics into separate files. It automatically detects stale entries, verifies accuracy against the current project, and enforces a 200-line limit. Use it when MEMORY.md approaches the line limit, after productive sessions, or when project changes may have outdated memory entries.
快速安装
Claude Code
推荐npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/manage-memory在 Claude Code 中复制并粘贴此命令以安装该技能
技能文档
Manage Memory
Maintain Claude Code's persistent memory dir → accurate, concise, useful across sessions. MEMORY.md loaded into system prompt every conv — lines after 200 truncated → file must be lean index pointing to topic files for detail.
Use When
- MEMORY.md nearing 200-line limit
- Session produced durable insights worth preserving (new patterns, arch decisions, debugging solutions)
- Topic section in MEMORY.md > 10-15 lines → extract
- Project state changed (renamed files, new domains, updated counts) → entries may be stale
- Starting new work area → check if relevant memory exists
- Periodic maintenance between sessions
In
- Req: Access to memory dir (typically
~/.claude/projects/<project-path>/memory/) - Opt: Specific trigger ("MEMORY.md too long", "just finished major refactor")
- Opt: Topic to add / update / extract
Do
Step 1: Assess Current State
Read MEMORY.md + list all files in memory dir:
wc -l <memory-dir>/MEMORY.md
ls -la <memory-dir>/
Check line count vs 200-line limit. Inventory existing topic files.
→ Clear picture of total lines, # topic files, which sections exist in MEMORY.md.
If err: Memory dir doesn't exist → create. MEMORY.md doesn't exist → minimal one w/ # Project Memory header + ## Topic Files section.
Step 2: ID Stale Entries
Compare memory claims vs current project state. Common staleness:
- Count drift: File counts, skill counts, domain counts changed after additions/removals
- Renamed paths: Files / dirs moved / renamed
- Superseded patterns: Workarounds no longer needed after fixes
- Contradictions: Two entries saying diff things about same topic
Use Grep to spot-check:
# Example: verify a skill count claim
grep -c "^ - id:" skills/_registry.yml
# Example: verify a file still exists
ls path/claimed/in/memory.md
→ List of stale entries w/ correct current vals.
If err: Can't verify claim (refs external state) → leave but add (unverified) note rather than silently preserve potentially wrong info.
Step 3: Decide What to Add
For new entries, apply filters before writing:
- Durability: Will this be true next session? Avoid session-specific (current task, in-progress, temporary).
- Non-duplication: CLAUDE.md / project docs already cover? Don't duplicate — memory for things NOT captured elsewhere.
- Verified: Confirmed across multi interactions, or single obs? Single → verify vs project docs before writing.
- Actionable: Does knowing change behavior? "Sky blue" ≠ useful. "Exit code 5 = quoting err → use temp files" changes how you work.
Exception: User explicitly asks to remember → save immediately, no multi confirmations needed.
→ Filtered list worth adding, each meeting durability + non-dup + verified + actionable.
If err: Unsure if worth keeping → err toward keeping briefly in MEMORY.md — easier to prune later than rediscover.
Step 4: Extract Oversize Topics
Section > ~10-15 lines → extract to dedicated topic file:
- Create
<memory-dir>/<topic-name>.mdw/ descriptive header - Move detailed content from MEMORY.md → topic file
- Replace section in MEMORY.md w/ 1-2 line summary + link:
## Topic Files
- [topic-name.md](topic-name.md) — Brief description of contents
Naming conventions:
- Lowercase kebab-case:
viz-architecture.md, notVizArchitecture.md - Name by topic, not chronology:
patterns.md, notsession-2024-12.md - Group related: combine "R debugging" + "WSL quirks" →
patterns.mdvs one file per fact
→ MEMORY.md stays < 200 lines. Each topic file self-contained + readable w/o MEMORY.md ctx.
If err: Topic file < 5 lines → probably not worth extracting → leave inline.
Step 5: Update MEMORY.md
Apply changes: remove stale, add new, update counts, ensure Topic Files section lists all dedicated files.
MEMORY.md structure:
# Project Memory
## Section 1 — High-level context
- Bullet points, concise
## Section 2 — Another topic
- Key facts only
## Topic Files
- [file.md](file.md) — What it covers
Guidelines:
- Each bullet 1-2 lines max
- Inline formatting (
code, bold) for scanability - Most frequently needed ctx first
- Topic Files section always last
→ MEMORY.md < 200 lines, accurate, working links to all topic files.
If err: Can't get < 200 after extraction → ID least-freq-used section + extract. Every section candidate — even project structure overview can go to topic file if needed, leaving 1-line summary.
Step 6: Verify Integrity
Final check:
- Line count: MEMORY.md < 200
- Links: Every topic file referenced exists
- Orphans: Topic files not referenced in MEMORY.md
- Accuracy: Spot-check 2-3 factual claims vs project state
wc -l <memory-dir>/MEMORY.md
# Check for broken links
for f in $(grep -oP '\[.*?\]\(\K[^)]+' <memory-dir>/MEMORY.md); do
ls <memory-dir>/$f 2>/dev/null || echo "BROKEN: $f"
done
# Check for orphan files
ls <memory-dir>/*.md | grep -v MEMORY.md
→ Line count < 200, no broken links, no orphans, spot-checked claims accurate.
If err: Fix broken links (update / remove). Orphans → add ref in MEMORY.md / delete if no longer relevant.
Check
- MEMORY.md < 200 lines
- All referenced topic files exist on disk
- No orphan
.mdin memory dir (every file linked from MEMORY.md) - No stale counts / renamed paths
- New entries meet durability / non-dup / verified / actionable
- Topic files have descriptive headers + self-contained
- MEMORY.md reads as quick-ref, not changelog
Traps
- Memory file pollution: Writing every session obs to memory. Most findings session-specific + don't need persisting. Apply 4 filters (Step 3) before writing.
- Stale counts: Updating code but not memory. Counts (skills, agents, domains, files) drift silently. Always verify vs source of truth before trusting memory.
- Chronological organization: "When I learned" vs "what it's about". Topic-based (
patterns.md,viz-architecture.md) > date-based files. - Duplicate CLAUDE.md: CLAUDE.md = authoritative project instructions. Memory captures things NOT in CLAUDE.md — debugging insights, arch decisions, workflow prefs, cross-project patterns.
- Over-extraction: Topic file for every 3-line section. Only extract when > ~10-15 lines. Small sections inline.
- Forget 200-line limit: MEMORY.md loaded every system prompt. Lines after 200 silently truncated. Grows past → bottom content effectively invisible.
→
write-claude-md— CLAUDE.md captures project instructions; memory captures cross-session learningprune-agent-memory— inverse of manage-memory: auditing, classifying, selectively forgetting storedwrite-continue-here— structured continuation file for session handoff; complements memory as short-term bridgeread-continue-here— read + act on continuation at session start; consumption side of handoffcreate-skill— new skills may produce memory-worthy patternsheal— self-healing may update memory as part of integration stepmeditate— meditation sessions may surface insights worth persisting
GitHub 仓库
相关推荐技能
qmd
开发这是一个本地搜索和索引的CLI工具,支持BM25、向量搜索和重排序功能。开发者可以用它快速索引本地文件(如Markdown文档)并进行混合搜索,特别适合代码库或文档的本地检索。它还提供MCP模式,能轻松集成到Claude开发环境中使用。
subagent-driven-development
开发该Skill用于在当前会话中执行包含独立任务的实施计划,它会为每个任务分派一个全新的子代理并在任务间进行代码审查。这种"全新子代理+任务间审查"的模式既能保障代码质量,又能实现快速迭代。适合需要在当前会话中连续执行独立任务,并希望在每个任务后都有质量把关的开发场景。
mcporter
开发mcporter Skill 让开发者能在Claude中直接管理和调用MCP服务器。它支持列出可用服务器、调用工具、处理OAuth认证以及管理服务器守护进程。开发者可以通过命令行式交互快速执行`mcporter list`查看服务器,或使用`mcporter call`直接调用工具,简化了MCP工作流程。
adk-deployment-specialist
开发这是一个用于部署和编排Google Vertex AI ADK智能体的Claude Skill,专为构建生产级多智能体系统而设计。它支持通过A2A协议进行智能体通信,提供代码执行沙箱和记忆库功能,并能处理智能体发现与任务提交。当开发者需要部署ADK智能体或编排多智能体协作时,可使用此Skill来简化Vertex AI Agent Engine的部署流程。
