Learn-skills.dev handoff-memory
Create, refresh, validate, and resume shared HANDOFF and memory documents for a repository, a workspace-wide cross-repo context, or a workstream inside a larger workspace. Use when asked to write a handoff, checkpoint progress, resume prior work, or standardize project-state notes in Git-trackable files such as `docs/HANDOFF.md`, `_memory/HANDOFF.md`, or `_memory/workstreams/checkout-flow/HANDOFF.md`.
git clone https://github.com/NeverSight/learn-skills.dev
T=$(mktemp -d) && git clone --depth=1 https://github.com/NeverSight/learn-skills.dev "$T" && mkdir -p ~/.claude/skills && cp -r "$T/data/skills-md/17-sss/agent-skills/handoff-memory" ~/.claude/skills/neversight-learn-skills-dev-handoff-memory && rm -rf "$T"
data/skills-md/17-sss/agent-skills/handoff-memory/SKILL.mdHandoff Memory
Overview
Keep shared memory documents close to the work they describe. For a single repository, keep the canonical handoff in the repo. For a multi-repository workspace, keep workspace-wide memory in the workspace root and workstream-specific memory under dedicated workstream folders.
This skill keeps one canonical handoff per scope and adds lightweight operational tooling:
- resolve the right document path
- create or refresh the canonical file
- validate that the document is structurally usable
- check whether the document is stale before trusting it
- optionally write timestamped session snapshots without making them the primary state
Compatibility and Prerequisites
must be available inpython3
to run the bundled scripts.PATH
must be available ingit
for branch metadata and freshness checks.PATH- The skill still resolves paths and validates documents outside Git, but stale checks are less informative there.
- All bundled scripts are non-interactive and expose
. Prefer running them directly instead of recreating their logic by hand.--help
Default Workflow
Use this as the default flow unless the user already has a stronger convention:
-
Resolve or initialize the canonical document. Run
. Addscripts/create_handoff.py --project-root <path> --scope auto --document handoff --format json
when the task belongs to one specific repo combination inside a larger workspace.--workstream <name> -
Read the canonical document before changing it. Preserve still-valid context. Remove stale claims that would mislead the next session.
-
Update the canonical document with the current state. Keep it short, explicit, and action-oriented.
-
Validate it before ending the session. Run
.scripts/validate_handoff.py --project-root <path> --scope auto --document handoff -
When resuming, check staleness before trusting old notes. Run
.scripts/check_staleness.py --project-root <path> --scope auto --document handoff
In mixed multi-repo workspaces, do not treat the parent folder as automatically workspace-wide. When the active handoff or a dominant workstream already names the relevant repositories, let that narrower repo set drive resume-time validation. Use
--workspace-wide only when the user explicitly wants status for every child repository.
For resume-style requests such as "continue", "resume", or "pick up where we left off", treat
Next Actions as the default execution queue and Resume Prompt as the default execution framing. Do not reopen design direction that the handoff already narrowed unless the user asks to rethink it or the current repo state clearly invalidates it.
Use
--snapshot with create_handoff.py only when the user wants a timestamped checkpoint that is worth preserving. Always pair it with --snapshot-kind and a short --snapshot-reason. Do not make snapshots the default shared state.
For day-to-day agent behavior, follow
references/agent-usage-best-practices.md.
Path Rules
- Prefer an explicit
when the project already defines a canonical location.--handoff-path - In repo scope, reuse an existing shared handoff file in a recognized location such as
,docs/HANDOFF.md
, ormemories/HANDOFF.md
.HANDOFF.md - In workspace scope, keep cross-repo memory under
._memory/ - If no repo handoff exists, create
.docs/HANDOFF.md - If no workspace handoff exists, create
._memory/HANDOFF.md - For workspace-wide memory, use these defaults:
for workspace-wide summary and active workstream index_memory/HANDOFF.md
for durable workspace structure_memory/WORKSPACE.md
for cross-repo architecture or policy choices_memory/DECISIONS.md
for repeatable conventions_memory/PATTERNS.md
- For workstream-specific memory, use these defaults:
_memory/workstreams/<name>/HANDOFF.md_memory/workstreams/<name>/WORKSTREAM.md_memory/workstreams/<name>/DECISIONS.md_memory/workstreams/<name>/PATTERNS.md
- Most sessions should only update the canonical handoff for the active scope. Touch companion workspace or workstream documents only when durable shared context changed.
- Optional snapshots live under
,docs/handoffs/
, or_memory/handoffs/
._memory/workstreams/<name>/handoffs/ - Avoid
,.codex
,.claude
, or.windsurf
as the default shared mutable handoff location..agents
Scope Guidance
Repo Scope
Use repo scope when the task belongs to one repository.
- Canonical file:
docs/HANDOFF.md - Session snapshots:
docs/handoffs/*.md - Keep implementation-level detail here
Workspace Scope
Use workspace scope when the agent session starts from a parent folder that coordinates multiple repositories and the task spans more than one of them at the workspace-wide level.
- Canonical file:
_memory/HANDOFF.md - Session snapshots:
_memory/handoffs/*.md - Keep workspace-wide coordination and durable shared context here
- Leave repo-specific implementation detail in each repo's own
docs/HANDOFF.md
Workstream Scope
Use workstream scope when the same workspace hosts multiple independent repo combinations and one handoff per workspace would blur them together.
- Canonical file:
_memory/workstreams/<name>/HANDOFF.md - Durable overview:
_memory/workstreams/<name>/WORKSTREAM.md - Session snapshots:
_memory/workstreams/<name>/handoffs/*.md - Keep only the repos relevant to that initiative in the workstream handoff
- Prefer workstream names that describe the initiative, not just the repo list
Content Rules
- Keep the document scan-friendly. The next session should understand it in under a minute.
- Start with a strong
.TL;DR - Prefer exact paths, commands, branch names, dates, and repo names over vague prose.
- Record what is true now, not a transcript of the full chat.
- Note what changed recently, what is risky, and what should happen next.
- Include a quick reference section with the few files, commands, dashboards, or docs that matter most.
- Keep a short resume checklist so the next session can verify the notes before acting on them.
- Note when a claim is unverified.
- Do not store secrets, tokens, private keys, raw credentials, or long confidential logs.
Document Model
The canonical handoff is the shared source of truth. Optional session snapshots are secondary artifacts for traceability.
- Canonical handoff:
- repo:
docs/HANDOFF.md - workspace-wide:
_memory/HANDOFF.md - workstream:
_memory/workstreams/<name>/HANDOFF.md
- repo:
- Snapshot archive:
- repo:
docs/handoffs/*.md - workspace-wide:
_memory/handoffs/*.md - workstream:
_memory/workstreams/<name>/handoffs/*.md
- repo:
This model keeps the current state easy to find while still allowing point-in-time captures when they are useful.
Resume Workflow
When asked to continue work from a prior session:
- Resolve the canonical handoff path.
- Read the canonical handoff before planning or editing code.
- Treat the first unfinished item in
as the default plan, and treatNext Actions
as the default continuation frame.Resume Prompt - Run the staleness check if the document might be old.
- If working in workspace scope, read companion memory files only when they are directly relevant.
- If the task is only one initiative inside a larger workspace, resolve the workstream document instead of the workspace-wide handoff.
- In a parent folder with unrelated repositories, narrow validation to the active workstream or the repositories named in the handoff before falling back to a workspace-wide scan.
- Compare the document against the current repo, workstream, or workspace state and call out drift.
- Execute the first unfinished next action. Explore only as needed to complete it, not to replace it with fresh design work.
- Refresh and validate the canonical handoff again before ending the session if anything material changed.
Scripts
scripts/resolve_handoff_path.py
scripts/resolve_handoff_path.pyResolve the canonical repo-local, workspace-wide, or workstream-specific memory path. Use
--scope repo|workspace|auto, --document handoff|workspace|workstream|decisions|patterns, --workstream, or --handoff-path to honor an explicit override. Use --ensure to create the file when it does not exist.
scripts/create_handoff.py
scripts/create_handoff.pyInitialize or refresh the canonical file and sync metadata such as project root, branch, and update timestamp. Use
--snapshot --snapshot-kind <kind> --snapshot-reason <text> to write a timestamped archive copy before the canonical file is refreshed.
scripts/validate_handoff.py
scripts/validate_handoff.pyCheck that the document has the required sections, does not leave obvious placeholders behind, and stays short enough to be useful. Use
--strict when placeholders or empty sections should fail validation.
scripts/check_staleness.py
scripts/check_staleness.pyCompare the handoff timestamp against recent repo activity. In workspace scope, the script first tries to infer the active workstream or active repo set from
_memory/HANDOFF.md before scanning every child repo. Use --workspace-wide only when the user explicitly wants full parent-folder status.
References
references/handoff-template.md
references/handoff-template.mdUse this to understand the expected handoff structure and section intent.
references/workspace-memory-guide.md
references/workspace-memory-guide.mdUse this when the task spans multiple repositories and you need to decide whether the canonical workspace handoff is enough or whether the task needs a dedicated workstream.
references/agent-usage-best-practices.md
references/agent-usage-best-practices.mdUse this when you want the recommended start-of-session, end-of-session, and scope-selection behavior for agents using this skill in normal work.
references/snapshot-strategy.md
references/snapshot-strategy.mdUse this when you need explicit guidance on when to create a snapshot, when not to, and which snapshot kind to use.
references/agent-integrations.md
references/agent-integrations.mdUse this when the user asks where to install the skill for Codex or another agent. Keep install notes separate from the handoff workflow itself.
Notes
- Installation scope and data location are separate concerns.
- The skill may be installed globally or per-project, but the shared mutable documents should stay inside the repository or workspace root they describe.
- Agent-specific files such as
,AGENTS.md
,CLAUDE.md
, or.codex/*
may reference the shared handoff, but should not become the primary mutable store..windsurf/rules/*