gsd-pi 2.33.0-dev.bafba33 → 2.33.1-dev.235d83a

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 (751) hide show
  1. package/README.md +13 -18
  2. package/dist/cli.js +16 -0
  3. package/dist/resource-loader.d.ts +2 -0
  4. package/dist/resource-loader.js +36 -3
  5. package/dist/resources/extensions/ask-user-questions.js +217 -0
  6. package/dist/resources/extensions/async-jobs/async-bash-tool.js +180 -0
  7. package/dist/resources/extensions/async-jobs/await-tool.js +90 -0
  8. package/dist/resources/extensions/async-jobs/cancel-job-tool.js +28 -0
  9. package/dist/resources/extensions/async-jobs/index.js +119 -0
  10. package/dist/resources/extensions/async-jobs/job-manager.js +159 -0
  11. package/dist/resources/extensions/aws-auth/index.js +138 -0
  12. package/dist/resources/extensions/bg-shell/bg-shell-command.js +182 -0
  13. package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.js +343 -0
  14. package/dist/resources/extensions/bg-shell/bg-shell-tool.js +831 -0
  15. package/dist/resources/extensions/bg-shell/index.js +41 -0
  16. package/dist/resources/extensions/bg-shell/interaction.js +160 -0
  17. package/dist/resources/extensions/bg-shell/output-formatter.js +245 -0
  18. package/dist/resources/extensions/bg-shell/overlay.js +378 -0
  19. package/dist/resources/extensions/bg-shell/process-manager.js +413 -0
  20. package/dist/resources/extensions/bg-shell/readiness-detector.js +109 -0
  21. package/dist/resources/extensions/bg-shell/types.js +96 -0
  22. package/dist/resources/extensions/bg-shell/utilities.js +50 -0
  23. package/dist/resources/extensions/browser-tools/capture.js +179 -0
  24. package/dist/resources/extensions/browser-tools/core.js +899 -0
  25. package/dist/resources/extensions/browser-tools/{evaluate-helpers.ts → evaluate-helpers.js} +0 -1
  26. package/dist/resources/extensions/browser-tools/index.js +123 -0
  27. package/dist/resources/extensions/browser-tools/lifecycle.js +222 -0
  28. package/dist/resources/extensions/browser-tools/refs.js +254 -0
  29. package/dist/resources/extensions/browser-tools/settle.js +173 -0
  30. package/dist/resources/extensions/browser-tools/state.js +126 -0
  31. package/dist/resources/extensions/browser-tools/tools/action-cache.js +179 -0
  32. package/dist/resources/extensions/browser-tools/tools/assertions.js +320 -0
  33. package/dist/resources/extensions/browser-tools/tools/codegen.js +242 -0
  34. package/dist/resources/extensions/browser-tools/tools/device.js +162 -0
  35. package/dist/resources/extensions/browser-tools/tools/extract.js +191 -0
  36. package/dist/resources/extensions/browser-tools/tools/forms.js +710 -0
  37. package/dist/resources/extensions/browser-tools/tools/injection-detect.js +178 -0
  38. package/dist/resources/extensions/browser-tools/tools/inspection.js +426 -0
  39. package/dist/resources/extensions/browser-tools/tools/intent.js +556 -0
  40. package/dist/resources/extensions/browser-tools/tools/interaction.js +776 -0
  41. package/dist/resources/extensions/browser-tools/tools/navigation.js +208 -0
  42. package/dist/resources/extensions/browser-tools/tools/network-mock.js +194 -0
  43. package/dist/resources/extensions/browser-tools/tools/pages.js +280 -0
  44. package/dist/resources/extensions/browser-tools/tools/pdf.js +74 -0
  45. package/dist/resources/extensions/browser-tools/tools/refs.js +485 -0
  46. package/dist/resources/extensions/browser-tools/tools/screenshot.js +87 -0
  47. package/dist/resources/extensions/browser-tools/tools/session.js +375 -0
  48. package/dist/resources/extensions/browser-tools/tools/state-persistence.js +180 -0
  49. package/dist/resources/extensions/browser-tools/tools/visual-diff.js +174 -0
  50. package/dist/resources/extensions/browser-tools/tools/wait.js +201 -0
  51. package/dist/resources/extensions/browser-tools/tools/zoom.js +90 -0
  52. package/dist/resources/extensions/browser-tools/utils.js +490 -0
  53. package/dist/resources/extensions/context7/index.js +337 -0
  54. package/dist/resources/extensions/get-secrets-from-user.js +492 -0
  55. package/dist/resources/extensions/google-search/index.js +373 -0
  56. package/dist/resources/extensions/gsd/activity-log.js +146 -0
  57. package/dist/resources/extensions/gsd/atomic-write.js +38 -0
  58. package/dist/resources/extensions/gsd/auto/session.js +187 -0
  59. package/dist/resources/extensions/gsd/auto-budget.js +30 -0
  60. package/dist/resources/extensions/gsd/{auto-constants.ts → auto-constants.js} +0 -1
  61. package/dist/resources/extensions/gsd/auto-dashboard.js +509 -0
  62. package/dist/resources/extensions/gsd/auto-direct-dispatch.js +180 -0
  63. package/dist/resources/extensions/gsd/auto-dispatch.js +382 -0
  64. package/dist/resources/extensions/gsd/auto-idempotency.js +106 -0
  65. package/dist/resources/extensions/gsd/auto-model-selection.js +133 -0
  66. package/dist/resources/extensions/gsd/auto-observability.js +54 -0
  67. package/dist/resources/extensions/gsd/auto-post-unit.js +495 -0
  68. package/dist/resources/extensions/gsd/auto-prompts.js +1121 -0
  69. package/dist/resources/extensions/gsd/auto-recovery.js +550 -0
  70. package/dist/resources/extensions/gsd/auto-start.js +393 -0
  71. package/dist/resources/extensions/gsd/auto-stuck-detection.js +165 -0
  72. package/dist/resources/extensions/gsd/{auto-supervisor.ts → auto-supervisor.js} +29 -32
  73. package/dist/resources/extensions/gsd/auto-timeout-recovery.js +183 -0
  74. package/dist/resources/extensions/gsd/auto-timers.js +181 -0
  75. package/dist/resources/extensions/gsd/auto-tool-tracking.js +50 -0
  76. package/dist/resources/extensions/gsd/auto-unit-closeout.js +30 -0
  77. package/dist/resources/extensions/gsd/auto-verification.js +209 -0
  78. package/dist/resources/extensions/gsd/auto-worktree.js +594 -0
  79. package/dist/resources/extensions/gsd/auto.js +1485 -0
  80. package/dist/resources/extensions/gsd/{cache.ts → cache.js} +5 -7
  81. package/dist/resources/extensions/gsd/captures.js +348 -0
  82. package/dist/resources/extensions/gsd/claude-import.js +540 -0
  83. package/dist/resources/extensions/gsd/collision-diagnostics.js +226 -0
  84. package/dist/resources/extensions/gsd/commands-bootstrap.js +223 -0
  85. package/dist/resources/extensions/gsd/commands-config.js +89 -0
  86. package/dist/resources/extensions/gsd/commands-extensions.js +259 -0
  87. package/dist/resources/extensions/gsd/commands-handlers.js +310 -0
  88. package/dist/resources/extensions/gsd/commands-inspect.js +70 -0
  89. package/dist/resources/extensions/gsd/commands-logs.js +468 -0
  90. package/dist/resources/extensions/gsd/commands-maintenance.js +185 -0
  91. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +660 -0
  92. package/dist/resources/extensions/gsd/commands-workflow-templates.js +408 -0
  93. package/dist/resources/extensions/gsd/commands.js +1024 -0
  94. package/dist/resources/extensions/gsd/complexity-classifier.js +257 -0
  95. package/dist/resources/extensions/gsd/{constants.ts → constants.js} +0 -6
  96. package/dist/resources/extensions/gsd/context-budget.js +187 -0
  97. package/dist/resources/extensions/gsd/context-store.js +165 -0
  98. package/dist/resources/extensions/gsd/crash-recovery.js +110 -0
  99. package/dist/resources/extensions/gsd/dashboard-overlay.js +562 -0
  100. package/dist/resources/extensions/gsd/db-writer.js +298 -0
  101. package/dist/resources/extensions/gsd/debug-logger.js +161 -0
  102. package/dist/resources/extensions/gsd/detection.js +373 -0
  103. package/dist/resources/extensions/gsd/diff-context.js +168 -0
  104. package/dist/resources/extensions/gsd/dispatch-guard.js +76 -0
  105. package/dist/resources/extensions/gsd/doctor-checks.js +563 -0
  106. package/dist/resources/extensions/gsd/doctor-environment.js +429 -0
  107. package/dist/resources/extensions/gsd/doctor-format.js +71 -0
  108. package/dist/resources/extensions/gsd/doctor-proactive.js +239 -0
  109. package/dist/resources/extensions/gsd/doctor-providers.js +292 -0
  110. package/dist/resources/extensions/gsd/doctor-types.js +12 -0
  111. package/dist/resources/extensions/gsd/doctor.js +672 -0
  112. package/dist/resources/extensions/gsd/error-utils.js +6 -0
  113. package/dist/resources/extensions/gsd/{errors.ts → errors.js} +6 -11
  114. package/dist/resources/extensions/gsd/exit-command.js +11 -0
  115. package/dist/resources/extensions/gsd/{export-html.ts → export-html.js} +482 -614
  116. package/dist/resources/extensions/gsd/export.js +268 -0
  117. package/dist/resources/extensions/gsd/file-watcher.js +76 -0
  118. package/dist/resources/extensions/gsd/files.js +937 -0
  119. package/dist/resources/extensions/gsd/forensics.js +511 -0
  120. package/dist/resources/extensions/gsd/{git-constants.ts → git-constants.js} +4 -5
  121. package/dist/resources/extensions/gsd/git-self-heal.js +113 -0
  122. package/dist/resources/extensions/gsd/git-service.js +460 -0
  123. package/dist/resources/extensions/gsd/{gitignore.ts → gitignore.js} +98 -125
  124. package/dist/resources/extensions/gsd/gsd-db.js +590 -0
  125. package/dist/resources/extensions/gsd/guided-flow-queue.js +366 -0
  126. package/dist/resources/extensions/gsd/guided-flow.js +1149 -0
  127. package/dist/resources/extensions/gsd/health-widget.js +141 -0
  128. package/dist/resources/extensions/gsd/history.js +118 -0
  129. package/dist/resources/extensions/gsd/index.js +1250 -0
  130. package/dist/resources/extensions/gsd/init-wizard.js +479 -0
  131. package/dist/resources/extensions/gsd/json-persistence.js +62 -0
  132. package/dist/resources/extensions/gsd/{jsonl-utils.ts → jsonl-utils.js} +10 -7
  133. package/dist/resources/extensions/gsd/key-manager.js +829 -0
  134. package/dist/resources/extensions/gsd/marketplace-discovery.js +356 -0
  135. package/dist/resources/extensions/gsd/md-importer.js +440 -0
  136. package/dist/resources/extensions/gsd/mechanical-completion.js +351 -0
  137. package/dist/resources/extensions/gsd/memory-extractor.js +295 -0
  138. package/dist/resources/extensions/gsd/memory-store.js +351 -0
  139. package/dist/resources/extensions/gsd/metrics.js +377 -0
  140. package/dist/resources/extensions/gsd/migrate/command.js +157 -0
  141. package/dist/resources/extensions/gsd/migrate/index.js +7 -0
  142. package/dist/resources/extensions/gsd/migrate/parser.js +268 -0
  143. package/dist/resources/extensions/gsd/migrate/parsers.js +477 -0
  144. package/dist/resources/extensions/gsd/migrate/preview.js +47 -0
  145. package/dist/resources/extensions/gsd/migrate/transformer.js +278 -0
  146. package/dist/resources/extensions/gsd/migrate/types.js +4 -0
  147. package/dist/resources/extensions/gsd/migrate/validator.js +41 -0
  148. package/dist/resources/extensions/gsd/migrate/writer.js +477 -0
  149. package/dist/resources/extensions/gsd/migrate-external.js +130 -0
  150. package/dist/resources/extensions/gsd/milestone-actions.js +111 -0
  151. package/dist/resources/extensions/gsd/{milestone-ids.ts → milestone-ids.js} +50 -63
  152. package/dist/resources/extensions/gsd/model-cost-table.js +48 -0
  153. package/dist/resources/extensions/gsd/model-router.js +187 -0
  154. package/dist/resources/extensions/gsd/namespaced-registry.js +322 -0
  155. package/dist/resources/extensions/gsd/namespaced-resolver.js +176 -0
  156. package/dist/resources/extensions/gsd/native-git-bridge.js +842 -0
  157. package/dist/resources/extensions/gsd/native-parser-bridge.js +156 -0
  158. package/dist/resources/extensions/gsd/notifications.js +58 -0
  159. package/dist/resources/extensions/gsd/observability-validator.js +398 -0
  160. package/dist/resources/extensions/gsd/parallel-eligibility.js +182 -0
  161. package/dist/resources/extensions/gsd/parallel-merge.js +121 -0
  162. package/dist/resources/extensions/gsd/parallel-orchestrator.js +687 -0
  163. package/dist/resources/extensions/gsd/paths.js +414 -0
  164. package/dist/resources/extensions/gsd/plugin-importer.js +254 -0
  165. package/dist/resources/extensions/gsd/post-unit-hooks.js +433 -0
  166. package/dist/resources/extensions/gsd/preferences-models.js +294 -0
  167. package/dist/resources/extensions/gsd/preferences-skills.js +154 -0
  168. package/dist/resources/extensions/gsd/preferences-types.js +73 -0
  169. package/dist/resources/extensions/gsd/preferences-validation.js +607 -0
  170. package/dist/resources/extensions/gsd/preferences.js +325 -0
  171. package/dist/resources/extensions/gsd/progress-score.js +197 -0
  172. package/dist/resources/extensions/gsd/prompt-cache-optimizer.js +150 -0
  173. package/dist/resources/extensions/gsd/prompt-compressor.js +393 -0
  174. package/dist/resources/extensions/gsd/prompt-loader.js +119 -0
  175. package/dist/resources/extensions/gsd/prompt-ordering.js +170 -0
  176. package/dist/resources/extensions/gsd/provider-error-pause.js +60 -0
  177. package/dist/resources/extensions/gsd/queue-order.js +178 -0
  178. package/dist/resources/extensions/gsd/queue-reorder-ui.js +234 -0
  179. package/dist/resources/extensions/gsd/quick.js +230 -0
  180. package/dist/resources/extensions/gsd/repo-identity.js +187 -0
  181. package/dist/resources/extensions/gsd/{reports.ts → reports.js} +146 -241
  182. package/dist/resources/extensions/gsd/{resource-version.ts → resource-version.js} +50 -53
  183. package/dist/resources/extensions/gsd/roadmap-slices.js +130 -0
  184. package/dist/resources/extensions/gsd/routing-history.js +210 -0
  185. package/dist/resources/extensions/gsd/safe-fs.js +52 -0
  186. package/dist/resources/extensions/gsd/semantic-chunker.js +254 -0
  187. package/dist/resources/extensions/gsd/session-forensics.js +427 -0
  188. package/dist/resources/extensions/gsd/session-lock.js +376 -0
  189. package/dist/resources/extensions/gsd/session-status-io.js +134 -0
  190. package/dist/resources/extensions/gsd/skill-discovery.js +121 -0
  191. package/dist/resources/extensions/gsd/skill-health.js +324 -0
  192. package/dist/resources/extensions/gsd/{skill-telemetry.ts → skill-telemetry.js} +58 -74
  193. package/dist/resources/extensions/gsd/state.js +653 -0
  194. package/dist/resources/extensions/gsd/structured-data-formatter.js +97 -0
  195. package/dist/resources/extensions/gsd/summary-distiller.js +212 -0
  196. package/dist/resources/extensions/gsd/token-counter.js +54 -0
  197. package/dist/resources/extensions/gsd/triage-resolution.js +217 -0
  198. package/dist/resources/extensions/gsd/triage-ui.js +125 -0
  199. package/dist/resources/extensions/gsd/types.js +4 -0
  200. package/dist/resources/extensions/gsd/undo.js +210 -0
  201. package/dist/resources/extensions/gsd/unit-id.js +7 -0
  202. package/dist/resources/extensions/gsd/unit-runtime.js +130 -0
  203. package/dist/resources/extensions/gsd/validate-directory.js +143 -0
  204. package/dist/resources/extensions/gsd/verification-evidence.js +123 -0
  205. package/dist/resources/extensions/gsd/verification-gate.js +543 -0
  206. package/dist/resources/extensions/gsd/visualizer-data.js +612 -0
  207. package/dist/resources/extensions/gsd/visualizer-overlay.js +501 -0
  208. package/dist/resources/extensions/gsd/visualizer-views.js +893 -0
  209. package/dist/resources/extensions/gsd/workflow-templates.js +188 -0
  210. package/dist/resources/extensions/gsd/workspace-index.js +139 -0
  211. package/dist/resources/extensions/gsd/worktree-command-bootstrap.js +40 -0
  212. package/dist/resources/extensions/gsd/worktree-command.js +676 -0
  213. package/dist/resources/extensions/gsd/worktree-manager.js +359 -0
  214. package/dist/resources/extensions/gsd/worktree.js +236 -0
  215. package/dist/resources/extensions/mac-tools/index.js +768 -0
  216. package/dist/resources/extensions/mcp-client/index.js +363 -0
  217. package/dist/resources/extensions/package.json +3 -0
  218. package/dist/resources/extensions/remote-questions/config.js +70 -0
  219. package/dist/resources/extensions/remote-questions/discord-adapter.js +134 -0
  220. package/dist/resources/extensions/remote-questions/format.js +234 -0
  221. package/dist/resources/extensions/remote-questions/http-client.js +43 -0
  222. package/dist/resources/extensions/remote-questions/manager.js +156 -0
  223. package/dist/resources/extensions/remote-questions/{mod.ts → mod.js} +1 -10
  224. package/dist/resources/extensions/remote-questions/notify.js +89 -0
  225. package/dist/resources/extensions/remote-questions/remote-command.js +453 -0
  226. package/dist/resources/extensions/remote-questions/slack-adapter.js +123 -0
  227. package/dist/resources/extensions/remote-questions/status.js +25 -0
  228. package/dist/resources/extensions/remote-questions/store.js +70 -0
  229. package/dist/resources/extensions/remote-questions/telegram-adapter.js +123 -0
  230. package/dist/resources/extensions/remote-questions/types.js +5 -0
  231. package/dist/resources/extensions/search-the-web/cache.js +74 -0
  232. package/dist/resources/extensions/search-the-web/command-search-provider.js +79 -0
  233. package/dist/resources/extensions/search-the-web/format.js +161 -0
  234. package/dist/resources/extensions/search-the-web/http.js +178 -0
  235. package/dist/resources/extensions/search-the-web/index.js +41 -0
  236. package/dist/resources/extensions/search-the-web/native-search.js +166 -0
  237. package/dist/resources/extensions/search-the-web/provider.js +143 -0
  238. package/dist/resources/extensions/search-the-web/tavily.js +82 -0
  239. package/dist/resources/extensions/search-the-web/tool-fetch-page.js +452 -0
  240. package/dist/resources/extensions/search-the-web/tool-llm-context.js +455 -0
  241. package/dist/resources/extensions/search-the-web/tool-search.js +482 -0
  242. package/dist/resources/extensions/search-the-web/url-utils.js +121 -0
  243. package/dist/resources/extensions/shared/confirm-ui.js +96 -0
  244. package/dist/resources/extensions/shared/{format-utils.ts → format-utils.js} +85 -91
  245. package/dist/resources/extensions/shared/frontmatter.js +109 -0
  246. package/dist/resources/extensions/shared/interview-ui.js +569 -0
  247. package/dist/resources/extensions/shared/{mod.ts → mod.js} +2 -24
  248. package/dist/resources/extensions/shared/next-action-ui.js +168 -0
  249. package/dist/resources/extensions/shared/{path-display.ts → path-display.js} +2 -3
  250. package/dist/resources/extensions/shared/sanitize.js +17 -0
  251. package/dist/resources/extensions/shared/terminal.js +21 -0
  252. package/dist/resources/extensions/shared/ui.js +245 -0
  253. package/dist/resources/extensions/shared/wizard-ui.js +478 -0
  254. package/dist/resources/extensions/slash-commands/audit.js +72 -0
  255. package/dist/resources/extensions/slash-commands/clear.js +8 -0
  256. package/dist/resources/extensions/slash-commands/create-extension.js +264 -0
  257. package/dist/resources/extensions/slash-commands/create-slash-command.js +208 -0
  258. package/dist/resources/extensions/slash-commands/index.js +10 -0
  259. package/dist/resources/extensions/subagent/agents.js +103 -0
  260. package/dist/resources/extensions/subagent/index.js +905 -0
  261. package/dist/resources/extensions/subagent/isolation.js +384 -0
  262. package/dist/resources/extensions/subagent/worker-registry.js +73 -0
  263. package/dist/resources/extensions/ttsr/index.js +144 -0
  264. package/dist/resources/extensions/ttsr/rule-loader.js +70 -0
  265. package/dist/resources/extensions/ttsr/ttsr-manager.js +380 -0
  266. package/dist/resources/extensions/universal-config/discovery.js +94 -0
  267. package/dist/resources/extensions/universal-config/format.js +178 -0
  268. package/dist/resources/extensions/universal-config/index.js +99 -0
  269. package/dist/resources/extensions/universal-config/scanners.js +574 -0
  270. package/dist/resources/extensions/universal-config/tools.js +57 -0
  271. package/dist/resources/extensions/universal-config/types.js +8 -0
  272. package/dist/resources/extensions/voice/index.js +247 -0
  273. package/dist/startup-timings.d.ts +2 -0
  274. package/dist/startup-timings.js +22 -0
  275. package/package.json +1 -1
  276. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts +1 -1
  277. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
  278. package/packages/pi-coding-agent/dist/core/extensions/index.js +1 -1
  279. package/packages/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
  280. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +1 -0
  281. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  282. package/packages/pi-coding-agent/dist/core/extensions/loader.js +31 -4
  283. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  284. package/packages/pi-coding-agent/dist/index.d.ts +1 -1
  285. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  286. package/packages/pi-coding-agent/dist/index.js +1 -1
  287. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  288. package/packages/pi-coding-agent/package.json +1 -1
  289. package/packages/pi-coding-agent/src/core/extensions/index.ts +1 -0
  290. package/packages/pi-coding-agent/src/core/extensions/loader.ts +35 -4
  291. package/packages/pi-coding-agent/src/index.ts +1 -0
  292. package/pkg/package.json +1 -1
  293. package/src/resources/extensions/bg-shell/index.ts +41 -46
  294. package/src/resources/extensions/browser-tools/index.ts +156 -67
  295. package/src/resources/extensions/gsd/auto-supervisor.ts +10 -5
  296. package/src/resources/extensions/gsd/auto-verification.ts +20 -2
  297. package/src/resources/extensions/gsd/auto-worktree.ts +136 -1
  298. package/src/resources/extensions/gsd/commands-bootstrap.ts +252 -0
  299. package/src/resources/extensions/gsd/commands.ts +53 -33
  300. package/src/resources/extensions/gsd/git-service.ts +24 -11
  301. package/src/resources/extensions/gsd/index.ts +106 -34
  302. package/src/resources/extensions/gsd/quick.ts +52 -3
  303. package/src/resources/extensions/gsd/repo-identity.ts +56 -22
  304. package/src/resources/extensions/gsd/session-lock.ts +80 -16
  305. package/src/resources/extensions/gsd/tests/auto-dispatch-loop.test.ts +691 -0
  306. package/src/resources/extensions/gsd/tests/cache-staleness-regression.test.ts +317 -0
  307. package/src/resources/extensions/gsd/tests/git-service.test.ts +16 -7
  308. package/src/resources/extensions/gsd/tests/loop-regression.test.ts +40 -5
  309. package/src/resources/extensions/gsd/tests/quick-branch-lifecycle.test.ts +281 -0
  310. package/src/resources/extensions/gsd/tests/repo-identity-worktree.test.ts +71 -0
  311. package/src/resources/extensions/gsd/tests/roadmap-parse-regression.test.ts +358 -0
  312. package/src/resources/extensions/gsd/tests/session-lock-regression.test.ts +216 -0
  313. package/src/resources/extensions/gsd/tests/session-lock.test.ts +119 -0
  314. package/src/resources/extensions/gsd/tests/verification-gate.test.ts +65 -0
  315. package/src/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +206 -0
  316. package/src/resources/extensions/gsd/types.ts +4 -0
  317. package/src/resources/extensions/gsd/verification-evidence.ts +1 -1
  318. package/src/resources/extensions/gsd/verification-gate.ts +23 -2
  319. package/src/resources/extensions/gsd/worktree-command-bootstrap.ts +46 -0
  320. package/src/resources/extensions/gsd/worktree-command.ts +17 -11
  321. package/src/resources/extensions/package.json +3 -0
  322. package/src/resources/extensions/search-the-web/command-search-provider.ts +1 -1
  323. package/src/resources/extensions/search-the-web/index.ts +35 -52
  324. package/src/resources/extensions/search-the-web/tavily.ts +1 -1
  325. package/dist/resources/extensions/ask-user-questions.ts +0 -290
  326. package/dist/resources/extensions/async-jobs/async-bash-tool.ts +0 -212
  327. package/dist/resources/extensions/async-jobs/await-tool.ts +0 -103
  328. package/dist/resources/extensions/async-jobs/cancel-job-tool.ts +0 -35
  329. package/dist/resources/extensions/async-jobs/index.ts +0 -141
  330. package/dist/resources/extensions/async-jobs/job-manager.ts +0 -211
  331. package/dist/resources/extensions/aws-auth/index.ts +0 -144
  332. package/dist/resources/extensions/bg-shell/bg-shell-command.ts +0 -219
  333. package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.ts +0 -400
  334. package/dist/resources/extensions/bg-shell/bg-shell-tool.ts +0 -985
  335. package/dist/resources/extensions/bg-shell/index.ts +0 -59
  336. package/dist/resources/extensions/bg-shell/interaction.ts +0 -198
  337. package/dist/resources/extensions/bg-shell/output-formatter.ts +0 -279
  338. package/dist/resources/extensions/bg-shell/overlay.ts +0 -437
  339. package/dist/resources/extensions/bg-shell/process-manager.ts +0 -464
  340. package/dist/resources/extensions/bg-shell/readiness-detector.ts +0 -126
  341. package/dist/resources/extensions/bg-shell/types.ts +0 -303
  342. package/dist/resources/extensions/bg-shell/utilities.ts +0 -57
  343. package/dist/resources/extensions/browser-tools/capture.ts +0 -199
  344. package/dist/resources/extensions/browser-tools/core.ts +0 -1196
  345. package/dist/resources/extensions/browser-tools/index.ts +0 -71
  346. package/dist/resources/extensions/browser-tools/lifecycle.ts +0 -270
  347. package/dist/resources/extensions/browser-tools/refs.ts +0 -264
  348. package/dist/resources/extensions/browser-tools/settle.ts +0 -197
  349. package/dist/resources/extensions/browser-tools/state.ts +0 -408
  350. package/dist/resources/extensions/browser-tools/tools/action-cache.ts +0 -216
  351. package/dist/resources/extensions/browser-tools/tools/assertions.ts +0 -342
  352. package/dist/resources/extensions/browser-tools/tools/codegen.ts +0 -274
  353. package/dist/resources/extensions/browser-tools/tools/device.ts +0 -183
  354. package/dist/resources/extensions/browser-tools/tools/extract.ts +0 -229
  355. package/dist/resources/extensions/browser-tools/tools/forms.ts +0 -801
  356. package/dist/resources/extensions/browser-tools/tools/injection-detect.ts +0 -221
  357. package/dist/resources/extensions/browser-tools/tools/inspection.ts +0 -492
  358. package/dist/resources/extensions/browser-tools/tools/intent.ts +0 -614
  359. package/dist/resources/extensions/browser-tools/tools/interaction.ts +0 -865
  360. package/dist/resources/extensions/browser-tools/tools/navigation.ts +0 -232
  361. package/dist/resources/extensions/browser-tools/tools/network-mock.ts +0 -244
  362. package/dist/resources/extensions/browser-tools/tools/pages.ts +0 -303
  363. package/dist/resources/extensions/browser-tools/tools/pdf.ts +0 -92
  364. package/dist/resources/extensions/browser-tools/tools/refs.ts +0 -541
  365. package/dist/resources/extensions/browser-tools/tools/screenshot.ts +0 -101
  366. package/dist/resources/extensions/browser-tools/tools/session.ts +0 -400
  367. package/dist/resources/extensions/browser-tools/tools/state-persistence.ts +0 -202
  368. package/dist/resources/extensions/browser-tools/tools/visual-diff.ts +0 -209
  369. package/dist/resources/extensions/browser-tools/tools/wait.ts +0 -247
  370. package/dist/resources/extensions/browser-tools/tools/zoom.ts +0 -104
  371. package/dist/resources/extensions/browser-tools/utils.ts +0 -660
  372. package/dist/resources/extensions/context7/index.ts +0 -428
  373. package/dist/resources/extensions/get-secrets-from-user.ts +0 -607
  374. package/dist/resources/extensions/google-search/index.ts +0 -466
  375. package/dist/resources/extensions/gsd/activity-log.ts +0 -162
  376. package/dist/resources/extensions/gsd/atomic-write.ts +0 -35
  377. package/dist/resources/extensions/gsd/auto/session.ts +0 -236
  378. package/dist/resources/extensions/gsd/auto-budget.ts +0 -32
  379. package/dist/resources/extensions/gsd/auto-dashboard.ts +0 -626
  380. package/dist/resources/extensions/gsd/auto-direct-dispatch.ts +0 -224
  381. package/dist/resources/extensions/gsd/auto-dispatch.ts +0 -409
  382. package/dist/resources/extensions/gsd/auto-idempotency.ts +0 -151
  383. package/dist/resources/extensions/gsd/auto-model-selection.ts +0 -179
  384. package/dist/resources/extensions/gsd/auto-observability.ts +0 -72
  385. package/dist/resources/extensions/gsd/auto-post-unit.ts +0 -618
  386. package/dist/resources/extensions/gsd/auto-prompts.ts +0 -1273
  387. package/dist/resources/extensions/gsd/auto-recovery.ts +0 -578
  388. package/dist/resources/extensions/gsd/auto-start.ts +0 -483
  389. package/dist/resources/extensions/gsd/auto-stuck-detection.ts +0 -221
  390. package/dist/resources/extensions/gsd/auto-timeout-recovery.ts +0 -263
  391. package/dist/resources/extensions/gsd/auto-timers.ts +0 -224
  392. package/dist/resources/extensions/gsd/auto-tool-tracking.ts +0 -54
  393. package/dist/resources/extensions/gsd/auto-unit-closeout.ts +0 -48
  394. package/dist/resources/extensions/gsd/auto-verification.ts +0 -229
  395. package/dist/resources/extensions/gsd/auto-worktree.ts +0 -524
  396. package/dist/resources/extensions/gsd/auto.ts +0 -1834
  397. package/dist/resources/extensions/gsd/captures.ts +0 -427
  398. package/dist/resources/extensions/gsd/claude-import.ts +0 -656
  399. package/dist/resources/extensions/gsd/collision-diagnostics.ts +0 -332
  400. package/dist/resources/extensions/gsd/commands-config.ts +0 -102
  401. package/dist/resources/extensions/gsd/commands-extensions.ts +0 -328
  402. package/dist/resources/extensions/gsd/commands-handlers.ts +0 -395
  403. package/dist/resources/extensions/gsd/commands-inspect.ts +0 -91
  404. package/dist/resources/extensions/gsd/commands-logs.ts +0 -536
  405. package/dist/resources/extensions/gsd/commands-maintenance.ts +0 -206
  406. package/dist/resources/extensions/gsd/commands-prefs-wizard.ts +0 -780
  407. package/dist/resources/extensions/gsd/commands-workflow-templates.ts +0 -543
  408. package/dist/resources/extensions/gsd/commands.ts +0 -1137
  409. package/dist/resources/extensions/gsd/complexity-classifier.ts +0 -320
  410. package/dist/resources/extensions/gsd/context-budget.ts +0 -266
  411. package/dist/resources/extensions/gsd/context-store.ts +0 -195
  412. package/dist/resources/extensions/gsd/crash-recovery.ts +0 -121
  413. package/dist/resources/extensions/gsd/dashboard-overlay.ts +0 -681
  414. package/dist/resources/extensions/gsd/db-writer.ts +0 -360
  415. package/dist/resources/extensions/gsd/debug-logger.ts +0 -178
  416. package/dist/resources/extensions/gsd/detection.ts +0 -470
  417. package/dist/resources/extensions/gsd/diff-context.ts +0 -214
  418. package/dist/resources/extensions/gsd/dispatch-guard.ts +0 -81
  419. package/dist/resources/extensions/gsd/doctor-checks.ts +0 -612
  420. package/dist/resources/extensions/gsd/doctor-environment.ts +0 -497
  421. package/dist/resources/extensions/gsd/doctor-format.ts +0 -78
  422. package/dist/resources/extensions/gsd/doctor-proactive.ts +0 -292
  423. package/dist/resources/extensions/gsd/doctor-providers.ts +0 -343
  424. package/dist/resources/extensions/gsd/doctor-types.ts +0 -87
  425. package/dist/resources/extensions/gsd/doctor.ts +0 -722
  426. package/dist/resources/extensions/gsd/error-utils.ts +0 -6
  427. package/dist/resources/extensions/gsd/exit-command.ts +0 -18
  428. package/dist/resources/extensions/gsd/export.ts +0 -317
  429. package/dist/resources/extensions/gsd/file-watcher.ts +0 -97
  430. package/dist/resources/extensions/gsd/files.ts +0 -1058
  431. package/dist/resources/extensions/gsd/forensics.ts +0 -629
  432. package/dist/resources/extensions/gsd/git-self-heal.ts +0 -127
  433. package/dist/resources/extensions/gsd/git-service.ts +0 -580
  434. package/dist/resources/extensions/gsd/gsd-db.ts +0 -685
  435. package/dist/resources/extensions/gsd/guided-flow-queue.ts +0 -440
  436. package/dist/resources/extensions/gsd/guided-flow.ts +0 -1303
  437. package/dist/resources/extensions/gsd/health-widget.ts +0 -167
  438. package/dist/resources/extensions/gsd/history.ts +0 -143
  439. package/dist/resources/extensions/gsd/index.ts +0 -1390
  440. package/dist/resources/extensions/gsd/init-wizard.ts +0 -587
  441. package/dist/resources/extensions/gsd/json-persistence.ts +0 -67
  442. package/dist/resources/extensions/gsd/key-manager.ts +0 -996
  443. package/dist/resources/extensions/gsd/marketplace-discovery.ts +0 -508
  444. package/dist/resources/extensions/gsd/md-importer.ts +0 -527
  445. package/dist/resources/extensions/gsd/mechanical-completion.ts +0 -430
  446. package/dist/resources/extensions/gsd/memory-extractor.ts +0 -352
  447. package/dist/resources/extensions/gsd/memory-store.ts +0 -441
  448. package/dist/resources/extensions/gsd/metrics.ts +0 -532
  449. package/dist/resources/extensions/gsd/migrate/command.ts +0 -219
  450. package/dist/resources/extensions/gsd/migrate/index.ts +0 -42
  451. package/dist/resources/extensions/gsd/migrate/parser.ts +0 -323
  452. package/dist/resources/extensions/gsd/migrate/parsers.ts +0 -539
  453. package/dist/resources/extensions/gsd/migrate/preview.ts +0 -48
  454. package/dist/resources/extensions/gsd/migrate/transformer.ts +0 -346
  455. package/dist/resources/extensions/gsd/migrate/types.ts +0 -370
  456. package/dist/resources/extensions/gsd/migrate/validator.ts +0 -55
  457. package/dist/resources/extensions/gsd/migrate/writer.ts +0 -579
  458. package/dist/resources/extensions/gsd/migrate-external.ts +0 -140
  459. package/dist/resources/extensions/gsd/milestone-actions.ts +0 -126
  460. package/dist/resources/extensions/gsd/model-cost-table.ts +0 -65
  461. package/dist/resources/extensions/gsd/model-router.ts +0 -256
  462. package/dist/resources/extensions/gsd/namespaced-registry.ts +0 -467
  463. package/dist/resources/extensions/gsd/namespaced-resolver.ts +0 -307
  464. package/dist/resources/extensions/gsd/native-git-bridge.ts +0 -1041
  465. package/dist/resources/extensions/gsd/native-parser-bridge.ts +0 -267
  466. package/dist/resources/extensions/gsd/notifications.ts +0 -87
  467. package/dist/resources/extensions/gsd/observability-validator.ts +0 -429
  468. package/dist/resources/extensions/gsd/parallel-eligibility.ts +0 -233
  469. package/dist/resources/extensions/gsd/parallel-merge.ts +0 -157
  470. package/dist/resources/extensions/gsd/parallel-orchestrator.ts +0 -826
  471. package/dist/resources/extensions/gsd/paths.ts +0 -449
  472. package/dist/resources/extensions/gsd/plugin-importer.ts +0 -411
  473. package/dist/resources/extensions/gsd/post-unit-hooks.ts +0 -520
  474. package/dist/resources/extensions/gsd/preferences-models.ts +0 -329
  475. package/dist/resources/extensions/gsd/preferences-skills.ts +0 -169
  476. package/dist/resources/extensions/gsd/preferences-types.ts +0 -229
  477. package/dist/resources/extensions/gsd/preferences-validation.ts +0 -590
  478. package/dist/resources/extensions/gsd/preferences.ts +0 -416
  479. package/dist/resources/extensions/gsd/progress-score.ts +0 -273
  480. package/dist/resources/extensions/gsd/prompt-cache-optimizer.ts +0 -213
  481. package/dist/resources/extensions/gsd/prompt-compressor.ts +0 -508
  482. package/dist/resources/extensions/gsd/prompt-loader.ts +0 -130
  483. package/dist/resources/extensions/gsd/prompt-ordering.ts +0 -200
  484. package/dist/resources/extensions/gsd/provider-error-pause.ts +0 -88
  485. package/dist/resources/extensions/gsd/queue-order.ts +0 -230
  486. package/dist/resources/extensions/gsd/queue-reorder-ui.ts +0 -276
  487. package/dist/resources/extensions/gsd/quick.ts +0 -212
  488. package/dist/resources/extensions/gsd/repo-identity.ts +0 -169
  489. package/dist/resources/extensions/gsd/roadmap-slices.ts +0 -149
  490. package/dist/resources/extensions/gsd/routing-history.ts +0 -286
  491. package/dist/resources/extensions/gsd/safe-fs.ts +0 -47
  492. package/dist/resources/extensions/gsd/semantic-chunker.ts +0 -336
  493. package/dist/resources/extensions/gsd/session-forensics.ts +0 -537
  494. package/dist/resources/extensions/gsd/session-lock.ts +0 -362
  495. package/dist/resources/extensions/gsd/session-status-io.ts +0 -179
  496. package/dist/resources/extensions/gsd/skill-discovery.ts +0 -139
  497. package/dist/resources/extensions/gsd/skill-health.ts +0 -417
  498. package/dist/resources/extensions/gsd/state.ts +0 -727
  499. package/dist/resources/extensions/gsd/structured-data-formatter.ts +0 -144
  500. package/dist/resources/extensions/gsd/summary-distiller.ts +0 -258
  501. package/dist/resources/extensions/gsd/tests/activity-log.test.ts +0 -213
  502. package/dist/resources/extensions/gsd/tests/agent-end-retry.test.ts +0 -107
  503. package/dist/resources/extensions/gsd/tests/all-milestones-complete-merge.test.ts +0 -200
  504. package/dist/resources/extensions/gsd/tests/auto-budget-alerts.test.ts +0 -50
  505. package/dist/resources/extensions/gsd/tests/auto-dashboard.test.ts +0 -166
  506. package/dist/resources/extensions/gsd/tests/auto-lock-creation.test.ts +0 -186
  507. package/dist/resources/extensions/gsd/tests/auto-preflight.test.ts +0 -40
  508. package/dist/resources/extensions/gsd/tests/auto-recovery.test.ts +0 -640
  509. package/dist/resources/extensions/gsd/tests/auto-reentrancy-guard.test.ts +0 -127
  510. package/dist/resources/extensions/gsd/tests/auto-secrets-gate.test.ts +0 -302
  511. package/dist/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +0 -257
  512. package/dist/resources/extensions/gsd/tests/auto-skip-loop.test.ts +0 -123
  513. package/dist/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +0 -340
  514. package/dist/resources/extensions/gsd/tests/auto-worktree.test.ts +0 -167
  515. package/dist/resources/extensions/gsd/tests/budget-prediction.test.ts +0 -220
  516. package/dist/resources/extensions/gsd/tests/captures.test.ts +0 -438
  517. package/dist/resources/extensions/gsd/tests/claude-import-tui.test.ts +0 -351
  518. package/dist/resources/extensions/gsd/tests/collect-from-manifest.test.ts +0 -469
  519. package/dist/resources/extensions/gsd/tests/collision-diagnostics.test.ts +0 -705
  520. package/dist/resources/extensions/gsd/tests/commands-logs.test.ts +0 -241
  521. package/dist/resources/extensions/gsd/tests/complete-milestone.test.ts +0 -209
  522. package/dist/resources/extensions/gsd/tests/complexity-classifier.test.ts +0 -181
  523. package/dist/resources/extensions/gsd/tests/context-budget.test.ts +0 -352
  524. package/dist/resources/extensions/gsd/tests/context-compression.test.ts +0 -193
  525. package/dist/resources/extensions/gsd/tests/context-store.test.ts +0 -462
  526. package/dist/resources/extensions/gsd/tests/continue-here.test.ts +0 -285
  527. package/dist/resources/extensions/gsd/tests/cost-projection.test.ts +0 -134
  528. package/dist/resources/extensions/gsd/tests/crash-recovery.test.ts +0 -134
  529. package/dist/resources/extensions/gsd/tests/dashboard-budget.test.ts +0 -346
  530. package/dist/resources/extensions/gsd/tests/db-writer.test.ts +0 -602
  531. package/dist/resources/extensions/gsd/tests/debug-logger.test.ts +0 -185
  532. package/dist/resources/extensions/gsd/tests/derive-state-db.test.ts +0 -405
  533. package/dist/resources/extensions/gsd/tests/derive-state-deps.test.ts +0 -421
  534. package/dist/resources/extensions/gsd/tests/derive-state-draft.test.ts +0 -308
  535. package/dist/resources/extensions/gsd/tests/derive-state.test.ts +0 -788
  536. package/dist/resources/extensions/gsd/tests/detection.test.ts +0 -398
  537. package/dist/resources/extensions/gsd/tests/diff-context.test.ts +0 -136
  538. package/dist/resources/extensions/gsd/tests/discuss-prompt.test.ts +0 -15
  539. package/dist/resources/extensions/gsd/tests/dispatch-guard.test.ts +0 -128
  540. package/dist/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +0 -132
  541. package/dist/resources/extensions/gsd/tests/dispatch-stall-guard.test.ts +0 -126
  542. package/dist/resources/extensions/gsd/tests/doctor-environment.test.ts +0 -314
  543. package/dist/resources/extensions/gsd/tests/doctor-fixlevel.test.ts +0 -245
  544. package/dist/resources/extensions/gsd/tests/doctor-git.test.ts +0 -344
  545. package/dist/resources/extensions/gsd/tests/doctor-proactive.test.ts +0 -278
  546. package/dist/resources/extensions/gsd/tests/doctor-providers.test.ts +0 -298
  547. package/dist/resources/extensions/gsd/tests/doctor-runtime.test.ts +0 -302
  548. package/dist/resources/extensions/gsd/tests/doctor.test.ts +0 -652
  549. package/dist/resources/extensions/gsd/tests/draft-promotion.test.ts +0 -169
  550. package/dist/resources/extensions/gsd/tests/exit-command.test.ts +0 -50
  551. package/dist/resources/extensions/gsd/tests/export-html-all.test.ts +0 -105
  552. package/dist/resources/extensions/gsd/tests/export-html-enhancements.test.ts +0 -378
  553. package/dist/resources/extensions/gsd/tests/extension-selector-separator.test.ts +0 -144
  554. package/dist/resources/extensions/gsd/tests/feature-branch-lifecycle-integration.test.ts +0 -424
  555. package/dist/resources/extensions/gsd/tests/git-self-heal.test.ts +0 -131
  556. package/dist/resources/extensions/gsd/tests/git-service.test.ts +0 -1172
  557. package/dist/resources/extensions/gsd/tests/gsd-db.test.ts +0 -353
  558. package/dist/resources/extensions/gsd/tests/gsd-inspect.test.ts +0 -125
  559. package/dist/resources/extensions/gsd/tests/gsd-tools.test.ts +0 -326
  560. package/dist/resources/extensions/gsd/tests/headless-answers.test.ts +0 -340
  561. package/dist/resources/extensions/gsd/tests/headless-query.test.ts +0 -162
  562. package/dist/resources/extensions/gsd/tests/idle-recovery.test.ts +0 -485
  563. package/dist/resources/extensions/gsd/tests/in-flight-tool-tracking.test.ts +0 -32
  564. package/dist/resources/extensions/gsd/tests/init-wizard.test.ts +0 -197
  565. package/dist/resources/extensions/gsd/tests/integration/headless-command.ts +0 -534
  566. package/dist/resources/extensions/gsd/tests/integration-edge.test.ts +0 -228
  567. package/dist/resources/extensions/gsd/tests/integration-lifecycle.test.ts +0 -277
  568. package/dist/resources/extensions/gsd/tests/integration-mixed-milestones.test.ts +0 -523
  569. package/dist/resources/extensions/gsd/tests/key-manager.test.ts +0 -414
  570. package/dist/resources/extensions/gsd/tests/knowledge.test.ts +0 -161
  571. package/dist/resources/extensions/gsd/tests/loop-regression.test.ts +0 -839
  572. package/dist/resources/extensions/gsd/tests/manifest-status.test.ts +0 -283
  573. package/dist/resources/extensions/gsd/tests/marketplace-test-fixtures.ts +0 -91
  574. package/dist/resources/extensions/gsd/tests/md-importer.test.ts +0 -410
  575. package/dist/resources/extensions/gsd/tests/mechanical-completion.test.ts +0 -356
  576. package/dist/resources/extensions/gsd/tests/memory-extractor.test.ts +0 -180
  577. package/dist/resources/extensions/gsd/tests/memory-leak-guards.test.ts +0 -91
  578. package/dist/resources/extensions/gsd/tests/memory-store.test.ts +0 -345
  579. package/dist/resources/extensions/gsd/tests/metrics.test.ts +0 -253
  580. package/dist/resources/extensions/gsd/tests/migrate-command.test.ts +0 -369
  581. package/dist/resources/extensions/gsd/tests/migrate-parser.test.ts +0 -757
  582. package/dist/resources/extensions/gsd/tests/migrate-transformer.test.ts +0 -635
  583. package/dist/resources/extensions/gsd/tests/migrate-validator-parsers.test.ts +0 -414
  584. package/dist/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +0 -303
  585. package/dist/resources/extensions/gsd/tests/migrate-writer.test.ts +0 -398
  586. package/dist/resources/extensions/gsd/tests/milestone-transition-worktree.test.ts +0 -147
  587. package/dist/resources/extensions/gsd/tests/model-cost-table.test.ts +0 -69
  588. package/dist/resources/extensions/gsd/tests/model-isolation.test.ts +0 -157
  589. package/dist/resources/extensions/gsd/tests/model-router.test.ts +0 -167
  590. package/dist/resources/extensions/gsd/tests/must-have-parser.test.ts +0 -291
  591. package/dist/resources/extensions/gsd/tests/namespaced-registry.test.ts +0 -1027
  592. package/dist/resources/extensions/gsd/tests/namespaced-resolver.test.ts +0 -671
  593. package/dist/resources/extensions/gsd/tests/native-has-changes-cache.test.ts +0 -61
  594. package/dist/resources/extensions/gsd/tests/next-milestone-id.test.ts +0 -23
  595. package/dist/resources/extensions/gsd/tests/none-mode-gates.test.ts +0 -114
  596. package/dist/resources/extensions/gsd/tests/notifications.test.ts +0 -67
  597. package/dist/resources/extensions/gsd/tests/overrides.test.ts +0 -131
  598. package/dist/resources/extensions/gsd/tests/parallel-budget-atomicity.test.ts +0 -331
  599. package/dist/resources/extensions/gsd/tests/parallel-crash-recovery.test.ts +0 -298
  600. package/dist/resources/extensions/gsd/tests/parallel-merge.test.ts +0 -468
  601. package/dist/resources/extensions/gsd/tests/parallel-orchestration.test.ts +0 -685
  602. package/dist/resources/extensions/gsd/tests/parallel-worker-monitoring.test.ts +0 -171
  603. package/dist/resources/extensions/gsd/tests/parallel-workers-multi-milestone-e2e.test.ts +0 -354
  604. package/dist/resources/extensions/gsd/tests/park-edge-cases.test.ts +0 -276
  605. package/dist/resources/extensions/gsd/tests/park-milestone.test.ts +0 -401
  606. package/dist/resources/extensions/gsd/tests/parsers.test.ts +0 -1704
  607. package/dist/resources/extensions/gsd/tests/plan-milestone.test.ts +0 -133
  608. package/dist/resources/extensions/gsd/tests/plan-quality-validator.test.ts +0 -363
  609. package/dist/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +0 -42
  610. package/dist/resources/extensions/gsd/tests/plugin-importer-live.test.ts +0 -481
  611. package/dist/resources/extensions/gsd/tests/plugin-importer.test.ts +0 -1383
  612. package/dist/resources/extensions/gsd/tests/post-unit-hooks.test.ts +0 -337
  613. package/dist/resources/extensions/gsd/tests/preferences.test.ts +0 -276
  614. package/dist/resources/extensions/gsd/tests/progress-score.test.ts +0 -206
  615. package/dist/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +0 -464
  616. package/dist/resources/extensions/gsd/tests/prompt-cache-optimizer.test.ts +0 -314
  617. package/dist/resources/extensions/gsd/tests/prompt-compressor.test.ts +0 -529
  618. package/dist/resources/extensions/gsd/tests/prompt-db.test.ts +0 -385
  619. package/dist/resources/extensions/gsd/tests/prompt-ordering.test.ts +0 -296
  620. package/dist/resources/extensions/gsd/tests/provider-errors.test.ts +0 -338
  621. package/dist/resources/extensions/gsd/tests/queue-draft-detection.test.ts +0 -126
  622. package/dist/resources/extensions/gsd/tests/queue-order.test.ts +0 -204
  623. package/dist/resources/extensions/gsd/tests/queue-reorder-e2e.test.ts +0 -282
  624. package/dist/resources/extensions/gsd/tests/reassess-detection.test.ts +0 -154
  625. package/dist/resources/extensions/gsd/tests/reassess-prompt.test.ts +0 -145
  626. package/dist/resources/extensions/gsd/tests/regex-hardening.test.ts +0 -281
  627. package/dist/resources/extensions/gsd/tests/remote-questions.test.ts +0 -642
  628. package/dist/resources/extensions/gsd/tests/remote-status.test.ts +0 -99
  629. package/dist/resources/extensions/gsd/tests/replan-slice.test.ts +0 -538
  630. package/dist/resources/extensions/gsd/tests/requirements.test.ts +0 -106
  631. package/dist/resources/extensions/gsd/tests/roadmap-slices.test.ts +0 -66
  632. package/dist/resources/extensions/gsd/tests/routing-history.test.ts +0 -240
  633. package/dist/resources/extensions/gsd/tests/run-uat.test.ts +0 -416
  634. package/dist/resources/extensions/gsd/tests/secure-env-collect.test.ts +0 -185
  635. package/dist/resources/extensions/gsd/tests/semantic-chunker.test.ts +0 -426
  636. package/dist/resources/extensions/gsd/tests/session-lock.test.ts +0 -315
  637. package/dist/resources/extensions/gsd/tests/skill-lifecycle.test.ts +0 -126
  638. package/dist/resources/extensions/gsd/tests/smart-entry-draft.test.ts +0 -123
  639. package/dist/resources/extensions/gsd/tests/stale-worktree-cwd.test.ts +0 -142
  640. package/dist/resources/extensions/gsd/tests/stop-auto-remote.test.ts +0 -156
  641. package/dist/resources/extensions/gsd/tests/structured-data-formatter.test.ts +0 -365
  642. package/dist/resources/extensions/gsd/tests/summary-distiller.test.ts +0 -323
  643. package/dist/resources/extensions/gsd/tests/test-helpers.ts +0 -61
  644. package/dist/resources/extensions/gsd/tests/token-counter.test.ts +0 -129
  645. package/dist/resources/extensions/gsd/tests/token-optimization-benchmark.test.ts +0 -1272
  646. package/dist/resources/extensions/gsd/tests/token-optimization-prefs.test.ts +0 -164
  647. package/dist/resources/extensions/gsd/tests/token-profile.test.ts +0 -268
  648. package/dist/resources/extensions/gsd/tests/token-savings.test.ts +0 -366
  649. package/dist/resources/extensions/gsd/tests/triage-dispatch.test.ts +0 -340
  650. package/dist/resources/extensions/gsd/tests/triage-resolution.test.ts +0 -416
  651. package/dist/resources/extensions/gsd/tests/undo.test.ts +0 -136
  652. package/dist/resources/extensions/gsd/tests/unique-milestone-ids.test.ts +0 -219
  653. package/dist/resources/extensions/gsd/tests/unit-runtime.test.ts +0 -258
  654. package/dist/resources/extensions/gsd/tests/update-command.test.ts +0 -67
  655. package/dist/resources/extensions/gsd/tests/validate-directory.test.ts +0 -222
  656. package/dist/resources/extensions/gsd/tests/validate-milestone.test.ts +0 -375
  657. package/dist/resources/extensions/gsd/tests/verification-evidence.test.ts +0 -745
  658. package/dist/resources/extensions/gsd/tests/verification-gate.test.ts +0 -1208
  659. package/dist/resources/extensions/gsd/tests/visualizer-critical-path.test.ts +0 -145
  660. package/dist/resources/extensions/gsd/tests/visualizer-data.test.ts +0 -446
  661. package/dist/resources/extensions/gsd/tests/visualizer-overlay.test.ts +0 -237
  662. package/dist/resources/extensions/gsd/tests/visualizer-views.test.ts +0 -718
  663. package/dist/resources/extensions/gsd/tests/worker-registry.test.ts +0 -148
  664. package/dist/resources/extensions/gsd/tests/workflow-templates.test.ts +0 -173
  665. package/dist/resources/extensions/gsd/tests/workspace-index.test.ts +0 -38
  666. package/dist/resources/extensions/gsd/tests/worktree-bugfix.test.ts +0 -120
  667. package/dist/resources/extensions/gsd/tests/worktree-e2e.test.ts +0 -244
  668. package/dist/resources/extensions/gsd/tests/worktree-integration.test.ts +0 -207
  669. package/dist/resources/extensions/gsd/tests/worktree-manager.test.ts +0 -141
  670. package/dist/resources/extensions/gsd/tests/worktree-post-create-hook.test.ts +0 -165
  671. package/dist/resources/extensions/gsd/tests/worktree.test.ts +0 -171
  672. package/dist/resources/extensions/gsd/tests/write-gate.test.ts +0 -211
  673. package/dist/resources/extensions/gsd/token-counter.ts +0 -65
  674. package/dist/resources/extensions/gsd/triage-resolution.ts +0 -284
  675. package/dist/resources/extensions/gsd/triage-ui.ts +0 -175
  676. package/dist/resources/extensions/gsd/types.ts +0 -425
  677. package/dist/resources/extensions/gsd/undo.ts +0 -223
  678. package/dist/resources/extensions/gsd/unit-id.ts +0 -14
  679. package/dist/resources/extensions/gsd/unit-runtime.ts +0 -192
  680. package/dist/resources/extensions/gsd/validate-directory.ts +0 -164
  681. package/dist/resources/extensions/gsd/verification-evidence.ts +0 -188
  682. package/dist/resources/extensions/gsd/verification-gate.ts +0 -643
  683. package/dist/resources/extensions/gsd/visualizer-data.ts +0 -866
  684. package/dist/resources/extensions/gsd/visualizer-overlay.ts +0 -566
  685. package/dist/resources/extensions/gsd/visualizer-views.ts +0 -1171
  686. package/dist/resources/extensions/gsd/workflow-templates.ts +0 -241
  687. package/dist/resources/extensions/gsd/workspace-index.ts +0 -217
  688. package/dist/resources/extensions/gsd/worktree-command.ts +0 -807
  689. package/dist/resources/extensions/gsd/worktree-manager.ts +0 -449
  690. package/dist/resources/extensions/gsd/worktree.ts +0 -257
  691. package/dist/resources/extensions/mac-tools/index.ts +0 -852
  692. package/dist/resources/extensions/mcp-client/index.ts +0 -459
  693. package/dist/resources/extensions/mcporter/extension-manifest.json +0 -12
  694. package/dist/resources/extensions/remote-questions/config.ts +0 -83
  695. package/dist/resources/extensions/remote-questions/discord-adapter.ts +0 -148
  696. package/dist/resources/extensions/remote-questions/format.ts +0 -315
  697. package/dist/resources/extensions/remote-questions/http-client.ts +0 -76
  698. package/dist/resources/extensions/remote-questions/manager.ts +0 -184
  699. package/dist/resources/extensions/remote-questions/notify.ts +0 -90
  700. package/dist/resources/extensions/remote-questions/remote-command.ts +0 -457
  701. package/dist/resources/extensions/remote-questions/slack-adapter.ts +0 -141
  702. package/dist/resources/extensions/remote-questions/status.ts +0 -31
  703. package/dist/resources/extensions/remote-questions/store.ts +0 -81
  704. package/dist/resources/extensions/remote-questions/telegram-adapter.ts +0 -149
  705. package/dist/resources/extensions/remote-questions/types.ts +0 -102
  706. package/dist/resources/extensions/search-the-web/cache.ts +0 -78
  707. package/dist/resources/extensions/search-the-web/command-search-provider.ts +0 -101
  708. package/dist/resources/extensions/search-the-web/format.ts +0 -258
  709. package/dist/resources/extensions/search-the-web/http.ts +0 -238
  710. package/dist/resources/extensions/search-the-web/index.ts +0 -65
  711. package/dist/resources/extensions/search-the-web/native-search.ts +0 -193
  712. package/dist/resources/extensions/search-the-web/provider.ts +0 -148
  713. package/dist/resources/extensions/search-the-web/tavily.ts +0 -116
  714. package/dist/resources/extensions/search-the-web/tool-fetch-page.ts +0 -589
  715. package/dist/resources/extensions/search-the-web/tool-llm-context.ts +0 -608
  716. package/dist/resources/extensions/search-the-web/tool-search.ts +0 -649
  717. package/dist/resources/extensions/search-the-web/url-utils.ts +0 -125
  718. package/dist/resources/extensions/shared/confirm-ui.ts +0 -126
  719. package/dist/resources/extensions/shared/frontmatter.ts +0 -117
  720. package/dist/resources/extensions/shared/interview-ui.ts +0 -613
  721. package/dist/resources/extensions/shared/next-action-ui.ts +0 -212
  722. package/dist/resources/extensions/shared/sanitize.ts +0 -19
  723. package/dist/resources/extensions/shared/terminal.ts +0 -23
  724. package/dist/resources/extensions/shared/tests/format-utils.test.ts +0 -153
  725. package/dist/resources/extensions/shared/ui.ts +0 -400
  726. package/dist/resources/extensions/shared/wizard-ui.ts +0 -551
  727. package/dist/resources/extensions/slash-commands/audit.ts +0 -88
  728. package/dist/resources/extensions/slash-commands/clear.ts +0 -10
  729. package/dist/resources/extensions/slash-commands/create-extension.ts +0 -297
  730. package/dist/resources/extensions/slash-commands/create-slash-command.ts +0 -234
  731. package/dist/resources/extensions/slash-commands/index.ts +0 -12
  732. package/dist/resources/extensions/subagent/agents.ts +0 -126
  733. package/dist/resources/extensions/subagent/index.ts +0 -1121
  734. package/dist/resources/extensions/subagent/isolation.ts +0 -501
  735. package/dist/resources/extensions/subagent/worker-registry.ts +0 -99
  736. package/dist/resources/extensions/ttsr/index.ts +0 -168
  737. package/dist/resources/extensions/ttsr/rule-loader.ts +0 -74
  738. package/dist/resources/extensions/ttsr/ttsr-manager.ts +0 -456
  739. package/dist/resources/extensions/universal-config/discovery.ts +0 -104
  740. package/dist/resources/extensions/universal-config/format.ts +0 -191
  741. package/dist/resources/extensions/universal-config/index.ts +0 -120
  742. package/dist/resources/extensions/universal-config/scanners.ts +0 -642
  743. package/dist/resources/extensions/universal-config/tests/discovery.test.ts +0 -119
  744. package/dist/resources/extensions/universal-config/tests/format.test.ts +0 -127
  745. package/dist/resources/extensions/universal-config/tests/scanners.test.ts +0 -456
  746. package/dist/resources/extensions/universal-config/tools.ts +0 -60
  747. package/dist/resources/extensions/universal-config/types.ts +0 -135
  748. package/dist/resources/extensions/voice/index.ts +0 -272
  749. package/dist/resources/skills/create-gsd-extension/templates/extension-skeleton.ts +0 -51
  750. package/dist/resources/skills/create-gsd-extension/templates/stateful-tool-skeleton.ts +0 -143
  751. package/src/resources/extensions/mcporter/extension-manifest.json +0 -12
@@ -0,0 +1,1149 @@
1
+ /**
2
+ * GSD Guided Flow — Smart Entry Wizard
3
+ *
4
+ * One function: showSmartEntry(). Reads state from disk, shows a contextual
5
+ * wizard via showNextAction(), and dispatches through GSD-WORKFLOW.md.
6
+ * No execution state, no hooks, no tools — the LLM does the rest.
7
+ */
8
+ import { showNextAction } from "../shared/mod.js";
9
+ import { loadFile, parseRoadmap } from "./files.js";
10
+ import { loadPrompt, inlineTemplate } from "./prompt-loader.js";
11
+ import { deriveState } from "./state.js";
12
+ import { invalidateAllCaches } from "./cache.js";
13
+ import { startAuto } from "./auto.js";
14
+ import { readCrashLock, clearLock, formatCrashInfo } from "./crash-recovery.js";
15
+ import { listUnitRuntimeRecords, clearUnitRuntimeRecord } from "./unit-runtime.js";
16
+ import { resolveExpectedArtifactPath } from "./auto.js";
17
+ import { gsdRoot, milestonesDir, resolveMilestoneFile, resolveSliceFile, resolveSlicePath, resolveGsdRootFile, relGsdRootFile, relMilestoneFile, relSliceFile, } from "./paths.js";
18
+ import { join } from "node:path";
19
+ import { readFileSync, existsSync, mkdirSync, readdirSync, unlinkSync } from "node:fs";
20
+ import { nativeIsRepo, nativeInit } from "./native-git-bridge.js";
21
+ import { ensureGitignore, ensurePreferences, untrackRuntimeFiles } from "./gitignore.js";
22
+ import { loadEffectiveGSDPreferences } from "./preferences.js";
23
+ import { detectProjectState } from "./detection.js";
24
+ import { showProjectInit, offerMigration } from "./init-wizard.js";
25
+ import { validateDirectory } from "./validate-directory.js";
26
+ import { showConfirm } from "../shared/mod.js";
27
+ import { debugLog } from "./debug-logger.js";
28
+ import { findMilestoneIds, nextMilestoneId } from "./milestone-ids.js";
29
+ import { parkMilestone, discardMilestone } from "./milestone-actions.js";
30
+ // ─── Re-exports (preserve public API for existing importers) ────────────────
31
+ export { MILESTONE_ID_RE, generateMilestoneSuffix, nextMilestoneId, extractMilestoneSeq, parseMilestoneId, milestoneIdSort, maxMilestoneNum, findMilestoneIds, } from "./milestone-ids.js";
32
+ export { showQueue, handleQueueReorder, showQueueAdd, buildExistingMilestonesContext, } from "./guided-flow-queue.js";
33
+ import { getErrorMessage } from "./error-utils.js";
34
+ // ─── Commit Instruction Helpers ──────────────────────────────────────────────
35
+ /** Build commit instruction for planning prompts. .gsd/ is managed externally and always gitignored. */
36
+ function buildDocsCommitInstruction(_message) {
37
+ return "Do not commit planning artifacts — .gsd/ is managed externally.";
38
+ }
39
+ // ─── Auto-start after discuss ─────────────────────────────────────────────────
40
+ /** Stashed context + flag for auto-starting after discuss phase completes */
41
+ let pendingAutoStart = null;
42
+ /** Returns the milestoneId being discussed, or null if no discussion is active */
43
+ export function getDiscussionMilestoneId() {
44
+ return pendingAutoStart?.milestoneId ?? null;
45
+ }
46
+ /** Called from agent_end to check if auto-mode should start after discuss */
47
+ export function checkAutoStartAfterDiscuss() {
48
+ if (!pendingAutoStart)
49
+ return false;
50
+ const { ctx, pi, basePath, milestoneId, step } = pendingAutoStart;
51
+ // Gate 1: Primary milestone must have CONTEXT.md or ROADMAP.md
52
+ // The "discuss" path creates CONTEXT.md; the "plan" path creates ROADMAP.md.
53
+ const contextFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT");
54
+ const roadmapFile = resolveMilestoneFile(basePath, milestoneId, "ROADMAP");
55
+ if (!contextFile && !roadmapFile)
56
+ return false; // neither artifact yet — keep waiting
57
+ // Gate 2: STATE.md must exist — written as the last step in the discuss
58
+ // output phase. This prevents auto-start from firing during Phase 3
59
+ // (sequential readiness gates for remaining milestones) in multi-milestone
60
+ // discussions, where M001-CONTEXT.md exists but M002/M003 haven't been
61
+ // processed yet.
62
+ const stateFile = resolveGsdRootFile(basePath, "STATE");
63
+ if (!stateFile)
64
+ return false; // discussion not finalized yet
65
+ // Gate 3: Multi-milestone completeness warning
66
+ // Parse PROJECT.md for milestone sequence, warn if any are missing context.
67
+ // Don't block — milestones can be intentionally queued without context.
68
+ const projectFile = resolveGsdRootFile(basePath, "PROJECT");
69
+ if (projectFile) {
70
+ try {
71
+ const projectContent = readFileSync(projectFile, "utf-8");
72
+ const milestoneIds = parseMilestoneSequenceFromProject(projectContent);
73
+ if (milestoneIds.length > 1) {
74
+ const missing = milestoneIds.filter(id => {
75
+ const hasContext = !!resolveMilestoneFile(basePath, id, "CONTEXT");
76
+ const hasDraft = !!resolveMilestoneFile(basePath, id, "CONTEXT-DRAFT");
77
+ const hasDir = existsSync(join(gsdRoot(basePath), "milestones", id));
78
+ return !hasContext && !hasDraft && !hasDir;
79
+ });
80
+ if (missing.length > 0) {
81
+ ctx.ui.notify(`Multi-milestone validation: ${missing.join(", ")} not found in filesystem. ` +
82
+ `Discussion may not have completed all readiness gates.`, "warning");
83
+ }
84
+ }
85
+ }
86
+ catch { /* non-fatal — PROJECT.md parsing failure shouldn't block auto-start */ }
87
+ }
88
+ // Gate 4: Discussion manifest process verification (multi-milestone only)
89
+ // The LLM writes DISCUSSION-MANIFEST.json after each Phase 3 gate decision.
90
+ // If the manifest exists but gates_completed < total, the LLM hasn't finished
91
+ // presenting all readiness gates to the user — block auto-start.
92
+ const manifestPath = join(gsdRoot(basePath), "DISCUSSION-MANIFEST.json");
93
+ if (existsSync(manifestPath)) {
94
+ try {
95
+ const manifest = JSON.parse(readFileSync(manifestPath, "utf-8"));
96
+ const total = typeof manifest.total === "number" ? manifest.total : 0;
97
+ const completed = typeof manifest.gates_completed === "number" ? manifest.gates_completed : 0;
98
+ if (total > 1 && completed < total) {
99
+ // Discussion not complete — block auto-start until all gates are done
100
+ return false;
101
+ }
102
+ // Cross-check manifest milestones against PROJECT.md if available
103
+ if (projectFile) {
104
+ const projectContent = readFileSync(projectFile, "utf-8");
105
+ const projectIds = parseMilestoneSequenceFromProject(projectContent);
106
+ const manifestIds = Object.keys(manifest.milestones ?? {});
107
+ const untracked = projectIds.filter(id => !manifestIds.includes(id));
108
+ if (untracked.length > 0) {
109
+ ctx.ui.notify(`Discussion manifest missing gates for: ${untracked.join(", ")}`, "warning");
110
+ }
111
+ }
112
+ }
113
+ catch { /* malformed manifest — warn but don't block */ }
114
+ }
115
+ // Draft promotion cleanup: if a CONTEXT-DRAFT.md exists alongside the new
116
+ // CONTEXT.md, delete the draft — it's been consumed by the discussion.
117
+ try {
118
+ const draftFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT-DRAFT");
119
+ if (draftFile)
120
+ unlinkSync(draftFile);
121
+ }
122
+ catch { /* non-fatal — stale draft doesn't break anything, CONTEXT.md wins */ }
123
+ // Cleanup: remove discussion manifest after auto-start (only needed during discussion)
124
+ try {
125
+ unlinkSync(manifestPath);
126
+ }
127
+ catch { /* may not exist for single-milestone */ }
128
+ pendingAutoStart = null;
129
+ startAuto(ctx, pi, basePath, false, { step }).catch((err) => {
130
+ ctx.ui.notify(`Auto-start failed: ${getErrorMessage(err)}`, "error");
131
+ if (process.env.GSD_DEBUG)
132
+ console.error('[gsd] auto start error:', err);
133
+ debugLog("auto-start-failed", { error: getErrorMessage(err) });
134
+ });
135
+ return true;
136
+ }
137
+ /**
138
+ * Extract milestone IDs from PROJECT.md milestone sequence table.
139
+ * Looks for rows like "| M001 | Name | Status |" and extracts the ID column.
140
+ */
141
+ function parseMilestoneSequenceFromProject(content) {
142
+ const ids = [];
143
+ const lines = content.split(/\r?\n/);
144
+ for (const line of lines) {
145
+ const match = line.match(/^\|\s*(M\d{3}[A-Z0-9-]*)\s*\|/);
146
+ if (match)
147
+ ids.push(match[1]);
148
+ }
149
+ return ids;
150
+ }
151
+ // ─── Helpers ──────────────────────────────────────────────────────────────────
152
+ /**
153
+ * Read GSD-WORKFLOW.md and dispatch it to the LLM with a contextual note.
154
+ * This is the only way the wizard triggers work — everything else is the LLM's job.
155
+ */
156
+ function dispatchWorkflow(pi, note, customType = "gsd-run") {
157
+ const workflowPath = process.env.GSD_WORKFLOW_PATH ?? join(process.env.HOME ?? "~", ".pi", "GSD-WORKFLOW.md");
158
+ const workflow = readFileSync(workflowPath, "utf-8");
159
+ pi.sendMessage({
160
+ customType,
161
+ content: `Read the following GSD workflow protocol and execute exactly.\n\n${workflow}\n\n## Your Task\n\n${note}`,
162
+ display: false,
163
+ }, { triggerTurn: true });
164
+ }
165
+ /**
166
+ * Build the discuss-and-plan prompt for a new milestone.
167
+ * Used by all three "new milestone" paths (first ever, no active, all complete).
168
+ */
169
+ function buildDiscussPrompt(nextId, preamble, _basePath) {
170
+ const milestoneRel = `.gsd/milestones/${nextId}`;
171
+ const inlinedTemplates = [
172
+ inlineTemplate("project", "Project"),
173
+ inlineTemplate("requirements", "Requirements"),
174
+ inlineTemplate("context", "Context"),
175
+ inlineTemplate("roadmap", "Roadmap"),
176
+ inlineTemplate("decisions", "Decisions"),
177
+ ].join("\n\n---\n\n");
178
+ return loadPrompt("discuss", {
179
+ milestoneId: nextId,
180
+ preamble,
181
+ contextPath: `${milestoneRel}/${nextId}-CONTEXT.md`,
182
+ roadmapPath: `${milestoneRel}/${nextId}-ROADMAP.md`,
183
+ inlinedTemplates,
184
+ commitInstruction: buildDocsCommitInstruction(`docs(${nextId}): context, requirements, and roadmap`),
185
+ multiMilestoneCommitInstruction: buildDocsCommitInstruction("docs: project plan — N milestones"),
186
+ });
187
+ }
188
+ /**
189
+ * Build the discuss prompt for headless milestone creation.
190
+ * Uses the discuss-headless prompt template with seed context injected.
191
+ */
192
+ function buildHeadlessDiscussPrompt(nextId, seedContext, _basePath) {
193
+ const milestoneRel = `.gsd/milestones/${nextId}`;
194
+ const inlinedTemplates = [
195
+ inlineTemplate("project", "Project"),
196
+ inlineTemplate("requirements", "Requirements"),
197
+ inlineTemplate("context", "Context"),
198
+ inlineTemplate("roadmap", "Roadmap"),
199
+ inlineTemplate("decisions", "Decisions"),
200
+ ].join("\n\n---\n\n");
201
+ return loadPrompt("discuss-headless", {
202
+ milestoneId: nextId,
203
+ seedContext,
204
+ contextPath: `${milestoneRel}/${nextId}-CONTEXT.md`,
205
+ roadmapPath: `${milestoneRel}/${nextId}-ROADMAP.md`,
206
+ inlinedTemplates,
207
+ commitInstruction: buildDocsCommitInstruction(`docs(${nextId}): context, requirements, and roadmap`),
208
+ multiMilestoneCommitInstruction: buildDocsCommitInstruction("docs: project plan — N milestones"),
209
+ });
210
+ }
211
+ /**
212
+ * Bootstrap a .gsd/ project from scratch for headless use.
213
+ * Ensures git repo, .gsd/ structure, gitignore, and preferences all exist.
214
+ */
215
+ function bootstrapGsdProject(basePath) {
216
+ if (!nativeIsRepo(basePath)) {
217
+ const mainBranch = loadEffectiveGSDPreferences()?.preferences?.git?.main_branch || "main";
218
+ nativeInit(basePath, mainBranch);
219
+ }
220
+ const root = gsdRoot(basePath);
221
+ mkdirSync(join(root, "milestones"), { recursive: true });
222
+ mkdirSync(join(root, "runtime"), { recursive: true });
223
+ ensureGitignore(basePath);
224
+ ensurePreferences(basePath);
225
+ untrackRuntimeFiles(basePath);
226
+ }
227
+ /**
228
+ * Headless milestone creation from a seed specification document.
229
+ * Bootstraps the project if needed, generates the next milestone ID,
230
+ * and dispatches the headless discuss prompt (no Q&A rounds).
231
+ */
232
+ export async function showHeadlessMilestoneCreation(ctx, pi, basePath, seedContext) {
233
+ // Ensure .gsd/ is bootstrapped
234
+ bootstrapGsdProject(basePath);
235
+ // Generate next milestone ID
236
+ const existingIds = findMilestoneIds(basePath);
237
+ const prefs = loadEffectiveGSDPreferences();
238
+ const nextId = nextMilestoneId(existingIds, prefs?.preferences?.unique_milestone_ids ?? false);
239
+ // Create milestone directory
240
+ const milestoneDir = join(gsdRoot(basePath), "milestones", nextId, "slices");
241
+ mkdirSync(milestoneDir, { recursive: true });
242
+ // Build and dispatch the headless discuss prompt
243
+ const prompt = buildHeadlessDiscussPrompt(nextId, seedContext, basePath);
244
+ // Set pending auto start (auto-mode triggers on "Milestone X ready." via checkAutoStartAfterDiscuss)
245
+ pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId };
246
+ // Dispatch
247
+ dispatchWorkflow(pi, prompt);
248
+ }
249
+ // ─── Discuss Flow ─────────────────────────────────────────────────────────────
250
+ /**
251
+ * Build a rich inlined-context prompt for discussing a specific slice.
252
+ * Preloads roadmap, milestone context, research, decisions, and completed
253
+ * slice summaries so the agent can ask grounded UX/behaviour questions
254
+ * without wasting a turn reading files.
255
+ */
256
+ async function buildDiscussSlicePrompt(mid, sid, sTitle, base, options) {
257
+ const inlined = [];
258
+ // Roadmap — always included so the agent sees surrounding slices
259
+ const roadmapPath = resolveMilestoneFile(base, mid, "ROADMAP");
260
+ const roadmapRel = relMilestoneFile(base, mid, "ROADMAP");
261
+ const roadmapContent = roadmapPath ? await loadFile(roadmapPath) : null;
262
+ if (roadmapContent) {
263
+ inlined.push(`### Milestone Roadmap\nSource: \`${roadmapRel}\`\n\n${roadmapContent.trim()}`);
264
+ }
265
+ // Milestone context — understanding the full milestone intent
266
+ const contextPath = resolveMilestoneFile(base, mid, "CONTEXT");
267
+ const contextRel = relMilestoneFile(base, mid, "CONTEXT");
268
+ const contextContent = contextPath ? await loadFile(contextPath) : null;
269
+ if (contextContent) {
270
+ inlined.push(`### Milestone Context\nSource: \`${contextRel}\`\n\n${contextContent.trim()}`);
271
+ }
272
+ // Milestone research — technical grounding
273
+ const researchPath = resolveMilestoneFile(base, mid, "RESEARCH");
274
+ const researchRel = relMilestoneFile(base, mid, "RESEARCH");
275
+ const researchContent = researchPath ? await loadFile(researchPath) : null;
276
+ if (researchContent) {
277
+ inlined.push(`### Milestone Research\nSource: \`${researchRel}\`\n\n${researchContent.trim()}`);
278
+ }
279
+ // Decisions — architectural context that constrains this slice
280
+ const decisionsPath = resolveGsdRootFile(base, "DECISIONS");
281
+ if (existsSync(decisionsPath)) {
282
+ const decisionsContent = await loadFile(decisionsPath);
283
+ if (decisionsContent) {
284
+ inlined.push(`### Decisions Register\nSource: \`${relGsdRootFile("DECISIONS")}\`\n\n${decisionsContent.trim()}`);
285
+ }
286
+ }
287
+ // Completed slice summaries — what was already built that this slice builds on
288
+ if (roadmapContent) {
289
+ const roadmap = parseRoadmap(roadmapContent);
290
+ for (const s of roadmap.slices) {
291
+ if (!s.done || s.id === sid)
292
+ continue;
293
+ const summaryPath = resolveSliceFile(base, mid, s.id, "SUMMARY");
294
+ const summaryRel = relSliceFile(base, mid, s.id, "SUMMARY");
295
+ const summaryContent = summaryPath ? await loadFile(summaryPath) : null;
296
+ if (summaryContent) {
297
+ inlined.push(`### ${s.id} Summary (completed)\nSource: \`${summaryRel}\`\n\n${summaryContent.trim()}`);
298
+ }
299
+ }
300
+ }
301
+ const inlinedContext = inlined.length > 0
302
+ ? `## Inlined Context (preloaded — do not re-read these files)\n\n${inlined.join("\n\n---\n\n")}`
303
+ : `## Inlined Context\n\n_(no context files found yet — go in blind and ask broad questions)_`;
304
+ const sliceDirPath = `.gsd/milestones/${mid}/slices/${sid}`;
305
+ const sliceContextPath = `${sliceDirPath}/${sid}-CONTEXT.md`;
306
+ // When re-discussing, inject a preamble so the agent treats this as an update interview
307
+ const rediscussPreamble = options?.rediscuss
308
+ ? `\n\n## Re-discuss Mode\n\nThis slice already has an existing context file (\`${sliceContextPath}\`) from a prior discussion. The user has chosen to re-discuss it. Read the existing context file, interview for any updates, changes, or new decisions, and rewrite the file with merged findings. Do NOT skip the interview — the user explicitly asked to revisit this slice.\n`
309
+ : "";
310
+ const inlinedTemplates = inlineTemplate("slice-context", "Slice Context");
311
+ return loadPrompt("guided-discuss-slice", {
312
+ milestoneId: mid,
313
+ sliceId: sid,
314
+ sliceTitle: sTitle,
315
+ inlinedContext: inlinedContext + rediscussPreamble,
316
+ sliceDirPath,
317
+ contextPath: sliceContextPath,
318
+ projectRoot: base,
319
+ inlinedTemplates,
320
+ commitInstruction: buildDocsCommitInstruction(`docs(${mid}/${sid}): slice context from discuss`),
321
+ });
322
+ }
323
+ /**
324
+ * /gsd discuss — show a picker of non-done slices and run a slice interview.
325
+ * Loops back to the picker after each discussion so the user can chain
326
+ * multiple slice interviews in one session.
327
+ */
328
+ export async function showDiscuss(ctx, pi, basePath) {
329
+ // Guard: no .gsd/ project
330
+ if (!existsSync(gsdRoot(basePath))) {
331
+ ctx.ui.notify("No GSD project found. Run /gsd to start one first.", "warning");
332
+ return;
333
+ }
334
+ // Invalidate caches to pick up artifacts written by a just-completed discuss/plan
335
+ invalidateAllCaches();
336
+ const state = await deriveState(basePath);
337
+ // Guard: no active milestone
338
+ if (!state.activeMilestone) {
339
+ ctx.ui.notify("No active milestone. Run /gsd to create one first.", "warning");
340
+ return;
341
+ }
342
+ const mid = state.activeMilestone.id;
343
+ const milestoneTitle = state.activeMilestone.title;
344
+ // Special case: milestone is in needs-discussion phase (has CONTEXT-DRAFT.md but no roadmap yet).
345
+ // Route to the draft discussion flow instead of erroring — the discussion IS how the roadmap gets created.
346
+ if (state.phase === "needs-discussion") {
347
+ const draftFile = resolveMilestoneFile(basePath, mid, "CONTEXT-DRAFT");
348
+ const draftContent = draftFile ? await loadFile(draftFile) : null;
349
+ const choice = await showNextAction(ctx, {
350
+ title: `GSD — ${mid}: ${milestoneTitle}`,
351
+ summary: ["This milestone has a draft context from a prior discussion.", "It needs a dedicated discussion before auto-planning can begin."],
352
+ actions: [
353
+ {
354
+ id: "discuss_draft",
355
+ label: "Discuss from draft",
356
+ description: "Continue where the prior discussion left off — seed material is loaded automatically.",
357
+ recommended: true,
358
+ },
359
+ {
360
+ id: "discuss_fresh",
361
+ label: "Start fresh discussion",
362
+ description: "Discard the draft and start a new discussion from scratch.",
363
+ },
364
+ {
365
+ id: "skip_milestone",
366
+ label: "Skip — create new milestone",
367
+ description: "Leave this milestone as-is and start something new.",
368
+ },
369
+ ],
370
+ notYetMessage: "Run /gsd discuss when ready to discuss this milestone.",
371
+ });
372
+ if (choice === "discuss_draft") {
373
+ const discussMilestoneTemplates = inlineTemplate("context", "Context");
374
+ const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
375
+ const basePrompt = loadPrompt("guided-discuss-milestone", {
376
+ milestoneId: mid, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
377
+ commitInstruction: buildDocsCommitInstruction(`docs(${mid}): milestone context from discuss`),
378
+ });
379
+ const seed = draftContent
380
+ ? `${basePrompt}\n\n## Prior Discussion (Draft Seed)\n\n${draftContent}`
381
+ : basePrompt;
382
+ pendingAutoStart = { ctx, pi, basePath, milestoneId: mid, step: false };
383
+ dispatchWorkflow(pi, seed, "gsd-discuss");
384
+ }
385
+ else if (choice === "discuss_fresh") {
386
+ const discussMilestoneTemplates = inlineTemplate("context", "Context");
387
+ const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
388
+ pendingAutoStart = { ctx, pi, basePath, milestoneId: mid, step: false };
389
+ dispatchWorkflow(pi, loadPrompt("guided-discuss-milestone", {
390
+ milestoneId: mid, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
391
+ commitInstruction: buildDocsCommitInstruction(`docs(${mid}): milestone context from discuss`),
392
+ }), "gsd-discuss");
393
+ }
394
+ else if (choice === "skip_milestone") {
395
+ const milestoneIds = findMilestoneIds(basePath);
396
+ const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
397
+ const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
398
+ pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: false };
399
+ dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
400
+ }
401
+ return;
402
+ }
403
+ // Guard: no roadmap yet
404
+ const roadmapFile = resolveMilestoneFile(basePath, mid, "ROADMAP");
405
+ const roadmapContent = roadmapFile ? await loadFile(roadmapFile) : null;
406
+ if (!roadmapContent) {
407
+ ctx.ui.notify("No roadmap yet for this milestone. Run /gsd to plan first.", "warning");
408
+ return;
409
+ }
410
+ const roadmap = parseRoadmap(roadmapContent);
411
+ const pendingSlices = roadmap.slices.filter(s => !s.done);
412
+ if (pendingSlices.length === 0) {
413
+ ctx.ui.notify("All slices are complete — nothing to discuss.", "info");
414
+ return;
415
+ }
416
+ // Loop: show picker, dispatch discuss, repeat until "not_yet"
417
+ while (true) {
418
+ // Invalidate caches so we pick up CONTEXT files written by the just-completed discussion
419
+ invalidateAllCaches();
420
+ // Build discussion-state map: which slices have CONTEXT files already?
421
+ const discussedMap = new Map();
422
+ for (const s of pendingSlices) {
423
+ const contextFile = resolveSliceFile(basePath, mid, s.id, "CONTEXT");
424
+ discussedMap.set(s.id, !!contextFile);
425
+ }
426
+ // If all pending slices are discussed, notify and exit instead of looping
427
+ const allDiscussed = pendingSlices.every(s => discussedMap.get(s.id));
428
+ if (allDiscussed) {
429
+ ctx.ui.notify(`All ${pendingSlices.length} slices discussed. Run /gsd to start planning.`, "info");
430
+ return;
431
+ }
432
+ // Find the first undiscussed slice to recommend
433
+ const firstUndiscussedId = pendingSlices.find(s => !discussedMap.get(s.id))?.id;
434
+ const actions = pendingSlices.map((s) => {
435
+ const discussed = discussedMap.get(s.id) ?? false;
436
+ const statusParts = [];
437
+ if (state.activeSlice?.id === s.id)
438
+ statusParts.push("active");
439
+ else
440
+ statusParts.push("upcoming");
441
+ statusParts.push(discussed ? "discussed ✓" : "not discussed");
442
+ return {
443
+ id: s.id,
444
+ label: `${s.id}: ${s.title}`,
445
+ description: statusParts.join(" · "),
446
+ recommended: s.id === firstUndiscussedId,
447
+ };
448
+ });
449
+ const choice = await showNextAction(ctx, {
450
+ title: "GSD — Discuss a slice",
451
+ summary: [
452
+ `${mid}: ${milestoneTitle}`,
453
+ "Pick a slice to interview. Context file will be written when done.",
454
+ ],
455
+ actions,
456
+ notYetMessage: "Run /gsd discuss when ready.",
457
+ });
458
+ if (choice === "not_yet")
459
+ return;
460
+ const chosen = pendingSlices.find(s => s.id === choice);
461
+ if (!chosen)
462
+ return;
463
+ // If the slice already has a CONTEXT file, confirm re-discuss intent
464
+ const isRediscuss = discussedMap.get(chosen.id) ?? false;
465
+ if (isRediscuss) {
466
+ const confirm = await showNextAction(ctx, {
467
+ title: `Re-discuss ${chosen.id}?`,
468
+ summary: [
469
+ `${chosen.id} already has a context file from a prior discussion.`,
470
+ "Re-discussing will interview for updates and rewrite the context file.",
471
+ ],
472
+ actions: [
473
+ { id: "rediscuss", label: "Re-discuss to update context", description: "Interview for changes and rewrite", recommended: true },
474
+ { id: "cancel", label: "Cancel", description: "Go back to slice picker" },
475
+ ],
476
+ });
477
+ if (confirm !== "rediscuss")
478
+ continue;
479
+ }
480
+ const prompt = await buildDiscussSlicePrompt(mid, chosen.id, chosen.title, basePath, { rediscuss: isRediscuss });
481
+ dispatchWorkflow(pi, prompt, "gsd-discuss");
482
+ // Wait for the discuss session to finish, then loop back to the picker
483
+ await ctx.waitForIdle();
484
+ invalidateAllCaches();
485
+ }
486
+ }
487
+ // ─── Smart Entry Point ────────────────────────────────────────────────────────
488
+ /**
489
+ * The one wizard. Reads state, shows contextual options, dispatches into the workflow doc.
490
+ */
491
+ /**
492
+ * Self-heal: scan runtime records and clear stale ones left behind when
493
+ * auto-mode crashed mid-unit. auto.ts has its own selfHealRuntimeRecords()
494
+ * but guided-flow (manual /gsd mode) never called it — meaning stale records
495
+ * persisted until the next /gsd auto run. This ensures the wizard always
496
+ * starts from a clean state regardless of how the previous session ended.
497
+ */
498
+ function selfHealRuntimeRecords(basePath, ctx) {
499
+ try {
500
+ const records = listUnitRuntimeRecords(basePath);
501
+ let cleared = 0;
502
+ for (const record of records) {
503
+ const { unitType, unitId, phase } = record;
504
+ // Clear records whose expected artifact already exists (completed but not cleaned up)
505
+ const artifactPath = resolveExpectedArtifactPath(unitType, unitId, basePath);
506
+ if (artifactPath && existsSync(artifactPath)) {
507
+ clearUnitRuntimeRecord(basePath, unitType, unitId);
508
+ cleared++;
509
+ continue;
510
+ }
511
+ // Clear records stuck in dispatched or timeout phase (process died mid-unit)
512
+ if (phase === "dispatched" || phase === "timeout") {
513
+ clearUnitRuntimeRecord(basePath, unitType, unitId);
514
+ cleared++;
515
+ }
516
+ }
517
+ if (cleared > 0) {
518
+ ctx.ui.notify(`Self-heal: cleared ${cleared} stale runtime record(s) from a previous session.`, "info");
519
+ }
520
+ return { cleared };
521
+ }
522
+ catch {
523
+ // Non-fatal — self-heal should never block the wizard
524
+ return { cleared: 0 };
525
+ }
526
+ }
527
+ // ─── Milestone Actions Submenu ──────────────────────────────────────────────
528
+ /**
529
+ * Shows a submenu with Park / Discard / Skip / Back options for the active milestone.
530
+ * Returns true if an action was taken (caller should re-enter showSmartEntry or
531
+ * dispatch a new workflow). Returns false if the user chose "Back".
532
+ */
533
+ async function handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options) {
534
+ const stepMode = options?.step;
535
+ const choice = await showNextAction(ctx, {
536
+ title: `Milestone Actions — ${milestoneId}`,
537
+ summary: [`${milestoneId}: ${milestoneTitle}`],
538
+ actions: [
539
+ {
540
+ id: "park",
541
+ label: "Park milestone",
542
+ description: "Pause this milestone — it stays on disk but is skipped.",
543
+ },
544
+ {
545
+ id: "discard",
546
+ label: "Discard milestone",
547
+ description: "Permanently delete this milestone and all its contents.",
548
+ },
549
+ {
550
+ id: "skip",
551
+ label: "Skip — create new milestone",
552
+ description: "Leave this milestone and start a fresh one.",
553
+ },
554
+ {
555
+ id: "back",
556
+ label: "Back",
557
+ description: "Return to the previous menu.",
558
+ },
559
+ ],
560
+ notYetMessage: "Run /gsd when ready.",
561
+ });
562
+ if (choice === "park") {
563
+ const reason = await showNextAction(ctx, {
564
+ title: `Park ${milestoneId}`,
565
+ summary: ["Why is this milestone being parked?"],
566
+ actions: [
567
+ { id: "priority_shift", label: "Priority shift", description: "Other work is more important right now." },
568
+ { id: "blocked_external", label: "Blocked externally", description: "Waiting on an external dependency or decision." },
569
+ { id: "needs_rethink", label: "Needs rethinking", description: "The approach needs to be reconsidered." },
570
+ ],
571
+ notYetMessage: "Run /gsd when ready.",
572
+ });
573
+ // User pressed "Not yet" / Escape — cancel the park operation
574
+ if (!reason || reason === "not_yet")
575
+ return false;
576
+ const reasonText = reason === "priority_shift" ? "Priority shift — other work is more important"
577
+ : reason === "blocked_external" ? "Blocked externally — waiting on external dependency"
578
+ : reason === "needs_rethink" ? "Needs rethinking — approach needs reconsideration"
579
+ : "Parked by user";
580
+ const success = parkMilestone(basePath, milestoneId, reasonText);
581
+ if (success) {
582
+ ctx.ui.notify(`Parked ${milestoneId}. Run /gsd unpark ${milestoneId} to reactivate.`, "info");
583
+ }
584
+ else {
585
+ ctx.ui.notify(`Could not park ${milestoneId} — milestone not found or already parked.`, "warning");
586
+ }
587
+ return true;
588
+ }
589
+ if (choice === "discard") {
590
+ const confirmed = await showConfirm(ctx, {
591
+ title: "Discard milestone?",
592
+ message: `This will permanently delete ${milestoneId} and all its contents (roadmap, plans, task summaries).`,
593
+ confirmLabel: "Discard",
594
+ declineLabel: "Cancel",
595
+ });
596
+ if (confirmed) {
597
+ discardMilestone(basePath, milestoneId);
598
+ ctx.ui.notify(`Discarded ${milestoneId}.`, "info");
599
+ return true;
600
+ }
601
+ return false;
602
+ }
603
+ if (choice === "skip") {
604
+ const milestoneIds = findMilestoneIds(basePath);
605
+ const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
606
+ const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
607
+ pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
608
+ dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
609
+ return true;
610
+ }
611
+ // "back" or null
612
+ return false;
613
+ }
614
+ export async function showSmartEntry(ctx, pi, basePath, options) {
615
+ const stepMode = options?.step;
616
+ // ── Directory safety check — refuse to operate in system/home dirs ───
617
+ const dirCheck = validateDirectory(basePath);
618
+ if (dirCheck.severity === "blocked") {
619
+ ctx.ui.notify(dirCheck.reason, "error");
620
+ return;
621
+ }
622
+ if (dirCheck.severity === "warning") {
623
+ const proceed = await showConfirm(ctx, {
624
+ title: "GSD — Unusual Directory",
625
+ message: dirCheck.reason,
626
+ confirmLabel: "Continue anyway",
627
+ declineLabel: "Cancel",
628
+ });
629
+ if (!proceed)
630
+ return;
631
+ }
632
+ // ── Detection preamble — run before any bootstrap ────────────────────
633
+ if (!existsSync(gsdRoot(basePath))) {
634
+ const detection = detectProjectState(basePath);
635
+ // v1 .planning/ detected — offer migration before anything else
636
+ if (detection.state === "v1-planning" && detection.v1) {
637
+ const migrationChoice = await offerMigration(ctx, detection.v1);
638
+ if (migrationChoice === "cancel")
639
+ return;
640
+ if (migrationChoice === "migrate") {
641
+ const { handleMigrate } = await import("./migrate/command.js");
642
+ await handleMigrate("", ctx, pi);
643
+ return;
644
+ }
645
+ // "fresh" — fall through to init wizard
646
+ }
647
+ // No .gsd/ — run the project init wizard
648
+ const result = await showProjectInit(ctx, pi, basePath, detection);
649
+ if (!result.completed)
650
+ return; // User cancelled
651
+ // Init wizard bootstrapped .gsd/ — fall through to the normal flow below
652
+ // which will detect "no milestones" and start the discuss prompt
653
+ }
654
+ // ── Ensure git repo exists — GSD needs it for worktree isolation ──────
655
+ if (!nativeIsRepo(basePath)) {
656
+ const mainBranch = loadEffectiveGSDPreferences()?.preferences?.git?.main_branch || "main";
657
+ nativeInit(basePath, mainBranch);
658
+ }
659
+ // ── Ensure .gitignore has baseline patterns ──────────────────────────
660
+ ensureGitignore(basePath);
661
+ untrackRuntimeFiles(basePath);
662
+ // ── Self-heal stale runtime records from crashed auto-mode sessions ──
663
+ selfHealRuntimeRecords(basePath, ctx);
664
+ // Check for crash from previous auto-mode session
665
+ const crashLock = readCrashLock(basePath);
666
+ if (crashLock) {
667
+ clearLock(basePath);
668
+ const resume = await showNextAction(ctx, {
669
+ title: "GSD — Interrupted Session Detected",
670
+ summary: [formatCrashInfo(crashLock)],
671
+ actions: [
672
+ { id: "resume", label: "Resume with /gsd auto", description: "Pick up where it left off", recommended: true },
673
+ { id: "continue", label: "Continue manually", description: "Open the wizard as normal" },
674
+ ],
675
+ });
676
+ if (resume === "resume") {
677
+ await startAuto(ctx, pi, basePath, false);
678
+ return;
679
+ }
680
+ }
681
+ const state = await deriveState(basePath);
682
+ if (!state.activeMilestone) {
683
+ // Guard: if a discuss session is already in flight, don't re-inject the prompt.
684
+ // Both /gsd and /gsd auto reach this branch when no milestone exists yet.
685
+ // Without this guard, every subsequent /gsd call overwrites pendingAutoStart
686
+ // and fires another dispatchWorkflow, resetting the conversation mid-interview.
687
+ if (pendingAutoStart) {
688
+ ctx.ui.notify("Discussion already in progress — answer the question above to continue.", "info");
689
+ return;
690
+ }
691
+ const milestoneIds = findMilestoneIds(basePath);
692
+ // Sanity check (#456): if findMilestoneIds returns [] but the milestones
693
+ // directory has contents, something went wrong (permissions, stale worktree
694
+ // cwd, etc). Warn instead of silently starting a new-project flow.
695
+ if (milestoneIds.length === 0) {
696
+ const mDir = milestonesDir(basePath);
697
+ if (existsSync(mDir)) {
698
+ try {
699
+ const entries = readdirSync(mDir);
700
+ if (entries.length > 0) {
701
+ ctx.ui.notify(`Milestone directory has ${entries.length} entries but none were recognized as milestones. ` +
702
+ `This may indicate a corrupted state or wrong working directory. Run \`/gsd doctor\` to diagnose.`, "warning");
703
+ return;
704
+ }
705
+ }
706
+ catch { /* directory exists but unreadable — fall through to normal flow */ }
707
+ }
708
+ }
709
+ const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
710
+ const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
711
+ const isFirst = milestoneIds.length === 0;
712
+ if (isFirst) {
713
+ // First ever — skip wizard, just ask directly
714
+ pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
715
+ dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New project, milestone ${nextId}. Do NOT read or explore .gsd/ — it's empty scaffolding.`, basePath));
716
+ }
717
+ else {
718
+ const choice = await showNextAction(ctx, {
719
+ title: "GSD — Get Shit Done",
720
+ summary: ["No active milestone."],
721
+ actions: [
722
+ {
723
+ id: "new_milestone",
724
+ label: "Create next milestone",
725
+ description: "Define what to build next.",
726
+ recommended: true,
727
+ },
728
+ ],
729
+ notYetMessage: "Run /gsd when ready.",
730
+ });
731
+ if (choice === "new_milestone") {
732
+ pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
733
+ dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
734
+ }
735
+ }
736
+ return;
737
+ }
738
+ const milestoneId = state.activeMilestone.id;
739
+ const milestoneTitle = state.activeMilestone.title;
740
+ // ── All milestones complete → New milestone ──────────────────────────
741
+ if (state.phase === "complete") {
742
+ const choice = await showNextAction(ctx, {
743
+ title: `GSD — ${milestoneId}: ${milestoneTitle}`,
744
+ summary: ["All milestones complete."],
745
+ actions: [
746
+ {
747
+ id: "new_milestone",
748
+ label: "Start new milestone",
749
+ description: "Define and plan the next milestone.",
750
+ recommended: true,
751
+ },
752
+ {
753
+ id: "status",
754
+ label: "View status",
755
+ description: "Review what was built.",
756
+ },
757
+ ],
758
+ notYetMessage: "Run /gsd when ready.",
759
+ });
760
+ if (choice === "new_milestone") {
761
+ const milestoneIds = findMilestoneIds(basePath);
762
+ const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
763
+ const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
764
+ pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
765
+ dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
766
+ }
767
+ else if (choice === "status") {
768
+ const { fireStatusViaCommand } = await import("./commands.js");
769
+ await fireStatusViaCommand(ctx);
770
+ }
771
+ return;
772
+ }
773
+ // ── Draft milestone — needs discussion before planning ────────────────
774
+ if (state.phase === "needs-discussion") {
775
+ const draftFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT-DRAFT");
776
+ const draftContent = draftFile ? await loadFile(draftFile) : null;
777
+ const choice = await showNextAction(ctx, {
778
+ title: `GSD — ${milestoneId}: ${milestoneTitle}`,
779
+ summary: ["This milestone has a draft context from a prior discussion.", "It needs a dedicated discussion before auto-planning can begin."],
780
+ actions: [
781
+ {
782
+ id: "discuss_draft",
783
+ label: "Discuss from draft",
784
+ description: "Continue where the prior discussion left off — seed material is loaded automatically.",
785
+ recommended: true,
786
+ },
787
+ {
788
+ id: "discuss_fresh",
789
+ label: "Start fresh discussion",
790
+ description: "Discard the draft and start a new discussion from scratch.",
791
+ },
792
+ {
793
+ id: "skip_milestone",
794
+ label: "Skip — create new milestone",
795
+ description: "Leave this milestone as-is and start something new.",
796
+ },
797
+ ],
798
+ notYetMessage: "Run /gsd when ready to discuss this milestone.",
799
+ });
800
+ if (choice === "discuss_draft") {
801
+ const discussMilestoneTemplates = inlineTemplate("context", "Context");
802
+ const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
803
+ const basePrompt = loadPrompt("guided-discuss-milestone", {
804
+ milestoneId, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
805
+ commitInstruction: buildDocsCommitInstruction(`docs(${milestoneId}): milestone context from discuss`),
806
+ });
807
+ const seed = draftContent
808
+ ? `${basePrompt}\n\n## Prior Discussion (Draft Seed)\n\n${draftContent}`
809
+ : basePrompt;
810
+ pendingAutoStart = { ctx, pi, basePath, milestoneId, step: stepMode };
811
+ dispatchWorkflow(pi, seed, "gsd-discuss");
812
+ }
813
+ else if (choice === "discuss_fresh") {
814
+ const discussMilestoneTemplates = inlineTemplate("context", "Context");
815
+ const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
816
+ pendingAutoStart = { ctx, pi, basePath, milestoneId, step: stepMode };
817
+ dispatchWorkflow(pi, loadPrompt("guided-discuss-milestone", {
818
+ milestoneId, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
819
+ commitInstruction: buildDocsCommitInstruction(`docs(${milestoneId}): milestone context from discuss`),
820
+ }), "gsd-discuss");
821
+ }
822
+ else if (choice === "skip_milestone") {
823
+ const milestoneIds = findMilestoneIds(basePath);
824
+ const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
825
+ const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
826
+ pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
827
+ dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
828
+ }
829
+ return;
830
+ }
831
+ // ── No active slice ──────────────────────────────────────────────────
832
+ if (!state.activeSlice) {
833
+ const roadmapFile = resolveMilestoneFile(basePath, milestoneId, "ROADMAP");
834
+ const hasRoadmap = !!(roadmapFile && await loadFile(roadmapFile));
835
+ if (!hasRoadmap) {
836
+ // No roadmap → discuss or plan
837
+ const contextFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT");
838
+ const hasContext = !!(contextFile && await loadFile(contextFile));
839
+ const actions = [
840
+ {
841
+ id: "plan",
842
+ label: "Create roadmap",
843
+ description: hasContext
844
+ ? "Context captured. Decompose into slices with a boundary map."
845
+ : "Decompose the milestone into slices with a boundary map.",
846
+ recommended: true,
847
+ },
848
+ ...(!hasContext ? [{
849
+ id: "discuss",
850
+ label: "Discuss first",
851
+ description: "Capture decisions on gray areas before planning.",
852
+ }] : []),
853
+ {
854
+ id: "skip_milestone",
855
+ label: "Skip — create new milestone",
856
+ description: "Leave this milestone on disk and start a fresh one.",
857
+ },
858
+ {
859
+ id: "discard_milestone",
860
+ label: "Discard this milestone",
861
+ description: "Delete the milestone directory and start over.",
862
+ },
863
+ ];
864
+ const choice = await showNextAction(ctx, {
865
+ title: `GSD — ${milestoneId}: ${milestoneTitle}`,
866
+ summary: [hasContext ? "Context captured. Ready to create roadmap." : "New milestone — no roadmap yet."],
867
+ actions,
868
+ notYetMessage: "Run /gsd when ready.",
869
+ });
870
+ if (choice === "plan") {
871
+ pendingAutoStart = { ctx, pi, basePath, milestoneId, step: stepMode };
872
+ const planMilestoneTemplates = [
873
+ inlineTemplate("roadmap", "Roadmap"),
874
+ inlineTemplate("plan", "Slice Plan"),
875
+ inlineTemplate("task-plan", "Task Plan"),
876
+ inlineTemplate("secrets-manifest", "Secrets Manifest"),
877
+ ].join("\n\n---\n\n");
878
+ const secretsOutputPath = relMilestoneFile(basePath, milestoneId, "SECRETS");
879
+ dispatchWorkflow(pi, loadPrompt("guided-plan-milestone", {
880
+ milestoneId, milestoneTitle, secretsOutputPath, inlinedTemplates: planMilestoneTemplates,
881
+ }));
882
+ }
883
+ else if (choice === "discuss") {
884
+ const discussMilestoneTemplates = inlineTemplate("context", "Context");
885
+ const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
886
+ dispatchWorkflow(pi, loadPrompt("guided-discuss-milestone", {
887
+ milestoneId, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
888
+ commitInstruction: buildDocsCommitInstruction(`docs(${milestoneId}): milestone context from discuss`),
889
+ }));
890
+ }
891
+ else if (choice === "skip_milestone") {
892
+ const milestoneIds = findMilestoneIds(basePath);
893
+ const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
894
+ const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
895
+ pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
896
+ dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
897
+ }
898
+ else if (choice === "discard_milestone") {
899
+ const confirmed = await showConfirm(ctx, {
900
+ title: "Discard milestone?",
901
+ message: `This will permanently delete ${milestoneId} and all its contents.`,
902
+ confirmLabel: "Discard",
903
+ declineLabel: "Cancel",
904
+ });
905
+ if (confirmed) {
906
+ discardMilestone(basePath, milestoneId);
907
+ return showSmartEntry(ctx, pi, basePath, options);
908
+ }
909
+ }
910
+ }
911
+ else {
912
+ // Roadmap exists — either blocked or ready for auto
913
+ const actions = [
914
+ {
915
+ id: "auto",
916
+ label: "Go auto",
917
+ description: "Execute everything automatically until milestone complete.",
918
+ recommended: true,
919
+ },
920
+ {
921
+ id: "status",
922
+ label: "View status",
923
+ description: "See milestone progress and blockers.",
924
+ },
925
+ {
926
+ id: "milestone_actions",
927
+ label: "Milestone actions",
928
+ description: "Park, discard, or skip this milestone.",
929
+ },
930
+ ];
931
+ const choice = await showNextAction(ctx, {
932
+ title: `GSD — ${milestoneId}: ${milestoneTitle}`,
933
+ summary: ["Roadmap exists. Ready to execute."],
934
+ actions,
935
+ notYetMessage: "Run /gsd status for details.",
936
+ });
937
+ if (choice === "auto") {
938
+ await startAuto(ctx, pi, basePath, false);
939
+ }
940
+ else if (choice === "status") {
941
+ const { fireStatusViaCommand } = await import("./commands.js");
942
+ await fireStatusViaCommand(ctx);
943
+ }
944
+ else if (choice === "milestone_actions") {
945
+ const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
946
+ if (acted)
947
+ return showSmartEntry(ctx, pi, basePath, options);
948
+ }
949
+ }
950
+ return;
951
+ }
952
+ const sliceId = state.activeSlice.id;
953
+ const sliceTitle = state.activeSlice.title;
954
+ // ── Slice needs planning ─────────────────────────────────────────────
955
+ if (state.phase === "planning") {
956
+ const contextFile = resolveSliceFile(basePath, milestoneId, sliceId, "CONTEXT");
957
+ const researchFile = resolveSliceFile(basePath, milestoneId, sliceId, "RESEARCH");
958
+ const hasContext = !!(contextFile && await loadFile(contextFile));
959
+ const hasResearch = !!(researchFile && await loadFile(researchFile));
960
+ const actions = [
961
+ {
962
+ id: "plan",
963
+ label: `Plan ${sliceId}`,
964
+ description: `Decompose "${sliceTitle}" into tasks with must-haves.`,
965
+ recommended: true,
966
+ },
967
+ ...(!hasContext ? [{
968
+ id: "discuss",
969
+ label: `Discuss ${sliceId} first`,
970
+ description: "Capture context and decisions for this slice.",
971
+ }] : []),
972
+ ...(!hasResearch ? [{
973
+ id: "research",
974
+ label: `Research ${sliceId} first`,
975
+ description: "Scout codebase and relevant docs.",
976
+ }] : []),
977
+ {
978
+ id: "status",
979
+ label: "View status",
980
+ description: "See milestone progress.",
981
+ },
982
+ {
983
+ id: "milestone_actions",
984
+ label: "Milestone actions",
985
+ description: "Park, discard, or skip this milestone.",
986
+ },
987
+ ];
988
+ const summaryParts = [];
989
+ if (hasContext)
990
+ summaryParts.push("context ✓");
991
+ if (hasResearch)
992
+ summaryParts.push("research ✓");
993
+ const summaryLine = summaryParts.length > 0
994
+ ? `${sliceId}: ${sliceTitle} (${summaryParts.join(", ")})`
995
+ : `${sliceId}: ${sliceTitle} — ready for planning.`;
996
+ const choice = await showNextAction(ctx, {
997
+ title: `GSD — ${milestoneId} / ${sliceId}: ${sliceTitle}`,
998
+ summary: [summaryLine],
999
+ actions,
1000
+ notYetMessage: "Run /gsd when ready.",
1001
+ });
1002
+ if (choice === "plan") {
1003
+ const planSliceTemplates = [
1004
+ inlineTemplate("plan", "Slice Plan"),
1005
+ inlineTemplate("task-plan", "Task Plan"),
1006
+ ].join("\n\n---\n\n");
1007
+ dispatchWorkflow(pi, loadPrompt("guided-plan-slice", {
1008
+ milestoneId, sliceId, sliceTitle, inlinedTemplates: planSliceTemplates,
1009
+ }));
1010
+ }
1011
+ else if (choice === "discuss") {
1012
+ dispatchWorkflow(pi, await buildDiscussSlicePrompt(milestoneId, sliceId, sliceTitle, basePath, { rediscuss: hasContext }));
1013
+ }
1014
+ else if (choice === "research") {
1015
+ const researchTemplates = inlineTemplate("research", "Research");
1016
+ dispatchWorkflow(pi, loadPrompt("guided-research-slice", {
1017
+ milestoneId, sliceId, sliceTitle, inlinedTemplates: researchTemplates,
1018
+ }));
1019
+ }
1020
+ else if (choice === "status") {
1021
+ const { fireStatusViaCommand } = await import("./commands.js");
1022
+ await fireStatusViaCommand(ctx);
1023
+ }
1024
+ else if (choice === "milestone_actions") {
1025
+ const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
1026
+ if (acted)
1027
+ return showSmartEntry(ctx, pi, basePath, options);
1028
+ }
1029
+ return;
1030
+ }
1031
+ // ── All tasks done → Complete slice ──────────────────────────────────
1032
+ if (state.phase === "summarizing") {
1033
+ const choice = await showNextAction(ctx, {
1034
+ title: `GSD — ${milestoneId} / ${sliceId}: ${sliceTitle}`,
1035
+ summary: ["All tasks complete. Ready for slice summary."],
1036
+ actions: [
1037
+ {
1038
+ id: "complete",
1039
+ label: `Complete ${sliceId}`,
1040
+ description: "Write slice summary, UAT, mark done, and squash-merge to main.",
1041
+ recommended: true,
1042
+ },
1043
+ {
1044
+ id: "status",
1045
+ label: "View status",
1046
+ description: "Review tasks before completing.",
1047
+ },
1048
+ {
1049
+ id: "milestone_actions",
1050
+ label: "Milestone actions",
1051
+ description: "Park, discard, or skip this milestone.",
1052
+ },
1053
+ ],
1054
+ notYetMessage: "Run /gsd when ready.",
1055
+ });
1056
+ if (choice === "complete") {
1057
+ const completeSliceTemplates = [
1058
+ inlineTemplate("slice-summary", "Slice Summary"),
1059
+ inlineTemplate("uat", "UAT"),
1060
+ ].join("\n\n---\n\n");
1061
+ dispatchWorkflow(pi, loadPrompt("guided-complete-slice", {
1062
+ workingDirectory: basePath, milestoneId, sliceId, sliceTitle, inlinedTemplates: completeSliceTemplates,
1063
+ }));
1064
+ }
1065
+ else if (choice === "status") {
1066
+ const { fireStatusViaCommand } = await import("./commands.js");
1067
+ await fireStatusViaCommand(ctx);
1068
+ }
1069
+ else if (choice === "milestone_actions") {
1070
+ const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
1071
+ if (acted)
1072
+ return showSmartEntry(ctx, pi, basePath, options);
1073
+ }
1074
+ return;
1075
+ }
1076
+ // ── Active task → Execute ────────────────────────────────────────────
1077
+ if (state.activeTask) {
1078
+ const taskId = state.activeTask.id;
1079
+ const taskTitle = state.activeTask.title;
1080
+ const continueFile = resolveSliceFile(basePath, milestoneId, sliceId, "CONTINUE");
1081
+ const sDir = resolveSlicePath(basePath, milestoneId, sliceId);
1082
+ const hasInterrupted = !!(continueFile && await loadFile(continueFile)) ||
1083
+ !!(sDir && await loadFile(join(sDir, "continue.md")));
1084
+ const choice = await showNextAction(ctx, {
1085
+ title: `GSD — ${milestoneId} / ${sliceId}: ${sliceTitle}`,
1086
+ summary: [
1087
+ hasInterrupted
1088
+ ? `Resuming: ${taskId} — ${taskTitle}`
1089
+ : `Next: ${taskId} — ${taskTitle}`,
1090
+ ],
1091
+ actions: [
1092
+ {
1093
+ id: "execute",
1094
+ label: hasInterrupted ? `Resume ${taskId}` : `Execute ${taskId}`,
1095
+ description: hasInterrupted
1096
+ ? "Continue from where you left off."
1097
+ : `Start working on "${taskTitle}".`,
1098
+ recommended: true,
1099
+ },
1100
+ {
1101
+ id: "auto",
1102
+ label: "Go auto",
1103
+ description: "Execute this and all remaining tasks automatically.",
1104
+ },
1105
+ {
1106
+ id: "status",
1107
+ label: "View status",
1108
+ description: "See slice progress before starting.",
1109
+ },
1110
+ {
1111
+ id: "milestone_actions",
1112
+ label: "Milestone actions",
1113
+ description: "Park, discard, or skip this milestone.",
1114
+ },
1115
+ ],
1116
+ notYetMessage: "Run /gsd when ready.",
1117
+ });
1118
+ if (choice === "auto") {
1119
+ await startAuto(ctx, pi, basePath, false);
1120
+ return;
1121
+ }
1122
+ if (choice === "execute") {
1123
+ if (hasInterrupted) {
1124
+ dispatchWorkflow(pi, loadPrompt("guided-resume-task", {
1125
+ milestoneId, sliceId,
1126
+ }));
1127
+ }
1128
+ else {
1129
+ const executeTaskTemplates = inlineTemplate("task-summary", "Task Summary");
1130
+ dispatchWorkflow(pi, loadPrompt("guided-execute-task", {
1131
+ milestoneId, sliceId, taskId, taskTitle, inlinedTemplates: executeTaskTemplates,
1132
+ }));
1133
+ }
1134
+ }
1135
+ else if (choice === "status") {
1136
+ const { fireStatusViaCommand } = await import("./commands.js");
1137
+ await fireStatusViaCommand(ctx);
1138
+ }
1139
+ else if (choice === "milestone_actions") {
1140
+ const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
1141
+ if (acted)
1142
+ return showSmartEntry(ctx, pi, basePath, options);
1143
+ }
1144
+ return;
1145
+ }
1146
+ // ── Fallback: show status ────────────────────────────────────────────
1147
+ const { fireStatusViaCommand } = await import("./commands.js");
1148
+ await fireStatusViaCommand(ctx);
1149
+ }