Claude-skill-registry gsd-plan-milestone-gaps
Parse audit gaps, spawn planner to create gap closure phases
git clone https://github.com/majiayu000/claude-skill-registry
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/gsd-plan-milestone-gaps" ~/.claude/skills/majiayu000-claude-skill-registry-gsd-plan-milestone-gaps && rm -rf "$T"
skills/data/gsd-plan-milestone-gaps/SKILL.mdReads MILESTONE-AUDIT.md, groups gaps into logical phases, creates phase entries in ROADMAP.md, and offers to plan each phase.
One command creates all fix phases — no manual
$gsd-add-phase per gap.
</objective>
<execution_context>
<!-- Spawns gsd-planner agent which has all planning expertise baked in --></execution_context>
<context> **Audit results:** Glob: .planning/v*-MILESTONE-AUDIT.md (use most recent)Original intent (for prioritization): @.planning/PROJECT.md @.planning/REQUIREMENTS.md
Current state: @.planning/ROADMAP.md @.planning/STATE.md </context>
<process>1. Load Audit Results
# Find the most recent audit file ls -t .planning/v*-MILESTONE-AUDIT.md 2>/dev/null | head -1
Parse YAML frontmatter to extract structured gaps:
— unsatisfied requirementsgaps.requirements
— missing cross-phase connectionsgaps.integration
— broken E2E flowsgaps.flows
If no audit file exists or has no gaps, error:
No audit gaps found. Run `$gsd-audit-milestone` first.
2. Prioritize Gaps
Group gaps by priority from REQUIREMENTS.md:
| Priority | Action |
|---|---|
| Create phase, blocks milestone |
| Create phase, recommended |
| Ask user: include or defer? |
For integration/flow gaps, infer priority from affected requirements.
3. Group Gaps into Phases
Cluster related gaps into logical phases:
Grouping rules:
- Same affected phase → combine into one fix phase
- Same subsystem (auth, API, UI) → combine
- Dependency order (fix stubs before wiring)
- Keep phases focused: 2-4 tasks each
Example grouping:
Gap: DASH-01 unsatisfied (Dashboard doesn't fetch) Gap: Integration Phase 1→3 (Auth not passed to API calls) Gap: Flow "View dashboard" broken at data fetch → Phase 6: "Wire Dashboard to API" - Add fetch to Dashboard.tsx - Include auth header in fetch - Handle response, update state - Render user data
4. Determine Phase Numbers
Find highest existing phase:
ls -d .planning/phases/*/ | sort -V | tail -1
New phases continue from there:
- If Phase 5 is highest, gaps become Phase 6, 7, 8...
5. Present Gap Closure Plan
## Gap Closure Plan **Milestone:** {version} **Gaps to close:** {N} requirements, {M} integration, {K} flows ### Proposed Phases **Phase {N}: {Name}** Closes: - {REQ-ID}: {description} - Integration: {from} → {to} Tasks: {count} **Phase {N+1}: {Name}** Closes: - {REQ-ID}: {description} - Flow: {flow name} Tasks: {count} {If nice-to-have gaps exist:} ### Deferred (nice-to-have) These gaps are optional. Include them? - {gap description} - {gap description} --- Create these {X} phases? (yes / adjust / defer all optional)
Wait for user confirmation.
6. Update ROADMAP.md
Add new phases to current milestone:
### Phase {N}: {Name} **Goal:** {derived from gaps being closed} **Requirements:** {REQ-IDs being satisfied} **Gap Closure:** Closes gaps from audit ### Phase {N+1}: {Name} ...
7. Create Phase Directories
mkdir -p ".planning/phases/{NN}-{name}"
8. Commit Roadmap Update
git add .planning/ROADMAP.md git commit -m "docs(roadmap): add gap closure phases {N}-{M}"
9. Offer Next Steps
</process>## ✓ Gap Closure Phases Created **Phases added:** {N} - {M} **Gaps addressed:** {count} requirements, {count} integration, {count} flows --- ## ▶ Next Up **Plan first gap closure phase** `$gsd-plan-phase {N}` <sub>`/clear` first → fresh context window</sub> --- **Also available:** - `$gsd-execute-phase {N}` — if plans already exist - `cat .planning/ROADMAP.md` — see updated roadmap --- **After all gap phases complete:** `$gsd-audit-milestone` — re-audit to verify gaps closed `$gsd-complete-milestone {version}` — archive when audit passes
<gap_to_phase_mapping>
How Gaps Become Tasks
Requirement gap → Tasks:
gap: id: DASH-01 description: "User sees their data" reason: "Dashboard exists but doesn't fetch from API" missing: - "useEffect with fetch to /api/user/data" - "State for user data" - "Render user data in JSX" becomes: phase: "Wire Dashboard Data" tasks: - name: "Add data fetching" files: [src/components/Dashboard.tsx] action: "Add useEffect that fetches /api/user/data on mount" - name: "Add state management" files: [src/components/Dashboard.tsx] action: "Add useState for userData, loading, error states" - name: "Render user data" files: [src/components/Dashboard.tsx] action: "Replace placeholder with userData.map rendering"
Integration gap → Tasks:
gap: from_phase: 1 to_phase: 3 connection: "Auth token → API calls" reason: "Dashboard API calls don't include auth header" missing: - "Auth header in fetch calls" - "Token refresh on 401" becomes: phase: "Add Auth to Dashboard API Calls" tasks: - name: "Add auth header to fetches" files: [src/components/Dashboard.tsx, src/lib/api.ts] action: "Include Authorization header with token in all API calls" - name: "Handle 401 responses" files: [src/lib/api.ts] action: "Add interceptor to refresh token or redirect to login on 401"
Flow gap → Tasks:
gap: name: "User views dashboard after login" broken_at: "Dashboard data load" reason: "No fetch call" missing: - "Fetch user data on mount" - "Display loading state" - "Render user data" becomes: # Usually same phase as requirement/integration gap # Flow gaps often overlap with other gap types
</gap_to_phase_mapping>
<success_criteria>
- MILESTONE-AUDIT.md loaded and gaps parsed
- Gaps prioritized (must/should/nice)
- Gaps grouped into logical phases
- User confirmed phase plan
- ROADMAP.md updated with new phases
- Phase directories created
- Changes committed
- User knows to run
next </success_criteria>$gsd-plan-phase