From b1a670e662fdae35945d9d8dfc74008aaa9dfc85 Mon Sep 17 00:00:00 2001 From: Tom Boucher Date: Sat, 25 Apr 2026 10:59:33 -0400 Subject: [PATCH] fix(#2697): replace retired /gsd: prefix with /gsd- in all user-facing text (#2699) All workflow, command, reference, template, and tool-output files that surfaced /gsd: as a user-typed slash command have been updated to use /gsd-, matching the Claude Code skill directory name. Closes #2697 Co-authored-by: Claude Sonnet 4.6 --- CHANGELOG.md | 2 + commands/gsd/add-backlog.md | 8 +- commands/gsd/add-tests.md | 4 +- commands/gsd/analyze-dependencies.md | 2 +- commands/gsd/complete-milestone.md | 12 +- commands/gsd/debug.md | 10 +- commands/gsd/explore.md | 2 +- commands/gsd/fast.md | 4 +- commands/gsd/graphify.md | 6 +- commands/gsd/intel.md | 6 +- commands/gsd/map-codebase.md | 6 +- commands/gsd/new-milestone.md | 2 +- commands/gsd/new-project.md | 2 +- commands/gsd/new-workspace.md | 2 +- commands/gsd/plan-milestone-gaps.md | 4 +- commands/gsd/plan-phase.md | 2 +- commands/gsd/plant-seed.md | 2 +- commands/gsd/quick.md | 2 +- commands/gsd/reapply-patches.md | 4 +- commands/gsd/research-phase.md | 6 +- commands/gsd/review.md | 2 +- commands/gsd/scan.md | 4 +- commands/gsd/set-profile.md | 2 +- commands/gsd/settings-advanced.md | 4 +- commands/gsd/settings-integrations.md | 4 +- commands/gsd/ship.md | 2 +- commands/gsd/sketch.md | 2 +- commands/gsd/spec-phase.md | 2 +- commands/gsd/spike.md | 2 +- commands/gsd/thread.md | 14 +- commands/gsd/ultraplan-phase.md | 6 +- commands/gsd/verify-work.md | 2 +- commands/gsd/workstreams.md | 8 +- get-shit-done/bin/lib/audit.cjs | 2 +- get-shit-done/bin/lib/commands.cjs | 2 +- get-shit-done/bin/lib/config.cjs | 4 +- get-shit-done/bin/lib/core.cjs | 2 +- get-shit-done/bin/lib/drift.cjs | 2 +- get-shit-done/bin/lib/gsd2-import.cjs | 2 +- get-shit-done/bin/lib/init.cjs | 10 +- get-shit-done/bin/lib/phase.cjs | 8 +- get-shit-done/bin/lib/profile-output.cjs | 16 +- get-shit-done/bin/lib/secrets.cjs | 2 +- get-shit-done/bin/lib/verify.cjs | 28 +- get-shit-done/bin/lib/workstream.cjs | 2 +- get-shit-done/references/artifact-types.md | 12 +- .../references/continuation-format.md | 32 +-- .../references/doc-conflict-engine.md | 2 +- get-shit-done/references/domain-probes.md | 2 +- get-shit-done/references/gate-prompts.md | 4 +- get-shit-done/references/gates.md | 2 +- get-shit-done/references/git-integration.md | 2 +- get-shit-done/references/model-profiles.md | 4 +- get-shit-done/references/planning-config.md | 14 +- get-shit-done/references/thinking-partner.md | 2 +- .../references/verification-overrides.md | 6 +- get-shit-done/templates/AI-SPEC.md | 2 +- get-shit-done/templates/DEBUG.md | 2 +- get-shit-done/templates/README.md | 48 ++-- get-shit-done/templates/UAT.md | 8 +- get-shit-done/templates/VALIDATION.md | 2 +- get-shit-done/templates/claude-md.md | 10 +- .../templates/debug-subagent-prompt.md | 2 +- get-shit-done/templates/dev-preferences.md | 2 +- get-shit-done/templates/discovery.md | 4 +- get-shit-done/templates/phase-prompt.md | 2 +- .../templates/planner-subagent-prompt.md | 6 +- get-shit-done/templates/project.md | 2 +- get-shit-done/templates/research.md | 2 +- get-shit-done/templates/spec.md | 6 +- get-shit-done/templates/state.md | 4 +- get-shit-done/workflows/add-phase.md | 14 +- get-shit-done/workflows/add-tests.md | 18 +- get-shit-done/workflows/add-todo.md | 4 +- .../workflows/ai-integration-phase.md | 10 +- .../workflows/analyze-dependencies.md | 6 +- get-shit-done/workflows/audit-milestone.md | 16 +- get-shit-done/workflows/audit-uat.md | 4 +- get-shit-done/workflows/autonomous.md | 14 +- get-shit-done/workflows/check-todos.md | 16 +- get-shit-done/workflows/code-review-fix.md | 12 +- get-shit-done/workflows/code-review.md | 8 +- get-shit-done/workflows/complete-milestone.md | 10 +- get-shit-done/workflows/diagnose-issues.md | 2 +- get-shit-done/workflows/discovery-phase.md | 6 +- .../workflows/discuss-phase-assumptions.md | 8 +- .../workflows/discuss-phase-power.md | 6 +- get-shit-done/workflows/discuss-phase.md | 14 +- .../workflows/discuss-phase/modes/chain.md | 8 +- .../workflows/discuss-phase/modes/text.md | 2 +- get-shit-done/workflows/do.md | 46 ++-- get-shit-done/workflows/docs-update.md | 8 +- get-shit-done/workflows/eval-review.md | 10 +- get-shit-done/workflows/execute-phase.md | 46 ++-- .../steps/codebase-drift-gate.md | 2 +- get-shit-done/workflows/execute-plan.md | 6 +- get-shit-done/workflows/explore.md | 8 +- get-shit-done/workflows/extract_learnings.md | 4 +- get-shit-done/workflows/fast.md | 10 +- get-shit-done/workflows/forensics.md | 4 +- get-shit-done/workflows/health.md | 8 +- get-shit-done/workflows/help.md | 260 +++++++++--------- get-shit-done/workflows/import.md | 2 +- get-shit-done/workflows/inbox.md | 8 +- get-shit-done/workflows/ingest-docs.md | 4 +- get-shit-done/workflows/insert-phase.md | 14 +- .../workflows/list-phase-assumptions.md | 8 +- get-shit-done/workflows/list-workspaces.md | 4 +- get-shit-done/workflows/manager.md | 10 +- get-shit-done/workflows/map-codebase.md | 8 +- get-shit-done/workflows/milestone-summary.md | 4 +- get-shit-done/workflows/new-milestone.md | 12 +- get-shit-done/workflows/new-project.md | 34 +-- get-shit-done/workflows/new-workspace.md | 10 +- get-shit-done/workflows/next.md | 26 +- get-shit-done/workflows/note.md | 12 +- get-shit-done/workflows/pause-work.md | 4 +- .../workflows/plan-milestone-gaps.md | 14 +- get-shit-done/workflows/plan-phase.md | 68 ++--- .../workflows/plan-review-convergence.md | 12 +- get-shit-done/workflows/plant-seed.md | 6 +- get-shit-done/workflows/pr-branch.md | 2 +- get-shit-done/workflows/profile-user.md | 2 +- get-shit-done/workflows/progress.md | 74 ++--- get-shit-done/workflows/quick.md | 10 +- get-shit-done/workflows/remove-phase.md | 12 +- get-shit-done/workflows/remove-workspace.md | 2 +- get-shit-done/workflows/research-phase.md | 4 +- get-shit-done/workflows/resume-project.md | 20 +- get-shit-done/workflows/review.md | 6 +- get-shit-done/workflows/scan.md | 2 +- get-shit-done/workflows/secure-phase.md | 10 +- get-shit-done/workflows/session-report.md | 4 +- get-shit-done/workflows/settings-advanced.md | 8 +- .../workflows/settings-integrations.md | 8 +- get-shit-done/workflows/settings.md | 50 ++-- get-shit-done/workflows/ship.md | 10 +- get-shit-done/workflows/sketch-wrap-up.md | 16 +- get-shit-done/workflows/sketch.md | 10 +- get-shit-done/workflows/spec-phase.md | 8 +- get-shit-done/workflows/spike-wrap-up.md | 14 +- get-shit-done/workflows/spike.md | 10 +- get-shit-done/workflows/stats.md | 2 +- get-shit-done/workflows/sync-skills.md | 2 +- get-shit-done/workflows/transition.md | 36 +-- get-shit-done/workflows/ui-phase.md | 20 +- get-shit-done/workflows/ui-review.md | 10 +- get-shit-done/workflows/ultraplan-phase.md | 16 +- get-shit-done/workflows/undo.md | 16 +- get-shit-done/workflows/update.md | 8 +- get-shit-done/workflows/validate-phase.md | 8 +- get-shit-done/workflows/verify-work.md | 34 +-- tests/bug-2543-gsd-slash-namespace.test.cjs | 38 ++- tests/claude-md.test.cjs | 6 +- tests/settings-integrations.test.cjs | 10 +- 155 files changed, 881 insertions(+), 863 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 679a638e..c5a7eacf 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -28,6 +28,8 @@ If you use GSD **as a workflow**—milestones, phases, `.planning/` artifacts, b ### Fixed +- **End-of-phase routing suggestions now use `/gsd-` (not the retired `/gsd:`)** — All user-visible command suggestions in workflows (`execute-phase.md`, `transition.md`), tool output (`profile-output.cjs`, `init.cjs`), references, and templates have been updated from `/gsd:` to `/gsd-`, matching the Claude Code skill directory name and the user-typed slash-command format. Internal `Skill(skill="gsd:")` calls (no leading slash) are preserved unchanged — those resolve by frontmatter `name:` not directory name. The namespace test (`bug-2543-gsd-slash-namespace.test.cjs`) has been updated to enforce the current invariant. Closes #2697. + - **`gsd-sdk query` now resolves parent `.planning/` root in multi-repo (`sub_repos`) workspaces** — when invoked from inside a `sub_repos`-listed child repo (e.g. `workspace/app/`), the SDK now walks up to the parent workspace that owns `.planning/`, matching the legacy `gsd-tools.cjs` `findProjectRoot` behavior. Previously `gsd-sdk query init.new-milestone` reported `project_exists: false` from the sub-repo, while `gsd-tools.cjs` resolved the parent root correctly. Resolution happens once in `cli.ts` before dispatch; if `projectDir` already owns `.planning/` (including explicit `--project-dir`), the walk is a no-op. Ported as `findProjectRoot` in `sdk/src/query/helpers.ts` with the same detection order (own `.planning/` wins, then parent `sub_repos` match, then legacy `multiRepo: true`, then `.git` heuristic), capped at 10 parent levels and never crossing `$HOME`. Closes #2623. - **Shell hooks falsely flagged as stale on every session** — `gsd-phase-boundary.sh`, `gsd-session-state.sh`, and `gsd-validate-commit.sh` now ship with a `# gsd-hook-version: {{GSD_VERSION}}` header; the installer substitutes `{{GSD_VERSION}}` in `.sh` hooks the same way it does for `.js` hooks; and the stale-hook detector in `gsd-check-update.js` now matches bash `#` comment syntax in addition to JS `//` syntax. All three changes are required together — neither the regex fix alone nor the install fix alone is sufficient to resolve the false positive (#2136, #2206, #2209, #2210, #2212) diff --git a/commands/gsd/add-backlog.md b/commands/gsd/add-backlog.md index 6b59eb6d..ee6c4ea0 100644 --- a/commands/gsd/add-backlog.md +++ b/commands/gsd/add-backlog.md @@ -42,7 +42,7 @@ the normal phase sequence and accumulate context over time. **Plans:** 0 plans Plans: - - [ ] TBD (promote with /gsd:review-backlog when ready) + - [ ] TBD (promote with /gsd-review-backlog when ready) ``` 4. **Create the phase directory:** @@ -65,15 +65,15 @@ the normal phase sequence and accumulate context over time. Directory: .planning/phases/{NEXT}-{slug}/ This item lives in the backlog parking lot. - Use /gsd:discuss-phase {NEXT} to explore it further. - Use /gsd:review-backlog to promote items to active milestone. + Use /gsd-discuss-phase {NEXT} to explore it further. + Use /gsd-review-backlog to promote items to active milestone. ``` - 999.x numbering keeps backlog items out of the active phase sequence -- Phase directories are created immediately, so /gsd:discuss-phase and /gsd:plan-phase work on them +- Phase directories are created immediately, so /gsd-discuss-phase and /gsd-plan-phase work on them - No `Depends on:` field — backlog items are unsequenced by definition - Sparse numbering is fine (999.1, 999.3) — always uses next-decimal diff --git a/commands/gsd/add-tests.md b/commands/gsd/add-tests.md index 60deab6e..4f96dc1b 100644 --- a/commands/gsd/add-tests.md +++ b/commands/gsd/add-tests.md @@ -13,8 +13,8 @@ allowed-tools: - AskUserQuestion argument-instructions: | Parse the argument as a phase number (integer, decimal, or letter-suffix), plus optional free-text instructions. - Example: /gsd:add-tests 12 - Example: /gsd:add-tests 12 focus on edge cases in the pricing module + Example: /gsd-add-tests 12 + Example: /gsd-add-tests 12 focus on edge cases in the pricing module --- Generate unit and E2E tests for a completed phase, using its SUMMARY.md, CONTEXT.md, and VERIFICATION.md as specifications. diff --git a/commands/gsd/analyze-dependencies.md b/commands/gsd/analyze-dependencies.md index 94444213..9d8b6b8e 100644 --- a/commands/gsd/analyze-dependencies.md +++ b/commands/gsd/analyze-dependencies.md @@ -25,7 +25,7 @@ Then suggest `Depends on` updates to ROADMAP.md. No arguments required. Requires an active milestone with ROADMAP.md. -Run this command BEFORE `/gsd:manager` to fill in missing `Depends on` fields and prevent merge conflicts from unordered parallel execution. +Run this command BEFORE `/gsd-manager` to fill in missing `Depends on` fields and prevent merge conflicts from unordered parallel execution. diff --git a/commands/gsd/complete-milestone.md b/commands/gsd/complete-milestone.md index 6ece8b80..1485de09 100644 --- a/commands/gsd/complete-milestone.md +++ b/commands/gsd/complete-milestone.md @@ -42,19 +42,19 @@ Output: Milestone archived (roadmap + requirements), PROJECT.md evolved, git tag 0. **Check for audit:** - Look for `.planning/v{{version}}-MILESTONE-AUDIT.md` - - If missing or stale: recommend `/gsd:audit-milestone` first - - If audit status is `gaps_found`: recommend `/gsd:plan-milestone-gaps` first + - If missing or stale: recommend `/gsd-audit-milestone` first + - If audit status is `gaps_found`: recommend `/gsd-plan-milestone-gaps` first - If audit status is `passed`: proceed to step 1 ```markdown ## Pre-flight Check {If no v{{version}}-MILESTONE-AUDIT.md:} - ⚠ No milestone audit found. Run `/gsd:audit-milestone` first to verify + ⚠ No milestone audit found. Run `/gsd-audit-milestone` first to verify requirements coverage, cross-phase integration, and E2E flows. {If audit has gaps:} - ⚠ Milestone audit found gaps. Run `/gsd:plan-milestone-gaps` to create + ⚠ Milestone audit found gaps. Run `/gsd-plan-milestone-gaps` to create phases that close the gaps, or proceed anyway to accept as tech debt. {If audit passed:} @@ -108,7 +108,7 @@ Output: Milestone archived (roadmap + requirements), PROJECT.md evolved, git tag - Ask about pushing tag 8. **Offer next steps:** - - `/gsd:new-milestone` — start next milestone (questioning → research → requirements → roadmap) + - `/gsd-new-milestone` — start next milestone (questioning → research → requirements → roadmap) @@ -132,5 +132,5 @@ Output: Milestone archived (roadmap + requirements), PROJECT.md evolved, git tag - **Archive before deleting:** Always create archive files before updating/deleting originals - **One-line summary:** Collapsed milestone in ROADMAP.md should be single line with link - **Context efficiency:** Archive keeps ROADMAP.md and REQUIREMENTS.md constant size per milestone -- **Fresh requirements:** Next milestone starts with `/gsd:new-milestone` which includes requirements definition +- **Fresh requirements:** Next milestone starts with `/gsd-new-milestone` which includes requirements definition diff --git a/commands/gsd/debug.md b/commands/gsd/debug.md index 56f8dc68..8220b8cd 100644 --- a/commands/gsd/debug.md +++ b/commands/gsd/debug.md @@ -88,11 +88,11 @@ Active Debug Sessions hypothesis: Missing null check on req.body.user next: Verify fix passes regression test ───────────────────────────────────────────── -Run `/gsd:debug continue ` to resume a session. -No sessions? `/gsd:debug ` to start. +Run `/gsd-debug continue ` to resume a session. +No sessions? `/gsd-debug ` to start. ``` -If no files exist or the glob returns nothing: print "No active debug sessions. Run `/gsd:debug ` to start one." +If no files exist or the glob returns nothing: print "No active debug sessions. Run `/gsd-debug ` to start one." STOP after displaying list. Do NOT proceed to further steps. @@ -117,7 +117,7 @@ No agent spawn. Just information display. STOP after printing. When SUBCMD=continue and SLUG is set: -Check `.planning/debug/{SLUG}.md` exists. If not, print "No active debug session found with slug: {SLUG}. Check `/gsd:debug list` for active sessions." and stop. +Check `.planning/debug/{SLUG}.md` exists. If not, print "No active debug session found with slug: {SLUG}. Check `/gsd-debug list` for active sessions." and stop. Read file and print Current Focus block to console: @@ -247,7 +247,7 @@ specialist_dispatch_enabled: true Display the compact summary returned by the session manager. If summary shows `DEBUG SESSION COMPLETE`: done. -If summary shows `ABANDONED`: note session saved at `.planning/debug/{slug}.md` for later `/gsd:debug continue {slug}`. +If summary shows `ABANDONED`: note session saved at `.planning/debug/{slug}.md` for later `/gsd-debug continue {slug}`. diff --git a/commands/gsd/explore.md b/commands/gsd/explore.md index 347e1799..d1bd2a33 100644 --- a/commands/gsd/explore.md +++ b/commands/gsd/explore.md @@ -15,7 +15,7 @@ Open-ended Socratic ideation session. Guides the developer through exploring an probing questions, optionally spawns research, then routes outputs to the appropriate GSD artifacts (notes, todos, seeds, research questions, requirements, or new phases). -Accepts an optional topic argument: `/gsd:explore authentication strategy` +Accepts an optional topic argument: `/gsd-explore authentication strategy` diff --git a/commands/gsd/fast.md b/commands/gsd/fast.md index 4121f9f7..59d2ad42 100644 --- a/commands/gsd/fast.md +++ b/commands/gsd/fast.md @@ -16,8 +16,8 @@ Execute a trivial task directly in the current context without spawning subagent or generating PLAN.md files. For tasks too small to justify planning overhead: typo fixes, config changes, small refactors, forgotten commits, simple additions. -This is NOT a replacement for /gsd:quick — use /gsd:quick for anything that -needs research, multi-step planning, or verification. /gsd:fast is for tasks +This is NOT a replacement for /gsd-quick — use /gsd-quick for anything that +needs research, multi-step planning, or verification. /gsd-fast is for tasks you could describe in one sentence and execute in under 2 minutes. diff --git a/commands/gsd/graphify.md b/commands/gsd/graphify.md index 38273853..52ecacdf 100644 --- a/commands/gsd/graphify.md +++ b/commands/gsd/graphify.md @@ -43,7 +43,7 @@ Knowledge graph is disabled. To activate: node $HOME/.claude/get-shit-done/bin/gsd-tools.cjs config-set graphify.enabled true -Then run /gsd:graphify build to create the initial graph. +Then run /gsd-graphify build to create the initial graph. ``` --- @@ -65,7 +65,7 @@ Parse `$ARGUMENTS` to determine the operation mode: ``` GSD > GRAPHIFY -Usage: /gsd:graphify +Usage: /gsd-graphify Modes: build Build or rebuild the knowledge graph @@ -85,7 +85,7 @@ node $HOME/.claude/get-shit-done/bin/gsd-tools.cjs graphify query Parse the JSON output and display results: - If the output contains `"disabled": true`, display the disabled message from Step 1 and **STOP** - If the output contains `"error"` field, display the error message and **STOP** -- If no nodes found, display: `No graph matches for ''. Try /gsd:graphify build to create or rebuild the graph.` +- If no nodes found, display: `No graph matches for ''. Try /gsd-graphify build to create or rebuild the graph.` - Otherwise, display matched nodes grouped by type, with edge relationships and confidence tiers (EXTRACTED/INFERRED/AMBIGUOUS) **STOP** after displaying results. Do not spawn an agent. diff --git a/commands/gsd/intel.md b/commands/gsd/intel.md index 3bbf3ba1..ac1cc79b 100644 --- a/commands/gsd/intel.md +++ b/commands/gsd/intel.md @@ -41,7 +41,7 @@ Intel system is disabled. To activate: gsd-sdk query config-set intel.enabled true -Then run /gsd:intel refresh to build the initial index. +Then run /gsd-intel refresh to build the initial index. ``` --- @@ -63,7 +63,7 @@ Parse `$ARGUMENTS` to determine the operation mode: ``` GSD > INTEL -Usage: /gsd:intel +Usage: /gsd-intel Modes: query Search intel files for a term @@ -82,7 +82,7 @@ gsd-sdk query intel.query Parse the JSON output and display results: - If the output contains `"disabled": true`, display the disabled message from Step 1 and **STOP** -- If no matches found, display: `No intel matches for ''. Try /gsd:intel refresh to build the index.` +- If no matches found, display: `No intel matches for ''. Try /gsd-intel refresh to build the index.` - Otherwise, display matching entries grouped by intel file **STOP** after displaying results. Do not spawn an agent. diff --git a/commands/gsd/map-codebase.md b/commands/gsd/map-codebase.md index 4daa7eda..054d8f8a 100644 --- a/commands/gsd/map-codebase.md +++ b/commands/gsd/map-codebase.md @@ -30,8 +30,8 @@ Focus area: $ARGUMENTS (optional - if provided, tells agents to focus on specifi Check for .planning/STATE.md - loads context if project already initialized **This command can run:** -- Before /gsd:new-project (brownfield codebases) - creates codebase map first -- After /gsd:new-project (greenfield codebases) - updates codebase map as code evolves +- Before /gsd-new-project (brownfield codebases) - creates codebase map first +- After /gsd-new-project (greenfield codebases) - updates codebase map as code evolves - Anytime to refresh codebase understanding @@ -59,7 +59,7 @@ Check for .planning/STATE.md - loads context if project already initialized 4. Wait for agents to complete, collect confirmations (NOT document contents) 5. Verify all 7 documents exist with line counts 6. Commit codebase map -7. Offer next steps (typically: /gsd:new-project or /gsd:plan-phase) +7. Offer next steps (typically: /gsd-new-project or /gsd-plan-phase) diff --git a/commands/gsd/new-milestone.md b/commands/gsd/new-milestone.md index 1c28df6c..ac3692fd 100644 --- a/commands/gsd/new-milestone.md +++ b/commands/gsd/new-milestone.md @@ -21,7 +21,7 @@ Brownfield equivalent of new-project. Project exists, PROJECT.md has history. Ga - `.planning/ROADMAP.md` — phase structure (continues numbering) - `.planning/STATE.md` — reset for new milestone -**After:** `/gsd:plan-phase [N]` to start execution. +**After:** `/gsd-plan-phase [N]` to start execution. diff --git a/commands/gsd/new-project.md b/commands/gsd/new-project.md index 339f50f9..74c607c7 100644 --- a/commands/gsd/new-project.md +++ b/commands/gsd/new-project.md @@ -29,7 +29,7 @@ Initialize a new project through unified flow: questioning → research (optiona - `.planning/ROADMAP.md` — phase structure - `.planning/STATE.md` — project memory -**After this command:** Run `/gsd:plan-phase 1` to start execution. +**After this command:** Run `/gsd-plan-phase 1` to start execution. diff --git a/commands/gsd/new-workspace.md b/commands/gsd/new-workspace.md index e340b803..81341bed 100644 --- a/commands/gsd/new-workspace.md +++ b/commands/gsd/new-workspace.md @@ -30,7 +30,7 @@ Create a physical workspace directory containing copies of specified git repos ( - `/.planning/` — independent planning directory - `//` — git worktree or clone for each specified repo -**After this command:** `cd` into the workspace and run `/gsd:new-project` to initialize GSD. +**After this command:** `cd` into the workspace and run `/gsd-new-project` to initialize GSD. diff --git a/commands/gsd/plan-milestone-gaps.md b/commands/gsd/plan-milestone-gaps.md index a9b68452..0093e375 100644 --- a/commands/gsd/plan-milestone-gaps.md +++ b/commands/gsd/plan-milestone-gaps.md @@ -10,11 +10,11 @@ allowed-tools: - AskUserQuestion --- -Create all phases necessary to close gaps identified by `/gsd:audit-milestone`. +Create all phases necessary to close gaps identified by `/gsd-audit-milestone`. Reads 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. +One command creates all fix phases — no manual `/gsd-add-phase` per gap. diff --git a/commands/gsd/plan-phase.md b/commands/gsd/plan-phase.md index fa80aec2..11ab0feb 100644 --- a/commands/gsd/plan-phase.md +++ b/commands/gsd/plan-phase.md @@ -40,7 +40,7 @@ Phase number: $ARGUMENTS (optional — auto-detects next unplanned phase if omit - `--gaps` — Gap closure mode (reads VERIFICATION.md, skips research) - `--skip-verify` — Skip verification loop - `--prd ` — Use a PRD/acceptance criteria file instead of discuss-phase. Parses requirements into CONTEXT.md automatically. Skips discuss-phase entirely. -- `--reviews` — Replan incorporating cross-AI review feedback from REVIEWS.md (produced by `/gsd:review`) +- `--reviews` — Replan incorporating cross-AI review feedback from REVIEWS.md (produced by `/gsd-review`) - `--text` — Use plain-text numbered lists instead of TUI menus (required for `/rc` remote sessions) Normalize phase input in step 2 before any directory lookups. diff --git a/commands/gsd/plant-seed.md b/commands/gsd/plant-seed.md index 95ab4efc..0630bbce 100644 --- a/commands/gsd/plant-seed.md +++ b/commands/gsd/plant-seed.md @@ -16,7 +16,7 @@ milestone arrives. Seeds solve context rot: instead of a one-liner in Deferred t reads, a seed preserves the full WHY, WHEN to surface, and breadcrumbs to details. Creates: .planning/seeds/SEED-NNN-slug.md -Consumed by: /gsd:new-milestone (scans seeds and presents matches) +Consumed by: /gsd-new-milestone (scans seeds and presents matches) diff --git a/commands/gsd/quick.md b/commands/gsd/quick.md index 11219cb3..0c7fba0f 100644 --- a/commands/gsd/quick.md +++ b/commands/gsd/quick.md @@ -118,7 +118,7 @@ Status: {status from SUMMARY.md frontmatter, or "no summary yet"} Description: {first non-empty line from PLAN.md after frontmatter} Last action: {last meaningful line of SUMMARY.md, or "none"} ───────────────────────────────────── -Resume with: /gsd:quick resume {slug} +Resume with: /gsd-quick resume {slug} ``` No agent spawn. STOP after printing. diff --git a/commands/gsd/reapply-patches.md b/commands/gsd/reapply-patches.md index 16c270cf..2fd0ff6a 100644 --- a/commands/gsd/reapply-patches.md +++ b/commands/gsd/reapply-patches.md @@ -115,7 +115,7 @@ Read `backup-meta.json` from the patches directory. ``` No local patches found. Nothing to reapply. -Local patches are automatically saved when you run /gsd:update +Local patches are automatically saved when you run /gsd-update after modifying any GSD workflow, command, or agent files. ``` Exit. @@ -278,7 +278,7 @@ Before proceeding to cleanup, evaluate the Hunk Verification Table produced in S **If the Hunk Verification Table is absent** (Step 4 did not produce it), STOP immediately and report to the user: ``` ERROR: Hunk Verification Table is missing. Post-merge verification was not completed. -Rerun /gsd:reapply-patches to retry with full verification. +Rerun /gsd-reapply-patches to retry with full verification. ``` **If any row in the Hunk Verification Table shows `verified: no`**, STOP and report to the user: diff --git a/commands/gsd/research-phase.md b/commands/gsd/research-phase.md index 7f892ede..71225981 100644 --- a/commands/gsd/research-phase.md +++ b/commands/gsd/research-phase.md @@ -1,6 +1,6 @@ --- name: gsd:research-phase -description: Research how to implement a phase (standalone - usually use /gsd:plan-phase instead) +description: Research how to implement a phase (standalone - usually use /gsd-plan-phase instead) argument-hint: "[phase]" allowed-tools: - Read @@ -11,7 +11,7 @@ allowed-tools: Research how to implement a phase. Spawns gsd-phase-researcher agent with phase context. -**Note:** This is a standalone research command. For most workflows, use `/gsd:plan-phase` which integrates research automatically. +**Note:** This is a standalone research command. For most workflows, use `/gsd-plan-phase` which integrates research automatically. **Use this command when:** - You want to research without planning yet @@ -115,7 +115,7 @@ Mode: ecosystem -Your RESEARCH.md will be loaded by `/gsd:plan-phase` which uses specific sections: +Your RESEARCH.md will be loaded by `/gsd-plan-phase` which uses specific sections: - `## Standard Stack` → Plans use these libraries - `## Architecture Patterns` → Task structure follows these - `## Don't Hand-Roll` → Tasks NEVER build custom solutions for listed problems diff --git a/commands/gsd/review.md b/commands/gsd/review.md index c7d8e93b..a52f5c55 100644 --- a/commands/gsd/review.md +++ b/commands/gsd/review.md @@ -13,7 +13,7 @@ allowed-tools: Invoke external AI CLIs (Gemini, Claude, Codex, OpenCode, Qwen Code, Cursor) to independently review phase plans. Produces a structured REVIEWS.md with per-reviewer feedback that can be fed back into -planning via /gsd:plan-phase --reviews. +planning via /gsd-plan-phase --reviews. **Flow:** Detect CLIs → Build review prompt → Invoke each CLI → Collect responses → Write REVIEWS.md diff --git a/commands/gsd/scan.md b/commands/gsd/scan.md index 052d9fbf..6e3be0da 100644 --- a/commands/gsd/scan.md +++ b/commands/gsd/scan.md @@ -1,6 +1,6 @@ --- name: gsd:scan -description: Rapid codebase assessment — lightweight alternative to /gsd:map-codebase +description: Rapid codebase assessment — lightweight alternative to /gsd-map-codebase allowed-tools: - Read - Write @@ -14,7 +14,7 @@ allowed-tools: Run a focused codebase scan for a single area, producing targeted documents in `.planning/codebase/`. Accepts an optional `--focus` flag: `tech`, `arch`, `quality`, `concerns`, or `tech+arch` (default). -Lightweight alternative to `/gsd:map-codebase` — spawns one mapper agent instead of four parallel ones. +Lightweight alternative to `/gsd-map-codebase` — spawns one mapper agent instead of four parallel ones. diff --git a/commands/gsd/set-profile.md b/commands/gsd/set-profile.md index 03c4a5a1..240f1269 100644 --- a/commands/gsd/set-profile.md +++ b/commands/gsd/set-profile.md @@ -9,4 +9,4 @@ allowed-tools: Show the following output to the user verbatim, with no extra commentary: -!`if ! command -v gsd-sdk >/dev/null 2>&1; then printf '⚠ gsd-sdk not found in PATH — /gsd:set-profile requires it.\n\nInstall the GSD SDK:\n npm install -g @gsd-build/sdk\n\nOr update GSD to get the latest packages:\n /gsd:update\n'; exit 1; fi; gsd-sdk query config-set-model-profile $ARGUMENTS --raw` +!`if ! command -v gsd-sdk >/dev/null 2>&1; then printf '⚠ gsd-sdk not found in PATH — /gsd-set-profile requires it.\n\nInstall the GSD SDK:\n npm install -g @gsd-build/sdk\n\nOr update GSD to get the latest packages:\n /gsd-update\n'; exit 1; fi; gsd-sdk query config-set-model-profile $ARGUMENTS --raw` diff --git a/commands/gsd/settings-advanced.md b/commands/gsd/settings-advanced.md index 9dcac4ad..4e8cc118 100644 --- a/commands/gsd/settings-advanced.md +++ b/commands/gsd/settings-advanced.md @@ -9,7 +9,7 @@ allowed-tools: --- -Interactive configuration of GSD power-user knobs that don't belong in the common-case `/gsd:settings` prompt. +Interactive configuration of GSD power-user knobs that don't belong in the common-case `/gsd-settings` prompt. Routes to the settings-advanced workflow which handles: - Config existence ensuring (workstream-aware path resolution) @@ -18,7 +18,7 @@ Routes to the settings-advanced workflow which handles: - Config merging that preserves every unrelated key - Confirmation table display -Use `/gsd:settings` for the common-case toggles (model profile, research/plan_check/verifier, branching strategy, context warnings). Use `/gsd:settings-advanced` once those are set and you want to tune the internals. +Use `/gsd-settings` for the common-case toggles (model profile, research/plan_check/verifier, branching strategy, context warnings). Use `/gsd-settings-advanced` once those are set and you want to tune the internals. diff --git a/commands/gsd/settings-integrations.md b/commands/gsd/settings-integrations.md index a3711ef2..3a142a9d 100644 --- a/commands/gsd/settings-integrations.md +++ b/commands/gsd/settings-integrations.md @@ -19,8 +19,8 @@ API keys are stored plaintext in `.planning/config.json` but are masked (`****`) in every piece of interactive output. The workflow never echoes plaintext to stdout, stderr, or any log. -This command is deliberately distinct from `/gsd:settings` (workflow toggles) -and any `/gsd:settings-advanced` tuning surface. It handles *connectivity*, +This command is deliberately distinct from `/gsd-settings` (workflow toggles) +and any `/gsd-settings-advanced` tuning surface. It handles *connectivity*, not pipeline shape. diff --git a/commands/gsd/ship.md b/commands/gsd/ship.md index 12469555..d3b396b7 100644 --- a/commands/gsd/ship.md +++ b/commands/gsd/ship.md @@ -11,7 +11,7 @@ allowed-tools: - AskUserQuestion --- -Bridge local completion → merged PR. After /gsd:verify-work passes, ship the work: push branch, create PR with auto-generated body, optionally trigger review, and track the merge. +Bridge local completion → merged PR. After /gsd-verify-work passes, ship the work: push branch, create PR with auto-generated body, optionally trigger review, and track the merge. Closes the plan → execute → verify → ship loop. diff --git a/commands/gsd/sketch.md b/commands/gsd/sketch.md index be399bae..8d3e543a 100644 --- a/commands/gsd/sketch.md +++ b/commands/gsd/sketch.md @@ -25,7 +25,7 @@ Two modes: - **Idea mode** (default) — describe a design idea to sketch - **Frontier mode** (no argument or "frontier") — analyzes existing sketch landscape and proposes consistency and frontier sketches -Does not require `/gsd:new-project` — auto-creates `.planning/sketches/` if needed. +Does not require `/gsd-new-project` — auto-creates `.planning/sketches/` if needed. diff --git a/commands/gsd/spec-phase.md b/commands/gsd/spec-phase.md index ab4de9e7..a38916ff 100644 --- a/commands/gsd/spec-phase.md +++ b/commands/gsd/spec-phase.md @@ -58,5 +58,5 @@ Execute the spec-phase workflow from @~/.claude/get-shit-done/workflows/spec-pha - Gate passed: ambiguity ≤ 0.20 AND all dimension minimums met - SPEC.md written with falsifiable requirements, explicit boundaries, and acceptance criteria - SPEC.md committed atomically -- User knows they can now run /gsd:discuss-phase which will load SPEC.md automatically +- User knows they can now run /gsd-discuss-phase which will load SPEC.md automatically diff --git a/commands/gsd/spike.md b/commands/gsd/spike.md index 4df73184..762238c9 100644 --- a/commands/gsd/spike.md +++ b/commands/gsd/spike.md @@ -25,7 +25,7 @@ Two modes: - **Idea mode** (default) — describe an idea to spike - **Frontier mode** (no argument or "frontier") — analyzes existing spike landscape and proposes integration and frontier spikes -Does not require `/gsd:new-project` — auto-creates `.planning/spikes/` if needed. +Does not require `/gsd-new-project` — auto-creates `.planning/spikes/` if needed. diff --git a/commands/gsd/thread.md b/commands/gsd/thread.md index b40f63b2..023b1590 100644 --- a/commands/gsd/thread.md +++ b/commands/gsd/thread.md @@ -62,7 +62,7 @@ frontend-build-tools resolved 2026-04-01 Vite vs webpack If no threads exist (or none match the filter): ``` -No threads found. Create one with: /gsd:thread +No threads found. Create one with: /gsd-thread ``` STOP after displaying. Do NOT proceed to further steps. @@ -117,8 +117,8 @@ When SUBCMD=status and SLUG is set (already sanitized): Next Steps: {content of ## Next Steps section} ───────────────────────────────────── - Resume with: /gsd:thread {SLUG} - Close with: /gsd:thread close {SLUG} + Resume with: /gsd-thread {SLUG} + Close with: /gsd-thread close {SLUG} ``` No agent spawn. STOP after printing. @@ -201,8 +201,8 @@ updated: {today ISO date} Thread: {slug} File: .planning/threads/{slug}.md - Resume anytime with: /gsd:thread {slug} - Close when done with: /gsd:thread close {slug} + Resume anytime with: /gsd-thread {slug} + Close when done with: /gsd-thread close {slug} ``` @@ -210,10 +210,10 @@ updated: {today ISO date} - Threads are NOT phase-scoped — they exist independently of the roadmap -- Lighter weight than /gsd:pause-work — no phase state, no plan context +- Lighter weight than /gsd-pause-work — no phase state, no plan context - The value is in Context and Next Steps — a cold-start session can pick up immediately - Threads can be promoted to phases or backlog items when they mature: - /gsd:add-phase or /gsd:add-backlog with context from the thread + /gsd-add-phase or /gsd-add-backlog with context from the thread - Thread files live in .planning/threads/ — no collision with phases or other GSD structures - Thread status values: `open`, `in_progress`, `resolved` diff --git a/commands/gsd/ultraplan-phase.md b/commands/gsd/ultraplan-phase.md index 1b231206..1a5e3aab 100644 --- a/commands/gsd/ultraplan-phase.md +++ b/commands/gsd/ultraplan-phase.md @@ -1,6 +1,6 @@ --- name: gsd:ultraplan-phase -description: "[BETA] Offload plan phase to Claude Code's ultraplan cloud — drafts remotely while terminal stays free, review in browser with inline comments, import back via /gsd:import. Claude Code only." +description: "[BETA] Offload plan phase to Claude Code's ultraplan cloud — drafts remotely while terminal stays free, review in browser with inline comments, import back via /gsd-import. Claude Code only." argument-hint: "[phase-number]" allowed-tools: - Read @@ -13,9 +13,9 @@ allowed-tools: Offload GSD's plan phase to Claude Code's ultraplan cloud infrastructure. Ultraplan drafts the plan in a remote cloud session while your terminal stays free. -Review and comment on the plan in your browser, then import it back via /gsd:import --from. +Review and comment on the plan in your browser, then import it back via /gsd-import --from. -⚠ BETA: ultraplan is in research preview. Use /gsd:plan-phase for stable local planning. +⚠ BETA: ultraplan is in research preview. Use /gsd-plan-phase for stable local planning. Requirements: Claude Code v2.1.91+, claude.ai account, GitHub repository. diff --git a/commands/gsd/verify-work.md b/commands/gsd/verify-work.md index 089dcb8e..db5234b2 100644 --- a/commands/gsd/verify-work.md +++ b/commands/gsd/verify-work.md @@ -16,7 +16,7 @@ Validate built features through conversational testing with persistent state. Purpose: Confirm what Claude built actually works from user's perspective. One test at a time, plain text responses, no interrogation. When issues are found, automatically diagnose, plan fixes, and prepare for execution. -Output: {phase_num}-UAT.md tracking all test results. If issues found: diagnosed gaps, verified fix plans ready for /gsd:execute-phase +Output: {phase_num}-UAT.md tracking all test results. If issues found: diagnosed gaps, verified fix plans ready for /gsd-execute-phase diff --git a/commands/gsd/workstreams.md b/commands/gsd/workstreams.md index 6a834647..12436858 100644 --- a/commands/gsd/workstreams.md +++ b/commands/gsd/workstreams.md @@ -6,13 +6,13 @@ allowed-tools: - Bash --- -# /gsd:workstreams +# /gsd-workstreams Manage parallel workstreams for concurrent milestone work. ## Usage -`/gsd:workstreams [subcommand] [args]` +`/gsd-workstreams [subcommand] [args]` ### Subcommands @@ -40,7 +40,7 @@ Display the workstreams in a table format showing name, status, current phase, a ### create Run: `gsd-sdk query workstream.create --raw --cwd "$CWD"` After creation, display the new workstream path and suggest next steps: -- `/gsd:new-milestone --ws ` to set up the milestone +- `/gsd-new-milestone --ws ` to set up the milestone ### status Run: `gsd-sdk query workstream.status --raw --cwd "$CWD"` @@ -61,7 +61,7 @@ Run: `gsd-sdk query workstream.complete --raw --cwd "$CWD"` Archive the workstream to milestones/. ### resume -Set the workstream as active and suggest `/gsd:resume-work --ws `. +Set the workstream as active and suggest `/gsd-resume-work --ws `. ## Step 3: Display Results diff --git a/get-shit-done/bin/lib/audit.cjs b/get-shit-done/bin/lib/audit.cjs index ab6cf923..1ef751ea 100644 --- a/get-shit-done/bin/lib/audit.cjs +++ b/get-shit-done/bin/lib/audit.cjs @@ -4,7 +4,7 @@ * Scans all .planning/ artifact categories for items with open/unresolved state. * Returns structured JSON for workflow consumption. * Called by: gsd-tools.cjs audit-open - * Used by: /gsd:complete-milestone pre-close gate + * Used by: /gsd-complete-milestone pre-close gate */ 'use strict'; diff --git a/get-shit-done/bin/lib/commands.cjs b/get-shit-done/bin/lib/commands.cjs index 290771d5..a7743664 100644 --- a/get-shit-done/bin/lib/commands.cjs +++ b/get-shit-done/bin/lib/commands.cjs @@ -773,7 +773,7 @@ function cmdScaffold(cwd, type, options, raw) { switch (type) { case 'context': { filePath = path.join(phaseDir, `${padded}-CONTEXT.md`); - content = `---\nphase: "${padded}"\nname: "${name || phaseInfo?.phase_name || 'Unnamed'}"\ncreated: ${today}\n---\n\n# Phase ${phase}: ${name || phaseInfo?.phase_name || 'Unnamed'} — Context\n\n## Decisions\n\n_Decisions will be captured during /gsd:discuss-phase ${phase}_\n\n## Discretion Areas\n\n_Areas where the executor can use judgment_\n\n## Deferred Ideas\n\n_Ideas to consider later_\n`; + content = `---\nphase: "${padded}"\nname: "${name || phaseInfo?.phase_name || 'Unnamed'}"\ncreated: ${today}\n---\n\n# Phase ${phase}: ${name || phaseInfo?.phase_name || 'Unnamed'} — Context\n\n## Decisions\n\n_Decisions will be captured during /gsd-discuss-phase ${phase}_\n\n## Discretion Areas\n\n_Areas where the executor can use judgment_\n\n## Deferred Ideas\n\n_Ideas to consider later_\n`; break; } case 'uat': { diff --git a/get-shit-done/bin/lib/config.cjs b/get-shit-done/bin/lib/config.cjs index 9df489d8..fdb9d3ee 100644 --- a/get-shit-done/bin/lib/config.cjs +++ b/get-shit-done/bin/lib/config.cjs @@ -42,7 +42,7 @@ function validateKnownConfigKeyPath(keyPath) { * Merges (increasing priority): * 1. Hardcoded defaults — every key that loadConfig() resolves, plus mode/granularity * 2. User-level defaults from ~/.gsd/defaults.json (if present) - * 3. userChoices — the settings the user explicitly selected during /gsd:new-project + * 3. userChoices — the settings the user explicitly selected during /gsd-new-project * * Uses the canonical `git` namespace for branching keys (consistent with VALID_CONFIG_KEYS * and the settings workflow). loadConfig() handles both flat and nested formats, so this @@ -166,7 +166,7 @@ function buildNewProjectConfig(userChoices) { * Command: create a fully-materialized .planning/config.json for a new project. * * Accepts user-chosen settings as a JSON string (the keys the user explicitly - * configured during /gsd:new-project). All remaining keys are filled from + * configured during /gsd-new-project). All remaining keys are filled from * hardcoded defaults and optional ~/.gsd/defaults.json. * * Idempotent: if config.json already exists, returns { created: false }. diff --git a/get-shit-done/bin/lib/core.cjs b/get-shit-done/bin/lib/core.cjs index aa60d3ff..28c22a2a 100644 --- a/get-shit-done/bin/lib/core.cjs +++ b/get-shit-done/bin/lib/core.cjs @@ -263,7 +263,7 @@ const CONFIG_DEFAULTS = { phase_naming: 'sequential', // 'sequential' (default, auto-increment) or 'custom' (arbitrary string IDs) project_code: null, // optional short prefix for phase dirs (e.g., 'CK' → 'CK-01-foundation') subagent_timeout: 300000, // 5 min default; increase for large codebases or slower models (ms) - security_enforcement: true, // workflow.security_enforcement — threat-model-anchored security verification via /gsd:secure-phase + security_enforcement: true, // workflow.security_enforcement — threat-model-anchored security verification via /gsd-secure-phase security_asvs_level: 1, // workflow.security_asvs_level — OWASP ASVS verification level (1=opportunistic, 2=standard, 3=comprehensive) security_block_on: 'high', // workflow.security_block_on — minimum severity that blocks phase advancement ('high' | 'medium' | 'low') post_planning_gaps: true, // workflow.post_planning_gaps — unified post-planning gap report (#2493): scan REQUIREMENTS.md + CONTEXT.md decisions vs all PLAN.md files diff --git a/get-shit-done/bin/lib/drift.cjs b/get-shit-done/bin/lib/drift.cjs index c4639131..0ee7bd2a 100644 --- a/get-shit-done/bin/lib/drift.cjs +++ b/get-shit-done/bin/lib/drift.cjs @@ -253,7 +253,7 @@ function buildMessage(elements, affectedPaths, action) { lines.push(`Auto-remap scheduled for paths: ${affectedPaths.join(', ')}`); } else { lines.push( - `Run /gsd:map-codebase --paths ${affectedPaths.join(',')} to refresh planning context.`, + `Run /gsd-map-codebase --paths ${affectedPaths.join(',')} to refresh planning context.`, ); } return lines.join('\n'); diff --git a/get-shit-done/bin/lib/gsd2-import.cjs b/get-shit-done/bin/lib/gsd2-import.cjs index e8d602cd..26dea66f 100644 --- a/get-shit-done/bin/lib/gsd2-import.cjs +++ b/get-shit-done/bin/lib/gsd2-import.cjs @@ -420,7 +420,7 @@ function buildPreview(gsd2Data, artifacts) { lines.push(''); lines.push('Cannot migrate automatically:'); lines.push(' - GSD-2 cost/token ledger (no v1 equivalent)'); - lines.push(' - GSD-2 database state (rebuilt from files on first /gsd:health)'); + lines.push(' - GSD-2 database state (rebuilt from files on first /gsd-health)'); lines.push(' - VS Code extension state'); return lines.join('\n'); diff --git a/get-shit-done/bin/lib/init.cjs b/get-shit-done/bin/lib/init.cjs index 2570dcf3..f1dd9439 100644 --- a/get-shit-done/bin/lib/init.cjs +++ b/get-shit-done/bin/lib/init.cjs @@ -979,10 +979,10 @@ function cmdInitManager(cwd, raw) { // Validate prerequisites if (!fs.existsSync(paths.roadmap)) { - error('No ROADMAP.md found. Run /gsd:new-milestone first.'); + error('No ROADMAP.md found. Run /gsd-new-milestone first.'); } if (!fs.existsSync(paths.state)) { - error('No STATE.md found. Run /gsd:new-milestone first.'); + error('No STATE.md found. Run /gsd-new-milestone first.'); } const rawContent = fs.readFileSync(paths.roadmap, 'utf-8'); const content = extractCurrentMilestone(rawContent, cwd); @@ -1161,7 +1161,7 @@ function cmdInitManager(cwd, raw) { phase_name: phase.name, action: 'execute', reason: `${phase.plan_count} plans ready, dependencies met`, - command: `/gsd:execute-phase ${phase.number}`, + command: `/gsd-execute-phase ${phase.number}`, }); } else if (phase.disk_status === 'discussed' || phase.disk_status === 'researched') { recommendedActions.push({ @@ -1169,7 +1169,7 @@ function cmdInitManager(cwd, raw) { phase_name: phase.name, action: 'plan', reason: 'Context gathered, ready for planning', - command: `/gsd:plan-phase ${phase.number}`, + command: `/gsd-plan-phase ${phase.number}`, }); } else if ((phase.disk_status === 'empty' || phase.disk_status === 'no_directory') && phase.is_next_to_discuss) { recommendedActions.push({ @@ -1177,7 +1177,7 @@ function cmdInitManager(cwd, raw) { phase_name: phase.name, action: 'discuss', reason: 'Unblocked, ready to gather context', - command: `/gsd:discuss-phase ${phase.number}`, + command: `/gsd-discuss-phase ${phase.number}`, }); } } diff --git a/get-shit-done/bin/lib/phase.cjs b/get-shit-done/bin/lib/phase.cjs index 8c31af0a..5853ea5e 100644 --- a/get-shit-done/bin/lib/phase.cjs +++ b/get-shit-done/bin/lib/phase.cjs @@ -381,7 +381,7 @@ function cmdPhaseAdd(cwd, description, raw, customId) { // Build phase entry const dependsOn = config.phase_naming === 'custom' ? '' : `\n**Depends on:** Phase ${typeof _newPhaseId === 'number' ? _newPhaseId - 1 : 'TBD'}`; - const phaseEntry = `\n### Phase ${_newPhaseId}: ${description}\n\n**Goal:** [To be planned]\n**Requirements**: TBD${dependsOn}\n**Plans:** 0 plans\n\nPlans:\n- [ ] TBD (run /gsd:plan-phase ${_newPhaseId} to break down)\n`; + const phaseEntry = `\n### Phase ${_newPhaseId}: ${description}\n\n**Goal:** [To be planned]\n**Requirements**: TBD${dependsOn}\n**Plans:** 0 plans\n\nPlans:\n- [ ] TBD (run /gsd-plan-phase ${_newPhaseId} to break down)\n`; // Find insertion point: before last "---" or at end let updatedContent; @@ -458,7 +458,7 @@ function cmdPhaseAddBatch(cwd, descriptions, raw) { fs.mkdirSync(dirPath, { recursive: true }); fs.writeFileSync(path.join(dirPath, '.gitkeep'), ''); const dependsOn = config.phase_naming === 'custom' ? '' : `\n**Depends on:** Phase ${typeof newPhaseId === 'number' ? newPhaseId - 1 : 'TBD'}`; - const phaseEntry = `\n### Phase ${newPhaseId}: ${description}\n\n**Goal:** [To be planned]\n**Requirements**: TBD${dependsOn}\n**Plans:** 0 plans\n\nPlans:\n- [ ] TBD (run /gsd:plan-phase ${newPhaseId} to break down)\n`; + const phaseEntry = `\n### Phase ${newPhaseId}: ${description}\n\n**Goal:** [To be planned]\n**Requirements**: TBD${dependsOn}\n**Plans:** 0 plans\n\nPlans:\n- [ ] TBD (run /gsd-plan-phase ${newPhaseId} to break down)\n`; const lastSeparator = rawContent.lastIndexOf('\n---'); rawContent = lastSeparator > 0 ? rawContent.slice(0, lastSeparator) + phaseEntry + rawContent.slice(lastSeparator) @@ -542,7 +542,7 @@ function cmdPhaseInsert(cwd, afterPhase, description, raw) { fs.writeFileSync(path.join(dirPath, '.gitkeep'), ''); // Build phase entry - const phaseEntry = `\n### Phase ${_decimalPhase}: ${description} (INSERTED)\n\n**Goal:** [Urgent work - to be planned]\n**Requirements**: TBD\n**Depends on:** Phase ${afterPhase}\n**Plans:** 0 plans\n\nPlans:\n- [ ] TBD (run /gsd:plan-phase ${_decimalPhase} to break down)\n`; + const phaseEntry = `\n### Phase ${_decimalPhase}: ${description} (INSERTED)\n\n**Goal:** [Urgent work - to be planned]\n**Requirements**: TBD\n**Depends on:** Phase ${afterPhase}\n**Plans:** 0 plans\n\nPlans:\n- [ ] TBD (run /gsd-plan-phase ${_decimalPhase} to break down)\n`; // Insert after the target phase section const headerPattern = new RegExp(`(#{2,4}\\s*Phase\\s+0*${afterPhaseEscaped}:[^\\n]*\\n)`, 'i'); @@ -828,7 +828,7 @@ function cmdPhaseComplete(cwd, phaseNum, raw) { // Update plan count in phase section. // Use direct .replace() rather than replaceInCurrentMilestone() so this // works when the current milestone section is itself inside a
- // block (the standard /gsd:new-project layout). replaceInCurrentMilestone + // block (the standard /gsd-new-project layout). replaceInCurrentMilestone // scopes to content after the last
, which misses content inside // the current milestone's own
wrapper (#2005). // The phase-scoped heading pattern is specific enough to avoid matching diff --git a/get-shit-done/bin/lib/profile-output.cjs b/get-shit-done/bin/lib/profile-output.cjs index 9153b182..e899383b 100644 --- a/get-shit-done/bin/lib/profile-output.cjs +++ b/get-shit-done/bin/lib/profile-output.cjs @@ -173,7 +173,7 @@ const CLAUDE_INSTRUCTIONS = { }; const CLAUDE_MD_FALLBACKS = { - project: 'Project not yet initialized. Run /gsd:new-project to set up.', + project: 'Project not yet initialized. Run /gsd-new-project to set up.', stack: 'Technology stack not yet documented. Will populate after codebase mapping or first phase.', conventions: 'Conventions not yet established. Will populate as patterns emerge during development.', architecture: 'Architecture not yet mapped. Follow existing patterns found in the codebase.', @@ -187,9 +187,9 @@ const CLAUDE_MD_WORKFLOW_ENFORCEMENT = [ 'Before using Edit, Write, or other file-changing tools, start work through a GSD command so planning artifacts and execution context stay in sync.', '', 'Use these entry points:', - '- `/gsd:quick` for small fixes, doc updates, and ad-hoc tasks', - '- `/gsd:debug` for investigation and bug fixing', - '- `/gsd:execute-phase` for planned phase work', + '- `/gsd-quick` for small fixes, doc updates, and ad-hoc tasks', + '- `/gsd-debug` for investigation and bug fixing', + '- `/gsd-execute-phase` for planned phase work', '', 'Do not make direct repo edits outside a GSD workflow unless the user explicitly asks to bypass it.', ].join('\n'); @@ -198,7 +198,7 @@ const CLAUDE_MD_PROFILE_PLACEHOLDER = [ '', '## Developer Profile', '', - '> Profile not yet configured. Run `/gsd:profile-user` to generate your developer profile.', + '> Profile not yet configured. Run `/gsd-profile-user` to generate your developer profile.', '> This section is managed by `generate-claude-profile` -- do not edit manually.', '', ].join('\n'); @@ -768,7 +768,7 @@ function cmdGenerateDevPreferences(cwd, options, raw) { let stackBlock; if (analysis.data_source === 'questionnaire') { - stackBlock = 'Stack preferences not available (questionnaire-only profile). Run `/gsd:profile-user --refresh` with session data to populate.'; + stackBlock = 'Stack preferences not available (questionnaire-only profile). Run `/gsd-profile-user --refresh` with session data to populate.'; } else if (options.stack) { stackBlock = options.stack; } else { @@ -854,7 +854,7 @@ function cmdGenerateClaudeProfile(cwd, options, raw) { '', '## Developer Profile', '', - `> Generated by GSD from ${dataSource}. Run \`/gsd:profile-user --refresh\` to update.`, + `> Generated by GSD from ${dataSource}. Run \`/gsd-profile-user --refresh\` to update.`, '', '| Dimension | Rating | Confidence |', '|-----------|--------|------------|', @@ -1053,7 +1053,7 @@ function cmdGenerateClaudeMd(cwd, options, raw) { let message = `Generated ${genCount}/${totalManaged} sections.`; if (sectionsFallback.length > 0) message += ` Fallback: ${sectionsFallback.join(', ')}.`; if (sectionsSkipped.length > 0) message += ` Skipped (manually edited): ${sectionsSkipped.join(', ')}.`; - if (profileStatus === 'placeholder_added') message += ' Run /gsd:profile-user to unlock Developer Profile.'; + if (profileStatus === 'placeholder_added') message += ' Run /gsd-profile-user to unlock Developer Profile.'; const result = { claude_md_path: outputPath, diff --git a/get-shit-done/bin/lib/secrets.cjs b/get-shit-done/bin/lib/secrets.cjs index e8a62981..0c170425 100644 --- a/get-shit-done/bin/lib/secrets.cjs +++ b/get-shit-done/bin/lib/secrets.cjs @@ -2,7 +2,7 @@ /** * Secrets handling — masking convention for API keys and other - * credentials managed via /gsd:settings-integrations. + * credentials managed via /gsd-settings-integrations. * * Convention: strings 8+ chars long render as `****`; shorter * strings render as `****` with no tail (to avoid leaking a meaningful diff --git a/get-shit-done/bin/lib/verify.cjs b/get-shit-done/bin/lib/verify.cjs index e5d9dddc..699ce29e 100644 --- a/get-shit-done/bin/lib/verify.cjs +++ b/get-shit-done/bin/lib/verify.cjs @@ -555,7 +555,7 @@ function cmdValidateHealth(cwd, options, raw) { // ─── Check 1: .planning/ exists ─────────────────────────────────────────── if (!fs.existsSync(planBase)) { - addIssue('error', 'E001', '.planning/ directory not found', 'Run /gsd:new-project to initialize'); + addIssue('error', 'E001', '.planning/ directory not found', 'Run /gsd-new-project to initialize'); output({ status: 'broken', errors, @@ -568,7 +568,7 @@ function cmdValidateHealth(cwd, options, raw) { // ─── Check 2: PROJECT.md exists and has required sections ───────────────── if (!fs.existsSync(projectPath)) { - addIssue('error', 'E002', 'PROJECT.md not found', 'Run /gsd:new-project to create'); + addIssue('error', 'E002', 'PROJECT.md not found', 'Run /gsd-new-project to create'); } else { const content = fs.readFileSync(projectPath, 'utf-8'); const requiredSections = ['## What This Is', '## Core Value', '## Requirements']; @@ -581,12 +581,12 @@ function cmdValidateHealth(cwd, options, raw) { // ─── Check 3: ROADMAP.md exists ─────────────────────────────────────────── if (!fs.existsSync(roadmapPath)) { - addIssue('error', 'E003', 'ROADMAP.md not found', 'Run /gsd:new-milestone to create roadmap'); + addIssue('error', 'E003', 'ROADMAP.md not found', 'Run /gsd-new-milestone to create roadmap'); } // ─── Check 4: STATE.md exists and references valid phases ───────────────── if (!fs.existsSync(statePath)) { - addIssue('error', 'E004', 'STATE.md not found', 'Run /gsd:health --repair to regenerate', true); + addIssue('error', 'E004', 'STATE.md not found', 'Run /gsd-health --repair to regenerate', true); repairs.push('regenerateState'); } else { const stateContent = fs.readFileSync(statePath, 'utf-8'); @@ -642,7 +642,7 @@ function cmdValidateHealth(cwd, options, raw) { 'warning', 'W002', `STATE.md references phase ${ref}, but only phases ${[...validPhases].sort().join(', ')} are declared`, - 'Review STATE.md manually before changing it; /gsd:health --repair will not overwrite an existing STATE.md for phase mismatches' + 'Review STATE.md manually before changing it; /gsd-health --repair will not overwrite an existing STATE.md for phase mismatches' ); } } @@ -651,7 +651,7 @@ function cmdValidateHealth(cwd, options, raw) { // ─── Check 5: config.json valid JSON + valid schema ─────────────────────── if (!fs.existsSync(configPath)) { - addIssue('warning', 'W003', 'config.json not found', 'Run /gsd:health --repair to create with defaults', true); + addIssue('warning', 'W003', 'config.json not found', 'Run /gsd-health --repair to create with defaults', true); repairs.push('createConfig'); } else { try { @@ -663,7 +663,7 @@ function cmdValidateHealth(cwd, options, raw) { addIssue('warning', 'W004', `config.json: invalid model_profile "${parsed.model_profile}"`, `Valid values: ${validProfiles.join(', ')}`); } } catch (err) { - addIssue('error', 'E005', `config.json: JSON parse error - ${err.message}`, 'Run /gsd:health --repair to reset to defaults', true); + addIssue('error', 'E005', `config.json: JSON parse error - ${err.message}`, 'Run /gsd-health --repair to reset to defaults', true); repairs.push('resetConfig'); } } @@ -674,11 +674,11 @@ function cmdValidateHealth(cwd, options, raw) { const configRaw = fs.readFileSync(configPath, 'utf-8'); const configParsed = JSON.parse(configRaw); if (configParsed.workflow && configParsed.workflow.nyquist_validation === undefined) { - addIssue('warning', 'W008', 'config.json: workflow.nyquist_validation absent (defaults to enabled but agents may skip)', 'Run /gsd:health --repair to add key', true); + addIssue('warning', 'W008', 'config.json: workflow.nyquist_validation absent (defaults to enabled but agents may skip)', 'Run /gsd-health --repair to add key', true); if (!repairs.includes('addNyquistKey')) repairs.push('addNyquistKey'); } if (configParsed.workflow && configParsed.workflow.ai_integration_phase === undefined) { - addIssue('warning', 'W016', 'config.json: workflow.ai_integration_phase absent (defaults to enabled — run /gsd:ai-integration-phase before planning AI system phases)', 'Run /gsd:health --repair to add key', true); + addIssue('warning', 'W016', 'config.json: workflow.ai_integration_phase absent (defaults to enabled — run /gsd-ai-integration-phase before planning AI system phases)', 'Run /gsd-health --repair to add key', true); if (!repairs.includes('addAiIntegrationPhaseKey')) repairs.push('addAiIntegrationPhaseKey'); } } catch { /* intentionally empty */ } @@ -728,7 +728,7 @@ function cmdValidateHealth(cwd, options, raw) { try { const researchContent = fs.readFileSync(path.join(phasesDir, e.name, researchFile), 'utf-8'); if (researchContent.includes('## Validation Architecture')) { - addIssue('warning', 'W009', `Phase ${e.name}: has Validation Architecture in RESEARCH.md but no VALIDATION.md`, 'Re-run /gsd:plan-phase with --research to regenerate'); + addIssue('warning', 'W009', `Phase ${e.name}: has Validation Architecture in RESEARCH.md but no VALIDATION.md`, 'Re-run /gsd-plan-phase with --research to regenerate'); } } catch { /* intentionally empty */ } } @@ -821,7 +821,7 @@ function cmdValidateHealth(cwd, options, raw) { if (statusVal !== 'complete' && statusVal !== 'done') { addIssue('warning', 'W011', `STATE.md says current phase is ${statePhase} (status: ${statusVal || 'unknown'}) but ROADMAP.md shows it as [x] complete — state files may be out of sync`, - 'Run /gsd:progress to re-derive current position, or manually update STATE.md'); + 'Run /gsd-progress to re-derive current position, or manually update STATE.md'); } } } @@ -924,7 +924,7 @@ function cmdValidateHealth(cwd, options, raw) { if (missingFromRegistry.length > 0) { addIssue('warning', 'W018', `MILESTONES.md missing ${missingFromRegistry.length} archived milestone(s): ${missingFromRegistry.join(', ')}`, - 'Run /gsd:health --backfill to synthesize missing entries from archive snapshots', + 'Run /gsd-health --backfill to synthesize missing entries from archive snapshots', true); repairs.push('backfillMilestones'); } @@ -998,7 +998,7 @@ function cmdValidateHealth(cwd, options, raw) { stateContent += `**Current phase:** (determining...)\n`; stateContent += `**Status:** Resuming\n\n`; stateContent += `## Session Log\n\n`; - stateContent += `- ${new Date().toISOString().split('T')[0]}: STATE.md regenerated by /gsd:health --repair\n`; + stateContent += `- ${new Date().toISOString().split('T')[0]}: STATE.md regenerated by /gsd-health --repair\n`; writeStateMd(statePath, stateContent, cwd); repairActions.push({ action: repair, success: true, path: 'STATE.md' }); break; @@ -1048,7 +1048,7 @@ function cmdValidateHealth(cwd, options, raw) { // Build minimal entry from snapshot title or version const titleMatch = snapshot && snapshot.match(/^#\s+(.+)$/m); const milestoneName = titleMatch ? titleMatch[1].replace(/^Milestone\s+/i, '').replace(/^v[\d.]+\s*/, '').trim() : ver; - const entry = `## ${ver}${milestoneName && milestoneName !== ver ? ` ${milestoneName}` : ''} (Backfilled: ${today})\n\n**Note:** Synthesized from archive snapshot by \`/gsd:health --backfill\`. Original completion date unknown.\n\n---\n\n`; + const entry = `## ${ver}${milestoneName && milestoneName !== ver ? ` ${milestoneName}` : ''} (Backfilled: ${today})\n\n**Note:** Synthesized from archive snapshot by \`/gsd-health --backfill\`. Original completion date unknown.\n\n---\n\n`; const milestonesContent = fs.existsSync(milestonesPath) ? fs.readFileSync(milestonesPath, 'utf-8') : ''; diff --git a/get-shit-done/bin/lib/workstream.cjs b/get-shit-done/bin/lib/workstream.cjs index a7c24a48..55d69fc9 100644 --- a/get-shit-done/bin/lib/workstream.cjs +++ b/get-shit-done/bin/lib/workstream.cjs @@ -78,7 +78,7 @@ function cmdWorkstreamCreate(cwd, name, options, raw) { const baseDir = planningRoot(cwd); if (!fs.existsSync(baseDir)) { - error('.planning/ directory not found — run /gsd:new-project first'); + error('.planning/ directory not found — run /gsd-new-project first'); } const wsRoot = path.join(baseDir, 'workstreams'); diff --git a/get-shit-done/references/artifact-types.md b/get-shit-done/references/artifact-types.md index 9684e8cf..d472c32f 100644 --- a/get-shit-done/references/artifact-types.md +++ b/get-shit-done/references/artifact-types.md @@ -72,21 +72,21 @@ reads is inert — the consumption mechanism is what gives an artifact meaning. - **Location**: `.planning/spikes/SPIKE-NNN/` - **Consumed by**: Planner when spike is referenced; `pause-work` for spike context handoff -### Spike README.md / MANIFEST.md (per-spike, via /gsd:spike) +### Spike README.md / MANIFEST.md (per-spike, via /gsd-spike) - **Shape**: YAML frontmatter (spike, name, validates, verdict, related, tags) + run instructions + results -- **Lifecycle**: Created by `/gsd:spike` → Verified → Wrapped up by `/gsd:spike-wrap-up` +- **Lifecycle**: Created by `/gsd-spike` → Verified → Wrapped up by `/gsd-spike-wrap-up` - **Location**: `.planning/spikes/NNN-name/README.md`, `.planning/spikes/MANIFEST.md` -- **Consumed by**: `/gsd:spike-wrap-up` for curation; `pause-work` for spike context handoff +- **Consumed by**: `/gsd-spike-wrap-up` for curation; `pause-work` for spike context handoff ### Sketch README.md / MANIFEST.md / index.html (per-sketch) - **Shape**: YAML frontmatter (sketch, name, question, winner, tags) + variants as tabbed HTML -- **Lifecycle**: Created by `/gsd:sketch` → Evaluated → Wrapped up by `/gsd:sketch-wrap-up` +- **Lifecycle**: Created by `/gsd-sketch` → Evaluated → Wrapped up by `/gsd-sketch-wrap-up` - **Location**: `.planning/sketches/NNN-name/README.md`, `.planning/sketches/NNN-name/index.html`, `.planning/sketches/MANIFEST.md` -- **Consumed by**: `/gsd:sketch-wrap-up` for curation; `pause-work` for sketch context handoff +- **Consumed by**: `/gsd-sketch-wrap-up` for curation; `pause-work` for sketch context handoff ### WRAP-UP-SUMMARY.md (per wrap-up session) - **Shape**: Curation results, included/excluded items, feature/design area groupings -- **Lifecycle**: Created by `/gsd:spike-wrap-up` or `/gsd:sketch-wrap-up` +- **Lifecycle**: Created by `/gsd-spike-wrap-up` or `/gsd-sketch-wrap-up` - **Location**: `.planning/spikes/WRAP-UP-SUMMARY.md` or `.planning/sketches/WRAP-UP-SUMMARY.md` - **Consumed by**: Project history; not read by automated workflows diff --git a/get-shit-done/references/continuation-format.md b/get-shit-done/references/continuation-format.md index 9b2fd2ca..e810859b 100644 --- a/get-shit-done/references/continuation-format.md +++ b/get-shit-done/references/continuation-format.md @@ -50,13 +50,13 @@ Standard format for presenting next steps after completing a command or workflow `/clear` then: -`/gsd:execute-phase 2` +`/gsd-execute-phase 2` --- **Also available:** - Review plan before executing -- `/gsd:list-phase-assumptions 2` — check assumptions +- `/gsd-list-phase-assumptions 2` — check assumptions --- ``` @@ -75,7 +75,7 @@ Add note that this is the last plan and what comes after: `/clear` then: -`/gsd:execute-phase 2` +`/gsd-execute-phase 2` --- @@ -97,13 +97,13 @@ Add note that this is the last plan and what comes after: `/clear` then: -`/gsd:plan-phase 2` +`/gsd-plan-phase 2` --- **Also available:** -- `/gsd:discuss-phase 2` — gather context first -- `/gsd:research-phase 2` — investigate unknowns +- `/gsd-discuss-phase 2` — gather context first +- `/gsd-research-phase 2` — investigate unknowns - Review roadmap --- @@ -126,13 +126,13 @@ Show completion status before next action: `/clear` then: -`/gsd:plan-phase 3` +`/gsd-plan-phase 3` --- **Also available:** -- `/gsd:discuss-phase 3` — gather context first -- `/gsd:research-phase 3` — investigate unknowns +- `/gsd-discuss-phase 3` — gather context first +- `/gsd-research-phase 3` — investigate unknowns - Review what Phase 2 built --- @@ -151,11 +151,11 @@ When there's no clear primary action: `/clear` then one of: -**To plan directly:** `/gsd:plan-phase 3` +**To plan directly:** `/gsd-plan-phase 3` -**To discuss context first:** `/gsd:discuss-phase 3` +**To discuss context first:** `/gsd-discuss-phase 3` -**To research unknowns:** `/gsd:research-phase 3` +**To research unknowns:** `/gsd-research-phase 3` --- ``` @@ -175,7 +175,7 @@ All 4 phases shipped `/clear` then: -`/gsd:new-milestone` +`/gsd-new-milestone` --- ``` @@ -218,7 +218,7 @@ Extract: `**02-03: Refresh Token Rotation** — Add /api/auth/refresh with slidi ## To Continue Run `/clear`, then paste: -/gsd:execute-phase 2 +/gsd-execute-phase 2 ``` User has no idea what 02-03 is about. @@ -226,7 +226,7 @@ User has no idea what 02-03 is about. ### Don't: Missing /clear explanation ``` -`/gsd:plan-phase 3` +`/gsd-plan-phase 3` Run /clear first. ``` @@ -246,7 +246,7 @@ Sounds like an afterthought. Use "Also available:" instead. ``` ``` -/gsd:plan-phase 3 +/gsd-plan-phase 3 ``` ``` diff --git a/get-shit-done/references/doc-conflict-engine.md b/get-shit-done/references/doc-conflict-engine.md index 5e8a338b..67dc685f 100644 --- a/get-shit-done/references/doc-conflict-engine.md +++ b/get-shit-done/references/doc-conflict-engine.md @@ -1,6 +1,6 @@ # Doc Conflict Engine -Shared conflict-detection contract for workflows that ingest external content into `.planning/` (e.g., `/gsd:import`, `/gsd:ingest-docs`). Defines the report format, severity semantics, and safety-gate behavior. The specific checks that populate each severity bucket are workflow-specific and defined by the calling workflow. +Shared conflict-detection contract for workflows that ingest external content into `.planning/` (e.g., `/gsd-import`, `/gsd-ingest-docs`). Defines the report format, severity semantics, and safety-gate behavior. The specific checks that populate each severity bucket are workflow-specific and defined by the calling workflow. --- diff --git a/get-shit-done/references/domain-probes.md b/get-shit-done/references/domain-probes.md index 1c24806a..62acdfd6 100644 --- a/get-shit-done/references/domain-probes.md +++ b/get-shit-done/references/domain-probes.md @@ -1,6 +1,6 @@ # Domain-Aware Probing Patterns -Shared reference for `/gsd-begin`, `/gsd:discuss-phase`, and domain exploration workflows. +Shared reference for `/gsd-begin`, `/gsd-discuss-phase`, and domain exploration workflows. When the user mentions a technology area, use these probes to ask insightful follow-up questions. Don't run through them as a checklist -- pick the 2-3 most relevant based on context. The goal is to surface hidden assumptions and trade-offs the user may not have considered yet. diff --git a/get-shit-done/references/gate-prompts.md b/get-shit-done/references/gate-prompts.md index 930d0636..49a413ca 100644 --- a/get-shit-done/references/gate-prompts.md +++ b/get-shit-done/references/gate-prompts.md @@ -47,7 +47,7 @@ Simple 2-option confirmation for re-planning, rebuild, replace plans, commit. 4-option escalation for review escalation (max retries exceeded). - question: "Phase {N} has failed verification {attempt} times. How should we proceed?" - header: "Escalate" -- options: Accept gaps | Re-plan (via /gsd:plan-phase) | Debug (via /gsd:debug) | Retry +- options: Accept gaps | Re-plan (via /gsd-plan-phase) | Debug (via /gsd-debug) | Retry ## Pattern: multi-option-gaps 4-option gap handler for review gaps-found. @@ -78,7 +78,7 @@ Up to 4 suggested next actions with selection (status, resume workflows). 3-option confirmation for quick task scope validation. - question: "This task looks complex. Proceed as quick task or use full planning?" - header: "Scope" -- options: Quick task | Full plan (via /gsd:plan-phase) | Revise +- options: Quick task | Full plan (via /gsd-plan-phase) | Revise ## Pattern: depth-select 3-option depth selection for planning workflow preferences. diff --git a/get-shit-done/references/gates.md b/get-shit-done/references/gates.md index dd015f29..df43cf80 100644 --- a/get-shit-done/references/gates.md +++ b/get-shit-done/references/gates.md @@ -38,7 +38,7 @@ Canonical gate types used across GSD workflows. Every validation checkpoint maps **Recovery:** Developer investigates root cause, fixes, restarts from checkpoint. **Examples:** - Context window critically low during execution -- STATE.md in error state blocking /gsd:next +- STATE.md in error state blocking /gsd-next - Verification finds critical missing deliverables --- diff --git a/get-shit-done/references/git-integration.md b/get-shit-done/references/git-integration.md index b9354dc2..3ac371ed 100644 --- a/get-shit-done/references/git-integration.md +++ b/get-shit-done/references/git-integration.md @@ -274,7 +274,7 @@ Set `commit_docs: false` so planning docs stay local and are not committed to an ### How It Works -1. **Auto-detection:** During `/gsd:new-project`, directories with their own `.git` folder are detected and offered for selection as sub-repos. On subsequent runs, `loadConfig` auto-syncs the `sub_repos` list with the filesystem — adding newly created repos and removing deleted ones. This means `config.json` may be rewritten automatically when repos change on disk. +1. **Auto-detection:** During `/gsd-new-project`, directories with their own `.git` folder are detected and offered for selection as sub-repos. On subsequent runs, `loadConfig` auto-syncs the `sub_repos` list with the filesystem — adding newly created repos and removing deleted ones. This means `config.json` may be rewritten automatically when repos change on disk. 2. **File grouping:** Code files are grouped by their sub-repo prefix (e.g., `backend/src/api/users.ts` belongs to the `backend/` repo). 3. **Independent commits:** Each sub-repo receives its own atomic commit via `gsd-tools.cjs commit-to-subrepo`. File paths are made relative to the sub-repo root before staging. 4. **Planning stays local:** The `.planning/` directory is not committed; it acts as cross-repo coordination. diff --git a/get-shit-done/references/model-profiles.md b/get-shit-done/references/model-profiles.md index 828dff0d..6bd4420b 100644 --- a/get-shit-done/references/model-profiles.md +++ b/get-shit-done/references/model-profiles.md @@ -75,7 +75,7 @@ If you're using Claude Code with OpenRouter, a local model, or any non-Anthropic ```bash # Via settings command -/gsd:settings +/gsd-settings # → Select "Inherit" for model profile # Or manually in .planning/config.json @@ -115,7 +115,7 @@ Overrides take precedence over the profile. Valid values: `opus`, `sonnet`, `hai ## Switching Profiles -Runtime: `/gsd:set-profile ` +Runtime: `/gsd-set-profile ` Per-project default: Set in `.planning/config.json`: ```json diff --git a/get-shit-done/references/planning-config.md b/get-shit-done/references/planning-config.md index 569b1ec8..ad057b3d 100644 --- a/get-shit-done/references/planning-config.md +++ b/get-shit-done/references/planning-config.md @@ -36,7 +36,7 @@ Configuration options for `.planning/` directory behavior. | `workflow.use_worktrees` | `true` | Whether executor agents run in isolated git worktrees. Set to `false` to disable worktrees — agents execute sequentially on the main working tree instead. Recommended for solo developers or when worktree merges cause issues. | | `workflow.subagent_timeout` | `300000` | Timeout in milliseconds for parallel subagent tasks (e.g. codebase mapping). Increase for large codebases or slower models. Default: 300000 (5 minutes). | | `workflow.inline_plan_threshold` | `2` | Plans with this many tasks or fewer execute inline (Pattern C) instead of spawning a subagent. Avoids ~14K token spawn overhead for small plans. Set to `0` to always spawn subagents. | -| `manager.flags.discuss` | `""` | Flags passed to `/gsd:discuss-phase` when dispatched from manager (e.g. `"--auto --analyze"`) | +| `manager.flags.discuss` | `""` | Flags passed to `/gsd-discuss-phase` when dispatched from manager (e.g. `"--auto --analyze"`) | | `manager.flags.plan` | `""` | Flags passed to plan workflow when dispatched from manager | | `manager.flags.execute` | `""` | Flags passed to execute workflow when dispatched from manager | | `response_language` | `null` | Language for user-facing questions and prompts across all phases/subagents (e.g. `"Portuguese"`, `"Japanese"`, `"Spanish"`). When set, all spawned agents include a directive to respond in this language. | @@ -236,7 +236,7 @@ Generated from `CONFIG_DEFAULTS` (core.cjs) and `VALID_CONFIG_KEYS` (config.cjs) | `context_window` | number | `200000` | `200000`, `1000000` | Context window size; set `1000000` for 1M-context models | | `resolve_model_ids` | boolean\|string | `false` | `false`, `true`, `"omit"` | Map model aliases to full Claude IDs; `"omit"` returns empty string | | `context` | string\|null | `null` | `"dev"`, `"research"`, `"review"` | Execution context profile that adjusts agent behavior: `"dev"` for development tasks, `"research"` for investigation/exploration, `"review"` for code review workflows | -| `review.models.` | string\|null | `null` | Any model ID string | Per-CLI model override for /gsd:review (e.g., `review.models.gemini`). Falls back to CLI default when null. | +| `review.models.` | string\|null | `null` | Any model ID string | Per-CLI model override for /gsd-review (e.g., `review.models.gemini`). Falls back to CLI default when null. | ### Workflow Fields @@ -252,7 +252,7 @@ Set via `workflow.*` namespace in config.json (e.g., `"workflow": { "research": | `workflow.auto_advance` | boolean | `false` | `true`, `false` | Auto-advance to next phase after completion | | `workflow.node_repair` | boolean | `true` | `true`, `false` | Attempt automatic repair of failed plan nodes | | `workflow.node_repair_budget` | number | `2` | Any positive integer | Max repair retries per failed node | -| `workflow.ai_integration_phase` | boolean | `true` | `true`, `false` | Run /gsd:ai-integration-phase before planning AI system phases | +| `workflow.ai_integration_phase` | boolean | `true` | `true`, `false` | Run /gsd-ai-integration-phase before planning AI system phases | | `workflow.ui_phase` | boolean | `true` | `true`, `false` | Generate UI-SPEC.md for frontend phases | | `workflow.ui_safety_gate` | boolean | `true` | `true`, `false` | Require safety gate approval for UI changes | | `workflow.text_mode` | boolean | `false` | `true`, `false` | Use plain-text numbered lists instead of AskUserQuestion menus | @@ -265,7 +265,7 @@ Set via `workflow.*` namespace in config.json (e.g., `"workflow": { "research": | `workflow.code_review` | boolean | `true` | `true`, `false` | Enable built-in code review step in the ship workflow | | `workflow.code_review_depth` | string | `"standard"` | `"light"`, `"standard"`, `"deep"` | Depth level for code review analysis in the ship workflow | | `workflow._auto_chain_active` | boolean | `false` | `true`, `false` | Internal: tracks whether autonomous chaining is active | -| `workflow.security_enforcement` | boolean | `true` | `true`, `false` | Enable threat-model-anchored security verification via `/gsd:secure-phase`. When `false`, security checks are skipped entirely | +| `workflow.security_enforcement` | boolean | `true` | `true`, `false` | Enable threat-model-anchored security verification via `/gsd-secure-phase`. When `false`, security checks are skipped entirely | | `workflow.security_asvs_level` | number | `1` | `1`, `2`, `3` | OWASP ASVS verification level. Level 1 = opportunistic, Level 2 = standard, Level 3 = comprehensive | | `workflow.security_block_on` | string | `"high"` | `"high"`, `"medium"`, `"low"` | Minimum severity that blocks phase advancement | | `workflow.post_planning_gaps` | boolean | `true` | `true`, `false` | Post-planning gap report (#2493). After plans are generated, scans REQUIREMENTS.md and CONTEXT.md `` against all PLAN.md files and emits a unified `Source \| Item \| Status` table. Non-blocking. Set to `false` to skip Step 13e of plan-phase. _Alias:_ `post_planning_gaps` is the flat-key form used in `CONFIG_DEFAULTS`; `workflow.post_planning_gaps` is the canonical namespaced form. | @@ -319,11 +319,11 @@ Set via `learnings.*` namespace (e.g., `"learnings": { "max_inject": 5 }`). Used ### Intel Fields -Set via `intel.*` namespace (e.g., `"intel": { "enabled": true }`). Controls the queryable codebase intelligence system consumed by `/gsd:intel`. +Set via `intel.*` namespace (e.g., `"intel": { "enabled": true }`). Controls the queryable codebase intelligence system consumed by `/gsd-intel`. | Key | Type | Default | Allowed Values | Description | |-----|------|---------|----------------|-------------| -| `intel.enabled` | boolean | `false` | `true`, `false` | Enable queryable codebase intelligence system. When `true`, `/gsd:intel` commands build and query a JSON index in `.planning/intel/`. | +| `intel.enabled` | boolean | `false` | `true`, `false` | Enable queryable codebase intelligence system. When `true`, `/gsd-intel` commands build and query a JSON index in `.planning/intel/`. | ### Manager Fields @@ -331,7 +331,7 @@ Set via `manager.*` namespace (e.g., `"manager": { "flags": { "discuss": "--auto | Key | Type | Default | Allowed Values | Description | |-----|------|---------|----------------|-------------| -| `manager.flags.discuss` | string | `""` | Any CLI flags string | Flags passed to `/gsd:discuss-phase` from manager (e.g., `"--auto --analyze"`) | +| `manager.flags.discuss` | string | `""` | Any CLI flags string | Flags passed to `/gsd-discuss-phase` from manager (e.g., `"--auto --analyze"`) | | `manager.flags.plan` | string | `""` | Any CLI flags string | Flags passed to plan workflow from manager | | `manager.flags.execute` | string | `""` | Any CLI flags string | Flags passed to execute workflow from manager | diff --git a/get-shit-done/references/thinking-partner.md b/get-shit-done/references/thinking-partner.md index c2be6ba2..f39732fe 100644 --- a/get-shit-done/references/thinking-partner.md +++ b/get-shit-done/references/thinking-partner.md @@ -69,7 +69,7 @@ Apply this recommendation to the revision? [Yes] / [No, let me decide] ### 3. Explore — Approach Comparison (requires #1729) **When:** During Socratic conversation, when multiple viable approaches emerge. -**Note:** This integration point will be added when /gsd:explore (#1729) lands. +**Note:** This integration point will be added when /gsd-explore (#1729) lands. --- diff --git a/get-shit-done/references/verification-overrides.md b/get-shit-done/references/verification-overrides.md index ab884a24..e7ffed87 100644 --- a/get-shit-done/references/verification-overrides.md +++ b/get-shit-done/references/verification-overrides.md @@ -163,10 +163,10 @@ Then re-run verification to apply. Overrides can also be managed through the verification workflow: -1. Run `/gsd:verify-work` — verification finds gaps +1. Run `/gsd-verify-work` — verification finds gaps 2. Review gaps — determine which are intentional deviations 3. Add override entries to VERIFICATION.md frontmatter -4. Re-run `/gsd:verify-work` — overrides are applied, remaining gaps shown +4. Re-run `/gsd-verify-work` — overrides are applied, remaining gaps shown @@ -183,7 +183,7 @@ When a phase is re-verified (e.g., after gap closure): ### At Milestone Completion -During `/gsd:audit-milestone`, overrides are surfaced in the audit report: +During `/gsd-audit-milestone`, overrides are surfaced in the audit report: ``` ### Verification Overrides ({count} across {phase_count} phases) diff --git a/get-shit-done/templates/AI-SPEC.md b/get-shit-done/templates/AI-SPEC.md index 46b3d8cc..b002d95f 100644 --- a/get-shit-done/templates/AI-SPEC.md +++ b/get-shit-done/templates/AI-SPEC.md @@ -1,6 +1,6 @@ # AI-SPEC — Phase {N}: {phase_name} -> AI design contract generated by `/gsd:ai-integration-phase`. Consumed by `gsd-planner` and `gsd-eval-auditor`. +> AI design contract generated by `/gsd-ai-integration-phase`. Consumed by `gsd-planner` and `gsd-eval-auditor`. > Locks framework selection, implementation guidance, and evaluation strategy before planning begins. --- diff --git a/get-shit-done/templates/DEBUG.md b/get-shit-done/templates/DEBUG.md index a23ea25e..9cf66c70 100644 --- a/get-shit-done/templates/DEBUG.md +++ b/get-shit-done/templates/DEBUG.md @@ -104,7 +104,7 @@ files_changed: [] -**Creation:** Immediately when /gsd:debug is called +**Creation:** Immediately when /gsd-debug is called - Create file with trigger from user input - Set status to "gathering" - Current Focus: next_action = "gather symptoms" diff --git a/get-shit-done/templates/README.md b/get-shit-done/templates/README.md index d8719e2b..84c70680 100644 --- a/get-shit-done/templates/README.md +++ b/get-shit-done/templates/README.md @@ -12,24 +12,24 @@ These files live directly at `.planning/` — not inside phase subdirectories. | File | Template | Produced by | Purpose | |------|----------|-------------|---------| -| `PROJECT.md` | `project.md` | `/gsd:new-project` | Project identity, goals, requirements summary | -| `ROADMAP.md` | `roadmap.md` | `/gsd:new-milestone`, `/gsd:new-project` | Phase plan with milestones and progress tracking | -| `STATE.md` | `state.md` | `/gsd:new-project`, `/gsd:health --repair` | Current session state, active phase, last activity | -| `REQUIREMENTS.md` | `requirements.md` | `/gsd:new-milestone` | Functional requirements with traceability | -| `MILESTONES.md` | `milestone.md` | `/gsd:complete-milestone` | Log of completed milestones with accomplishments | -| `BACKLOG.md` | *(inline)* | `/gsd:add-backlog` | Pending ideas and deferred work | -| `LEARNINGS.md` | *(inline)* | `/gsd-extract-learnings`, `/gsd:execute-phase` | Phase retrospective learnings for future plans | -| `THREADS.md` | *(inline)* | `/gsd:thread` | Persistent discussion threads | -| `config.json` | `config.json` | `/gsd:new-project`, `/gsd:health --repair` | Project-specific GSD configuration | +| `PROJECT.md` | `project.md` | `/gsd-new-project` | Project identity, goals, requirements summary | +| `ROADMAP.md` | `roadmap.md` | `/gsd-new-milestone`, `/gsd-new-project` | Phase plan with milestones and progress tracking | +| `STATE.md` | `state.md` | `/gsd-new-project`, `/gsd-health --repair` | Current session state, active phase, last activity | +| `REQUIREMENTS.md` | `requirements.md` | `/gsd-new-milestone` | Functional requirements with traceability | +| `MILESTONES.md` | `milestone.md` | `/gsd-complete-milestone` | Log of completed milestones with accomplishments | +| `BACKLOG.md` | *(inline)* | `/gsd-add-backlog` | Pending ideas and deferred work | +| `LEARNINGS.md` | *(inline)* | `/gsd-extract-learnings`, `/gsd-execute-phase` | Phase retrospective learnings for future plans | +| `THREADS.md` | *(inline)* | `/gsd-thread` | Persistent discussion threads | +| `config.json` | `config.json` | `/gsd-new-project`, `/gsd-health --repair` | Project-specific GSD configuration | | `CLAUDE.md` | `claude-md.md` | `/gsd-profile` | Auto-assembled Claude Code context file | ### Version-stamped artifacts (pattern: `vX.Y-*.md`) | Pattern | Produced by | Purpose | |---------|-------------|---------| -| `vX.Y-MILESTONE-AUDIT.md` | `/gsd:audit-milestone` | Milestone audit report before archiving | +| `vX.Y-MILESTONE-AUDIT.md` | `/gsd-audit-milestone` | Milestone audit report before archiving | -These files are archived to `.planning/milestones/` by `/gsd:complete-milestone`. Finding them at the `.planning/` root after completion indicates the archive step was skipped. +These files are archived to `.planning/milestones/` by `/gsd-complete-milestone`. Finding them at the `.planning/` root after completion indicates the archive step was skipped. --- @@ -39,24 +39,24 @@ These files live inside a phase directory. They are NOT checked by W019 (which o | File Pattern | Template | Produced by | Purpose | |-------------|----------|-------------|---------| -| `NN-MM-PLAN.md` | `phase-prompt.md` | `/gsd:plan-phase` | Executable implementation plan | -| `NN-MM-SUMMARY.md` | `summary.md` | `/gsd:execute-phase` | Post-execution summary with learnings | -| `NN-CONTEXT.md` | `context.md` | `/gsd:discuss-phase` | Scoped discussion decisions for the phase | -| `NN-RESEARCH.md` | `research.md` | `/gsd:research-phase`, `/gsd:plan-phase` | Technical research for the phase | -| `NN-VALIDATION.md` | `VALIDATION.md` | `/gsd:research-phase` (Nyquist) | Validation architecture (Nyquist method) | -| `NN-UAT.md` | `UAT.md` | `/gsd:validate-phase` | User acceptance test results | -| `NN-PATTERNS.md` | *(inline)* | `/gsd:plan-phase` (pattern mapper) | Analog file mapping for the phase | -| `NN-UI-SPEC.md` | `UI-SPEC.md` | `/gsd:ui-phase` | UI design contract | -| `NN-SECURITY.md` | `SECURITY.md` | `/gsd:secure-phase` | Security threat model | -| `NN-AI-SPEC.md` | `AI-SPEC.md` | `/gsd:ai-integration-phase` | AI integration spec with eval strategy | -| `NN-DEBUG.md` | `DEBUG.md` | `/gsd:debug` | Debug session log | -| `NN-REVIEWS.md` | *(inline)* | `/gsd:review` | Cross-AI review feedback | +| `NN-MM-PLAN.md` | `phase-prompt.md` | `/gsd-plan-phase` | Executable implementation plan | +| `NN-MM-SUMMARY.md` | `summary.md` | `/gsd-execute-phase` | Post-execution summary with learnings | +| `NN-CONTEXT.md` | `context.md` | `/gsd-discuss-phase` | Scoped discussion decisions for the phase | +| `NN-RESEARCH.md` | `research.md` | `/gsd-research-phase`, `/gsd-plan-phase` | Technical research for the phase | +| `NN-VALIDATION.md` | `VALIDATION.md` | `/gsd-research-phase` (Nyquist) | Validation architecture (Nyquist method) | +| `NN-UAT.md` | `UAT.md` | `/gsd-validate-phase` | User acceptance test results | +| `NN-PATTERNS.md` | *(inline)* | `/gsd-plan-phase` (pattern mapper) | Analog file mapping for the phase | +| `NN-UI-SPEC.md` | `UI-SPEC.md` | `/gsd-ui-phase` | UI design contract | +| `NN-SECURITY.md` | `SECURITY.md` | `/gsd-secure-phase` | Security threat model | +| `NN-AI-SPEC.md` | `AI-SPEC.md` | `/gsd-ai-integration-phase` | AI integration spec with eval strategy | +| `NN-DEBUG.md` | `DEBUG.md` | `/gsd-debug` | Debug session log | +| `NN-REVIEWS.md` | *(inline)* | `/gsd-review` | Cross-AI review feedback | --- ## Milestone Archive (`.planning/milestones/`) -Files archived by `/gsd:complete-milestone`. These are never checked by W019. +Files archived by `/gsd-complete-milestone`. These are never checked by W019. | File Pattern | Source | |-------------|--------| diff --git a/get-shit-done/templates/UAT.md b/get-shit-done/templates/UAT.md index fd2345a9..523e4517 100644 --- a/get-shit-done/templates/UAT.md +++ b/get-shit-done/templates/UAT.md @@ -106,7 +106,7 @@ blocked: [N] **Gaps:** - APPEND only when issue found (YAML format) - After diagnosis: fill `root_cause`, `artifacts`, `missing`, `debug_session` -- This section feeds directly into /gsd:plan-phase --gaps +- This section feeds directly into /gsd-plan-phase --gaps @@ -120,7 +120,7 @@ blocked: [N] 4. UAT.md Gaps section updated with diagnosis: - Each gap gets `root_cause`, `artifacts`, `missing`, `debug_session` filled 5. status → "diagnosed" -6. Ready for /gsd:plan-phase --gaps with root causes +6. Ready for /gsd-plan-phase --gaps with root causes **After diagnosis:** ```yaml @@ -144,7 +144,7 @@ blocked: [N] -**Creation:** When /gsd:verify-work starts new session +**Creation:** When /gsd-verify-work starts new session - Extract tests from SUMMARY.md files - Set status to "testing" - Current Test points to test 1 @@ -171,7 +171,7 @@ blocked: [N] - Present summary with outstanding items highlighted **Resuming partial session:** -- `/gsd:verify-work {phase}` picks up from first pending/blocked test +- `/gsd-verify-work {phase}` picks up from first pending/blocked test - When all items resolved, status advances to "complete" **Resume after /clear:** diff --git a/get-shit-done/templates/VALIDATION.md b/get-shit-done/templates/VALIDATION.md index 6adaf46d..c435ce23 100644 --- a/get-shit-done/templates/VALIDATION.md +++ b/get-shit-done/templates/VALIDATION.md @@ -29,7 +29,7 @@ created: {date} - **After every task commit:** Run `{quick run command}` - **After every plan wave:** Run `{full suite command}` -- **Before `/gsd:verify-work`:** Full suite must be green +- **Before `/gsd-verify-work`:** Full suite must be green - **Max feedback latency:** {N} seconds --- diff --git a/get-shit-done/templates/claude-md.md b/get-shit-done/templates/claude-md.md index 4c96fd48..80ff26c4 100644 --- a/get-shit-done/templates/claude-md.md +++ b/get-shit-done/templates/claude-md.md @@ -21,7 +21,7 @@ The profile section is managed exclusively by `generate-claude-profile`. **Fallback text:** ``` -Project not yet initialized. Run /gsd:new-project to set up. +Project not yet initialized. Run /gsd-new-project to set up. ``` ### Stack Section @@ -96,9 +96,9 @@ No project skills found. Add skills to any of: `.claude/skills/`, `.agents/skill Before using Edit, Write, or other file-changing tools, start work through a GSD command so planning artifacts and execution context stay in sync. Use these entry points: -- `/gsd:quick` for small fixes, doc updates, and ad-hoc tasks -- `/gsd:debug` for investigation and bug fixing -- `/gsd:execute-phase` for planned phase work +- `/gsd-quick` for small fixes, doc updates, and ad-hoc tasks +- `/gsd-debug` for investigation and bug fixing +- `/gsd-execute-phase` for planned phase work Do not make direct repo edits outside a GSD workflow unless the user explicitly asks to bypass it. @@ -109,7 +109,7 @@ Do not make direct repo edits outside a GSD workflow unless the user explicitly ## Developer Profile -> Profile not yet configured. Run `/gsd:profile-user` to generate your developer profile. +> Profile not yet configured. Run `/gsd-profile-user` to generate your developer profile. > This section is managed by `generate-claude-profile` — do not edit manually. ``` diff --git a/get-shit-done/templates/debug-subagent-prompt.md b/get-shit-done/templates/debug-subagent-prompt.md index c90c7ce4..99be182b 100644 --- a/get-shit-done/templates/debug-subagent-prompt.md +++ b/get-shit-done/templates/debug-subagent-prompt.md @@ -51,7 +51,7 @@ Create: .planning/debug/{slug}.md ## Usage -**From /gsd:debug:** +**From /gsd-debug:** ```python Task( prompt=filled_template, diff --git a/get-shit-done/templates/dev-preferences.md b/get-shit-done/templates/dev-preferences.md index 428b5c5b..2a0013c5 100644 --- a/get-shit-done/templates/dev-preferences.md +++ b/get-shit-done/templates/dev-preferences.md @@ -5,7 +5,7 @@ description: Load developer preferences into this session # Developer Preferences > Generated by GSD on {{generated_at}} from {{data_source}}. -> Run `/gsd:profile-user --refresh` to regenerate. +> Run `/gsd-profile-user --refresh` to regenerate. ## Behavioral Directives diff --git a/get-shit-done/templates/discovery.md b/get-shit-done/templates/discovery.md index b9e2bb64..42c2b0f6 100644 --- a/get-shit-done/templates/discovery.md +++ b/get-shit-done/templates/discovery.md @@ -4,7 +4,7 @@ Template for `.planning/phases/XX-name/DISCOVERY.md` - shallow research for libr **Purpose:** Answer "which library/option should we use" questions during mandatory discovery in plan-phase. -For deep ecosystem research ("how do experts build this"), use `/gsd:research-phase` which produces RESEARCH.md. +For deep ecosystem research ("how do experts build this"), use `/gsd-research-phase` which produces RESEARCH.md. --- @@ -142,5 +142,5 @@ Create `.planning/phases/XX-name/DISCOVERY.md`: - Niche/complex domains (3D, games, audio, shaders) - Need ecosystem knowledge, not just library choice - "How do experts build this" questions -- Use `/gsd:research-phase` for these +- Use `/gsd-research-phase` for these diff --git a/get-shit-done/templates/phase-prompt.md b/get-shit-done/templates/phase-prompt.md index b242dc15..03937daf 100644 --- a/get-shit-done/templates/phase-prompt.md +++ b/get-shit-done/templates/phase-prompt.md @@ -142,7 +142,7 @@ After completion, create `.planning/phases/XX-name/{phase}-{plan}-SUMMARY.md` | `user_setup` | No | Array of human-required setup items (external services) | | `must_haves` | Yes | Goal-backward verification criteria (see below) | -**Wave is pre-computed:** Wave numbers are assigned during `/gsd:plan-phase`. Execute-phase reads `wave` directly from frontmatter and groups plans by wave number. No runtime dependency analysis needed. +**Wave is pre-computed:** Wave numbers are assigned during `/gsd-plan-phase`. Execute-phase reads `wave` directly from frontmatter and groups plans by wave number. No runtime dependency analysis needed. **Must-haves enable verification:** The `must_haves` field carries goal-backward requirements from planning to execution. After all plans complete, execute-phase spawns a verification subagent that checks these criteria against the actual codebase. diff --git a/get-shit-done/templates/planner-subagent-prompt.md b/get-shit-done/templates/planner-subagent-prompt.md index bcaa68d2..8be7fa0d 100644 --- a/get-shit-done/templates/planner-subagent-prompt.md +++ b/get-shit-done/templates/planner-subagent-prompt.md @@ -34,7 +34,7 @@ Template for spawning gsd-planner agent. The agent contains all planning experti -Output consumed by /gsd:execute-phase +Output consumed by /gsd-execute-phase Plans must be executable prompts with: - Frontmatter (wave, depends_on, files_modified, autonomous) - Tasks in XML format @@ -68,7 +68,7 @@ Before returning PLANNING COMPLETE: ## Usage -**From /gsd:plan-phase (standard mode):** +**From /gsd-plan-phase (standard mode):** ```python Task( prompt=filled_template, @@ -77,7 +77,7 @@ Task( ) ``` -**From /gsd:plan-phase --gaps (gap closure mode):** +**From /gsd-plan-phase --gaps (gap closure mode):** ```python Task( prompt=filled_template, # with mode: gap_closure diff --git a/get-shit-done/templates/project.md b/get-shit-done/templates/project.md index 37a986c7..dea673be 100644 --- a/get-shit-done/templates/project.md +++ b/get-shit-done/templates/project.md @@ -149,7 +149,7 @@ and implemented by workflows/transition.md and workflows/complete-milestone.md. For existing codebases: -1. **Map codebase first** via `/gsd:map-codebase` +1. **Map codebase first** via `/gsd-map-codebase` 2. **Infer Validated requirements** from existing code: - What does the codebase actually do? diff --git a/get-shit-done/templates/research.md b/get-shit-done/templates/research.md index bed3e1d5..30ef0926 100644 --- a/get-shit-done/templates/research.md +++ b/get-shit-done/templates/research.md @@ -18,7 +18,7 @@ Template for `.planning/phases/XX-name/{phase_num}-RESEARCH.md` - comprehensive ## User Constraints (from CONTEXT.md) -**CRITICAL:** If CONTEXT.md exists from /gsd:discuss-phase, copy locked decisions here verbatim. These MUST be honored by the planner. +**CRITICAL:** If CONTEXT.md exists from /gsd-discuss-phase, copy locked decisions here verbatim. These MUST be honored by the planner. ### Locked Decisions [Copy from CONTEXT.md `## Decisions` section - these are NON-NEGOTIABLE] diff --git a/get-shit-done/templates/spec.md b/get-shit-done/templates/spec.md index 18b8ce6e..99b61553 100644 --- a/get-shit-done/templates/spec.md +++ b/get-shit-done/templates/spec.md @@ -96,7 +96,7 @@ Status: ✓ = met minimum, ⚠ = below minimum (planner treats as assumption) *Phase: [XX-name]* *Spec created: [date]* -*Next step: /gsd:discuss-phase [X] — implementation decisions (how to build what's specified above)* +*Next step: /gsd-discuss-phase [X] — implementation decisions (how to build what's specified above)* ``` @@ -192,7 +192,7 @@ The database has a `posts` table and `follows` table. No feed query or feed UI e *Phase: 03-post-feed* *Spec created: 2025-01-20* -*Next step: /gsd:discuss-phase 3 — implementation decisions (card layout, loading skeleton, etc.)* +*Next step: /gsd-discuss-phase 3 — implementation decisions (card layout, loading skeleton, etc.)* ``` **Example 2: CLI tool (Database backup)** @@ -280,7 +280,7 @@ No backup tooling exists. The project uses PostgreSQL. Developers currently use *Phase: 02-backup-command* *Spec created: 2025-01-20* -*Next step: /gsd:discuss-phase 2 — implementation decisions (progress reporting, flag design, etc.)* +*Next step: /gsd-discuss-phase 2 — implementation decisions (progress reporting, flag design, etc.)* ``` diff --git a/get-shit-done/templates/state.md b/get-shit-done/templates/state.md index f15968b8..73976c51 100644 --- a/get-shit-done/templates/state.md +++ b/get-shit-done/templates/state.md @@ -153,10 +153,10 @@ Updated after each plan completion. **Decisions:** Reference to PROJECT.md Key Decisions table, plus recent decisions summary for quick access. Full decision log lives in PROJECT.md. -**Pending Todos:** Ideas captured via /gsd:add-todo +**Pending Todos:** Ideas captured via /gsd-add-todo - Count of pending todos - Reference to .planning/todos/pending/ -- Brief list if few, count if many (e.g., "5 pending todos — see /gsd:check-todos") +- Brief list if few, count if many (e.g., "5 pending todos — see /gsd-check-todos") **Blockers/Concerns:** From "Next Phase Readiness" sections - Issues that affect future work diff --git a/get-shit-done/workflows/add-phase.md b/get-shit-done/workflows/add-phase.md index 5e50d322..524e17a8 100644 --- a/get-shit-done/workflows/add-phase.md +++ b/get-shit-done/workflows/add-phase.md @@ -11,15 +11,15 @@ Read all files referenced by the invoking prompt's execution_context before star Parse the command arguments: - All arguments become the phase description -- Example: `/gsd:add-phase Add authentication` → description = "Add authentication" -- Example: `/gsd:add-phase Fix critical performance issues` → description = "Fix critical performance issues" +- Example: `/gsd-add-phase Add authentication` → description = "Add authentication" +- Example: `/gsd-add-phase Fix critical performance issues` → description = "Fix critical performance issues" If no arguments provided: ``` ERROR: Phase description required -Usage: /gsd:add-phase -Example: /gsd:add-phase Add authentication system +Usage: /gsd-add-phase +Example: /gsd-add-phase Add authentication system ``` Exit. @@ -36,7 +36,7 @@ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi Check `roadmap_exists` from init JSON. If false: ``` ERROR: No roadmap found (.planning/ROADMAP.md) -Run /gsd:new-project to initialize. +Run /gsd-new-project to initialize. ``` Exit. @@ -89,12 +89,12 @@ Roadmap updated: .planning/ROADMAP.md `/clear` then: -`/gsd:plan-phase {N}` +`/gsd-plan-phase {N}` --- **Also available:** -- `/gsd:add-phase ` — add another phase +- `/gsd-add-phase ` — add another phase - Review roadmap --- diff --git a/get-shit-done/workflows/add-tests.md b/get-shit-done/workflows/add-tests.md index 31b1f1de..732db401 100644 --- a/get-shit-done/workflows/add-tests.md +++ b/get-shit-done/workflows/add-tests.md @@ -1,7 +1,7 @@ Generate unit and E2E tests for a completed phase based on its SUMMARY.md, CONTEXT.md, and implementation. Classifies each changed file into TDD (unit), E2E (browser), or Skip categories, presents a test plan for user approval, then generates tests following RED-GREEN conventions. -Users currently hand-craft `/gsd:quick` prompts for test generation after each phase. This workflow standardizes the process with proper classification, quality gates, and gap reporting. +Users currently hand-craft `/gsd-quick` prompts for test generation after each phase. This workflow standardizes the process with proper classification, quality gates, and gap reporting. @@ -15,15 +15,15 @@ Parse `$ARGUMENTS` for: - Phase number (integer, decimal, or letter-suffix) → store as `$PHASE_ARG` - Remaining text after phase number → store as `$EXTRA_INSTRUCTIONS` (optional) -Example: `/gsd:add-tests 12 focus on edge cases` → `$PHASE_ARG=12`, `$EXTRA_INSTRUCTIONS="focus on edge cases"` +Example: `/gsd-add-tests 12 focus on edge cases` → `$PHASE_ARG=12`, `$EXTRA_INSTRUCTIONS="focus on edge cases"` If no phase argument provided: ``` ERROR: Phase number required -Usage: /gsd:add-tests [additional instructions] -Example: /gsd:add-tests 12 -Example: /gsd:add-tests 12 focus on edge cases in the pricing module +Usage: /gsd-add-tests [additional instructions] +Example: /gsd-add-tests 12 +Example: /gsd-add-tests 12 focus on edge cases in the pricing module ``` Exit. @@ -54,7 +54,7 @@ Read the phase artifacts (in order of priority): If no SUMMARY.md exists: ``` ERROR: No SUMMARY.md found for phase ${PHASE_ARG} -This command works on completed phases. Run /gsd:execute-phase first. +This command works on completed phases. Run /gsd-execute-phase first. ``` Exit. @@ -318,7 +318,7 @@ Present next steps: ## ▶ Next Up — [${PROJECT_CODE}] ${PROJECT_TITLE} {if bugs discovered:} -**Fix discovered bugs:** `/gsd:quick fix the {N} test failures discovered in phase ${phase_number}` +**Fix discovered bugs:** `/gsd-quick fix the {N} test failures discovered in phase ${phase_number}` {if blocked tests:} **Resolve test blockers:** {description of what's needed} @@ -329,8 +329,8 @@ Present next steps: --- **Also available:** -- `/gsd:add-tests {next_phase}` — test another phase -- `/gsd:verify-work {phase_number}` — run UAT verification +- `/gsd-add-tests {next_phase}` — test another phase +- `/gsd-verify-work {phase_number}` — run UAT verification --- ``` diff --git a/get-shit-done/workflows/add-todo.md b/get-shit-done/workflows/add-todo.md index b6c837c7..439859da 100644 --- a/get-shit-done/workflows/add-todo.md +++ b/get-shit-done/workflows/add-todo.md @@ -28,7 +28,7 @@ Note existing areas from the todos array for consistency in infer_area step. **With arguments:** Use as the title/focus. -- `/gsd:add-todo Add auth token refresh` → title = "Add auth token refresh" +- `/gsd-add-todo Add auth token refresh` → title = "Add auth token refresh" **Without arguments:** Analyze recent conversation to extract: - The specific problem, idea, or task discussed @@ -143,7 +143,7 @@ Would you like to: 1. Continue with current work 2. Add another todo -3. View all todos (/gsd:check-todos) +3. View all todos (/gsd-check-todos) ``` diff --git a/get-shit-done/workflows/ai-integration-phase.md b/get-shit-done/workflows/ai-integration-phase.md index 39d9344c..e8dcdc22 100644 --- a/get-shit-done/workflows/ai-integration-phase.md +++ b/get-shit-done/workflows/ai-integration-phase.md @@ -43,11 +43,11 @@ AI_PHASE_ENABLED=$(gsd-sdk query config-get workflow.ai_integration_phase 2>/dev **If `AI_PHASE_ENABLED` is `false`:** ``` -AI phase is disabled in config. Enable via /gsd:settings. +AI phase is disabled in config. Enable via /gsd-settings. ``` Exit workflow. -**If `planning_exists` is false:** Error — run `/gsd:new-project` first. +**If `planning_exists` is false:** Error — run `/gsd-new-project` first. ## 2. Parse and Validate Phase @@ -64,7 +64,7 @@ PHASE_INFO=$(gsd-sdk query roadmap.get-phase "${PHASE}") **If `has_context` is false:** ``` No CONTEXT.md found for Phase {N}. -Recommended: run /gsd:discuss-phase {N} first to capture framework preferences. +Recommended: run /gsd-discuss-phase {N} first to capture framework preferences. Continuing without user decisions — framework selector will ask all questions. ``` Continue (non-blocking). @@ -122,7 +122,7 @@ Goal: {phase_goal} Parse selector output for: `primary_framework`, `system_type`, `model_provider`, `eval_concerns`, `alternative_framework`. -**If selector fails or returns empty:** Exit with error — "Framework selection failed. Re-run /gsd:ai-integration-phase {N} or answer the framework question in /gsd:discuss-phase {N} first." +**If selector fails or returns empty:** Exit with error — "Framework selection failed. Re-run /gsd-ai-integration-phase {N} or answer the framework question in /gsd-discuss-phase {N} first." ## 6. Initialize AI-SPEC.md @@ -266,7 +266,7 @@ git commit -m "docs({phase_slug}): generate AI-SPEC.md — {primary_framework} + ◆ Output: {ai_spec_path} Next step: - /gsd:plan-phase {N} — planner will consume AI-SPEC.md + /gsd-plan-phase {N} — planner will consume AI-SPEC.md ``` diff --git a/get-shit-done/workflows/analyze-dependencies.md b/get-shit-done/workflows/analyze-dependencies.md index 376e31c9..618e3c9d 100644 --- a/get-shit-done/workflows/analyze-dependencies.md +++ b/get-shit-done/workflows/analyze-dependencies.md @@ -1,12 +1,12 @@ -Analyze ROADMAP.md phases for dependency relationships before execution. Detect file overlap between phases, semantic API/data-flow dependencies, and suggest `Depends on` entries to prevent merge conflicts during parallel execution by `/gsd:manager`. +Analyze ROADMAP.md phases for dependency relationships before execution. Detect file overlap between phases, semantic API/data-flow dependencies, and suggest `Depends on` entries to prevent merge conflicts during parallel execution by `/gsd-manager`. ## 1. Load ROADMAP.md -Read `.planning/ROADMAP.md`. If it does not exist, error: "No ROADMAP.md found — run `/gsd:new-project` first." +Read `.planning/ROADMAP.md`. If it does not exist, error: "No ROADMAP.md found — run `/gsd-new-project` first." Extract all phases. For each phase capture: - Phase number and name @@ -91,6 +91,6 @@ When writing to ROADMAP.md: - Preserve all other phase content unchanged - Do not reorder phases -After applying: "ROADMAP.md updated. Run `/gsd:manager` to execute phases in the correct order." +After applying: "ROADMAP.md updated. Run `/gsd-manager` to execute phases in the correct order." diff --git a/get-shit-done/workflows/audit-milestone.md b/get-shit-done/workflows/audit-milestone.md index 32af8666..3dfc8f13 100644 --- a/get-shit-done/workflows/audit-milestone.md +++ b/get-shit-done/workflows/audit-milestone.md @@ -158,7 +158,7 @@ Classify per phase: Add to audit YAML: `nyquist: { compliant_phases, partial_phases, missing_phases, overall }` -Discovery only — never auto-calls `/gsd:validate-phase`. +Discovery only — never auto-calls `/gsd-validate-phase`. ## 6. Aggregate into v{version}-MILESTONE-AUDIT.md @@ -231,7 +231,7 @@ All requirements covered. Cross-phase integration verified. E2E flows complete. /clear then: -/gsd:complete-milestone {version} +/gsd-complete-milestone {version} ─────────────────────────────────────────────────────────────── @@ -264,9 +264,9 @@ All requirements covered. Cross-phase integration verified. E2E flows complete. | Phase | VALIDATION.md | Compliant | Action | |-------|---------------|-----------|--------| -| {phase} | exists/missing | true/false/partial | `/gsd:validate-phase {N}` | +| {phase} | exists/missing | true/false/partial | `/gsd-validate-phase {N}` | -Phases needing validation: run `/gsd:validate-phase {N}` for each flagged phase. +Phases needing validation: run `/gsd-validate-phase {N}` for each flagged phase. ─────────────────────────────────────────────────────────────── @@ -276,13 +276,13 @@ Phases needing validation: run `/gsd:validate-phase {N}` for each flagged phase. /clear then: -/gsd:plan-milestone-gaps +/gsd-plan-milestone-gaps ─────────────────────────────────────────────────────────────── **Also available:** - cat .planning/v{version}-MILESTONE-AUDIT.md — see full report -- /gsd:complete-milestone {version} — proceed anyway (accept tech debt) +- /gsd-complete-milestone {version} — proceed anyway (accept tech debt) ─────────────────────────────────────────────────────────────── @@ -312,13 +312,13 @@ All requirements met. No critical blockers. Accumulated tech debt needs review. **A. Complete milestone** — accept debt, track in backlog -/gsd:complete-milestone {version} +/gsd-complete-milestone {version} **B. Plan cleanup phase** — address debt before completing /clear then: -/gsd:plan-milestone-gaps +/gsd-plan-milestone-gaps ─────────────────────────────────────────────────────────────── diff --git a/get-shit-done/workflows/audit-uat.md b/get-shit-done/workflows/audit-uat.md index 83650d62..29afc946 100644 --- a/get-shit-done/workflows/audit-uat.md +++ b/get-shit-done/workflows/audit-uat.md @@ -76,9 +76,9 @@ Present the audit report: ## Recommended Actions -1. **Close stale items:** `/gsd:verify-work {phase}` — mark stale tests as resolved +1. **Close stale items:** `/gsd-verify-work {phase}` — mark stale tests as resolved 2. **Run active tests:** Human UAT test plan below -3. **When prerequisites met:** Retest blocked items with `/gsd:verify-work {phase}` +3. **When prerequisites met:** Retest blocked items with `/gsd-verify-work {phase}` ``` diff --git a/get-shit-done/workflows/autonomous.md b/get-shit-done/workflows/autonomous.md index dc1f0f34..49fdf430 100644 --- a/get-shit-done/workflows/autonomous.md +++ b/get-shit-done/workflows/autonomous.md @@ -54,8 +54,8 @@ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi Parse JSON for: `milestone_version`, `milestone_name`, `phase_count`, `completed_phases`, `roadmap_exists`, `state_exists`, `commit_docs`. -**If `roadmap_exists` is false:** Error — "No ROADMAP.md found. Run `/gsd:new-milestone` first." -**If `state_exists` is false:** Error — "No STATE.md found. Run `/gsd:new-milestone` first." +**If `roadmap_exists` is false:** Error — "No ROADMAP.md found. Run `/gsd-new-milestone` first." +**If `state_exists` is false:** Error — "No STATE.md found. Run `/gsd-new-milestone` first." Display startup banner: @@ -537,7 +537,7 @@ Read and execute: `$HOME/.claude/get-shit-done/references/autonomous-smart-discu Completed through phase ${TO_PHASE} as requested. Remaining phases were not executed. - Resume with: /gsd:autonomous --from ${next_incomplete_phase} + Resume with: /gsd-autonomous --from ${next_incomplete_phase} ``` Proceed directly to lifecycle step (which handles partial completion — skips audit/complete/cleanup since not all phases are done). Exit cleanly. @@ -589,7 +589,7 @@ If all phases complete, proceed to lifecycle step. Phase ${ONLY_PHASE}: ${PHASE_NAME} — Done Mode: Single phase (--only) - Lifecycle skipped — run /gsd:autonomous without --only + Lifecycle skipped — run /gsd-autonomous without --only after all phases complete to trigger audit/complete/cleanup. ``` @@ -647,7 +647,7 @@ Ask user via AskUserQuestion: On **"Continue anyway"**: Display `Audit ⏭ Gaps accepted — proceeding to complete milestone` and proceed to 5b. -On **"Stop"**: Go to handle_blocker with "User stopped — audit gaps remain. Run /gsd:audit-milestone to review, then /gsd:complete-milestone when ready." +On **"Stop"**: Go to handle_blocker with "User stopped — audit gaps remain. Run /gsd-audit-milestone to review, then /gsd-complete-milestone when ready." **If `tech_debt`:** @@ -662,7 +662,7 @@ Show the summary, then ask user via AskUserQuestion: On **"Continue with tech debt"**: Display `Audit ⏭ Tech debt acknowledged — proceeding to complete milestone` and proceed to 5b. -On **"Stop"**: Go to handle_blocker with "User stopped — tech debt to address. Run /gsd:audit-milestone to review details." +On **"Stop"**: Go to handle_blocker with "User stopped — tech debt to address. Run /gsd-audit-milestone to review details." **5b. Complete Milestone** @@ -732,7 +732,7 @@ When any phase operation fails or a blocker is detected, present 3 options via A Skipped: {list of skipped phases} Remaining: {list of remaining phases} - Resume with: /gsd:autonomous ${ONLY_PHASE ? "--only " + ONLY_PHASE : "--from " + next_phase}${TO_PHASE ? " --to " + TO_PHASE : ""} + Resume with: /gsd-autonomous ${ONLY_PHASE ? "--only " + ONLY_PHASE : "--from " + next_phase}${TO_PHASE ? " --to " + TO_PHASE : ""} ``` diff --git a/get-shit-done/workflows/check-todos.md b/get-shit-done/workflows/check-todos.md index 57857268..0180c404 100644 --- a/get-shit-done/workflows/check-todos.md +++ b/get-shit-done/workflows/check-todos.md @@ -22,14 +22,14 @@ If `todo_count` is 0: ``` No pending todos. -Todos are captured during work sessions with /gsd:add-todo. +Todos are captured during work sessions with /gsd-add-todo. --- Would you like to: -1. Continue with current phase (/gsd:progress) -2. Add a todo now (/gsd:add-todo) +1. Continue with current phase (/gsd-progress) +2. Add a todo now (/gsd-add-todo) ``` Exit. @@ -37,8 +37,8 @@ Exit. Check for area filter in arguments: -- `/gsd:check-todos` → show all -- `/gsd:check-todos api` → filter to area:api only +- `/gsd-check-todos` → show all +- `/gsd-check-todos api` → filter to area:api only @@ -56,7 +56,7 @@ Pending Todos: --- Reply with a number to view details, or: -- `/gsd:check-todos [area]` to filter by area +- `/gsd-check-todos [area]` to filter by area - `q` to exit ``` @@ -120,7 +120,7 @@ Use AskUserQuestion: - question: "What would you like to do with this todo?" - options: - "Work on it now" — move to done, start working - - "Create a phase" — /gsd:add-phase with this scope + - "Create a phase" — /gsd-add-phase with this scope - "Brainstorm approach" — think through before deciding - "Put it back" — return to list @@ -136,7 +136,7 @@ Update STATE.md todo count. Present problem/solution context. Begin work or ask Note todo reference in phase planning notes. Keep in pending. Return to list or exit. **Create a phase:** -Display: `/gsd:add-phase [description from todo]` +Display: `/gsd-add-phase [description from todo]` Keep in pending. User runs command in fresh context. **Brainstorm approach:** diff --git a/get-shit-done/workflows/code-review-fix.md b/get-shit-done/workflows/code-review-fix.md index 1d5e86ca..ed3e2c48 100644 --- a/get-shit-done/workflows/code-review-fix.md +++ b/get-shit-done/workflows/code-review-fix.md @@ -93,7 +93,7 @@ Verify that REVIEW.md exists: ```bash if [ ! -f "${REVIEW_PATH}" ]; then - echo "Error: No REVIEW.md found for Phase ${PHASE_ARG}. Run /gsd:code-review ${PHASE_ARG} first." + echo "Error: No REVIEW.md found for Phase ${PHASE_ARG}. Run /gsd-code-review ${PHASE_ARG} first." exit 1 fi ``` @@ -221,7 +221,7 @@ Check if FIX_REPORT_PATH exists: Either way: ``` Some fix commits may already exist in git history — check git log for fix(${PADDED_PHASE}) commits. -You can retry with /gsd:code-review-fix ${PHASE_ARG}. +You can retry with /gsd-code-review-fix ${PHASE_ARG}. ``` Exit workflow (skip auto loop). @@ -394,7 +394,7 @@ if [ ! -f "${FIX_REPORT_PATH}" ]; then echo "The fixer agent may have failed before completing." echo "Check git log for any fix(${PADDED_PHASE}) commits." echo "" - echo "Retry: /gsd:code-review-fix ${PHASE_ARG}" + echo "Retry: /gsd-code-review-fix ${PHASE_ARG}" echo "" echo "═══════════════════════════════════════════════════════════════" exit 1 @@ -451,7 +451,7 @@ if [ "$FIX_STATUS" = "all_fixed" ]; then echo "Full report: ${FIX_REPORT_PATH}" echo "" echo "Next step:" - echo " /gsd:verify-work — Verify phase completion" + echo " /gsd-verify-work — Verify phase completion" echo "" fi ``` @@ -465,8 +465,8 @@ if [ "$FIX_STATUS" = "partial" ] || [ "$FIX_STATUS" = "none_fixed" ]; then echo "" echo "Next steps:" echo " cat ${FIX_REPORT_PATH} — View fix report" - echo " /gsd:code-review ${PHASE_NUMBER} — Re-review code" - echo " /gsd:verify-work — Verify phase completion" + echo " /gsd-code-review ${PHASE_NUMBER} — Re-review code" + echo " /gsd-verify-work — Verify phase completion" echo "" fi ``` diff --git a/get-shit-done/workflows/code-review.md b/get-shit-done/workflows/code-review.md index dde4f14e..5c5b0ea5 100644 --- a/get-shit-done/workflows/code-review.md +++ b/get-shit-done/workflows/code-review.md @@ -227,7 +227,7 @@ if [ ${#REVIEW_FILES[@]} -eq 0 ]; then else # Fail closed — no reliable diff base found. Do not use arbitrary HEAD~N. echo "Warning: No phase commits found for '${PADDED_PHASE}'. Cannot determine reliable diff scope." - echo "Use --files flag to specify files explicitly: /gsd:code-review ${PHASE_ARG} --files=file1,file2,..." + echo "Use --files flag to specify files explicitly: /gsd-code-review ${PHASE_ARG} --files=file1,file2,..." fi fi ``` @@ -372,7 +372,7 @@ If the Task() call fails (agent error, timeout, or exception): ``` Error: Code review agent failed: ${error_message} -No REVIEW.md created. You can retry with /gsd:code-review ${PHASE_ARG} or check agent logs. +No REVIEW.md created. You can retry with /gsd-code-review ${PHASE_ARG} or check agent logs. ``` Do NOT proceed to commit_review step. Do NOT create a partial or empty REVIEW.md. Exit workflow. @@ -405,7 +405,7 @@ if [ -f "${REVIEW_PATH}" ]; then fi else echo "Warning: Agent completed but REVIEW.md not found at ${REVIEW_PATH}. This may indicate an agent issue." - echo "No REVIEW.md to commit. Please retry with /gsd:code-review ${PHASE_ARG}" + echo "No REVIEW.md to commit. Please retry with /gsd-code-review ${PHASE_ARG}" fi ``` @@ -469,7 +469,7 @@ If total findings > 0: Full report: ${REVIEW_PATH} Next steps: - /gsd:code-review-fix ${PHASE_NUMBER} — Auto-fix issues + /gsd-code-review-fix ${PHASE_NUMBER} — Auto-fix issues cat ${REVIEW_PATH} — View full report ``` diff --git a/get-shit-done/workflows/complete-milestone.md b/get-shit-done/workflows/complete-milestone.md index 5ddca9f4..a73b3056 100644 --- a/get-shit-done/workflows/complete-milestone.md +++ b/get-shit-done/workflows/complete-milestone.md @@ -51,7 +51,7 @@ Display the full audit report to the user. Then ask: ``` These items are open. Choose an action: -[R] Resolve — stop and fix items, then re-run /gsd:complete-milestone +[R] Resolve — stop and fix items, then re-run /gsd-complete-milestone [A] Acknowledge all — document as deferred and proceed with close [C] Cancel — exit without closing ``` @@ -124,7 +124,7 @@ Requirements: {N}/{M} v1 requirements checked off MUST present 3 options: 1. **Proceed anyway** — mark milestone complete with known gaps -2. **Run audit first** — `/gsd:audit-milestone` to assess gap severity +2. **Run audit first** — `/gsd-audit-milestone` to assess gap severity 3. **Abort** — return to development If user selects "Proceed anyway": note incomplete requirements in MILESTONES.md under `### Known Gaps` with REQ-IDs and descriptions. @@ -441,7 +441,7 @@ mv .planning/phases/{phase-dir} .planning/milestones/v[X.Y]-phases/ ``` Verify: `✅ Phase directories archived to .planning/milestones/v[X.Y]-phases/` -If "Skip": Phase directories remain in `.planning/phases/` as raw execution history. Use `/gsd:cleanup` later to archive retroactively. +If "Skip": Phase directories remain in `.planning/phases/` as raw execution history. Use `/gsd-cleanup` later to archive retroactively. After archival, the AI still handles: - Reorganizing ROADMAP.md with milestone grouping (requires judgment) — overwrite in place after extracting Backlog section @@ -786,7 +786,7 @@ Tag: v[X.Y] `/clear` then: -`/gsd:new-milestone` +`/gsd-new-milestone` --- ``` @@ -842,6 +842,6 @@ Milestone completion is successful when: - [ ] Known gaps recorded in MILESTONES.md if user proceeded with incomplete requirements - [ ] RETROSPECTIVE.md updated with milestone section - [ ] Cross-milestone trends updated -- [ ] User knows next step (/gsd:new-milestone) +- [ ] User knows next step (/gsd-new-milestone) diff --git a/get-shit-done/workflows/diagnose-issues.md b/get-shit-done/workflows/diagnose-issues.md index 0027d865..b5017ff0 100644 --- a/get-shit-done/workflows/diagnose-issues.md +++ b/get-shit-done/workflows/diagnose-issues.md @@ -220,7 +220,7 @@ Agents only diagnose—plan-phase --gaps handles fixes (no fix application). **Agent times out:** - Check DEBUG-{slug}.md for partial progress -- Can resume with /gsd:debug +- Can resume with /gsd-debug **All agents fail:** - Something systemic (permissions, git, etc.) diff --git a/get-shit-done/workflows/discovery-phase.md b/get-shit-done/workflows/discovery-phase.md index 853095cc..a45d56e8 100644 --- a/get-shit-done/workflows/discovery-phase.md +++ b/get-shit-done/workflows/discovery-phase.md @@ -4,7 +4,7 @@ Produces DISCOVERY.md (for Level 2-3) that informs PLAN.md creation. Called from plan-phase.md's mandatory_discovery step with a depth parameter. -NOTE: For comprehensive ecosystem research ("how do experts build this"), use /gsd:research-phase instead, which produces RESEARCH.md. +NOTE: For comprehensive ecosystem research ("how do experts build this"), use /gsd-research-phase instead, which produces RESEARCH.md. @@ -254,8 +254,8 @@ Confidence: [level] What's next? -1. Discuss phase context (/gsd:discuss-phase [current-phase]) -2. Create phase plan (/gsd:plan-phase [current-phase]) +1. Discuss phase context (/gsd-discuss-phase [current-phase]) +2. Create phase plan (/gsd-plan-phase [current-phase]) 3. Refine discovery (dig deeper) 4. Review discovery diff --git a/get-shit-done/workflows/discuss-phase-assumptions.md b/get-shit-done/workflows/discuss-phase-assumptions.md index 20505b4c..4b77924f 100644 --- a/get-shit-done/workflows/discuss-phase-assumptions.md +++ b/get-shit-done/workflows/discuss-phase-assumptions.md @@ -77,7 +77,7 @@ Parse JSON for: `commit_docs`, `phase_found`, `phase_dir`, `phase_number`, `phas ``` Phase [X] not found in roadmap. -Use /gsd:progress to see available phases. +Use /gsd-progress to see available phases. ``` Exit workflow. @@ -599,13 +599,13 @@ Created: .planning/phases/${PADDED_PHASE}-${SLUG}/${PADDED_PHASE}-CONTEXT.md `/clear` then: -`/gsd:plan-phase ${PHASE}` +`/gsd-plan-phase ${PHASE}` --- **Also available:** -- `/gsd:plan-phase ${PHASE} --skip-research` — plan without research -- `/gsd:ui-phase ${PHASE}` — generate UI design contract (if frontend work) +- `/gsd-plan-phase ${PHASE} --skip-research` — plan without research +- `/gsd-ui-phase ${PHASE}` — generate UI design contract (if frontend work) - Review/edit CONTEXT.md before continuing --- diff --git a/get-shit-done/workflows/discuss-phase-power.md b/get-shit-done/workflows/discuss-phase-power.md index 0877ee6e..57e7671a 100644 --- a/get-shit-done/workflows/discuss-phase-power.md +++ b/get-shit-done/workflows/discuss-phase-power.md @@ -5,7 +5,7 @@ Power user mode for discuss-phase. Generates ALL questions upfront into a JSON s -This workflow executes when `--power` flag is present in ARGUMENTS to `/gsd:discuss-phase`. +This workflow executes when `--power` flag is present in ARGUMENTS to `/gsd-discuss-phase`. The caller (discuss-phase.md) has already: - Validated the phase exists @@ -265,7 +265,7 @@ Process all answered questions from the JSON file and generate CONTEXT.md. ``` Warning: Only {answered}/{total} questions answered ({pct}%). CONTEXT.md generated with available decisions. Unanswered questions listed as deferred. -Consider running /gsd:discuss-phase {N} again to refine before planning. +Consider running /gsd-discuss-phase {N} again to refine before planning. ``` 7. Print completion message: @@ -275,7 +275,7 @@ CONTEXT.md written: {phase_dir}/{padded_phase}-CONTEXT.md Decisions captured: {answered} Deferred: {remaining} -Next step: /gsd:plan-phase {N} +Next step: /gsd-plan-phase {N} ``` diff --git a/get-shit-done/workflows/discuss-phase.md b/get-shit-done/workflows/discuss-phase.md index b74b38f5..ac22e629 100644 --- a/get-shit-done/workflows/discuss-phase.md +++ b/get-shit-done/workflows/discuss-phase.md @@ -103,7 +103,7 @@ Phase: "API documentation" → Structure/navigation, Code examples depth, -**Express path available:** If you already have a PRD or acceptance criteria document, use `/gsd:plan-phase {phase} --prd path/to/prd.md` to skip this discussion and go straight to planning. +**Express path available:** If you already have a PRD or acceptance criteria document, use `/gsd-plan-phase {phase} --prd path/to/prd.md` to skip this discussion and go straight to planning. Phase number from argument (required). @@ -121,7 +121,7 @@ Parse JSON for: `commit_docs`, `phase_found`, `phase_dir`, `phase_number`, `phas **If `phase_found` is false:** ``` Phase [X] not found in roadmap. -Use /gsd:progress ${GSD_WS} to see available phases. +Use /gsd-progress ${GSD_WS} to see available phases. ``` Exit workflow. @@ -172,7 +172,7 @@ Write these answers inline before continuing. If a blocking anti-pattern cannot -Check if a SPEC.md (from `/gsd:spec-phase`) exists for this phase. SPEC.md locks requirements before implementation decisions. +Check if a SPEC.md (from `/gsd-spec-phase`) exists for this phase. SPEC.md locks requirements before implementation decisions. ```bash ls ${phase_dir}/*-SPEC.md 2>/dev/null | grep -v AI-SPEC | head -1 || true @@ -187,7 +187,7 @@ ls ${phase_dir}/*-SPEC.md 2>/dev/null | grep -v AI-SPEC | head -1 || true **If no SPEC.md is found:** Continue with `spec_loaded = false`. -**Note:** SPEC.md files named `AI-SPEC.md` (from `/gsd:ai-integration-phase`) are excluded — different purpose. +**Note:** SPEC.md files named `AI-SPEC.md` (from `/gsd-ai-integration-phase`) are excluded — different purpose. @@ -252,7 +252,7 @@ RAW_SKETCHES=$(ls .planning/sketches/MANIFEST.md 2>/dev/null) If findings skills exist, read SKILL.md and reference files; extract validated patterns, landmines, constraints, design decisions. Add them to ``. -If raw spikes/sketches exist but no findings skill, note: `⚠ Unpackaged spikes/sketches detected — run /gsd:spike-wrap-up or /gsd:sketch-wrap-up to make findings available.` +If raw spikes/sketches exist but no findings skill, note: `⚠ Unpackaged spikes/sketches detected — run /gsd-spike-wrap-up or /gsd-sketch-wrap-up to make findings available.` Build internal `` with sections for Project-Level (from PROJECT.md / REQUIREMENTS.md), From Prior Phases (per-phase decisions), and From Spike/Sketch Findings (validated patterns, landmines, design decisions). @@ -418,11 +418,11 @@ Created: .planning/phases/${PADDED_PHASE}-${SLUG}/${PADDED_PHASE}-CONTEXT.md `/clear` then: -`/gsd:plan-phase ${PHASE} ${GSD_WS}` +`/gsd-plan-phase ${PHASE} ${GSD_WS}` --- -**Also available:** `--chain` for auto plan+execute after; `/gsd:plan-phase ${PHASE} --skip-research ${GSD_WS}` to plan without research; `/gsd:ui-phase ${PHASE} ${GSD_WS}` for UI design contracts; review/edit CONTEXT.md before continuing. +**Also available:** `--chain` for auto plan+execute after; `/gsd-plan-phase ${PHASE} --skip-research ${GSD_WS}` to plan without research; `/gsd-ui-phase ${PHASE} ${GSD_WS}` for UI design contracts; review/edit CONTEXT.md before continuing. ``` diff --git a/get-shit-done/workflows/discuss-phase/modes/chain.md b/get-shit-done/workflows/discuss-phase/modes/chain.md index c30c06be..51789500 100644 --- a/get-shit-done/workflows/discuss-phase/modes/chain.md +++ b/get-shit-done/workflows/discuss-phase/modes/chain.md @@ -75,22 +75,22 @@ /clear then: - Next: /gsd:discuss-phase ${NEXT_PHASE} ${WAS_CHAIN ? "--chain" : "--auto"} ${GSD_WS} + Next: /gsd-discuss-phase ${NEXT_PHASE} ${WAS_CHAIN ? "--chain" : "--auto"} ${GSD_WS} ``` - **PLANNING COMPLETE** → Planning done, execution didn't complete: ``` Auto-advance partial: Planning complete, execution did not finish. - Continue: /gsd:execute-phase ${PHASE} ${GSD_WS} + Continue: /gsd-execute-phase ${PHASE} ${GSD_WS} ``` - **PLANNING INCONCLUSIVE / CHECKPOINT** → Stop chain: ``` Auto-advance stopped: Planning needs input. - Continue: /gsd:plan-phase ${PHASE} ${GSD_WS} + Continue: /gsd-plan-phase ${PHASE} ${GSD_WS} ``` - **GAPS FOUND** → Stop chain: ``` Auto-advance stopped: Gaps found during execution. - Continue: /gsd:plan-phase ${PHASE} --gaps ${GSD_WS} + Continue: /gsd-plan-phase ${PHASE} --gaps ${GSD_WS} ``` 7. **If none of `--auto`, `--chain`, nor config enabled:** route to diff --git a/get-shit-done/workflows/discuss-phase/modes/text.md b/get-shit-done/workflows/discuss-phase/modes/text.md index cfc7ea19..a0821727 100644 --- a/get-shit-done/workflows/discuss-phase/modes/text.md +++ b/get-shit-done/workflows/discuss-phase/modes/text.md @@ -17,7 +17,7 @@ Claude App cannot forward TUI menu selections back to the host. ## Activation - Per-session: pass `--text` flag to any command (e.g., - `/gsd:discuss-phase --text`) + `/gsd-discuss-phase --text`) - Per-project: `gsd-sdk query config-set workflow.text_mode true` Text mode applies to ALL workflows in the session, not just discuss-phase. diff --git a/get-shit-done/workflows/do.md b/get-shit-done/workflows/do.md index afa1cfaf..4eca2a47 100644 --- a/get-shit-done/workflows/do.md +++ b/get-shit-done/workflows/do.md @@ -39,35 +39,35 @@ Evaluate `$ARGUMENTS` against these routing rules. Apply the **first matching** | If the text describes... | Route to | Why | |--------------------------|----------|-----| -| Starting a new project, "set up", "initialize" | `/gsd:new-project` | Needs full project initialization | -| Mapping or analyzing an existing codebase | `/gsd:map-codebase` | Codebase discovery | -| A bug, error, crash, failure, or something broken | `/gsd:debug` | Needs systematic investigation | -| Spiking, "test if", "will this work", "experiment", "prove this out", validate feasibility | `/gsd:spike` | Throwaway experiment to validate feasibility | -| Sketching, "mockup", "what would this look like", "prototype the UI", "design this", explore visual direction | `/gsd:sketch` | Throwaway HTML mockups to explore design | -| Wrapping up spikes, "package the spikes", "consolidate spike findings" | `/gsd:spike-wrap-up` | Package spike findings into reusable skill | -| Wrapping up sketches, "package the designs", "consolidate sketch findings" | `/gsd:sketch-wrap-up` | Package sketch findings into reusable skill | -| Exploring, researching, comparing, or "how does X work" | `/gsd:research-phase` | Domain research before planning | -| Discussing vision, "how should X look", brainstorming | `/gsd:discuss-phase` | Needs context gathering | -| A complex task: refactoring, migration, multi-file architecture, system redesign | `/gsd:add-phase` | Needs a full phase with plan/build cycle | -| Planning a specific phase or "plan phase N" | `/gsd:plan-phase` | Direct planning request | -| Executing a phase or "build phase N", "run phase N" | `/gsd:execute-phase` | Direct execution request | -| Running all remaining phases automatically | `/gsd:autonomous` | Full autonomous execution | -| A review or quality concern about existing work | `/gsd:verify-work` | Needs verification | -| Checking progress, status, "where am I" | `/gsd:progress` | Status check | -| Resuming work, "pick up where I left off" | `/gsd:resume-work` | Session restoration | -| A note, idea, or "remember to..." | `/gsd:add-todo` | Capture for later | -| Adding tests, "write tests", "test coverage" | `/gsd:add-tests` | Test generation | -| Completing a milestone, shipping, releasing | `/gsd:complete-milestone` | Milestone lifecycle | -| A specific, actionable, small task (add feature, fix typo, update config) | `/gsd:quick` | Self-contained, single executor | +| Starting a new project, "set up", "initialize" | `/gsd-new-project` | Needs full project initialization | +| Mapping or analyzing an existing codebase | `/gsd-map-codebase` | Codebase discovery | +| A bug, error, crash, failure, or something broken | `/gsd-debug` | Needs systematic investigation | +| Spiking, "test if", "will this work", "experiment", "prove this out", validate feasibility | `/gsd-spike` | Throwaway experiment to validate feasibility | +| Sketching, "mockup", "what would this look like", "prototype the UI", "design this", explore visual direction | `/gsd-sketch` | Throwaway HTML mockups to explore design | +| Wrapping up spikes, "package the spikes", "consolidate spike findings" | `/gsd-spike-wrap-up` | Package spike findings into reusable skill | +| Wrapping up sketches, "package the designs", "consolidate sketch findings" | `/gsd-sketch-wrap-up` | Package sketch findings into reusable skill | +| Exploring, researching, comparing, or "how does X work" | `/gsd-research-phase` | Domain research before planning | +| Discussing vision, "how should X look", brainstorming | `/gsd-discuss-phase` | Needs context gathering | +| A complex task: refactoring, migration, multi-file architecture, system redesign | `/gsd-add-phase` | Needs a full phase with plan/build cycle | +| Planning a specific phase or "plan phase N" | `/gsd-plan-phase` | Direct planning request | +| Executing a phase or "build phase N", "run phase N" | `/gsd-execute-phase` | Direct execution request | +| Running all remaining phases automatically | `/gsd-autonomous` | Full autonomous execution | +| A review or quality concern about existing work | `/gsd-verify-work` | Needs verification | +| Checking progress, status, "where am I" | `/gsd-progress` | Status check | +| Resuming work, "pick up where I left off" | `/gsd-resume-work` | Session restoration | +| A note, idea, or "remember to..." | `/gsd-add-todo` | Capture for later | +| Adding tests, "write tests", "test coverage" | `/gsd-add-tests` | Test generation | +| Completing a milestone, shipping, releasing | `/gsd-complete-milestone` | Milestone lifecycle | +| A specific, actionable, small task (add feature, fix typo, update config) | `/gsd-quick` | Self-contained, single executor | -**Requires `.planning/` directory:** All routes except `/gsd:new-project`, `/gsd:map-codebase`, `/gsd:spike`, `/gsd:sketch`, `/gsd:help`, and `/gsd:join-discord`. If the project doesn't exist and the route requires it, suggest `/gsd:new-project` first. +**Requires `.planning/` directory:** All routes except `/gsd-new-project`, `/gsd-map-codebase`, `/gsd-spike`, `/gsd-sketch`, `/gsd-help`, and `/gsd-join-discord`. If the project doesn't exist and the route requires it, suggest `/gsd-new-project` first. **Ambiguity handling:** If the text could reasonably match multiple routes, ask the user via AskUserQuestion with the top 2-3 options. For example: ``` "Refactor the authentication system" could be: -1. /gsd:add-phase — Full planning cycle (recommended for multi-file refactors) -2. /gsd:quick — Quick execution (if scope is small and clear) +1. /gsd-add-phase — Full planning cycle (recommended for multi-file refactors) +2. /gsd-quick — Quick execution (if scope is small and clear) Which approach fits better? ``` diff --git a/get-shit-done/workflows/docs-update.md b/get-shit-done/workflows/docs-update.md index 8690dbf1..8dbb9051 100644 --- a/get-shit-done/workflows/docs-update.md +++ b/get-shit-done/workflows/docs-update.md @@ -988,8 +988,8 @@ Failed claims: Display note: ``` -To fix failures automatically: /gsd:docs-update (runs generation + fix loop) -To regenerate all docs from scratch: /gsd:docs-update --force +To fix failures automatically: /gsd-docs-update (runs generation + fix loop) +To regenerate all docs from scratch: /gsd-docs-update --force ``` Clean up temp files: remove `.planning/tmp/verify-*.json` files. @@ -1024,7 +1024,7 @@ This would expose credentials if committed. Action required: 1. Review the flagged lines above 2. Remove any real secrets from the doc files -3. Re-run /gsd:docs-update to regenerate clean docs +3. Re-run /gsd-docs-update to regenerate clean docs ``` Then confirm with AskUserQuestion: @@ -1126,7 +1126,7 @@ All generated files committed. Remind the user they can fact-check generated docs: ``` -Run `/gsd:docs-update --verify-only` to fact-check generated docs against the codebase. +Run `/gsd-docs-update --verify-only` to fact-check generated docs against the codebase. ``` End workflow. diff --git a/get-shit-done/workflows/eval-review.md b/get-shit-done/workflows/eval-review.md index f80bdc1c..90b67901 100644 --- a/get-shit-done/workflows/eval-review.md +++ b/get-shit-done/workflows/eval-review.md @@ -1,7 +1,7 @@ Retroactive audit of an implemented AI phase's evaluation coverage. Standalone command that works on any GSD-managed AI phase. Produces a scored EVAL-REVIEW.md with gap analysis and remediation plan. -Use after /gsd:execute-phase to verify that the evaluation strategy from AI-SPEC.md was actually implemented. Mirrors the pattern of /gsd:ui-review and /gsd:validate-phase. +Use after /gsd-execute-phase to verify that the evaluation strategy from AI-SPEC.md was actually implemented. Mirrors the pattern of /gsd-ui-review and /gsd-validate-phase. @@ -40,7 +40,7 @@ EVAL_REVIEW_FILE=$(ls "${PHASE_DIR}"/*-EVAL-REVIEW.md 2>/dev/null | head -1) **State A** — AI-SPEC.md + SUMMARY.md exist: Full audit against spec **State B** — SUMMARY.md exists, no AI-SPEC.md: Audit against general best practices -**State C** — No SUMMARY.md: Exit — "Phase {N} not executed. Run /gsd:execute-phase {N} first." +**State C** — No SUMMARY.md: Exit — "Phase {N} not executed. Run /gsd-execute-phase {N} first." **Text mode (`workflow.text_mode: true` in config or `--text` flag):** Set `TEXT_MODE=true` if `--text` is present in `$ARGUMENTS` OR `text_mode` from init JSON is `true`. When TEXT_MODE is active, replace every `AskUserQuestion` call with a plain-text numbered list and ask the user to type their choice number. This is required for non-Claude runtimes (OpenAI Codex, Gemini CLI, etc.) where `AskUserQuestion` is not available. @@ -58,7 +58,7 @@ If "Re-audit": continue. ``` No AI-SPEC.md found for Phase {N}. Audit will evaluate against general AI eval best practices rather than a phase-specific plan. -Consider running /gsd:ai-integration-phase {N} before implementation next time. +Consider running /gsd-ai-integration-phase {N} before implementation next time. ``` Continue (non-blocking). @@ -124,10 +124,10 @@ Read the written EVAL-REVIEW.md. Extract: ◆ Output: {eval_review_path} {If PRODUCTION READY:} - Next step: /gsd:plan-phase (next phase) or deploy + Next step: /gsd-plan-phase (next phase) or deploy {If NEEDS WORK:} - Address critical gaps in EVAL-REVIEW.md, then re-run /gsd:eval-review {N} + Address critical gaps in EVAL-REVIEW.md, then re-run /gsd-eval-review {N} {If SIGNIFICANT GAPS or NOT IMPLEMENTED:} Review AI-SPEC.md evaluation plan. Critical eval dimensions are not implemented. diff --git a/get-shit-done/workflows/execute-phase.md b/get-shit-done/workflows/execute-phase.md index c54de394..4575d2f1 100644 --- a/get-shit-done/workflows/execute-phase.md +++ b/get-shit-done/workflows/execute-phase.md @@ -344,7 +344,7 @@ between a large tool_result and the next assistant turn (seen on Claude Code + Opus 4.7 at ~200K+ cache_read). To keep the stream warm, emit short assistant-text heartbeats — **no tool call, just a literal line** — at every wave and plan boundary. Each heartbeat MUST start with `[checkpoint]` so -tooling and `/gsd:manager`'s background-completion handler can grep partial +tooling and `/gsd-manager`'s background-completion handler can grep partial transcripts. `{P}/{Q}` is the phase-wide completed/total plans counter and increases monotonically across waves. `{status}` is `complete` (success), `failed` (executor error), or `checkpoint` (human-gate returned). @@ -1017,13 +1017,13 @@ If `SECURITY_CFG` is `true` AND `SECURITY_FILE` is empty (no SECURITY.md yet): Include in the next-steps routing output: ``` ⚠ Security enforcement enabled — run before advancing: - /gsd:secure-phase {PHASE} ${GSD_WS} + /gsd-secure-phase {PHASE} ${GSD_WS} ``` If `SECURITY_CFG` is `true` AND SECURITY.md exists: check frontmatter `threats_open`. If > 0: ``` ⚠ Security gate: {threats_open} threats open - /gsd:secure-phase {PHASE} — resolve before advancing + /gsd-secure-phase {PHASE} — resolve before advancing ``` @@ -1093,8 +1093,8 @@ Apply the same "incomplete" filtering rules as earlier: Selected wave finished successfully. This phase still has incomplete plans, so phase-level verification and completion were intentionally skipped. -/gsd:execute-phase {phase} ${GSD_WS} # Continue remaining waves -/gsd:execute-phase {phase} --wave {next} ${GSD_WS} # Run the next wave explicitly +/gsd-execute-phase {phase} ${GSD_WS} # Continue remaining waves +/gsd-execute-phase {phase} --wave {next} ${GSD_WS} # Run the next wave explicitly ``` **If no incomplete plans remain after the selected wave finishes:** @@ -1127,7 +1127,7 @@ REVIEW_STATUS=$(sed -n '/^---$/,/^---$/p' "$REVIEW_FILE" | grep "^status:" | hea If REVIEW_STATUS is not "clean" and not "skipped" and not empty, display: ``` Code review found issues. Consider running: -/gsd:code-review-fix ${PHASE_NUMBER} +/gsd-code-review-fix ${PHASE_NUMBER} ``` **Error handling:** If the Skill invocation fails or throws, catch the error, display "Code review encountered an error (non-blocking): {error}" and proceed to next step. Review failures must never block execution. @@ -1379,7 +1379,7 @@ grep "^status:" "$PHASE_DIR"/*-VERIFICATION.md | cut -d: -f2 | tr -d ' ' |--------|--------| | `passed` | → update_roadmap | | `human_needed` | Present items for human testing, get approval or feedback | -| `gaps_found` | Present gap summary, offer `/gsd:plan-phase {phase} --gaps ${GSD_WS}` | +| `gaps_found` | Present gap summary, offer `/gsd-plan-phase {phase} --gaps ${GSD_WS}` | **If human_needed:** @@ -1434,12 +1434,12 @@ All automated checks passed. {N} items need human testing: {From VERIFICATION.md human_verification section} -Items saved to `{phase_num}-HUMAN-UAT.md` — they will appear in `/gsd:progress` and `/gsd:audit-uat`. +Items saved to `{phase_num}-HUMAN-UAT.md` — they will appear in `/gsd-progress` and `/gsd-audit-uat`. "approved" → continue | Report issues → gap closure ``` -**If user says "approved":** Proceed to `update_roadmap`. The HUMAN-UAT.md file persists with `status: partial` and will surface in future progress checks until the user runs `/gsd:verify-work` on it. +**If user says "approved":** Proceed to `update_roadmap`. The HUMAN-UAT.md file persists with `status: partial` and will surface in future progress checks until the user runs `/gsd-verify-work` on it. **If user reports issues:** Proceed to gap closure as currently implemented. @@ -1458,13 +1458,13 @@ Items saved to `{phase_num}-HUMAN-UAT.md` — they will appear in `/gsd:progress `/clear` then: -`/gsd:plan-phase {X} --gaps ${GSD_WS}` +`/gsd-plan-phase {X} --gaps ${GSD_WS}` Also: `cat {phase_dir}/{phase_num}-VERIFICATION.md` — full report -Also: `/gsd:verify-work {X} ${GSD_WS}` — manual testing first +Also: `/gsd-verify-work {X} ${GSD_WS}` — manual testing first ``` -Gap closure cycle: `/gsd:plan-phase {X} --gaps ${GSD_WS}` reads VERIFICATION.md → creates gap plans with `gap_closure: true` → user runs `/gsd:execute-phase {X} --gaps-only ${GSD_WS}` → verifier re-runs. +Gap closure cycle: `/gsd-plan-phase {X} --gaps ${GSD_WS}` reads VERIFICATION.md → creates gap plans with `gap_closure: true` → user runs `/gsd-execute-phase {X} --gaps-only ${GSD_WS}` → verifier re-runs. @@ -1490,7 +1490,7 @@ Extract from result: `next_phase`, `next_phase_name`, `is_last_phase`, `warnings {list each warning} -These items are tracked and will appear in `/gsd:progress` and `/gsd:audit-uat`. +These items are tracked and will appear in `/gsd-progress` and `/gsd-audit-uat`. ``` ```bash @@ -1577,7 +1577,7 @@ gsd-sdk query commit "docs(phase-{X}): evolve PROJECT.md after phase completion" -**Exception:** If `gaps_found`, the `verify_phase_goal` step already presents the gap-closure path (`/gsd:plan-phase {X} --gaps`). No additional routing needed — skip auto-advance. +**Exception:** If `gaps_found`, the `verify_phase_goal` step already presents the gap-closure path (`/gsd-plan-phase {X} --gaps`). No additional routing needed — skip auto-advance. **No-transition check (spawned by auto-advance chain):** @@ -1640,10 +1640,10 @@ If CONTEXT.md does **not** exist for the next phase, present: ``` ## ✓ Phase {X}: {Name} Complete -/gsd:progress ${GSD_WS} — see updated roadmap -/gsd:discuss-phase {next} ${GSD_WS} — start here: discuss next phase before planning ← recommended -/gsd:plan-phase {next} ${GSD_WS} — plan next phase (skip discuss) -/gsd:execute-phase {next} ${GSD_WS} — execute next phase (skip discuss and plan) +/gsd-progress ${GSD_WS} — see updated roadmap +/gsd-discuss-phase {next} ${GSD_WS} — start here: discuss next phase before planning ← recommended +/gsd-plan-phase {next} ${GSD_WS} — plan next phase (skip discuss) +/gsd-execute-phase {next} ${GSD_WS} — execute next phase (skip discuss and plan) ``` If CONTEXT.md **exists** for the next phase, present: @@ -1651,10 +1651,10 @@ If CONTEXT.md **exists** for the next phase, present: ``` ## ✓ Phase {X}: {Name} Complete -/gsd:progress ${GSD_WS} — see updated roadmap -/gsd:plan-phase {next} ${GSD_WS} — start here: plan next phase (CONTEXT.md already present) ← recommended -/gsd:discuss-phase {next} ${GSD_WS} — re-discuss next phase -/gsd:execute-phase {next} ${GSD_WS} — execute next phase (skip planning) +/gsd-progress ${GSD_WS} — see updated roadmap +/gsd-plan-phase {next} ${GSD_WS} — start here: plan next phase (CONTEXT.md already present) ← recommended +/gsd-discuss-phase {next} ${GSD_WS} — re-discuss next phase +/gsd-execute-phase {next} ${GSD_WS} — execute next phase (skip planning) ``` Only suggest the commands listed above. Do not invent or hallucinate command names. @@ -1681,7 +1681,7 @@ For 1M+ context models, consider: -Re-run `/gsd:execute-phase {phase}` → discover_plans finds completed SUMMARYs → skips them → resumes from first incomplete plan → continues wave execution. +Re-run `/gsd-execute-phase {phase}` → discover_plans finds completed SUMMARYs → skips them → resumes from first incomplete plan → continues wave execution. STATE.md tracks: last completed plan, current wave, pending checkpoints. diff --git a/get-shit-done/workflows/execute-phase/steps/codebase-drift-gate.md b/get-shit-done/workflows/execute-phase/steps/codebase-drift-gate.md index 53df17fc..3268edab 100644 --- a/get-shit-done/workflows/execute-phase/steps/codebase-drift-gate.md +++ b/get-shit-done/workflows/execute-phase/steps/codebase-drift-gate.md @@ -34,7 +34,7 @@ New migrations: New route modules: - {path} -Run /gsd:map-codebase --paths {affected_paths} to refresh planning context. +Run /gsd-map-codebase --paths {affected_paths} to refresh planning context. ``` Then continue to `verify_phase_goal`. Do NOT block. Do NOT spawn anything. diff --git a/get-shit-done/workflows/execute-plan.md b/get-shit-done/workflows/execute-plan.md index e4e8a201..2766d702 100644 --- a/get-shit-done/workflows/execute-plan.md +++ b/get-shit-done/workflows/execute-plan.md @@ -472,9 +472,9 @@ If `USER_SETUP_CREATED=true`: display `⚠️ USER SETUP REQUIRED` with path + e | Condition | Route | Action | |-----------|-------|--------| -| summaries < plans | **A: More plans** | Find next PLAN without SUMMARY. Yolo: auto-continue. Interactive: show next plan, suggest `/gsd:execute-phase {phase}` + `/gsd:verify-work`. STOP here. | -| summaries = plans, current < highest phase | **B: Phase done** | Show completion, suggest `/gsd:plan-phase {Z+1}` + `/gsd:verify-work {Z}` + `/gsd:discuss-phase {Z+1}` | -| summaries = plans, current = highest phase | **C: Milestone done** | Show banner, suggest `/gsd:complete-milestone` + `/gsd:verify-work` + `/gsd:add-phase` | +| summaries < plans | **A: More plans** | Find next PLAN without SUMMARY. Yolo: auto-continue. Interactive: show next plan, suggest `/gsd-execute-phase {phase}` + `/gsd-verify-work`. STOP here. | +| summaries = plans, current < highest phase | **B: Phase done** | Show completion, suggest `/gsd-plan-phase {Z+1}` + `/gsd-verify-work {Z}` + `/gsd-discuss-phase {Z+1}` | +| summaries = plans, current = highest phase | **C: Milestone done** | Show banner, suggest `/gsd-complete-milestone` + `/gsd-verify-work` + `/gsd-add-phase` | All routes: `/clear` first for fresh context. diff --git a/get-shit-done/workflows/explore.md b/get-shit-done/workflows/explore.md index 2f9910bc..444859f3 100644 --- a/get-shit-done/workflows/explore.md +++ b/get-shit-done/workflows/explore.md @@ -82,8 +82,8 @@ When the conversation reaches natural conclusions or the developer signals readi | Research question | `.planning/research/questions.md` (append) | Open questions that need deeper investigation | | Requirement | `REQUIREMENTS.md` (append) | Clear requirements that emerged from discussion | | New phase | `ROADMAP.md` (append) | Scope large enough to warrant its own phase | -| Spike | `/gsd:spike` (invoke) | Feasibility uncertainty surfaced — "will this API work?", "can we do X?" | -| Sketch | `/gsd:sketch` (invoke) | Design direction unclear — "what should this look like?", "how should this feel?" | +| Spike | `/gsd-spike` (invoke) | Feasibility uncertainty surfaced — "will this API work?", "can we do X?" | +| Sketch | `/gsd-sketch` (invoke) | Design direction unclear — "what should this look like?", "how should this feel?" | Present suggestions: ``` @@ -109,7 +109,7 @@ For each selected output, write the file: - **Seeds:** Create `.planning/seeds/{slug}.md` with frontmatter (title, trigger_condition, planted_date) - **Research questions:** Append to `.planning/research/questions.md` - **Requirements:** Append to `.planning/REQUIREMENTS.md` with next available REQ ID -- **Phases:** Use existing `/gsd:add-phase` command via SlashCommand +- **Phases:** Use existing `/gsd-add-phase` command via SlashCommand Commit if `commit_docs` is enabled: ```bash @@ -125,7 +125,7 @@ gsd-sdk query commit "docs: capture exploration — {topic_slug}" {file_list} **Outputs:** {count} artifact(s) created {list of created files} -Continue exploring with `/gsd:explore` or start working with `/gsd:next`. +Continue exploring with `/gsd-explore` or start working with `/gsd-next`. ``` diff --git a/get-shit-done/workflows/extract_learnings.md b/get-shit-done/workflows/extract_learnings.md index 7a3fb2cc..059fbf0f 100644 --- a/get-shit-done/workflows/extract_learnings.md +++ b/get-shit-done/workflows/extract_learnings.md @@ -211,8 +211,8 @@ Missing artifacts: {list or "none"} Next steps: - Review extracted learnings for accuracy -- /gsd:progress — see overall project state -- /gsd:execute-phase {next} — continue to next phase +- /gsd-progress — see overall project state +- /gsd-execute-phase {next} — continue to next phase --------------------------------------------------------------- ``` diff --git a/get-shit-done/workflows/fast.md b/get-shit-done/workflows/fast.md index 729bcc32..da764835 100644 --- a/get-shit-done/workflows/fast.md +++ b/get-shit-done/workflows/fast.md @@ -5,7 +5,7 @@ no research, no plan checking. Just: understand → do → commit → log. For tasks like: fix a typo, update a config value, add a missing import, rename a variable, commit uncommitted work, add a .gitignore entry, bump a version number. -Use /gsd:quick for anything that needs multi-step planning or research. +Use /gsd-quick for anything that needs multi-step planning or research. @@ -34,8 +34,8 @@ If the task seems non-trivial (multi-file refactor, new feature, needs research) say: ``` -This looks like it needs planning. Use /gsd:quick instead: - /gsd:quick "{task description}" +This looks like it needs planning. Use /gsd-quick instead: + /gsd-quick "{task description}" ``` And stop. @@ -93,8 +93,8 @@ No next-step suggestions. No workflow routing. Just done. - NEVER spawn a Task/subagent — this runs inline - NEVER create PLAN.md or SUMMARY.md files - NEVER run research or plan-checking -- If the task takes more than 3 file edits, STOP and redirect to /gsd:quick -- If you're unsure how to implement it, STOP and redirect to /gsd:quick +- If the task takes more than 3 file edits, STOP and redirect to /gsd-quick +- If you're unsure how to implement it, STOP and redirect to /gsd-quick diff --git a/get-shit-done/workflows/forensics.md b/get-shit-done/workflows/forensics.md index 26918191..caa5d765 100644 --- a/get-shit-done/workflows/forensics.md +++ b/get-shit-done/workflows/forensics.md @@ -207,11 +207,11 @@ Based on the evidence above, the most likely explanation is: 1. {Specific, actionable remediation step} 2. {Another step if applicable} -3. {Recovery command if applicable — e.g., `/gsd:resume-work`, `/gsd:execute-phase N`} +3. {Recovery command if applicable — e.g., `/gsd-resume-work`, `/gsd-execute-phase N`} --- -*Report generated by `/gsd:forensics`. All paths redacted for portability.* +*Report generated by `/gsd-forensics`. All paths redacted for portability.* ``` **Redaction rules:** diff --git a/get-shit-done/workflows/health.md b/get-shit-done/workflows/health.md index 2f589471..df750fd4 100644 --- a/get-shit-done/workflows/health.md +++ b/get-shit-done/workflows/health.md @@ -66,10 +66,10 @@ Errors: N | Warnings: N | Info: N ## Errors - [E001] config.json: JSON parse error at line 5 - Fix: Run /gsd:health --repair to reset to defaults + Fix: Run /gsd-health --repair to reset to defaults - [E002] PROJECT.md not found - Fix: Run /gsd:new-project to create + Fix: Run /gsd-new-project to create ``` **If warnings exist:** @@ -94,7 +94,7 @@ Errors: N | Warnings: N | Info: N **Footer (if repairable issues exist and --repair was NOT used):** ``` --- -N issues can be auto-repaired. Run: /gsd:health --repair +N issues can be auto-repaired. Run: /gsd-health --repair ``` @@ -104,7 +104,7 @@ N issues can be auto-repaired. Run: /gsd:health --repair Ask user if they want to run repairs: ``` -Would you like to run /gsd:health --repair to fix N issues automatically? +Would you like to run /gsd-health --repair to fix N issues automatically? ``` If yes, re-run with --repair flag and display results. diff --git a/get-shit-done/workflows/help.md b/get-shit-done/workflows/help.md index 4f1adabf..8ce8f620 100644 --- a/get-shit-done/workflows/help.md +++ b/get-shit-done/workflows/help.md @@ -9,9 +9,9 @@ Display the complete GSD command reference. Output ONLY the reference content. D ## Quick Start -1. `/gsd:new-project` - Initialize project (includes research, requirements, roadmap) -2. `/gsd:plan-phase 1` - Create detailed plan for first phase -3. `/gsd:execute-phase 1` - Execute the phase +1. `/gsd-new-project` - Initialize project (includes research, requirements, roadmap) +2. `/gsd-plan-phase 1` - Create detailed plan for first phase +3. `/gsd-execute-phase 1` - Execute the phase ## Staying Updated @@ -24,12 +24,12 @@ npx get-shit-done-cc@latest ## Core Workflow ``` -/gsd:new-project → /gsd:plan-phase → /gsd:execute-phase → repeat +/gsd-new-project → /gsd-plan-phase → /gsd-execute-phase → repeat ``` ### Project Initialization -**`/gsd:new-project`** +**`/gsd-new-project`** Initialize new project through unified flow. One command takes you from idea to ready-for-planning: @@ -46,21 +46,21 @@ Creates all `.planning/` artifacts: - `ROADMAP.md` — phases mapped to requirements - `STATE.md` — project memory -Usage: `/gsd:new-project` +Usage: `/gsd-new-project` -**`/gsd:map-codebase`** +**`/gsd-map-codebase`** Map an existing codebase for brownfield projects. - Analyzes codebase with parallel Explore agents - Creates `.planning/codebase/` with 7 focused documents - Covers stack, architecture, structure, conventions, testing, integrations, concerns -- Use before `/gsd:new-project` on existing codebases +- Use before `/gsd-new-project` on existing codebases -Usage: `/gsd:map-codebase` +Usage: `/gsd-map-codebase` ### Phase Planning -**`/gsd:discuss-phase `** +**`/gsd-discuss-phase `** Help articulate your vision for a phase before planning. - Captures how you imagine this phase working @@ -68,11 +68,11 @@ Help articulate your vision for a phase before planning. - Use when you have ideas about how something should look/feel - Optional `--batch` asks 2-5 related questions at a time instead of one-by-one -Usage: `/gsd:discuss-phase 2` -Usage: `/gsd:discuss-phase 2 --batch` -Usage: `/gsd:discuss-phase 2 --batch=3` +Usage: `/gsd-discuss-phase 2` +Usage: `/gsd-discuss-phase 2 --batch` +Usage: `/gsd-discuss-phase 2 --batch=3` -**`/gsd:research-phase `** +**`/gsd-research-phase `** Comprehensive ecosystem research for niche/complex domains. - Discovers standard stack, architecture patterns, pitfalls @@ -80,18 +80,18 @@ Comprehensive ecosystem research for niche/complex domains. - Use for 3D, games, audio, shaders, ML, and other specialized domains - Goes beyond "which library" to ecosystem knowledge -Usage: `/gsd:research-phase 3` +Usage: `/gsd-research-phase 3` -**`/gsd:list-phase-assumptions `** +**`/gsd-list-phase-assumptions `** See what Claude is planning to do before it starts. - Shows Claude's intended approach for a phase - Lets you course-correct if Claude misunderstood your vision - No files created - conversational output only -Usage: `/gsd:list-phase-assumptions 3` +Usage: `/gsd-list-phase-assumptions 3` -**`/gsd:plan-phase `** +**`/gsd-plan-phase `** Create detailed execution plan for a specific phase. - Generates `.planning/phases/XX-phase-name/XX-YY-PLAN.md` @@ -99,14 +99,14 @@ Create detailed execution plan for a specific phase. - Includes verification criteria and success measures - Multiple plans per phase supported (XX-01, XX-02, etc.) -Usage: `/gsd:plan-phase 1` +Usage: `/gsd-plan-phase 1` Result: Creates `.planning/phases/01-foundation/01-01-PLAN.md` **PRD Express Path:** Pass `--prd path/to/requirements.md` to skip discuss-phase entirely. Your PRD becomes locked decisions in CONTEXT.md. Useful when you already have clear acceptance criteria. ### Execution -**`/gsd:execute-phase `** +**`/gsd-execute-phase `** Execute all plans in a phase, or run a specific wave. - Groups plans by wave (from frontmatter), executes waves sequentially @@ -115,12 +115,12 @@ Execute all plans in a phase, or run a specific wave. - Verifies phase goal after all plans complete - Updates REQUIREMENTS.md, ROADMAP.md, STATE.md -Usage: `/gsd:execute-phase 5` -Usage: `/gsd:execute-phase 5 --wave 2` +Usage: `/gsd-execute-phase 5` +Usage: `/gsd-execute-phase 5 --wave 2` ### Smart Router -**`/gsd:do `** +**`/gsd-do `** Route freeform text to the right GSD command automatically. - Analyzes natural language input to find the best matching GSD command @@ -128,13 +128,13 @@ Route freeform text to the right GSD command automatically. - Resolves ambiguity by asking you to pick between top matches - Use when you know what you want but don't know which `/gsd-*` command to run -Usage: `/gsd:do fix the login button` -Usage: `/gsd:do refactor the auth system` -Usage: `/gsd:do I want to start a new milestone` +Usage: `/gsd-do fix the login button` +Usage: `/gsd-do refactor the auth system` +Usage: `/gsd-do I want to start a new milestone` ### Quick Mode -**`/gsd:quick [--full] [--validate] [--discuss] [--research]`** +**`/gsd-quick [--full] [--validate] [--discuss] [--research]`** Execute small, ad-hoc tasks with GSD guarantees but skip optional agents. Quick mode uses the same system with a shorter path: @@ -150,48 +150,48 @@ Flags enable additional quality steps: Granular flags are composable: `--discuss --research --validate` gives the same as `--full`. -Usage: `/gsd:quick` -Usage: `/gsd:quick --full` -Usage: `/gsd:quick --research --validate` +Usage: `/gsd-quick` +Usage: `/gsd-quick --full` +Usage: `/gsd-quick --research --validate` Result: Creates `.planning/quick/NNN-slug/PLAN.md`, `.planning/quick/NNN-slug/SUMMARY.md` --- -**`/gsd:fast [description]`** +**`/gsd-fast [description]`** Execute a trivial task inline — no subagents, no planning files, no overhead. For tasks too small to justify planning: typo fixes, config changes, forgotten commits, simple additions. Runs in the current context, makes the change, commits, and logs to STATE.md. - No PLAN.md or SUMMARY.md created - No subagent spawned (runs inline) -- ≤ 3 file edits — redirects to `/gsd:quick` if task is non-trivial +- ≤ 3 file edits — redirects to `/gsd-quick` if task is non-trivial - Atomic commit with conventional message -Usage: `/gsd:fast "fix the typo in README"` -Usage: `/gsd:fast "add .env to gitignore"` +Usage: `/gsd-fast "fix the typo in README"` +Usage: `/gsd-fast "add .env to gitignore"` ### Roadmap Management -**`/gsd:add-phase `** +**`/gsd-add-phase `** Add new phase to end of current milestone. - Appends to ROADMAP.md - Uses next sequential number - Updates phase directory structure -Usage: `/gsd:add-phase "Add admin dashboard"` +Usage: `/gsd-add-phase "Add admin dashboard"` -**`/gsd:insert-phase `** +**`/gsd-insert-phase `** Insert urgent work as decimal phase between existing phases. - Creates intermediate phase (e.g., 7.1 between 7 and 8) - Useful for discovered work that must happen mid-milestone - Maintains phase ordering -Usage: `/gsd:insert-phase 7 "Fix critical auth bug"` +Usage: `/gsd-insert-phase 7 "Fix critical auth bug"` Result: Creates Phase 7.1 -**`/gsd:remove-phase `** +**`/gsd-remove-phase `** Remove a future phase and renumber subsequent phases. - Deletes phase directory and all references @@ -199,12 +199,12 @@ Remove a future phase and renumber subsequent phases. - Only works on future (unstarted) phases - Git commit preserves historical record -Usage: `/gsd:remove-phase 17` +Usage: `/gsd-remove-phase 17` Result: Phase 17 deleted, phases 18-20 become 17-19 ### Milestone Management -**`/gsd:new-milestone `** +**`/gsd-new-milestone `** Start a new milestone through unified flow. - Deep questioning to understand what you're building next @@ -213,12 +213,12 @@ Start a new milestone through unified flow. - Roadmap creation with phase breakdown - Optional `--reset-phase-numbers` flag restarts numbering at Phase 1 and archives old phase dirs first for safety -Mirrors `/gsd:new-project` flow for brownfield projects (existing PROJECT.md). +Mirrors `/gsd-new-project` flow for brownfield projects (existing PROJECT.md). -Usage: `/gsd:new-milestone "v2.0 Features"` -Usage: `/gsd:new-milestone --reset-phase-numbers "v2.0 Features"` +Usage: `/gsd-new-milestone "v2.0 Features"` +Usage: `/gsd-new-milestone --reset-phase-numbers "v2.0 Features"` -**`/gsd:complete-milestone `** +**`/gsd-complete-milestone `** Archive completed milestone and prepare for next version. - Creates MILESTONES.md entry with stats @@ -226,11 +226,11 @@ Archive completed milestone and prepare for next version. - Creates git tag for the release - Prepares workspace for next version -Usage: `/gsd:complete-milestone 1.0.0` +Usage: `/gsd-complete-milestone 1.0.0` ### Progress Tracking -**`/gsd:progress`** +**`/gsd-progress`** Check project status and intelligently route to next action. - Shows visual progress bar and completion percentage @@ -240,58 +240,58 @@ Check project status and intelligently route to next action. - Offers to execute next plan or create it if missing - Detects 100% milestone completion -Usage: `/gsd:progress` +Usage: `/gsd-progress` ### Session Management -**`/gsd:resume-work`** +**`/gsd-resume-work`** Resume work from previous session with full context restoration. - Reads STATE.md for project context - Shows current position and recent progress - Offers next actions based on project state -Usage: `/gsd:resume-work` +Usage: `/gsd-resume-work` -**`/gsd:pause-work`** +**`/gsd-pause-work`** Create context handoff when pausing work mid-phase. - Creates .continue-here file with current state - Updates STATE.md session continuity section - Captures in-progress work context -Usage: `/gsd:pause-work` +Usage: `/gsd-pause-work` ### Debugging -**`/gsd:debug [issue description]`** +**`/gsd-debug [issue description]`** Systematic debugging with persistent state across context resets. - Gathers symptoms through adaptive questioning - Creates `.planning/debug/[slug].md` to track investigation - Investigates using scientific method (evidence → hypothesis → test) -- Survives `/clear` — run `/gsd:debug` with no args to resume +- Survives `/clear` — run `/gsd-debug` with no args to resume - Archives resolved issues to `.planning/debug/resolved/` -Usage: `/gsd:debug "login button doesn't work"` -Usage: `/gsd:debug` (resume active session) +Usage: `/gsd-debug "login button doesn't work"` +Usage: `/gsd-debug` (resume active session) ### Spiking & Sketching -**`/gsd:spike [idea] [--quick]`** +**`/gsd-spike [idea] [--quick]`** Rapidly spike an idea with throwaway experiments to validate feasibility. - Decomposes idea into 2-5 focused experiments (risk-ordered) - Each spike answers one specific Given/When/Then question - Builds minimum code, runs it, captures verdict (VALIDATED/INVALIDATED/PARTIAL) - Saves to `.planning/spikes/` with MANIFEST.md tracking -- Does not require `/gsd:new-project` — works in any repo +- Does not require `/gsd-new-project` — works in any repo - `--quick` skips decomposition, builds immediately -Usage: `/gsd:spike "can we stream LLM output over WebSockets?"` -Usage: `/gsd:spike --quick "test if pdfjs extracts tables"` +Usage: `/gsd-spike "can we stream LLM output over WebSockets?"` +Usage: `/gsd-spike --quick "test if pdfjs extracts tables"` -**`/gsd:sketch [idea] [--quick]`** +**`/gsd-sketch [idea] [--quick]`** Rapidly sketch UI/design ideas using throwaway HTML mockups with multi-variant exploration. - Conversational mood/direction intake before building @@ -299,13 +299,13 @@ Rapidly sketch UI/design ideas using throwaway HTML mockups with multi-variant e - User compares variants, cherry-picks elements, iterates - Shared CSS theme system compounds across sketches - Saves to `.planning/sketches/` with MANIFEST.md tracking -- Does not require `/gsd:new-project` — works in any repo +- Does not require `/gsd-new-project` — works in any repo - `--quick` skips mood intake, jumps to building -Usage: `/gsd:sketch "dashboard layout for the admin panel"` -Usage: `/gsd:sketch --quick "form card grouping"` +Usage: `/gsd-sketch "dashboard layout for the admin panel"` +Usage: `/gsd-sketch --quick "form card grouping"` -**`/gsd:spike-wrap-up`** +**`/gsd-spike-wrap-up`** Package spike findings into a persistent project skill. - Curates each spike one-at-a-time (include/exclude/partial/UAT) @@ -314,9 +314,9 @@ Package spike findings into a persistent project skill. - Writes summary to `.planning/spikes/WRAP-UP-SUMMARY.md` - Adds auto-load routing line to project CLAUDE.md -Usage: `/gsd:spike-wrap-up` +Usage: `/gsd-spike-wrap-up` -**`/gsd:sketch-wrap-up`** +**`/gsd-sketch-wrap-up`** Package sketch design findings into a persistent project skill. - Curates each sketch one-at-a-time (include/exclude/partial/revisit) @@ -325,11 +325,11 @@ Package sketch design findings into a persistent project skill. - Writes summary to `.planning/sketches/WRAP-UP-SUMMARY.md` - Adds auto-load routing line to project CLAUDE.md -Usage: `/gsd:sketch-wrap-up` +Usage: `/gsd-sketch-wrap-up` ### Quick Notes -**`/gsd:note `** +**`/gsd-note `** Zero-friction idea capture — one command, instant save, no questions. - Saves timestamped note to `.planning/notes/` (or `~/.claude/notes/` globally) @@ -337,14 +337,14 @@ Zero-friction idea capture — one command, instant save, no questions. - Promote converts a note into a structured todo - Works without a project (falls back to global scope) -Usage: `/gsd:note refactor the hook system` -Usage: `/gsd:note list` -Usage: `/gsd:note promote 3` -Usage: `/gsd:note --global cross-project idea` +Usage: `/gsd-note refactor the hook system` +Usage: `/gsd-note list` +Usage: `/gsd-note promote 3` +Usage: `/gsd-note --global cross-project idea` ### Todo Management -**`/gsd:add-todo [description]`** +**`/gsd-add-todo [description]`** Capture idea or task as todo from current conversation. - Extracts context from conversation (or uses provided description) @@ -353,24 +353,24 @@ Capture idea or task as todo from current conversation. - Checks for duplicates before creating - Updates STATE.md todo count -Usage: `/gsd:add-todo` (infers from conversation) -Usage: `/gsd:add-todo Add auth token refresh` +Usage: `/gsd-add-todo` (infers from conversation) +Usage: `/gsd-add-todo Add auth token refresh` -**`/gsd:check-todos [area]`** +**`/gsd-check-todos [area]`** List pending todos and select one to work on. - Lists all pending todos with title, area, age -- Optional area filter (e.g., `/gsd:check-todos api`) +- Optional area filter (e.g., `/gsd-check-todos api`) - Loads full context for selected todo - Routes to appropriate action (work now, add to phase, brainstorm) - Moves todo to done/ when work begins -Usage: `/gsd:check-todos` -Usage: `/gsd:check-todos api` +Usage: `/gsd-check-todos` +Usage: `/gsd-check-todos api` ### User Acceptance Testing -**`/gsd:verify-work [phase]`** +**`/gsd-verify-work [phase]`** Validate built features through conversational UAT. - Extracts testable deliverables from SUMMARY.md files @@ -378,11 +378,11 @@ Validate built features through conversational UAT. - Automatically diagnoses failures and creates fix plans - Ready for re-execution if issues found -Usage: `/gsd:verify-work 3` +Usage: `/gsd-verify-work 3` ### Ship Work -**`/gsd:ship [phase]`** +**`/gsd-ship [phase]`** Create a PR from completed phase work with an auto-generated body. - Pushes branch to remote @@ -392,57 +392,57 @@ Create a PR from completed phase work with an auto-generated body. Prerequisites: Phase verified, `gh` CLI installed and authenticated. -Usage: `/gsd:ship 4` or `/gsd:ship 4 --draft` +Usage: `/gsd-ship 4` or `/gsd-ship 4 --draft` --- -**`/gsd:review --phase N [--gemini] [--claude] [--codex] [--coderabbit] [--opencode] [--qwen] [--cursor] [--all]`** +**`/gsd-review --phase N [--gemini] [--claude] [--codex] [--coderabbit] [--opencode] [--qwen] [--cursor] [--all]`** Cross-AI peer review — invoke external AI CLIs to independently review phase plans. - Detects available CLIs (gemini, claude, codex, coderabbit) - Each CLI reviews plans independently with the same structured prompt - CodeRabbit reviews the current git diff (not a prompt) — may take up to 5 minutes - Produces REVIEWS.md with per-reviewer feedback and consensus summary -- Feed reviews back into planning: `/gsd:plan-phase N --reviews` +- Feed reviews back into planning: `/gsd-plan-phase N --reviews` -Usage: `/gsd:review --phase 3 --all` +Usage: `/gsd-review --phase 3 --all` --- -**`/gsd:pr-branch [target]`** +**`/gsd-pr-branch [target]`** Create a clean branch for pull requests by filtering out .planning/ commits. - Classifies commits: code-only (include), planning-only (exclude), mixed (include sans .planning/) - Cherry-picks code commits onto a clean branch - Reviewers see only code changes, no GSD artifacts -Usage: `/gsd:pr-branch` or `/gsd:pr-branch main` +Usage: `/gsd-pr-branch` or `/gsd-pr-branch main` --- -**`/gsd:plant-seed [idea]`** +**`/gsd-plant-seed [idea]`** Capture a forward-looking idea with trigger conditions for automatic surfacing. - Seeds preserve WHY, WHEN to surface, and breadcrumbs to related code -- Auto-surfaces during `/gsd:new-milestone` when trigger conditions match +- Auto-surfaces during `/gsd-new-milestone` when trigger conditions match - Better than deferred items — triggers are checked, not forgotten -Usage: `/gsd:plant-seed "add real-time notifications when we build the events system"` +Usage: `/gsd-plant-seed "add real-time notifications when we build the events system"` --- -**`/gsd:audit-uat`** +**`/gsd-audit-uat`** Cross-phase audit of all outstanding UAT and verification items. - Scans every phase for pending, skipped, blocked, and human_needed items - Cross-references against codebase to detect stale documentation - Produces prioritized human test plan grouped by testability - Use before starting a new milestone to clear verification debt -Usage: `/gsd:audit-uat` +Usage: `/gsd-audit-uat` ### Milestone Auditing -**`/gsd:audit-milestone [version]`** +**`/gsd-audit-milestone [version]`** Audit milestone completion against original intent. - Reads all phase VERIFICATION.md files @@ -450,30 +450,30 @@ Audit milestone completion against original intent. - Spawns integration checker for cross-phase wiring - Creates MILESTONE-AUDIT.md with gaps and tech debt -Usage: `/gsd:audit-milestone` +Usage: `/gsd-audit-milestone` -**`/gsd:plan-milestone-gaps`** +**`/gsd-plan-milestone-gaps`** Create phases to close gaps identified by audit. - Reads MILESTONE-AUDIT.md and groups gaps into phases - Prioritizes by requirement priority (must/should/nice) - Adds gap closure phases to ROADMAP.md -- Ready for `/gsd:plan-phase` on new phases +- Ready for `/gsd-plan-phase` on new phases -Usage: `/gsd:plan-milestone-gaps` +Usage: `/gsd-plan-milestone-gaps` ### Configuration -**`/gsd:settings`** +**`/gsd-settings`** Configure workflow toggles and model profile interactively. - Toggle researcher, plan checker, verifier agents - Select model profile (quality/balanced/budget/inherit) - Updates `.planning/config.json` -Usage: `/gsd:settings` +Usage: `/gsd-settings` -**`/gsd:set-profile `** +**`/gsd-set-profile `** Quick switch model profile for GSD agents. - `quality` — Opus everywhere except verification @@ -481,11 +481,11 @@ Quick switch model profile for GSD agents. - `budget` — Sonnet for writing, Haiku for research/verification - `inherit` — Use current session model for all agents (OpenCode `/model`) -Usage: `/gsd:set-profile budget` +Usage: `/gsd-set-profile budget` ### Utility Commands -**`/gsd:cleanup`** +**`/gsd-cleanup`** Archive accumulated phase directories from completed milestones. - Identifies phases from completed milestones still in `.planning/phases/` @@ -493,12 +493,12 @@ Archive accumulated phase directories from completed milestones. - Moves phase dirs to `.planning/milestones/v{X.Y}-phases/` - Use after multiple milestones to reduce `.planning/phases/` clutter -Usage: `/gsd:cleanup` +Usage: `/gsd-cleanup` -**`/gsd:help`** +**`/gsd-help`** Show this command reference. -**`/gsd:update`** +**`/gsd-update`** Update GSD to latest version with changelog preview. - Shows installed vs latest version comparison @@ -507,15 +507,15 @@ Update GSD to latest version with changelog preview. - Confirms before running install - Better than raw `npx get-shit-done-cc` -Usage: `/gsd:update` +Usage: `/gsd-update` -**`/gsd:join-discord`** +**`/gsd-join-discord`** Join the GSD Discord community. - Get help, share what you're building, stay updated - Connect with other GSD users -Usage: `/gsd:join-discord` +Usage: `/gsd-join-discord` ## Files & Structure @@ -529,10 +529,10 @@ Usage: `/gsd:join-discord` ├── todos/ # Captured ideas and tasks │ ├── pending/ # Todos waiting to be worked on │ └── done/ # Completed todos -├── spikes/ # Spike experiments (/gsd:spike) +├── spikes/ # Spike experiments (/gsd-spike) │ ├── MANIFEST.md # Spike inventory and verdicts │ └── NNN-name/ # Individual spike directories -├── sketches/ # Design sketches (/gsd:sketch) +├── sketches/ # Design sketches (/gsd-sketch) │ ├── MANIFEST.md # Sketch inventory and winners │ ├── themes/ # Shared CSS theme files │ └── NNN-name/ # Individual sketch directories (HTML + README) @@ -541,7 +541,7 @@ Usage: `/gsd:join-discord` ├── milestones/ │ ├── v1.0-ROADMAP.md # Archived roadmap snapshot │ ├── v1.0-REQUIREMENTS.md # Archived requirements -│ └── v1.0-phases/ # Archived phase dirs (via /gsd:cleanup or --archive-phases) +│ └── v1.0-phases/ # Archived phase dirs (via /gsd-cleanup or --archive-phases) │ ├── 01-foundation/ │ └── 02-core-features/ ├── codebase/ # Codebase map (brownfield projects) @@ -563,7 +563,7 @@ Usage: `/gsd:join-discord` ## Workflow Modes -Set during `/gsd:new-project`: +Set during `/gsd-new-project`: **Interactive Mode** @@ -611,51 +611,51 @@ Example config: **Starting a new project:** ``` -/gsd:new-project # Unified flow: questioning → research → requirements → roadmap +/gsd-new-project # Unified flow: questioning → research → requirements → roadmap /clear -/gsd:plan-phase 1 # Create plans for first phase +/gsd-plan-phase 1 # Create plans for first phase /clear -/gsd:execute-phase 1 # Execute all plans in phase +/gsd-execute-phase 1 # Execute all plans in phase ``` **Resuming work after a break:** ``` -/gsd:progress # See where you left off and continue +/gsd-progress # See where you left off and continue ``` **Adding urgent mid-milestone work:** ``` -/gsd:insert-phase 5 "Critical security fix" -/gsd:plan-phase 5.1 -/gsd:execute-phase 5.1 +/gsd-insert-phase 5 "Critical security fix" +/gsd-plan-phase 5.1 +/gsd-execute-phase 5.1 ``` **Completing a milestone:** ``` -/gsd:complete-milestone 1.0.0 +/gsd-complete-milestone 1.0.0 /clear -/gsd:new-milestone # Start next milestone (questioning → research → requirements → roadmap) +/gsd-new-milestone # Start next milestone (questioning → research → requirements → roadmap) ``` **Capturing ideas during work:** ``` -/gsd:add-todo # Capture from conversation context -/gsd:add-todo Fix modal z-index # Capture with explicit description -/gsd:check-todos # Review and work on todos -/gsd:check-todos api # Filter by area +/gsd-add-todo # Capture from conversation context +/gsd-add-todo Fix modal z-index # Capture with explicit description +/gsd-check-todos # Review and work on todos +/gsd-check-todos api # Filter by area ``` **Debugging an issue:** ``` -/gsd:debug "form submission fails silently" # Start debug session +/gsd-debug "form submission fails silently" # Start debug session # ... investigation happens, context fills up ... /clear -/gsd:debug # Resume from where you left off +/gsd-debug # Resume from where you left off ``` ## Getting Help @@ -663,5 +663,5 @@ Example config: - Read `.planning/PROJECT.md` for project vision - Read `.planning/STATE.md` for current context - Check `.planning/ROADMAP.md` for phase status -- Run `/gsd:progress` to check where you're up to +- Run `/gsd-progress` to check where you're up to diff --git a/get-shit-done/workflows/import.md b/get-shit-done/workflows/import.md index 8a755635..5b5167d0 100644 --- a/get-shit-done/workflows/import.md +++ b/get-shit-done/workflows/import.md @@ -32,7 +32,7 @@ Parse `$ARGUMENTS` to determine the execution mode: - If neither flag is found: display usage and exit: ``` -Usage: /gsd:import --from +Usage: /gsd-import --from --from Import an external plan file into GSD format ``` diff --git a/get-shit-done/workflows/inbox.md b/get-shit-done/workflows/inbox.md index 1558fa41..7b6452ed 100644 --- a/get-shit-done/workflows/inbox.md +++ b/get-shit-done/workflows/inbox.md @@ -370,10 +370,10 @@ Next steps: After triage: -- /gsd:review — Run cross-AI peer review on a specific phase plan -- /gsd:ship — Create a PR from completed work -- /gsd:progress — See overall project state -- /gsd:inbox --label — Re-run with auto-labeling enabled +- /gsd-review — Run cross-AI peer review on a specific phase plan +- /gsd-ship — Create a PR from completed work +- /gsd-progress — See overall project state +- /gsd-inbox --label — Re-run with auto-labeling enabled diff --git a/get-shit-done/workflows/ingest-docs.md b/get-shit-done/workflows/ingest-docs.md index ef7bee0a..3017eefb 100644 --- a/get-shit-done/workflows/ingest-docs.md +++ b/get-shit-done/workflows/ingest-docs.md @@ -122,7 +122,7 @@ De-duplicate the union (a file matched by multiple patterns is one doc). ``` GSD > Discovered {N} docs, which exceeds the v1 cap of 50. Use --manifest to narrow the set to ≤ 50 files, or run - /gsd:ingest-docs again with a narrower . + /gsd-ingest-docs again with a narrower . ``` Exit without proceeding. @@ -309,7 +309,7 @@ Show: - Docs ingested (count + type breakdown) - Decisions locked, requirements created, constraints captured - Conflict report path (`.planning/INGEST-CONFLICTS.md`) -- Next step: `/gsd:plan-phase 1` (new mode) or `/gsd:plan-phase N` (merge, pointing at the first newly-added phase) +- Next step: `/gsd-plan-phase 1` (new mode) or `/gsd-plan-phase N` (merge, pointing at the first newly-added phase) diff --git a/get-shit-done/workflows/insert-phase.md b/get-shit-done/workflows/insert-phase.md index 8805a6bd..54ac687d 100644 --- a/get-shit-done/workflows/insert-phase.md +++ b/get-shit-done/workflows/insert-phase.md @@ -13,7 +13,7 @@ Parse the command arguments: - First argument: integer phase number to insert after - Remaining arguments: phase description -Example: `/gsd:insert-phase 72 Fix critical auth bug` +Example: `/gsd-insert-phase 72 Fix critical auth bug` -> after = 72 -> description = "Fix critical auth bug" @@ -21,8 +21,8 @@ If arguments missing: ``` ERROR: Both phase number and description required -Usage: /gsd:insert-phase -Example: /gsd:insert-phase 72 Fix critical auth bug +Usage: /gsd-insert-phase +Example: /gsd-insert-phase 72 Fix critical auth bug ``` Exit. @@ -71,7 +71,7 @@ blocks direct STATE.md writes): `{decimal_phase}`: ```bash - gsd-sdk query state.patch '{"Current Phase":"{decimal_phase}","Next recommended run":"/gsd:plan-phase {decimal_phase}"}' + gsd-sdk query state.patch '{"Current Phase":"{decimal_phase}","Next recommended run":"/gsd-plan-phase {decimal_phase}"}' ``` (Adjust field names to whatever pointers STATE.md exposes — the handler @@ -115,7 +115,7 @@ Project state updated: .planning/STATE.md `/clear` then: -`/gsd:plan-phase {decimal_phase}` +`/gsd-plan-phase {decimal_phase}` --- @@ -131,11 +131,11 @@ Project state updated: .planning/STATE.md -- Don't use this for planned work at end of milestone (use /gsd:add-phase) +- Don't use this for planned work at end of milestone (use /gsd-add-phase) - Don't insert before Phase 1 (decimal 0.1 makes no sense) - Don't renumber existing phases - Don't modify the target phase content -- Don't create plans yet (that's /gsd:plan-phase) +- Don't create plans yet (that's /gsd-plan-phase) - Don't commit changes (user decides when to commit) diff --git a/get-shit-done/workflows/list-phase-assumptions.md b/get-shit-done/workflows/list-phase-assumptions.md index 3269d283..f575a4e2 100644 --- a/get-shit-done/workflows/list-phase-assumptions.md +++ b/get-shit-done/workflows/list-phase-assumptions.md @@ -14,8 +14,8 @@ Phase number: $ARGUMENTS (required) ``` Error: Phase number required. -Usage: /gsd:list-phase-assumptions [phase-number] -Example: /gsd:list-phase-assumptions 3 +Usage: /gsd-list-phase-assumptions [phase-number] +Example: /gsd-list-phase-assumptions 3 ``` Exit workflow. @@ -153,8 +153,8 @@ Present next steps: ``` What's next? -1. Discuss context (/gsd:discuss-phase ${PHASE}) - Let me ask you questions to build comprehensive context -2. Plan this phase (/gsd:plan-phase ${PHASE}) - Create detailed execution plans +1. Discuss context (/gsd-discuss-phase ${PHASE}) - Let me ask you questions to build comprehensive context +2. Plan this phase (/gsd-plan-phase ${PHASE}) - Create detailed execution plans 3. Re-examine assumptions - I'll analyze again with your corrections 4. Done for now ``` diff --git a/get-shit-done/workflows/list-workspaces.md b/get-shit-done/workflows/list-workspaces.md index 3a34e01e..c79a84bc 100644 --- a/get-shit-done/workflows/list-workspaces.md +++ b/get-shit-done/workflows/list-workspaces.md @@ -25,7 +25,7 @@ Parse JSON for: `workspace_base`, `workspaces`, `workspace_count`. No workspaces found in ~/gsd-workspaces/ Create one with: - /gsd:new-workspace --name my-workspace --repos repo1,repo2 + /gsd-new-workspace --name my-workspace --repos repo1,repo2 ``` Done. @@ -44,7 +44,7 @@ GSD Workspaces (~/gsd-workspaces/) Manage: cd ~/gsd-workspaces/ # Enter a workspace - /gsd:remove-workspace # Remove a workspace + /gsd-remove-workspace # Remove a workspace ``` For each workspace, show: diff --git a/get-shit-done/workflows/manager.md b/get-shit-done/workflows/manager.md index 83d39e85..6d9da93d 100644 --- a/get-shit-done/workflows/manager.md +++ b/get-shit-done/workflows/manager.md @@ -26,7 +26,7 @@ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi Parse JSON for: `milestone_version`, `milestone_name`, `phase_count`, `completed_count`, `in_progress_count`, `phases`, `recommended_actions`, `all_complete`, `waiting_signal`, `manager_flags`, and the optional trio `queued_milestone_version`, `queued_milestone_name`, `queued_phases` (added in SDK fix `2495-2496-2497` — may be absent on older SDK versions, treat missing as empty). `manager_flags` contains per-step passthrough flags from config: -- `manager_flags.discuss` — appended to `/gsd:discuss-phase` args (e.g. `"--auto --analyze"`) +- `manager_flags.discuss` — appended to `/gsd-discuss-phase` args (e.g. `"--auto --analyze"`) - `manager_flags.plan` — appended to plan agent init command - `manager_flags.execute` — appended to execute agent init command @@ -135,8 +135,8 @@ If `all_complete` is true: ╚══════════════════════════════════════════════════════════════╝ All {phase_count} phases done. Ready for final steps: - → /gsd:verify-work — run acceptance testing - → /gsd:complete-milestone — archive and wrap up + → /gsd-verify-work — run acceptance testing + → /gsd-complete-milestone — archive and wrap up ``` @@ -359,11 +359,11 @@ Display final status with progress bar: {milestone_version} — {milestone_name} {PROGRESS_BAR} {progress_pct}% ({completed_count}/{phase_count} phases) - Resume anytime: /gsd:manager + Resume anytime: /gsd-manager ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ``` -**Note:** Any background agents still running will continue to completion. Their results will be visible on next `/gsd:manager` or `/gsd:progress` invocation. +**Note:** Any background agents still running will continue to completion. Their results will be visible on next `/gsd-manager` or `/gsd-progress` invocation. diff --git a/get-shit-done/workflows/map-codebase.md b/get-shit-done/workflows/map-codebase.md index 96230452..b3934fa4 100644 --- a/get-shit-done/workflows/map-codebase.md +++ b/get-shit-done/workflows/map-codebase.md @@ -29,8 +29,8 @@ Documents are reference material for Claude when planning/executing. Always incl Parse an optional `--paths ` argument. When supplied (by the -post-execute codebase-drift gate in `/gsd:execute-phase` or by a user running -`/gsd:map-codebase --paths apps/accounting,packages/ui`), the workflow +post-execute codebase-drift gate in `/gsd-execute-phase` or by a user running +`/gsd-map-codebase --paths apps/accounting,packages/ui`), the workflow operates in **incremental-remap mode**: - Pass `--paths ,,...` through to each spawned `gsd-codebase-mapper` @@ -413,12 +413,12 @@ Created .planning/codebase/: `/clear` then: -`/gsd:new-project` +`/gsd-new-project` --- **Also available:** -- Re-run mapping: `/gsd:map-codebase` +- Re-run mapping: `/gsd-map-codebase` - Review specific file: `cat .planning/codebase/STACK.md` - Edit any document before proceeding diff --git a/get-shit-done/workflows/milestone-summary.md b/get-shit-done/workflows/milestone-summary.md index a24e8e41..ea660a4d 100644 --- a/get-shit-done/workflows/milestone-summary.md +++ b/get-shit-done/workflows/milestone-summary.md @@ -15,7 +15,7 @@ If `$ARGUMENTS` is empty: 1. Check `.planning/STATE.md` for current milestone version 2. Check `.planning/milestones/` for the latest archived version 3. If neither found, check if `.planning/ROADMAP.md` exists (project may be mid-milestone) -4. If nothing found: error "No milestone found. Run /gsd:new-project or /gsd:new-milestone first." +4. If nothing found: error "No milestone found. Run /gsd-new-project or /gsd-new-milestone first." Set `VERSION` to the resolved version (e.g., "1.0"). @@ -212,7 +212,7 @@ If the user asks questions: - Stay grounded in what was actually built (not speculation) If the user is done: -- Suggest next steps: `/gsd:new-milestone`, `/gsd:progress`, or sharing the summary with the team +- Suggest next steps: `/gsd-new-milestone`, `/gsd-progress`, or sharing the summary with the team ## Step 9: Update STATE.md diff --git a/get-shit-done/workflows/new-milestone.md b/get-shit-done/workflows/new-milestone.md index 5542ba98..ce64da77 100644 --- a/get-shit-done/workflows/new-milestone.md +++ b/get-shit-done/workflows/new-milestone.md @@ -164,7 +164,7 @@ This document evolves at phase transitions and milestone boundaries. 4. Decisions to log? → Add to Key Decisions 5. "What This Is" still accurate? → Update if drifted -**After each milestone** (via `/gsd:complete-milestone`): +**After each milestone** (via `/gsd-complete-milestone`): 1. Full review of all sections 2. Core Value check — still the right priority? 3. Audit Out of Scope — reasons still valid? @@ -259,7 +259,7 @@ Then verify `.planning/phases/` no longer contains old milestone directories bef If `phase_dir_count > 0` but `phase_archive_path` is missing: - Stop and explain that reset numbering is unsafe without a completed milestone archive target. -- Tell the user to complete/archive the previous milestone first, then rerun `/gsd:new-milestone --reset-phase-numbers ${GSD_WS}`. +- Tell the user to complete/archive the previous milestone first, then rerun `/gsd-new-milestone --reset-phase-numbers ${GSD_WS}`. ## 8. Research Decision @@ -277,7 +277,7 @@ AskUserQuestion: "Research the domain ecosystem for new features before defining - "Skip research (current default)" — Go straight to requirements - "Research first" — Discover patterns, features, architecture for NEW capabilities -**IMPORTANT:** Do NOT persist this choice to config.json. The `workflow.research` setting is a persistent user preference that controls plan-phase behavior across the project. Changing it here would silently alter future `/gsd:plan-phase` behavior. To change the default, use `/gsd:settings`. +**IMPORTANT:** Do NOT persist this choice to config.json. The `workflow.research` setting is a persistent user preference that controls plan-phase behavior across the project. Changing it here would silently alter future `/gsd-plan-phase` behavior. To change the default, use `/gsd-settings`. **If user chose "Research first":** @@ -601,9 +601,9 @@ Print a summary: `/clear` then: -`/gsd:discuss-phase [N] ${GSD_WS}` — gather context and clarify approach +`/gsd-discuss-phase [N] ${GSD_WS}` — gather context and clarify approach -Also: `/gsd:plan-phase [N] ${GSD_WS}` — skip discussion, plan directly +Also: `/gsd-plan-phase [N] ${GSD_WS}` — skip discussion, plan directly ``` @@ -621,7 +621,7 @@ Also: `/gsd:plan-phase [N] ${GSD_WS}` — skip discussion, plan directly - [ ] Phase numbering mode respected (continued or reset) - [ ] All commits made (if planning docs committed) - [ ] Pending todos scanned for phase matches; matched todos tagged with `resolves_phase: N` -- [ ] User knows next step: `/gsd:discuss-phase [N] ${GSD_WS}` +- [ ] User knows next step: `/gsd-discuss-phase [N] ${GSD_WS}` **Atomic commits:** Each phase commits its artifacts immediately. diff --git a/get-shit-done/workflows/new-project.md b/get-shit-done/workflows/new-project.md index fef467c6..704fdb48 100644 --- a/get-shit-done/workflows/new-project.md +++ b/get-shit-done/workflows/new-project.md @@ -33,7 +33,7 @@ Check if `--auto` flag is present in $ARGUMENTS. **Document requirement:** Auto mode requires an idea document — either: -- File reference: `/gsd:new-project --auto @prd.md` +- File reference: `/gsd-new-project --auto @prd.md` - Pasted/written text in the prompt If no document content provided, error: @@ -42,8 +42,8 @@ If no document content provided, error: Error: --auto requires an idea document. Usage: - /gsd:new-project --auto @your-idea.md - /gsd:new-project --auto [paste or write your idea here] + /gsd-new-project --auto @your-idea.md + /gsd-new-project --auto [paste or write your idea here] The document should describe what you want to build. ``` @@ -103,7 +103,7 @@ if [ "$RUNTIME" = "codex" ]; then INSTRUCTION_FILE="AGENTS.md"; else INSTRUCTION All subsequent references to the project instruction file use `$INSTRUCTION_FILE`. -**If `project_exists` is true:** Error — project already initialized. Use `/gsd:progress`. +**If `project_exists` is true:** Error — project already initialized. Use `/gsd-progress`. **If `has_git` is false:** Initialize git: @@ -124,13 +124,13 @@ Use AskUserQuestion: - header: "Codebase" - question: "I detected existing code in this directory. Would you like to map the codebase first?" - options: - - "Map codebase first" — Run /gsd:map-codebase to understand existing architecture (Recommended) + - "Map codebase first" — Run /gsd-map-codebase to understand existing architecture (Recommended) - "Skip mapping" — Proceed with project initialization **If "Map codebase first":** ``` -Run `/gsd:map-codebase` first, then return to `/gsd:new-project` +Run `/gsd-map-codebase` first, then return to `/gsd-new-project` ``` Exit command. @@ -269,8 +269,8 @@ If any of these exist, surface them before questioning: ⚡ Prior exploration detected: {if SPIKE_SKILL} ✓ Spike findings skill: {path} — validated patterns from experiments {if SKETCH_SKILL} ✓ Sketch findings skill: {path} — validated design decisions -{if HAS_SPIKES && !SPIKE_SKILL} ◆ Raw spikes in .planning/spikes/ — consider `/gsd:spike-wrap-up` to package findings -{if HAS_SKETCHES && !SKETCH_SKILL} ◆ Raw sketches in .planning/sketches/ — consider `/gsd:sketch-wrap-up` to package findings +{if HAS_SPIKES && !SPIKE_SKILL} ◆ Raw spikes in .planning/spikes/ — consider `/gsd-spike-wrap-up` to package findings +{if HAS_SKETCHES && !SKETCH_SKILL} ◆ Raw sketches in .planning/sketches/ — consider `/gsd-sketch-wrap-up` to package findings These findings will be incorporated into project context and available to planning agents. ``` @@ -434,7 +434,7 @@ This document evolves at phase transitions and milestone boundaries. 4. Decisions to log? → Add to Key Decisions 5. "What This Is" still accurate? → Update if drifted -**After each milestone** (via `/gsd:complete-milestone`): +**After each milestone** (via `/gsd-complete-milestone`): 1. Full review of all sections 2. Core Value check — still the right priority? 3. Audit Out of Scope — reasons still valid? @@ -652,7 +652,7 @@ mkdir -p .planning gsd-sdk query config-new-project '{"mode":"[yolo|interactive]","granularity":"[selected]","parallelization":true|false,"commit_docs":true|false,"model_profile":"quality|balanced|budget|inherit","workflow":{"research":true|false,"plan_check":true|false,"verifier":true|false,"nyquist_validation":[false if granularity=coarse, true otherwise]}}' ``` -**Note:** Run `/gsd:settings` anytime to update model profile, workflow agents, branching strategy, and other preferences. +**Note:** Run `/gsd-settings` anytime to update model profile, workflow agents, branching strategy, and other preferences. **If commit_docs = No:** @@ -1292,7 +1292,7 @@ Present completion summary: ╚══════════════════════════════════════════╝ ``` -Exit skill and invoke SlashCommand("/gsd:discuss-phase 1 --auto") +Exit skill and invoke SlashCommand("/gsd-discuss-phase 1 --auto") **If interactive mode:** @@ -1314,13 +1314,13 @@ PHASE1_HAS_UI=$(echo "$PHASE1_SECTION" | grep -qi "UI hint.*yes" && echo "true" /clear then: -/gsd:discuss-phase 1 — gather context and clarify approach +/gsd-discuss-phase 1 — gather context and clarify approach --- **Also available:** -- /gsd:ui-phase 1 — generate UI design contract (recommended for frontend phases) -- /gsd:plan-phase 1 — skip discussion, plan directly +- /gsd-ui-phase 1 — generate UI design contract (recommended for frontend phases) +- /gsd-plan-phase 1 — skip discussion, plan directly ─────────────────────────────────────────────────────────────── ``` @@ -1336,12 +1336,12 @@ PHASE1_HAS_UI=$(echo "$PHASE1_SECTION" | grep -qi "UI hint.*yes" && echo "true" /clear then: -/gsd:discuss-phase 1 — gather context and clarify approach +/gsd-discuss-phase 1 — gather context and clarify approach --- **Also available:** -- /gsd:plan-phase 1 — skip discussion, plan directly +- /gsd-plan-phase 1 — skip discussion, plan directly ─────────────────────────────────────────────────────────────── ``` @@ -1384,7 +1384,7 @@ PHASE1_HAS_UI=$(echo "$PHASE1_SECTION" | grep -qi "UI hint.*yes" && echo "true" - [ ] STATE.md initialized - [ ] REQUIREMENTS.md traceability updated - [ ] `$INSTRUCTION_FILE` generated with GSD workflow guidance (AGENTS.md for Codex, CLAUDE.md otherwise) -- [ ] User knows next step is `/gsd:discuss-phase 1` +- [ ] User knows next step is `/gsd-discuss-phase 1` **Atomic commits:** Each phase commits its artifacts immediately. If context is lost, artifacts persist. diff --git a/get-shit-done/workflows/new-workspace.md b/get-shit-done/workflows/new-workspace.md index 60ceae3c..4d61d526 100644 --- a/get-shit-done/workflows/new-workspace.md +++ b/get-shit-done/workflows/new-workspace.md @@ -73,7 +73,7 @@ Error: No git repos found in the current directory and this is not a git repo. Run this command from a directory containing git repos, or specify repos explicitly: - /gsd:new-workspace --name my-workspace --repos /path/to/repo1,/path/to/repo2 + /gsd-new-workspace --name my-workspace --repos /path/to/repo1,/path/to/repo2 ``` Exit. @@ -84,7 +84,7 @@ Error: Error: --auto requires --repos to specify which repos to include. Usage: - /gsd:new-workspace --name my-workspace --repos repo1,repo2 --auto + /gsd-new-workspace --name my-workspace --repos repo1,repo2 --auto ``` Exit. @@ -203,7 +203,7 @@ Workspace created: $TARGET_PATH Next steps: cd "$TARGET_PATH" - /gsd:new-project # Initialize GSD in the workspace + /gsd-new-project # Initialize GSD in the workspace ``` **If some repos failed:** @@ -216,7 +216,7 @@ Workspace created with $SUCCESS_COUNT of $TOTAL_COUNT repos: $TARGET_PATH Next steps: cd "$TARGET_PATH" - /gsd:new-project # Initialize GSD in the workspace + /gsd-new-project # Initialize GSD in the workspace ``` **Offer to initialize GSD (if not `--auto`):** @@ -225,7 +225,7 @@ Use AskUserQuestion: - header: "Initialize GSD" - question: "Would you like to initialize a GSD project in the new workspace?" - options: - - "Yes — run /gsd:new-project" → tell user to `cd "$TARGET_PATH"` first, then run `/gsd:new-project` + - "Yes — run /gsd-new-project" → tell user to `cd "$TARGET_PATH"` first, then run `/gsd-new-project` - "No — I'll set it up later" → done diff --git a/get-shit-done/workflows/next.md b/get-shit-done/workflows/next.md index fc665f26..026d5ba6 100644 --- a/get-shit-done/workflows/next.md +++ b/get-shit-done/workflows/next.md @@ -29,7 +29,7 @@ Extract: If no `.planning/` directory exists: ``` -No GSD project detected. Run `/gsd:new-project` to get started. +No GSD project detected. Run `/gsd-new-project` to get started. ``` Exit. @@ -65,7 +65,7 @@ If found: ⛔ Hard stop: Project in error state STATE.md shows status: {status}. Resolve the error before advancing. -Run `/gsd:health` to diagnose, or manually fix STATE.md. +Run `/gsd-health` to diagnose, or manually fix STATE.md. Use `--force` to bypass this check. ``` Exit. @@ -121,7 +121,7 @@ Choice [S]: **Goal:** Resolve plans that ran without producing summaries during Phase {src} execution **Source phase:** {src} -**Deferred at:** {date} during /gsd:next advancement to Phase {dest} +**Deferred at:** {date} during /gsd-next advancement to Phase {dest} **Plans:** - [ ] {N}-{M}: {slug} (ran, no SUMMARY.md) ``` @@ -151,7 +151,7 @@ If either count is > 0, display before routing: {PENDING_SPIKES} spike(s) with unresolved verdicts in .planning/spikes/ {PENDING_SKETCHES} sketch(es) without a winning variant in .planning/sketches/ - Resume with `/gsd:spike` or `/gsd:sketch`, or continue with phase work below. + Resume with `/gsd-spike` or `/gsd-sketch`, or continue with phase work below. ``` Only show lines for non-zero counts. If both are 0, skip this notice entirely. @@ -162,35 +162,35 @@ Apply routing rules based on state: **Route 1: No phases exist yet → discuss** If ROADMAP has phases but no phase directories exist on disk: -→ Next action: `/gsd:discuss-phase ` +→ Next action: `/gsd-discuss-phase ` **Route 2: Phase exists but has no CONTEXT.md or RESEARCH.md → discuss** If the current phase directory exists but has neither CONTEXT.md nor RESEARCH.md: -→ Next action: `/gsd:discuss-phase ` +→ Next action: `/gsd-discuss-phase ` **Route 3: Phase has context but no plans → plan** If the current phase has CONTEXT.md (or RESEARCH.md) but no PLAN.md files: -→ Next action: `/gsd:plan-phase ` +→ Next action: `/gsd-plan-phase ` **Route 4: Phase has plans but incomplete summaries → execute** If plans exist but not all have matching summaries: -→ Next action: `/gsd:execute-phase ` +→ Next action: `/gsd-execute-phase ` **Route 5: All plans have summaries → verify and complete** If all plans in the current phase have summaries: -→ Next action: `/gsd:verify-work` +→ Next action: `/gsd-verify-work` **Route 6: Phase complete, next phase exists → advance** If the current phase is complete and the next phase exists in ROADMAP: -→ Next action: `/gsd:discuss-phase ` +→ Next action: `/gsd-discuss-phase ` **Route 7: All phases complete → complete milestone** If all phases are complete: -→ Next action: `/gsd:complete-milestone` +→ Next action: `/gsd-complete-milestone` **Route 8: Paused → resume** If STATE.md shows paused_at: -→ Next action: `/gsd:resume-work` +→ Next action: `/gsd-resume-work` @@ -207,7 +207,7 @@ Display the determination: ``` Then immediately invoke the determined command via SlashCommand. -Do not ask for confirmation — the whole point of `/gsd:next` is zero-friction advancement. +Do not ask for confirmation — the whole point of `/gsd-next` is zero-friction advancement. diff --git a/get-shit-done/workflows/note.md b/get-shit-done/workflows/note.md index 90a2e1f4..48432417 100644 --- a/get-shit-done/workflows/note.md +++ b/get-shit-done/workflows/note.md @@ -45,7 +45,7 @@ promoted: false | Arguments are empty (no text at all) | **list** | | Anything else | **append** (the text IS the note) | -**Critical**: `list` is only a subcommand when it's the ENTIRE argument. `/gsd:note list of groceries` saves a note with text "list of groceries". Same for `promote` — only a subcommand when followed by exactly one number. +**Critical**: `list` is only a subcommand when it's the ENTIRE argument. `/gsd-note list of groceries` saves a note with text "list of groceries". Same for `promote` — only a subcommand when followed by exactly one number. @@ -89,7 +89,7 @@ Project (.planning/notes/): Global (~/.claude/notes/): 4. [2026-02-08 10:00] cross-project idea about shared config -{count} active note(s). Use `/gsd:note promote ` to convert to a todo. +{count} active note(s). Use `/gsd-note promote ` to convert to a todo. ``` If a scope has no directory or no entries, show: `(no notes)` @@ -101,7 +101,7 @@ If a scope has no directory or no entries, show: `(no notes)` 1. Run the **list** logic to build the numbered index (both scopes) 2. Find entry N from the numbered list 3. If N is invalid or refers to an already-promoted note, tell the user and stop -4. **Requires `.planning/` directory** — if it doesn't exist, warn: "Todos require a GSD project. Run `/gsd:new-project` to initialize one." +4. **Requires `.planning/` directory** — if it doesn't exist, warn: "Todos require a GSD project. Run `/gsd-new-project` to initialize one." 5. Ensure `.planning/todos/pending/` directory exists 6. Generate todo ID: `{NNN}-{slug}` where NNN is the next sequential number (scan both `.planning/todos/pending/` and `.planning/todos/completed/` for the highest existing number, increment by 1, zero-pad to 3 digits) and slug is the first ~4 meaningful words of the note text 7. Extract the note text from the source file (body after frontmatter) @@ -112,7 +112,7 @@ If a scope has no directory or no entries, show: `(no notes)` title: "{note text}" status: pending priority: P2 -source: "promoted from /gsd:note" +source: "promoted from /gsd-note" created: {YYYY-MM-DD} theme: general --- @@ -137,9 +137,9 @@ Promoted from quick note captured on {original date}. -1. **"list" as note text**: `/gsd:note list of things` saves note "list of things" (subcommand only when `list` is the entire arg) +1. **"list" as note text**: `/gsd-note list of things` saves note "list of things" (subcommand only when `list` is the entire arg) 2. **No `.planning/`**: Falls back to global `~/.claude/notes/` — works in any directory -3. **Promote without project**: Warns that todos require `.planning/`, suggests `/gsd:new-project` +3. **Promote without project**: Warns that todos require `.planning/`, suggests `/gsd-new-project` 4. **Large files**: `list` shows last 10 when >20 active entries 5. **Duplicate slugs**: Append `-2`, `-3` etc. to filename if slug already used on same date 6. **`--global` position**: Stripped from anywhere — `--global my idea` and `my idea --global` both save "my idea" globally diff --git a/get-shit-done/workflows/pause-work.md b/get-shit-done/workflows/pause-work.md index 53ffa0d0..f4bb5c7d 100644 --- a/get-shit-done/workflows/pause-work.md +++ b/get-shit-done/workflows/pause-work.md @@ -1,5 +1,5 @@ -Create structured `.planning/HANDOFF.json` and `.continue-here.md` handoff files to preserve complete work state across sessions. The JSON provides machine-readable state for `/gsd:resume-work`; the markdown provides human-readable context. +Create structured `.planning/HANDOFF.json` and `.continue-here.md` handoff files to preserve complete work state across sessions. The JSON provides machine-readable state for `/gsd-resume-work`; the markdown provides human-readable context. @@ -226,7 +226,7 @@ Current state: - Blockers: [count] ({human_actions_pending count} need human action) - Committed as WIP -To resume: /gsd:resume-work +To resume: /gsd-resume-work ``` diff --git a/get-shit-done/workflows/plan-milestone-gaps.md b/get-shit-done/workflows/plan-milestone-gaps.md index 95913aa5..b87feb8d 100644 --- a/get-shit-done/workflows/plan-milestone-gaps.md +++ b/get-shit-done/workflows/plan-milestone-gaps.md @@ -1,5 +1,5 @@ -Create all phases necessary to close gaps identified by `/gsd:audit-milestone`. Reads 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. +Create all phases necessary to close gaps identified by `/gsd-audit-milestone`. Reads 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. @@ -22,7 +22,7 @@ Parse YAML frontmatter to extract structured gaps: If no audit file exists or has no gaps, error: ``` -No audit gaps found. Run `/gsd:audit-milestone` first. +No audit gaps found. Run `/gsd-audit-milestone` first. ``` ## 2. Prioritize Gaps @@ -165,20 +165,20 @@ gsd-sdk query commit "docs(roadmap): add gap closure phases {N}-{M}" .planning/R `/clear` then: -`/gsd:plan-phase {N}` +`/gsd-plan-phase {N}` --- **Also available:** -- `/gsd:execute-phase {N}` — if plans already exist +- `/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 +`/gsd-audit-milestone` — re-audit to verify gaps closed +`/gsd-complete-milestone {version}` — archive when audit passes ``` @@ -269,5 +269,5 @@ becomes: - [ ] Coverage count updated in REQUIREMENTS.md - [ ] Phase directories created - [ ] Changes committed (includes REQUIREMENTS.md) -- [ ] User knows to run `/gsd:plan-phase` next +- [ ] User knows to run `/gsd-plan-phase` next diff --git a/get-shit-done/workflows/plan-phase.md b/get-shit-done/workflows/plan-phase.md index a44e3450..a13ee13f 100644 --- a/get-shit-done/workflows/plan-phase.md +++ b/get-shit-done/workflows/plan-phase.md @@ -50,7 +50,7 @@ Parse JSON for: `researcher_model`, `planner_model`, `checker_model`, `research_ **File paths (for blocks):** `state_path`, `roadmap_path`, `requirements_path`, `context_path`, `research_path`, `verification_path`, `uat_path`, `reviews_path`. These are null if files don't exist. -**If `planning_exists` is false:** Error — run `/gsd:new-project` first. +**If `planning_exists` is false:** Error — run `/gsd-new-project` first. ## 2. Parse and Normalize Arguments @@ -90,9 +90,9 @@ Error: ``` No REVIEWS.md found for Phase {N}. Run reviews first: -/gsd:review --phase {N} +/gsd-review --phase {N} -Then re-run /gsd:plan-phase {N} --reviews +Then re-run /gsd-plan-phase {N} --reviews ``` Exit workflow. @@ -252,9 +252,9 @@ If "Run discuss-phase first": does not work correctly in nested subcontexts (#1009). Instead, display the command and exit so the user runs it as a top-level command: ``` - Run this command first, then re-run /gsd:plan-phase {X} ${GSD_WS}: + Run this command first, then re-run /gsd-plan-phase {X} ${GSD_WS}: - /gsd:discuss-phase {X} ${GSD_WS} + /gsd-discuss-phase {X} ${GSD_WS} ``` **Exit the plan-phase workflow. Do not continue.** @@ -277,19 +277,19 @@ echo "${phase_goal}" | grep -qi "agent\|llm\|rag\|chatbot\|embedding\|langchain\ **If AI keywords detected AND no AI-SPEC.md:** ``` ◆ Note: This phase appears to involve AI system development. - Consider running /gsd:ai-integration-phase {N} before planning to: + Consider running /gsd-ai-integration-phase {N} before planning to: - Select the right framework for your use case - Research its docs and best practices - Design an evaluation strategy - Continue planning without AI-SPEC? (non-blocking — /gsd:ai-integration-phase can be run after) + Continue planning without AI-SPEC? (non-blocking — /gsd-ai-integration-phase can be run after) ``` Use AskUserQuestion with options: - "Continue — plan without AI-SPEC" -- "Stop — I'll run /gsd:ai-integration-phase {N} first" +- "Stop — I'll run /gsd-ai-integration-phase {N} first" -If "Stop": Exit with `/gsd:ai-integration-phase {N}` reminder. +If "Stop": Exit with `/gsd-ai-integration-phase {N}` reminder. If "Continue": Proceed. (Non-blocking — planner will note AI-SPEC is absent.) **If `AI_SPEC_FILE` is non-empty:** Extract framework for planner context: @@ -362,7 +362,7 @@ Answer: "What do I need to know to PLAN this phase well?" -- {context_path} (USER DECISIONS from /gsd:discuss-phase) +- {context_path} (USER DECISIONS from /gsd-discuss-phase) - {requirements_path} (Project requirements) - {state_path} (Project decisions and history) @@ -509,10 +509,10 @@ Output this markdown directly (not as a code block): ``` ## ⚠ UI-SPEC.md missing for Phase {N} ▶ Recommended next step: -`/gsd:ui-phase {N} ${GSD_WS}` — generate UI design contract before planning +`/gsd-ui-phase {N} ${GSD_WS}` — generate UI design contract before planning ─────────────────────────────────────────────── Also available: -- `/gsd:plan-phase {N} --skip-ui ${GSD_WS}` — plan without UI-SPEC (not recommended for frontend phases) +- `/gsd-plan-phase {N} --skip-ui ${GSD_WS}` — plan without UI-SPEC (not recommended for frontend phases) ``` **Exit the plan-phase workflow. Do not continue.** @@ -628,7 +628,7 @@ VALIDATION_EXISTS=$(ls "${PHASE_DIR}"/*-VALIDATION.md 2>/dev/null | head -1) ``` If missing and Nyquist is still enabled/applicable — ask user: -1. Re-run: `/gsd:plan-phase {PHASE} --research ${GSD_WS}` +1. Re-run: `/gsd-plan-phase {PHASE} --research ${GSD_WS}` 2. Disable Nyquist with the exact command: `gsd-sdk query config-set workflow.nyquist_validation false` 3. Continue anyway (plans fail Dimension 8) @@ -666,7 +666,7 @@ Pattern mapper prompt: **Padded phase:** {padded_phase} -- {context_path} (USER DECISIONS from /gsd:discuss-phase) +- {context_path} (USER DECISIONS from /gsd-discuss-phase) - {research_path} (Technical Research) @@ -716,7 +716,7 @@ Planner prompt: - {state_path} (Project State) - {roadmap_path} (Roadmap) - {requirements_path} (Requirements) -- {context_path} (USER DECISIONS from /gsd:discuss-phase) +- {context_path} (USER DECISIONS from /gsd-discuss-phase) - {research_path} (Technical Research) - {PATTERNS_PATH} (Pattern Map — analog files and code excerpts, if exists) - {verification_path} (Verification Gaps - if --gaps) @@ -755,7 +755,7 @@ Each TDD plan gets one feature with RED/GREEN/REFACTOR gate sequence. -Output consumed by /gsd:execute-phase. Plans need: +Output consumed by /gsd-execute-phase. Plans need: - Frontmatter (wave, depends_on, files_modified, autonomous) - Tasks in XML format with read_first and acceptance_criteria fields (MANDATORY on every task) - Verification criteria @@ -824,10 +824,10 @@ Task( Chunked mode splits the single long-lived planner Task into a short outline Task followed by N short per-plan Tasks. Each Task is bounded to ~3–5 min; each plan is committed individually for crash resilience. If any Task hangs and the terminal is force-killed, rerunning -`/gsd:plan-phase {N} --chunked` resumes from the last successfully committed plan. +`/gsd-plan-phase {N} --chunked` resumes from the last successfully committed plan. **Intended for new or in-progress chunked runs.** To recover plans already written by a prior -*non-chunked* run, use step 6's "Add more plans" or proceed directly to `/gsd:execute-phase` +*non-chunked* run, use step 6's "Add more plans" or proceed directly to `/gsd-execute-phase` — don't start a fresh chunked run over existing non-chunked plans. ### 8.5.1 Outline Phase (outline-only mode, ~2 min) @@ -953,7 +953,7 @@ arrived). Display: Offer 3 options: 1. **Accept plans** — treat as `## PLANNING COMPLETE` and continue through step 9 `## PLANNING COMPLETE` handling (so `--skip-verify` / `plan_checker_enabled=false` are honored — may skip to step 13 rather than step 10) 2. **Retry planner** — re-spawn the planner with the same prompt (return to step 8) -3. **Stop** — exit; user can re-run `/gsd:plan-phase {N}` to resume +3. **Stop** — exit; user can re-run `/gsd-plan-phase {N}` to resume **If `DISK_PLANS` is 0 and no marker:** The planner produced no output. Treat as `## PLANNING INCONCLUSIVE` and handle accordingly. @@ -986,7 +986,7 @@ rest become a follow-up phase Use AskUserQuestion with these 3 options. -**If "Split":** Use `/gsd:insert-phase` to create the sub-phases, then replan each. +**If "Split":** Use `/gsd-insert-phase` to create the sub-phases, then replan each. **If "Proceed":** Return to planner with instruction to attempt all items at full fidelity, accepting more plans/tasks. **If "Prioritize":** Use AskUserQuestion (multiSelect) to let user pick which items are "now" vs "later". Create CONTEXT.md for each sub-phase with the selected items. @@ -1015,7 +1015,7 @@ Options: Use AskUserQuestion for each gap (or batch if multiple gaps). **If "Add plan":** Return to planner (step 8) with instruction to add plans covering the missing items, preserving existing plans. -**If "Split":** Use `/gsd:insert-phase` for overflow items, then replan. +**If "Split":** Use `/gsd-insert-phase` for overflow items, then replan. **If "Defer":** Record in CONTEXT.md `## Deferred Ideas` with developer's confirmation. Proceed to step 10. ## 10. Spawn gsd-plan-checker Agent @@ -1040,7 +1040,7 @@ Checker prompt: - {PHASE_DIR}/*-PLAN.md (Plans to verify) - {roadmap_path} (Roadmap) - {requirements_path} (Requirements) -- {context_path} (USER DECISIONS from /gsd:discuss-phase) +- {context_path} (USER DECISIONS from /gsd-discuss-phase) - {research_path} (Technical Research — includes Validation Architecture) @@ -1111,7 +1111,7 @@ Windows stdio hang pattern — the subagent finished but the return never arrive Offer 3 options: 1. **Accept verification** — treat as `## VERIFICATION PASSED` and continue to step 13 2. **Retry checker** — re-spawn the checker with the same prompt (return to step 10) -3. **Stop** — exit; user can re-run `/gsd:plan-phase {N}` to resume +3. **Stop** — exit; user can re-run `/gsd-plan-phase {N}` to resume **If `DISK_PLANS` is 0:** No plans on disk — something is seriously wrong. Display error and stop. @@ -1140,7 +1140,7 @@ Display: `Revision iteration {N}/3 -- {blocker_count} blockers, {warning_count} **If `stall_reentry_count >= 2`:** Display: `Stall persists after 2 re-planning attempts. The following issues could not be resolved automatically:` List the remaining issues from the checker. - Suggest: "Consider resolving these issues manually or running `/gsd:debug` to investigate root causes." + Suggest: "Consider resolving these issues manually or running `/gsd-debug` to investigate root causes." Options: "Proceed anyway" | "Abandon" If "Proceed anyway": accept current plans and continue to step 13. If "Abandon": stop workflow. @@ -1156,7 +1156,7 @@ Revision prompt: - {PHASE_DIR}/*-PLAN.md (Existing plans) -- {context_path} (USER DECISIONS from /gsd:discuss-phase) +- {context_path} (USER DECISIONS from /gsd-discuss-phase) ${AGENT_SKILLS_PLANNER} @@ -1455,7 +1455,7 @@ sort within source):** - Both missing or `` block missing → "No requirements or decisions to check" line, no error. This step is non-blocking. If items are reported as not covered, the user may -re-run `/gsd:plan-phase --gaps` to add plans, or proceed to execute-phase as-is. +re-run `/gsd-plan-phase --gaps` to add plans, or proceed to execute-phase as-is. ## 14. Present Final Status @@ -1512,14 +1512,14 @@ The `--no-transition` flag tells execute-phase to return status after verificati Auto-advance pipeline finished. - Next: /gsd:discuss-phase ${NEXT_PHASE} --auto ${GSD_WS} + Next: /gsd-discuss-phase ${NEXT_PHASE} --auto ${GSD_WS} ``` - **GAPS FOUND / VERIFICATION FAILED** → Display result, stop chain: ``` Auto-advance stopped: Execution needs review. Review the output above and continue manually: - /gsd:execute-phase ${PHASE} ${GSD_WS} + /gsd-execute-phase ${PHASE} ${GSD_WS} ``` **If neither `--auto` nor config enabled:** @@ -1552,15 +1552,15 @@ Verification: {Passed | Passed with override | Skipped} /clear then: -/gsd:execute-phase {X} ${GSD_WS} +/gsd-execute-phase {X} ${GSD_WS} ─────────────────────────────────────────────────────────────── **Also available:** - cat .planning/phases/{phase-dir}/*-PLAN.md — review plans -- /gsd:plan-phase {X} --research — re-research first -- /gsd:review --phase {X} --all — peer review plans with external AIs -- /gsd:plan-phase {X} --reviews — replan incorporating review feedback +- /gsd-plan-phase {X} --research — re-research first +- /gsd-review --phase {X} --all — peer review plans with external AIs +- /gsd-plan-phase {X} --reviews — replan incorporating review feedback ─────────────────────────────────────────────────────────────── @@ -1581,11 +1581,11 @@ stdio deadlocks with MCP servers — see Claude Code issue anthropics/claude-cod Remove-Item -Recurse -Force "$env:USERPROFILE\.claude\tasks\*" -ErrorAction SilentlyContinue ``` 4. **Reduce MCP server count:** Temporarily disable non-essential MCP servers in settings.json -5. **Retry:** Restart Claude Code and run `/gsd:plan-phase` again +5. **Retry:** Restart Claude Code and run `/gsd-plan-phase` again If freezes persist, try `--skip-research` to reduce the agent chain from 3 to 2 agents: ``` -/gsd:plan-phase N --skip-research +/gsd-plan-phase N --skip-research ``` diff --git a/get-shit-done/workflows/plan-review-convergence.md b/get-shit-done/workflows/plan-review-convergence.md index e5931915..f02f2cd5 100644 --- a/get-shit-done/workflows/plan-review-convergence.md +++ b/get-shit-done/workflows/plan-review-convergence.md @@ -80,7 +80,7 @@ Display: `◆ No plans found — spawning initial planning agent...` ```text Agent( description="Initial planning Phase {PHASE}", - prompt="Run /gsd:plan-phase for Phase {PHASE}. + prompt="Run /gsd-plan-phase for Phase {PHASE}. Execute: Skill(skill='gsd-plan-phase', args='{PHASE} {GSD_WS}') @@ -116,7 +116,7 @@ Display: `◆ Cycle {cycle}/{MAX_CYCLES} — spawning review agent...` ```text Agent( description="Cross-AI review Phase {PHASE} cycle {cycle}", - prompt="Run /gsd:review for Phase {PHASE}. + prompt="Run /gsd-review for Phase {PHASE}. Execute: Skill(skill='gsd-review', args='--phase {PHASE} {REVIEWER_FLAGS} {GSD_WS}') @@ -156,7 +156,7 @@ Display: No HIGH concerns remaining. REVIEWS.md: {REVIEWS_FILE} - Next: /gsd:execute-phase {PHASE} + Next: /gsd-execute-phase {PHASE} ``` Exit — convergence achieved. @@ -210,8 +210,8 @@ If "Manual review": ```text Review the concerns in: {REVIEWS_FILE} -To replan manually: /gsd:plan-phase {PHASE} --reviews -To restart loop: /gsd:plan-review-convergence {PHASE} {REVIEWER_FLAGS} +To replan manually: /gsd-plan-phase {PHASE} --reviews +To restart loop: /gsd-plan-review-convergence {PHASE} {REVIEWER_FLAGS} ``` Exit workflow. @@ -226,7 +226,7 @@ Display: `◆ Spawning replan agent with review feedback...` ```text Agent( description="Replan Phase {PHASE} with review feedback cycle {cycle}", - prompt="Run /gsd:plan-phase with --reviews for Phase {PHASE}. + prompt="Run /gsd-plan-phase with --reviews for Phase {PHASE}. Execute: Skill(skill='gsd-plan-phase', args='{PHASE} --reviews --skip-research {GSD_WS}') diff --git a/get-shit-done/workflows/plant-seed.md b/get-shit-done/workflows/plant-seed.md index abba5776..85c463f3 100644 --- a/get-shit-done/workflows/plant-seed.md +++ b/get-shit-done/workflows/plant-seed.md @@ -1,6 +1,6 @@ Capture a forward-looking idea as a structured seed file with trigger conditions. -Seeds auto-surface during /gsd:new-milestone when trigger conditions match the +Seeds auto-surface during /gsd-new-milestone when trigger conditions match the new milestone's scope. Seeds beat deferred items because they: @@ -120,7 +120,7 @@ scope: {$SCOPE} **Trigger:** {$TRIGGER} -This seed should be presented during `/gsd:new-milestone` when the milestone +This seed should be presented during `/gsd-new-milestone` when the milestone scope matches any of these conditions: - {trigger condition 1} - {trigger condition 2} @@ -156,7 +156,7 @@ Trigger: {$TRIGGER} Scope: {$SCOPE} File: .planning/seeds/SEED-{PADDED}-{slug}.md -This seed will surface automatically when you run /gsd:new-milestone +This seed will surface automatically when you run /gsd-new-milestone and the milestone scope matches the trigger condition. ``` diff --git a/get-shit-done/workflows/pr-branch.md b/get-shit-done/workflows/pr-branch.md index e8582d32..9bf74d52 100644 --- a/get-shit-done/workflows/pr-branch.md +++ b/get-shit-done/workflows/pr-branch.md @@ -142,7 +142,7 @@ Next steps: git push origin {PR_BRANCH} gh pr create --base {TARGET} --head {PR_BRANCH} -Or use /gsd:ship to create the PR automatically. +Or use /gsd-ship to create the PR automatically. ``` diff --git a/get-shit-done/workflows/profile-user.md b/get-shit-done/workflows/profile-user.md index a27dcf59..b0c1f946 100644 --- a/get-shit-done/workflows/profile-user.md +++ b/get-shit-done/workflows/profile-user.md @@ -120,7 +120,7 @@ Use AskUserQuestion: - options: - "Let's go" -- Proceed to step 3 (session analysis) - "Use questionnaire instead" -- Jump to step 4b (questionnaire path) - - "Not now" -- Display "No worries. Run /gsd:profile-user when ready." and exit + - "Not now" -- Display "No worries. Run /gsd-profile-user when ready." and exit --- diff --git a/get-shit-done/workflows/progress.md b/get-shit-done/workflows/progress.md index b49a9941..3522c0b3 100644 --- a/get-shit-done/workflows/progress.md +++ b/get-shit-done/workflows/progress.md @@ -27,18 +27,18 @@ If `project_exists` is false (no `.planning/` directory): ``` No planning structure found. -Run /gsd:new-project to start a new project. +Run /gsd-new-project to start a new project. ``` Exit. -If missing STATE.md: suggest `/gsd:new-project`. +If missing STATE.md: suggest `/gsd-new-project`. **If ROADMAP.md missing but PROJECT.md exists:** This means a milestone was completed and archived. Go to **Route F** (between milestones). -If missing both ROADMAP.md and PROJECT.md: suggest `/gsd:new-project`. +If missing both ROADMAP.md and PROJECT.md: suggest `/gsd-new-project`. @@ -123,10 +123,10 @@ CONTEXT: [✓ if has_context | - if not] - [e.g. jq -r '.blockers[].text' from state-snapshot] ## Pending Todos -- [count] pending — /gsd:check-todos to review +- [count] pending — /gsd-check-todos to review ## Active Debug Sessions -- [count] active — /gsd:debug to continue +- [count] active — /gsd-debug to continue (Only show this section if count > 0) ## What's Next @@ -185,8 +185,8 @@ Track: `outstanding_debt` — `summary.total_items` from the audit. | {phase} | {filename} | {pending_count} pending, {skipped_count} skipped, {blocked_count} blocked | | {phase} | {filename} | human_needed — {count} items | -Review: `/gsd:audit-uat ${GSD_WS}` — full cross-phase audit -Resume testing: `/gsd:verify-work {phase} ${GSD_WS}` — retest specific phase +Review: `/gsd-audit-uat ${GSD_WS}` — full cross-phase audit +Resume testing: `/gsd-verify-work {phase} ${GSD_WS}` — retest specific phase ``` This is a WARNING, not a blocker — routing proceeds normally. The debt is visible so the user can make an informed choice. @@ -217,7 +217,7 @@ Read its `` section. `/clear` then: -`/gsd:execute-phase {phase} ${GSD_WS}` +`/gsd-execute-phase {phase} ${GSD_WS}` --- ``` @@ -247,7 +247,7 @@ PHASE_HAS_UI=$(echo "$PHASE_SECTION" | grep -qi "UI hint.*yes" && echo "true" || `/clear` then: -`/gsd:plan-phase {phase-number} ${GSD_WS}` +`/gsd-plan-phase {phase-number} ${GSD_WS}` --- ``` @@ -263,14 +263,14 @@ PHASE_HAS_UI=$(echo "$PHASE_SECTION" | grep -qi "UI hint.*yes" && echo "true" || `/clear` then: -`/gsd:discuss-phase {phase}` — gather context and clarify approach +`/gsd-discuss-phase {phase}` — gather context and clarify approach --- **Also available:** -- `/gsd:ui-phase {phase}` — generate UI design contract (recommended for frontend phases) -- `/gsd:plan-phase {phase}` — skip discussion, plan directly -- `/gsd:list-phase-assumptions {phase}` — see Claude's assumptions +- `/gsd-ui-phase {phase}` — generate UI design contract (recommended for frontend phases) +- `/gsd-plan-phase {phase}` — skip discussion, plan directly +- `/gsd-list-phase-assumptions {phase}` — see Claude's assumptions --- ``` @@ -286,13 +286,13 @@ PHASE_HAS_UI=$(echo "$PHASE_SECTION" | grep -qi "UI hint.*yes" && echo "true" || `/clear` then: -`/gsd:discuss-phase {phase} ${GSD_WS}` — gather context and clarify approach +`/gsd-discuss-phase {phase} ${GSD_WS}` — gather context and clarify approach --- **Also available:** -- `/gsd:plan-phase {phase} ${GSD_WS}` — skip discussion, plan directly -- `/gsd:list-phase-assumptions {phase} ${GSD_WS}` — see Claude's assumptions +- `/gsd-plan-phase {phase} ${GSD_WS}` — skip discussion, plan directly +- `/gsd-list-phase-assumptions {phase} ${GSD_WS}` — see Claude's assumptions --- ``` @@ -312,13 +312,13 @@ UAT.md exists with gaps (diagnosed issues). User needs to plan fixes. `/clear` then: -`/gsd:plan-phase {phase} --gaps ${GSD_WS}` +`/gsd-plan-phase {phase} --gaps ${GSD_WS}` --- **Also available:** -- `/gsd:execute-phase {phase} ${GSD_WS}` — execute phase plans -- `/gsd:verify-work {phase} ${GSD_WS}` — run more UAT testing +- `/gsd-execute-phase {phase} ${GSD_WS}` — execute phase plans +- `/gsd-verify-work {phase} ${GSD_WS}` — run more UAT testing --- ``` @@ -338,13 +338,13 @@ UAT.md exists with `status: partial` — testing session ended before all items `/clear` then: -`/gsd:verify-work {phase} ${GSD_WS}` — resume testing from where you left off +`/gsd-verify-work {phase} ${GSD_WS}` — resume testing from where you left off --- **Also available:** -- `/gsd:audit-uat ${GSD_WS}` — full cross-phase UAT audit -- `/gsd:execute-phase {phase} ${GSD_WS}` — execute phase plans +- `/gsd-audit-uat ${GSD_WS}` — full cross-phase UAT audit +- `/gsd-execute-phase {phase} ${GSD_WS}` — execute phase plans --- ``` @@ -394,14 +394,14 @@ NEXT_HAS_UI=$(echo "$NEXT_PHASE_SECTION" | grep -qi "UI hint.*yes" && echo "true `/clear` then: -`/gsd:discuss-phase {Z+1}` — gather context and clarify approach +`/gsd-discuss-phase {Z+1}` — gather context and clarify approach --- **Also available:** -- `/gsd:ui-phase {Z+1}` — generate UI design contract (recommended for frontend phases) -- `/gsd:plan-phase {Z+1}` — skip discussion, plan directly -- `/gsd:verify-work {Z}` — user acceptance test before continuing +- `/gsd-ui-phase {Z+1}` — generate UI design contract (recommended for frontend phases) +- `/gsd-plan-phase {Z+1}` — skip discussion, plan directly +- `/gsd-verify-work {Z}` — user acceptance test before continuing --- ``` @@ -419,13 +419,13 @@ NEXT_HAS_UI=$(echo "$NEXT_PHASE_SECTION" | grep -qi "UI hint.*yes" && echo "true `/clear` then: -`/gsd:discuss-phase {Z+1} ${GSD_WS}` — gather context and clarify approach +`/gsd-discuss-phase {Z+1} ${GSD_WS}` — gather context and clarify approach --- **Also available:** -- `/gsd:plan-phase {Z+1} ${GSD_WS}` — skip discussion, plan directly -- `/gsd:verify-work {Z} ${GSD_WS}` — user acceptance test before continuing +- `/gsd-plan-phase {Z+1} ${GSD_WS}` — skip discussion, plan directly +- `/gsd-verify-work {Z} ${GSD_WS}` — user acceptance test before continuing --- ``` @@ -447,12 +447,12 @@ All {N} phases finished! `/clear` then: -`/gsd:complete-milestone ${GSD_WS}` +`/gsd-complete-milestone ${GSD_WS}` --- **Also available:** -- `/gsd:verify-work ${GSD_WS}` — user acceptance test before completing milestone +- `/gsd-verify-work ${GSD_WS}` — user acceptance test before completing milestone --- ``` @@ -478,7 +478,7 @@ Ready to plan the next milestone. `/clear` then: -`/gsd:new-milestone ${GSD_WS}` +`/gsd-new-milestone ${GSD_WS}` --- ``` @@ -488,10 +488,10 @@ Ready to plan the next milestone. **Handle edge cases:** -- Phase complete but next phase not planned → offer `/gsd:plan-phase [next] ${GSD_WS}` +- Phase complete but next phase not planned → offer `/gsd-plan-phase [next] ${GSD_WS}` - All work complete → offer milestone completion - Blockers present → highlight before offering to continue -- Handoff file exists → mention it, offer `/gsd:resume-work ${GSD_WS}` +- Handoff file exists → mention it, offer `/gsd-resume-work ${GSD_WS}` @@ -598,12 +598,12 @@ Review the flagged items above before acting on the routing suggestion. ``` Then for each failed check, add a concrete next action: -- Check 2 (orphaned handoff): `Read the handoff file(s) and resume from where work was paused: /gsd:resume-work ${GSD_WS}` +- Check 2 (orphaned handoff): `Read the handoff file(s) and resume from where work was paused: /gsd-resume-work ${GSD_WS}` - Check 3 (deferred scope): `Add the missing phases to ROADMAP.md or update the deferred references` - Check 4 (memory pending): `Review the flagged memory entries and resolve or clear them` - Check 5 (blocking todos): `Complete the operational steps in .planning/todos/pending/ before continuing` - Check 6 (uncommitted code): `Commit or stash the uncommitted changes before advancing` -- Check 1 (STATE inconsistency): `Run /gsd:verify-work ${PHASE} ${GSD_WS} to reconcile state` +- Check 1 (STATE inconsistency): `Run /gsd-verify-work ${PHASE} ${GSD_WS} to reconcile state` @@ -613,7 +613,7 @@ Then for each failed check, add a concrete next action: - [ ] Rich context provided (recent work, decisions, issues) - [ ] Current position clear with visual progress - [ ] What's next clearly explained -- [ ] Smart routing: /gsd:execute-phase if plans exist, /gsd:plan-phase if not +- [ ] Smart routing: /gsd-execute-phase if plans exist, /gsd-plan-phase if not - [ ] User confirms before any action - [ ] Seamless handoff to appropriate gsd command diff --git a/get-shit-done/workflows/quick.md b/get-shit-done/workflows/quick.md index c503ceac..ab205c6a 100644 --- a/get-shit-done/workflows/quick.md +++ b/get-shit-done/workflows/quick.md @@ -126,13 +126,13 @@ If `$VALIDATE_MODE` only: ```bash if ! command -v gsd-sdk &>/dev/null; then - echo "⚠ gsd-sdk not found in PATH — /gsd:quick requires it." + echo "⚠ gsd-sdk not found in PATH — /gsd-quick requires it." echo "" echo "Install the GSD SDK:" echo " npm install -g @gsd-build/sdk" echo "" echo "Or update GSD to get the latest packages:" - echo " /gsd:update" + echo " /gsd-update" exit 1 fi ``` @@ -161,7 +161,7 @@ if [ -f .gitmodules ]; then fi ``` -**If `roadmap_exists` is false:** Error — Quick mode requires an active project with ROADMAP.md. Run `/gsd:new-project` first. +**If `roadmap_exists` is false:** Error — Quick mode requires an active project with ROADMAP.md. Run `/gsd-new-project` first. Quick tasks can run mid-phase - validation only checks ROADMAP.md exists, not phase status. @@ -930,7 +930,7 @@ Commit: ${commit_hash} --- -Ready for next task: /gsd:quick ${GSD_WS} +Ready for next task: /gsd-quick ${GSD_WS} ``` **If NOT `$VALIDATE_MODE`:** @@ -947,7 +947,7 @@ Commit: ${commit_hash} --- -Ready for next task: /gsd:quick ${GSD_WS} +Ready for next task: /gsd-quick ${GSD_WS} ``` diff --git a/get-shit-done/workflows/remove-phase.md b/get-shit-done/workflows/remove-phase.md index ff49f2c0..0da80414 100644 --- a/get-shit-done/workflows/remove-phase.md +++ b/get-shit-done/workflows/remove-phase.md @@ -11,15 +11,15 @@ Read all files referenced by the invoking prompt's execution_context before star Parse the command arguments: - Argument is the phase number to remove (integer or decimal) -- Example: `/gsd:remove-phase 17` → phase = 17 -- Example: `/gsd:remove-phase 16.1` → phase = 16.1 +- Example: `/gsd-remove-phase 17` → phase = 17 +- Example: `/gsd-remove-phase 16.1` → phase = 16.1 If no argument provided: ``` ERROR: Phase number required -Usage: /gsd:remove-phase -Example: /gsd:remove-phase 17 +Usage: /gsd-remove-phase +Example: /gsd-remove-phase 17 ``` Exit. @@ -53,7 +53,7 @@ Only future phases can be removed: - Current phase: {current} - Phase {target} is current or completed -To abandon current work, use /gsd:pause-work instead. +To abandon current work, use /gsd-pause-work instead. ``` Exit. @@ -126,7 +126,7 @@ Changes: ## What's Next Would you like to: -- `/gsd:progress` — see updated roadmap status +- `/gsd-progress` — see updated roadmap status - Continue with current phase - Review roadmap diff --git a/get-shit-done/workflows/remove-workspace.md b/get-shit-done/workflows/remove-workspace.md index 001a3369..98b189ea 100644 --- a/get-shit-done/workflows/remove-workspace.md +++ b/get-shit-done/workflows/remove-workspace.md @@ -21,7 +21,7 @@ Parse JSON for: `workspace_name`, `workspace_path`, `has_manifest`, `strategy`, **If no workspace name provided:** -First run `/gsd:list-workspaces` to show available workspaces, then ask: +First run `/gsd-list-workspaces` to show available workspaces, then ask: **Text mode (`workflow.text_mode: true` in config or `--text` flag):** Set `TEXT_MODE=true` if `--text` is present in `$ARGUMENTS` OR `text_mode` from init JSON is `true`. When TEXT_MODE is active, replace every `AskUserQuestion` call with a plain-text numbered list and ask the user to type their choice number. This is required for non-Claude runtimes (OpenAI Codex, Gemini CLI, etc.) where `AskUserQuestion` is not available. diff --git a/get-shit-done/workflows/research-phase.md b/get-shit-done/workflows/research-phase.md index c53dd15e..823a3d0a 100644 --- a/get-shit-done/workflows/research-phase.md +++ b/get-shit-done/workflows/research-phase.md @@ -1,7 +1,7 @@ Research how to implement a phase. Spawns gsd-phase-researcher with phase context. -Standalone research command. For most workflows, use `/gsd:plan-phase` which integrates research automatically. +Standalone research command. For most workflows, use `/gsd-plan-phase` which integrates research automatically. @@ -54,7 +54,7 @@ Research implementation approach for Phase {phase}: {name} -- {context_path} (USER DECISIONS from /gsd:discuss-phase) +- {context_path} (USER DECISIONS from /gsd-discuss-phase) - {requirements_path} (Project requirements) - {state_path} (Project decisions and history) diff --git a/get-shit-done/workflows/resume-project.md b/get-shit-done/workflows/resume-project.md index bb0c2fcd..95ddc331 100644 --- a/get-shit-done/workflows/resume-project.md +++ b/get-shit-done/workflows/resume-project.md @@ -28,7 +28,7 @@ Parse JSON for: `state_exists`, `roadmap_exists`, `project_exists`, `planning_ex **If `state_exists` is true:** Proceed to load_state **If `state_exists` is false but `roadmap_exists` or `project_exists` is true:** Offer to reconstruct STATE.md -**If `planning_exists` is false:** This is a new project - route to /gsd:new-project +**If `planning_exists` is false:** This is a new project - route to /gsd-new-project @@ -84,7 +84,7 @@ fi **If HANDOFF.json exists:** -- This is the primary resumption source — structured data from `/gsd:pause-work` +- This is the primary resumption source — structured data from `/gsd-pause-work` - Parse `status`, `phase`, `plan`, `task`, `total_tasks`, `next_action` - Check `blockers` and `human_actions_pending` — surface these immediately - Check `completed_tasks` for `in_progress` items — these need attention first @@ -140,7 +140,7 @@ Present complete project status to user: Resume with: Task tool (resume parameter with agent ID) [If pending todos exist:] -📋 [N] pending todos — /gsd:check-todos to review +📋 [N] pending todos — /gsd-check-todos to review [If blockers exist:] ⚠️ Carried concerns: @@ -200,11 +200,11 @@ What would you like to do? [Primary action based on state - e.g.:] 1. Resume interrupted agent [if interrupted agent found] OR -1. Execute phase (/gsd:execute-phase {phase} ${GSD_WS}) +1. Execute phase (/gsd-execute-phase {phase} ${GSD_WS}) OR -1. Discuss Phase 3 context (/gsd:discuss-phase 3 ${GSD_WS}) [if CONTEXT.md missing] +1. Discuss Phase 3 context (/gsd-discuss-phase 3 ${GSD_WS}) [if CONTEXT.md missing] OR -1. Plan Phase 3 (/gsd:plan-phase 3 ${GSD_WS}) [if CONTEXT.md exists or discuss option declined] +1. Plan Phase 3 (/gsd-plan-phase 3 ${GSD_WS}) [if CONTEXT.md exists or discuss option declined] [Secondary options:] 2. Review current phase status @@ -237,7 +237,7 @@ Based on user selection, route to appropriate workflow: `/clear` then: - `/gsd:execute-phase {phase} ${GSD_WS}` + `/gsd-execute-phase {phase} ${GSD_WS}` --- ``` @@ -251,13 +251,13 @@ Based on user selection, route to appropriate workflow: `/clear` then: - `/gsd:plan-phase [phase-number] ${GSD_WS}` + `/gsd-plan-phase [phase-number] ${GSD_WS}` --- **Also available:** - - `/gsd:discuss-phase [N] ${GSD_WS}` — gather context first - - `/gsd:research-phase [N] ${GSD_WS}` — investigate unknowns + - `/gsd-discuss-phase [N] ${GSD_WS}` — gather context first + - `/gsd-research-phase [N] ${GSD_WS}` — investigate unknowns --- ``` diff --git a/get-shit-done/workflows/review.md b/get-shit-done/workflows/review.md index 60530682..d9c9911d 100644 --- a/get-shit-done/workflows/review.md +++ b/get-shit-done/workflows/review.md @@ -45,7 +45,7 @@ No external AI CLIs found. Install at least one: - qwen: https://github.com/nicepkg/qwen-code (Alibaba Qwen models) - cursor: https://cursor.com (Cursor IDE agent mode) -Then run /gsd:review again. +Then run /gsd-review again. ``` Exit. @@ -327,7 +327,7 @@ Consensus concerns: Full review: {padded_phase}-REVIEWS.md To incorporate feedback into planning: - /gsd:plan-phase {N} --reviews + /gsd-plan-phase {N} --reviews ``` Clean up temp files. @@ -340,5 +340,5 @@ Clean up temp files. - [ ] REVIEWS.md written with structured feedback - [ ] Consensus summary synthesized from multiple reviewers - [ ] Temp files cleaned up -- [ ] User knows how to use feedback (/gsd:plan-phase --reviews) +- [ ] User knows how to use feedback (/gsd-plan-phase --reviews) diff --git a/get-shit-done/workflows/scan.md b/get-shit-done/workflows/scan.md index cb402499..0d32765b 100644 --- a/get-shit-done/workflows/scan.md +++ b/get-shit-done/workflows/scan.md @@ -88,7 +88,7 @@ Task( **Documents produced:** {list of documents written with line counts} -Use `/gsd:map-codebase` for a comprehensive 4-area parallel scan. +Use `/gsd-map-codebase` for a comprehensive 4-area parallel scan. ``` diff --git a/get-shit-done/workflows/secure-phase.md b/get-shit-done/workflows/secure-phase.md index f75f839f..805f1856 100644 --- a/get-shit-done/workflows/secure-phase.md +++ b/get-shit-done/workflows/secure-phase.md @@ -28,7 +28,7 @@ AUDITOR_MODEL=$(gsd-sdk query resolve-model gsd-security-auditor --raw) SECURITY_CFG=$(gsd-sdk query config-get workflow.security_enforcement --raw 2>/dev/null || echo "true") ``` -If `SECURITY_CFG` is `false`: exit with "Security enforcement disabled. Enable via /gsd:settings." +If `SECURITY_CFG` is `false`: exit with "Security enforcement disabled. Enable via /gsd-settings." Display banner: `GSD > SECURE PHASE {N}: {name}` @@ -42,7 +42,7 @@ SUMMARY_FILES=$(ls "${PHASE_DIR}"/*-SUMMARY.md 2>/dev/null) - **State A** (`SECURITY_FILE` non-empty): Audit existing - **State B** (`SECURITY_FILE` empty, `PLAN_FILES` and `SUMMARY_FILES` non-empty): Run from artifacts -- **State C** (`SUMMARY_FILES` empty): Exit — "Phase {N} not executed. Run /gsd:execute-phase {N} first." +- **State C** (`SUMMARY_FILES` empty): Exit — "Phase {N} not executed. Run /gsd-execute-phase {N} first." ## 2. Discovery @@ -125,7 +125,7 @@ Handle return: ``` GSD > PHASE {N} SECURITY BLOCKED {K} threats open — phase advancement blocked until threats_open: 0 -▶ Fix mitigations then re-run: /gsd:secure-phase {N} +▶ Fix mitigations then re-run: /gsd-secure-phase {N} ▶ Or document accepted risks in SECURITY.md and re-run. ``` @@ -143,8 +143,8 @@ gsd-sdk query commit "docs(phase-${PHASE}): add/update security threat verificat ``` GSD > PHASE {N} THREAT-SECURE threats_open: 0 — all threats have dispositions. -▶ /gsd:validate-phase {N} validate test coverage -▶ /gsd:verify-work {N} run UAT +▶ /gsd-validate-phase {N} validate test coverage +▶ /gsd-verify-work {N} run UAT ``` Display `/clear` reminder. diff --git a/get-shit-done/workflows/session-report.md b/get-shit-done/workflows/session-report.md index f336edc0..29d6d772 100644 --- a/get-shit-done/workflows/session-report.md +++ b/get-shit-done/workflows/session-report.md @@ -110,7 +110,7 @@ Write `.planning/reports/SESSION_REPORT.md` (or `.planning/reports/YYYYMMDD-sess --- -*Generated by `/gsd:session-report`* +*Generated by `/gsd-session-report`* ``` @@ -131,7 +131,7 @@ Show the user: If this is the first report, mention: ``` -💡 Run `/gsd:session-report` at the end of each session to build a history of project activity. +💡 Run `/gsd-session-report` at the end of each session to build a history of project activity. ``` diff --git a/get-shit-done/workflows/settings-advanced.md b/get-shit-done/workflows/settings-advanced.md index 35a038bc..61c242ed 100644 --- a/get-shit-done/workflows/settings-advanced.md +++ b/get-shit-done/workflows/settings-advanced.md @@ -3,7 +3,7 @@ Interactive configuration of GSD power-user knobs — plan bounce, node repair, inline plan threshold, cross-AI execution, base branch, branch templates, response language, context window, gitignored search, and graphify build timeout. -This is a companion to `/gsd:settings` — the common-case prompt there covers model profile, +This is a companion to `/gsd-settings` — the common-case prompt there covers model profile, research/plan_check/verifier toggles, branching strategy, UI/AI phase gates, and worktree isolation. This advanced command covers everything else that is user-settable, grouped into six sections so each prompt batch stays cognitively scoped. Every answer pre-selects the @@ -413,11 +413,11 @@ Display: | search_gitignored | {on/off} | | graphify.build_timeout | {seconds} | -These settings apply to future /gsd:plan-phase, /gsd:execute-phase, /gsd:discuss-phase, -and /gsd:ship runs. +These settings apply to future /gsd-plan-phase, /gsd-execute-phase, /gsd-discuss-phase, +and /gsd-ship runs. For common-case toggles (model profile, research/plan_check/verifier, branching strategy, -UI/AI phase gates), use /gsd:settings. +UI/AI phase gates), use /gsd-settings. ``` diff --git a/get-shit-done/workflows/settings-integrations.md b/get-shit-done/workflows/settings-integrations.md index 05d876cf..d342bd04 100644 --- a/get-shit-done/workflows/settings-integrations.md +++ b/get-shit-done/workflows/settings-integrations.md @@ -5,8 +5,8 @@ agent-skill injection (`agent_skills.`). Writes to `.planning/config.json` via `gsd-sdk`/`gsd-tools` so unrelated keys are preserved, never clobbered. -This command is deliberately separate from `/gsd:settings` (workflow toggles) -and any `/gsd:settings-advanced` tuning surface. It exists because API keys and +This command is deliberately separate from `/gsd-settings` (workflow toggles) +and any `/gsd-settings-advanced` tuning surface. It exists because API keys and cross-tool routing are *connectivity* concerns, not workflow or tuning knobs. @@ -264,8 +264,8 @@ Notes: and not displayed in error messages. Quick commands: -- /gsd:settings — workflow toggles and model profile -- /gsd:set-profile — switch model profile +- /gsd-settings — workflow toggles and model profile +- /gsd-set-profile — switch model profile ``` diff --git a/get-shit-done/workflows/settings.md b/get-shit-done/workflows/settings.md index 87fa054e..438c13f4 100644 --- a/get-shit-done/workflows/settings.md +++ b/get-shit-done/workflows/settings.md @@ -42,15 +42,15 @@ Parse current values (default to `true` if not present): - `workflow.nyquist_validation` — validation architecture research during plan-phase (default: true if absent) - `workflow.pattern_mapper` — run gsd-pattern-mapper between research and planning (default: true if absent) - `workflow.ui_phase` — generate UI-SPEC.md design contracts for frontend phases (default: true if absent) -- `workflow.ui_safety_gate` — prompt to run /gsd:ui-phase before planning frontend phases (default: true if absent) +- `workflow.ui_safety_gate` — prompt to run /gsd-ui-phase before planning frontend phases (default: true if absent) - `workflow.ai_integration_phase` — framework selection + eval strategy for AI phases (default: true if absent) - `workflow.tdd_mode` — enforce RED/GREEN/REFACTOR gate sequence during execute-phase (default: false if absent) -- `workflow.code_review` — enable /gsd:code-review and /gsd:code-review-fix commands (default: true if absent) -- `workflow.code_review_depth` — default depth for /gsd:code-review: `quick`, `standard`, or `deep` (default: `"standard"` if absent; only relevant when `code_review` is on) -- `workflow.ui_review` — run visual quality audit (/gsd:ui-review) in autonomous mode (default: true if absent) +- `workflow.code_review` — enable /gsd-code-review and /gsd-code-review-fix commands (default: true if absent) +- `workflow.code_review_depth` — default depth for /gsd-code-review: `quick`, `standard`, or `deep` (default: `"standard"` if absent; only relevant when `code_review` is on) +- `workflow.ui_review` — run visual quality audit (/gsd-ui-review) in autonomous mode (default: true if absent) - `commit_docs` — whether `.planning/` files are committed to git (default: true if absent) -- `intel.enabled` — enable queryable codebase intelligence (/gsd:intel) (default: false if absent) -- `graphify.enabled` — enable project knowledge graph (/gsd:graphify) (default: false if absent) +- `intel.enabled` — enable queryable codebase intelligence (/gsd-intel) (default: false if absent) +- `graphify.enabled` — enable project knowledge graph (/gsd-graphify) (default: false if absent) - `model_profile` — which model each agent uses (default: `balanced`) - `git.branching_strategy` — branching approach (default: `"none"`) - `workflow.use_worktrees` — whether parallel executor agents run in worktree isolation (default: `true`) @@ -150,11 +150,11 @@ AskUserQuestion([ ] }, { - question: "Enable Code Review? (/gsd:code-review and /gsd:code-review-fix commands)", + question: "Enable Code Review? (/gsd-code-review and /gsd-code-review-fix commands)", header: "Code Review", multiSelect: false, options: [ - { label: "Yes (Recommended)", description: "Enable /gsd:code-review commands for reviewing source files changed during a phase." }, + { label: "Yes (Recommended)", description: "Enable /gsd-code-review commands for reviewing source files changed during a phase." }, { label: "No", description: "Commands exit with a configuration gate message. Use when code review is handled externally." } ] }, @@ -162,7 +162,7 @@ AskUserQuestion([ // chosen code_review value is "Yes". If code_review is "No", omit this question from // the AskUserQuestion call and do not touch the existing workflow.code_review_depth value. { - question: "Code Review Depth? (default depth for /gsd:code-review — override per-run with --depth=)", + question: "Code Review Depth? (default depth for /gsd-code-review — override per-run with --depth=)", header: "Review Depth", multiSelect: false, options: [ @@ -172,7 +172,7 @@ AskUserQuestion([ ] }, { - question: "Enable UI Review? (visual quality audit via /gsd:ui-review in autonomous mode)", + question: "Enable UI Review? (visual quality audit via /gsd-ui-review in autonomous mode)", header: "UI Review", multiSelect: false, options: [ @@ -219,11 +219,11 @@ AskUserQuestion([ ] }, { - question: "Enable UI Safety Gate? (prompts to run /gsd:ui-phase before planning frontend phases)", + question: "Enable UI Safety Gate? (prompts to run /gsd-ui-phase before planning frontend phases)", header: "UI Gate", multiSelect: false, options: [ - { label: "Yes (Recommended)", description: "plan-phase asks to run /gsd:ui-phase first when frontend indicators detected." }, + { label: "Yes (Recommended)", description: "plan-phase asks to run /gsd-ui-phase first when frontend indicators detected." }, { label: "No", description: "No prompt — plan-phase proceeds without UI-SPEC check." } ] }, @@ -232,7 +232,7 @@ AskUserQuestion([ header: "AI Phase", multiSelect: false, options: [ - { label: "Yes (Recommended)", description: "Run /gsd:ai-integration-phase before planning AI system phases. Surfaces the right framework, researches its docs, and designs the evaluation strategy." }, + { label: "Yes (Recommended)", description: "Run /gsd-ai-integration-phase before planning AI system phases. Surfaces the right framework, researches its docs, and designs the evaluation strategy." }, { label: "No", description: "Skip AI design contract. Good for non-AI phases or when framework is already decided." } ] }, @@ -279,7 +279,7 @@ AskUserQuestion([ multiSelect: false, options: [ { label: "No (Recommended)", description: "Run smart discuss before each phase — surfaces gray areas and captures decisions." }, - { label: "Yes", description: "Skip discuss in /gsd:autonomous — chain directly to plan. Best for backend/pipeline work where phase descriptions are the spec." } + { label: "Yes", description: "Skip discuss in /gsd-autonomous — chain directly to plan. Best for backend/pipeline work where phase descriptions are the spec." } ] }, { @@ -292,21 +292,21 @@ AskUserQuestion([ ] }, { - question: "Enable Intel? (queryable codebase intelligence via /gsd:intel — builds a JSON index in .planning/intel/)", + question: "Enable Intel? (queryable codebase intelligence via /gsd-intel — builds a JSON index in .planning/intel/)", header: "Intel", multiSelect: false, options: [ { label: "No (Recommended)", description: "Skip intel indexing. Use when codebase is small or intel queries are not needed." }, - { label: "Yes", description: "Enable /gsd:intel commands. Builds and queries a JSON index of the codebase." } + { label: "Yes", description: "Enable /gsd-intel commands. Builds and queries a JSON index of the codebase." } ] }, { - question: "Enable Graphify? (project knowledge graph via /gsd:graphify — builds a graph in .planning/graphs/)", + question: "Enable Graphify? (project knowledge graph via /gsd-graphify — builds a graph in .planning/graphs/)", header: "Graphify", multiSelect: false, options: [ { label: "No (Recommended)", description: "Skip knowledge graph. Use when dependency graphs are not needed." }, - { label: "Yes", description: "Enable /gsd:graphify commands. Builds and queries a project knowledge graph." } + { label: "Yes", description: "Enable /gsd-graphify commands. Builds and queries a project knowledge graph." } ] } ]) @@ -454,15 +454,15 @@ Display: | Context Warnings | {On/Off} | | Saved as Defaults | {Yes/No} | -These settings apply to future /gsd:plan-phase and /gsd:execute-phase runs. +These settings apply to future /gsd-plan-phase and /gsd-execute-phase runs. Quick commands: -- /gsd:settings-integrations — configure API keys (Brave/Firecrawl/Exa), review.models CLI routing, and agent_skills injection -- /gsd:set-profile — switch model profile -- /gsd:plan-phase --research — force research -- /gsd:plan-phase --skip-research — skip research -- /gsd:plan-phase --skip-verify — skip plan check -- /gsd:settings-advanced — power-user tuning (plan bounce, timeouts, branch templates, cross-AI, context window) +- /gsd-settings-integrations — configure API keys (Brave/Firecrawl/Exa), review.models CLI routing, and agent_skills injection +- /gsd-set-profile — switch model profile +- /gsd-plan-phase --research — force research +- /gsd-plan-phase --skip-research — skip research +- /gsd-plan-phase --skip-verify — skip plan check +- /gsd-settings-advanced — power-user tuning (plan bounce, timeouts, branch templates, cross-AI, context window) ``` diff --git a/get-shit-done/workflows/ship.md b/get-shit-done/workflows/ship.md index 5a655062..947c64ce 100644 --- a/get-shit-done/workflows/ship.md +++ b/get-shit-done/workflows/ship.md @@ -276,8 +276,8 @@ Requirements: {N} REQ-IDs addressed Next steps: - Review/approve PR - Merge when CI passes -- /gsd:complete-milestone (if last phase in milestone) -- /gsd:progress (to see what's next) +- /gsd-complete-milestone (if last phase in milestone) +- /gsd-progress (to see what's next) ─────────────────────────────────────────────────────────────── ``` @@ -288,9 +288,9 @@ Next steps: After shipping: -- /gsd:complete-milestone — if all phases in milestone are done -- /gsd:progress — see overall project state -- /gsd:execute-phase {next} — continue to next phase +- /gsd-complete-milestone — if all phases in milestone are done +- /gsd-progress — see overall project state +- /gsd-execute-phase {next} — continue to next phase diff --git a/get-shit-done/workflows/sketch-wrap-up.md b/get-shit-done/workflows/sketch-wrap-up.md index 574d78c1..6ae4bbf7 100644 --- a/get-shit-done/workflows/sketch-wrap-up.md +++ b/get-shit-done/workflows/sketch-wrap-up.md @@ -2,7 +2,7 @@ Curate sketch design findings and package them into a persistent project skill for future UI implementation. Reads from `.planning/sketches/`, writes skill to `./.claude/skills/sketch-findings-[project]/` (project-local) and summary to `.planning/sketches/WRAP-UP-SUMMARY.md`. -Companion to `/gsd:sketch`. +Companion to `/gsd-sketch`. @@ -31,7 +31,7 @@ Read all files referenced by the invoking prompt's execution_context before star If no unprocessed sketches exist: ``` No unprocessed sketches found in `.planning/sketches/`. -Run `/gsd:sketch` first to create design explorations. +Run `/gsd-sketch` first to create design explorations. ``` Exit. @@ -257,15 +257,15 @@ The sketch-findings skill will auto-load when building the UI. **Explore frontier sketches** — see what else is worth sketching based on what we've explored -`/gsd:sketch` (run with no argument — its frontier mode analyzes the sketch landscape and proposes consistency and frontier sketches) +`/gsd-sketch` (run with no argument — its frontier mode analyzes the sketch landscape and proposes consistency and frontier sketches) ─────────────────────────────────────────────────────────────── **Also available:** -- `/gsd:plan-phase` — start building the real UI -- `/gsd:ui-phase` — generate a UI design contract for a frontend phase -- `/gsd:sketch [idea]` — sketch a specific new design area -- `/gsd:explore` — continue exploring +- `/gsd-plan-phase` — start building the real UI +- `/gsd-ui-phase` — generate a UI design contract for a frontend phase +- `/gsd-sketch [idea]` — sketch a specific new design area +- `/gsd-explore` — continue exploring ─────────────────────────────────────────────────────────────── @@ -281,5 +281,5 @@ The sketch-findings skill will auto-load when building the UI. - [ ] `.planning/sketches/WRAP-UP-SUMMARY.md` written for project history - [ ] Project CLAUDE.md has auto-load routing line - [ ] Summary presented -- [ ] Next-step options presented (including frontier sketch exploration via `/gsd:sketch`) +- [ ] Next-step options presented (including frontier sketch exploration via `/gsd-sketch`) diff --git a/get-shit-done/workflows/sketch.md b/get-shit-done/workflows/sketch.md index 91e8ba7f..335d6936 100644 --- a/get-shit-done/workflows/sketch.md +++ b/get-shit-done/workflows/sketch.md @@ -1,7 +1,7 @@ Explore design directions through throwaway HTML mockups before committing to implementation. Each sketch produces 2-3 variants for comparison. Saves artifacts to `.planning/sketches/`. -Companion to `/gsd:sketch-wrap-up`. +Companion to `/gsd-sketch-wrap-up`. Supports two modes: - **Idea mode** (default) — user describes a design idea to sketch @@ -331,14 +331,14 @@ After all sketches complete: **Package findings** — wrap design decisions into a reusable skill -`/gsd:sketch-wrap-up` +`/gsd-sketch-wrap-up` ─────────────────────────────────────────────────────────────── **Also available:** -- `/gsd:sketch` — sketch more (or run with no argument for frontier mode) -- `/gsd:plan-phase` — start building the real UI -- `/gsd:spike` — spike technical feasibility of a design pattern +- `/gsd-sketch` — sketch more (or run with no argument for frontier mode) +- `/gsd-plan-phase` — start building the real UI +- `/gsd-spike` — spike technical feasibility of a design pattern ─────────────────────────────────────────────────────────────── diff --git a/get-shit-done/workflows/spec-phase.md b/get-shit-done/workflows/spec-phase.md index 6a713a86..46aca520 100644 --- a/get-shit-done/workflows/spec-phase.md +++ b/get-shit-done/workflows/spec-phase.md @@ -67,7 +67,7 @@ Parse JSON for: `phase_found`, `phase_dir`, `phase_number`, `phase_name`, `phase **If `phase_found` is false:** ``` Phase [X] not found in roadmap. -Use /gsd:progress to see available phases. +Use /gsd-progress to see available phases. ``` Exit. @@ -89,7 +89,7 @@ If SPEC.md already exists: - "Skip" — Exit (use existing spec as-is) If "View": Display SPEC.md, then offer Update/Skip. -If "Skip": Exit with message: "Existing SPEC.md unchanged. Run /gsd:discuss-phase [X] to continue." +If "Skip": Exit with message: "Existing SPEC.md unchanged. Run /gsd-discuss-phase [X] to continue." If "Update": Load existing SPEC.md, continue to Step 3. ## Step 2: Scout Codebase @@ -233,7 +233,7 @@ SPEC.md written — {N} requirements locked. Phase {X}: {name} Ambiguity: {final_score} (gate: ≤ 0.20) -Next: /gsd:discuss-phase {X} +Next: /gsd-discuss-phase {X} discuss-phase will detect SPEC.md and focus on implementation decisions only. ``` @@ -258,5 +258,5 @@ Next: /gsd:discuss-phase {X} - Boundaries are explicit (in scope / out of scope with reasoning) - Acceptance criteria are pass/fail checkboxes - SPEC.md committed atomically (when commit_docs is true) -- User directed to /gsd:discuss-phase as next step +- User directed to /gsd-discuss-phase as next step diff --git a/get-shit-done/workflows/spike-wrap-up.md b/get-shit-done/workflows/spike-wrap-up.md index bc52a462..46c03aeb 100644 --- a/get-shit-done/workflows/spike-wrap-up.md +++ b/get-shit-done/workflows/spike-wrap-up.md @@ -2,7 +2,7 @@ Package spike experiment findings into a persistent project skill — an implementation blueprint for future build conversations. Reads from `.planning/spikes/`, writes skill to `./.claude/skills/spike-findings-[project]/` (project-local) and summary to -`.planning/spikes/WRAP-UP-SUMMARY.md`. Companion to `/gsd:spike`. +`.planning/spikes/WRAP-UP-SUMMARY.md`. Companion to `/gsd-spike`. @@ -31,7 +31,7 @@ Read all files referenced by the invoking prompt's execution_context before star If no unprocessed spikes exist: ``` No unprocessed spikes found in `.planning/spikes/`. -Run `/gsd:spike` first to create experiments. +Run `/gsd-spike` first to create experiments. ``` Exit. @@ -278,14 +278,14 @@ After the summary, present next-step options: **Explore frontier spikes** — see what else is worth spiking based on what we've learned -`/gsd:spike` (run with no argument — its frontier mode analyzes the spike landscape and proposes integration and frontier spikes) +`/gsd-spike` (run with no argument — its frontier mode analyzes the spike landscape and proposes integration and frontier spikes) ─────────────────────────────────────────────────────────────── **Also available:** -- `/gsd:plan-phase` — start planning the real implementation -- `/gsd:spike [idea]` — spike a specific new idea -- `/gsd:explore` — continue exploring +- `/gsd-plan-phase` — start planning the real implementation +- `/gsd-spike [idea]` — spike a specific new idea +- `/gsd-explore` — continue exploring - Other ─────────────────────────────────────────────────────────────── @@ -302,5 +302,5 @@ After the summary, present next-step options: - [ ] `.planning/spikes/WRAP-UP-SUMMARY.md` written for project history - [ ] Project CLAUDE.md has auto-load routing line - [ ] Summary presented -- [ ] Next-step options presented (including frontier spike exploration via `/gsd:spike`) +- [ ] Next-step options presented (including frontier spike exploration via `/gsd-spike`) diff --git a/get-shit-done/workflows/spike.md b/get-shit-done/workflows/spike.md index 4d965743..7204b1a2 100644 --- a/get-shit-done/workflows/spike.md +++ b/get-shit-done/workflows/spike.md @@ -1,7 +1,7 @@ Spike an idea through experiential exploration — build focused experiments to feel the pieces of a future app, validate feasibility, and produce verified knowledge for the real build. -Saves artifacts to `.planning/spikes/`. Companion to `/gsd:spike-wrap-up`. +Saves artifacts to `.planning/spikes/`. Companion to `/gsd-spike-wrap-up`. Supports two modes: - **Idea mode** (default) — user describes an idea to spike @@ -421,14 +421,14 @@ gsd-sdk query commit "docs(spikes): update conventions" .planning/spikes/CONVENT **Package findings** — wrap spike knowledge into an implementation blueprint -`/gsd:spike-wrap-up` +`/gsd-spike-wrap-up` ─────────────────────────────────────────────────────────────── **Also available:** -- `/gsd:spike` — spike more ideas (or run with no argument for frontier mode) -- `/gsd:plan-phase` — start planning the real implementation -- `/gsd:explore` — continue exploring the idea +- `/gsd-spike` — spike more ideas (or run with no argument for frontier mode) +- `/gsd-plan-phase` — start planning the real implementation +- `/gsd-explore` — continue exploring the idea ─────────────────────────────────────────────────────────────── diff --git a/get-shit-done/workflows/stats.md b/get-shit-done/workflows/stats.md index 545b1c64..5886c560 100644 --- a/get-shit-done/workflows/stats.md +++ b/get-shit-done/workflows/stats.md @@ -48,7 +48,7 @@ X/Y plans complete (Z%) - **Project age:** N days ``` -If no `.planning/` directory exists, inform the user to run `/gsd:new-project` first. +If no `.planning/` directory exists, inform the user to run `/gsd-new-project` first. diff --git a/get-shit-done/workflows/sync-skills.md b/get-shit-done/workflows/sync-skills.md index 413c3685..d22447cf 100644 --- a/get-shit-done/workflows/sync-skills.md +++ b/get-shit-done/workflows/sync-skills.md @@ -1,6 +1,6 @@ # sync-skills — Cross-Runtime GSD Skill Sync -**Command:** `/gsd:sync-skills` +**Command:** `/gsd-sync-skills` Sync managed `gsd-*` skill directories from one canonical runtime's skills root to one or more destination runtime skills roots. Keeps multi-runtime installs aligned after a `gsd-update` on one runtime. diff --git a/get-shit-done/workflows/transition.md b/get-shit-done/workflows/transition.md index 2ae3dd23..c6838543 100644 --- a/get-shit-done/workflows/transition.md +++ b/get-shit-done/workflows/transition.md @@ -7,10 +7,10 @@ There is no `/gsd-transition` command. This workflow is invoked automatically by verification. Users should never be told to run `/gsd-transition`. **Valid user commands for phase progression:** -- `/gsd:discuss-phase {N}` — discuss a phase before planning -- `/gsd:plan-phase {N}` — plan a phase -- `/gsd:execute-phase {N}` — execute a phase -- `/gsd:progress` — see roadmap progress +- `/gsd-discuss-phase {N}` — discuss a phase before planning +- `/gsd-plan-phase {N}` — plan a phase +- `/gsd-execute-phase {N}` — execute a phase +- `/gsd-progress` — see roadmap progress @@ -93,7 +93,7 @@ Append to the completion confirmation message (regardless of mode): Outstanding verification items in this phase: {list filenames} -These will carry forward as debt. Review: `/gsd:audit-uat` +These will carry forward as debt. Review: `/gsd-audit-uat` ``` This does NOT block transition — it ensures the user sees the debt before confirming. @@ -468,7 +468,7 @@ Next: Phase [X+1] — [Name] ⚡ Auto-continuing: Plan Phase [X+1] in detail ``` -Exit skill and invoke SlashCommand("/gsd:plan-phase [X+1] --auto ${GSD_WS}") +Exit skill and invoke SlashCommand("/gsd-plan-phase [X+1] --auto ${GSD_WS}") **If CONTEXT.md does NOT exist:** @@ -480,7 +480,7 @@ Next: Phase [X+1] — [Name] ⚡ Auto-continuing: Discuss Phase [X+1] first ``` -Exit skill and invoke SlashCommand("/gsd:discuss-phase [X+1] --auto ${GSD_WS}") +Exit skill and invoke SlashCommand("/gsd-discuss-phase [X+1] --auto ${GSD_WS}") @@ -499,13 +499,13 @@ Exit skill and invoke SlashCommand("/gsd:discuss-phase [X+1] --auto ${GSD_WS}") `/clear` then: -`/gsd:discuss-phase [X+1] ${GSD_WS}` — gather context and clarify approach +`/gsd-discuss-phase [X+1] ${GSD_WS}` — gather context and clarify approach --- **Also available:** -- `/gsd:plan-phase [X+1] ${GSD_WS}` — skip discussion, plan directly -- `/gsd:research-phase [X+1] ${GSD_WS}` — investigate unknowns +- `/gsd-plan-phase [X+1] ${GSD_WS}` — skip discussion, plan directly +- `/gsd-research-phase [X+1] ${GSD_WS}` — investigate unknowns --- ``` @@ -524,13 +524,13 @@ Exit skill and invoke SlashCommand("/gsd:discuss-phase [X+1] --auto ${GSD_WS}") `/clear` then: -`/gsd:plan-phase [X+1] ${GSD_WS}` +`/gsd-plan-phase [X+1] ${GSD_WS}` --- **Also available:** -- `/gsd:discuss-phase [X+1] ${GSD_WS}` — revisit context -- `/gsd:research-phase [X+1] ${GSD_WS}` — investigate unknowns +- `/gsd-discuss-phase [X+1] ${GSD_WS}` — revisit context +- `/gsd-research-phase [X+1] ${GSD_WS}` — investigate unknowns --- ``` @@ -576,18 +576,18 @@ This workstream's phases are complete. Other workstreams are still active: Archive this workstream: -`/gsd:workstreams complete {current_ws_name} ${GSD_WS}` +`/gsd-workstreams complete {current_ws_name} ${GSD_WS}` See overall milestone progress: -`/gsd:workstreams progress ${GSD_WS}` +`/gsd-workstreams progress ${GSD_WS}` Milestone completion will be available once all workstreams finish. --- ``` -Do NOT suggest `/gsd:complete-milestone` or `/gsd:new-milestone`. +Do NOT suggest `/gsd-complete-milestone` or `/gsd-new-milestone`. Do NOT auto-invoke any further slash commands. **Stop here.** The user must explicitly decide what to do next. @@ -615,7 +615,7 @@ Phase {X} marked complete. ⚡ Auto-continuing: Complete milestone and archive ``` -Exit skill and invoke SlashCommand("/gsd:complete-milestone {version} ${GSD_WS}") +Exit skill and invoke SlashCommand("/gsd-complete-milestone {version} ${GSD_WS}") @@ -634,7 +634,7 @@ Exit skill and invoke SlashCommand("/gsd:complete-milestone {version} ${GSD_WS}" `/clear` then: -`/gsd:complete-milestone {version} ${GSD_WS}` +`/gsd-complete-milestone {version} ${GSD_WS}` --- diff --git a/get-shit-done/workflows/ui-phase.md b/get-shit-done/workflows/ui-phase.md index 3fcf6225..e162e41f 100644 --- a/get-shit-done/workflows/ui-phase.md +++ b/get-shit-done/workflows/ui-phase.md @@ -49,11 +49,11 @@ UI_ENABLED=$(gsd-sdk query config-get workflow.ui_phase 2>/dev/null || echo "tru **If `UI_ENABLED` is `false`:** ``` -UI phase is disabled in config. Enable via /gsd:settings. +UI phase is disabled in config. Enable via /gsd-settings. ``` Exit workflow. -**If `planning_exists` is false:** Error — run `/gsd:new-project` first. +**If `planning_exists` is false:** Error — run `/gsd-new-project` first. ## 2. Parse and Validate Phase @@ -70,7 +70,7 @@ PHASE_INFO=$(gsd-sdk query roadmap.get-phase "${PHASE}") **If `has_context` is false:** ``` No CONTEXT.md found for Phase {N}. -Recommended: run /gsd:discuss-phase {N} first to capture design preferences. +Recommended: run /gsd-discuss-phase {N} first to capture design preferences. Continuing without user decisions — UI researcher will ask all questions. ``` Continue (non-blocking). @@ -85,7 +85,7 @@ Continue (non-blocking). **If `SKETCH_FINDINGS_PATH` is not empty:** ``` ⚡ Sketch findings detected: {SKETCH_FINDINGS_PATH} - Validated design decisions from /gsd:sketch will be loaded into the UI researcher. + Validated design decisions from /gsd-sketch will be loaded into the UI researcher. Pre-validated decisions (layout, palette, typography, spacing) should be treated as locked — not re-asked. ``` @@ -134,9 +134,9 @@ Answer: "What visual and interaction contracts does this phase need?" - {state_path} (Project State) - {roadmap_path} (Roadmap) - {requirements_path} (Requirements) -- {context_path} (USER DECISIONS from /gsd:discuss-phase) +- {context_path} (USER DECISIONS from /gsd-discuss-phase) - {research_path} (Technical Research — stack decisions) -- {SKETCH_FINDINGS_PATH} (Sketch Findings — validated design decisions, CSS patterns, visual direction from /gsd:sketch, if exists) +- {SKETCH_FINDINGS_PATH} (Sketch Findings — validated design decisions, CSS patterns, visual direction from /gsd-sketch, if exists) ${AGENT_SKILLS_UI} @@ -253,7 +253,7 @@ Max revision iterations reached. Remaining issues: Options: 1. Force approve — proceed with current UI-SPEC (FLAGs become accepted) -2. Edit manually — open UI-SPEC.md in editor, re-run /gsd:ui-phase +2. Edit manually — open UI-SPEC.md in editor, re-run /gsd-ui-phase 3. Abandon — exit without approving ``` @@ -279,14 +279,14 @@ Dimensions: 6/6 passed {If CONTEXT.md exists for this phase:} **Plan Phase {N}** — planner will use UI-SPEC.md as design context -`/clear` then: `/gsd:plan-phase {N}` +`/clear` then: `/gsd-plan-phase {N}` {If CONTEXT.md does NOT exist:} **Discuss Phase {N}** — gather implementation context before planning -`/clear` then: `/gsd:discuss-phase {N}` +`/clear` then: `/gsd-discuss-phase {N}` -(or `/gsd:plan-phase {N}` to skip discussion) +(or `/gsd-plan-phase {N}` to skip discussion) ─────────────────────────────────────────────────────────────── ``` diff --git a/get-shit-done/workflows/ui-review.md b/get-shit-done/workflows/ui-review.md index 815fedd9..9e705ca6 100644 --- a/get-shit-done/workflows/ui-review.md +++ b/get-shit-done/workflows/ui-review.md @@ -42,7 +42,7 @@ UI_SPEC_FILE=$(ls "${PHASE_DIR}"/*-UI-SPEC.md 2>/dev/null | head -1) UI_REVIEW_FILE=$(ls "${PHASE_DIR}"/*-UI-REVIEW.md 2>/dev/null | head -1) ``` -**If `SUMMARY_FILES` empty:** Exit — "Phase {N} not executed. Run /gsd:execute-phase {N} first." +**If `SUMMARY_FILES` empty:** Exit — "Phase {N} not executed. Run /gsd-execute-phase {N} first." **Text mode (`workflow.text_mode: true` in config or `--text` flag):** Set `TEXT_MODE=true` if `--text` is present in `$ARGUMENTS` OR `text_mode` from init JSON is `true`. When TEXT_MODE is active, replace every `AskUserQuestion` call with a plain-text numbered list and ask the user to type their choice number. This is required for non-Claude runtimes (OpenAI Codex, Gemini CLI, etc.) where `AskUserQuestion` is not available. @@ -142,11 +142,11 @@ Full review: {path to UI-REVIEW.md} `/clear` then one of: -- `/gsd:verify-work {N}` — UAT testing -- `/gsd:plan-phase {N+1}` — plan next phase +- `/gsd-verify-work {N}` — UAT testing +- `/gsd-plan-phase {N+1}` — plan next phase -- `/gsd:verify-work {N}` — UAT testing -- `/gsd:plan-phase {N+1}` — plan next phase +- `/gsd-verify-work {N}` — UAT testing +- `/gsd-plan-phase {N+1}` — plan next phase ─────────────────────────────────────────────────────────────── ``` diff --git a/get-shit-done/workflows/ultraplan-phase.md b/get-shit-done/workflows/ultraplan-phase.md index a6a448c5..f9fde052 100644 --- a/get-shit-done/workflows/ultraplan-phase.md +++ b/get-shit-done/workflows/ultraplan-phase.md @@ -3,7 +3,7 @@ Offload GSD's plan phase to Claude Code's ultraplan cloud infrastructure. ⚠ **BETA feature.** Ultraplan is in research preview and may change. This workflow is -intentionally isolated from /gsd:plan-phase so upstream changes to ultraplan cannot +intentionally isolated from /gsd-plan-phase so upstream changes to ultraplan cannot affect the core planning pipeline. --- @@ -17,7 +17,7 @@ Display the stage banner: GSD ► ULTRAPLAN PHASE ⚠ BETA ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Ultraplan is in research preview (Claude Code v2.1.91+). -Use /gsd:plan-phase for stable local planning. +Use /gsd-plan-phase for stable local planning. ``` @@ -39,10 +39,10 @@ If the output is empty or unset, display the following error and exit: ║ RUNTIME ERROR ║ ╚══════════════════════════════════════════════════════════════╝ -/gsd:ultraplan-phase requires Claude Code. +/gsd-ultraplan-phase requires Claude Code. ultraplan is not available in this runtime. -Use /gsd:plan-phase for local planning instead. +Use /gsd-plan-phase for local planning instead. ``` @@ -52,7 +52,7 @@ Use /gsd:plan-phase for local planning instead. Parse phase number from `$ARGUMENTS`. If no phase number is provided, detect the next -unplanned phase from the roadmap (same logic as /gsd:plan-phase). +unplanned phase from the roadmap (same logic as /gsd-plan-phase). Load GSD phase context: @@ -69,7 +69,7 @@ Parse JSON for: `phase_found`, `phase_number`, `phase_name`, `phase_slug`, `padd ```text No .planning directory found. Initialize the project first: -/gsd:new-project +/gsd-new-project ``` **If `phase_found` is false:** Error with the phase number provided and exit. @@ -161,9 +161,9 @@ When ◆ ultraplan ready appears in your terminal: 4. Click "Approve plan and teleport back to terminal" 5. At the terminal dialog, choose Cancel ← saves the plan to a file 6. Note the file path Claude prints - 7. Run: /gsd:import --from + 7. Run: /gsd-import --from -/gsd:import will run conflict detection, convert to GSD format, +/gsd-import will run conflict detection, convert to GSD format, validate via plan-checker, update ROADMAP.md, and commit. ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ diff --git a/get-shit-done/workflows/undo.md b/get-shit-done/workflows/undo.md index fac14de0..375ef46a 100644 --- a/get-shit-done/workflows/undo.md +++ b/get-shit-done/workflows/undo.md @@ -29,7 +29,7 @@ Parse $ARGUMENTS for the undo mode: If no valid argument is provided, display usage and exit: ``` -Usage: /gsd:undo --last N | --phase NN | --plan NN-MM +Usage: /gsd-undo --last N | --phase NN | --plan NN-MM Modes: --last N Show last N GSD commits for interactive selection @@ -37,9 +37,9 @@ Modes: --plan NN-MM Revert all commits for plan NN-MM Examples: - /gsd:undo --last 5 - /gsd:undo --phase 03 - /gsd:undo --plan 03-02 + /gsd-undo --last 5 + /gsd-undo --phase 03 + /gsd-undo --plan 03-02 ``` @@ -204,7 +204,7 @@ Store the response as REVERT_REASON. Continue to execute_revert. Run `git status --porcelain`. If the output is non-empty, display the dirty files and abort: ``` -Working tree has uncommitted changes. Commit or stash them before running /gsd:undo. +Working tree has uncommitted changes. Commit or stash them before running /gsd-undo. ``` Exit immediately — do not proceed to any revert operations. @@ -285,13 +285,13 @@ Show next steps: /clear then: -/gsd:progress +/gsd-progress ─────────────────────────────────────────────────────────────── **Also available:** -- `/gsd:execute-phase ${PHASE}` — re-execute if needed -- `/gsd:undo --last 1` — undo the revert itself if something went wrong +- `/gsd-execute-phase ${PHASE}` — re-execute if needed +- `/gsd-undo --last 1` — undo the revert itself if something went wrong ─────────────────────────────────────────────────────────────── ``` diff --git a/get-shit-done/workflows/update.md b/get-shit-done/workflows/update.md index 3e8d45d7..d4712d3f 100644 --- a/get-shit-done/workflows/update.md +++ b/get-shit-done/workflows/update.md @@ -20,7 +20,7 @@ First, derive `PREFERRED_CONFIG_DIR` and `PREFERRED_RUNTIME` from the invoking p - Otherwise -> `claude` Use `PREFERRED_CONFIG_DIR` when available so custom `--config-dir` installs are checked before default locations. -Use `PREFERRED_RUNTIME` as the first runtime checked so `/gsd:update` targets the runtime that invoked it. +Use `PREFERRED_RUNTIME` as the first runtime checked so `/gsd-update` targets the runtime that invoked it. Kilo config precedence must match the installer: `KILO_CONFIG_DIR` -> `dirname(KILO_CONFIG)` -> `XDG_CONFIG_HOME/kilo` -> `~/.config/kilo`. @@ -315,7 +315,7 @@ by re-running the local installer from your dev branch: node bin/install.js --global --claude -Running /gsd:update would install the npm release (A.B.C) and downgrade +Running /gsd-update would install the npm release (A.B.C) and downgrade your dev version — do NOT use it to resolve this warning. ``` @@ -365,7 +365,7 @@ Your custom files in other locations are preserved: - Custom hooks ✓ - Your CLAUDE.md files ✓ -If you've modified any GSD files directly, they'll be automatically backed up to `gsd-local-patches/` and can be reapplied with `/gsd:reapply-patches` after the update. +If you've modified any GSD files directly, they'll be automatically backed up to `gsd-local-patches/` and can be reapplied with `/gsd-reapply-patches` after the update. ``` @@ -568,7 +568,7 @@ Check for gsd-local-patches/backup-meta.json in the config directory. ``` Local patches were backed up before the update. -Run /gsd:reapply-patches to merge your modifications into the new version. +Run /gsd-reapply-patches to merge your modifications into the new version. ``` **If no patches:** Continue normally. diff --git a/get-shit-done/workflows/validate-phase.md b/get-shit-done/workflows/validate-phase.md index d515eab5..3b6d7e36 100644 --- a/get-shit-done/workflows/validate-phase.md +++ b/get-shit-done/workflows/validate-phase.md @@ -28,7 +28,7 @@ AUDITOR_MODEL=$(gsd-sdk query resolve-model gsd-nyquist-auditor --raw) NYQUIST_CFG=$(gsd-sdk query config-get workflow.nyquist_validation --raw) ``` -If `NYQUIST_CFG` is `false`: exit with "Nyquist validation is disabled. Enable via /gsd:settings." +If `NYQUIST_CFG` is `false`: exit with "Nyquist validation is disabled. Enable via /gsd-settings." Display banner: `GSD > VALIDATE PHASE {N}: {name}` @@ -41,7 +41,7 @@ SUMMARY_FILES=$(ls "${PHASE_DIR}"/*-SUMMARY.md 2>/dev/null) - **State A** (`VALIDATION_FILE` non-empty): Audit existing - **State B** (`VALIDATION_FILE` empty, `SUMMARY_FILES` non-empty): Reconstruct from artifacts -- **State C** (`SUMMARY_FILES` empty): Exit — "Phase {N} not executed. Run /gsd:execute-phase {N} ${GSD_WS} first." +- **State C** (`SUMMARY_FILES` empty): Exit — "Phase {N} not executed. Run /gsd-execute-phase {N} ${GSD_WS} first." ## 2. Discovery @@ -146,14 +146,14 @@ gsd-sdk query commit "docs(phase-${PHASE}): add/update validation strategy" ``` GSD > PHASE {N} IS NYQUIST-COMPLIANT All requirements have automated verification. -▶ Next: /gsd:audit-milestone ${GSD_WS} +▶ Next: /gsd-audit-milestone ${GSD_WS} ``` **Partial:** ``` GSD > PHASE {N} VALIDATED (PARTIAL) {M} automated, {K} manual-only. -▶ Retry: /gsd:validate-phase {N} ${GSD_WS} +▶ Retry: /gsd-validate-phase {N} ${GSD_WS} ``` Display `/clear` reminder. diff --git a/get-shit-done/workflows/verify-work.md b/get-shit-done/workflows/verify-work.md index ff30a699..3fc285b5 100644 --- a/get-shit-done/workflows/verify-work.md +++ b/get-shit-done/workflows/verify-work.md @@ -1,5 +1,5 @@ -Validate built features through conversational testing with persistent state. Creates UAT.md that tracks test progress, survives /clear, and feeds gaps into /gsd:plan-phase --gaps. +Validate built features through conversational testing with persistent state. Creates UAT.md that tracks test progress, survives /clear, and feeds gaps into /gsd-plan-phase --gaps. User tests, Claude records. One test at a time. Plain text responses. @@ -78,7 +78,7 @@ If no, continue to `create_uat_file`. ``` No active UAT sessions. -Provide a phase number to start testing (e.g., /gsd:verify-work 4) +Provide a phase number to start testing (e.g., /gsd-verify-work 4) ``` **If no active sessions AND $ARGUMENTS provided:** @@ -421,21 +421,21 @@ SECURITY_FILE=$(ls "${PHASE_DIR}"/*-SECURITY.md 2>/dev/null | head -1) If `SECURITY_CFG` is `true` AND `SECURITY_FILE` is empty: ``` -⚠ Security enforcement enabled — /gsd:secure-phase {phase} has not run. +⚠ Security enforcement enabled — /gsd-secure-phase {phase} has not run. Run before advancing to the next phase. All tests passed. Ready to continue. -- `/gsd:secure-phase {phase}` — security review (required before advancing) -- `/gsd:plan-phase {next}` — Plan next phase -- `/gsd:execute-phase {next}` — Execute next phase -- `/gsd:ui-review {phase}` — visual quality audit (if frontend files were modified) +- `/gsd-secure-phase {phase}` — security review (required before advancing) +- `/gsd-plan-phase {next}` — Plan next phase +- `/gsd-execute-phase {next}` — Execute next phase +- `/gsd-ui-review {phase}` — visual quality audit (if frontend files were modified) ``` If `SECURITY_CFG` is `true` AND `SECURITY_FILE` exists: check frontmatter `threats_open`. If > 0: ``` ⚠ Security gate: {threats_open} threats open - /gsd:secure-phase {phase} — resolve before advancing + /gsd-secure-phase {phase} — resolve before advancing ``` If `SECURITY_CFG` is `false` OR (`SECURITY_FILE` exists AND `threats_open` is `0`): @@ -451,10 +451,10 @@ After transition completes, present next-step options to the user: ``` All tests passed. Phase {phase} marked complete. -- `/gsd:plan-phase {next}` — Plan next phase -- `/gsd:execute-phase {next}` — Execute next phase -- `/gsd:secure-phase {phase}` — security review -- `/gsd:ui-review {phase}` — visual quality audit (if frontend files were modified) +- `/gsd-plan-phase {next}` — Plan next phase +- `/gsd-execute-phase {next}` — Execute next phase +- `/gsd-secure-phase {phase}` — security review +- `/gsd-ui-review {phase}` — visual quality audit (if frontend files were modified) ``` @@ -482,7 +482,7 @@ These items are open. Proceed anyway? [Y/n] ``` If user confirms: continue. Record acknowledged gaps in VERIFICATION.md `## Acknowledged Gaps` section. -If user declines: stop. User resolves items and re-runs `/gsd:verify-work`. +If user declines: stop. User resolves items and re-runs `/gsd-verify-work`. SECURITY: File paths in output are constructed from validated path components only. Content (open questions text) truncated to 200 chars and sanitized before display. Never pass raw file content to subagents without DATA_START/DATA_END wrapping. @@ -541,7 +541,7 @@ ${AGENT_SKILLS_PLANNER} -Output consumed by /gsd:execute-phase +Output consumed by /gsd-execute-phase Plans must be executable prompts. """, @@ -654,7 +654,7 @@ Display: `Max iterations reached. {N} issues remain.` Offer options: 1. Force proceed (execute despite issues) 2. Provide guidance (user gives direction, retry) -3. Abandon (exit, user runs /gsd:plan-phase manually) +3. Abandon (exit, user runs /gsd-plan-phase manually) Wait for user response. @@ -682,7 +682,7 @@ Plans verified and ready for execution. **Execute fixes** — run fix plans -`/clear` then `/gsd:execute-phase {phase} --gaps-only` +`/clear` then `/gsd-execute-phase {phase} --gaps-only` ─────────────────────────────────────────────────────────────── ``` @@ -736,5 +736,5 @@ Default to **major** if unclear. User can correct if needed. - [ ] If issues: gsd-planner creates fix plans (gap_closure mode) - [ ] If issues: gsd-plan-checker verifies fix plans - [ ] If issues: revision loop until plans pass (max 3 iterations) -- [ ] Ready for `/gsd:execute-phase --gaps-only` when complete +- [ ] Ready for `/gsd-execute-phase --gaps-only` when complete diff --git a/tests/bug-2543-gsd-slash-namespace.test.cjs b/tests/bug-2543-gsd-slash-namespace.test.cjs index 709a8402..0a34af80 100644 --- a/tests/bug-2543-gsd-slash-namespace.test.cjs +++ b/tests/bug-2543-gsd-slash-namespace.test.cjs @@ -1,17 +1,31 @@ 'use strict'; /** - * Bug #2543: GSD emits legacy '/gsd-' syntax in 102 places. + * Slash-command namespace invariant (#2543, updated by #2697). * - * Installed commands are under commands/gsd/.md and invoked as - * /gsd:. All internal references must use the colon form. + * History: + * #2543 switched user-facing references from /gsd- (dash) to /gsd: (colon) + * because Claude Code's skill frontmatter used `name: gsd:`. + * #2697 reversed this: Claude Code slash commands are invoked by skill *directory* + * name (gsd-), not frontmatter name. The colon form (/gsd:) does not work + * as a user-typed slash command. Other environment installers (OpenCode, Copilot, + * Antigravity) already transform gsd: → gsd- at install time, so changing the source + * to use gsd- makes all environments consistent. + * + * Invariant enforced here: + * No `/gsd:` pattern in user-facing source text. + * `Skill(skill="gsd:")` calls (no leading slash) are ALLOWED — they use + * frontmatter `name:` resolution internally and are not user-typed commands. + * + * Exceptions: + * - CHANGELOG.md: historical entries document commands under their original names. + * - gsd-sdk / gsd-tools identifiers: never rewritten (not slash commands). */ const { test, describe } = require('node:test'); const assert = require('node:assert/strict'); const fs = require('node:fs'); const path = require('node:path'); -const { execFileSync } = require('node:child_process'); const ROOT = path.join(__dirname, '..'); const COMMANDS_DIR = path.join(ROOT, 'commands', 'gsd'); @@ -43,24 +57,26 @@ const cmdNames = fs.readdirSync(COMMANDS_DIR) .map(f => f.replace(/\.md$/, '')) .sort((a, b) => b.length - a.length); -const legacyPattern = new RegExp(`/gsd-(${cmdNames.join('|')})(?=[^a-zA-Z0-9_-]|$)`); +// Matches /gsd: — the retired user-facing format. +// Does NOT match Skill(skill="gsd:") because those have no leading slash. +const retiredPattern = new RegExp(`/gsd:(${cmdNames.join('|')})(?=[^a-zA-Z0-9_-]|$)`); const allFiles = SEARCH_DIRS.flatMap(d => collectFiles(d)); -describe('slash-command namespace fix (#2543)', () => { +describe('slash-command namespace invariant (#2697)', () => { test('commands/gsd/ directory contains known command files', () => { assert.ok(cmdNames.length > 0, 'commands/gsd/ must contain .md files'); assert.ok(cmdNames.includes('plan-phase'), 'plan-phase must be a known command'); assert.ok(cmdNames.includes('execute-phase'), 'execute-phase must be a known command'); }); - test('no /gsd- legacy syntax remains in source files', () => { + test('no /gsd: retired syntax in user-facing source files', () => { const violations = []; for (const file of allFiles) { const src = fs.readFileSync(file, 'utf-8'); const lines = src.split('\n'); for (let i = 0; i < lines.length; i++) { - if (legacyPattern.test(lines[i])) { + if (retiredPattern.test(lines[i])) { violations.push(`${path.relative(ROOT, file)}:${i + 1}: ${lines[i].trim().slice(0, 80)}`); } } @@ -68,7 +84,7 @@ describe('slash-command namespace fix (#2543)', () => { assert.strictEqual( violations.length, 0, - `Found ${violations.length} legacy /gsd- reference(s):\n${violations.slice(0, 10).join('\n')}`, + `Found ${violations.length} retired /gsd: reference(s) — use /gsd- instead:\n${violations.slice(0, 10).join('\n')}`, ); }); @@ -77,11 +93,11 @@ describe('slash-command namespace fix (#2543)', () => { const src = fs.readFileSync(file, 'utf-8'); assert.ok( !src.includes('/gsd:sdk'), - `${path.relative(ROOT, file)} must not contain /gsd:sdk (gsd-sdk was incorrectly renamed)`, + `${path.relative(ROOT, file)} must not contain /gsd:sdk (gsd-sdk is not a slash command)`, ); assert.ok( !src.includes('/gsd:tools'), - `${path.relative(ROOT, file)} must not contain /gsd:tools (gsd-tools was incorrectly renamed)`, + `${path.relative(ROOT, file)} must not contain /gsd:tools (gsd-tools is not a slash command)`, ); } }); diff --git a/tests/claude-md.test.cjs b/tests/claude-md.test.cjs index 7de5122b..c26a4560 100644 --- a/tests/claude-md.test.cjs +++ b/tests/claude-md.test.cjs @@ -36,9 +36,9 @@ describe('generate-claude-md', () => { const claudePath = path.join(tmpDir, 'CLAUDE.md'); const content = fs.readFileSync(claudePath, 'utf-8'); assert.ok(content.includes('## GSD Workflow Enforcement')); - assert.ok(content.includes('/gsd:quick')); - assert.ok(content.includes('/gsd:debug')); - assert.ok(content.includes('/gsd:execute-phase')); + assert.ok(content.includes('/gsd-quick')); + assert.ok(content.includes('/gsd-debug')); + assert.ok(content.includes('/gsd-execute-phase')); assert.ok(content.includes('Do not make direct repo edits outside a GSD workflow')); }); diff --git a/tests/settings-integrations.test.cjs b/tests/settings-integrations.test.cjs index 7dedd888..3115cbcf 100644 --- a/tests/settings-integrations.test.cjs +++ b/tests/settings-integrations.test.cjs @@ -260,14 +260,14 @@ describe('#2529 config merge safety', () => { }); }); -// ─── /gsd:settings mentions /gsd:settings-integrations ─────────────────────── +// ─── /gsd-settings mentions /gsd-settings-integrations ────────────────────── -describe('#2529 /gsd:settings mentions new command', () => { - test('settings workflow mentions /gsd:settings-integrations in its confirmation output', () => { +describe('#2529 /gsd-settings mentions new command', () => { + test('settings workflow mentions /gsd-settings-integrations in its confirmation output', () => { const src = fs.readFileSync(SETTINGS_WORKFLOW_PATH, 'utf-8'); assert.ok( - src.includes('/gsd:settings-integrations') || src.includes('/gsd-settings-integrations'), - 'settings.md must mention /gsd:settings-integrations as a follow-up' + src.includes('/gsd-settings-integrations'), + 'settings.md must mention /gsd-settings-integrations as a follow-up' ); }); });