session-checkpoint
npx skills add https://github.com/guardzcom/skills --skill session-checkpoint
Agent 安装分布
Skill 文档
Checkpoint
Commands
- Save: “save checkpoint {name}”, “save checkpoint” (defaults to branch name)
- Resume: “continue”, “continue {name}”, “resume” (auto-select if one checkpoint, list if many)
- Cleanup: “clear checkpoint {name}”, “clear all checkpoints”
Save Procedure
1. Determine Name
If user gave a name, use it (lowercase, sanitize: replace / with -).
If no name, derive from branch:
git branch --show-current
Sanitize: lowercase, replace / with -, strip leading -.
2. Locate Memory Directory
Find the auto memory directory path from the system prompt line:
You have a persistent auto memory directory at <path>
3. Gather State
Run in a single bash call:
git branch --show-current && git status --short | head -10 && date '+%Y-%m-%d %H:%M'
From conversation context, determine:
- What was accomplished this session
- What failed or was abandoned (and why)
- Where work left off (only what was explicitly discussed, don’t infer next steps)
- Which files were modified
4. Find Active Plan
Check if a plan file was referenced in conversation context. If found, read it to get step N of M. If none referenced, skip â don’t guess.
5. Write Checkpoint File
If checkpoint-{name}.md already exists, use AskUserQuestion to confirm â show the existing checkpoint’s Saved date and Left Off summary, with options: “Overwrite” / “Different name” (user provides new name via “Other”). If they choose a different name, continue from this step with the new name.
Write <memory_dir>/checkpoint-{name}.md:
# Checkpoint: {name}
- **Branch:** `{branch}`
- **Saved:** {YYYY-MM-DD HH:MM}
- **Plan:** `~/.claude/plans/{file}` (step N of M)
## Left Off
{1-3 lines describing where work stopped}
## Done This Session
- {accomplishments}
## Failed Approaches
- {what + why â or "None"}
## Modified Files
- {list}
Omit the Plan: line if no plan file exists.
6. Update MEMORY.md Index
Read MEMORY.md. Find the ## Active Checkpoints section.
- If checkpoint name already in index: update its line.
- If not: add a new bullet.
- If no
## Active Checkpointssection exists: insert it after the first#heading. If MEMORY.md doesn’t exist, create it with# Project Memoryas the heading.
Bullet format:
- **{name}** ({branch}, {Mon DD}) â {one-line summary}
Keep the Resume any: \continue` or `continue {name}“ line after the bullets.
Do NOT touch any other sections in MEMORY.md.
7. Smart Output
Keep output minimal â this often runs near end of context window. No explanations, just confirmation + question.
Always save the checkpoint file (it’s insurance if they /clear later). Output one line:
Checkpoint "{name}" saved -> checkpoint-{name}.md
Then use AskUserQuestion with options: “/clear”, “/compact”, “Done for now”. Put the recommended option first:
- Plan referenced in context â recommend /clear (context is disposable)
- No plan â recommend /compact (context has unique value)
Include the ready-to-run command in each option’s description (/compact {focus guidance}, /clear then continue {name}). After the user picks, output the exact command prefixed with Run:.
Resume Procedure
1. Determine Name
If user gave a name, use it. If no name given:
- List
checkpoint-*.mdfiles in memory directory - If exactly one: use it automatically
- If multiple: use
AskUserQuestionwith checkpoint names as options (include branch and date in each option’s description) - If none: report “No saved checkpoints found.” and stop
2. Read Checkpoint File
Read <memory_dir>/checkpoint-{name}.md.
If file missing: remove the orphaned bullet from MEMORY.md’s ## Active Checkpoints, report “Checkpoint file missing (cleaned up stale entry)”, and stop.
3. Check Branch
git branch --show-current
If current branch differs from checkpoint’s branch, warn:
Warning: You're on `{current}` but checkpoint was saved on `{saved}`. Switch with: git checkout {saved}
Continue regardless â user decides.
4. Load Plan
If checkpoint references a plan file, read it.
5. Present and Begin
Output the checkpoint summary and last context. If Failed Approaches is non-empty, include them:
â Previously failed: {approach} â {why}
6. Auto-Clear
The checkpoint is now consumed â context is live. Delete the checkpoint file and remove its bullet from MEMORY.md’s ## Active Checkpoints (same as Cleanup steps 1-2). If no bullets remain, remove the entire section.
Do NOT mention the cleanup to the user. They see only the summary from step 5, then wait for their direction.
Cleanup Procedure
1. Delete File
Remove the checkpoint file via Bash:
rm <memory_dir>/checkpoint-{name}.md
2. Update MEMORY.md
Remove the bullet for {name} from ## Active Checkpoints.
If no bullets remain, remove the entire section (header + resume line).
3. Output
Cleared checkpoint "{name}"
“clear all checkpoints”
Glob checkpoint-*.md in memory directory. Delete all matches. Remove the entire ## Active Checkpoints section (header + bullets + resume line) from MEMORY.md. Output:
Cleared {N} checkpoint(s)