retrospective/SKILL.md
Interactive post-session retrospective that captures learnings, updates skills, and saves memories. Use when the user says "/retrospective", "let's do a retro", "what did we learn", "session review", "retro", or "wrap up". Also use at the end of long productive sessions when significant patterns or corrections emerged. Supports multi-session mode — by default processes all of today's sessions across projects.
npx skillsauth add glebis/claude-skills retrospectiveInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Interactive post-session retro. Scans sessions, asks focused questions, proposes concrete actions the user approves in one step.
Scans the current conversation only. This is the original behavior.
Scans all sessions from a given day (default: today) across all projects. Extracts user corrections, skill failures, and patterns from JSONL transcripts.
Trigger: /retrospective at the start of a fresh session, or /retrospective today, or /retrospective 2026-05-24.
# Find today's sessions (default)
find ~/.claude/projects -maxdepth 2 -name "*.jsonl" -not -path "*/subagents/*" -mtime 0
# Or for a specific date, filter by file modification date
find ~/.claude/projects -maxdepth 2 -name "*.jsonl" -not -path "*/subagents/*" -newermt "YYYY-MM-DD" ! -newermt "YYYY-MM-DD + 1 day"
For each JSONL file found, extract a summary:
projects/, decoded from the path-encoding)user and assistant messages (type user and assistant)message.content (may be string or array of {type: "text", text: "..."})message.content array where type == "text"Show the user what was found:
Found N sessions today:
- project-name-1 (session-id[:8]) — "first user message preview..."
- project-name-2 (session-id[:8]) — "first user message preview..."
Then continue to Step 1a with the combined findings from all sessions. Each candidate action should note which session it came from (project name + short ID).
Scan the conversation and estimate session depth. Look for tool calls (Read, Edit, Write, Bash, Skill invocations), errors encountered, and back-and-forth exchanges. Don't try to count exactly — judge by feel:
Silently scan the conversation and collect:
Then read existing state:
glob ~/.claude/projects/*/memory/MEMORY.md and read it plus relevant memory files~/.claude/skills/{name}/skill.md)test -f ~/.claude/skills/linear/scripts/linear && echo "configured" || echo "not configured"Generate up to 5 candidate actions, ranked by signal strength:
Dedup rules:
Present everything in a single AskUserQuestion call (up to 4 questions):
| # | Question | Type |
|---|----------|------|
| 1 | "Quick session check?" | Single select: Productive / Mixed / Rough / Skip retro |
| 2 | "What felt slow or broken?" | Free text via Other (optional) |
| 3 | "Anything to carry forward as a rule?" | Free text via Other (optional) |
| 4 | "Which of these should I save?" | Multi-select: generated candidates with descriptions. Always include a "Nothing / skip all" option. |
If Q1 = "Skip retro" → exit immediately.
If Q1 = "Rough" and Q2/Q3 are empty → exit with "Nothing to save — session closed." Don't add another question after the user already signaled they're done.
Single AskUserQuestion call with one question:
If "Nothing" → exit. If free text → save as memory, exit.
For each approved item from Q4 (plus any insights from Q2/Q3 free text):
Action types and their targets:
| Type | Target | Tool |
|------|--------|------|
| Skill update | ~/.claude/skills/{name}/skill.md | Edit |
| Memory (feedback) | Current project's memory/feedback_*.md + MEMORY.md | Write |
| Memory (project) | Current project's memory/project_*.md + MEMORY.md | Write |
| CLAUDE.md rule | ~/.claude/CLAUDE.md or project CLAUDE.md | Edit |
| Linear task | ~/.claude/skills/linear/scripts/linear issue create --title "..." --description "..." | Bash |
One-line per action taken:
Updated telegram skill — added chat type mismatch note
Saved memory — Qwen /api/chat not /api/generate
Skipped: pdf-generation update (already documented)
Done. No trailing commentary.
Session transcripts are stored as JSONL files at ~/.claude/projects/{project-path}/{session-id}.jsonl.
Each line is a JSON object with a type field. Relevant types:
user — user message. Content at message.content (string or array of {type: "text", text: "..."})assistant — Claude's response. Content at message.content (array of content blocks; extract where type == "text")ai-title — auto-generated session titleTo extract a readable transcript from a JSONL file, use a Python one-liner or read the file and filter for user/assistant types.
Project name decoding: The directory name uses the absolute path with slashes replaced by dashes, e.g., -Users-glebkalinin-ai-projects-foo → ~/ai_projects/foo.
When /retrospective is invoked:
/retrospective invocation) → multi-session mode (scan today's sessions)Each candidate in Q4 must have a description showing the exact proposed content, not just a title. The user judges candidates by reading descriptions, not by opening files.
Good: "Add to telegram skill: get_chat_type() misclassifies private chats as channels — use Telethon client.send_message() directly for DMs"
Bad: "Update telegram skill with DM fix"
This skill only captures session learnings. It does not review code quality, analyze PRs, create documentation, or run tests. For those, use the appropriate dedicated skills.
Engine logic is tested in retro_engine.py with 9 scenario fixtures and 30 pytest tests.
Run: cd ~/.claude/skills/retrospective && python3 -m pytest test_retro_engine.py -v
development
This skill should be used when designing, running, validating, or auditing statistical experiments on personal or observational time-series data (health metrics, speech/text corpora, behavioral logs, diaries, n-of-1 self-tracking). It enforces pre-registration, exact permutation tests, FDR discipline, data-validation gates, adversarial code review, and cross-validation with external models. Triggers on "design an experiment", "test this hypothesis on my data", "is this correlation real", "audit these findings", "pre-register", "validate this dataset", or any n-of-1 / quantified-self analysis request.
development
Create Tufte-inspired data reports and infographic dashboards as standalone HTML files. Uses EB Garamond for text, Monaspace Argon for numbers, Chart.js for interactive charts, and inline SVG sparklines. Produces publication-quality reports with 2-column narrative+data layouts, status dashboards, scroll animations, and responsive mobile support. Use this skill whenever the user wants to create a data report, activity dashboard, infographic, personal analytics page, health tracker visualization, or any document that combines narrative text with interactive charts and tables. Also triggers for "make a report like Tufte", "create an infographic", "build a dashboard", "visualize my data", or requests for beautiful data-driven documents.
documentation
Cut a software release and maintain a tiered compatibility policy. Use when the user wants to release, ship a version, bump the version, tag a release, write a changelog, or update COMPATIBILITY. Config-driven via release.config.json; bumps version files, runs a readiness gate, updates COMPATIBILITY.md tiers and deprecations, tags (→ release workflow), and reports closed issues. Teaches the underlying standards as it runs.
development
Sync and manage bilingual (EN/RU) library content for agency-docs. Use when adding, updating, or reviewing library articles. Handles translation, sync checks, and Russian stylistic review.