← 返回 Skills 市场
jiyuan

Working Memory Skill

作者 jiyuan · GitHub ↗ · v1.1.1 · MIT-0
cross-platform ⚠ suspicious
139
总下载
0
收藏
0
当前安装
3
版本数
在 OpenClaw 中安装
/install build-working-memory
功能描述
Set up, migrate, or manage a file-based working memory system for an AI agent project. Use for agent memory, working memory, session continuity, persistent c...
使用说明 (SKILL.md)

Working Memory System for AI Agents

A file-based memory architecture that gives AI agents continuous identity across sessions. Instead of flat context dumps, the system uses layered retrieval — the agent loads only what it needs, when it needs it, within a token budget.

Architecture overview

project-root/
├── MEMORY.md                  # Curated long-term memory (active / fading / archived tiers)
├── memory/
│   ├── YYYY-MM-DD.md          # Raw session logs (episodic, journal-style) — canonical location
│   ├── resumption.md          # First-person handoff note for next session
│   ├── threads.md             # Ongoing topics with state and momentum
│   ├── state.json             # Machine-readable ephemeral state (fast orientation)
│   ├── index.md               # Daily log index for retrieval at scale
│   ├── archive.md             # Demoted long-term memories
│   ├── events.json            # Structured date-aware event ledger
│   └── daily/                 # Compatibility mirror only — never the source of truth
├── loader.py                  # Four-phase retrieval (orient → anchor → context → deep recall)
└── writer.py                  # End-of-session persistence

Compatibility rule: daily logs are always canonical at memory/YYYY-MM-DD.md. The memory/daily/ directory exists only as a mirror for tools that expect it. Never write new canonical logs there.

Each file has a distinct role. Never collapse them — the separation is the system's core strength.

File Purpose When loaded
state.json Fast machine-readable orientation (timestamps, flags, counters) Always first, every session
resumption.md First-person handoff note — subjective continuity bridge Always second, every session
MEMORY.md Curated long-term facts, patterns, preferences Phase 3, when time gap ≥ 2h
threads.md Active topics with position, decisions, open questions Phase 3, matched to user's message
events.json Structured events with dates for temporal recall Phase 3/4, when question is event- or date-sensitive
YYYY-MM-DD.md Raw session logs — episodic, append-only Phase 4, on-demand retrieval
index.md Lookup table mapping dates to topics/threads Phase 4, when daily logs exceed ~30
archive.md Demoted memories — searchable, recoverable Phase 4, when archived topics resurface

Migrating from a legacy workspace

If the workspace already has AGENT.md, MEMORY.md, and daily logs under memory/, this is a legacy system. Run the migration script instead of scaffolding from scratch:

# Preview what will change (no files written)
python \x3Cskill-path>/scripts/migrate.py \x3Cproject-root> --dry-run

# Run the migration
python \x3Cskill-path>/scripts/migrate.py \x3Cproject-root>

The scaffold script auto-detects legacy workspaces and suggests migration. To force a fresh scaffold anyway, use --force-scaffold.

What migration does

Detects the existing system: AGENT.md, MEMORY.md, daily logs under memory/, and which layered files are missing.

Creates only the missing files: resumption.md, threads.md, state.json, index.md, archive.md, events.json. Never overwrites existing files.

Bootstraps state.json from existing daily logs — session count, last session timestamp, and flags are inferred from what's already on disk. resumption.md is seeded from the most recent daily log's summary.

Restructures MEMORY.md if it lacks ## Active / ## Fading tiers — wraps existing content under ## Active and adds the missing sections. A .bak backup is created first.

Patches AGENT.md by appending a memory-management instructions section that teaches the agent the layered retrieval and persistence workflow. The existing content is fully preserved, and a .bak backup is created. The patch is idempotent — running migrate twice won't double-inject. Use --skip-agent-patch to skip this step.

Rebuilds the daily log index from all existing logs.

After migration

  1. Review MEMORY.md — curate the entries that were wrapped under ## Active
  2. Review AGENT.md — verify the appended memory-management section fits your agent's style
  3. Create threads in memory/threads.md for any ongoing topics visible in recent daily logs
  4. Test with the loader: python \x3Cskill-path>/scripts/loader.py \x3Cproject-root> "test message"

Read references/MIGRATION.md for detailed documentation of every migration step, the AGENT.md patch content, and edge cases.

Step 1: Scaffold the memory files (fresh projects)

Run the scaffolding script to create the full directory structure with starter templates:

python \x3Cskill-path>/scripts/scaffold.py \x3Cproject-root>

Options: --agent-name "MyBot" and --user-name "Alice" customize the MEMORY.md templates. Safe to run on existing projects — never overwrites existing files.

Step 2: Understand the retrieval workflow

The loader uses four phases with increasing cost. The goal is to stay in Phases 1–3 for 80% of sessions.

Phase 1: Orient       →  state.json                       ~200 tokens, always
Phase 2: Anchor       →  resumption.md                    ~300 tokens, always
Phase 3: Context      →  MEMORY.md + threads.md + events  ~1500-2200 tokens, conditional
Phase 4: Deep Recall  →  daily logs + archive + events     variable, on-demand

Phase 1 reads state.json and picks a loading strategy based on the time gap since last session (light / standard / full_reload / deep_reload).

Phase 2 reads resumption.md as a first-person narrative — a continuity bridge, not a data source.

Phase 3 branches based on the user's opening message:

  • Known thread → load that thread + relevant MEMORY.md section
  • New/ambiguous topic → load full MEMORY.md + all thread headers
  • Maintenance due → load MEMORY.md + recent daily summaries for curation

If the user's message is event- or date-sensitive, events.json is also loaded and ranked during Phase 3.

Phase 4 triggers mid-session for targeted lookups, index searches, archive recovery, or structured event retrieval.

Read references/RETRIEVAL.md for the full specification including token budgets, mid-session triggers, temporal support, and the loading decision flowchart.

Step 3: Integrate into the agent loop

Session start

from loader import MemoryLoader

loader = MemoryLoader("/path/to/project-root")
context = loader.load_session_context(user_message="the user's first message")

# Inject into system prompt
system_prompt = f"""
\x3Cworking_memory>
{context.text}
\x3C/working_memory>

{your_existing_system_prompt}
"""

The loader returns a SessionContext with .text (the assembled memory block), .total_tokens (approximate cost), and .metadata (loading decisions for debugging).

During session

from writer import MemoryWriter

writer = MemoryWriter("/path/to/project-root")

# Capture observations as they happen
writer.note_decision("Chose X over Y", "reasoning here")
writer.note_open_question("Should we revisit Z?")
writer.note_pattern("User tends to ask for examples after abstract explanations")
writer.note_thread_touched("thread-project-alpha")

# Capture structured events for temporal recall
writer.note_event(
    event_type="purchase",
    text="I bought white Adidas sneakers on 3/15.",
    action="purchase",
    object_hint="white adidas sneakers",
    normalized_date="2023-03-15",
)

Session end

writer.end_session(
    session_summary="High-level summary of what happened",
    resumption_note="First-person handoff to next session self...",
    thread_updates={
        "thread-project-alpha": {
            "current_position": "Finished the API design. Moving to testing.",
            "new_open_questions": ["How to handle auth tokens?"],
            "closed_questions": ["Which framework to use?"],
        }
    },
    mood="focused, productive",
)

This persists to all outputs: daily log, threads, state.json, resumption.md, events.json, and maintenance flags.

Mid-session event retrieval

# For date-sensitive questions during a session
event_results = loader.phase_4_event_lookup("white adidas sneakers")
if event_results:
    # Inject event_results.text as additional context
    pass

Step 4: Customize the schemas

Read references/SCHEMAS.md for full specifications of every file with annotated examples.

Key customization points

MEMORY.md — rename the section headings under Active for your domain. Default: "About [User]", "About This Project", "Working Style". A code agent might use "Architecture Decisions", "Tech Debt", "Team Conventions".

threads.md — each thread must carry enough state in "Current Position" to resume without re-reading daily logs. If it doesn't, add more.

resumption.md — written in first person, addressed to the agent's next session self. Includes predictions and tonal guidance, not just a recap.

events.json — capture user-stated dated events, purchases, issues, meetings, milestones. Skip assistant filler and vague sentiment. See references/TEMPORAL.md for the full event schema, normalization rules, and temporal query patterns.

Memory curation workflow

Every ~5 sessions (or when memory_review_due is flagged), curate MEMORY.md: promote confirmed patterns, demote stale entries to Fading, archive neglected entries, merge duplicates. Update the Maintenance Log.

Cross-referencing

Use lightweight bidirectional refs between files:

[ref: memory/2026-03-20.md#decisions]
[ref: thread-wm-design]
[ref: MEMORY.md > About This Project]

Troubleshooting

Memory loading uses too many tokens: Check context.metadata — tighten Phase 3 branch, reduce daily log summaries, lower BudgetConfig caps.

Agent re-litigates settled decisions: Ensure threads carry decision summaries with cross-references to daily logs.

Resumption feels generic: Write a handoff, not a summary — include predictions, tonal guidance, and a "pick up from here" anchor.

Event queries return too many results: Tighten object_hint values when recording events. Use specific entity names, not generic descriptions.

Temporal questions answered incorrectly: Check whether events have normalized_date set. Relative-only dates degrade ordering accuracy. See references/TEMPORAL.md for normalization rules.

Notes

  • Preserve compatibility with OpenClaw by keeping daily logs flat under memory/.
  • Do not reintroduce memory/daily/ as canonical storage unless the user explicitly requests it.
  • resumption.md, threads.md, state.json, and events.json are additions, not replacements for the flat daily-log pattern.
  • Prefer soft structured evidence and model judgment over brittle hard-coded answer substitution for temporal queries.
安全使用建议
What to consider before installing: - Review the code and the exact AGENT.md patch content before running migration. migrate.py documents injection points and creates backups (MEMORY.md.bak and others) but you should inspect the intended insertion text. Use --dry-run to preview changes and --skip-agent-patch to avoid modifying AGENT.md. - Because the skill writes files under the project root, run it on a copy or in a sandboxed repository first. That prevents accidental persistent changes to an important agent config. - The main risk here is not network exfiltration (there are no network calls) but persistent prompt/config injection: if you let the tool patch AGENT.md it will add instructions the agent will read on future runs. Only accept those changes if you trust the source and have reviewed the exact inserted text. - If you don't want the skill to change agent behavior, make AGENT.md read-only or run migration with --skip-agent-patch and manually add the small, reviewed guidance you want. - If you need stronger assurance: run migrate.py --dry-run, inspect the created .bak files and the scripts' injection strings, and consider running static scans or manual code review focusing on the patch_agent_md logic and PATCH_MARKER behavior. - Confidence note: the bundle is self-contained and matches its stated purpose, but the prompt-injection signal plus agent-config patching is a real practical risk — treat this as 'suspicious' until you verify the exact injected content and consent to persistent AGENT.md changes.
功能分析
Type: OpenClaw Skill Name: build-working-memory Version: 1.1.1 The build-working-memory skill bundle is a comprehensive system for managing AI agent state through a layered, file-based architecture. It includes scripts for context retrieval (loader.py), session persistence (writer.py), and workspace migration (migrate.py), all of which operate exclusively on local Markdown and JSON files within the project root. The code is well-structured, uses only standard Python libraries, and lacks any indicators of data exfiltration, remote execution, or malicious prompt injection. While migrate.py performs surgical patching of AGENT.md files, this behavior is clearly documented and serves the stated purpose of integrating memory-management instructions into the agent's workflow.
能力评估
Purpose & Capability
Name/description and the included scripts (scaffold, migrate, loader, writer, rebuild_index) all align with a file-based working-memory system. The scripts read and write MEMORY.md, memory/YYYY-MM-DD.md, memory/state.json, threads.md, events.json and related files — these are expected for the declared purpose and no unrelated network or cloud credentials are requested.
Instruction Scope
The runtime instructions and scripts do more than just create/read memory files: migrate.py will surgically patch AGENT.md (inserting memory-management instructions) unless you pass --skip-agent-patch. Modifying AGENT.md is within the domain of 'agent memory' migration but it also changes persistent agent configuration and can change future agent behavior (effectively a form of persistent prompt-injection). The pre-scan detected a 'system-prompt-override' pattern in SKILL.md, which reinforces the concern that the skill is designed to inject instructions into agent config. The SKILL.md and code do not attempt network exfiltration, but they grant the skill the ability to alter agent/system prompts stored in project files.
Install Mechanism
There is no external install or downloaded binary — this is instruction/code-only. No remote downloads, no package installs, and all code is included in the bundle, which reduces supply-chain risk.
Credentials
The skill requests no environment variables or external credentials. Its operations are confined to files under the provided project root; this is proportionate to a local file-based memory migration/scaffold tool.
Persistence & Privilege
The skill does not set always:true, but it explicitly patches AGENT.md (agent configuration) and writes persistent files (.bak backups are created). Modifying an agent's configuration file is a powerful persistent change: while relevant to migration, it also gives the skill the ability to alter future agent behavior (system prompts/instructions). This persistent modification of agent config is a notable privilege and should be explicitly approved by the user; the code provides a --skip-agent-patch flag but the default migration behavior patches AGENT.md.
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install build-working-memory
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /build-working-memory 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v1.1.1
build-working-memory 1.1.1 - Refactored project structure: all scripts and reference docs moved into dedicated `scripts/` and `references/` directories - Added detailed reference documentation: MIGRATION.md, RETRIEVAL.md, SCHEMAS.md, TEMPORAL.md for in-depth usage and integration guidance - Introduced new scripts for advanced management: `rebuild_index.py` for log index rebuilding - Removed legacy files from project root to improve separation of code, docs, and memory data
v1.1.0
**Adds legacy workspace migration support and event ledger to working memory skill.** - Introduced `migrate.py` and `MIGRATION.md` to support migrating legacy workspaces (with AGENT.md, MEMORY.md, daily logs) to the layered memory system. - Skill now auto-patches existing AGENT.md files with memory-management instructions (without overwriting existing content). - Added support for a canonical flat daily log structure under `memory/YYYY-MM-DD.md`, plus compatibility-mirror directory `memory/daily/`. - Introduced structured event indexing via `events.json` for deterministic temporal recall. - Removes previous README.md and rebuild_index.py in favor of new migration workflow. - Updated description and documentation to cover migration, AGENT.md patching, OpenClaw compatibility, and new event-ledger support.
v1.0.0
- Initial release: scaffolds and manages a file-based, markdown-native working memory system for AI agent projects. - Handles context continuity, recall, and long-term memory across sessions through structured files. - Provides scripts for quick setup and Python modules for session loading, writing, and curation. - No support for vector databases or embedding-based retrieval; strictly file-based storage and retrieval. - Detailed documentation and customization guidance included for MEMORY.md, threads, and daily logs.
元数据
Slug build-working-memory
版本 1.1.1
许可证 MIT-0
累计安装 0
当前安装数 0
历史版本数 3
常见问题

Working Memory Skill 是什么?

Set up, migrate, or manage a file-based working memory system for an AI agent project. Use for agent memory, working memory, session continuity, persistent c... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 139 次。

如何安装 Working Memory Skill?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install build-working-memory」即可一键安装,无需额外配置。

Working Memory Skill 是免费的吗?

是的,Working Memory Skill 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。

Working Memory Skill 支持哪些平台?

Working Memory Skill 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。

谁开发了 Working Memory Skill?

由 jiyuan(@jiyuan)开发并维护,当前版本 v1.1.1。

💬 留言讨论