@opengsd/gsd-core 1.2.0-rc.1

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 (503) hide show
  1. package/LICENSE +21 -0
  2. package/README.ja-JP.md +870 -0
  3. package/README.ko-KR.md +861 -0
  4. package/README.md +301 -0
  5. package/README.pt-BR.md +492 -0
  6. package/README.zh-CN.md +842 -0
  7. package/agents/gsd-advisor-researcher.md +127 -0
  8. package/agents/gsd-ai-researcher.md +133 -0
  9. package/agents/gsd-assumptions-analyzer.md +105 -0
  10. package/agents/gsd-code-fixer.md +668 -0
  11. package/agents/gsd-code-reviewer.md +387 -0
  12. package/agents/gsd-codebase-mapper.md +853 -0
  13. package/agents/gsd-debug-session-manager.md +314 -0
  14. package/agents/gsd-debugger.md +1452 -0
  15. package/agents/gsd-doc-classifier.md +168 -0
  16. package/agents/gsd-doc-synthesizer.md +204 -0
  17. package/agents/gsd-doc-verifier.md +217 -0
  18. package/agents/gsd-doc-writer.md +615 -0
  19. package/agents/gsd-domain-researcher.md +153 -0
  20. package/agents/gsd-eval-auditor.md +191 -0
  21. package/agents/gsd-eval-planner.md +154 -0
  22. package/agents/gsd-executor.md +772 -0
  23. package/agents/gsd-framework-selector.md +160 -0
  24. package/agents/gsd-integration-checker.md +470 -0
  25. package/agents/gsd-intel-updater.md +342 -0
  26. package/agents/gsd-nyquist-auditor.md +203 -0
  27. package/agents/gsd-pattern-mapper.md +335 -0
  28. package/agents/gsd-phase-researcher.md +928 -0
  29. package/agents/gsd-plan-checker.md +978 -0
  30. package/agents/gsd-planner.md +1218 -0
  31. package/agents/gsd-project-researcher.md +677 -0
  32. package/agents/gsd-research-synthesizer.md +255 -0
  33. package/agents/gsd-roadmapper.md +688 -0
  34. package/agents/gsd-security-auditor.md +155 -0
  35. package/agents/gsd-ui-auditor.md +495 -0
  36. package/agents/gsd-ui-checker.md +309 -0
  37. package/agents/gsd-ui-researcher.md +380 -0
  38. package/agents/gsd-user-profiler.md +171 -0
  39. package/agents/gsd-verifier.md +917 -0
  40. package/bin/install.js +10936 -0
  41. package/bin/lib/ui-safety-gate.cjs +107 -0
  42. package/commands/gsd/add-tests.md +42 -0
  43. package/commands/gsd/ai-integration-phase.md +37 -0
  44. package/commands/gsd/audit-fix.md +34 -0
  45. package/commands/gsd/audit-milestone.md +37 -0
  46. package/commands/gsd/audit-uat.md +24 -0
  47. package/commands/gsd/autonomous.md +46 -0
  48. package/commands/gsd/capture.md +62 -0
  49. package/commands/gsd/cleanup.md +24 -0
  50. package/commands/gsd/code-review.md +59 -0
  51. package/commands/gsd/complete-milestone.md +143 -0
  52. package/commands/gsd/config.md +56 -0
  53. package/commands/gsd/debug.md +52 -0
  54. package/commands/gsd/discuss-phase.md +76 -0
  55. package/commands/gsd/docs-update.md +49 -0
  56. package/commands/gsd/eval-review.md +33 -0
  57. package/commands/gsd/execute-phase.md +64 -0
  58. package/commands/gsd/explore.md +27 -0
  59. package/commands/gsd/extract-learnings.md +23 -0
  60. package/commands/gsd/fast.md +31 -0
  61. package/commands/gsd/forensics.md +57 -0
  62. package/commands/gsd/graphify.md +199 -0
  63. package/commands/gsd/health.md +31 -0
  64. package/commands/gsd/help.md +28 -0
  65. package/commands/gsd/import.md +41 -0
  66. package/commands/gsd/inbox.md +39 -0
  67. package/commands/gsd/ingest-docs.md +42 -0
  68. package/commands/gsd/manager.md +45 -0
  69. package/commands/gsd/map-codebase.md +83 -0
  70. package/commands/gsd/milestone-summary.md +51 -0
  71. package/commands/gsd/mvp-phase.md +45 -0
  72. package/commands/gsd/new-milestone.md +45 -0
  73. package/commands/gsd/new-project.md +47 -0
  74. package/commands/gsd/ns-context.md +23 -0
  75. package/commands/gsd/ns-ideate.md +24 -0
  76. package/commands/gsd/ns-manage.md +29 -0
  77. package/commands/gsd/ns-project.md +22 -0
  78. package/commands/gsd/ns-review.md +26 -0
  79. package/commands/gsd/ns-workflow.md +28 -0
  80. package/commands/gsd/pause-work.md +43 -0
  81. package/commands/gsd/phase.md +56 -0
  82. package/commands/gsd/plan-phase.md +62 -0
  83. package/commands/gsd/plan-review-convergence.md +59 -0
  84. package/commands/gsd/pr-branch.md +26 -0
  85. package/commands/gsd/profile-user.md +46 -0
  86. package/commands/gsd/progress.md +47 -0
  87. package/commands/gsd/quick.md +174 -0
  88. package/commands/gsd/resume-work.md +30 -0
  89. package/commands/gsd/review-backlog.md +63 -0
  90. package/commands/gsd/review.md +41 -0
  91. package/commands/gsd/secure-phase.md +36 -0
  92. package/commands/gsd/settings.md +29 -0
  93. package/commands/gsd/ship.md +24 -0
  94. package/commands/gsd/sketch.md +60 -0
  95. package/commands/gsd/spec-phase.md +63 -0
  96. package/commands/gsd/spike.md +57 -0
  97. package/commands/gsd/stats.md +19 -0
  98. package/commands/gsd/surface.md +155 -0
  99. package/commands/gsd/thread.md +24 -0
  100. package/commands/gsd/ui-phase.md +35 -0
  101. package/commands/gsd/ui-review.md +33 -0
  102. package/commands/gsd/ultraplan-phase.md +34 -0
  103. package/commands/gsd/undo.md +35 -0
  104. package/commands/gsd/update.md +48 -0
  105. package/commands/gsd/validate-phase.md +36 -0
  106. package/commands/gsd/verify-work.md +39 -0
  107. package/commands/gsd/workspace.md +52 -0
  108. package/commands/gsd/workstreams.md +70 -0
  109. package/get-shit-done/bin/check-latest-version.cjs +106 -0
  110. package/get-shit-done/bin/gsd-tools.cjs +1676 -0
  111. package/get-shit-done/bin/lib/active-workstream-store.cjs +302 -0
  112. package/get-shit-done/bin/lib/adr-parser.cjs +394 -0
  113. package/get-shit-done/bin/lib/agent-command-router.cjs +65 -0
  114. package/get-shit-done/bin/lib/artifacts.cjs +53 -0
  115. package/get-shit-done/bin/lib/audit.cjs +755 -0
  116. package/get-shit-done/bin/lib/check-command-router.cjs +333 -0
  117. package/get-shit-done/bin/lib/cjs-command-router-adapter.cjs +118 -0
  118. package/get-shit-done/bin/lib/clock.cjs +96 -0
  119. package/get-shit-done/bin/lib/clusters.cjs +135 -0
  120. package/get-shit-done/bin/lib/code-review-flags.cjs +74 -0
  121. package/get-shit-done/bin/lib/command-aliases.cjs +815 -0
  122. package/get-shit-done/bin/lib/command-arg-projection.cjs +62 -0
  123. package/get-shit-done/bin/lib/command-routing-hub.cjs +388 -0
  124. package/get-shit-done/bin/lib/commands.cjs +1188 -0
  125. package/get-shit-done/bin/lib/config-schema.cjs +31 -0
  126. package/get-shit-done/bin/lib/config.cjs +728 -0
  127. package/get-shit-done/bin/lib/configuration.cjs +248 -0
  128. package/get-shit-done/bin/lib/context-utilization.cjs +47 -0
  129. package/get-shit-done/bin/lib/core.cjs +2121 -0
  130. package/get-shit-done/bin/lib/decisions.cjs +116 -0
  131. package/get-shit-done/bin/lib/docs.cjs +270 -0
  132. package/get-shit-done/bin/lib/drift.cjs +388 -0
  133. package/get-shit-done/bin/lib/fallow-runner.cjs +109 -0
  134. package/get-shit-done/bin/lib/frontmatter.cjs +389 -0
  135. package/get-shit-done/bin/lib/gap-checker.cjs +205 -0
  136. package/get-shit-done/bin/lib/graphify.cjs +592 -0
  137. package/get-shit-done/bin/lib/gsd2-import.cjs +514 -0
  138. package/get-shit-done/bin/lib/init-command-router.cjs +58 -0
  139. package/get-shit-done/bin/lib/init.cjs +2112 -0
  140. package/get-shit-done/bin/lib/install-profiles.cjs +603 -0
  141. package/get-shit-done/bin/lib/installer-migration-authoring.cjs +117 -0
  142. package/get-shit-done/bin/lib/installer-migration-report.cjs +354 -0
  143. package/get-shit-done/bin/lib/installer-migrations/000-first-time-baseline.cjs +220 -0
  144. package/get-shit-done/bin/lib/installer-migrations/001-legacy-orphan-files.cjs +41 -0
  145. package/get-shit-done/bin/lib/installer-migrations/002-codex-legacy-hooks-json.cjs +80 -0
  146. package/get-shit-done/bin/lib/installer-migrations.cjs +778 -0
  147. package/get-shit-done/bin/lib/intel.cjs +708 -0
  148. package/get-shit-done/bin/lib/learnings.cjs +421 -0
  149. package/get-shit-done/bin/lib/milestone.cjs +314 -0
  150. package/get-shit-done/bin/lib/model-catalog.cjs +212 -0
  151. package/get-shit-done/bin/lib/model-profiles.cjs +31 -0
  152. package/get-shit-done/bin/lib/observability/event.cjs +82 -0
  153. package/get-shit-done/bin/lib/observability/logger.cjs +174 -0
  154. package/get-shit-done/bin/lib/observability/redaction.cjs +50 -0
  155. package/get-shit-done/bin/lib/package-identity.cjs +31 -0
  156. package/get-shit-done/bin/lib/phase-command-router.cjs +191 -0
  157. package/get-shit-done/bin/lib/phase-lifecycle.cjs +80 -0
  158. package/get-shit-done/bin/lib/phase.cjs +1607 -0
  159. package/get-shit-done/bin/lib/phases-command-router.cjs +39 -0
  160. package/get-shit-done/bin/lib/plan-scan.cjs +97 -0
  161. package/get-shit-done/bin/lib/planning-workspace.cjs +238 -0
  162. package/get-shit-done/bin/lib/profile-output.cjs +1141 -0
  163. package/get-shit-done/bin/lib/profile-pipeline.cjs +539 -0
  164. package/get-shit-done/bin/lib/project-root.cjs +112 -0
  165. package/get-shit-done/bin/lib/prompt-budget.cjs +399 -0
  166. package/get-shit-done/bin/lib/review-reviewer-selection.cjs +125 -0
  167. package/get-shit-done/bin/lib/roadmap-command-router.cjs +28 -0
  168. package/get-shit-done/bin/lib/roadmap.cjs +650 -0
  169. package/get-shit-done/bin/lib/runtime-artifact-layout.cjs +301 -0
  170. package/get-shit-done/bin/lib/runtime-homes.cjs +222 -0
  171. package/get-shit-done/bin/lib/runtime-name-policy.cjs +83 -0
  172. package/get-shit-done/bin/lib/runtime-slash.cjs +112 -0
  173. package/get-shit-done/bin/lib/schema-detect.cjs +165 -0
  174. package/get-shit-done/bin/lib/secrets.cjs +32 -0
  175. package/get-shit-done/bin/lib/security.cjs +600 -0
  176. package/get-shit-done/bin/lib/semver-compare.cjs +35 -0
  177. package/get-shit-done/bin/lib/shell-command-projection.cjs +500 -0
  178. package/get-shit-done/bin/lib/state-command-router.cjs +252 -0
  179. package/get-shit-done/bin/lib/state-document.cjs +263 -0
  180. package/get-shit-done/bin/lib/state.cjs +2038 -0
  181. package/get-shit-done/bin/lib/surface.cjs +470 -0
  182. package/get-shit-done/bin/lib/task-command-router.cjs +81 -0
  183. package/get-shit-done/bin/lib/template.cjs +228 -0
  184. package/get-shit-done/bin/lib/uat.cjs +289 -0
  185. package/get-shit-done/bin/lib/update-context.cjs +209 -0
  186. package/get-shit-done/bin/lib/validate-command-router.cjs +83 -0
  187. package/get-shit-done/bin/lib/validate.cjs +92 -0
  188. package/get-shit-done/bin/lib/verify-command-router.cjs +40 -0
  189. package/get-shit-done/bin/lib/verify.cjs +1511 -0
  190. package/get-shit-done/bin/lib/workstream-inventory-builder.cjs +74 -0
  191. package/get-shit-done/bin/lib/workstream-inventory.cjs +146 -0
  192. package/get-shit-done/bin/lib/workstream-name-policy.cjs +94 -0
  193. package/get-shit-done/bin/lib/workstream.cjs +389 -0
  194. package/get-shit-done/bin/lib/worktree-safety.cjs +985 -0
  195. package/get-shit-done/bin/shared/config-defaults.manifest.json +97 -0
  196. package/get-shit-done/bin/shared/config-schema.manifest.json +175 -0
  197. package/get-shit-done/bin/shared/model-catalog.json +122 -0
  198. package/get-shit-done/bin/shared/runtime-aliases.manifest.json +75 -0
  199. package/get-shit-done/bin/verify-reapply-patches.cjs +352 -0
  200. package/get-shit-done/contexts/dev.md +21 -0
  201. package/get-shit-done/contexts/research.md +22 -0
  202. package/get-shit-done/contexts/review.md +23 -0
  203. package/get-shit-done/references/agent-contracts.md +79 -0
  204. package/get-shit-done/references/ai-evals.md +156 -0
  205. package/get-shit-done/references/ai-frameworks.md +186 -0
  206. package/get-shit-done/references/artifact-types.md +131 -0
  207. package/get-shit-done/references/autonomous-smart-discuss.md +277 -0
  208. package/get-shit-done/references/checkpoints.md +814 -0
  209. package/get-shit-done/references/common-bug-patterns.md +114 -0
  210. package/get-shit-done/references/context-budget.md +85 -0
  211. package/get-shit-done/references/continuation-format.md +253 -0
  212. package/get-shit-done/references/debugger-philosophy.md +76 -0
  213. package/get-shit-done/references/decimal-phase-calculation.md +64 -0
  214. package/get-shit-done/references/doc-conflict-engine.md +91 -0
  215. package/get-shit-done/references/domain-probes.md +125 -0
  216. package/get-shit-done/references/execute-mvp-tdd.md +81 -0
  217. package/get-shit-done/references/executor-examples.md +110 -0
  218. package/get-shit-done/references/few-shot-examples/plan-checker.md +73 -0
  219. package/get-shit-done/references/few-shot-examples/verifier.md +109 -0
  220. package/get-shit-done/references/gate-prompts.md +100 -0
  221. package/get-shit-done/references/gates.md +70 -0
  222. package/get-shit-done/references/git-integration.md +298 -0
  223. package/get-shit-done/references/git-planning-commit.md +40 -0
  224. package/get-shit-done/references/ios-scaffold.md +123 -0
  225. package/get-shit-done/references/mandatory-initial-read.md +2 -0
  226. package/get-shit-done/references/model-profile-resolution.md +38 -0
  227. package/get-shit-done/references/model-profiles.md +245 -0
  228. package/get-shit-done/references/mvp-concepts.md +49 -0
  229. package/get-shit-done/references/phase-argument-parsing.md +61 -0
  230. package/get-shit-done/references/planner-antipatterns.md +89 -0
  231. package/get-shit-done/references/planner-chunked.md +49 -0
  232. package/get-shit-done/references/planner-gap-closure.md +62 -0
  233. package/get-shit-done/references/planner-graphify-auto-update.md +67 -0
  234. package/get-shit-done/references/planner-human-verify-mode.md +57 -0
  235. package/get-shit-done/references/planner-interface-context.md +62 -0
  236. package/get-shit-done/references/planner-mvp-mode.md +53 -0
  237. package/get-shit-done/references/planner-reviews.md +39 -0
  238. package/get-shit-done/references/planner-revision.md +87 -0
  239. package/get-shit-done/references/planner-source-audit.md +73 -0
  240. package/get-shit-done/references/planning-config.md +471 -0
  241. package/get-shit-done/references/project-skills-discovery.md +19 -0
  242. package/get-shit-done/references/questioning.md +162 -0
  243. package/get-shit-done/references/revision-loop.md +97 -0
  244. package/get-shit-done/references/scout-codebase.md +51 -0
  245. package/get-shit-done/references/skeleton-template.md +48 -0
  246. package/get-shit-done/references/sketch-interactivity.md +41 -0
  247. package/get-shit-done/references/sketch-theme-system.md +94 -0
  248. package/get-shit-done/references/sketch-tooling.md +45 -0
  249. package/get-shit-done/references/sketch-variant-patterns.md +81 -0
  250. package/get-shit-done/references/spidr-splitting.md +69 -0
  251. package/get-shit-done/references/tdd.md +330 -0
  252. package/get-shit-done/references/thinking-models-debug.md +44 -0
  253. package/get-shit-done/references/thinking-models-execution.md +50 -0
  254. package/get-shit-done/references/thinking-models-planning.md +62 -0
  255. package/get-shit-done/references/thinking-models-research.md +50 -0
  256. package/get-shit-done/references/thinking-models-verification.md +55 -0
  257. package/get-shit-done/references/thinking-partner.md +96 -0
  258. package/get-shit-done/references/ui-brand.md +160 -0
  259. package/get-shit-done/references/universal-anti-patterns.md +63 -0
  260. package/get-shit-done/references/user-profiling.md +681 -0
  261. package/get-shit-done/references/user-story-template.md +58 -0
  262. package/get-shit-done/references/verification-overrides.md +227 -0
  263. package/get-shit-done/references/verification-patterns.md +612 -0
  264. package/get-shit-done/references/verify-mvp-mode.md +85 -0
  265. package/get-shit-done/references/workstream-flag.md +111 -0
  266. package/get-shit-done/references/worktree-path-safety.md +89 -0
  267. package/get-shit-done/templates/AI-SPEC.md +246 -0
  268. package/get-shit-done/templates/DEBUG.md +169 -0
  269. package/get-shit-done/templates/README.md +77 -0
  270. package/get-shit-done/templates/SECURITY.md +61 -0
  271. package/get-shit-done/templates/UAT.md +265 -0
  272. package/get-shit-done/templates/UI-SPEC.md +100 -0
  273. package/get-shit-done/templates/VALIDATION.md +76 -0
  274. package/get-shit-done/templates/claude-md.md +145 -0
  275. package/get-shit-done/templates/codebase/architecture.md +255 -0
  276. package/get-shit-done/templates/codebase/concerns.md +310 -0
  277. package/get-shit-done/templates/codebase/conventions.md +307 -0
  278. package/get-shit-done/templates/codebase/integrations.md +280 -0
  279. package/get-shit-done/templates/codebase/stack.md +186 -0
  280. package/get-shit-done/templates/codebase/structure.md +285 -0
  281. package/get-shit-done/templates/codebase/testing.md +480 -0
  282. package/get-shit-done/templates/config.json +62 -0
  283. package/get-shit-done/templates/context.md +352 -0
  284. package/get-shit-done/templates/continue-here.md +78 -0
  285. package/get-shit-done/templates/copilot-instructions.md +7 -0
  286. package/get-shit-done/templates/debug-subagent-prompt.md +91 -0
  287. package/get-shit-done/templates/dev-preferences.md +21 -0
  288. package/get-shit-done/templates/discovery.md +146 -0
  289. package/get-shit-done/templates/discussion-log.md +63 -0
  290. package/get-shit-done/templates/milestone-archive.md +123 -0
  291. package/get-shit-done/templates/milestone.md +115 -0
  292. package/get-shit-done/templates/phase-prompt.md +610 -0
  293. package/get-shit-done/templates/planner-subagent-prompt.md +117 -0
  294. package/get-shit-done/templates/project.md +186 -0
  295. package/get-shit-done/templates/requirements.md +231 -0
  296. package/get-shit-done/templates/research-project/ARCHITECTURE.md +204 -0
  297. package/get-shit-done/templates/research-project/FEATURES.md +147 -0
  298. package/get-shit-done/templates/research-project/PITFALLS.md +200 -0
  299. package/get-shit-done/templates/research-project/STACK.md +120 -0
  300. package/get-shit-done/templates/research-project/SUMMARY.md +170 -0
  301. package/get-shit-done/templates/research.md +592 -0
  302. package/get-shit-done/templates/retrospective.md +54 -0
  303. package/get-shit-done/templates/roadmap.md +202 -0
  304. package/get-shit-done/templates/spec.md +307 -0
  305. package/get-shit-done/templates/state.md +195 -0
  306. package/get-shit-done/templates/summary-complex.md +59 -0
  307. package/get-shit-done/templates/summary-minimal.md +41 -0
  308. package/get-shit-done/templates/summary-standard.md +48 -0
  309. package/get-shit-done/templates/summary.md +248 -0
  310. package/get-shit-done/templates/user-profile.md +146 -0
  311. package/get-shit-done/templates/user-setup.md +311 -0
  312. package/get-shit-done/templates/verification-report.md +322 -0
  313. package/get-shit-done/workflows/_runtime-launcher.snippet.sh +1 -0
  314. package/get-shit-done/workflows/add-backlog.md +91 -0
  315. package/get-shit-done/workflows/add-phase.md +113 -0
  316. package/get-shit-done/workflows/add-tests.md +355 -0
  317. package/get-shit-done/workflows/add-todo.md +161 -0
  318. package/get-shit-done/workflows/ai-integration-phase.md +295 -0
  319. package/get-shit-done/workflows/analyze-dependencies.md +96 -0
  320. package/get-shit-done/workflows/audit-fix.md +178 -0
  321. package/get-shit-done/workflows/audit-milestone.md +358 -0
  322. package/get-shit-done/workflows/audit-uat.md +110 -0
  323. package/get-shit-done/workflows/autonomous.md +795 -0
  324. package/get-shit-done/workflows/check-todos.md +180 -0
  325. package/get-shit-done/workflows/cleanup.md +155 -0
  326. package/get-shit-done/workflows/code-review-fix.md +502 -0
  327. package/get-shit-done/workflows/code-review.md +656 -0
  328. package/get-shit-done/workflows/complete-milestone.md +855 -0
  329. package/get-shit-done/workflows/debug.md +232 -0
  330. package/get-shit-done/workflows/diagnose-issues.md +241 -0
  331. package/get-shit-done/workflows/discovery-phase.md +291 -0
  332. package/get-shit-done/workflows/discuss-phase/modes/advisor.md +176 -0
  333. package/get-shit-done/workflows/discuss-phase/modes/all.md +28 -0
  334. package/get-shit-done/workflows/discuss-phase/modes/analyze.md +44 -0
  335. package/get-shit-done/workflows/discuss-phase/modes/auto.md +57 -0
  336. package/get-shit-done/workflows/discuss-phase/modes/batch.md +52 -0
  337. package/get-shit-done/workflows/discuss-phase/modes/chain.md +98 -0
  338. package/get-shit-done/workflows/discuss-phase/modes/default.md +141 -0
  339. package/get-shit-done/workflows/discuss-phase/modes/power.md +44 -0
  340. package/get-shit-done/workflows/discuss-phase/modes/text.md +55 -0
  341. package/get-shit-done/workflows/discuss-phase/templates/checkpoint.json +18 -0
  342. package/get-shit-done/workflows/discuss-phase/templates/context.md +136 -0
  343. package/get-shit-done/workflows/discuss-phase/templates/discussion-log.md +50 -0
  344. package/get-shit-done/workflows/discuss-phase-assumptions.md +675 -0
  345. package/get-shit-done/workflows/discuss-phase-power.md +291 -0
  346. package/get-shit-done/workflows/discuss-phase.md +499 -0
  347. package/get-shit-done/workflows/do.md +111 -0
  348. package/get-shit-done/workflows/docs-update.md +1162 -0
  349. package/get-shit-done/workflows/edit-phase.md +295 -0
  350. package/get-shit-done/workflows/eval-review.md +156 -0
  351. package/get-shit-done/workflows/execute-phase/steps/codebase-drift-gate.md +82 -0
  352. package/get-shit-done/workflows/execute-phase/steps/per-plan-worktree-gate.md +94 -0
  353. package/get-shit-done/workflows/execute-phase/steps/post-merge-gate.md +117 -0
  354. package/get-shit-done/workflows/execute-phase.md +1709 -0
  355. package/get-shit-done/workflows/execute-plan.md +526 -0
  356. package/get-shit-done/workflows/explore.md +144 -0
  357. package/get-shit-done/workflows/extract-learnings.md +243 -0
  358. package/get-shit-done/workflows/fast.md +124 -0
  359. package/get-shit-done/workflows/forensics.md +279 -0
  360. package/get-shit-done/workflows/graduation.md +196 -0
  361. package/get-shit-done/workflows/health.md +224 -0
  362. package/get-shit-done/workflows/help/modes/brief.md +22 -0
  363. package/get-shit-done/workflows/help/modes/default.md +50 -0
  364. package/get-shit-done/workflows/help/modes/full.md +784 -0
  365. package/get-shit-done/workflows/help/modes/topic.md +74 -0
  366. package/get-shit-done/workflows/help.md +24 -0
  367. package/get-shit-done/workflows/import.md +254 -0
  368. package/get-shit-done/workflows/inbox.md +387 -0
  369. package/get-shit-done/workflows/ingest-docs.md +339 -0
  370. package/get-shit-done/workflows/insert-phase.md +152 -0
  371. package/get-shit-done/workflows/list-phase-assumptions.md +178 -0
  372. package/get-shit-done/workflows/list-workspaces.md +57 -0
  373. package/get-shit-done/workflows/manager.md +393 -0
  374. package/get-shit-done/workflows/map-codebase.md +444 -0
  375. package/get-shit-done/workflows/milestone-summary.md +224 -0
  376. package/get-shit-done/workflows/mvp-phase.md +222 -0
  377. package/get-shit-done/workflows/new-milestone.md +635 -0
  378. package/get-shit-done/workflows/new-project.md +1555 -0
  379. package/get-shit-done/workflows/new-workspace.md +240 -0
  380. package/get-shit-done/workflows/next.md +299 -0
  381. package/get-shit-done/workflows/node-repair.md +92 -0
  382. package/get-shit-done/workflows/note.md +158 -0
  383. package/get-shit-done/workflows/pause-work.md +244 -0
  384. package/get-shit-done/workflows/plan-milestone-gaps.md +281 -0
  385. package/get-shit-done/workflows/plan-phase.md +1809 -0
  386. package/get-shit-done/workflows/plan-review-convergence.md +346 -0
  387. package/get-shit-done/workflows/plant-seed.md +230 -0
  388. package/get-shit-done/workflows/pr-branch.md +157 -0
  389. package/get-shit-done/workflows/profile-user.md +453 -0
  390. package/get-shit-done/workflows/progress.md +699 -0
  391. package/get-shit-done/workflows/quick.md +1039 -0
  392. package/get-shit-done/workflows/reapply-patches.md +426 -0
  393. package/get-shit-done/workflows/remove-phase.md +156 -0
  394. package/get-shit-done/workflows/remove-workspace.md +108 -0
  395. package/get-shit-done/workflows/resume-project.md +332 -0
  396. package/get-shit-done/workflows/review.md +623 -0
  397. package/get-shit-done/workflows/scan.md +105 -0
  398. package/get-shit-done/workflows/secure-phase.md +180 -0
  399. package/get-shit-done/workflows/session-report.md +146 -0
  400. package/get-shit-done/workflows/settings-advanced.md +620 -0
  401. package/get-shit-done/workflows/settings-integrations.md +312 -0
  402. package/get-shit-done/workflows/settings.md +552 -0
  403. package/get-shit-done/workflows/ship.md +356 -0
  404. package/get-shit-done/workflows/sketch-wrap-up.md +286 -0
  405. package/get-shit-done/workflows/sketch.md +361 -0
  406. package/get-shit-done/workflows/spec-phase.md +262 -0
  407. package/get-shit-done/workflows/spike-wrap-up.md +307 -0
  408. package/get-shit-done/workflows/spike.md +453 -0
  409. package/get-shit-done/workflows/stats.md +80 -0
  410. package/get-shit-done/workflows/sync-skills.md +182 -0
  411. package/get-shit-done/workflows/thread.md +222 -0
  412. package/get-shit-done/workflows/transition.md +694 -0
  413. package/get-shit-done/workflows/ui-phase.md +328 -0
  414. package/get-shit-done/workflows/ui-review.md +193 -0
  415. package/get-shit-done/workflows/ultraplan-phase.md +199 -0
  416. package/get-shit-done/workflows/undo.md +314 -0
  417. package/get-shit-done/workflows/update.md +443 -0
  418. package/get-shit-done/workflows/validate-phase.md +179 -0
  419. package/get-shit-done/workflows/verify-phase.md +544 -0
  420. package/get-shit-done/workflows/verify-work.md +781 -0
  421. package/hooks/dist/gsd-check-update-worker.js +95 -0
  422. package/hooks/dist/gsd-check-update.js +64 -0
  423. package/hooks/dist/gsd-context-monitor.js +195 -0
  424. package/hooks/dist/gsd-graphify-update.sh +158 -0
  425. package/hooks/dist/gsd-phase-boundary.sh +47 -0
  426. package/hooks/dist/gsd-prompt-guard.js +97 -0
  427. package/hooks/dist/gsd-read-guard.js +101 -0
  428. package/hooks/dist/gsd-read-injection-scanner.js +203 -0
  429. package/hooks/dist/gsd-session-state.sh +59 -0
  430. package/hooks/dist/gsd-statusline.js +548 -0
  431. package/hooks/dist/gsd-update-banner.js +134 -0
  432. package/hooks/dist/gsd-validate-commit.sh +57 -0
  433. package/hooks/dist/gsd-workflow-guard.js +166 -0
  434. package/hooks/dist/lib/git-cmd.js +150 -0
  435. package/hooks/dist/lib/gsd-graphify-rebuild.sh +65 -0
  436. package/hooks/gsd-check-update-worker.js +95 -0
  437. package/hooks/gsd-check-update.js +64 -0
  438. package/hooks/gsd-context-monitor.js +195 -0
  439. package/hooks/gsd-graphify-update.sh +158 -0
  440. package/hooks/gsd-phase-boundary.sh +47 -0
  441. package/hooks/gsd-prompt-guard.js +97 -0
  442. package/hooks/gsd-read-guard.js +101 -0
  443. package/hooks/gsd-read-injection-scanner.js +203 -0
  444. package/hooks/gsd-session-state.sh +59 -0
  445. package/hooks/gsd-statusline.js +548 -0
  446. package/hooks/gsd-update-banner.js +134 -0
  447. package/hooks/gsd-validate-commit.sh +57 -0
  448. package/hooks/gsd-workflow-guard.js +166 -0
  449. package/hooks/lib/git-cmd.js +150 -0
  450. package/hooks/lib/gsd-graphify-rebuild.sh +65 -0
  451. package/hooks/managed-hooks-registry.cjs +34 -0
  452. package/package.json +102 -0
  453. package/scripts/affected-tests-lib.cjs +541 -0
  454. package/scripts/audit-workflow-script-paths.cjs +73 -0
  455. package/scripts/base64-scan.sh +339 -0
  456. package/scripts/build-hooks.js +236 -0
  457. package/scripts/changeset/README.md +129 -0
  458. package/scripts/changeset/cli.cjs +392 -0
  459. package/scripts/changeset/github-release-notes.cjs +199 -0
  460. package/scripts/changeset/lint.cjs +110 -0
  461. package/scripts/changeset/new.cjs +137 -0
  462. package/scripts/changeset/parse.cjs +114 -0
  463. package/scripts/changeset/render.cjs +34 -0
  464. package/scripts/changeset/serialize.cjs +130 -0
  465. package/scripts/check-alias-drift.cjs +108 -0
  466. package/scripts/check-env.cjs +302 -0
  467. package/scripts/check-npm-integrity.cjs +209 -0
  468. package/scripts/ci-guard-runner.cjs +16 -0
  469. package/scripts/ci-prepare-test-scope.cjs +46 -0
  470. package/scripts/ci-rebase-check.cjs +85 -0
  471. package/scripts/ci-test-scope.cjs +302 -0
  472. package/scripts/command-contract-helpers.cjs +64 -0
  473. package/scripts/diff-touches-shipped-paths.cjs +147 -0
  474. package/scripts/fix-slash-commands.cjs +147 -0
  475. package/scripts/gen-inventory-manifest.cjs +109 -0
  476. package/scripts/generate-package-identity.cjs +104 -0
  477. package/scripts/lint-command-contract.cjs +108 -0
  478. package/scripts/lint-descriptions.cjs +83 -0
  479. package/scripts/lint-docs-required.cjs +222 -0
  480. package/scripts/lint-no-source-grep-extras.cjs +81 -0
  481. package/scripts/lint-no-source-grep.cjs +174 -0
  482. package/scripts/lint-package-identity-drift.cjs +141 -0
  483. package/scripts/lint-pr-check-project-dir.cjs +98 -0
  484. package/scripts/lint-shared-module-handsync.cjs +388 -0
  485. package/scripts/lint-shell-command-projection-drift.cjs +57 -0
  486. package/scripts/lint-skill-deps.cjs +180 -0
  487. package/scripts/lint-test-file-count.allowlist.json +36 -0
  488. package/scripts/lint-test-file-count.cjs +190 -0
  489. package/scripts/pr-template-policy.cjs +268 -0
  490. package/scripts/prompt-injection-scan.sh +203 -0
  491. package/scripts/release-tarball-smoke.cjs +627 -0
  492. package/scripts/run-affected-tests.cjs +6 -0
  493. package/scripts/run-cross-platform-tests.cjs +63 -0
  494. package/scripts/run-tests.cjs +282 -0
  495. package/scripts/secret-scan-lint.sh +231 -0
  496. package/scripts/secret-scan.sh +358 -0
  497. package/scripts/setup-branch-protection.sh +236 -0
  498. package/scripts/shared-module-handsync-allowlist.json +183 -0
  499. package/scripts/strip-prose-atrefs.cjs +106 -0
  500. package/scripts/sync-rulesets.sh +34 -0
  501. package/scripts/sync-runtime-launcher.cjs +402 -0
  502. package/scripts/test-failure-reasons.cjs +34 -0
  503. package/scripts/workflow-policy.cjs +450 -0
@@ -0,0 +1,1039 @@
1
+ <purpose>
2
+ Execute small, ad-hoc tasks with GSD guarantees (atomic commits, STATE.md tracking). Quick mode spawns gsd-planner (quick mode) + gsd-executor(s), tracks tasks in `.planning/quick/`, and updates STATE.md's "Quick Tasks Completed" table.
3
+
4
+ With `--full` flag: enables the complete quality pipeline — discussion + research + plan-checking + verification. One flag for everything.
5
+
6
+ With `--validate` flag: enables plan-checking (max 2 iterations) and post-execution verification only. Use when you want quality guarantees without discussion or research.
7
+
8
+ With `--discuss` flag: lightweight discussion phase before planning. Surfaces assumptions, clarifies gray areas, captures decisions in CONTEXT.md so the planner treats them as locked.
9
+
10
+ With `--research` flag: spawns a focused research agent before planning. Investigates implementation approaches, library options, and pitfalls. Use when you're unsure how to approach a task.
11
+
12
+ Granular flags are composable: `--discuss --research --validate` gives the same result as `--full`.
13
+ </purpose>
14
+
15
+ <required_reading>
16
+ Read all files referenced by the invoking prompt's execution_context before starting.
17
+ </required_reading>
18
+
19
+ <available_agent_types>
20
+ Valid GSD subagent types (use exact names — do not fall back to 'general-purpose'):
21
+ - gsd-phase-researcher — Researches technical approaches for a phase
22
+ - gsd-planner — Creates detailed plans from phase scope
23
+ - gsd-plan-checker — Reviews plan quality before execution
24
+ - gsd-executor — Executes plan tasks, commits, creates SUMMARY.md
25
+ - gsd-verifier — Verifies phase completion, checks quality gates
26
+ - gsd-code-reviewer — Reviews source files for bugs, security issues, and code quality
27
+ </available_agent_types>
28
+
29
+ <process>
30
+ **Step 1: Parse arguments and get task description**
31
+
32
+ Parse `$ARGUMENTS` for:
33
+ - `--full` flag → store `$FULL_MODE=true`, `$DISCUSS_MODE=true`, `$RESEARCH_MODE=true`, `$VALIDATE_MODE=true`
34
+ - `--validate` flag → store `$VALIDATE_MODE=true`
35
+ - `--discuss` flag → store `$DISCUSS_MODE=true`
36
+ - `--research` flag → store `$RESEARCH_MODE=true`
37
+ - Remaining text → use as `$DESCRIPTION` if non-empty
38
+
39
+ After parsing, normalize: if `$DISCUSS_MODE` and `$RESEARCH_MODE` and `$VALIDATE_MODE` are all true, set `$FULL_MODE=true`. This ensures `--discuss --research --validate` is treated identically to `--full`.
40
+
41
+ If `$DESCRIPTION` is empty after parsing, prompt user interactively:
42
+
43
+
44
+ **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.
45
+
46
+ ```
47
+ AskUserQuestion(
48
+ header: "Quick Task",
49
+ question: "What do you want to do?",
50
+ followUp: null
51
+ )
52
+ ```
53
+
54
+ Store response as `$DESCRIPTION`.
55
+
56
+ If still empty, re-prompt: "Please provide a task description."
57
+
58
+ Display banner based on active flags:
59
+
60
+ If `$FULL_MODE` (all phases enabled — `--full` or all granular flags):
61
+ ```
62
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
63
+ GSD ► QUICK TASK (FULL)
64
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
65
+
66
+ ◆ Discussion + research + plan checking + verification enabled
67
+ ```
68
+
69
+ If `$DISCUSS_MODE` and `$VALIDATE_MODE` (no research):
70
+ ```
71
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
72
+ GSD ► QUICK TASK (DISCUSS + VALIDATE)
73
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
74
+
75
+ ◆ Discussion + plan checking + verification enabled
76
+ ```
77
+
78
+ If `$DISCUSS_MODE` and `$RESEARCH_MODE` (no validate):
79
+ ```
80
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
81
+ GSD ► QUICK TASK (DISCUSS + RESEARCH)
82
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
83
+
84
+ ◆ Discussion + research enabled
85
+ ```
86
+
87
+ If `$RESEARCH_MODE` and `$VALIDATE_MODE` (no discuss):
88
+ ```
89
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
90
+ GSD ► QUICK TASK (RESEARCH + VALIDATE)
91
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
92
+
93
+ ◆ Research + plan checking + verification enabled
94
+ ```
95
+
96
+ If `$DISCUSS_MODE` only:
97
+ ```
98
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
99
+ GSD ► QUICK TASK (DISCUSS)
100
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
101
+
102
+ ◆ Discussion phase enabled — surfacing gray areas before planning
103
+ ```
104
+
105
+ If `$RESEARCH_MODE` only:
106
+ ```
107
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
108
+ GSD ► QUICK TASK (RESEARCH)
109
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
110
+
111
+ ◆ Research phase enabled — investigating approaches before planning
112
+ ```
113
+
114
+ If `$VALIDATE_MODE` only:
115
+ ```
116
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
117
+ GSD ► QUICK TASK (VALIDATE)
118
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
119
+
120
+ ◆ Plan checking + verification enabled
121
+ ```
122
+
123
+ ---
124
+
125
+ **Step 2: Initialize**
126
+
127
+ ```bash
128
+ _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}/get-shit-done/bin/${_GSD_SHIM_NAME}"; if [ -f "$GSD_TOOLS" ]; then gsd_run() { node "$GSD_TOOLS" "$@"; }; elif [ -f "${_GSD_RUNTIME_ROOT}/.claude/get-shit-done/bin/${_GSD_SHIM_NAME}" ]; then GSD_TOOLS="${_GSD_RUNTIME_ROOT}/.claude/get-shit-done/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/get-shit-done/bin/${_GSD_SHIM_NAME}" ]; then GSD_TOOLS="$HOME/.claude/get-shit-done/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 @opengsd/gsd-core@latest --claude --local" >&2; exit 1; fi
129
+ INIT=$(gsd_run query init.quick "$DESCRIPTION")
130
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
131
+ AGENT_SKILLS_PLANNER=$(gsd_run query agent-skills gsd-planner)
132
+ AGENT_SKILLS_EXECUTOR=$(gsd_run query agent-skills gsd-executor)
133
+ AGENT_SKILLS_CHECKER=$(gsd_run query agent-skills gsd-plan-checker)
134
+ AGENT_SKILLS_VERIFIER=$(gsd_run query agent-skills gsd-verifier)
135
+ ```
136
+
137
+ Parse JSON for: `planner_model`, `executor_model`, `checker_model`, `verifier_model`, `commit_docs`, `branch_name`, `quick_id`, `slug`, `date`, `timestamp`, `quick_dir`, `task_dir`, `roadmap_exists`, `planning_exists`.
138
+
139
+ ```bash
140
+ USE_WORKTREES=$(gsd_run query config-get workflow.use_worktrees 2>/dev/null || echo "true")
141
+ ```
142
+
143
+ If `USE_WORKTREES` is not `"false"`, run a startup orphan sweep before spawning any executors. This reaps locked worktrees whose lock-owner process is dead, whose branch is merged into the default branch, and whose lock file mtime is older than 5 minutes. Running it at startup prevents accumulation of orphaned worktrees from prior sessions that exited without cleanup (#3707).
144
+
145
+ ```bash
146
+ if [ "$USE_WORKTREES" != "false" ]; then
147
+ gsd_run query worktree.reap-orphans 2>/dev/null || true
148
+ fi
149
+ ```
150
+
151
+ If the project uses git submodules, worktree isolation is unsafe **only when the quick task touches a submodule path**. The previous behavior unconditionally disabled worktree isolation whenever `.gitmodules` existed, which penalised every quick task in a submodule project even when the task was nowhere near a submodule. Parse submodule paths from `.gitmodules` so the executor can act on actual submodule paths rather than the mere file's existence:
152
+
153
+ ```bash
154
+ # Parse submodule paths from .gitmodules once (empty if no .gitmodules).
155
+ # SUBMODULE_PATHS is a newline-separated list of repo-relative paths used as
156
+ # a fail-loud commit-time guard inside the quick-task executor — if the
157
+ # executor stages any path that falls inside SUBMODULE_PATHS, it must abort
158
+ # the commit and surface the conflict rather than silently corrupting the
159
+ # submodule state.
160
+ if [ -f .gitmodules ]; then
161
+ SUBMODULE_PATHS=$(git config --file .gitmodules --get-regexp '^submodule\..*\.path$' 2>/dev/null | awk '{print $2}')
162
+ else
163
+ SUBMODULE_PATHS=""
164
+ fi
165
+ ```
166
+
167
+ Quick mode does not have a pre-declared `files_modified` list (the task is freeform), so use a fail-loud guard at commit time: when the executor stages files for the quick-task commit, if any staged path falls inside a `SUBMODULE_PATHS` entry, abort with a clear error explaining that worktree-isolated commits cannot safely span submodule boundaries — the user can re-run with `workflow.use_worktrees=false` to fall back to sequential execution on the main tree. If `SUBMODULE_PATHS` is empty (no `.gitmodules` in the repo), worktree isolation proceeds normally.
168
+
169
+ **If `roadmap_exists` is false:** Error — Quick mode requires an active project with ROADMAP.md. Run `/gsd:new-project` first.
170
+
171
+ Quick tasks can run mid-phase - validation only checks ROADMAP.md exists, not phase status.
172
+
173
+ ---
174
+
175
+ **Step 2.5: Handle quick-task branching**
176
+
177
+ **If `branch_name` is empty/null:** Skip and continue on the current branch.
178
+
179
+ **If `branch_name` is set:** Check out the quick-task branch before any planning commits.
180
+
181
+ The new branch must fork off the project's default branch (`origin/HEAD`), not
182
+ off whatever HEAD happens to be checked out — otherwise consecutive quick tasks
183
+ compound on top of each other and stay unpushed (#2916). If `$branch_name`
184
+ already exists locally, reuse it as-is so resumed work is not rebased.
185
+
186
+ ```bash
187
+ DEFAULT_BRANCH=$(git symbolic-ref --quiet --short refs/remotes/origin/HEAD 2>/dev/null | sed 's|^origin/||')
188
+ DEFAULT_BRANCH=${DEFAULT_BRANCH:-main}
189
+
190
+ if git show-ref --verify --quiet "refs/heads/$branch_name"; then
191
+ git switch "$branch_name" \
192
+ || { echo "ERROR: Could not switch to existing quick-task branch '$branch_name'." >&2; exit 1; }
193
+ else
194
+ # Fetch the default branch so origin/$DEFAULT_BRANCH is current. If the fetch
195
+ # fails (offline, no remote, auth failure) AND we have no local copy of
196
+ # origin/$DEFAULT_BRANCH to fall back on, abort — creating the branch off
197
+ # arbitrary HEAD is exactly the bug #2916 fixed.
198
+ if ! git fetch --quiet origin "$DEFAULT_BRANCH"; then
199
+ if ! git show-ref --verify --quiet "refs/remotes/origin/$DEFAULT_BRANCH"; then
200
+ echo "ERROR: Could not fetch origin/$DEFAULT_BRANCH and no local copy exists. Refusing to create '$branch_name' off the current HEAD (#2916). Resolve the remote/network issue and retry." >&2
201
+ exit 1
202
+ fi
203
+ echo "WARNING: git fetch origin $DEFAULT_BRANCH failed; using the local copy of origin/$DEFAULT_BRANCH as base." >&2
204
+ fi
205
+
206
+ if [ -n "$(git status --porcelain)" ]; then
207
+ echo "WARNING: Uncommitted changes present. Carrying them onto the new quick-task branch — they will be branched off origin/$DEFAULT_BRANCH (not the previous-task HEAD)."
208
+ else
209
+ # Best-effort: fast-forward the local default branch so subsequent local
210
+ # work sees the latest tip. Failure here is non-fatal because we always
211
+ # create the new branch directly from origin/$DEFAULT_BRANCH below.
212
+ git switch --quiet "$DEFAULT_BRANCH" 2>/dev/null \
213
+ && git merge --ff-only --quiet "origin/$DEFAULT_BRANCH" 2>/dev/null \
214
+ || true
215
+ fi
216
+
217
+ # Pin the new branch to origin/$DEFAULT_BRANCH so the start point is
218
+ # deterministic regardless of which branch we are currently on (#2916).
219
+ # On success HEAD is exactly at origin/$DEFAULT_BRANCH, so a post-creation
220
+ # merge-base / "ahead-of" guard would be unreachable — the explicit base
221
+ # argument here is the single source of correctness for #2916.
222
+ git checkout -b "$branch_name" "origin/$DEFAULT_BRANCH" \
223
+ || { echo "ERROR: Could not create '$branch_name' from origin/$DEFAULT_BRANCH (#2916)." >&2; exit 1; }
224
+ fi
225
+ ```
226
+
227
+ All quick-task commits for this run stay on that branch. User handles merge/rebase afterward.
228
+
229
+ ---
230
+
231
+ **Step 3: Create task directory**
232
+
233
+ ```bash
234
+ mkdir -p "${task_dir}"
235
+ ```
236
+
237
+ ---
238
+
239
+ **Step 4: Create quick task directory**
240
+
241
+ Create the directory for this quick task:
242
+
243
+ ```bash
244
+ QUICK_DIR=".planning/quick/${quick_id}-${slug}"
245
+ mkdir -p "$QUICK_DIR"
246
+ ```
247
+
248
+ Report to user:
249
+ ```
250
+ Creating quick task ${quick_id}: ${DESCRIPTION}
251
+ Directory: ${QUICK_DIR}
252
+ ```
253
+
254
+ Store `$QUICK_DIR` for use in orchestration.
255
+
256
+ ---
257
+
258
+ **Step 4.5: Discussion phase (only when `$DISCUSS_MODE`)**
259
+
260
+ Skip this step entirely if NOT `$DISCUSS_MODE`.
261
+
262
+ Display banner:
263
+ ```
264
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
265
+ GSD ► DISCUSSING QUICK TASK
266
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
267
+
268
+ ◆ Surfacing gray areas for: ${DESCRIPTION}
269
+ ```
270
+
271
+ **4.5a. Identify gray areas**
272
+
273
+ Analyze `$DESCRIPTION` to identify 2-4 gray areas — implementation decisions that would change the outcome and that the user should weigh in on.
274
+
275
+ Use the domain-aware heuristic to generate phase-specific (not generic) gray areas:
276
+ - Something users **SEE** → layout, density, interactions, states
277
+ - Something users **CALL** → responses, errors, auth, versioning
278
+ - Something users **RUN** → output format, flags, modes, error handling
279
+ - Something users **READ** → structure, tone, depth, flow
280
+ - Something being **ORGANIZED** → criteria, grouping, naming, exceptions
281
+
282
+ Each gray area should be a concrete decision point, not a vague category. Example: "Loading behavior" not "UX".
283
+
284
+ **4.5b. Present gray areas**
285
+
286
+ ```
287
+ AskUserQuestion(
288
+ header: "Gray Areas",
289
+ question: "Which areas need clarification before planning?",
290
+ options: [
291
+ { label: "${area_1}", description: "${why_it_matters_1}" },
292
+ { label: "${area_2}", description: "${why_it_matters_2}" },
293
+ { label: "${area_3}", description: "${why_it_matters_3}" },
294
+ { label: "All clear", description: "Skip discussion — I know what I want" }
295
+ ],
296
+ multiSelect: true
297
+ )
298
+ ```
299
+
300
+ If user selects "All clear" → skip to Step 5 (no CONTEXT.md written).
301
+
302
+ **4.5c. Discuss selected areas**
303
+
304
+ For each selected area, ask 1-2 focused questions via AskUserQuestion:
305
+
306
+ ```
307
+ AskUserQuestion(
308
+ header: "${area_name}",
309
+ question: "${specific_question_about_this_area}",
310
+ options: [
311
+ { label: "${concrete_choice_1}", description: "${what_this_means}" },
312
+ { label: "${concrete_choice_2}", description: "${what_this_means}" },
313
+ { label: "${concrete_choice_3}", description: "${what_this_means}" },
314
+ { label: "You decide", description: "Claude's discretion" }
315
+ ],
316
+ multiSelect: false
317
+ )
318
+ ```
319
+
320
+ Rules:
321
+ - Options must be concrete choices, not abstract categories
322
+ - Highlight recommended choice where you have a clear opinion
323
+ - If user selects "Other" with freeform text, switch to plain text follow-up (per questioning.md freeform rule)
324
+ - If user selects "You decide", capture as Claude's Discretion in CONTEXT.md
325
+ - Max 2 questions per area — this is lightweight, not a deep dive
326
+
327
+ Collect all decisions into `$DECISIONS`.
328
+
329
+ **4.5d. Write CONTEXT.md**
330
+
331
+ Write `${QUICK_DIR}/${quick_id}-CONTEXT.md` using the standard context template structure:
332
+
333
+ ```markdown
334
+ # Quick Task ${quick_id}: ${DESCRIPTION} - Context
335
+
336
+ **Gathered:** ${date}
337
+ **Status:** Ready for planning
338
+
339
+ <domain>
340
+ ## Task Boundary
341
+
342
+ ${DESCRIPTION}
343
+
344
+ </domain>
345
+
346
+ <decisions>
347
+ ## Implementation Decisions
348
+
349
+ ### ${area_1_name}
350
+ - ${decision_from_discussion}
351
+
352
+ ### ${area_2_name}
353
+ - ${decision_from_discussion}
354
+
355
+ ### Claude's Discretion
356
+ ${areas_where_user_said_you_decide_or_areas_not_discussed}
357
+
358
+ </decisions>
359
+
360
+ <specifics>
361
+ ## Specific Ideas
362
+
363
+ ${any_specific_references_or_examples_from_discussion}
364
+
365
+ [If none: "No specific requirements — open to standard approaches"]
366
+
367
+ </specifics>
368
+
369
+ <canonical_refs>
370
+ ## Canonical References
371
+
372
+ ${any_specs_adrs_or_docs_referenced_during_discussion}
373
+
374
+ [If none: "No external specs — requirements fully captured in decisions above"]
375
+
376
+ </canonical_refs>
377
+ ```
378
+
379
+ Note: Quick task CONTEXT.md omits `<code_context>` and `<deferred>` sections (no codebase scouting, no phase scope to defer to). Keep it lean. The `<canonical_refs>` section is included when external docs were referenced — omit it only if no external docs apply.
380
+
381
+ Report: `Context captured: ${QUICK_DIR}/${quick_id}-CONTEXT.md`
382
+
383
+ ---
384
+
385
+ **Step 4.75: Research phase (only when `$RESEARCH_MODE`)**
386
+
387
+ Skip this step entirely if NOT `$RESEARCH_MODE`.
388
+
389
+ Display banner:
390
+ ```
391
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
392
+ GSD ► RESEARCHING QUICK TASK
393
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
394
+
395
+ ◆ Investigating approaches for: ${DESCRIPTION}
396
+ ```
397
+
398
+ Spawn a single focused researcher (not 4 parallel researchers like full phases — quick tasks need targeted research, not broad domain surveys):
399
+
400
+ ```
401
+ Agent(
402
+ prompt="
403
+ <research_context>
404
+
405
+ **Mode:** quick-task
406
+ **Task:** ${DESCRIPTION}
407
+ **Output:** ${QUICK_DIR}/${quick_id}-RESEARCH.md
408
+
409
+ <files_to_read>
410
+ - .planning/STATE.md (Project state — what's already built)
411
+ - .planning/PROJECT.md (Project context)
412
+ - ./CLAUDE.md (if exists — project-specific guidelines)
413
+ ${DISCUSS_MODE ? '- ' + QUICK_DIR + '/' + quick_id + '-CONTEXT.md (User decisions — research should align with these)' : ''}
414
+ </files_to_read>
415
+
416
+ ${AGENT_SKILLS_PLANNER}
417
+
418
+ </research_context>
419
+
420
+ <focus>
421
+ This is a quick task, not a full phase. Research should be concise and targeted:
422
+ 1. Best libraries/patterns for this specific task
423
+ 2. Common pitfalls and how to avoid them
424
+ 3. Integration points with existing codebase
425
+ 4. Any constraints or gotchas worth knowing before planning
426
+
427
+ Do NOT produce a full domain survey. Target 1-2 pages of actionable findings.
428
+ </focus>
429
+
430
+ <output>
431
+ Write research to: ${QUICK_DIR}/${quick_id}-RESEARCH.md
432
+ Use standard research format but keep it lean — skip sections that don't apply.
433
+ Return: ## RESEARCH COMPLETE with file path
434
+ </output>
435
+ ",
436
+ subagent_type="gsd-phase-researcher",
437
+ model="{planner_model}",
438
+ description="Research: ${DESCRIPTION}"
439
+ )
440
+ ```
441
+
442
+ > **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.
443
+
444
+ After researcher returns:
445
+ 1. Verify research exists at `${QUICK_DIR}/${quick_id}-RESEARCH.md`
446
+ 2. Report: "Research complete: ${QUICK_DIR}/${quick_id}-RESEARCH.md"
447
+
448
+ If research file not found, warn but continue: "Research agent did not produce output — proceeding to planning without research."
449
+
450
+ ---
451
+
452
+ **Step 5: Spawn planner (quick mode)**
453
+
454
+ **If `$VALIDATE_MODE`:** Use `quick-full` mode with stricter constraints.
455
+
456
+ **If NOT `$VALIDATE_MODE`:** Use standard `quick` mode.
457
+
458
+ ```
459
+ Agent(
460
+ prompt="
461
+ <planning_context>
462
+
463
+ **Mode:** ${VALIDATE_MODE ? 'quick-full' : 'quick'}
464
+ **Directory:** ${QUICK_DIR}
465
+ **Description:** ${DESCRIPTION}
466
+
467
+ <files_to_read>
468
+ - .planning/STATE.md (Project State)
469
+ - ./CLAUDE.md (if exists — follow project-specific guidelines)
470
+ ${DISCUSS_MODE ? '- ' + QUICK_DIR + '/' + quick_id + '-CONTEXT.md (User decisions — locked, do not revisit)' : ''}
471
+ ${RESEARCH_MODE ? '- ' + QUICK_DIR + '/' + quick_id + '-RESEARCH.md (Research findings — use to inform implementation choices)' : ''}
472
+ </files_to_read>
473
+
474
+ ${AGENT_SKILLS_PLANNER}
475
+
476
+ **Project skills:** Check .claude/skills/ or .agents/skills/ directory (if either exists) — read SKILL.md files, plans should account for project skill rules
477
+
478
+ </planning_context>
479
+
480
+ <constraints>
481
+ - Create a SINGLE plan with 1-3 focused tasks
482
+ - Quick tasks should be atomic and self-contained
483
+ ${RESEARCH_MODE ? '- Research findings are available — use them to inform library/pattern choices' : '- No research phase'}
484
+ ${VALIDATE_MODE ? '- Target ~40% context usage (structured for verification)' : '- Target ~30% context usage (simple, focused)'}
485
+ ${VALIDATE_MODE ? '- MUST generate `must_haves` in plan frontmatter (truths, artifacts, key_links)' : ''}
486
+ ${VALIDATE_MODE ? '- Each task MUST have `files`, `action`, `verify`, `done` fields' : ''}
487
+ </constraints>
488
+
489
+ <output>
490
+ Write plan to: ${QUICK_DIR}/${quick_id}-PLAN.md
491
+ Return: ## PLANNING COMPLETE with plan path
492
+ </output>
493
+ ",
494
+ subagent_type="gsd-planner",
495
+ model="{planner_model}",
496
+ description="Quick plan: ${DESCRIPTION}"
497
+ )
498
+ ```
499
+
500
+ > **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.
501
+
502
+ After planner returns:
503
+ 1. Verify plan exists at `${QUICK_DIR}/${quick_id}-PLAN.md`
504
+ 2. Extract plan count (typically 1 for quick tasks)
505
+ 3. Report: "Plan created: ${QUICK_DIR}/${quick_id}-PLAN.md"
506
+
507
+ If plan not found, error: "Planner failed to create ${quick_id}-PLAN.md"
508
+
509
+ ---
510
+
511
+ **Step 5.5: Plan-checker loop (only when `$VALIDATE_MODE`)**
512
+
513
+ Skip this step entirely if NOT `$VALIDATE_MODE`.
514
+
515
+ Display banner:
516
+ ```
517
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
518
+ GSD ► CHECKING PLAN
519
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
520
+
521
+ ◆ Spawning plan checker...
522
+ ```
523
+
524
+ Checker prompt:
525
+
526
+ ```markdown
527
+ <verification_context>
528
+ **Mode:** quick-full
529
+ **Task Description:** ${DESCRIPTION}
530
+
531
+ <files_to_read>
532
+ - ${QUICK_DIR}/${quick_id}-PLAN.md (Plan to verify)
533
+ </files_to_read>
534
+
535
+ ${AGENT_SKILLS_CHECKER}
536
+
537
+ **Scope:** This is a quick task, not a full phase. Skip checks that require a ROADMAP phase goal.
538
+ </verification_context>
539
+
540
+ <check_dimensions>
541
+ - Requirement coverage: Does the plan address the task description?
542
+ - Task completeness: Do tasks have files, action, verify, done fields?
543
+ - Key links: Are referenced files real?
544
+ - Scope sanity: Is this appropriately sized for a quick task (1-3 tasks)?
545
+ - must_haves derivation: Are must_haves traceable to the task description?
546
+
547
+ Skip: cross-plan deps (single plan), ROADMAP alignment
548
+ ${DISCUSS_MODE ? '- Context compliance: Does the plan honor locked decisions from CONTEXT.md?' : '- Skip: context compliance (no CONTEXT.md)'}
549
+ </check_dimensions>
550
+
551
+ <expected_output>
552
+ - ## VERIFICATION PASSED — all checks pass
553
+ - ## ISSUES FOUND — structured issue list
554
+ </expected_output>
555
+ ```
556
+
557
+ ```
558
+ Agent(
559
+ prompt=checker_prompt,
560
+ subagent_type="gsd-plan-checker",
561
+ model="{checker_model}",
562
+ description="Check quick plan: ${DESCRIPTION}"
563
+ )
564
+ ```
565
+
566
+ > **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.
567
+
568
+ **Handle checker return:**
569
+
570
+ - **`## VERIFICATION PASSED`:** Display confirmation, proceed to step 6.
571
+ - **`## ISSUES FOUND`:** Display issues, check iteration count, enter revision loop.
572
+
573
+ **Revision loop (max 2 iterations):**
574
+
575
+ Track `iteration_count` (starts at 1 after initial plan + check).
576
+
577
+ **If iteration_count < 2:**
578
+
579
+ Display: `Sending back to planner for revision... (iteration ${N}/2)`
580
+
581
+ Revision prompt:
582
+
583
+ ```markdown
584
+ <revision_context>
585
+ **Mode:** quick-full (revision)
586
+
587
+ <files_to_read>
588
+ - ${QUICK_DIR}/${quick_id}-PLAN.md (Existing plan)
589
+ </files_to_read>
590
+
591
+ ${AGENT_SKILLS_PLANNER}
592
+
593
+ **Checker issues:** ${structured_issues_from_checker}
594
+
595
+ </revision_context>
596
+
597
+ <instructions>
598
+ Make targeted updates to address checker issues.
599
+ Do NOT replan from scratch unless issues are fundamental.
600
+ Return what changed.
601
+ </instructions>
602
+ ```
603
+
604
+ ```
605
+ Agent(
606
+ prompt=revision_prompt,
607
+ subagent_type="gsd-planner",
608
+ model="{planner_model}",
609
+ description="Revise quick plan: ${DESCRIPTION}"
610
+ )
611
+ ```
612
+
613
+ > **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.
614
+
615
+ After planner returns → spawn checker again, increment iteration_count.
616
+
617
+ **If iteration_count >= 2:**
618
+
619
+ Display: `Max iterations reached. ${N} issues remain:` + issue list
620
+
621
+ Offer: 1) Force proceed, 2) Abort
622
+
623
+ ---
624
+
625
+ **Step 5.6: Pre-dispatch plan commit (worktree mode only)**
626
+
627
+ When `USE_WORKTREES !== "false"`, commit PLAN.md to the current branch **before** spawning the executor. This ensures the worktree inherits PLAN.md at its branch HEAD so the executor can read it via a worktree-rooted path — avoiding the main-repo path priming that triggers CC #36182 path-resolution drift.
628
+
629
+ Skip this step entirely if `USE_WORKTREES === "false"` (non-worktree mode: PLAN.md is committed in Step 8 as usual).
630
+
631
+ ```bash
632
+ if [ "${USE_WORKTREES}" != "false" ]; then
633
+ COMMIT_DOCS=$(gsd_run query config-get commit_docs 2>/dev/null || echo "true")
634
+ if [ "$COMMIT_DOCS" != "false" ]; then
635
+ git add "${QUICK_DIR}/${quick_id}-PLAN.md"
636
+ # No-op skip if nothing actually staged (idempotent re-runs).
637
+ if git diff --cached --quiet -- "${QUICK_DIR}/${quick_id}-PLAN.md"; then
638
+ echo "ℹ Pre-dispatch PLAN.md commit skipped (no staged changes)"
639
+ else
640
+ # Run hooks normally (#2924). If a project opts out via
641
+ # workflow.worktree_skip_hooks=true, honor that opt-in only.
642
+ SKIP_HOOKS=$(gsd_run query config-get workflow.worktree_skip_hooks 2>/dev/null || echo "false")
643
+ if [ "$SKIP_HOOKS" = "true" ]; then
644
+ git commit --no-verify -m "docs(${quick_id}): pre-dispatch plan for ${DESCRIPTION}" -- "${QUICK_DIR}/${quick_id}-PLAN.md" \
645
+ || { echo "ERROR: pre-dispatch PLAN.md commit failed (--no-verify path). Aborting before executor dispatch." >&2; exit 1; }
646
+ else
647
+ git commit -m "docs(${quick_id}): pre-dispatch plan for ${DESCRIPTION}" -- "${QUICK_DIR}/${quick_id}-PLAN.md" \
648
+ || { echo "ERROR: pre-dispatch PLAN.md commit failed — likely a pre-commit hook failure. Fix the hook output above (or set workflow.worktree_skip_hooks=true to bypass) and re-run." >&2; exit 1; }
649
+ fi
650
+ fi
651
+ fi
652
+ fi
653
+ ```
654
+
655
+ ---
656
+
657
+ **Step 6: Spawn executor**
658
+
659
+ Capture current HEAD before spawning (used for worktree branch check):
660
+ ```bash
661
+ EXPECTED_BASE=$(git rev-parse HEAD)
662
+ if [ "${USE_WORKTREES:-true}" != "false" ]; then
663
+ QUICK_WORKTREE_MANIFEST=$(mktemp "${TMPDIR:-/tmp}/gsd-quick-worktree-XXXXXX.json")
664
+ printf '{"worktrees":[]}\n' > "$QUICK_WORKTREE_MANIFEST"
665
+ export QUICK_WORKTREE_MANIFEST
666
+ fi
667
+ ```
668
+
669
+ Spawn gsd-executor with plan reference:
670
+
671
+ ```
672
+ Agent(
673
+ prompt="
674
+ Execute quick task ${quick_id}.
675
+
676
+ ${USE_WORKTREES !== "false" ? `
677
+ <worktree_branch_check>
678
+ FIRST ACTION before any other work: verify this worktree's HEAD is bound to a per-agent
679
+ branch and that the branch is based on the correct commit.
680
+
681
+ Step 1 — HEAD attachment assertion (MANDATORY, runs before any reset/commit):
682
+ HEAD_REF=$(git symbolic-ref --quiet HEAD || echo "DETACHED")
683
+ ACTUAL_BRANCH=$(git rev-parse --abbrev-ref HEAD)
684
+ if [ "$HEAD_REF" = "DETACHED" ] || echo "$ACTUAL_BRANCH" | grep -Eq '^(main|master|develop|trunk|release/.*)$'; then
685
+ echo "FATAL: worktree HEAD is on '$ACTUAL_BRANCH' (expected per-agent branch like worktree-agent-*)." >&2
686
+ echo "Refusing to commit/reset on a protected ref. DO NOT self-recover via 'git update-ref refs/heads/$ACTUAL_BRANCH' — that destroys concurrent work (#2924)." >&2
687
+ echo "Aborting before any commits. Surface as a blocker for human review." >&2
688
+ exit 1
689
+ fi
690
+ if ! echo "$ACTUAL_BRANCH" | grep -Eq '^worktree-agent-[A-Za-z0-9._/-]+$'; then
691
+ echo "FATAL: worktree HEAD '$ACTUAL_BRANCH' is not in the worktree-agent-* namespace (Claude Code's per-agent worktree branch namespace)." >&2
692
+ echo "Refusing to commit; surface as blocker (#2924)." >&2
693
+ exit 1
694
+ fi
695
+
696
+ Step 2 — Base correctness (only after Step 1 passes):
697
+ Run: git merge-base HEAD ${EXPECTED_BASE}
698
+ If the result differs from ${EXPECTED_BASE}, hard-reset to the correct base (safe — Step 1 confirmed HEAD is on a per-agent branch and the worktree is fresh):
699
+ git reset --hard ${EXPECTED_BASE}
700
+ Then verify: if [ "$(git rev-parse HEAD)" != "${EXPECTED_BASE}" ]; then echo "ERROR: Could not correct worktree base"; exit 1; fi
701
+
702
+ This corrects a known issue where EnterWorktree creates branches from main instead of the feature branch HEAD (#2015) and prevents the destructive HEAD-on-master self-recovery path (#2924).
703
+ </worktree_branch_check>
704
+ ` : ''}
705
+
706
+ <files_to_read>
707
+ - ${QUICK_DIR}/${quick_id}-PLAN.md (Plan)
708
+ - .planning/STATE.md (Project state)
709
+ - ./CLAUDE.md (Project instructions, if exists)
710
+ - .claude/skills/ or .agents/skills/ (Project skills, if either exists — list skills, read SKILL.md for each, follow relevant rules during implementation)
711
+ </files_to_read>
712
+
713
+ ${AGENT_SKILLS_EXECUTOR}
714
+
715
+ <submodule_commit_guard>
716
+ SUBMODULE_PATHS for this project: ${SUBMODULE_PATHS}
717
+
718
+ If SUBMODULE_PATHS is non-empty, you MUST run this fail-loud guard immediately
719
+ before EVERY git commit you create during this quick task (after \`git add\`,
720
+ before \`git commit\`). Quick mode does not have a pre-declared files_modified
721
+ list, so the guard runs at commit time:
722
+
723
+ \`\`\`bash
724
+ SUBMODULE_PATHS=\"${SUBMODULE_PATHS}\"
725
+ if [ -n \"\$SUBMODULE_PATHS\" ]; then
726
+ STAGED=\$(git diff --cached --name-only)
727
+ for sm_raw in \$SUBMODULE_PATHS; do
728
+ sm=\"\${sm_raw#./}\"
729
+ sm=\"\${sm%/}\"
730
+ [ -z \"\$sm\" ] && continue
731
+ for f_raw in \$STAGED; do
732
+ f=\"\${f_raw#./}\"
733
+ f=\"\${f%/}\"
734
+ case \"\$f\" in
735
+ \"\$sm\"|\"\$sm\"/*)
736
+ echo \"ABORT: staged path \$f_raw falls inside submodule \$sm — worktree-isolated commits cannot safely span submodule boundaries. Re-run with workflow.use_worktrees=false.\" >&2
737
+ exit 1 ;;
738
+ esac
739
+ done
740
+ done
741
+ fi
742
+ \`\`\`
743
+
744
+ If the guard aborts, do NOT attempt the commit, do NOT remove the staged files,
745
+ and do NOT continue subsequent tasks. Surface the abort message in your
746
+ SUMMARY.md and stop — the user must rerun with worktrees disabled.
747
+ </submodule_commit_guard>
748
+
749
+ <constraints>
750
+ - Execute all tasks in the plan
751
+ - Commit each task atomically (code changes only)
752
+ - Run the <submodule_commit_guard> bash block before every \`git commit\` if SUBMODULE_PATHS is non-empty
753
+ - Create summary at: ${QUICK_DIR}/${quick_id}-SUMMARY.md
754
+ - Do NOT commit docs artifacts (SUMMARY.md, STATE.md, PLAN.md) — the orchestrator handles the docs commit in Step 8
755
+ - Do NOT update ROADMAP.md (quick tasks are separate from planned phases)
756
+ </constraints>
757
+ ",
758
+ subagent_type="gsd-executor",
759
+ model="{executor_model}",
760
+ ${USE_WORKTREES !== "false" ? 'isolation="worktree",' : ''}
761
+ description="Execute: ${DESCRIPTION}"
762
+ )
763
+ ```
764
+
765
+ > **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.
766
+
767
+ If the executor ran with `isolation="worktree"`, append its returned `{agent_id, worktree_path, branch, expected_base}` metadata to `QUICK_WORKTREE_MANIFEST` before cleanup. If any field is unavailable, stop and ask for recovery; do not discover global worktrees.
768
+
769
+ After executor returns:
770
+ 1. **Worktree cleanup:** If the executor ran with `isolation="worktree"`, merge the worktree branch back and clean up:
771
+ ```bash
772
+ QUICK_WORKTREE_MANIFEST=${QUICK_WORKTREE_MANIFEST:-$WAVE_WORKTREE_MANIFEST}
773
+ [ -n "${QUICK_WORKTREE_MANIFEST:-}" ] && [ -f "$QUICK_WORKTREE_MANIFEST" ] || {
774
+ echo "BLOCKED: missing QUICK_WORKTREE_MANIFEST; refusing broad worktree cleanup (#3384)." >&2
775
+ exit 1
776
+ }
777
+
778
+ # Prefer the bounded cleanup helper. It verifies branch identity, expected
779
+ # base, deletion diffs, merge result, and worktree removal before branch
780
+ # deletion. If it blocks, resolve the reported manifest entry and rerun.
781
+ # Fail closed: SDK refusal (safety guard #3174/#3384) must surface — do not swallow exit 1.
782
+ gsd_run query worktree.cleanup-wave --manifest "$QUICK_WORKTREE_MANIFEST" || exit 1
783
+ ```
784
+ If `workflow.use_worktrees` is `false`, skip this step.
785
+ 2. Verify summary exists at `${QUICK_DIR}/${quick_id}-SUMMARY.md`
786
+ 3. Extract commit hash from executor output
787
+ 4. Report completion status
788
+
789
+ **Known Claude Code bug (classifyHandoffIfNeeded):** If executor reports "failed" with error `classifyHandoffIfNeeded is not defined`, this is a Claude Code runtime bug — not a real failure. Check if summary file exists and git log shows commits. If so, treat as successful.
790
+
791
+ If summary not found, error: "Executor failed to create ${quick_id}-SUMMARY.md"
792
+
793
+ Note: For quick tasks producing multiple plans (rare), spawn executors in parallel waves per execute-phase patterns.
794
+
795
+ ---
796
+
797
+ **Step 6.25: Code review (auto)**
798
+
799
+ Skip this step entirely if `$FULL_MODE` is false.
800
+
801
+ **Config gate:**
802
+ ```bash
803
+ CODE_REVIEW_ENABLED=$(gsd_run query config-get workflow.code_review 2>/dev/null || echo "true")
804
+ ```
805
+ If `"false"`, skip with message "Code review skipped (workflow.code_review=false)".
806
+
807
+ **Scope files from executor's commits:**
808
+ ```bash
809
+ # Find the diff base: last commit before quick task started
810
+ # Use git log to find commits referencing the quick task id, then take the parent of the oldest
811
+ QUICK_COMMITS=$(git log --oneline --format="%H" --grep="${quick_id}" 2>/dev/null)
812
+ if [ -n "$QUICK_COMMITS" ]; then
813
+ DIFF_BASE=$(echo "$QUICK_COMMITS" | tail -1)^
814
+ # Verify parent exists (guard against first commit in repo)
815
+ git rev-parse "${DIFF_BASE}" >/dev/null 2>&1 || DIFF_BASE=$(echo "$QUICK_COMMITS" | tail -1)
816
+ else
817
+ # No commits found for this quick task — skip review
818
+ DIFF_BASE=""
819
+ fi
820
+
821
+ if [ -n "$DIFF_BASE" ]; then
822
+ CHANGED_FILES=$(git diff --name-only "${DIFF_BASE}..HEAD" -- . ':!.planning' 2>/dev/null | tr '\n' ' ')
823
+ else
824
+ CHANGED_FILES=""
825
+ fi
826
+ ```
827
+
828
+ If `CHANGED_FILES` is empty, skip with "No source files changed — skipping code review."
829
+
830
+ **Invoke review:**
831
+ ```
832
+ Agent(
833
+ prompt="Review these files for bugs, security issues, and code quality.
834
+ Files: ${CHANGED_FILES}
835
+ Output: ${QUICK_DIR}/${quick_id}-REVIEW.md
836
+ Depth: quick",
837
+ subagent_type="gsd-code-reviewer",
838
+ model="{executor_model}"
839
+ )
840
+ ```
841
+
842
+ > **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.
843
+
844
+ If review produces findings, display advisory message. **Error handling:** Failures are non-blocking — catch and proceed.
845
+
846
+ ---
847
+
848
+ **Step 6.5: Verification (only when `$VALIDATE_MODE`)**
849
+
850
+ Skip this step entirely if NOT `$VALIDATE_MODE`.
851
+
852
+ Display banner:
853
+ ```
854
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
855
+ GSD ► VERIFYING RESULTS
856
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
857
+
858
+ ◆ Spawning verifier...
859
+ ```
860
+
861
+ ```
862
+ Agent(
863
+ prompt="Verify quick task goal achievement.
864
+ Task directory: ${QUICK_DIR}
865
+ Task goal: ${DESCRIPTION}
866
+
867
+ <files_to_read>
868
+ - ${QUICK_DIR}/${quick_id}-PLAN.md (Plan)
869
+ </files_to_read>
870
+
871
+ ${AGENT_SKILLS_VERIFIER}
872
+
873
+ Check must_haves against actual codebase. Create VERIFICATION.md at ${QUICK_DIR}/${quick_id}-VERIFICATION.md.",
874
+ subagent_type="gsd-verifier",
875
+ model="{verifier_model}",
876
+ description="Verify: ${DESCRIPTION}"
877
+ )
878
+ ```
879
+
880
+ > **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.
881
+
882
+ Read verification status:
883
+ ```bash
884
+ grep "^status:" "${QUICK_DIR}/${quick_id}-VERIFICATION.md" | cut -d: -f2 | tr -d ' '
885
+ ```
886
+
887
+ Store as `$VERIFICATION_STATUS`.
888
+
889
+ | Status | Action |
890
+ |--------|--------|
891
+ | `passed` | Store `$VERIFICATION_STATUS = "Verified"`, continue to step 7 |
892
+ | `human_needed` | Display items needing manual check, store `$VERIFICATION_STATUS = "Needs Review"`, continue |
893
+ | `gaps_found` | Display gap summary, offer: 1) Re-run executor to fix gaps, 2) Accept as-is. Store `$VERIFICATION_STATUS = "Gaps"` |
894
+
895
+ ---
896
+
897
+ **Step 7: Update STATE.md**
898
+
899
+ Update STATE.md with quick task completion record.
900
+
901
+ **7a. Check if "Quick Tasks Completed" section exists:**
902
+
903
+ Read STATE.md and check for `### Quick Tasks Completed` section.
904
+
905
+ **7b. If section doesn't exist, create it:**
906
+
907
+ Insert after `### Blockers/Concerns` section:
908
+
909
+ **If `$VALIDATE_MODE`:**
910
+ ```markdown
911
+ ### Quick Tasks Completed
912
+
913
+ | # | Description | Date | Commit | Status | Directory |
914
+ |---|-------------|------|--------|--------|-----------|
915
+ ```
916
+
917
+ **If NOT `$VALIDATE_MODE`:**
918
+ ```markdown
919
+ ### Quick Tasks Completed
920
+
921
+ | # | Description | Date | Commit | Directory |
922
+ |---|-------------|------|--------|-----------|
923
+ ```
924
+
925
+ **Note:** If the table already exists, match its existing column format. If adding `--validate` (or `--full`) to a project that already has quick tasks without a Status column, add the Status column to the header and separator rows, and leave Status empty for the new row's predecessors.
926
+
927
+ **7c. Append new row to table:**
928
+
929
+ Use `date` from init:
930
+
931
+ **If `$VALIDATE_MODE` (or table has Status column):**
932
+ ```markdown
933
+ | ${quick_id} | ${DESCRIPTION} | ${date} | ${commit_hash} | ${VERIFICATION_STATUS} | [${quick_id}-${slug}](./quick/${quick_id}-${slug}/) |
934
+ ```
935
+
936
+ **If NOT `$VALIDATE_MODE` (and table has no Status column):**
937
+ ```markdown
938
+ | ${quick_id} | ${DESCRIPTION} | ${date} | ${commit_hash} | [${quick_id}-${slug}](./quick/${quick_id}-${slug}/) |
939
+ ```
940
+
941
+ **7d. Update "Last activity" line:**
942
+
943
+ Use `date` from init:
944
+ ```
945
+ Last activity: ${date} - Completed quick task ${quick_id}: ${DESCRIPTION}
946
+ ```
947
+
948
+ Use Edit tool to make these changes atomically
949
+
950
+ ---
951
+
952
+ **Step 8: Final commit and completion**
953
+
954
+ Stage and commit quick task artifacts. This step MUST always run — even if the executor already committed some files (e.g. when running without worktree isolation). The `gsd-tools.cjs query commit` command (or legacy `gsd-tools.cjs` commit) handles already-committed files gracefully.
955
+
956
+ Build file list:
957
+ - `${QUICK_DIR}/${quick_id}-PLAN.md`
958
+ - `${QUICK_DIR}/${quick_id}-SUMMARY.md`
959
+ - `.planning/STATE.md`
960
+ - If `$DISCUSS_MODE` and context file exists: `${QUICK_DIR}/${quick_id}-CONTEXT.md`
961
+ - If `$RESEARCH_MODE` and research file exists: `${QUICK_DIR}/${quick_id}-RESEARCH.md`
962
+ - If `$VALIDATE_MODE` and verification file exists: `${QUICK_DIR}/${quick_id}-VERIFICATION.md`
963
+ - If `${QUICK_DIR}/${quick_id}-deferred-items.md` exists: `${QUICK_DIR}/${quick_id}-deferred-items.md`
964
+
965
+ ```bash
966
+ # Explicitly stage all artifacts before commit — PLAN.md may be untracked
967
+ # if the executor ran without worktree isolation and committed docs early
968
+ # Filter .planning/ files from staging if commit_docs is disabled (#1783)
969
+ COMMIT_DOCS=$(gsd_run query config-get commit_docs 2>/dev/null || echo "true")
970
+ if [ "$COMMIT_DOCS" = "false" ]; then
971
+ file_list_filtered=$(echo "${file_list}" | tr ' ' '\n' | grep -v '^\.planning/' | tr '\n' ' ')
972
+ git add ${file_list_filtered} 2>/dev/null
973
+ else
974
+ git add ${file_list} 2>/dev/null
975
+ fi
976
+ gsd_run query commit "docs(quick-${quick_id}): ${DESCRIPTION}" --files ${file_list}
977
+ ```
978
+
979
+ Get final commit hash:
980
+ ```bash
981
+ commit_hash=$(git rev-parse --short HEAD)
982
+ ```
983
+
984
+ Display completion output:
985
+
986
+ **If `$VALIDATE_MODE`:**
987
+ ```
988
+ ---
989
+
990
+ GSD > QUICK TASK COMPLETE (VALIDATED)
991
+
992
+ Quick Task ${quick_id}: ${DESCRIPTION}
993
+
994
+ ${RESEARCH_MODE ? 'Research: ' + QUICK_DIR + '/' + quick_id + '-RESEARCH.md' : ''}
995
+ Summary: ${QUICK_DIR}/${quick_id}-SUMMARY.md
996
+ Verification: ${QUICK_DIR}/${quick_id}-VERIFICATION.md (${VERIFICATION_STATUS})
997
+ Commit: ${commit_hash}
998
+
999
+ ---
1000
+
1001
+ Ready for next task: /gsd:quick ${GSD_WS}
1002
+ ```
1003
+
1004
+ **If NOT `$VALIDATE_MODE`:**
1005
+ ```
1006
+ ---
1007
+
1008
+ GSD > QUICK TASK COMPLETE
1009
+
1010
+ Quick Task ${quick_id}: ${DESCRIPTION}
1011
+
1012
+ ${RESEARCH_MODE ? 'Research: ' + QUICK_DIR + '/' + quick_id + '-RESEARCH.md' : ''}
1013
+ Summary: ${QUICK_DIR}/${quick_id}-SUMMARY.md
1014
+ Commit: ${commit_hash}
1015
+
1016
+ ---
1017
+
1018
+ Ready for next task: /gsd:quick ${GSD_WS}
1019
+ ```
1020
+
1021
+ </process>
1022
+
1023
+ <success_criteria>
1024
+ - [ ] ROADMAP.md validation passes
1025
+ - [ ] User provides task description
1026
+ - [ ] `--full`, `--validate`, `--discuss`, and `--research` flags parsed from arguments when present
1027
+ - [ ] `--full` sets all booleans (`$FULL_MODE`, `$DISCUSS_MODE`, `$RESEARCH_MODE`, `$VALIDATE_MODE`)
1028
+ - [ ] Slug generated (lowercase, hyphens, max 40 chars)
1029
+ - [ ] Quick ID generated (YYMMDD-xxx format, 2s Base36 precision)
1030
+ - [ ] Directory created at `.planning/quick/YYMMDD-xxx-slug/`
1031
+ - [ ] (--discuss) Gray areas identified and presented, decisions captured in `${quick_id}-CONTEXT.md`
1032
+ - [ ] (--research) Research agent spawned, `${quick_id}-RESEARCH.md` created
1033
+ - [ ] `${quick_id}-PLAN.md` created by planner (honors CONTEXT.md decisions when --discuss, uses RESEARCH.md findings when --research)
1034
+ - [ ] (--validate) Plan checker validates plan, revision loop capped at 2
1035
+ - [ ] `${quick_id}-SUMMARY.md` created by executor
1036
+ - [ ] (--validate) `${quick_id}-VERIFICATION.md` created by verifier
1037
+ - [ ] STATE.md updated with quick task row (Status column when --validate)
1038
+ - [ ] Artifacts committed
1039
+ </success_criteria>