@therocketcode/gsd-core 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (568) hide show
  1. package/.claude-plugin/plugin.json +23 -0
  2. package/GEMINI.md +53 -0
  3. package/LICENSE +21 -0
  4. package/README.ja-JP.md +125 -0
  5. package/README.ko-KR.md +125 -0
  6. package/README.md +144 -0
  7. package/README.pt-BR.md +125 -0
  8. package/README.zh-CN.md +125 -0
  9. package/agents/gsd-advisor-researcher.md +108 -0
  10. package/agents/gsd-ai-researcher.md +114 -0
  11. package/agents/gsd-assumptions-analyzer.md +105 -0
  12. package/agents/gsd-code-fixer.md +668 -0
  13. package/agents/gsd-code-reviewer.md +387 -0
  14. package/agents/gsd-codebase-mapper.md +853 -0
  15. package/agents/gsd-debug-session-manager.md +314 -0
  16. package/agents/gsd-debugger.md +1452 -0
  17. package/agents/gsd-doc-classifier.md +168 -0
  18. package/agents/gsd-doc-synthesizer.md +204 -0
  19. package/agents/gsd-doc-verifier.md +217 -0
  20. package/agents/gsd-doc-writer.md +616 -0
  21. package/agents/gsd-domain-researcher.md +147 -0
  22. package/agents/gsd-eval-auditor.md +191 -0
  23. package/agents/gsd-eval-planner.md +154 -0
  24. package/agents/gsd-executor.md +785 -0
  25. package/agents/gsd-framework-selector.md +160 -0
  26. package/agents/gsd-integration-checker.md +470 -0
  27. package/agents/gsd-intel-updater.md +342 -0
  28. package/agents/gsd-nyquist-auditor.md +203 -0
  29. package/agents/gsd-pattern-mapper.md +335 -0
  30. package/agents/gsd-phase-researcher.md +867 -0
  31. package/agents/gsd-plan-checker.md +978 -0
  32. package/agents/gsd-planner.md +1204 -0
  33. package/agents/gsd-project-researcher.md +611 -0
  34. package/agents/gsd-research-synthesizer.md +259 -0
  35. package/agents/gsd-roadmapper.md +688 -0
  36. package/agents/gsd-security-auditor.md +155 -0
  37. package/agents/gsd-ui-auditor.md +495 -0
  38. package/agents/gsd-ui-checker.md +309 -0
  39. package/agents/gsd-ui-researcher.md +374 -0
  40. package/agents/gsd-user-profiler.md +171 -0
  41. package/agents/gsd-verifier.md +923 -0
  42. package/assets/gsd-logo-2000-transparent.png +0 -0
  43. package/assets/gsd-logo-2000-transparent.svg +17 -0
  44. package/assets/gsd-logo-2000.png +0 -0
  45. package/assets/gsd-logo-2000.svg +21 -0
  46. package/assets/terminal.svg +68 -0
  47. package/bin/install.js +12726 -0
  48. package/bin/lib/ui-safety-gate.cjs +107 -0
  49. package/commands/gsd/add-tests.md +42 -0
  50. package/commands/gsd/ai-integration-phase.md +37 -0
  51. package/commands/gsd/audit-fix.md +34 -0
  52. package/commands/gsd/audit-milestone.md +37 -0
  53. package/commands/gsd/audit-uat.md +24 -0
  54. package/commands/gsd/autonomous.md +48 -0
  55. package/commands/gsd/capture.md +62 -0
  56. package/commands/gsd/cleanup.md +24 -0
  57. package/commands/gsd/code-review.md +59 -0
  58. package/commands/gsd/complete-milestone.md +143 -0
  59. package/commands/gsd/config.md +56 -0
  60. package/commands/gsd/debug.md +52 -0
  61. package/commands/gsd/discover-product.md +65 -0
  62. package/commands/gsd/discuss-phase.md +77 -0
  63. package/commands/gsd/docs-update.md +49 -0
  64. package/commands/gsd/eval-review.md +33 -0
  65. package/commands/gsd/execute-phase.md +66 -0
  66. package/commands/gsd/explore.md +27 -0
  67. package/commands/gsd/extract-learnings.md +23 -0
  68. package/commands/gsd/fast.md +31 -0
  69. package/commands/gsd/forensics.md +57 -0
  70. package/commands/gsd/graphify.md +204 -0
  71. package/commands/gsd/health.md +31 -0
  72. package/commands/gsd/help.md +28 -0
  73. package/commands/gsd/import.md +45 -0
  74. package/commands/gsd/inbox.md +39 -0
  75. package/commands/gsd/ingest-docs.md +42 -0
  76. package/commands/gsd/manager.md +45 -0
  77. package/commands/gsd/map-codebase.md +83 -0
  78. package/commands/gsd/milestone-summary.md +51 -0
  79. package/commands/gsd/model-domain.md +65 -0
  80. package/commands/gsd/mvp-phase.md +45 -0
  81. package/commands/gsd/new-milestone.md +45 -0
  82. package/commands/gsd/new-project.md +47 -0
  83. package/commands/gsd/ns-context.md +23 -0
  84. package/commands/gsd/ns-ideate.md +24 -0
  85. package/commands/gsd/ns-manage.md +29 -0
  86. package/commands/gsd/ns-project.md +22 -0
  87. package/commands/gsd/ns-review.md +26 -0
  88. package/commands/gsd/ns-workflow.md +28 -0
  89. package/commands/gsd/pause-work.md +43 -0
  90. package/commands/gsd/phase.md +56 -0
  91. package/commands/gsd/plan-phase.md +64 -0
  92. package/commands/gsd/plan-review-convergence.md +59 -0
  93. package/commands/gsd/pr-branch.md +26 -0
  94. package/commands/gsd/profile-user.md +46 -0
  95. package/commands/gsd/progress.md +48 -0
  96. package/commands/gsd/quick.md +174 -0
  97. package/commands/gsd/recommend-architecture.md +64 -0
  98. package/commands/gsd/resume-work.md +30 -0
  99. package/commands/gsd/review-backlog.md +63 -0
  100. package/commands/gsd/review.md +42 -0
  101. package/commands/gsd/secure-phase.md +36 -0
  102. package/commands/gsd/settings.md +29 -0
  103. package/commands/gsd/ship.md +24 -0
  104. package/commands/gsd/sketch.md +60 -0
  105. package/commands/gsd/spec-phase.md +63 -0
  106. package/commands/gsd/spike.md +57 -0
  107. package/commands/gsd/stats.md +20 -0
  108. package/commands/gsd/surface.md +155 -0
  109. package/commands/gsd/testing-strategy.md +65 -0
  110. package/commands/gsd/thread.md +24 -0
  111. package/commands/gsd/ui-phase.md +35 -0
  112. package/commands/gsd/ui-review.md +33 -0
  113. package/commands/gsd/ultraplan-phase.md +34 -0
  114. package/commands/gsd/undo.md +35 -0
  115. package/commands/gsd/update.md +49 -0
  116. package/commands/gsd/validate-phase.md +36 -0
  117. package/commands/gsd/verify-work.md +39 -0
  118. package/commands/gsd/workspace.md +52 -0
  119. package/commands/gsd/workstreams.md +70 -0
  120. package/gemini-extension.json +6 -0
  121. package/gsd-core/bin/check-latest-version.cjs +161 -0
  122. package/gsd-core/bin/gsd-tools.cjs +1928 -0
  123. package/gsd-core/bin/lib/active-workstream-store.cjs +291 -0
  124. package/gsd-core/bin/lib/adr-parser.cjs +399 -0
  125. package/gsd-core/bin/lib/agent-command-router.cjs +68 -0
  126. package/gsd-core/bin/lib/artifacts.cjs +51 -0
  127. package/gsd-core/bin/lib/audit.cjs +743 -0
  128. package/gsd-core/bin/lib/check-command-router.cjs +343 -0
  129. package/gsd-core/bin/lib/cjs-command-router-adapter.cjs +81 -0
  130. package/gsd-core/bin/lib/cli-exit.cjs +42 -0
  131. package/gsd-core/bin/lib/clock.cjs +95 -0
  132. package/gsd-core/bin/lib/clusters.cjs +132 -0
  133. package/gsd-core/bin/lib/code-review-flags.cjs +59 -0
  134. package/gsd-core/bin/lib/command-aliases.cjs +809 -0
  135. package/gsd-core/bin/lib/command-arg-projection.cjs +55 -0
  136. package/gsd-core/bin/lib/command-routing-hub.cjs +300 -0
  137. package/gsd-core/bin/lib/commands.cjs +1203 -0
  138. package/gsd-core/bin/lib/config-schema.cjs +29 -0
  139. package/gsd-core/bin/lib/config-types.cjs +19 -0
  140. package/gsd-core/bin/lib/config.cjs +738 -0
  141. package/gsd-core/bin/lib/configuration.cjs +239 -0
  142. package/gsd-core/bin/lib/context-utilization.cjs +48 -0
  143. package/gsd-core/bin/lib/core.cjs +2051 -0
  144. package/gsd-core/bin/lib/decisions.cjs +118 -0
  145. package/gsd-core/bin/lib/docs.cjs +252 -0
  146. package/gsd-core/bin/lib/drift.cjs +364 -0
  147. package/gsd-core/bin/lib/fallow-runner.cjs +115 -0
  148. package/gsd-core/bin/lib/frontmatter.cjs +442 -0
  149. package/gsd-core/bin/lib/gap-checker.cjs +257 -0
  150. package/gsd-core/bin/lib/graphify.cjs +496 -0
  151. package/gsd-core/bin/lib/gsd2-import.cjs +456 -0
  152. package/gsd-core/bin/lib/init-command-router.cjs +62 -0
  153. package/gsd-core/bin/lib/init.cjs +1815 -0
  154. package/gsd-core/bin/lib/install-profiles.cjs +584 -0
  155. package/gsd-core/bin/lib/installer-migration-authoring.cjs +122 -0
  156. package/gsd-core/bin/lib/installer-migration-report.cjs +350 -0
  157. package/gsd-core/bin/lib/installer-migrations/000-first-time-baseline.cjs +218 -0
  158. package/gsd-core/bin/lib/installer-migrations/001-legacy-orphan-files.cjs +48 -0
  159. package/gsd-core/bin/lib/installer-migrations/002-codex-legacy-hooks-json.cjs +94 -0
  160. package/gsd-core/bin/lib/installer-migrations/003-rename-get-shit-done-to-gsd-core.cjs +108 -0
  161. package/gsd-core/bin/lib/installer-migrations.cjs +823 -0
  162. package/gsd-core/bin/lib/intel.cjs +590 -0
  163. package/gsd-core/bin/lib/learnings.cjs +270 -0
  164. package/gsd-core/bin/lib/legacy-cleanup.cjs +253 -0
  165. package/gsd-core/bin/lib/milestone.cjs +373 -0
  166. package/gsd-core/bin/lib/model-catalog.cjs +154 -0
  167. package/gsd-core/bin/lib/model-profiles.cjs +24 -0
  168. package/gsd-core/bin/lib/observability/event.cjs +51 -0
  169. package/gsd-core/bin/lib/observability/logger.cjs +146 -0
  170. package/gsd-core/bin/lib/observability/redaction.cjs +48 -0
  171. package/gsd-core/bin/lib/package-identity.cjs +35 -0
  172. package/gsd-core/bin/lib/package-legitimacy.cjs +368 -0
  173. package/gsd-core/bin/lib/phase-command-router.cjs +189 -0
  174. package/gsd-core/bin/lib/phase-lifecycle.cjs +74 -0
  175. package/gsd-core/bin/lib/phase.cjs +1307 -0
  176. package/gsd-core/bin/lib/phases-command-router.cjs +43 -0
  177. package/gsd-core/bin/lib/plan-scan.cjs +91 -0
  178. package/gsd-core/bin/lib/planning-workspace.cjs +245 -0
  179. package/gsd-core/bin/lib/profile-output.cjs +1120 -0
  180. package/gsd-core/bin/lib/profile-pipeline.cjs +517 -0
  181. package/gsd-core/bin/lib/project-root.cjs +119 -0
  182. package/gsd-core/bin/lib/prompt-budget.cjs +305 -0
  183. package/gsd-core/bin/lib/research-provider.cjs +137 -0
  184. package/gsd-core/bin/lib/research-store.cjs +167 -0
  185. package/gsd-core/bin/lib/review-reviewer-selection.cjs +121 -0
  186. package/gsd-core/bin/lib/roadmap-command-router.cjs +166 -0
  187. package/gsd-core/bin/lib/roadmap-upgrade.cjs +476 -0
  188. package/gsd-core/bin/lib/roadmap.cjs +600 -0
  189. package/gsd-core/bin/lib/runtime-artifact-layout.cjs +312 -0
  190. package/gsd-core/bin/lib/runtime-config-adapter-registry.cjs +56 -0
  191. package/gsd-core/bin/lib/runtime-homes.cjs +190 -0
  192. package/gsd-core/bin/lib/runtime-name-policy.cjs +96 -0
  193. package/gsd-core/bin/lib/runtime-slash.cjs +119 -0
  194. package/gsd-core/bin/lib/schema-detect.cjs +159 -0
  195. package/gsd-core/bin/lib/secrets.cjs +34 -0
  196. package/gsd-core/bin/lib/security.cjs +480 -0
  197. package/gsd-core/bin/lib/semver-compare.cjs +42 -0
  198. package/gsd-core/bin/lib/shell-command-projection.cjs +533 -0
  199. package/gsd-core/bin/lib/state-command-router.cjs +160 -0
  200. package/gsd-core/bin/lib/state-document.cjs +259 -0
  201. package/gsd-core/bin/lib/state.cjs +2010 -0
  202. package/gsd-core/bin/lib/surface.cjs +449 -0
  203. package/gsd-core/bin/lib/task-command-router.cjs +85 -0
  204. package/gsd-core/bin/lib/template.cjs +237 -0
  205. package/gsd-core/bin/lib/uat.cjs +297 -0
  206. package/gsd-core/bin/lib/ui-safety-gate.cjs +98 -0
  207. package/gsd-core/bin/lib/update-context.cjs +218 -0
  208. package/gsd-core/bin/lib/validate-command-router.cjs +91 -0
  209. package/gsd-core/bin/lib/validate.cjs +112 -0
  210. package/gsd-core/bin/lib/verification-command-router.cjs +31 -0
  211. package/gsd-core/bin/lib/verification.cjs +193 -0
  212. package/gsd-core/bin/lib/verify-command-router.cjs +44 -0
  213. package/gsd-core/bin/lib/verify.cjs +1451 -0
  214. package/gsd-core/bin/lib/workstream-inventory-builder.cjs +81 -0
  215. package/gsd-core/bin/lib/workstream-inventory.cjs +147 -0
  216. package/gsd-core/bin/lib/workstream-name-policy.cjs +91 -0
  217. package/gsd-core/bin/lib/workstream.cjs +380 -0
  218. package/gsd-core/bin/lib/worktree-base-ref.cjs +325 -0
  219. package/gsd-core/bin/lib/worktree-safety.cjs +943 -0
  220. package/gsd-core/bin/shared/config-defaults.manifest.json +98 -0
  221. package/gsd-core/bin/shared/config-schema.manifest.json +192 -0
  222. package/gsd-core/bin/shared/model-catalog.json +149 -0
  223. package/gsd-core/bin/shared/runtime-aliases.manifest.json +75 -0
  224. package/gsd-core/bin/verify-reapply-patches.cjs +349 -0
  225. package/gsd-core/contexts/dev.md +21 -0
  226. package/gsd-core/contexts/research.md +22 -0
  227. package/gsd-core/contexts/review.md +23 -0
  228. package/gsd-core/references/agent-contracts.md +79 -0
  229. package/gsd-core/references/ai-evals.md +156 -0
  230. package/gsd-core/references/ai-frameworks.md +186 -0
  231. package/gsd-core/references/architecture-decision.md +74 -0
  232. package/gsd-core/references/artifact-types.md +131 -0
  233. package/gsd-core/references/auth-in-tests.md +91 -0
  234. package/gsd-core/references/autonomous-smart-discuss.md +277 -0
  235. package/gsd-core/references/checkpoints.md +814 -0
  236. package/gsd-core/references/common-bug-patterns.md +114 -0
  237. package/gsd-core/references/context-budget.md +85 -0
  238. package/gsd-core/references/continuation-format.md +253 -0
  239. package/gsd-core/references/db-test-isolation.md +54 -0
  240. package/gsd-core/references/debugger-philosophy.md +76 -0
  241. package/gsd-core/references/decimal-phase-calculation.md +64 -0
  242. package/gsd-core/references/doc-conflict-engine.md +91 -0
  243. package/gsd-core/references/domain-modeling.md +80 -0
  244. package/gsd-core/references/domain-probes.md +125 -0
  245. package/gsd-core/references/e2e-tiering.md +35 -0
  246. package/gsd-core/references/execute-mvp-tdd.md +81 -0
  247. package/gsd-core/references/executor-examples.md +110 -0
  248. package/gsd-core/references/few-shot-examples/plan-checker.md +73 -0
  249. package/gsd-core/references/few-shot-examples/verifier.md +109 -0
  250. package/gsd-core/references/flaky-test-checklist.md +22 -0
  251. package/gsd-core/references/gate-prompts.md +100 -0
  252. package/gsd-core/references/gates.md +70 -0
  253. package/gsd-core/references/git-integration.md +298 -0
  254. package/gsd-core/references/git-planning-commit.md +40 -0
  255. package/gsd-core/references/ios-scaffold.md +123 -0
  256. package/gsd-core/references/mandatory-initial-read.md +2 -0
  257. package/gsd-core/references/model-profile-resolution.md +38 -0
  258. package/gsd-core/references/model-profiles.md +245 -0
  259. package/gsd-core/references/mvp-concepts.md +49 -0
  260. package/gsd-core/references/phase-argument-parsing.md +61 -0
  261. package/gsd-core/references/planner-antipatterns.md +89 -0
  262. package/gsd-core/references/planner-chunked.md +49 -0
  263. package/gsd-core/references/planner-gap-closure.md +62 -0
  264. package/gsd-core/references/planner-graphify-auto-update.md +67 -0
  265. package/gsd-core/references/planner-human-verify-mode.md +57 -0
  266. package/gsd-core/references/planner-interface-context.md +62 -0
  267. package/gsd-core/references/planner-load-graph-context.md +36 -0
  268. package/gsd-core/references/planner-mvp-mode.md +53 -0
  269. package/gsd-core/references/planner-reviews.md +39 -0
  270. package/gsd-core/references/planner-revision.md +87 -0
  271. package/gsd-core/references/planner-source-audit.md +73 -0
  272. package/gsd-core/references/planning-config.md +473 -0
  273. package/gsd-core/references/product-discovery.md +49 -0
  274. package/gsd-core/references/project-skills-discovery.md +19 -0
  275. package/gsd-core/references/questioning.md +162 -0
  276. package/gsd-core/references/realistic-test-data.md +44 -0
  277. package/gsd-core/references/research-documentation-lookup.md +29 -0
  278. package/gsd-core/references/research-philosophy.md +29 -0
  279. package/gsd-core/references/research-verification-protocol.md +27 -0
  280. package/gsd-core/references/revision-loop.md +97 -0
  281. package/gsd-core/references/scout-codebase.md +51 -0
  282. package/gsd-core/references/skeleton-template.md +48 -0
  283. package/gsd-core/references/sketch-interactivity.md +41 -0
  284. package/gsd-core/references/sketch-theme-system.md +94 -0
  285. package/gsd-core/references/sketch-tooling.md +45 -0
  286. package/gsd-core/references/sketch-variant-patterns.md +81 -0
  287. package/gsd-core/references/spidr-splitting.md +69 -0
  288. package/gsd-core/references/tdd.md +330 -0
  289. package/gsd-core/references/test-containers.md +55 -0
  290. package/gsd-core/references/test-strategy.md +75 -0
  291. package/gsd-core/references/thinking-models-debug.md +44 -0
  292. package/gsd-core/references/thinking-models-execution.md +50 -0
  293. package/gsd-core/references/thinking-models-planning.md +62 -0
  294. package/gsd-core/references/thinking-models-research.md +50 -0
  295. package/gsd-core/references/thinking-models-verification.md +55 -0
  296. package/gsd-core/references/thinking-partner.md +96 -0
  297. package/gsd-core/references/ui-brand.md +162 -0
  298. package/gsd-core/references/universal-anti-patterns.md +63 -0
  299. package/gsd-core/references/user-profiling.md +681 -0
  300. package/gsd-core/references/user-story-template.md +58 -0
  301. package/gsd-core/references/verification-overrides.md +227 -0
  302. package/gsd-core/references/verification-patterns.md +612 -0
  303. package/gsd-core/references/verify-mvp-mode.md +85 -0
  304. package/gsd-core/references/workstream-flag.md +111 -0
  305. package/gsd-core/references/worktree-branch-check.md +38 -0
  306. package/gsd-core/references/worktree-path-safety.md +67 -0
  307. package/gsd-core/templates/AI-SPEC.md +246 -0
  308. package/gsd-core/templates/DEBUG.md +169 -0
  309. package/gsd-core/templates/README.md +77 -0
  310. package/gsd-core/templates/SECURITY.md +61 -0
  311. package/gsd-core/templates/UAT.md +265 -0
  312. package/gsd-core/templates/UI-SPEC.md +100 -0
  313. package/gsd-core/templates/VALIDATION.md +76 -0
  314. package/gsd-core/templates/adr.md +58 -0
  315. package/gsd-core/templates/claude-md.md +145 -0
  316. package/gsd-core/templates/codebase/architecture.md +255 -0
  317. package/gsd-core/templates/codebase/concerns.md +310 -0
  318. package/gsd-core/templates/codebase/conventions.md +307 -0
  319. package/gsd-core/templates/codebase/integrations.md +280 -0
  320. package/gsd-core/templates/codebase/stack.md +186 -0
  321. package/gsd-core/templates/codebase/structure.md +285 -0
  322. package/gsd-core/templates/codebase/testing.md +480 -0
  323. package/gsd-core/templates/config.json +62 -0
  324. package/gsd-core/templates/context.md +352 -0
  325. package/gsd-core/templates/continue-here.md +78 -0
  326. package/gsd-core/templates/copilot-instructions.md +7 -0
  327. package/gsd-core/templates/debug-subagent-prompt.md +91 -0
  328. package/gsd-core/templates/dev-preferences.md +21 -0
  329. package/gsd-core/templates/discovery.md +146 -0
  330. package/gsd-core/templates/discussion-log.md +63 -0
  331. package/gsd-core/templates/domain-model.md +54 -0
  332. package/gsd-core/templates/milestone-archive.md +123 -0
  333. package/gsd-core/templates/milestone.md +115 -0
  334. package/gsd-core/templates/phase-prompt.md +610 -0
  335. package/gsd-core/templates/planner-subagent-prompt.md +117 -0
  336. package/gsd-core/templates/product-brief.md +55 -0
  337. package/gsd-core/templates/project.md +186 -0
  338. package/gsd-core/templates/requirements.md +231 -0
  339. package/gsd-core/templates/research-project/ARCHITECTURE.md +204 -0
  340. package/gsd-core/templates/research-project/FEATURES.md +147 -0
  341. package/gsd-core/templates/research-project/PITFALLS.md +200 -0
  342. package/gsd-core/templates/research-project/STACK.md +120 -0
  343. package/gsd-core/templates/research-project/SUMMARY.md +170 -0
  344. package/gsd-core/templates/research.md +592 -0
  345. package/gsd-core/templates/retrospective.md +54 -0
  346. package/gsd-core/templates/roadmap.md +202 -0
  347. package/gsd-core/templates/spec.md +307 -0
  348. package/gsd-core/templates/state.md +195 -0
  349. package/gsd-core/templates/summary-complex.md +59 -0
  350. package/gsd-core/templates/summary-minimal.md +41 -0
  351. package/gsd-core/templates/summary-standard.md +48 -0
  352. package/gsd-core/templates/summary.md +248 -0
  353. package/gsd-core/templates/test-strategy.md +50 -0
  354. package/gsd-core/templates/user-profile.md +146 -0
  355. package/gsd-core/templates/user-setup.md +311 -0
  356. package/gsd-core/templates/verification-report.md +322 -0
  357. package/gsd-core/workflows/_runtime-launcher.snippet.sh +1 -0
  358. package/gsd-core/workflows/add-backlog.md +91 -0
  359. package/gsd-core/workflows/add-phase.md +113 -0
  360. package/gsd-core/workflows/add-tests.md +355 -0
  361. package/gsd-core/workflows/add-todo.md +161 -0
  362. package/gsd-core/workflows/ai-integration-phase.md +295 -0
  363. package/gsd-core/workflows/analyze-dependencies.md +96 -0
  364. package/gsd-core/workflows/audit-fix.md +178 -0
  365. package/gsd-core/workflows/audit-milestone.md +360 -0
  366. package/gsd-core/workflows/audit-uat.md +110 -0
  367. package/gsd-core/workflows/autonomous.md +797 -0
  368. package/gsd-core/workflows/check-todos.md +180 -0
  369. package/gsd-core/workflows/cleanup.md +195 -0
  370. package/gsd-core/workflows/code-review-fix.md +502 -0
  371. package/gsd-core/workflows/code-review.md +658 -0
  372. package/gsd-core/workflows/complete-milestone.md +855 -0
  373. package/gsd-core/workflows/debug.md +237 -0
  374. package/gsd-core/workflows/diagnose-issues.md +245 -0
  375. package/gsd-core/workflows/discover-product.md +112 -0
  376. package/gsd-core/workflows/discovery-phase.md +291 -0
  377. package/gsd-core/workflows/discuss-phase/modes/advisor.md +176 -0
  378. package/gsd-core/workflows/discuss-phase/modes/all.md +28 -0
  379. package/gsd-core/workflows/discuss-phase/modes/analyze.md +44 -0
  380. package/gsd-core/workflows/discuss-phase/modes/auto.md +57 -0
  381. package/gsd-core/workflows/discuss-phase/modes/batch.md +52 -0
  382. package/gsd-core/workflows/discuss-phase/modes/chain.md +98 -0
  383. package/gsd-core/workflows/discuss-phase/modes/default.md +141 -0
  384. package/gsd-core/workflows/discuss-phase/modes/power.md +44 -0
  385. package/gsd-core/workflows/discuss-phase/modes/text.md +55 -0
  386. package/gsd-core/workflows/discuss-phase/templates/checkpoint.json +18 -0
  387. package/gsd-core/workflows/discuss-phase/templates/context.md +136 -0
  388. package/gsd-core/workflows/discuss-phase/templates/discussion-log.md +50 -0
  389. package/gsd-core/workflows/discuss-phase-assumptions.md +675 -0
  390. package/gsd-core/workflows/discuss-phase-power.md +291 -0
  391. package/gsd-core/workflows/discuss-phase.md +499 -0
  392. package/gsd-core/workflows/do.md +111 -0
  393. package/gsd-core/workflows/docs-update.md +1176 -0
  394. package/gsd-core/workflows/edit-phase.md +295 -0
  395. package/gsd-core/workflows/eval-review.md +156 -0
  396. package/gsd-core/workflows/execute-phase/steps/codebase-drift-gate.md +95 -0
  397. package/gsd-core/workflows/execute-phase/steps/per-plan-worktree-gate.md +94 -0
  398. package/gsd-core/workflows/execute-phase/steps/post-merge-gate.md +117 -0
  399. package/gsd-core/workflows/execute-phase.md +1752 -0
  400. package/gsd-core/workflows/execute-plan.md +526 -0
  401. package/gsd-core/workflows/explore.md +146 -0
  402. package/gsd-core/workflows/extract-learnings.md +243 -0
  403. package/gsd-core/workflows/fast.md +124 -0
  404. package/gsd-core/workflows/forensics.md +279 -0
  405. package/gsd-core/workflows/graduation.md +196 -0
  406. package/gsd-core/workflows/health.md +224 -0
  407. package/gsd-core/workflows/help/modes/brief.md +22 -0
  408. package/gsd-core/workflows/help/modes/default.md +50 -0
  409. package/gsd-core/workflows/help/modes/full.md +789 -0
  410. package/gsd-core/workflows/help/modes/topic.md +74 -0
  411. package/gsd-core/workflows/help.md +24 -0
  412. package/gsd-core/workflows/import.md +256 -0
  413. package/gsd-core/workflows/inbox.md +387 -0
  414. package/gsd-core/workflows/ingest-docs.md +340 -0
  415. package/gsd-core/workflows/insert-phase.md +152 -0
  416. package/gsd-core/workflows/list-phase-assumptions.md +178 -0
  417. package/gsd-core/workflows/list-workspaces.md +57 -0
  418. package/gsd-core/workflows/manager.md +393 -0
  419. package/gsd-core/workflows/map-codebase.md +446 -0
  420. package/gsd-core/workflows/milestone-summary.md +224 -0
  421. package/gsd-core/workflows/model-domain.md +162 -0
  422. package/gsd-core/workflows/mvp-phase.md +222 -0
  423. package/gsd-core/workflows/new-milestone.md +635 -0
  424. package/gsd-core/workflows/new-project.md +1555 -0
  425. package/gsd-core/workflows/new-workspace.md +240 -0
  426. package/gsd-core/workflows/next.md +299 -0
  427. package/gsd-core/workflows/node-repair.md +92 -0
  428. package/gsd-core/workflows/note.md +158 -0
  429. package/gsd-core/workflows/pause-work.md +244 -0
  430. package/gsd-core/workflows/plan-milestone-gaps.md +281 -0
  431. package/gsd-core/workflows/plan-phase.md +1814 -0
  432. package/gsd-core/workflows/plan-review-convergence.md +346 -0
  433. package/gsd-core/workflows/plant-seed.md +230 -0
  434. package/gsd-core/workflows/pr-branch.md +157 -0
  435. package/gsd-core/workflows/profile-user.md +453 -0
  436. package/gsd-core/workflows/progress.md +699 -0
  437. package/gsd-core/workflows/quick.md +1017 -0
  438. package/gsd-core/workflows/reapply-patches.md +426 -0
  439. package/gsd-core/workflows/recommend-architecture.md +135 -0
  440. package/gsd-core/workflows/remove-phase.md +156 -0
  441. package/gsd-core/workflows/remove-workspace.md +108 -0
  442. package/gsd-core/workflows/resume-project.md +332 -0
  443. package/gsd-core/workflows/review.md +748 -0
  444. package/gsd-core/workflows/scan.md +107 -0
  445. package/gsd-core/workflows/secure-phase.md +182 -0
  446. package/gsd-core/workflows/session-report.md +146 -0
  447. package/gsd-core/workflows/settings-advanced.md +810 -0
  448. package/gsd-core/workflows/settings-integrations.md +312 -0
  449. package/gsd-core/workflows/settings.md +566 -0
  450. package/gsd-core/workflows/ship.md +405 -0
  451. package/gsd-core/workflows/sketch-wrap-up.md +286 -0
  452. package/gsd-core/workflows/sketch.md +361 -0
  453. package/gsd-core/workflows/spec-phase.md +263 -0
  454. package/gsd-core/workflows/spike-wrap-up.md +307 -0
  455. package/gsd-core/workflows/spike.md +453 -0
  456. package/gsd-core/workflows/stats.md +80 -0
  457. package/gsd-core/workflows/sync-skills.md +182 -0
  458. package/gsd-core/workflows/testing-strategy.md +122 -0
  459. package/gsd-core/workflows/thread.md +222 -0
  460. package/gsd-core/workflows/transition.md +694 -0
  461. package/gsd-core/workflows/ui-phase.md +328 -0
  462. package/gsd-core/workflows/ui-review.md +193 -0
  463. package/gsd-core/workflows/ultraplan-phase.md +199 -0
  464. package/gsd-core/workflows/undo.md +314 -0
  465. package/gsd-core/workflows/update.md +496 -0
  466. package/gsd-core/workflows/validate-phase.md +181 -0
  467. package/gsd-core/workflows/verify-phase.md +544 -0
  468. package/gsd-core/workflows/verify-work.md +781 -0
  469. package/hooks/dist/gsd-check-update-worker.js +108 -0
  470. package/hooks/dist/gsd-check-update.js +66 -0
  471. package/hooks/dist/gsd-config-reload.js +133 -0
  472. package/hooks/dist/gsd-context-monitor.js +195 -0
  473. package/hooks/dist/gsd-cursor-post-tool.js +75 -0
  474. package/hooks/dist/gsd-cursor-session-start.js +52 -0
  475. package/hooks/dist/gsd-graphify-update.sh +158 -0
  476. package/hooks/dist/gsd-phase-boundary.sh +47 -0
  477. package/hooks/dist/gsd-prompt-guard.js +97 -0
  478. package/hooks/dist/gsd-read-guard.js +101 -0
  479. package/hooks/dist/gsd-read-injection-scanner.js +203 -0
  480. package/hooks/dist/gsd-session-state.sh +59 -0
  481. package/hooks/dist/gsd-statusline.js +566 -0
  482. package/hooks/dist/gsd-update-banner.js +138 -0
  483. package/hooks/dist/gsd-validate-commit.sh +57 -0
  484. package/hooks/dist/gsd-workflow-guard.js +167 -0
  485. package/hooks/dist/gsd-worktree-path-guard.js +169 -0
  486. package/hooks/dist/lib/git-cmd.js +150 -0
  487. package/hooks/dist/lib/gsd-graphify-rebuild.sh +65 -0
  488. package/hooks/dist/managed-hooks-registry.cjs +38 -0
  489. package/hooks/gsd-check-update-worker.js +108 -0
  490. package/hooks/gsd-check-update.js +66 -0
  491. package/hooks/gsd-config-reload.js +133 -0
  492. package/hooks/gsd-context-monitor.js +195 -0
  493. package/hooks/gsd-cursor-post-tool.js +75 -0
  494. package/hooks/gsd-cursor-session-start.js +52 -0
  495. package/hooks/gsd-graphify-update.sh +158 -0
  496. package/hooks/gsd-phase-boundary.sh +47 -0
  497. package/hooks/gsd-prompt-guard.js +97 -0
  498. package/hooks/gsd-read-guard.js +101 -0
  499. package/hooks/gsd-read-injection-scanner.js +203 -0
  500. package/hooks/gsd-session-state.sh +59 -0
  501. package/hooks/gsd-statusline.js +566 -0
  502. package/hooks/gsd-update-banner.js +138 -0
  503. package/hooks/gsd-validate-commit.sh +57 -0
  504. package/hooks/gsd-workflow-guard.js +167 -0
  505. package/hooks/gsd-worktree-path-guard.js +169 -0
  506. package/hooks/hooks.json +69 -0
  507. package/hooks/lib/git-cmd.js +150 -0
  508. package/hooks/lib/gsd-graphify-rebuild.sh +65 -0
  509. package/hooks/managed-hooks-registry.cjs +38 -0
  510. package/package.json +115 -0
  511. package/scripts/affected-tests-lib.cjs +542 -0
  512. package/scripts/audit-workflow-script-paths.cjs +73 -0
  513. package/scripts/base64-scan.sh +351 -0
  514. package/scripts/build-hooks.js +247 -0
  515. package/scripts/changeset/README.md +129 -0
  516. package/scripts/changeset/cli.cjs +590 -0
  517. package/scripts/changeset/github-release-notes.cjs +199 -0
  518. package/scripts/changeset/lint.cjs +111 -0
  519. package/scripts/changeset/new.cjs +137 -0
  520. package/scripts/changeset/parse.cjs +114 -0
  521. package/scripts/changeset/render.cjs +34 -0
  522. package/scripts/changeset/serialize.cjs +130 -0
  523. package/scripts/check-alias-drift.cjs +114 -0
  524. package/scripts/check-env.cjs +312 -0
  525. package/scripts/check-npm-integrity.cjs +215 -0
  526. package/scripts/ci-guard-runner.cjs +22 -0
  527. package/scripts/ci-prepare-test-scope.cjs +51 -0
  528. package/scripts/ci-rebase-check.cjs +86 -0
  529. package/scripts/ci-test-scope.cjs +431 -0
  530. package/scripts/command-contract-helpers.cjs +64 -0
  531. package/scripts/diff-touches-shipped-paths.cjs +155 -0
  532. package/scripts/fix-slash-commands.cjs +147 -0
  533. package/scripts/gen-inventory-manifest.cjs +115 -0
  534. package/scripts/gen-research-agents.cjs +276 -0
  535. package/scripts/generate-package-identity.cjs +125 -0
  536. package/scripts/issue-dedupe.cjs +278 -0
  537. package/scripts/lib/allowlist-ratchet.cjs +136 -0
  538. package/scripts/lib/cli-exit.cjs +56 -0
  539. package/scripts/lint-command-contract.cjs +114 -0
  540. package/scripts/lint-descriptions.cjs +87 -0
  541. package/scripts/lint-docs-required.cjs +222 -0
  542. package/scripts/lint-legacy-dir-name.cjs +160 -0
  543. package/scripts/lint-package-identity-drift.cjs +141 -0
  544. package/scripts/lint-pr-check-project-dir.cjs +99 -0
  545. package/scripts/lint-shell-command-projection-drift.cjs +62 -0
  546. package/scripts/lint-skill-deps.cjs +185 -0
  547. package/scripts/lint-test-file-count.allowlist.json +135 -0
  548. package/scripts/lint-test-file-count.cjs +246 -0
  549. package/scripts/mutation-matrix.cjs +222 -0
  550. package/scripts/pr-template-policy.cjs +268 -0
  551. package/scripts/prompt-injection-scan.sh +207 -0
  552. package/scripts/release-notes/discord-release-summary.cjs +373 -0
  553. package/scripts/release-notes/format-github-release-notes.cjs +261 -0
  554. package/scripts/release-tarball-smoke.cjs +629 -0
  555. package/scripts/research-profiles.cjs +149 -0
  556. package/scripts/run-affected-tests.cjs +7 -0
  557. package/scripts/run-cross-platform-tests.cjs +67 -0
  558. package/scripts/run-tests.cjs +315 -0
  559. package/scripts/secret-scan-lint.sh +231 -0
  560. package/scripts/secret-scan.sh +358 -0
  561. package/scripts/setup-branch-protection.sh +236 -0
  562. package/scripts/strip-prose-atrefs.cjs +106 -0
  563. package/scripts/sync-manifest-versions.cjs +119 -0
  564. package/scripts/sync-rulesets.sh +34 -0
  565. package/scripts/sync-runtime-launcher.cjs +399 -0
  566. package/scripts/test-failure-reasons.cjs +34 -0
  567. package/scripts/verify-npm-publish.cjs +240 -0
  568. package/scripts/workflow-policy.cjs +450 -0
@@ -0,0 +1,496 @@
1
+ <purpose>
2
+ Check for GSD updates via npm, display changelog for versions between installed and latest, obtain user confirmation, and execute clean installation with cache clearing.
3
+ </purpose>
4
+
5
+ <required_reading>
6
+ Read all files referenced by the invoking prompt's execution_context before starting.
7
+ </required_reading>
8
+
9
+ <process>
10
+
11
+ <step name="get_installed_version">
12
+ Detect the installed GSD version, scope, runtime, and config dir.
13
+
14
+ First, derive `PREFERRED_CONFIG_DIR` and `PREFERRED_RUNTIME` from the invoking prompt's `execution_context` path — this is the one input only the workflow knows:
15
+ - If the path contains `/gsd-core/workflows/update.md`, strip that suffix and store the remainder as `PREFERRED_CONFIG_DIR`.
16
+ - Infer `PREFERRED_RUNTIME` from the path: `/.codex/` -> `codex`; `/.gemini/antigravity-ide/`, `/.gemini/antigravity-cli/`, `/.gemini/antigravity/`, `/.agent/` -> `antigravity` (`.agent` is the local Antigravity install dir; see bin/install.js `getDirName('antigravity')`, #503); `/.gemini/` -> `gemini`; `/.config/kilo/` or `/.kilo/` -> `kilo`; `/.config/opencode/` or `/.opencode/` -> `opencode`; otherwise `claude`.
17
+
18
+ Then resolve the install context via the deterministic projection (#498). **Do NOT re-derive scope, runtime, or version by hand** — `update-context` owns that cascade in tested code (`gsd-core/bin/lib/update-context.cjs`), the same way `check-latest-version` owns the package name (#2992):
19
+
20
+ ```bash
21
+ # Resolve gsd-tools.cjs WITHOUT yet knowing GSD_DIR. The running workflow lives
22
+ # at <PREFERRED_CONFIG_DIR>/gsd-core/workflows/update.md, so its sibling
23
+ # bin/gsd-tools.cjs is the authoritative tool for THIS install. Fall back to a
24
+ # global copy, then to gsd-tools on PATH.
25
+ GSD_TOOLS=""
26
+ for cand in \
27
+ "$PREFERRED_CONFIG_DIR/gsd-core/bin/gsd-tools.cjs" \
28
+ "$HOME/.claude/gsd-core/bin/gsd-tools.cjs"; do
29
+ if [ -n "$cand" ] && [ -f "$cand" ]; then GSD_TOOLS="$cand"; break; fi
30
+ done
31
+ # Last resort: the gsd-tools shim on PATH — resolved to its absolute path and
32
+ # invoked via the variable (never a bare `gsd-tools` command; see #2851).
33
+ if [ -z "$GSD_TOOLS" ] && command -v gsd-tools >/dev/null 2>&1; then
34
+ GSD_TOOLS="$(command -v gsd-tools)"
35
+ fi
36
+
37
+ UC=""
38
+ if [ -n "$GSD_TOOLS" ]; then
39
+ case "$GSD_TOOLS" in
40
+ *.cjs) UC="$(node "$GSD_TOOLS" update-context --config-dir "$PREFERRED_CONFIG_DIR" --runtime "$PREFERRED_RUNTIME" --json 2>/dev/null)" ;;
41
+ *) UC="$("$GSD_TOOLS" update-context --config-dir "$PREFERRED_CONFIG_DIR" --runtime "$PREFERRED_RUNTIME" --json 2>/dev/null)" ;;
42
+ esac
43
+ fi
44
+
45
+ if [ -n "$UC" ]; then
46
+ INSTALLED_VERSION="$(printf '%s' "$UC" | jq -r '.installedVersion')"
47
+ INSTALL_SCOPE="$(printf '%s' "$UC" | jq -r '.scope')"
48
+ TARGET_RUNTIME="$(printf '%s' "$UC" | jq -r '.runtime')"
49
+ GSD_DIR="$(printf '%s' "$UC" | jq -r '.gsdDir')"
50
+ else
51
+ # No tool resolvable / projection failed -> treat as a fresh install.
52
+ INSTALLED_VERSION="0.0.0"
53
+ INSTALL_SCOPE="UNKNOWN"
54
+ TARGET_RUNTIME="claude"
55
+ GSD_DIR=""
56
+ fi
57
+
58
+ echo "$INSTALLED_VERSION"
59
+ echo "$INSTALL_SCOPE"
60
+ echo "$TARGET_RUNTIME"
61
+ echo "$GSD_DIR"
62
+ ```
63
+
64
+ Parse output:
65
+ - Line 1 = installed version (`0.0.0` means unknown version)
66
+ - Line 2 = install scope (`LOCAL`, `GLOBAL`, or `UNKNOWN`)
67
+ - Line 3 = target runtime (`claude`, `opencode`, `gemini`, `kilo`, `codex`, `antigravity`)
68
+ - Line 4 = resolved GSD config dir (e.g. `/Users/me/.claude`, `/Users/me/.gemini`); empty if scope is `UNKNOWN`. Capture this as `GSD_DIR` and pass it to subsequent steps so they don't re-derive the runtime path.
69
+ - If scope is `UNKNOWN`, proceed to install using the `--claude --global` fallback.
70
+
71
+ `update-context` reproduces the previous detection cascade — preferred-config-dir fast path, local-over-global with same-path dedup (so `CWD=$HOME` does not misdetect as LOCAL), env-var overrides (`CLAUDE_CONFIG_DIR`, `OPENCODE_CONFIG_DIR`, `KILO_CONFIG`, `XDG_CONFIG_HOME`, `CODEX_HOME`, …), and semver validation — but as a tested projection rather than ~280 lines of inline bash. Branch coverage lives in `tests/issue-498-update-context.test.cjs`.
72
+
73
+ If multiple runtime installs are detected and the invoking runtime cannot be determined from execution_context, ask the user which runtime to update before running install.
74
+
75
+ **If VERSION file missing (version resolves to `0.0.0`):** report the installed version as Unknown and proceed to install (treated as `0.0.0` for comparison).
76
+ </step>
77
+
78
+ <step name="parse_update_channel">
79
+ Determine the release channel from `$ARGUMENTS`. This selects which npm dist-tag the entire update flow targets — `latest` (stable) by default, or `next` (the RC channel established by ADR #660) when the user opts in with `--next`/`--rc`:
80
+
81
+ ```bash
82
+ case " $ARGUMENTS " in
83
+ *" --next "*|*" --rc "*)
84
+ TAG="next"
85
+ CHANNEL_LABEL="next (RC)"
86
+ ;;
87
+ *)
88
+ TAG="latest"
89
+ CHANNEL_LABEL="latest (stable)"
90
+ ;;
91
+ esac
92
+ ```
93
+
94
+ `TAG` is restricted to `latest`/`next` by `check-latest-version.cjs` (it rejects any other value with exit 2), so no arbitrary dist-tag can leak through. Omitting `--next`/`--rc` reproduces the prior behavior exactly: `TAG=latest`.
95
+ </step>
96
+
97
+ <step name="check_latest_version">
98
+ Check npm for latest version via the deterministic script. **Do NOT run `npm view` or `npm search` directly** — the package name must come from the script, not from a free choice at execution time. (#2992: LLM-driven prescriptions of npm package names produced wrong-package queries; moving the package name into a script constant closes that gap.)
99
+
100
+ The `GSD_DIR` value emitted by `get_installed_version` (line 4) resolves to the runtime-specific config dir (`~/.claude/`, `~/.gemini/`, `~/.codex/`, etc.), so the script invocation works for every runtime — not just Claude. If `GSD_DIR` is empty (scope `UNKNOWN`), skip this step and go directly to install.
101
+
102
+ `LATEST_RESULT` is a JSON document with the documented shape `{ ok: bool, version: string, reason: string, detail?: string }`. Parse via `jq` ONLY when the script actually ran. When `GSD_DIR` is empty (scope `UNKNOWN`), skip the check entirely and seed the parsed fields with their no-op values so downstream logic does not mistake an unset `LATEST_RESULT` for a failed network check (#2993 CR feedback):
103
+
104
+ ```bash
105
+ if [ -z "$GSD_DIR" ]; then
106
+ # No install detected — fall through to install step; version-check is skipped.
107
+ LATEST_RESULT=""
108
+ LATEST_STATUS=0
109
+ LATEST_OK=false
110
+ LATEST_VERSION=""
111
+ LATEST_REASON="no_install_detected"
112
+ else
113
+ LATEST_RESULT="$(node "$GSD_DIR/gsd-core/bin/check-latest-version.cjs" --json --tag "$TAG" 2>/dev/null)"
114
+ LATEST_STATUS=$?
115
+ # #2993 CR: when node is missing or the script doesn't exist, LATEST_RESULT
116
+ # is empty and piping it to `jq` produces a parse error on stderr while
117
+ # leaving LATEST_OK / LATEST_REASON as empty strings. Fail the check with a
118
+ # meaningful reason instead of a blank diagnostic.
119
+ if [ -n "$LATEST_RESULT" ]; then
120
+ LATEST_OK="$(printf '%s' "$LATEST_RESULT" | jq -r '.ok // false')"
121
+ LATEST_VERSION="$(printf '%s' "$LATEST_RESULT" | jq -r '.version // empty')"
122
+ LATEST_REASON="$(printf '%s' "$LATEST_RESULT" | jq -r '.reason // empty')"
123
+ else
124
+ LATEST_OK=false
125
+ LATEST_VERSION=""
126
+ LATEST_REASON="script_not_found_or_node_unavailable"
127
+ fi
128
+ fi
129
+ ```
130
+
131
+ **If `LATEST_OK` is not `true`** (or `LATEST_STATUS` is non-zero):
132
+
133
+ ```text
134
+ Couldn't check for updates (reason: {LATEST_REASON}, exit: {LATEST_STATUS}).
135
+
136
+ To update manually: `npx -y --package=@therocketcode/gsd-core@{TAG} -- gsd-core --global`
137
+ ```
138
+
139
+ Exit.
140
+ </step>
141
+
142
+ <step name="compare_versions">
143
+ Compare installed vs latest:
144
+
145
+ **Only when `TAG=next`** (the user passed `--next`/`--rc`), prepend a channel banner so they know they are leaving the stable line — add this line immediately after the `**Latest:**` line in whichever output block renders:
146
+
147
+ **Channel:** {CHANNEL_LABEL}
148
+
149
+ On the default stable channel (`TAG=latest`), do NOT add a channel line — the output must match the prior stable behavior exactly.
150
+
151
+ When `TAG=next`, the "latest" value is the release candidate published under `@next` (e.g. `1.4.0-rc.1`). Apply standard semver precedence for prereleases (`1.4.0-rc.1` is newer than `1.3.1` but older than the final `1.4.0`). Do NOT treat an `-rc.N` suffix as a dev install or as "behind" — offer it as an available update.
152
+
153
+ **If installed == latest:**
154
+ ```
155
+ ## GSD Update
156
+
157
+ **Installed:** X.Y.Z
158
+ **Latest:** X.Y.Z
159
+
160
+ You're already on the latest version.
161
+ ```
162
+
163
+ Exit.
164
+
165
+ **If installed > latest:**
166
+ ```
167
+ ## GSD Update
168
+
169
+ **Installed:** X.Y.Z
170
+ **Latest:** A.B.C
171
+
172
+ You're ahead of the latest release — this looks like a dev install.
173
+
174
+ If you see a "⚠ dev install — re-run installer to sync hooks" warning in
175
+ your statusline, your hook files are older than your VERSION file. Fix it
176
+ by re-running the local installer from your dev branch:
177
+
178
+ node bin/install.js --global --claude
179
+
180
+ Running /gsd:update would install the npm release (A.B.C) and downgrade
181
+ your dev version — do NOT use it to resolve this warning.
182
+ ```
183
+
184
+ Exit.
185
+ </step>
186
+
187
+ <step name="show_changes_and_confirm">
188
+ **If update available**, fetch and show what's new BEFORE updating:
189
+
190
+ 1. Fetch changelog from GitHub raw URL and save to a temp file, e.g. `/tmp/gsd-changelog-$$.md`.
191
+ 2. Extract entries between installed and latest versions using the deterministic range helper (fix for #3496 — do NOT use ad-hoc grep/awk extraction which silently skips intermediate versions):
192
+
193
+ ```bash
194
+ CHANGELOG_TMP="/tmp/gsd-changelog-$$.md"
195
+ curl -fsSL "https://raw.githubusercontent.com/TheRocketCodeMX/gsd-core/main/CHANGELOG.md" -o "$CHANGELOG_TMP" 2>/dev/null \
196
+ || wget -qO "$CHANGELOG_TMP" "https://raw.githubusercontent.com/TheRocketCodeMX/gsd-core/main/CHANGELOG.md" 2>/dev/null
197
+
198
+ EXTRACT_JSON=$(node "$GSD_DIR/gsd-core/scripts/changeset/cli.cjs" extract \
199
+ --from "$INSTALLED_VERSION" \
200
+ --to "$LATEST_VERSION" \
201
+ --changelog "$CHANGELOG_TMP" \
202
+ --json 2>/dev/null)
203
+ EXTRACT_EXIT=$?
204
+
205
+ if [ "$EXTRACT_EXIT" -eq 2 ]; then
206
+ # Exit 2 = no releases in range (e.g. versions are equal or changelog is sparse)
207
+ CHANGELOG_PREVIEW="No changelog updates between v${INSTALLED_VERSION} and v${LATEST_VERSION}."
208
+ elif [ "$EXTRACT_EXIT" -ne 0 ] || [ -z "$EXTRACT_JSON" ]; then
209
+ CHANGELOG_PREVIEW="(Could not extract changelog — update will still proceed)"
210
+ else
211
+ # Re-run without --json to get the human-readable markdown for display
212
+ CHANGELOG_PREVIEW=$(node "$GSD_DIR/gsd-core/scripts/changeset/cli.cjs" extract \
213
+ --from "$INSTALLED_VERSION" \
214
+ --to "$LATEST_VERSION" \
215
+ --changelog "$CHANGELOG_TMP" 2>/dev/null || echo "(changelog unavailable)")
216
+ fi
217
+ # Clean up temp changelog now that both extract runs are done
218
+ rm -f "$CHANGELOG_TMP"
219
+ ```
220
+
221
+ 3. Display preview and ask for confirmation, using `$CHANGELOG_PREVIEW` from the extract step above:
222
+
223
+ ```
224
+ ## GSD Update Available
225
+
226
+ **Installed:** {INSTALLED_VERSION}
227
+ **Latest:** {LATEST_VERSION}
228
+
229
+ ### What's New
230
+ ────────────────────────────────────────────────────────────
231
+
232
+ {CHANGELOG_PREVIEW}
233
+
234
+ ────────────────────────────────────────────────────────────
235
+
236
+ ⚠️ **Note:** The installer performs a clean install of GSD folders:
237
+ - `commands/gsd/` will be wiped and replaced
238
+ - `gsd-core/` will be wiped and replaced
239
+ - `agents/gsd-*` files will be replaced
240
+
241
+ (Paths are relative to detected runtime install location:
242
+ global: `~/.claude/`, `~/.config/opencode/`, `~/.opencode/`, `~/.gemini/`, `~/.config/kilo/`, or `~/.codex/`
243
+ local: `./.claude/`, `./.config/opencode/`, `./.opencode/`, `./.gemini/`, `./.kilo/`, or `./.codex/`)
244
+
245
+ Your custom files in other locations are preserved:
246
+ - Custom commands not in `commands/gsd/` ✓
247
+ - Custom agents not prefixed with `gsd-` ✓
248
+ - Custom hooks ✓
249
+ - Your CLAUDE.md files ✓
250
+
251
+ If you've modified any GSD files directly, they'll be automatically backed up to `gsd-local-patches/` and can be reapplied with `/gsd:update --reapply` after the update.
252
+ ```
253
+
254
+
255
+ **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.
256
+ Use AskUserQuestion:
257
+ - Question: "Proceed with update?"
258
+ - Options:
259
+ - "Yes, update now"
260
+ - "No, cancel"
261
+
262
+ **If user cancels:** Exit.
263
+ </step>
264
+
265
+ <step name="backup_custom_files">
266
+ Before running the installer, detect and back up any user-added files inside
267
+ GSD-managed directories. These are files that exist on disk but are NOT listed
268
+ in `gsd-file-manifest.json` — i.e., files the user added themselves that the
269
+ installer does not know about and will delete during the wipe.
270
+
271
+ **Do not use bash path-stripping (`${filepath#$RUNTIME_DIR/}`) or `node -e require()`
272
+ inline** — those patterns fail when `$RUNTIME_DIR` is unset and the stripped
273
+ relative path may not match manifest key format, which causes CUSTOM_COUNT=0
274
+ even when custom files exist (bug #1997). Use `gsd-tools.cjs query detect-custom-files`
275
+ or the bundled `gsd-tools.cjs detect-custom-files` path — both resolve paths
276
+ reliably with Node.js `path.relative()`.
277
+
278
+ First, resolve the config directory (`RUNTIME_DIR`) from the install scope
279
+ detected in `get_installed_version`:
280
+
281
+ ```bash
282
+ # RUNTIME_DIR is the resolved config directory (e.g. ~/.config/opencode, ~/.gemini).
283
+ # get_installed_version emits it as GSD_DIR (LOCAL or GLOBAL install dir, or empty
284
+ # when scope is UNKNOWN). Empty RUNTIME_DIR skips the backup below.
285
+ RUNTIME_DIR="$GSD_DIR"
286
+ ```
287
+
288
+ If `RUNTIME_DIR` is empty or does not exist, skip this step (no config dir to
289
+ inspect).
290
+
291
+ Otherwise run `detect-custom-files`:
292
+
293
+ ```bash
294
+ CUSTOM_JSON=''
295
+ if [ -f "$GSD_TOOLS" ] && [ -n "$RUNTIME_DIR" ]; then
296
+ CUSTOM_JSON=$(node "$GSD_TOOLS" detect-custom-files --config-dir "$RUNTIME_DIR" 2>/dev/null)
297
+ fi
298
+ if [ -z "$CUSTOM_JSON" ]; then
299
+ CUSTOM_JSON='{"custom_files":[],"custom_count":0}'
300
+ fi
301
+ CUSTOM_COUNT=$(echo "$CUSTOM_JSON" | node -e "process.stdin.resume();let d='';process.stdin.on('data',c=>d+=c);process.stdin.on('end',()=>{try{console.log(JSON.parse(d).custom_count);}catch{console.log(0);}})" 2>/dev/null || echo "0")
302
+ ```
303
+
304
+ **If `CUSTOM_COUNT` > 0:**
305
+
306
+ Back up each custom file to `$RUNTIME_DIR/gsd-user-files-backup/` before the
307
+ installer wipes the directories:
308
+
309
+ ```bash
310
+ BACKUP_DIR="$RUNTIME_DIR/gsd-user-files-backup"
311
+ mkdir -p "$BACKUP_DIR"
312
+
313
+ # Parse custom_files array from CUSTOM_JSON and copy each file
314
+ node - "$RUNTIME_DIR" "$BACKUP_DIR" "$CUSTOM_JSON" <<'JSEOF'
315
+ const [,, runtimeDir, backupDir, customJson] = process.argv;
316
+ const { custom_files } = JSON.parse(customJson);
317
+ const fs = require('fs');
318
+ const path = require('path');
319
+ for (const relPath of custom_files) {
320
+ const src = path.join(runtimeDir, relPath);
321
+ const dst = path.join(backupDir, relPath);
322
+ if (!fs.existsSync(src)) continue;
323
+
324
+ try {
325
+ fs.mkdirSync(path.dirname(dst), { recursive: true });
326
+ fs.copyFileSync(src, dst);
327
+ console.log(' Backed up: ' + relPath);
328
+ } catch (err) {
329
+ const code = err && err.code ? String(err.code) : 'ERROR';
330
+ console.log(' Skipped (non-fatal): ' + relPath + ' [' + code + ']');
331
+ }
332
+ }
333
+ JSEOF
334
+ ```
335
+
336
+ Then inform the user:
337
+
338
+ ```
339
+ ⚠️ Found N custom file(s) inside GSD-managed directories.
340
+ These have been backed up to gsd-user-files-backup/ before the update.
341
+ Restore them after the update if needed.
342
+ ```
343
+
344
+ **If `CUSTOM_COUNT` == 0:** No user-added files detected. Continue to install.
345
+ </step>
346
+
347
+ <step name="run_update">
348
+ Run the update using the install type detected in step 1:
349
+
350
+ Build runtime flag from step 1:
351
+ ```bash
352
+ RUNTIME_FLAG="--$TARGET_RUNTIME"
353
+ ```
354
+
355
+ **If LOCAL install:**
356
+ ```bash
357
+ npx -y --package=@therocketcode/gsd-core@"$TAG" -- gsd-core "$RUNTIME_FLAG" --local
358
+ ```
359
+
360
+ **If GLOBAL install:**
361
+ ```bash
362
+ npx -y --package=@therocketcode/gsd-core@"$TAG" -- gsd-core "$RUNTIME_FLAG" --global
363
+ ```
364
+
365
+ **If UNKNOWN install:**
366
+ ```bash
367
+ npx -y --package=@therocketcode/gsd-core@"$TAG" -- gsd-core --claude --global
368
+ ```
369
+
370
+ Capture output. If install fails, show error and exit.
371
+
372
+ Clear the update cache so statusline indicator disappears:
373
+
374
+ ```bash
375
+ expand_home() {
376
+ case "$1" in
377
+ "~/"*) printf '%s/%s\n' "$HOME" "${1#~/}" ;;
378
+ *) printf '%s\n' "$1" ;;
379
+ esac
380
+ }
381
+
382
+ # Clear update cache across preferred, env-derived, and default runtime directories
383
+ CACHE_DIRS=()
384
+ if [ -n "$PREFERRED_CONFIG_DIR" ]; then
385
+ CACHE_DIRS+=( "$(expand_home "$PREFERRED_CONFIG_DIR")" )
386
+ fi
387
+ if [ -n "$CLAUDE_CONFIG_DIR" ]; then
388
+ CACHE_DIRS+=( "$(expand_home "$CLAUDE_CONFIG_DIR")" )
389
+ fi
390
+ if [ -n "$GEMINI_CONFIG_DIR" ]; then
391
+ CACHE_DIRS+=( "$(expand_home "$GEMINI_CONFIG_DIR")" )
392
+ fi
393
+ if [ -n "$KILO_CONFIG_DIR" ]; then
394
+ CACHE_DIRS+=( "$(expand_home "$KILO_CONFIG_DIR")" )
395
+ elif [ -n "$KILO_CONFIG" ]; then
396
+ CACHE_DIRS+=( "$(dirname "$(expand_home "$KILO_CONFIG")")" )
397
+ elif [ -n "$XDG_CONFIG_HOME" ]; then
398
+ CACHE_DIRS+=( "$(expand_home "$XDG_CONFIG_HOME")/kilo" )
399
+ fi
400
+ if [ -n "$OPENCODE_CONFIG_DIR" ]; then
401
+ CACHE_DIRS+=( "$(expand_home "$OPENCODE_CONFIG_DIR")" )
402
+ elif [ -n "$OPENCODE_CONFIG" ]; then
403
+ CACHE_DIRS+=( "$(dirname "$(expand_home "$OPENCODE_CONFIG")")" )
404
+ elif [ -n "$XDG_CONFIG_HOME" ]; then
405
+ CACHE_DIRS+=( "$(expand_home "$XDG_CONFIG_HOME")/opencode" )
406
+ fi
407
+ if [ -n "$CODEX_HOME" ]; then
408
+ CACHE_DIRS+=( "$(expand_home "$CODEX_HOME")" )
409
+ fi
410
+ if [ -n "$CURSOR_CONFIG_DIR" ]; then
411
+ CACHE_DIRS+=( "$(expand_home "$CURSOR_CONFIG_DIR")" )
412
+ fi
413
+ if [ -n "$WINDSURF_CONFIG_DIR" ]; then
414
+ CACHE_DIRS+=( "$(expand_home "$WINDSURF_CONFIG_DIR")" )
415
+ fi
416
+ if [ -n "$AUGMENT_CONFIG_DIR" ]; then
417
+ CACHE_DIRS+=( "$(expand_home "$AUGMENT_CONFIG_DIR")" )
418
+ fi
419
+ if [ -n "$TRAE_CONFIG_DIR" ]; then
420
+ CACHE_DIRS+=( "$(expand_home "$TRAE_CONFIG_DIR")" )
421
+ fi
422
+ if [ -n "$QWEN_CONFIG_DIR" ]; then
423
+ CACHE_DIRS+=( "$(expand_home "$QWEN_CONFIG_DIR")" )
424
+ fi
425
+ if [ -n "$HERMES_HOME" ]; then
426
+ CACHE_DIRS+=( "$(expand_home "$HERMES_HOME")" )
427
+ fi
428
+ if [ -n "$CODEBUDDY_CONFIG_DIR" ]; then
429
+ CACHE_DIRS+=( "$(expand_home "$CODEBUDDY_CONFIG_DIR")" )
430
+ fi
431
+ if [ -n "$CLINE_CONFIG_DIR" ]; then
432
+ CACHE_DIRS+=( "$(expand_home "$CLINE_CONFIG_DIR")" )
433
+ fi
434
+
435
+ for dir in "${CACHE_DIRS[@]}"; do
436
+ if [ -n "$dir" ]; then
437
+ rm -f "$dir/cache/gsd-update-check"*.json
438
+ fi
439
+ done
440
+
441
+ for dir in .claude .config/opencode .opencode .gemini/antigravity-ide .gemini/antigravity-cli .gemini/antigravity .agent .gemini .config/kilo .kilo .codex .cursor .codeium/windsurf .augment .trae .qwen .hermes .codebuddy .cline; do
442
+ rm -f "./$dir/cache/gsd-update-check"*.json
443
+ rm -f "$HOME/$dir/cache/gsd-update-check"*.json
444
+ done
445
+
446
+ # Clear the shared tool-agnostic cache written by gsd-check-update.js hook (#2784).
447
+ # The hook uses ~/.cache/gsd/gsd-update-check.json (legacy) or a per-package name
448
+ # like gsd-update-check-therocketcode-gsd-core.json; the glob clears all variants so the
449
+ # statusline stops showing the stale "⬆ /gsd:update" indicator after update.
450
+ rm -f "$HOME/.cache/gsd/gsd-update-check"*.json
451
+ ```
452
+
453
+ The SessionStart hook (`gsd-check-update.js`) writes to the detected runtime's cache directory, so preferred/env-derived paths and default paths must all be cleared to prevent stale update indicators.
454
+ </step>
455
+
456
+ <step name="display_result">
457
+ Format completion message (changelog was already shown in confirmation step):
458
+
459
+ ```
460
+ ╔═══════════════════════════════════════════════════════════╗
461
+ ║ GSD Updated: v1.5.10 → v1.5.15 ║
462
+ ╚═══════════════════════════════════════════════════════════╝
463
+
464
+ ⚠️ Restart your runtime to pick up the new commands.
465
+
466
+ [View full changelog](https://github.com/TheRocketCodeMX/gsd-core/blob/main/CHANGELOG.md)
467
+ ```
468
+ </step>
469
+
470
+
471
+ <step name="check_local_patches">
472
+ After update completes, check if the installer detected and backed up any locally modified files:
473
+
474
+ Check for gsd-local-patches/backup-meta.json in the config directory.
475
+
476
+ **If patches found:**
477
+
478
+ ```
479
+ Local patches were backed up before the update.
480
+ Run `/gsd:update --reapply` to merge your modifications into the new version.
481
+ ```
482
+
483
+ **If no patches:** Continue normally.
484
+ </step>
485
+ </process>
486
+
487
+ <success_criteria>
488
+ - [ ] Installed version read correctly
489
+ - [ ] Latest version checked via npm
490
+ - [ ] Update skipped if already current
491
+ - [ ] Changelog fetched and displayed BEFORE update
492
+ - [ ] Clean install warning shown
493
+ - [ ] User confirmation obtained
494
+ - [ ] Update executed successfully
495
+ - [ ] Restart reminder shown
496
+ </success_criteria>
@@ -0,0 +1,181 @@
1
+ <purpose>
2
+ Audit Nyquist validation gaps for a completed phase. Generate missing tests. Update VALIDATION.md.
3
+ </purpose>
4
+
5
+ <required_reading>
6
+ @~/.claude/gsd-core/references/ui-brand.md
7
+ </required_reading>
8
+
9
+ <available_agent_types>
10
+ Valid GSD subagent types (use exact names — do not fall back to 'general-purpose'):
11
+ - gsd-nyquist-auditor — Validates verification coverage
12
+ </available_agent_types>
13
+
14
+ <process>
15
+
16
+ ## 0. Initialize
17
+
18
+ ```bash
19
+ _GSD_SHIM_NAME="gsd-tools.cjs"; _GSD_RUNTIME_ROOT="${RUNTIME_DIR:-$(git rev-parse --show-toplevel 2>/dev/null || pwd)}"; GSD_TOOLS="${_GSD_RUNTIME_ROOT}/gsd-core/bin/${_GSD_SHIM_NAME}"; if [ -f "$GSD_TOOLS" ]; then gsd_run() { node "$GSD_TOOLS" "$@"; }; elif [ -f "${_GSD_RUNTIME_ROOT}/.claude/gsd-core/bin/${_GSD_SHIM_NAME}" ]; then GSD_TOOLS="${_GSD_RUNTIME_ROOT}/.claude/gsd-core/bin/${_GSD_SHIM_NAME}"; gsd_run() { node "$GSD_TOOLS" "$@"; }; elif command -v gsd-tools >/dev/null 2>&1; then GSD_TOOLS="$(command -v gsd-tools)"; gsd_run() { "$GSD_TOOLS" "$@"; }; elif [ -f "$HOME/.claude/gsd-core/bin/${_GSD_SHIM_NAME}" ]; then GSD_TOOLS="$HOME/.claude/gsd-core/bin/${_GSD_SHIM_NAME}"; gsd_run() { node "$GSD_TOOLS" "$@"; }; else echo "ERROR: gsd-tools.cjs not found at $GSD_TOOLS and gsd-tools is not on PATH. Run: npx -y @therocketcode/gsd-core@latest --claude --local" >&2; exit 1; fi
20
+ INIT=$(gsd_run query init.phase-op "${PHASE_ARG}")
21
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
22
+ AGENT_SKILLS_AUDITOR=$(gsd_run query agent-skills gsd-nyquist-auditor)
23
+ ```
24
+
25
+ Parse: `phase_dir`, `phase_number`, `phase_name`, `phase_slug`, `padded_phase`.
26
+
27
+ ```bash
28
+ AUDITOR_MODEL=$(gsd_run query resolve-model gsd-nyquist-auditor --raw)
29
+ NYQUIST_CFG=$(gsd_run query config-get workflow.nyquist_validation --raw --default true)
30
+ ```
31
+
32
+ If `NYQUIST_CFG` is `false`: exit with "Nyquist validation is disabled. Enable via /gsd:settings."
33
+
34
+ Display banner: `GSD > VALIDATE PHASE {N}: {name}`
35
+
36
+ ## 1. Detect Input State
37
+
38
+ ```bash
39
+ VALIDATION_FILE=$(ls "${PHASE_DIR}"/*-VALIDATION.md 2>/dev/null | head -1)
40
+ SUMMARY_FILES=$(ls "${PHASE_DIR}"/*-SUMMARY.md 2>/dev/null)
41
+ ```
42
+
43
+ - **State A** (`VALIDATION_FILE` non-empty): Audit existing
44
+ - **State B** (`VALIDATION_FILE` empty, `SUMMARY_FILES` non-empty): Reconstruct from artifacts
45
+ - **State C** (`SUMMARY_FILES` empty): Exit — "Phase {N} not executed. Run /gsd:execute-phase {N} ${GSD_WS} first."
46
+
47
+ ## 2. Discovery
48
+
49
+ ### 2a. Read Phase Artifacts
50
+
51
+ Read all PLAN and SUMMARY files. Extract: task lists, requirement IDs, key-files changed, verify blocks.
52
+
53
+ ### 2b. Build Requirement-to-Task Map
54
+
55
+ Per task: `{ task_id, plan_id, wave, requirement_ids, has_automated_command }`
56
+
57
+ ### 2c. Detect Test Infrastructure
58
+
59
+ State A: Parse from existing VALIDATION.md Test Infrastructure table.
60
+ State B: Filesystem scan:
61
+
62
+ ```bash
63
+ find . -name "pytest.ini" -o -name "jest.config.*" -o -name "vitest.config.*" -o -name "pyproject.toml" 2>/dev/null | head -10
64
+ find . \( -name "*.test.*" -o -name "*.spec.*" -o -name "test_*" \) -not -path "*/node_modules/*" 2>/dev/null | head -40
65
+ ```
66
+
67
+ ### 2d. Cross-Reference
68
+
69
+ Match each requirement to existing tests by filename, imports, test descriptions. Record: requirement → test_file → status.
70
+
71
+ ## 3. Gap Analysis
72
+
73
+ Classify each requirement:
74
+
75
+ | Status | Criteria |
76
+ |--------|----------|
77
+ | COVERED | Test exists, targets behavior, runs green |
78
+ | PARTIAL | Test exists, failing or incomplete |
79
+ | MISSING | No test found |
80
+
81
+ Build: `{ task_id, requirement, gap_type, suggested_test_path, suggested_command }`
82
+
83
+ No gaps → skip to Step 6, set `nyquist_compliant: true`.
84
+
85
+ ## 4. Present Gap Plan
86
+
87
+
88
+ **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.
89
+ Call AskUserQuestion with gap table and options:
90
+ 1. "Fix all gaps" → Step 5
91
+ 2. "Skip — mark manual-only" → add to Manual-Only, Step 6
92
+ 3. "Cancel" → exit
93
+
94
+ ## 5. Spawn gsd-nyquist-auditor
95
+
96
+ Print: `◆ Spawning nyquist auditor... (runs in a subagent — no output until it returns, ~1–5 min; expected, not a freeze)`
97
+
98
+ ```
99
+ Agent(
100
+ prompt="Read ~/.claude/agents/gsd-nyquist-auditor.md for instructions.\n\n" +
101
+ "<files_to_read>{PLAN, SUMMARY, impl files, VALIDATION.md}</files_to_read>" +
102
+ "<gaps>{gap list}</gaps>" +
103
+ "<test_infrastructure>{framework, config, commands}</test_infrastructure>" +
104
+ "<constraints>Never modify impl files. Max 3 debug iterations. Escalate impl bugs.</constraints>" +
105
+ "${AGENT_SKILLS_AUDITOR}",
106
+ subagent_type="gsd-nyquist-auditor",
107
+ model="{AUDITOR_MODEL}",
108
+ description="Fill validation gaps for Phase {N}"
109
+ )
110
+ ```
111
+
112
+ > **ORCHESTRATOR RULE — CODEX RUNTIME**: After calling Agent() above, stop working on this task immediately. Do not read more files, edit code, or run tests related to this task while the subagent is active. Wait for the subagent to return its result. This prevents duplicate work, conflicting edits, and wasted context. Only resume when the subagent result is available.
113
+
114
+ Handle return:
115
+ - `## GAPS FILLED` → record tests + map updates, Step 6
116
+ - `## PARTIAL` → record resolved, move escalated to manual-only, Step 6
117
+ - `## ESCALATE` → move all to manual-only, Step 6
118
+
119
+ ## 6. Generate/Update VALIDATION.md
120
+
121
+ **State B (create):**
122
+ 1. Read template from `~/.claude/gsd-core/templates/VALIDATION.md`
123
+ 2. Fill: frontmatter, Test Infrastructure, Per-Task Map, Manual-Only, Sign-Off
124
+ 3. Write to `${PHASE_DIR}/${PADDED_PHASE}-VALIDATION.md`
125
+
126
+ **State A (update):**
127
+ 1. Update Per-Task Map statuses, add escalated to Manual-Only, update frontmatter
128
+ 2. Append audit trail:
129
+
130
+ ```markdown
131
+ ## Validation Audit {date}
132
+ | Metric | Count |
133
+ |--------|-------|
134
+ | Gaps found | {N} |
135
+ | Resolved | {M} |
136
+ | Escalated | {K} |
137
+ ```
138
+
139
+ ## 7. Commit
140
+
141
+ ```bash
142
+ git add {test_files}
143
+ git commit -m "test(phase-${PHASE}): add Nyquist validation tests"
144
+
145
+ gsd_run query commit "docs(phase-${PHASE}): add/update validation strategy"
146
+ ```
147
+
148
+ ## 8. Results + Routing
149
+
150
+ **Compliant:**
151
+ ```
152
+ GSD > PHASE {N} IS NYQUIST-COMPLIANT
153
+ All requirements have automated verification.
154
+ ▶ Next: /gsd:audit-milestone ${GSD_WS}
155
+ ```
156
+
157
+ **Partial:**
158
+ ```
159
+ GSD > PHASE {N} VALIDATED (PARTIAL)
160
+ {M} automated, {K} manual-only.
161
+ ▶ Retry: /gsd:validate-phase {N} ${GSD_WS}
162
+ ```
163
+
164
+ Display `/clear` reminder.
165
+
166
+ </process>
167
+
168
+ <success_criteria>
169
+ - [ ] Nyquist config checked (exit if disabled)
170
+ - [ ] Input state detected (A/B/C)
171
+ - [ ] State C exits cleanly
172
+ - [ ] PLAN/SUMMARY files read, requirement map built
173
+ - [ ] Test infrastructure detected
174
+ - [ ] Gaps classified (COVERED/PARTIAL/MISSING)
175
+ - [ ] User gate with gap table
176
+ - [ ] Auditor spawned with complete context
177
+ - [ ] All three return formats handled
178
+ - [ ] VALIDATION.md created or updated
179
+ - [ ] Test files committed separately
180
+ - [ ] Results with routing presented
181
+ </success_criteria>