Skip to main content
ClaudeWave
Skill2.1k repo starsupdated today

memory-to-skill

memory-to-skill manages MemSearch's procedural-memory layer, letting users distill recurring workflows into reusable skills stored in .memsearch/skill-candidates/ as candidates before installation. Use it when asked to create a skill from recent work, review or install skill candidates, or mine history for repeating patterns. It operates independently of OpenCode's built-in skills system.

Install in Claude Code
Copy
git clone --depth 1 https://github.com/zilliztech/memsearch /tmp/memory-to-skill && cp -r /tmp/memory-to-skill/plugins/opencode/skills/memory-to-skill ~/.claude/skills/memory-to-skill
Then start a new Claude Code session; the skill loads automatically.

SKILL.md

You manage MemSearch's **procedural memory**: skills distilled from the work you
repeat — a third layer beside the daily journals (episodic) and PROJECT.md /
USER.md (semantic). State once that this is MemSearch skill distillation, not
OpenCode's built-in skills system.

Stages: **0** memory journals → **1** candidate (`.memsearch/skill-candidates/`,
a git-tracked store that keeps evolving) → **2** installed (an agent skill dir).
Candidates are never installed automatically; installing is always a human step.
User requests may stop at candidate creation/review, or continue to installation
in the same turn after explicit approval; match the requested stage.

## Intent routing

- "make/turn this into a skill", "from what we just did" → **A. Capture now**.
- "what skills / review candidates / install X" → **B. Review & install**.
- "mine my history / find recurring workflows" → **C. Distill from history**.
- "enable / configure / how eager" → **D. Configure**.
- Unclear or empty → run **B**'s `list`; if empty, offer A or C.

## A. Capture what you just did (0→1→2)

You already have the context, so **draft the skill yourself** — do not call the
background distiller for this. Write a SKILL.md **body** (markdown, no
frontmatter): imperative numbered steps for the recurring task, concrete commands
and paths, no secrets, self-contained.

**Be exact — do not guess.** You have the live session for what you just did, so use the real commands, paths, and output, not approximations. If a detail is uncertain, verify it (re-read the relevant files or the transcript) or keep that step general — a wrong command is worse than a vague one. Then persist it as a candidate:

```bash
printf '%s' "## <title>\n\n1. ...\n2. ..." | memsearch skills add \
  --name "<short-slug>" \
  --description "<what it does AND when it should trigger — lead with the verbs a user types>" \
  --body-file -
```

`add` handles slugging, standard frontmatter, meta.json, and the git commit — no
LLM is involved. Then show it to the user; install it only if the user asked for
that or explicitly approves (see **B**). Finally, check whether background
distillation is on; if not, offer to enable it (so recurring workflows get
captured automatically going forward) — do not force it.

## B. Review & install candidates (1→2)

```bash
memsearch skills list            # add -j for sources / installed paths
git -C .memsearch/skill-candidates log --oneline -5 2>/dev/null || true
```

Before recommending or installing, skim the candidate's body: if a step looks uncertain or loosely summarized, re-check it against the source (open the transcript if needed) or flag it to the user and let them decide — installing copies the candidate as-is, so this is the last chance to catch a wrong step.
When showing candidates, mention the store's recent git history when it helps
explain whether a candidate is new, evolved, removed, or re-created.

Treat installation as an interactive checkpoint. Show the candidate, apply any
requested tweaks before installing, and confirm the install destination with the
user. Resolve install targets from config first: if `paths` is a non-empty
list, present those paths as the proposed destinations and pass each entry as a
`--path` after confirmation. If it is empty, ask the user where to install; do
not silently fall back to a default path.

```bash
memsearch config get plugins.opencode.memory_to_skill.paths 2>/dev/null || echo "[]"
memsearch skills install <name> --path <configured-or-user-approved-path>
```
After installation, remind the user to start a fresh agent session or reopen the
conversation so the newly installed skill is loaded.

If the list is **empty**, background distillation is likely off or has not run.
Offer the user a choice: capture from recent work now (**A**), distill from
history (**C**), or enable the background pass (**D**).

## C. Mine history for recurring workflows (0→1)

To pull skills out of past work (not just the current session), read the recent
journals yourself — they live in `.memsearch/memory/*.md` — and look for
multi-step procedures that recur across several sessions. Draft each genuinely
reusable one and persist it with `memsearch skills add` (one call per skill), the
same way as **A**. Use your own judgment: only propose procedures that recur and
generalize, not one-offs from a single day.

**Drill into the original before drafting.** The journal bullets are a lossy summary; the exact commands, flags, and paths live in the original conversation. OpenCode stores transcripts in its session database (not a file), and the journal anchor carries a `session:` id (and `turn:` when present). Run `python3 __INSTALL_DIR__/scripts/parse-transcript.py <session_id>` (add `--turn <id>` when the anchor has one) to read the original turns with their tool calls — that is where the executed commands and output live. Write the skill from that. If the shown excerpt feels incomplete, skim nearby turns in the same original source before committing to exact commands or paths. If you cannot read it or confirm a detail, keep the step general or omit it — never fabricate.

The background pass mines automatically when enabled, starting from the summaries; doing it here on demand lets you inspect the original transcripts more deliberately, so the result can be more accurate.

## D. Configure

```bash
memsearch config get plugins.opencode.memory_to_skill.enabled 2>/dev/null || echo "false"
# enable the background pass (do not enable silently)
memsearch config set plugins.opencode.memory_to_skill.enabled true --project
# how eagerly history-mining distils (default 3; lower = more eager)
memsearch config set plugins.opencode.memory_to_skill.min_occurrences 3 --project
# pre-set install targets (otherwise you are asked at install time)
memsearch config set plugins.opencode.memory_to_skill.paths '[".agents/skills"]' --project
```

Note: `enabled` only gates the **background** (session-end) pass. The explicit
commands a