gsd-remix 1.0.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 (554) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +939 -0
  3. package/README.zh-CN.md +876 -0
  4. package/agents/gsd-advisor-researcher.md +127 -0
  5. package/agents/gsd-ai-researcher.md +133 -0
  6. package/agents/gsd-assumptions-analyzer.md +105 -0
  7. package/agents/gsd-code-fixer.md +517 -0
  8. package/agents/gsd-code-reviewer.md +371 -0
  9. package/agents/gsd-codebase-mapper.md +781 -0
  10. package/agents/gsd-debug-session-manager.md +314 -0
  11. package/agents/gsd-debugger.md +1452 -0
  12. package/agents/gsd-doc-classifier.md +168 -0
  13. package/agents/gsd-doc-synthesizer.md +204 -0
  14. package/agents/gsd-doc-verifier.md +217 -0
  15. package/agents/gsd-doc-writer.md +615 -0
  16. package/agents/gsd-domain-researcher.md +153 -0
  17. package/agents/gsd-eval-auditor.md +191 -0
  18. package/agents/gsd-eval-planner.md +154 -0
  19. package/agents/gsd-executor.md +603 -0
  20. package/agents/gsd-framework-selector.md +160 -0
  21. package/agents/gsd-integration-checker.md +470 -0
  22. package/agents/gsd-intel-updater.md +334 -0
  23. package/agents/gsd-nyquist-auditor.md +203 -0
  24. package/agents/gsd-pattern-mapper.md +335 -0
  25. package/agents/gsd-phase-researcher.md +841 -0
  26. package/agents/gsd-plan-checker.md +978 -0
  27. package/agents/gsd-planner.md +1251 -0
  28. package/agents/gsd-project-researcher.md +677 -0
  29. package/agents/gsd-research-synthesizer.md +247 -0
  30. package/agents/gsd-roadmapper.md +688 -0
  31. package/agents/gsd-security-auditor.md +155 -0
  32. package/agents/gsd-ui-auditor.md +495 -0
  33. package/agents/gsd-ui-checker.md +309 -0
  34. package/agents/gsd-ui-researcher.md +380 -0
  35. package/agents/gsd-user-profiler.md +171 -0
  36. package/agents/gsd-verifier.md +830 -0
  37. package/bin/install.js +7062 -0
  38. package/commands/gsd/add-backlog.md +79 -0
  39. package/commands/gsd/add-phase.md +43 -0
  40. package/commands/gsd/add-tests.md +41 -0
  41. package/commands/gsd/add-todo.md +47 -0
  42. package/commands/gsd/ai-integration-phase.md +36 -0
  43. package/commands/gsd/analyze-dependencies.md +34 -0
  44. package/commands/gsd/audit-fix.md +33 -0
  45. package/commands/gsd/audit-milestone.md +36 -0
  46. package/commands/gsd/audit-uat.md +24 -0
  47. package/commands/gsd/autonomous.md +46 -0
  48. package/commands/gsd/check-todos.md +45 -0
  49. package/commands/gsd/cleanup.md +23 -0
  50. package/commands/gsd/code-review-fix.md +52 -0
  51. package/commands/gsd/code-review.md +55 -0
  52. package/commands/gsd/complete-milestone.md +136 -0
  53. package/commands/gsd/debug.md +263 -0
  54. package/commands/gsd/discuss-phase.md +69 -0
  55. package/commands/gsd/do.md +30 -0
  56. package/commands/gsd/docs-update.md +48 -0
  57. package/commands/gsd/eval-review.md +32 -0
  58. package/commands/gsd/execute-phase.md +63 -0
  59. package/commands/gsd/explore.md +27 -0
  60. package/commands/gsd/extract_learnings.md +22 -0
  61. package/commands/gsd/fast.md +30 -0
  62. package/commands/gsd/forensics.md +56 -0
  63. package/commands/gsd/from-gsd2.md +47 -0
  64. package/commands/gsd/graphify.md +201 -0
  65. package/commands/gsd/health.md +22 -0
  66. package/commands/gsd/help.md +24 -0
  67. package/commands/gsd/import.md +37 -0
  68. package/commands/gsd/inbox.md +38 -0
  69. package/commands/gsd/ingest-docs.md +42 -0
  70. package/commands/gsd/insert-phase.md +32 -0
  71. package/commands/gsd/intel.md +179 -0
  72. package/commands/gsd/join-discord.md +19 -0
  73. package/commands/gsd/list-phase-assumptions.md +46 -0
  74. package/commands/gsd/list-workspaces.md +19 -0
  75. package/commands/gsd/manager.md +40 -0
  76. package/commands/gsd/map-codebase.md +71 -0
  77. package/commands/gsd/milestone-summary.md +51 -0
  78. package/commands/gsd/new-milestone.md +44 -0
  79. package/commands/gsd/new-project.md +46 -0
  80. package/commands/gsd/new-workspace.md +44 -0
  81. package/commands/gsd/next.md +28 -0
  82. package/commands/gsd/note.md +34 -0
  83. package/commands/gsd/pause-work.md +38 -0
  84. package/commands/gsd/plan-milestone-gaps.md +34 -0
  85. package/commands/gsd/plan-phase.md +52 -0
  86. package/commands/gsd/plan-review-convergence.md +52 -0
  87. package/commands/gsd/plant-seed.md +28 -0
  88. package/commands/gsd/pr-branch.md +25 -0
  89. package/commands/gsd/profile-user.md +46 -0
  90. package/commands/gsd/progress.md +25 -0
  91. package/commands/gsd/quick.md +173 -0
  92. package/commands/gsd/reapply-patches.md +331 -0
  93. package/commands/gsd/remove-phase.md +31 -0
  94. package/commands/gsd/remove-workspace.md +26 -0
  95. package/commands/gsd/research-phase.md +195 -0
  96. package/commands/gsd/resume-work.md +40 -0
  97. package/commands/gsd/review-backlog.md +62 -0
  98. package/commands/gsd/review.md +40 -0
  99. package/commands/gsd/scan.md +26 -0
  100. package/commands/gsd/secure-phase.md +35 -0
  101. package/commands/gsd/session-report.md +19 -0
  102. package/commands/gsd/set-profile.md +12 -0
  103. package/commands/gsd/settings.md +36 -0
  104. package/commands/gsd/ship.md +23 -0
  105. package/commands/gsd/sketch-wrap-up.md +31 -0
  106. package/commands/gsd/sketch.md +49 -0
  107. package/commands/gsd/spec-phase.md +62 -0
  108. package/commands/gsd/spike-wrap-up.md +31 -0
  109. package/commands/gsd/spike.md +46 -0
  110. package/commands/gsd/stats.md +18 -0
  111. package/commands/gsd/sync-skills.md +19 -0
  112. package/commands/gsd/thread.md +227 -0
  113. package/commands/gsd/ui-phase.md +34 -0
  114. package/commands/gsd/ui-review.md +32 -0
  115. package/commands/gsd/ultraplan-phase.md +33 -0
  116. package/commands/gsd/undo.md +34 -0
  117. package/commands/gsd/update.md +37 -0
  118. package/commands/gsd/validate-phase.md +35 -0
  119. package/commands/gsd/verify-work.md +38 -0
  120. package/commands/gsd/workstreams.md +69 -0
  121. package/get-shit-done/bin/gsd-tools.cjs +1263 -0
  122. package/get-shit-done/bin/lib/artifacts.cjs +52 -0
  123. package/get-shit-done/bin/lib/audit.cjs +757 -0
  124. package/get-shit-done/bin/lib/commands.cjs +1023 -0
  125. package/get-shit-done/bin/lib/config-schema.cjs +79 -0
  126. package/get-shit-done/bin/lib/config.cjs +463 -0
  127. package/get-shit-done/bin/lib/core.cjs +1794 -0
  128. package/get-shit-done/bin/lib/docs.cjs +267 -0
  129. package/get-shit-done/bin/lib/frontmatter.cjs +379 -0
  130. package/get-shit-done/bin/lib/graphify.cjs +494 -0
  131. package/get-shit-done/bin/lib/gsd2-import.cjs +511 -0
  132. package/get-shit-done/bin/lib/init.cjs +1878 -0
  133. package/get-shit-done/bin/lib/intel.cjs +639 -0
  134. package/get-shit-done/bin/lib/learnings.cjs +378 -0
  135. package/get-shit-done/bin/lib/milestone.cjs +283 -0
  136. package/get-shit-done/bin/lib/model-profiles.cjs +71 -0
  137. package/get-shit-done/bin/lib/phase.cjs +1058 -0
  138. package/get-shit-done/bin/lib/profile-output.cjs +1080 -0
  139. package/get-shit-done/bin/lib/profile-pipeline.cjs +539 -0
  140. package/get-shit-done/bin/lib/roadmap.cjs +523 -0
  141. package/get-shit-done/bin/lib/schema-detect.cjs +238 -0
  142. package/get-shit-done/bin/lib/security.cjs +504 -0
  143. package/get-shit-done/bin/lib/state.cjs +1649 -0
  144. package/get-shit-done/bin/lib/template.cjs +226 -0
  145. package/get-shit-done/bin/lib/uat.cjs +288 -0
  146. package/get-shit-done/bin/lib/verify.cjs +1184 -0
  147. package/get-shit-done/bin/lib/workstream.cjs +495 -0
  148. package/get-shit-done/bin/repair-sdk.cjs +177 -0
  149. package/get-shit-done/contexts/dev.md +21 -0
  150. package/get-shit-done/contexts/research.md +22 -0
  151. package/get-shit-done/contexts/review.md +22 -0
  152. package/get-shit-done/references/agent-contracts.md +79 -0
  153. package/get-shit-done/references/ai-evals.md +156 -0
  154. package/get-shit-done/references/ai-frameworks.md +186 -0
  155. package/get-shit-done/references/artifact-types.md +131 -0
  156. package/get-shit-done/references/autonomous-smart-discuss.md +277 -0
  157. package/get-shit-done/references/checkpoints.md +808 -0
  158. package/get-shit-done/references/common-bug-patterns.md +114 -0
  159. package/get-shit-done/references/context-budget.md +49 -0
  160. package/get-shit-done/references/continuation-format.md +253 -0
  161. package/get-shit-done/references/debugger-philosophy.md +76 -0
  162. package/get-shit-done/references/decimal-phase-calculation.md +64 -0
  163. package/get-shit-done/references/doc-conflict-engine.md +91 -0
  164. package/get-shit-done/references/domain-probes.md +125 -0
  165. package/get-shit-done/references/executor-examples.md +110 -0
  166. package/get-shit-done/references/few-shot-examples/plan-checker.md +73 -0
  167. package/get-shit-done/references/few-shot-examples/verifier.md +109 -0
  168. package/get-shit-done/references/gate-prompts.md +100 -0
  169. package/get-shit-done/references/gates.md +70 -0
  170. package/get-shit-done/references/git-integration.md +295 -0
  171. package/get-shit-done/references/git-planning-commit.md +40 -0
  172. package/get-shit-done/references/ios-scaffold.md +123 -0
  173. package/get-shit-done/references/mandatory-initial-read.md +2 -0
  174. package/get-shit-done/references/model-profile-resolution.md +38 -0
  175. package/get-shit-done/references/model-profiles.md +145 -0
  176. package/get-shit-done/references/phase-argument-parsing.md +61 -0
  177. package/get-shit-done/references/planner-antipatterns.md +89 -0
  178. package/get-shit-done/references/planner-gap-closure.md +62 -0
  179. package/get-shit-done/references/planner-reviews.md +39 -0
  180. package/get-shit-done/references/planner-revision.md +87 -0
  181. package/get-shit-done/references/planner-source-audit.md +73 -0
  182. package/get-shit-done/references/planning-config.md +460 -0
  183. package/get-shit-done/references/project-skills-discovery.md +19 -0
  184. package/get-shit-done/references/questioning.md +162 -0
  185. package/get-shit-done/references/revision-loop.md +97 -0
  186. package/get-shit-done/references/sketch-interactivity.md +41 -0
  187. package/get-shit-done/references/sketch-theme-system.md +94 -0
  188. package/get-shit-done/references/sketch-tooling.md +45 -0
  189. package/get-shit-done/references/sketch-variant-patterns.md +81 -0
  190. package/get-shit-done/references/tdd.md +330 -0
  191. package/get-shit-done/references/thinking-models-debug.md +44 -0
  192. package/get-shit-done/references/thinking-models-execution.md +50 -0
  193. package/get-shit-done/references/thinking-models-planning.md +62 -0
  194. package/get-shit-done/references/thinking-models-research.md +50 -0
  195. package/get-shit-done/references/thinking-models-verification.md +55 -0
  196. package/get-shit-done/references/thinking-partner.md +96 -0
  197. package/get-shit-done/references/ui-brand.md +160 -0
  198. package/get-shit-done/references/universal-anti-patterns.md +63 -0
  199. package/get-shit-done/references/user-profiling.md +681 -0
  200. package/get-shit-done/references/verification-overrides.md +227 -0
  201. package/get-shit-done/references/verification-patterns.md +612 -0
  202. package/get-shit-done/references/workstream-flag.md +111 -0
  203. package/get-shit-done/templates/AI-SPEC.md +246 -0
  204. package/get-shit-done/templates/DEBUG.md +169 -0
  205. package/get-shit-done/templates/README.md +76 -0
  206. package/get-shit-done/templates/SECURITY.md +61 -0
  207. package/get-shit-done/templates/UAT.md +265 -0
  208. package/get-shit-done/templates/UI-SPEC.md +100 -0
  209. package/get-shit-done/templates/VALIDATION.md +76 -0
  210. package/get-shit-done/templates/claude-md.md +145 -0
  211. package/get-shit-done/templates/codebase/architecture.md +255 -0
  212. package/get-shit-done/templates/codebase/concerns.md +310 -0
  213. package/get-shit-done/templates/codebase/conventions.md +307 -0
  214. package/get-shit-done/templates/codebase/integrations.md +280 -0
  215. package/get-shit-done/templates/codebase/stack.md +186 -0
  216. package/get-shit-done/templates/codebase/structure.md +285 -0
  217. package/get-shit-done/templates/codebase/testing.md +480 -0
  218. package/get-shit-done/templates/config.json +56 -0
  219. package/get-shit-done/templates/context.md +352 -0
  220. package/get-shit-done/templates/continue-here.md +78 -0
  221. package/get-shit-done/templates/copilot-instructions.md +7 -0
  222. package/get-shit-done/templates/debug-subagent-prompt.md +91 -0
  223. package/get-shit-done/templates/dev-preferences.md +21 -0
  224. package/get-shit-done/templates/discovery.md +146 -0
  225. package/get-shit-done/templates/discussion-log.md +63 -0
  226. package/get-shit-done/templates/milestone-archive.md +123 -0
  227. package/get-shit-done/templates/milestone.md +115 -0
  228. package/get-shit-done/templates/phase-prompt.md +610 -0
  229. package/get-shit-done/templates/planner-subagent-prompt.md +117 -0
  230. package/get-shit-done/templates/project.md +186 -0
  231. package/get-shit-done/templates/requirements.md +231 -0
  232. package/get-shit-done/templates/research-project/ARCHITECTURE.md +204 -0
  233. package/get-shit-done/templates/research-project/FEATURES.md +147 -0
  234. package/get-shit-done/templates/research-project/PITFALLS.md +200 -0
  235. package/get-shit-done/templates/research-project/STACK.md +120 -0
  236. package/get-shit-done/templates/research-project/SUMMARY.md +170 -0
  237. package/get-shit-done/templates/research.md +592 -0
  238. package/get-shit-done/templates/retrospective.md +54 -0
  239. package/get-shit-done/templates/roadmap.md +202 -0
  240. package/get-shit-done/templates/spec.md +307 -0
  241. package/get-shit-done/templates/state.md +184 -0
  242. package/get-shit-done/templates/summary-complex.md +59 -0
  243. package/get-shit-done/templates/summary-minimal.md +41 -0
  244. package/get-shit-done/templates/summary-standard.md +48 -0
  245. package/get-shit-done/templates/summary.md +248 -0
  246. package/get-shit-done/templates/user-profile.md +146 -0
  247. package/get-shit-done/templates/user-setup.md +311 -0
  248. package/get-shit-done/templates/verification-report.md +322 -0
  249. package/get-shit-done/workflows/add-phase.md +112 -0
  250. package/get-shit-done/workflows/add-tests.md +354 -0
  251. package/get-shit-done/workflows/add-todo.md +160 -0
  252. package/get-shit-done/workflows/ai-integration-phase.md +284 -0
  253. package/get-shit-done/workflows/analyze-dependencies.md +96 -0
  254. package/get-shit-done/workflows/audit-fix.md +175 -0
  255. package/get-shit-done/workflows/audit-milestone.md +340 -0
  256. package/get-shit-done/workflows/audit-uat.md +109 -0
  257. package/get-shit-done/workflows/autonomous.md +789 -0
  258. package/get-shit-done/workflows/check-todos.md +179 -0
  259. package/get-shit-done/workflows/cleanup.md +154 -0
  260. package/get-shit-done/workflows/code-review-fix.md +497 -0
  261. package/get-shit-done/workflows/code-review.md +515 -0
  262. package/get-shit-done/workflows/complete-milestone.md +847 -0
  263. package/get-shit-done/workflows/diagnose-issues.md +238 -0
  264. package/get-shit-done/workflows/discovery-phase.md +291 -0
  265. package/get-shit-done/workflows/discuss-phase-assumptions.md +670 -0
  266. package/get-shit-done/workflows/discuss-phase-power.md +308 -0
  267. package/get-shit-done/workflows/discuss-phase.md +1378 -0
  268. package/get-shit-done/workflows/do.md +110 -0
  269. package/get-shit-done/workflows/docs-update.md +1155 -0
  270. package/get-shit-done/workflows/eval-review.md +155 -0
  271. package/get-shit-done/workflows/execute-phase.md +1677 -0
  272. package/get-shit-done/workflows/execute-plan.md +533 -0
  273. package/get-shit-done/workflows/explore.md +141 -0
  274. package/get-shit-done/workflows/extract_learnings.md +242 -0
  275. package/get-shit-done/workflows/fast.md +105 -0
  276. package/get-shit-done/workflows/forensics.md +265 -0
  277. package/get-shit-done/workflows/graduation.md +195 -0
  278. package/get-shit-done/workflows/health.md +314 -0
  279. package/get-shit-done/workflows/help.md +667 -0
  280. package/get-shit-done/workflows/import.md +246 -0
  281. package/get-shit-done/workflows/inbox.md +387 -0
  282. package/get-shit-done/workflows/ingest-docs.md +328 -0
  283. package/get-shit-done/workflows/insert-phase.md +130 -0
  284. package/get-shit-done/workflows/list-phase-assumptions.md +178 -0
  285. package/get-shit-done/workflows/list-workspaces.md +56 -0
  286. package/get-shit-done/workflows/manager.md +365 -0
  287. package/get-shit-done/workflows/map-codebase.md +393 -0
  288. package/get-shit-done/workflows/milestone-summary.md +223 -0
  289. package/get-shit-done/workflows/new-milestone.md +611 -0
  290. package/get-shit-done/workflows/new-project.md +1391 -0
  291. package/get-shit-done/workflows/new-workspace.md +239 -0
  292. package/get-shit-done/workflows/next.md +220 -0
  293. package/get-shit-done/workflows/node-repair.md +92 -0
  294. package/get-shit-done/workflows/note.md +158 -0
  295. package/get-shit-done/workflows/pause-work.md +243 -0
  296. package/get-shit-done/workflows/plan-milestone-gaps.md +273 -0
  297. package/get-shit-done/workflows/plan-phase.md +1349 -0
  298. package/get-shit-done/workflows/plan-review-convergence.md +254 -0
  299. package/get-shit-done/workflows/plant-seed.md +172 -0
  300. package/get-shit-done/workflows/pr-branch.md +157 -0
  301. package/get-shit-done/workflows/profile-user.md +452 -0
  302. package/get-shit-done/workflows/progress.md +619 -0
  303. package/get-shit-done/workflows/quick.md +970 -0
  304. package/get-shit-done/workflows/remove-phase.md +155 -0
  305. package/get-shit-done/workflows/remove-workspace.md +92 -0
  306. package/get-shit-done/workflows/research-phase.md +89 -0
  307. package/get-shit-done/workflows/resume-project.md +326 -0
  308. package/get-shit-done/workflows/review.md +344 -0
  309. package/get-shit-done/workflows/scan.md +102 -0
  310. package/get-shit-done/workflows/secure-phase.md +166 -0
  311. package/get-shit-done/workflows/session-report.md +146 -0
  312. package/get-shit-done/workflows/settings.md +319 -0
  313. package/get-shit-done/workflows/ship.md +302 -0
  314. package/get-shit-done/workflows/sketch-wrap-up.md +283 -0
  315. package/get-shit-done/workflows/sketch.md +286 -0
  316. package/get-shit-done/workflows/spec-phase.md +262 -0
  317. package/get-shit-done/workflows/spike-wrap-up.md +281 -0
  318. package/get-shit-done/workflows/spike.md +362 -0
  319. package/get-shit-done/workflows/stats.md +60 -0
  320. package/get-shit-done/workflows/sync-skills.md +182 -0
  321. package/get-shit-done/workflows/transition.md +693 -0
  322. package/get-shit-done/workflows/ui-phase.md +323 -0
  323. package/get-shit-done/workflows/ui-review.md +190 -0
  324. package/get-shit-done/workflows/ultraplan-phase.md +189 -0
  325. package/get-shit-done/workflows/undo.md +314 -0
  326. package/get-shit-done/workflows/update.md +587 -0
  327. package/get-shit-done/workflows/validate-phase.md +176 -0
  328. package/get-shit-done/workflows/verify-phase.md +465 -0
  329. package/get-shit-done/workflows/verify-work.md +740 -0
  330. package/hooks/dist/gsd-check-update-worker.js +108 -0
  331. package/hooks/dist/gsd-check-update.js +64 -0
  332. package/hooks/dist/gsd-context-monitor.js +192 -0
  333. package/hooks/dist/gsd-phase-boundary.sh +28 -0
  334. package/hooks/dist/gsd-prompt-guard.js +97 -0
  335. package/hooks/dist/gsd-read-guard.js +82 -0
  336. package/hooks/dist/gsd-read-injection-scanner.js +152 -0
  337. package/hooks/dist/gsd-session-state.sh +34 -0
  338. package/hooks/dist/gsd-statusline.js +293 -0
  339. package/hooks/dist/gsd-validate-commit.sh +48 -0
  340. package/hooks/dist/gsd-workflow-guard.js +94 -0
  341. package/hooks/gsd-check-update-worker.js +108 -0
  342. package/hooks/gsd-check-update.js +64 -0
  343. package/hooks/gsd-context-monitor.js +192 -0
  344. package/hooks/gsd-phase-boundary.sh +28 -0
  345. package/hooks/gsd-prompt-guard.js +97 -0
  346. package/hooks/gsd-read-guard.js +82 -0
  347. package/hooks/gsd-read-injection-scanner.js +152 -0
  348. package/hooks/gsd-session-state.sh +34 -0
  349. package/hooks/gsd-statusline.js +293 -0
  350. package/hooks/gsd-validate-commit.sh +48 -0
  351. package/hooks/gsd-workflow-guard.js +94 -0
  352. package/package.json +59 -0
  353. package/scripts/base64-scan.sh +262 -0
  354. package/scripts/build-hooks.js +95 -0
  355. package/scripts/gen-inventory-manifest.cjs +109 -0
  356. package/scripts/prompt-injection-scan.sh +201 -0
  357. package/scripts/run-tests.cjs +33 -0
  358. package/scripts/secret-scan.sh +227 -0
  359. package/sdk/package-lock.json +1998 -0
  360. package/sdk/package.json +52 -0
  361. package/sdk/prompts/agents/gsd-executor.md +110 -0
  362. package/sdk/prompts/agents/gsd-phase-researcher.md +158 -0
  363. package/sdk/prompts/agents/gsd-plan-checker.md +160 -0
  364. package/sdk/prompts/agents/gsd-planner.md +214 -0
  365. package/sdk/prompts/agents/gsd-project-researcher.md +323 -0
  366. package/sdk/prompts/agents/gsd-research-synthesizer.md +237 -0
  367. package/sdk/prompts/agents/gsd-roadmapper.md +670 -0
  368. package/sdk/prompts/agents/gsd-verifier.md +159 -0
  369. package/sdk/prompts/templates/project.md +186 -0
  370. package/sdk/prompts/templates/requirements.md +231 -0
  371. package/sdk/prompts/templates/research-project/ARCHITECTURE.md +204 -0
  372. package/sdk/prompts/templates/research-project/FEATURES.md +147 -0
  373. package/sdk/prompts/templates/research-project/PITFALLS.md +200 -0
  374. package/sdk/prompts/templates/research-project/STACK.md +120 -0
  375. package/sdk/prompts/templates/research-project/SUMMARY.md +170 -0
  376. package/sdk/prompts/templates/roadmap.md +202 -0
  377. package/sdk/prompts/templates/state.md +175 -0
  378. package/sdk/prompts/workflows/discuss-phase.md +126 -0
  379. package/sdk/prompts/workflows/execute-plan.md +106 -0
  380. package/sdk/prompts/workflows/plan-phase.md +84 -0
  381. package/sdk/prompts/workflows/research-phase.md +45 -0
  382. package/sdk/prompts/workflows/verify-phase.md +142 -0
  383. package/sdk/src/assembled-prompts.test.ts +349 -0
  384. package/sdk/src/cli-transport.test.ts +388 -0
  385. package/sdk/src/cli-transport.ts +130 -0
  386. package/sdk/src/cli.test.ts +383 -0
  387. package/sdk/src/cli.ts +670 -0
  388. package/sdk/src/config.test.ts +168 -0
  389. package/sdk/src/config.ts +177 -0
  390. package/sdk/src/context-engine.test.ts +295 -0
  391. package/sdk/src/context-engine.ts +170 -0
  392. package/sdk/src/context-truncation.test.ts +163 -0
  393. package/sdk/src/context-truncation.ts +233 -0
  394. package/sdk/src/e2e.integration.test.ts +178 -0
  395. package/sdk/src/errors.ts +72 -0
  396. package/sdk/src/event-stream.test.ts +661 -0
  397. package/sdk/src/event-stream.ts +441 -0
  398. package/sdk/src/failure-memory.test.ts +457 -0
  399. package/sdk/src/failure-memory.ts +1324 -0
  400. package/sdk/src/golden/capture.ts +95 -0
  401. package/sdk/src/golden/fixtures/generate-slug.golden.json +1 -0
  402. package/sdk/src/golden/fixtures/profile-sample-sessions/demo-project/sample.jsonl +3 -0
  403. package/sdk/src/golden/fixtures/summary-extract-sample.md +26 -0
  404. package/sdk/src/golden/fixtures/uat-render-checkpoint-sample.md +15 -0
  405. package/sdk/src/golden/golden-integration-covered.ts +30 -0
  406. package/sdk/src/golden/golden-mutation-covered.ts +7 -0
  407. package/sdk/src/golden/golden-policy.test.ts +8 -0
  408. package/sdk/src/golden/golden-policy.ts +112 -0
  409. package/sdk/src/golden/golden.integration.test.ts +373 -0
  410. package/sdk/src/golden/init-golden-normalize.ts +15 -0
  411. package/sdk/src/golden/read-only-golden-rows.ts +77 -0
  412. package/sdk/src/golden/read-only-parity.integration.test.ts +125 -0
  413. package/sdk/src/golden/registry-canonical-commands.ts +31 -0
  414. package/sdk/src/gsd-tools.test.ts +409 -0
  415. package/sdk/src/gsd-tools.ts +595 -0
  416. package/sdk/src/headless-prompts.test.ts +159 -0
  417. package/sdk/src/index.ts +333 -0
  418. package/sdk/src/init-e2e.integration.test.ts +136 -0
  419. package/sdk/src/init-runner.test.ts +783 -0
  420. package/sdk/src/init-runner.ts +735 -0
  421. package/sdk/src/lifecycle-e2e.integration.test.ts +258 -0
  422. package/sdk/src/logger.test.ts +149 -0
  423. package/sdk/src/logger.ts +113 -0
  424. package/sdk/src/milestone-runner.test.ts +421 -0
  425. package/sdk/src/phase-prompt.test.ts +538 -0
  426. package/sdk/src/phase-prompt.ts +264 -0
  427. package/sdk/src/phase-runner-types.test.ts +421 -0
  428. package/sdk/src/phase-runner.integration.test.ts +377 -0
  429. package/sdk/src/phase-runner.test.ts +2333 -0
  430. package/sdk/src/phase-runner.ts +1203 -0
  431. package/sdk/src/plan-parser.test.ts +528 -0
  432. package/sdk/src/plan-parser.ts +427 -0
  433. package/sdk/src/prompt-builder.test.ts +306 -0
  434. package/sdk/src/prompt-builder.ts +193 -0
  435. package/sdk/src/prompt-sanitizer.test.ts +260 -0
  436. package/sdk/src/prompt-sanitizer.ts +71 -0
  437. package/sdk/src/query/QUERY-HANDLERS.md +317 -0
  438. package/sdk/src/query/audit-open.ts +722 -0
  439. package/sdk/src/query/check-auto-mode.test.ts +77 -0
  440. package/sdk/src/query/check-auto-mode.ts +50 -0
  441. package/sdk/src/query/check-completion.test.ts +113 -0
  442. package/sdk/src/query/check-completion.ts +182 -0
  443. package/sdk/src/query/check-gates.test.ts +103 -0
  444. package/sdk/src/query/check-gates.ts +112 -0
  445. package/sdk/src/query/check-ship-ready.test.ts +77 -0
  446. package/sdk/src/query/check-ship-ready.ts +103 -0
  447. package/sdk/src/query/check-verification-status.test.ts +143 -0
  448. package/sdk/src/query/check-verification-status.ts +160 -0
  449. package/sdk/src/query/commit.test.ts +202 -0
  450. package/sdk/src/query/commit.ts +301 -0
  451. package/sdk/src/query/config-gates.test.ts +89 -0
  452. package/sdk/src/query/config-gates.ts +69 -0
  453. package/sdk/src/query/config-mutation.test.ts +365 -0
  454. package/sdk/src/query/config-mutation.ts +497 -0
  455. package/sdk/src/query/config-query.test.ts +161 -0
  456. package/sdk/src/query/config-query.ts +190 -0
  457. package/sdk/src/query/context-history.test.ts +165 -0
  458. package/sdk/src/query/context-history.ts +467 -0
  459. package/sdk/src/query/decomposed-handlers.test.ts +365 -0
  460. package/sdk/src/query/detect-custom-files.ts +97 -0
  461. package/sdk/src/query/detect-phase-type.test.ts +105 -0
  462. package/sdk/src/query/detect-phase-type.ts +141 -0
  463. package/sdk/src/query/docs-init.ts +257 -0
  464. package/sdk/src/query/failure-capture.ts +58 -0
  465. package/sdk/src/query/frontmatter-array.test.ts +14 -0
  466. package/sdk/src/query/frontmatter-mutation.test.ts +259 -0
  467. package/sdk/src/query/frontmatter-mutation.ts +343 -0
  468. package/sdk/src/query/frontmatter.test.ts +281 -0
  469. package/sdk/src/query/frontmatter.ts +397 -0
  470. package/sdk/src/query/helpers.test.ts +426 -0
  471. package/sdk/src/query/helpers.ts +482 -0
  472. package/sdk/src/query/index.ts +586 -0
  473. package/sdk/src/query/init-complex.test.ts +232 -0
  474. package/sdk/src/query/init-complex.ts +578 -0
  475. package/sdk/src/query/init.test.ts +522 -0
  476. package/sdk/src/query/init.ts +1046 -0
  477. package/sdk/src/query/intel.test.ts +90 -0
  478. package/sdk/src/query/intel.ts +404 -0
  479. package/sdk/src/query/normalize-query-command.test.ts +50 -0
  480. package/sdk/src/query/normalize-query-command.ts +56 -0
  481. package/sdk/src/query/phase-lifecycle.test.ts +1126 -0
  482. package/sdk/src/query/phase-lifecycle.ts +1799 -0
  483. package/sdk/src/query/phase-list-queries.test.ts +88 -0
  484. package/sdk/src/query/phase-list-queries.ts +152 -0
  485. package/sdk/src/query/phase-ready.test.ts +65 -0
  486. package/sdk/src/query/phase-ready.ts +158 -0
  487. package/sdk/src/query/phase.test.ts +307 -0
  488. package/sdk/src/query/phase.ts +340 -0
  489. package/sdk/src/query/pipeline.test.ts +169 -0
  490. package/sdk/src/query/pipeline.ts +243 -0
  491. package/sdk/src/query/plan-execution-route.test.ts +166 -0
  492. package/sdk/src/query/plan-execution-route.ts +209 -0
  493. package/sdk/src/query/plan-task-structure.test.ts +65 -0
  494. package/sdk/src/query/plan-task-structure.ts +63 -0
  495. package/sdk/src/query/profile-extract-messages.ts +247 -0
  496. package/sdk/src/query/profile-output.ts +908 -0
  497. package/sdk/src/query/profile-questionnaire-data.ts +181 -0
  498. package/sdk/src/query/profile-sample.ts +184 -0
  499. package/sdk/src/query/profile-scan-sessions.ts +174 -0
  500. package/sdk/src/query/profile.test.ts +74 -0
  501. package/sdk/src/query/profile.ts +337 -0
  502. package/sdk/src/query/progress.test.ts +156 -0
  503. package/sdk/src/query/progress.ts +566 -0
  504. package/sdk/src/query/registry.test.ts +216 -0
  505. package/sdk/src/query/registry.ts +174 -0
  506. package/sdk/src/query/requirements-extract-from-plans.test.ts +58 -0
  507. package/sdk/src/query/requirements-extract-from-plans.ts +86 -0
  508. package/sdk/src/query/roadmap-update-plan-progress.ts +132 -0
  509. package/sdk/src/query/roadmap.test.ts +359 -0
  510. package/sdk/src/query/roadmap.ts +591 -0
  511. package/sdk/src/query/route-next-action.test.ts +61 -0
  512. package/sdk/src/query/route-next-action.ts +345 -0
  513. package/sdk/src/query/runtime-health.ts +7 -0
  514. package/sdk/src/query/schema-detect.ts +189 -0
  515. package/sdk/src/query/skill-manifest.ts +214 -0
  516. package/sdk/src/query/skills.test.ts +80 -0
  517. package/sdk/src/query/skills.ts +62 -0
  518. package/sdk/src/query/state-mutation.test.ts +450 -0
  519. package/sdk/src/query/state-mutation.ts +1444 -0
  520. package/sdk/src/query/state-project-load.ts +109 -0
  521. package/sdk/src/query/state.test.ts +347 -0
  522. package/sdk/src/query/state.ts +397 -0
  523. package/sdk/src/query/summary.test.ts +95 -0
  524. package/sdk/src/query/summary.ts +296 -0
  525. package/sdk/src/query/template.test.ts +180 -0
  526. package/sdk/src/query/template.ts +242 -0
  527. package/sdk/src/query/uat.test.ts +77 -0
  528. package/sdk/src/query/uat.ts +314 -0
  529. package/sdk/src/query/utils.test.ts +82 -0
  530. package/sdk/src/query/utils.ts +92 -0
  531. package/sdk/src/query/validate.test.ts +656 -0
  532. package/sdk/src/query/validate.ts +807 -0
  533. package/sdk/src/query/verify.test.ts +414 -0
  534. package/sdk/src/query/verify.ts +645 -0
  535. package/sdk/src/query/websearch.test.ts +31 -0
  536. package/sdk/src/query/websearch.ts +82 -0
  537. package/sdk/src/query/workspace.test.ts +119 -0
  538. package/sdk/src/query/workspace.ts +131 -0
  539. package/sdk/src/query/workstream.test.ts +51 -0
  540. package/sdk/src/query/workstream.ts +434 -0
  541. package/sdk/src/research-gate.test.ts +190 -0
  542. package/sdk/src/research-gate.ts +94 -0
  543. package/sdk/src/runtime-health.test.ts +176 -0
  544. package/sdk/src/runtime-health.ts +387 -0
  545. package/sdk/src/session-runner.test.ts +98 -0
  546. package/sdk/src/session-runner.ts +299 -0
  547. package/sdk/src/tool-scoping.test.ts +160 -0
  548. package/sdk/src/tool-scoping.ts +61 -0
  549. package/sdk/src/types.ts +917 -0
  550. package/sdk/src/workstream-utils.ts +33 -0
  551. package/sdk/src/ws-flag.test.ts +285 -0
  552. package/sdk/src/ws-transport.test.ts +161 -0
  553. package/sdk/src/ws-transport.ts +93 -0
  554. package/sdk/tsconfig.json +20 -0
@@ -0,0 +1,533 @@
1
+ <purpose>
2
+ Execute a phase prompt (PLAN.md) and create the outcome summary (SUMMARY.md).
3
+ </purpose>
4
+
5
+ <required_reading>
6
+ Read STATE.md before any operation to load project context.
7
+ Read config.json for planning behavior settings.
8
+
9
+ @~/.claude/get-shit-done/references/git-integration.md
10
+ </required_reading>
11
+
12
+ <available_agent_types>
13
+ Valid GSD subagent types (use exact names — do not fall back to 'general-purpose'):
14
+ - gsd-executor — Executes plan tasks, commits, creates SUMMARY.md
15
+ </available_agent_types>
16
+
17
+ <process>
18
+
19
+ <step name="init_context" priority="first">
20
+ Load execution context (paths only to minimize orchestrator context):
21
+
22
+ ```bash
23
+ INIT=$(gsd-remix-sdk query init.execute-phase "${PHASE}")
24
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
25
+ ```
26
+
27
+ Extract from init JSON: `executor_model`, `commit_docs`, `sub_repos`, `phase_dir`, `phase_number`, `plans`, `summaries`, `incomplete_plans`, `state_path`, `config_path`.
28
+
29
+ If `.planning/` missing: error.
30
+ </step>
31
+
32
+ <step name="failure_memory_preflight">
33
+ Run deterministic preflight checks compiled from promoted failure memories:
34
+
35
+ ```bash
36
+ FAILURE_PREFLIGHT=$(gsd-remix-sdk query failure.preflight 2>/dev/null || echo '{}')
37
+ ```
38
+
39
+ Parse JSON for: `passed`, `checks[]`, `blockers[]`, `warnings[]`, `recommended_package_manager`, `expected_node_version`, `related_memory_ids[]`.
40
+
41
+ Rules:
42
+ - Do NOT read `FM-xxx.md` files by default. This preflight already compresses the relevant memory into short checks.
43
+ - If `blockers[]` is non-empty: STOP before executing any task. Present the blocker exactly and wait for the user to fix the environment or explicitly override.
44
+ - If `recommended_package_manager` is present: prefer that tool for install/test/build commands unless the plan explicitly requires something else.
45
+ - If `warnings[]` is non-empty: treat them as short guardrails during execution; do not expand them into long historical context.
46
+
47
+ This step exists to turn repeated failures into deterministic execution guards without growing prompt context.
48
+ </step>
49
+
50
+ <step name="identify_plan">
51
+ ```bash
52
+ # Use plans/summaries from INIT JSON, or list files
53
+ (ls .planning/phases/XX-name/*-PLAN.md 2>/dev/null || true) | sort
54
+ (ls .planning/phases/XX-name/*-SUMMARY.md 2>/dev/null || true) | sort
55
+ ```
56
+
57
+ Find first PLAN without matching SUMMARY. Decimal phases supported (`01.1-hotfix/`):
58
+
59
+ ```bash
60
+ PHASE=$(echo "$PLAN_PATH" | grep -oE '[0-9]+(\.[0-9]+)?-[0-9]+')
61
+ # config settings can be fetched via gsd-remix-sdk query config-get if needed
62
+ ```
63
+
64
+ <if mode="yolo">
65
+ Auto-approve: `⚡ Execute {phase}-{plan}-PLAN.md [Plan X of Y for Phase Z]` → parse_segments.
66
+ </if>
67
+
68
+ <if mode="interactive" OR="custom with gates.execute_next_plan true">
69
+ Present plan identification, wait for confirmation.
70
+ </if>
71
+ </step>
72
+
73
+ <step name="record_start_time">
74
+ ```bash
75
+ PLAN_START_TIME=$(date -u +"%Y-%m-%dT%H:%M:%SZ")
76
+ PLAN_START_EPOCH=$(date +%s)
77
+ ```
78
+ </step>
79
+
80
+ <step name="parse_segments">
81
+ ```bash
82
+ PLAN_FILE=".planning/phases/XX-name/{phase}-{plan}-PLAN.md"
83
+ INLINE_THRESHOLD=$(gsd-remix-sdk query config-get workflow.inline_plan_threshold 2>/dev/null || echo "2")
84
+ EXECUTION_ROUTE=$(gsd-remix-sdk query plan.execution-route "$PLAN_FILE" --inline-threshold "${INLINE_THRESHOLD}" 2>/dev/null || echo "{}")
85
+ ```
86
+
87
+ Parse JSON for: `task_count`, `inline_threshold`, `checkpoint_mode`, `threshold_inline`, `dynamic_inline_band`, `low_complexity_inline`, `low_complexity_reasons[]`, `low_complexity_blockers[]`, `complexity_score`, `complexity_signals[]`, `recommended_pattern`, `recommended_execution`, `reason`.
88
+
89
+ **Primary routing: code-derived execution route**
90
+
91
+ Use the route returned by `plan.execution-route` by default. This decision is deterministic and code-based — do NOT substitute your own LLM judgment unless the query failed.
92
+
93
+ Routing rules encoded in the query:
94
+ - `INLINE_THRESHOLD` remains the hard floor. If `task_count <= INLINE_THRESHOLD`, use inline execution immediately.
95
+ - For plans above the threshold, a conservative low-complexity override is allowed only for simple `3-5` task plans with:
96
+ - no checkpoint tasks
97
+ - small file surface
98
+ - small `read_first` surface
99
+ - small acceptance criteria surface
100
+ - Verify-only checkpoints still route to Pattern B.
101
+ - Decision or human-action checkpoints still route to Pattern C.
102
+ - All other plans route to Pattern A.
103
+
104
+ **Checkpoint-based routing (plans with > threshold tasks):**
105
+
106
+ | Checkpoints | Pattern | Execution |
107
+ |-------------|---------|-----------|
108
+ | None | A (autonomous) | Single subagent: full plan + SUMMARY + commit |
109
+ | Verify-only | B (segmented) | Segments between checkpoints. After none/human-verify → SUBAGENT. After decision/human-action → MAIN |
110
+ | Decision | C (main) | Execute entirely in main context |
111
+
112
+ If `reason == "low_complexity_override"`:
113
+ - Treat this plan as intentionally inline to avoid unnecessary ~14K token subagent overhead
114
+ - Use `low_complexity_reasons[]` as the justification
115
+ - Do NOT escalate back to Pattern A unless you discover contradictory evidence while reading the plan
116
+
117
+ If `EXECUTION_ROUTE` failed or returned no usable recommendation:
118
+ - Fall back to the legacy behavior:
119
+ ```bash
120
+ TASK_COUNT=$(grep -cE '^\s*<task[[:space:]>]' "$PLAN_FILE" 2>/dev/null || echo "0")
121
+ grep -n 'type="checkpoint' "$PLAN_FILE"
122
+ ```
123
+ - count `<task>` tags
124
+ - inline when `TASK_COUNT <= INLINE_THRESHOLD`
125
+ - otherwise apply checkpoint-based routing
126
+
127
+ **Pattern A:** init_agent_tracking → capture `EXPECTED_BASE=$(git rev-parse HEAD)` → spawn Task(subagent_type="gsd-executor", model=executor_model) with prompt: execute plan at [path], autonomous, all tasks + SUMMARY + commit, follow deviation/auth rules, report: plan name, tasks, SUMMARY path, commit hash → track agent_id → wait → update tracking → report. **Include `isolation="worktree"` only if `workflow.use_worktrees` is not `false`** (read via `config-get workflow.use_worktrees`). **When using `isolation="worktree"`, include a `<worktree_branch_check>` block in the prompt** instructing the executor to run `git merge-base HEAD {EXPECTED_BASE}` and, if the result differs from `{EXPECTED_BASE}`, hard-reset the branch with `git reset --hard {EXPECTED_BASE}` before starting work (safe — runs before any agent work), then verify with `[ "$(git rev-parse HEAD)" != "{EXPECTED_BASE}" ] && exit 1`. This corrects a known issue where `EnterWorktree` creates branches from `main` instead of the feature branch HEAD (affects all platforms).
128
+
129
+ **Pattern B:** Execute segment-by-segment. Autonomous segments: spawn subagent for assigned tasks only (no SUMMARY/commit). Checkpoints: main context. After all segments: aggregate, create SUMMARY, commit. See segment_execution.
130
+
131
+ **Pattern C:** Execute in main using standard flow (step name="execute").
132
+
133
+ Fresh context per subagent preserves peak quality. Main context stays lean.
134
+ </step>
135
+
136
+ <step name="init_agent_tracking">
137
+ ```bash
138
+ if [ ! -f .planning/agent-history.json ]; then
139
+ echo '{"version":"1.0","max_entries":50,"entries":[]}' > .planning/agent-history.json
140
+ fi
141
+ rm -f .planning/current-agent-id.txt
142
+ if [ -f .planning/current-agent-id.txt ]; then
143
+ INTERRUPTED_ID=$(cat .planning/current-agent-id.txt)
144
+ echo "Found interrupted agent: $INTERRUPTED_ID"
145
+ fi
146
+ ```
147
+
148
+ If interrupted: ask user to resume (Task `resume` parameter) or start fresh.
149
+
150
+ **Tracking protocol:** On spawn: write agent_id to `current-agent-id.txt`, append to agent-history.json: `{"agent_id":"[id]","task_description":"[desc]","phase":"[phase]","plan":"[plan]","segment":[num|null],"timestamp":"[ISO]","status":"spawned","completion_timestamp":null}`. On completion: status → "completed", set completion_timestamp, delete current-agent-id.txt. Prune: if entries > max_entries, remove oldest "completed" (never "spawned").
151
+
152
+ Run for Pattern A/B before spawning. Pattern C: skip.
153
+ </step>
154
+
155
+ <step name="segment_execution">
156
+ Pattern B only (verify-only checkpoints). Skip for A/C.
157
+
158
+ 1. Parse segment map: checkpoint locations and types
159
+ 2. Per segment:
160
+ - Subagent route: spawn gsd-executor for assigned tasks only. Prompt: task range, plan path, read full plan for context, execute assigned tasks, track deviations, NO SUMMARY/commit. Track via agent protocol.
161
+ - Main route: execute tasks using standard flow (step name="execute")
162
+ 3. After ALL segments: aggregate files/deviations/decisions → create SUMMARY.md → commit → self-check:
163
+ - Verify key-files.created exist on disk with `[ -f ]`
164
+ - Check `git log --oneline --all --grep="{phase}-{plan}"` returns ≥1 commit
165
+ - Re-run ALL `<acceptance_criteria>` from every task — if any fail, fix before finalizing SUMMARY
166
+ - Re-run the plan-level `<verification>` commands — log results in SUMMARY
167
+ - Append `## Self-Check: PASSED` or `## Self-Check: FAILED` to SUMMARY
168
+
169
+ **Known Claude Code bug (classifyHandoffIfNeeded):** If any segment agent reports "failed" with `classifyHandoffIfNeeded is not defined`, this is a Claude Code runtime bug — not a real failure. Run spot-checks; if they pass, treat as successful.
170
+
171
+
172
+
173
+
174
+ </step>
175
+
176
+ <step name="load_prompt">
177
+ ```bash
178
+ cat .planning/phases/XX-name/{phase}-{plan}-PLAN.md
179
+ ```
180
+ This IS the execution instructions. Follow exactly. If plan references CONTEXT.md: honor user's vision throughout.
181
+
182
+ **If plan contains `<interfaces>` block:** These are pre-extracted type definitions and contracts. Use them directly — do NOT re-read the source files to discover types. The planner already extracted what you need.
183
+ </step>
184
+
185
+ <step name="previous_phase_check">
186
+ ```bash
187
+ gsd-remix-sdk query phases.list --type summaries --raw
188
+ # Extract the second-to-last summary from the JSON result
189
+ ```
190
+
191
+ **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.
192
+ If previous SUMMARY has unresolved "Issues Encountered" or "Next Phase Readiness" blockers: AskUserQuestion(header="Previous Issues", options: "Proceed anyway" | "Address first" | "Review previous").
193
+ </step>
194
+
195
+ <step name="execute">
196
+ Deviations are normal — handle via rules below.
197
+
198
+ 1. Read @context files from prompt
199
+ 2. **MCP tools:** If CLAUDE.md or project instructions reference MCP tools (e.g. jCodeMunch for code navigation), prefer them over Grep/Glob when available. Fall back to Grep/Glob if MCP tools are not accessible.
200
+ 3. Per task:
201
+ - **MANDATORY read_first gate:** If the task has a `<read_first>` field, you MUST read every listed file BEFORE making any edits. This is not optional. Do not skip files because you "already know" what's in them — read them. The read_first files establish ground truth for the task.
202
+ - `type="auto"`: if `tdd="true"` → TDD execution. Implement with deviation rules + auth gates. Verify done criteria. Commit (see task_commit). Track hash for Summary.
203
+ - `type="checkpoint:*"`: STOP → checkpoint_protocol → wait for user → continue only after confirmation.
204
+ - **HARD GATE — acceptance_criteria verification:** After completing each task, if it has `<acceptance_criteria>`, you MUST run a verification loop before proceeding:
205
+ 1. For each criterion: execute the grep, file check, or CLI command that proves it passes
206
+ 2. Log each result as PASS or FAIL with the command output
207
+ 3. If ANY criterion fails: fix the implementation immediately, then re-run ALL criteria
208
+ 4. Repeat until all criteria pass — you are BLOCKED from starting the next task until this gate clears
209
+ 5. If a criterion cannot be satisfied after 2 fix attempts, log it as a deviation with reason — do NOT silently skip it
210
+ This is not advisory. A task with failing acceptance criteria is an incomplete task.
211
+ 3. Run `<verification>` checks
212
+ 4. Confirm `<success_criteria>` met
213
+ 5. Document deviations in Summary
214
+ </step>
215
+
216
+ <authentication_gates>
217
+
218
+ ## Authentication Gates
219
+
220
+ Auth errors during execution are NOT failures — they're expected interaction points.
221
+
222
+ **Indicators:** "Not authenticated", "Unauthorized", 401/403, "Please run {tool} login", "Set {ENV_VAR}"
223
+
224
+ **Protocol:**
225
+ 1. Recognize auth gate (not a bug)
226
+ 2. STOP task execution
227
+ 3. Create dynamic checkpoint:human-action with exact auth steps
228
+ 4. Wait for user to authenticate
229
+ 5. Verify credentials work
230
+ 6. Retry original task
231
+ 7. Continue normally
232
+
233
+ **Example:** `vercel --yes` → "Not authenticated" → checkpoint asking user to `vercel login` → verify with `vercel whoami` → retry deploy → continue
234
+
235
+ **In Summary:** Document as normal flow under "## Authentication Gates", not as deviations.
236
+
237
+ </authentication_gates>
238
+
239
+ <deviation_rules>
240
+
241
+ ## Deviation Rules
242
+
243
+ Apply deviation rules from the gsd-executor agent definition (single source of truth):
244
+ - **Rules 1-3** (bugs, missing critical, blockers): auto-fix, test, verify, track as deviations
245
+ - **Rule 4** (architectural changes): STOP, present decision to user, await approval
246
+ - **Scope boundary**: do not auto-fix pre-existing issues unrelated to current task
247
+ - **Fix attempt limit**: max 3 retries per deviation before escalating
248
+ - **Priority**: Rule 4 (STOP) > Rules 1-3 (auto) > unsure → Rule 4
249
+
250
+ </deviation_rules>
251
+
252
+ <deviation_documentation>
253
+
254
+ ## Documenting Deviations
255
+
256
+ Summary MUST include deviations section. None? → `## Deviations from Plan\n\nNone - plan executed exactly as written.`
257
+
258
+ Per deviation: **[Rule N - Category] Title** — Found during: Task X | Issue | Fix | Files modified | Verification | Commit hash
259
+
260
+ End with: **Total deviations:** N auto-fixed (breakdown). **Impact:** assessment.
261
+
262
+ </deviation_documentation>
263
+
264
+ <tdd_plan_execution>
265
+ ## TDD Execution
266
+
267
+ For `type: tdd` plans — RED-GREEN-REFACTOR:
268
+
269
+ 1. **Infrastructure** (first TDD plan only): detect project, install framework, config, verify empty suite
270
+ 2. **RED:** Read `<behavior>` → failing test(s) → run (MUST fail) → commit: `test({phase}-{plan}): add failing test for [feature]`
271
+ 3. **GREEN:** Read `<implementation>` → minimal code → run (MUST pass) → commit: `feat({phase}-{plan}): implement [feature]`
272
+ 4. **REFACTOR:** Clean up → tests MUST pass → commit: `refactor({phase}-{plan}): clean up [feature]`
273
+
274
+ Errors: RED doesn't fail → investigate test/existing feature. GREEN doesn't pass → debug, iterate. REFACTOR breaks → undo.
275
+
276
+ See `~/.claude/get-shit-done/references/tdd.md` for structure.
277
+ </tdd_plan_execution>
278
+
279
+ <precommit_failure_handling>
280
+ ## Pre-commit Hook Failure Handling
281
+
282
+ Your commits may trigger pre-commit hooks. Auto-fix hooks handle themselves transparently — files get fixed and re-staged automatically.
283
+
284
+ **If running as a parallel executor agent (spawned by execute-phase):**
285
+ Use `--no-verify` on all commits. Pre-commit hooks cause build lock contention when multiple agents commit simultaneously (e.g., cargo lock fights in Rust projects). The orchestrator validates once after all agents complete.
286
+
287
+ **If running as the sole executor (sequential mode):**
288
+ If a commit is BLOCKED by a hook:
289
+
290
+ 1. The `git commit` command fails with hook error output
291
+ 2. Read the error — it tells you exactly which hook and what failed
292
+ 3. Fix the issue (type error, lint violation, secret leak, etc.)
293
+ 4. `git add` the fixed files
294
+ 5. Retry the commit
295
+ 6. Budget 1-2 retry cycles per commit
296
+ </precommit_failure_handling>
297
+
298
+ <task_commit>
299
+ ## Task Commit Protocol
300
+
301
+ Canonical per-task commit rules live in **`agents/gsd-executor.md`** (`<task_commit_protocol>`). Follow that section for staging, `{type}({phase}-{plan})` messages, `commit-to-subrepo` when `sub_repos` is set, post-commit checks, and untracked-file handling — do not duplicate or paraphrase the full protocol here (single source of truth).
302
+
303
+ **Orchestrator note:** After each task, the spawned executor reports commit hashes; this workflow does not re-specify commit semantics beyond pointing at the executor.
304
+
305
+ </task_commit>
306
+
307
+ <step name="checkpoint_protocol">
308
+ On `type="checkpoint:*"`: automate everything possible first. Checkpoints are for verification/decisions only.
309
+
310
+ Display: `CHECKPOINT: [Type]` box → Progress {X}/{Y} → Task name → type-specific content → `YOUR ACTION: [signal]`
311
+
312
+ | Type | Content | Resume signal |
313
+ |------|---------|---------------|
314
+ | human-verify (90%) | What was built + verification steps (commands/URLs) | "approved" or describe issues |
315
+ | decision (9%) | Decision needed + context + options with pros/cons | "Select: option-id" |
316
+ | human-action (1%) | What was automated + ONE manual step + verification plan | "done" |
317
+
318
+ After response: verify if specified. Pass → continue. Fail → inform, wait. WAIT for user — do NOT hallucinate completion.
319
+
320
+ See ~/.claude/get-shit-done/references/checkpoints.md for details.
321
+ </step>
322
+
323
+ <step name="checkpoint_return_for_orchestrator">
324
+ When spawned via Task and hitting checkpoint: return structured state (cannot interact with user directly).
325
+
326
+ **Required return:** 1) Completed Tasks table (hashes + files) 2) Current Task (what's blocking) 3) Checkpoint Details (user-facing content) 4) Awaiting (what's needed from user)
327
+
328
+ Orchestrator parses → presents to user → spawns fresh continuation with your completed tasks state. You will NOT be resumed. In main context: use checkpoint_protocol above.
329
+ </step>
330
+
331
+ <step name="verification_failure_gate">
332
+ If verification fails:
333
+
334
+ **Check if node repair is enabled** (default: on):
335
+ ```bash
336
+ NODE_REPAIR=$(gsd-remix-sdk query config-get workflow.node_repair 2>/dev/null || echo "true")
337
+ ```
338
+
339
+ If `NODE_REPAIR` is `true`: invoke `@./.claude/get-shit-done/workflows/node-repair.md` with:
340
+ - FAILED_TASK: task number, name, done-criteria
341
+ - ERROR: expected vs actual result
342
+ - PLAN_CONTEXT: adjacent task names + phase goal
343
+ - REPAIR_BUDGET: `workflow.node_repair_budget` from config (default: 2)
344
+
345
+ Node repair will attempt RETRY, DECOMPOSE, or PRUNE autonomously. Only reaches this gate again if repair budget is exhausted (ESCALATE).
346
+
347
+ If `NODE_REPAIR` is `false` OR repair returns ESCALATE: STOP. Present: "Verification failed for Task [X]: [name]. Expected: [criteria]. Actual: [result]. Repair attempted: [summary of what was tried]." Options: Retry | Skip (mark incomplete) | Stop (investigate). If skipped → SUMMARY "Issues Encountered".
348
+ </step>
349
+
350
+ <step name="record_completion_time">
351
+ ```bash
352
+ PLAN_END_TIME=$(date -u +"%Y-%m-%dT%H:%M:%SZ")
353
+ PLAN_END_EPOCH=$(date +%s)
354
+
355
+ DURATION_SEC=$(( PLAN_END_EPOCH - PLAN_START_EPOCH ))
356
+ DURATION_MIN=$(( DURATION_SEC / 60 ))
357
+
358
+ if [[ $DURATION_MIN -ge 60 ]]; then
359
+ HRS=$(( DURATION_MIN / 60 ))
360
+ MIN=$(( DURATION_MIN % 60 ))
361
+ DURATION="${HRS}h ${MIN}m"
362
+ else
363
+ DURATION="${DURATION_MIN} min"
364
+ fi
365
+ ```
366
+ </step>
367
+
368
+ <step name="generate_user_setup">
369
+ ```bash
370
+ grep -A 50 "^user_setup:" .planning/phases/XX-name/{phase}-{plan}-PLAN.md | head -50
371
+ ```
372
+
373
+ If user_setup exists: create `{phase}-USER-SETUP.md` using template `~/.claude/get-shit-done/templates/user-setup.md`. Per service: env vars table, account setup checklist, dashboard config, local dev notes, verification commands. Status "Incomplete". Set `USER_SETUP_CREATED=true`. If empty/missing: skip.
374
+ </step>
375
+
376
+ <step name="create_summary">
377
+ Create `{phase}-{plan}-SUMMARY.md` at `.planning/phases/XX-name/`. Use `~/.claude/get-shit-done/templates/summary.md`.
378
+
379
+ **Frontmatter:** phase, plan, subsystem, tags | requires/provides/affects | tech-stack.added/patterns | key-files.created/modified | key-decisions | requirements-completed (**MUST** copy `requirements` array from PLAN.md frontmatter verbatim) | duration ($DURATION), completed ($PLAN_END_TIME date).
380
+
381
+ Title: `# Phase [X] Plan [Y]: [Name] Summary`
382
+
383
+ One-liner SUBSTANTIVE: "JWT auth with refresh rotation using jose library" not "Authentication implemented"
384
+
385
+ Include: duration, start/end times, task count, file count.
386
+
387
+ Next: more plans → "Ready for {next-plan}" | last → "Phase complete, ready for next step".
388
+ </step>
389
+
390
+ <step name="update_current_position">
391
+ **Skip this step if running in parallel mode** (the orchestrator in execute-phase.md
392
+ handles STATE.md/ROADMAP.md updates centrally after merging worktrees to avoid
393
+ merge conflicts).
394
+
395
+ Update STATE.md using gsd-remix-sdk query (or legacy gsd-tools) state mutations:
396
+
397
+ ```bash
398
+ # Auto-detect parallel mode: .git is a file in worktrees, a directory in main repo
399
+ IS_WORKTREE=$([ -f .git ] && echo "true" || echo "false")
400
+
401
+ # Skip in parallel mode — orchestrator handles STATE.md centrally
402
+ if [ "$IS_WORKTREE" != "true" ]; then
403
+ # Advance plan counter (handles last-plan edge case)
404
+ gsd-remix-sdk query state.advance-plan
405
+
406
+ # Recalculate progress bar from disk state
407
+ gsd-remix-sdk query state.update-progress
408
+
409
+ # Record execution metrics
410
+ gsd-remix-sdk query state.record-metric \
411
+ --phase "${PHASE}" --plan "${PLAN}" --duration "${DURATION}" \
412
+ --tasks "${TASK_COUNT}" --files "${FILE_COUNT}"
413
+ fi
414
+ ```
415
+ </step>
416
+
417
+ <step name="extract_decisions_and_issues">
418
+ From SUMMARY: Extract decisions and add to STATE.md:
419
+
420
+ ```bash
421
+ # Add each decision from SUMMARY key-decisions
422
+ # Prefer file inputs for shell-safe text (preserves `$`, `*`, etc. exactly)
423
+ gsd-remix-sdk query state.add-decision \
424
+ --phase "${PHASE}" --summary-file "${DECISION_TEXT_FILE}" --rationale-file "${RATIONALE_FILE}"
425
+
426
+ # Add blockers if any found
427
+ gsd-remix-sdk query state.add-blocker --text-file "${BLOCKER_TEXT_FILE}"
428
+ ```
429
+ </step>
430
+
431
+ <step name="update_session_continuity">
432
+ Update session info using gsd-remix-sdk query (or legacy gsd-tools):
433
+
434
+ ```bash
435
+ gsd-remix-sdk query state.record-session \
436
+ --stopped-at "Completed ${PHASE}-${PLAN}-PLAN.md" \
437
+ --resume-file "None"
438
+ ```
439
+
440
+ Keep STATE.md under 150 lines.
441
+ </step>
442
+
443
+ <step name="issues_review_gate">
444
+ If SUMMARY "Issues Encountered" ≠ "None": yolo → log and continue. Interactive → present issues, wait for acknowledgment.
445
+ </step>
446
+
447
+ <step name="update_roadmap">
448
+ **Skip this step if running in parallel mode** (the orchestrator handles ROADMAP.md
449
+ updates centrally after merging worktrees).
450
+
451
+ ```bash
452
+ # Auto-detect parallel mode: .git is a file in worktrees, a directory in main repo
453
+ IS_WORKTREE=$([ -f .git ] && echo "true" || echo "false")
454
+
455
+ # Skip in parallel mode — orchestrator handles ROADMAP.md centrally
456
+ if [ "$IS_WORKTREE" != "true" ]; then
457
+ gsd-remix-sdk query roadmap.update-plan-progress "${PHASE}"
458
+ fi
459
+ ```
460
+ Counts PLAN vs SUMMARY files on disk. Updates progress table row with correct count and status (`In Progress` or `Complete` with date).
461
+ </step>
462
+
463
+ <step name="update_requirements">
464
+ Mark completed requirements from the PLAN.md frontmatter `requirements:` field:
465
+
466
+ ```bash
467
+ gsd-remix-sdk query requirements.mark-complete ${REQ_IDS}
468
+ ```
469
+
470
+ Extract requirement IDs from the plan's frontmatter (e.g., `requirements: [AUTH-01, AUTH-02]`). If no requirements field, skip.
471
+ </step>
472
+
473
+ <step name="git_commit_metadata">
474
+ Task code already committed per-task. Commit plan metadata:
475
+
476
+ ```bash
477
+ # Auto-detect parallel mode: .git is a file in worktrees, a directory in main repo
478
+ IS_WORKTREE=$([ -f .git ] && echo "true" || echo "false")
479
+
480
+ # In parallel mode: exclude STATE.md and ROADMAP.md (orchestrator commits these)
481
+ if [ "$IS_WORKTREE" = "true" ]; then
482
+ gsd-remix-sdk query commit "docs({phase}-{plan}): complete [plan-name] plan" .planning/phases/XX-name/{phase}-{plan}-SUMMARY.md .planning/REQUIREMENTS.md
483
+ else
484
+ gsd-remix-sdk query commit "docs({phase}-{plan}): complete [plan-name] plan" .planning/phases/XX-name/{phase}-{plan}-SUMMARY.md .planning/STATE.md .planning/ROADMAP.md .planning/REQUIREMENTS.md
485
+ fi
486
+ ```
487
+ </step>
488
+
489
+ <step name="update_codebase_map">
490
+ If .planning/codebase/ doesn't exist: skip.
491
+
492
+ ```bash
493
+ FIRST_TASK=$(git log --oneline --grep="feat({phase}-{plan}):" --grep="fix({phase}-{plan}):" --grep="test({phase}-{plan}):" --reverse | head -1 | cut -d' ' -f1)
494
+ git diff --name-only ${FIRST_TASK}^..HEAD 2>/dev/null || true
495
+ ```
496
+
497
+ Update only structural changes: new src/ dir → STRUCTURE.md | deps → STACK.md | file pattern → CONVENTIONS.md | API client → INTEGRATIONS.md | config → STACK.md | renamed → update paths. Skip code-only/bugfix/content changes.
498
+
499
+ ```bash
500
+ gsd-remix-sdk query commit "" .planning/codebase/*.md --amend
501
+ ```
502
+ </step>
503
+
504
+ <step name="offer_next">
505
+ If `USER_SETUP_CREATED=true`: display `⚠️ USER SETUP REQUIRED` with path + env/config tasks at TOP.
506
+
507
+ ```bash
508
+ (ls -1 .planning/phases/[current-phase-dir]/*-PLAN.md 2>/dev/null || true) | wc -l
509
+ (ls -1 .planning/phases/[current-phase-dir]/*-SUMMARY.md 2>/dev/null || true) | wc -l
510
+ ```
511
+
512
+ | Condition | Route | Action |
513
+ |-----------|-------|--------|
514
+ | summaries < plans | **A: More plans** | Find next PLAN without SUMMARY. Yolo: auto-continue. Interactive: show next plan, suggest `/gsd-execute-phase {phase}` + `/gsd-verify-work`. STOP here. |
515
+ | summaries = plans, current < highest phase | **B: Phase done** | Show completion, suggest `/gsd-plan-phase {Z+1}` + `/gsd-verify-work {Z}` + `/gsd-discuss-phase {Z+1}` |
516
+ | summaries = plans, current = highest phase | **C: Milestone done** | Show banner, suggest `/gsd-complete-milestone` + `/gsd-verify-work` + `/gsd-add-phase` |
517
+
518
+ All routes: `/clear` first for fresh context.
519
+ </step>
520
+
521
+ </process>
522
+
523
+ <success_criteria>
524
+
525
+ - All tasks from PLAN.md completed
526
+ - All verifications pass
527
+ - USER-SETUP.md generated if user_setup in frontmatter
528
+ - SUMMARY.md created with substantive content
529
+ - STATE.md updated (position, decisions, issues, session) — unless parallel mode (orchestrator handles)
530
+ - ROADMAP.md updated — unless parallel mode (orchestrator handles)
531
+ - If codebase map exists: map updated with execution changes (or skipped if no significant changes)
532
+ - If USER-SETUP.md created: prominently surfaced in completion output
533
+ </success_criteria>
@@ -0,0 +1,141 @@
1
+ <purpose>
2
+ Socratic ideation workflow. Guides the developer through exploring an idea via probing questions,
3
+ offers mid-conversation research when useful, then routes crystallized outputs to GSD artifacts.
4
+ </purpose>
5
+
6
+ <required_reading>
7
+ Read all files referenced by the invoking prompt's execution_context before starting.
8
+
9
+ @~/.claude/get-shit-done/references/questioning.md
10
+ @~/.claude/get-shit-done/references/domain-probes.md
11
+ </required_reading>
12
+
13
+ <available_agent_types>
14
+ Valid GSD subagent types (use exact names — do not fall back to 'general-purpose'):
15
+ - gsd-phase-researcher — Researches specific questions and returns concise findings
16
+ </available_agent_types>
17
+
18
+ <process>
19
+
20
+ ## Step 1: Open the conversation
21
+
22
+ If a topic was provided, acknowledge it and begin exploring:
23
+ ```
24
+ ## Explore: {topic}
25
+
26
+ Let's think through this together. I'll ask questions to help clarify the idea
27
+ before we commit to any artifacts.
28
+ ```
29
+
30
+ If no topic, ask:
31
+ ```
32
+ ## Explore
33
+
34
+ What's on your mind? This could be a feature idea, an architectural question,
35
+ a problem you're trying to solve, or something you're not sure about yet.
36
+ ```
37
+
38
+ ## Step 2: Socratic conversation (2-5 exchanges)
39
+
40
+ Guide the conversation using principles from `questioning.md` and `domain-probes.md`:
41
+
42
+ - Ask **one question at a time** (never a list of questions)
43
+ - Questions should probe: constraints, tradeoffs, users, scope, dependencies, risks
44
+ - Use domain-specific probes contextually when the topic touches a known domain
45
+ - Listen for signals: "or" / "versus" / "tradeoff" indicate competing priorities worth exploring
46
+ - Reflect back what you hear to confirm understanding before moving forward
47
+
48
+ **Conversation should feel natural, not formulaic.** Avoid rigid sequences. Follow the developer's energy — if they're excited about one aspect, go deeper there.
49
+
50
+ ## Step 3: Mid-conversation research offer (after 2-3 exchanges)
51
+
52
+ If the conversation surfaces factual questions, technology comparisons, or unknowns that research could resolve, offer:
53
+
54
+ ```
55
+ This touches on [specific question]. Want me to do a quick research pass before we continue?
56
+ This would take ~30 seconds and might surface useful context.
57
+
58
+ [Yes, research this] / [No, let's keep exploring]
59
+ ```
60
+
61
+ If yes, spawn a research agent:
62
+ ```
63
+ Task(
64
+ prompt="Quick research: {specific_question}. Return 3-5 key findings, no more than 200 words.",
65
+ subagent_type="gsd-phase-researcher"
66
+ )
67
+ ```
68
+
69
+ Share findings and continue the conversation.
70
+
71
+ If the topic doesn't warrant research, skip this step entirely. **Don't force it.**
72
+
73
+ ## Step 4: Crystallize outputs (after 3-6 exchanges)
74
+
75
+ When the conversation reaches natural conclusions or the developer signals readiness, propose outputs. Analyze the conversation to identify what was discussed and suggest **up to 4 outputs** from:
76
+
77
+ | Type | Destination | When to suggest |
78
+ |------|-------------|-----------------|
79
+ | Note | `.planning/notes/{slug}.md` | Observations, context, decisions worth remembering |
80
+ | Todo | `.planning/todos/pending/{slug}.md` | Concrete actionable tasks identified |
81
+ | Seed | `.planning/seeds/{slug}.md` | Forward-looking ideas with trigger conditions |
82
+ | Research question | `.planning/research/questions.md` (append) | Open questions that need deeper investigation |
83
+ | Requirement | `REQUIREMENTS.md` (append) | Clear requirements that emerged from discussion |
84
+ | New phase | `ROADMAP.md` (append) | Scope large enough to warrant its own phase |
85
+ | Spike | `/gsd-spike` (invoke) | Feasibility uncertainty surfaced — "will this API work?", "can we do X?" |
86
+ | Sketch | `/gsd-sketch` (invoke) | Design direction unclear — "what should this look like?", "how should this feel?" |
87
+
88
+ Present suggestions:
89
+ ```
90
+ Based on our conversation, I'd suggest capturing:
91
+
92
+ 1. **Note:** "Authentication strategy decisions" — your reasoning about JWT vs sessions
93
+ 2. **Todo:** "Evaluate Passport.js vs custom middleware" — the comparison you want to do
94
+ 3. **Seed:** "OAuth2 provider support" — trigger: when user management phase starts
95
+
96
+ Create these? You can select specific ones or modify them.
97
+
98
+ [Create all] / [Let me pick] / [Skip — just exploring]
99
+ ```
100
+
101
+ **Never write artifacts without explicit user selection.**
102
+
103
+ ## Step 5: Write selected outputs
104
+
105
+ For each selected output, write the file:
106
+
107
+ - **Notes:** Create `.planning/notes/{slug}.md` with frontmatter (title, date, context)
108
+ - **Todos:** Create `.planning/todos/pending/{slug}.md` with frontmatter (title, date, priority)
109
+ - **Seeds:** Create `.planning/seeds/{slug}.md` with frontmatter (title, trigger_condition, planted_date)
110
+ - **Research questions:** Append to `.planning/research/questions.md`
111
+ - **Requirements:** Append to `.planning/REQUIREMENTS.md` with next available REQ ID
112
+ - **Phases:** Use existing `/gsd-add-phase` command via SlashCommand
113
+
114
+ Commit if `commit_docs` is enabled:
115
+ ```bash
116
+ gsd-remix-sdk query commit "docs: capture exploration — {topic_slug}" {file_list}
117
+ ```
118
+
119
+ ## Step 6: Close
120
+
121
+ ```
122
+ ## Exploration Complete
123
+
124
+ **Topic:** {topic}
125
+ **Outputs:** {count} artifact(s) created
126
+ {list of created files}
127
+
128
+ Continue exploring with `/gsd-explore` or start working with `/gsd-next`.
129
+ ```
130
+
131
+ </process>
132
+
133
+ <success_criteria>
134
+ - [ ] Socratic conversation follows questioning.md principles
135
+ - [ ] Questions asked one at a time, not in batches
136
+ - [ ] Research offered contextually (not forced)
137
+ - [ ] Up to 4 outputs proposed from conversation
138
+ - [ ] User explicitly selects which outputs to create
139
+ - [ ] Files written to correct destinations
140
+ - [ ] Commit respects commit_docs config
141
+ </success_criteria>