gsd-pi 2.33.1 → 2.34.0-dev.bbb5216

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 (828) hide show
  1. package/dist/bundled-resource-path.d.ts +8 -0
  2. package/dist/bundled-resource-path.js +14 -0
  3. package/dist/cli.js +16 -0
  4. package/dist/headless-query.js +6 -6
  5. package/dist/resource-loader.d.ts +2 -0
  6. package/dist/resource-loader.js +39 -4
  7. package/dist/resources/extensions/ask-user-questions.js +217 -0
  8. package/dist/resources/extensions/async-jobs/async-bash-tool.js +180 -0
  9. package/dist/resources/extensions/async-jobs/await-tool.js +90 -0
  10. package/dist/resources/extensions/async-jobs/cancel-job-tool.js +28 -0
  11. package/dist/resources/extensions/async-jobs/index.js +119 -0
  12. package/dist/resources/extensions/async-jobs/job-manager.js +159 -0
  13. package/dist/resources/extensions/aws-auth/index.js +138 -0
  14. package/dist/resources/extensions/bg-shell/bg-shell-command.js +182 -0
  15. package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.js +343 -0
  16. package/dist/resources/extensions/bg-shell/bg-shell-tool.js +831 -0
  17. package/dist/resources/extensions/bg-shell/index.js +41 -0
  18. package/dist/resources/extensions/bg-shell/interaction.js +160 -0
  19. package/dist/resources/extensions/bg-shell/output-formatter.js +245 -0
  20. package/dist/resources/extensions/bg-shell/overlay.js +378 -0
  21. package/dist/resources/extensions/bg-shell/process-manager.js +413 -0
  22. package/dist/resources/extensions/bg-shell/readiness-detector.js +109 -0
  23. package/dist/resources/extensions/bg-shell/types.js +96 -0
  24. package/dist/resources/extensions/bg-shell/utilities.js +50 -0
  25. package/dist/resources/extensions/browser-tools/capture.js +179 -0
  26. package/dist/resources/extensions/browser-tools/core.js +899 -0
  27. package/dist/resources/extensions/browser-tools/{evaluate-helpers.ts → evaluate-helpers.js} +0 -1
  28. package/dist/resources/extensions/browser-tools/index.js +123 -0
  29. package/dist/resources/extensions/browser-tools/lifecycle.js +222 -0
  30. package/dist/resources/extensions/browser-tools/refs.js +254 -0
  31. package/dist/resources/extensions/browser-tools/settle.js +173 -0
  32. package/dist/resources/extensions/browser-tools/state.js +126 -0
  33. package/dist/resources/extensions/browser-tools/tools/action-cache.js +179 -0
  34. package/dist/resources/extensions/browser-tools/tools/assertions.js +320 -0
  35. package/dist/resources/extensions/browser-tools/tools/codegen.js +242 -0
  36. package/dist/resources/extensions/browser-tools/tools/device.js +162 -0
  37. package/dist/resources/extensions/browser-tools/tools/extract.js +191 -0
  38. package/dist/resources/extensions/browser-tools/tools/forms.js +710 -0
  39. package/dist/resources/extensions/browser-tools/tools/injection-detect.js +178 -0
  40. package/dist/resources/extensions/browser-tools/tools/inspection.js +426 -0
  41. package/dist/resources/extensions/browser-tools/tools/intent.js +556 -0
  42. package/dist/resources/extensions/browser-tools/tools/interaction.js +776 -0
  43. package/dist/resources/extensions/browser-tools/tools/navigation.js +208 -0
  44. package/dist/resources/extensions/browser-tools/tools/network-mock.js +194 -0
  45. package/dist/resources/extensions/browser-tools/tools/pages.js +280 -0
  46. package/dist/resources/extensions/browser-tools/tools/pdf.js +74 -0
  47. package/dist/resources/extensions/browser-tools/tools/refs.js +485 -0
  48. package/dist/resources/extensions/browser-tools/tools/screenshot.js +87 -0
  49. package/dist/resources/extensions/browser-tools/tools/session.js +375 -0
  50. package/dist/resources/extensions/browser-tools/tools/state-persistence.js +180 -0
  51. package/dist/resources/extensions/browser-tools/tools/visual-diff.js +174 -0
  52. package/dist/resources/extensions/browser-tools/tools/wait.js +201 -0
  53. package/dist/resources/extensions/browser-tools/tools/zoom.js +90 -0
  54. package/dist/resources/extensions/browser-tools/utils.js +490 -0
  55. package/dist/resources/extensions/context7/index.js +337 -0
  56. package/dist/resources/extensions/get-secrets-from-user.js +492 -0
  57. package/dist/resources/extensions/google-search/index.js +373 -0
  58. package/dist/resources/extensions/gsd/activity-log.js +146 -0
  59. package/dist/resources/extensions/gsd/atomic-write.js +38 -0
  60. package/dist/resources/extensions/gsd/auto/session.js +182 -0
  61. package/dist/resources/extensions/gsd/auto-budget.js +30 -0
  62. package/dist/resources/extensions/gsd/auto-dashboard.js +429 -0
  63. package/dist/resources/extensions/gsd/auto-direct-dispatch.js +185 -0
  64. package/dist/resources/extensions/gsd/auto-dispatch.js +353 -0
  65. package/dist/resources/extensions/gsd/auto-loop.js +956 -0
  66. package/dist/resources/extensions/gsd/auto-model-selection.js +133 -0
  67. package/dist/resources/extensions/gsd/auto-observability.js +56 -0
  68. package/dist/resources/extensions/gsd/auto-post-unit.js +385 -0
  69. package/dist/resources/extensions/gsd/auto-prompts.js +1153 -0
  70. package/dist/resources/extensions/gsd/auto-recovery.js +512 -0
  71. package/dist/resources/extensions/gsd/auto-start.js +414 -0
  72. package/dist/resources/extensions/gsd/auto-supervisor.js +47 -0
  73. package/dist/resources/extensions/gsd/auto-timeout-recovery.js +183 -0
  74. package/dist/resources/extensions/gsd/auto-timers.js +180 -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 +171 -0
  78. package/dist/resources/extensions/gsd/auto-worktree-sync.js +167 -0
  79. package/dist/resources/extensions/gsd/auto-worktree.js +830 -0
  80. package/dist/resources/extensions/gsd/auto.js +765 -0
  81. package/dist/resources/extensions/gsd/{cache.ts → cache.js} +5 -7
  82. package/dist/resources/extensions/gsd/captures.js +354 -0
  83. package/dist/resources/extensions/gsd/claude-import.js +540 -0
  84. package/dist/resources/extensions/gsd/collision-diagnostics.js +226 -0
  85. package/dist/resources/extensions/gsd/commands-bootstrap.js +223 -0
  86. package/dist/resources/extensions/gsd/commands-config.js +89 -0
  87. package/dist/resources/extensions/gsd/commands-extensions.js +259 -0
  88. package/dist/resources/extensions/gsd/commands-handlers.js +310 -0
  89. package/dist/resources/extensions/gsd/commands-inspect.js +70 -0
  90. package/dist/resources/extensions/gsd/commands-logs.js +468 -0
  91. package/dist/resources/extensions/gsd/commands-maintenance.js +185 -0
  92. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +660 -0
  93. package/dist/resources/extensions/gsd/commands-workflow-templates.js +408 -0
  94. package/dist/resources/extensions/gsd/commands.js +1024 -0
  95. package/dist/resources/extensions/gsd/complexity-classifier.js +257 -0
  96. package/dist/resources/extensions/gsd/{constants.ts → constants.js} +0 -6
  97. package/dist/resources/extensions/gsd/context-budget.js +187 -0
  98. package/dist/resources/extensions/gsd/context-store.js +165 -0
  99. package/dist/resources/extensions/gsd/crash-recovery.js +110 -0
  100. package/dist/resources/extensions/gsd/dashboard-overlay.js +562 -0
  101. package/dist/resources/extensions/gsd/db-writer.js +298 -0
  102. package/dist/resources/extensions/gsd/debug-logger.js +161 -0
  103. package/dist/resources/extensions/gsd/detection.js +373 -0
  104. package/dist/resources/extensions/gsd/diff-context.js +168 -0
  105. package/dist/resources/extensions/gsd/dispatch-guard.js +75 -0
  106. package/dist/resources/extensions/gsd/docs/preferences-reference.md +25 -18
  107. package/dist/resources/extensions/gsd/doctor-checks.js +562 -0
  108. package/dist/resources/extensions/gsd/doctor-environment.js +429 -0
  109. package/dist/resources/extensions/gsd/doctor-format.js +71 -0
  110. package/dist/resources/extensions/gsd/doctor-proactive.js +239 -0
  111. package/dist/resources/extensions/gsd/doctor-providers.js +292 -0
  112. package/dist/resources/extensions/gsd/doctor-types.js +12 -0
  113. package/dist/resources/extensions/gsd/doctor.js +672 -0
  114. package/dist/resources/extensions/gsd/error-utils.js +6 -0
  115. package/dist/resources/extensions/gsd/{errors.ts → errors.js} +6 -11
  116. package/dist/resources/extensions/gsd/exit-command.js +11 -0
  117. package/dist/resources/extensions/gsd/{export-html.ts → export-html.js} +482 -614
  118. package/dist/resources/extensions/gsd/export.js +268 -0
  119. package/dist/resources/extensions/gsd/file-watcher.js +76 -0
  120. package/dist/resources/extensions/gsd/files.js +937 -0
  121. package/dist/resources/extensions/gsd/forensics.js +511 -0
  122. package/dist/resources/extensions/gsd/{git-constants.ts → git-constants.js} +4 -5
  123. package/dist/resources/extensions/gsd/git-self-heal.js +113 -0
  124. package/dist/resources/extensions/gsd/git-service.js +460 -0
  125. package/dist/resources/extensions/gsd/{gitignore.ts → gitignore.js} +98 -125
  126. package/dist/resources/extensions/gsd/gsd-db.js +735 -0
  127. package/dist/resources/extensions/gsd/guided-flow-queue.js +366 -0
  128. package/dist/resources/extensions/gsd/guided-flow.js +1158 -0
  129. package/dist/resources/extensions/gsd/health-widget.js +141 -0
  130. package/dist/resources/extensions/gsd/history.js +118 -0
  131. package/dist/resources/extensions/gsd/index.js +1114 -0
  132. package/dist/resources/extensions/gsd/init-wizard.js +479 -0
  133. package/dist/resources/extensions/gsd/json-persistence.js +62 -0
  134. package/dist/resources/extensions/gsd/{jsonl-utils.ts → jsonl-utils.js} +10 -7
  135. package/dist/resources/extensions/gsd/key-manager.js +829 -0
  136. package/dist/resources/extensions/gsd/marketplace-discovery.js +356 -0
  137. package/dist/resources/extensions/gsd/md-importer.js +440 -0
  138. package/dist/resources/extensions/gsd/memory-extractor.js +295 -0
  139. package/dist/resources/extensions/gsd/memory-store.js +351 -0
  140. package/dist/resources/extensions/gsd/metrics.js +377 -0
  141. package/dist/resources/extensions/gsd/migrate/command.js +157 -0
  142. package/dist/resources/extensions/gsd/migrate/index.js +7 -0
  143. package/dist/resources/extensions/gsd/migrate/parser.js +268 -0
  144. package/dist/resources/extensions/gsd/migrate/parsers.js +477 -0
  145. package/dist/resources/extensions/gsd/migrate/preview.js +47 -0
  146. package/dist/resources/extensions/gsd/migrate/transformer.js +278 -0
  147. package/dist/resources/extensions/gsd/migrate/types.js +4 -0
  148. package/dist/resources/extensions/gsd/migrate/validator.js +41 -0
  149. package/dist/resources/extensions/gsd/migrate/writer.js +477 -0
  150. package/dist/resources/extensions/gsd/migrate-external.js +130 -0
  151. package/dist/resources/extensions/gsd/milestone-actions.js +111 -0
  152. package/dist/resources/extensions/gsd/{milestone-ids.ts → milestone-ids.js} +50 -63
  153. package/dist/resources/extensions/gsd/model-cost-table.js +48 -0
  154. package/dist/resources/extensions/gsd/model-router.js +187 -0
  155. package/dist/resources/extensions/gsd/namespaced-registry.js +322 -0
  156. package/dist/resources/extensions/gsd/namespaced-resolver.js +176 -0
  157. package/dist/resources/extensions/gsd/native-git-bridge.js +842 -0
  158. package/dist/resources/extensions/gsd/native-parser-bridge.js +156 -0
  159. package/dist/resources/extensions/gsd/notifications.js +58 -0
  160. package/dist/resources/extensions/gsd/observability-validator.js +398 -0
  161. package/dist/resources/extensions/gsd/parallel-eligibility.js +182 -0
  162. package/dist/resources/extensions/gsd/parallel-merge.js +121 -0
  163. package/dist/resources/extensions/gsd/parallel-orchestrator.js +687 -0
  164. package/dist/resources/extensions/gsd/paths.js +414 -0
  165. package/dist/resources/extensions/gsd/plugin-importer.js +254 -0
  166. package/dist/resources/extensions/gsd/post-unit-hooks.js +433 -0
  167. package/dist/resources/extensions/gsd/preferences-models.js +294 -0
  168. package/dist/resources/extensions/gsd/preferences-skills.js +154 -0
  169. package/dist/resources/extensions/gsd/preferences-types.js +73 -0
  170. package/dist/resources/extensions/gsd/preferences-validation.js +607 -0
  171. package/dist/resources/extensions/gsd/preferences.js +325 -0
  172. package/dist/resources/extensions/gsd/progress-score.js +102 -0
  173. package/dist/resources/extensions/gsd/prompt-cache-optimizer.js +150 -0
  174. package/dist/resources/extensions/gsd/prompt-compressor.js +393 -0
  175. package/dist/resources/extensions/gsd/prompt-loader.js +119 -0
  176. package/dist/resources/extensions/gsd/prompt-ordering.js +170 -0
  177. package/dist/resources/extensions/gsd/provider-error-pause.js +60 -0
  178. package/dist/resources/extensions/gsd/queue-order.js +178 -0
  179. package/dist/resources/extensions/gsd/queue-reorder-ui.js +234 -0
  180. package/dist/resources/extensions/gsd/quick.js +206 -0
  181. package/dist/resources/extensions/gsd/repo-identity.js +187 -0
  182. package/dist/resources/extensions/gsd/{reports.ts → reports.js} +146 -241
  183. package/dist/resources/extensions/gsd/{resource-version.ts → resource-version.js} +50 -53
  184. package/dist/resources/extensions/gsd/roadmap-slices.js +130 -0
  185. package/dist/resources/extensions/gsd/routing-history.js +210 -0
  186. package/dist/resources/extensions/gsd/safe-fs.js +52 -0
  187. package/dist/resources/extensions/gsd/semantic-chunker.js +254 -0
  188. package/dist/resources/extensions/gsd/session-forensics.js +427 -0
  189. package/dist/resources/extensions/gsd/session-lock.js +397 -0
  190. package/dist/resources/extensions/gsd/session-status-io.js +134 -0
  191. package/dist/resources/extensions/gsd/skill-discovery.js +121 -0
  192. package/dist/resources/extensions/gsd/skill-health.js +324 -0
  193. package/dist/resources/extensions/gsd/{skill-telemetry.ts → skill-telemetry.js} +58 -74
  194. package/dist/resources/extensions/gsd/state.js +653 -0
  195. package/dist/resources/extensions/gsd/structured-data-formatter.js +97 -0
  196. package/dist/resources/extensions/gsd/summary-distiller.js +212 -0
  197. package/dist/resources/extensions/gsd/templates/preferences.md +1 -0
  198. package/dist/resources/extensions/gsd/token-counter.js +54 -0
  199. package/dist/resources/extensions/gsd/triage-resolution.js +217 -0
  200. package/dist/resources/extensions/gsd/triage-ui.js +125 -0
  201. package/dist/resources/extensions/gsd/types.js +4 -0
  202. package/dist/resources/extensions/gsd/undo.js +205 -0
  203. package/dist/resources/extensions/gsd/unit-id.js +7 -0
  204. package/dist/resources/extensions/gsd/unit-runtime.js +131 -0
  205. package/dist/resources/extensions/gsd/validate-directory.js +143 -0
  206. package/dist/resources/extensions/gsd/verification-evidence.js +122 -0
  207. package/dist/resources/extensions/gsd/verification-gate.js +514 -0
  208. package/dist/resources/extensions/gsd/visualizer-data.js +612 -0
  209. package/dist/resources/extensions/gsd/visualizer-overlay.js +501 -0
  210. package/dist/resources/extensions/gsd/visualizer-views.js +893 -0
  211. package/dist/resources/extensions/gsd/workflow-templates.js +188 -0
  212. package/dist/resources/extensions/gsd/workspace-index.js +139 -0
  213. package/dist/resources/extensions/gsd/worktree-command-bootstrap.js +40 -0
  214. package/dist/resources/extensions/gsd/worktree-command.js +682 -0
  215. package/dist/resources/extensions/gsd/worktree-manager.js +358 -0
  216. package/dist/resources/extensions/gsd/worktree-resolver.js +344 -0
  217. package/dist/resources/extensions/gsd/worktree.js +199 -0
  218. package/dist/resources/extensions/mac-tools/index.js +768 -0
  219. package/dist/resources/extensions/mcp-client/index.js +363 -0
  220. package/dist/resources/extensions/package.json +3 -0
  221. package/dist/resources/extensions/remote-questions/config.js +70 -0
  222. package/dist/resources/extensions/remote-questions/discord-adapter.js +134 -0
  223. package/dist/resources/extensions/remote-questions/format.js +234 -0
  224. package/dist/resources/extensions/remote-questions/http-client.js +43 -0
  225. package/dist/resources/extensions/remote-questions/manager.js +156 -0
  226. package/dist/resources/extensions/remote-questions/{mod.ts → mod.js} +1 -10
  227. package/dist/resources/extensions/remote-questions/notify.js +89 -0
  228. package/dist/resources/extensions/remote-questions/remote-command.js +453 -0
  229. package/dist/resources/extensions/remote-questions/slack-adapter.js +123 -0
  230. package/dist/resources/extensions/remote-questions/status.js +25 -0
  231. package/dist/resources/extensions/remote-questions/store.js +70 -0
  232. package/dist/resources/extensions/remote-questions/telegram-adapter.js +123 -0
  233. package/dist/resources/extensions/remote-questions/types.js +5 -0
  234. package/dist/resources/extensions/search-the-web/cache.js +74 -0
  235. package/dist/resources/extensions/search-the-web/command-search-provider.js +79 -0
  236. package/dist/resources/extensions/search-the-web/format.js +161 -0
  237. package/dist/resources/extensions/search-the-web/http.js +178 -0
  238. package/dist/resources/extensions/search-the-web/index.js +41 -0
  239. package/dist/resources/extensions/search-the-web/native-search.js +166 -0
  240. package/dist/resources/extensions/search-the-web/provider.js +143 -0
  241. package/dist/resources/extensions/search-the-web/tavily.js +82 -0
  242. package/dist/resources/extensions/search-the-web/tool-fetch-page.js +452 -0
  243. package/dist/resources/extensions/search-the-web/tool-llm-context.js +455 -0
  244. package/dist/resources/extensions/search-the-web/tool-search.js +482 -0
  245. package/dist/resources/extensions/search-the-web/url-utils.js +121 -0
  246. package/dist/resources/extensions/shared/confirm-ui.js +96 -0
  247. package/dist/resources/extensions/shared/{format-utils.ts → format-utils.js} +85 -91
  248. package/dist/resources/extensions/shared/frontmatter.js +109 -0
  249. package/dist/resources/extensions/shared/interview-ui.js +569 -0
  250. package/dist/resources/extensions/shared/{mod.ts → mod.js} +2 -24
  251. package/dist/resources/extensions/shared/next-action-ui.js +168 -0
  252. package/dist/resources/extensions/shared/{path-display.ts → path-display.js} +2 -3
  253. package/dist/resources/extensions/shared/sanitize.js +17 -0
  254. package/dist/resources/extensions/shared/terminal.js +21 -0
  255. package/dist/resources/extensions/shared/ui.js +245 -0
  256. package/dist/resources/extensions/shared/wizard-ui.js +478 -0
  257. package/dist/resources/extensions/slash-commands/audit.js +72 -0
  258. package/dist/resources/extensions/slash-commands/clear.js +8 -0
  259. package/dist/resources/extensions/slash-commands/create-extension.js +264 -0
  260. package/dist/resources/extensions/slash-commands/create-slash-command.js +208 -0
  261. package/dist/resources/extensions/slash-commands/index.js +10 -0
  262. package/dist/resources/extensions/subagent/agents.js +103 -0
  263. package/dist/resources/extensions/subagent/index.js +905 -0
  264. package/dist/resources/extensions/subagent/isolation.js +384 -0
  265. package/dist/resources/extensions/subagent/worker-registry.js +73 -0
  266. package/dist/resources/extensions/ttsr/index.js +144 -0
  267. package/dist/resources/extensions/ttsr/rule-loader.js +70 -0
  268. package/dist/resources/extensions/ttsr/ttsr-manager.js +380 -0
  269. package/dist/resources/extensions/universal-config/discovery.js +94 -0
  270. package/dist/resources/extensions/universal-config/format.js +178 -0
  271. package/dist/resources/extensions/universal-config/index.js +99 -0
  272. package/dist/resources/extensions/universal-config/scanners.js +574 -0
  273. package/dist/resources/extensions/universal-config/tools.js +57 -0
  274. package/dist/resources/extensions/universal-config/types.js +8 -0
  275. package/dist/resources/extensions/voice/index.js +247 -0
  276. package/dist/startup-timings.d.ts +2 -0
  277. package/dist/startup-timings.js +22 -0
  278. package/dist/tool-bootstrap.js +59 -11
  279. package/dist/worktree-cli.js +7 -7
  280. package/package.json +1 -1
  281. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  282. package/packages/pi-coding-agent/dist/core/agent-session.js +9 -0
  283. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  284. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts +1 -1
  285. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
  286. package/packages/pi-coding-agent/dist/core/extensions/index.js +1 -1
  287. package/packages/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
  288. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +1 -0
  289. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  290. package/packages/pi-coding-agent/dist/core/extensions/loader.js +31 -4
  291. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  292. package/packages/pi-coding-agent/dist/index.d.ts +1 -1
  293. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  294. package/packages/pi-coding-agent/dist/index.js +1 -1
  295. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  296. package/packages/pi-coding-agent/package.json +1 -1
  297. package/packages/pi-coding-agent/src/core/agent-session.ts +9 -0
  298. package/packages/pi-coding-agent/src/core/extensions/index.ts +1 -0
  299. package/packages/pi-coding-agent/src/core/extensions/loader.ts +35 -4
  300. package/packages/pi-coding-agent/src/index.ts +1 -0
  301. package/pkg/package.json +1 -1
  302. package/src/resources/extensions/bg-shell/index.ts +41 -46
  303. package/src/resources/extensions/browser-tools/index.ts +156 -67
  304. package/src/resources/extensions/gsd/auto/session.ts +47 -30
  305. package/src/resources/extensions/gsd/auto-dashboard.ts +28 -131
  306. package/src/resources/extensions/gsd/auto-direct-dispatch.ts +6 -1
  307. package/src/resources/extensions/gsd/auto-dispatch.ts +135 -91
  308. package/src/resources/extensions/gsd/auto-loop.ts +1665 -0
  309. package/src/resources/extensions/gsd/auto-observability.ts +4 -2
  310. package/src/resources/extensions/gsd/auto-post-unit.ts +85 -228
  311. package/src/resources/extensions/gsd/auto-prompts.ts +138 -109
  312. package/src/resources/extensions/gsd/auto-recovery.ts +124 -118
  313. package/src/resources/extensions/gsd/auto-start.ts +440 -354
  314. package/src/resources/extensions/gsd/auto-supervisor.ts +5 -12
  315. package/src/resources/extensions/gsd/auto-timeout-recovery.ts +8 -8
  316. package/src/resources/extensions/gsd/auto-timers.ts +3 -4
  317. package/src/resources/extensions/gsd/auto-verification.ts +76 -72
  318. package/src/resources/extensions/gsd/auto-worktree-sync.ts +204 -0
  319. package/src/resources/extensions/gsd/auto-worktree.ts +453 -133
  320. package/src/resources/extensions/gsd/auto.ts +516 -1189
  321. package/src/resources/extensions/gsd/captures.ts +10 -4
  322. package/src/resources/extensions/gsd/commands-bootstrap.ts +252 -0
  323. package/src/resources/extensions/gsd/commands.ts +39 -31
  324. package/src/resources/extensions/gsd/dispatch-guard.ts +13 -9
  325. package/src/resources/extensions/gsd/docs/preferences-reference.md +25 -18
  326. package/src/resources/extensions/gsd/doctor-checks.ts +3 -4
  327. package/src/resources/extensions/gsd/git-service.ts +32 -12
  328. package/src/resources/extensions/gsd/gitignore.ts +4 -2
  329. package/src/resources/extensions/gsd/gsd-db.ts +375 -180
  330. package/src/resources/extensions/gsd/guided-flow.ts +22 -11
  331. package/src/resources/extensions/gsd/index.ts +76 -163
  332. package/src/resources/extensions/gsd/post-unit-hooks.ts +13 -13
  333. package/src/resources/extensions/gsd/progress-score.ts +65 -200
  334. package/src/resources/extensions/gsd/quick.ts +121 -76
  335. package/src/resources/extensions/gsd/repo-identity.ts +56 -22
  336. package/src/resources/extensions/gsd/session-lock.ts +17 -0
  337. package/src/resources/extensions/gsd/templates/preferences.md +1 -0
  338. package/src/resources/extensions/gsd/tests/agent-end-retry.test.ts +32 -59
  339. package/src/resources/extensions/gsd/tests/all-milestones-complete-merge.test.ts +75 -27
  340. package/src/resources/extensions/gsd/tests/auto-budget-alerts.test.ts +1 -1
  341. package/src/resources/extensions/gsd/tests/auto-lock-creation.test.ts +37 -0
  342. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +1458 -0
  343. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +8 -162
  344. package/src/resources/extensions/gsd/tests/auto-secrets-gate.test.ts +2 -108
  345. package/src/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +1 -3
  346. package/src/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +0 -3
  347. package/src/resources/extensions/gsd/tests/auto-worktree.test.ts +58 -0
  348. package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +0 -55
  349. package/src/resources/extensions/gsd/tests/git-service.test.ts +16 -7
  350. package/src/resources/extensions/gsd/tests/headless-query.test.ts +22 -0
  351. package/src/resources/extensions/gsd/tests/milestone-transition-worktree.test.ts +8 -11
  352. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +4 -6
  353. package/src/resources/extensions/gsd/tests/quick-branch-lifecycle.test.ts +281 -0
  354. package/src/resources/extensions/gsd/tests/repo-identity-worktree.test.ts +71 -0
  355. package/src/resources/extensions/gsd/tests/run-uat.test.ts +3 -3
  356. package/src/resources/extensions/gsd/tests/session-lock-regression.test.ts +64 -0
  357. package/src/resources/extensions/gsd/tests/sidecar-queue.test.ts +181 -0
  358. package/src/resources/extensions/gsd/tests/stale-worktree-cwd.test.ts +0 -3
  359. package/src/resources/extensions/gsd/tests/token-profile.test.ts +6 -6
  360. package/src/resources/extensions/gsd/tests/triage-dispatch.test.ts +6 -6
  361. package/src/resources/extensions/gsd/tests/undo.test.ts +6 -0
  362. package/src/resources/extensions/gsd/tests/verification-evidence.test.ts +24 -26
  363. package/src/resources/extensions/gsd/tests/verification-gate.test.ts +7 -136
  364. package/src/resources/extensions/gsd/tests/worktree-db-integration.test.ts +205 -0
  365. package/src/resources/extensions/gsd/tests/worktree-db.test.ts +442 -0
  366. package/src/resources/extensions/gsd/tests/worktree-e2e.test.ts +0 -3
  367. package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +705 -0
  368. package/src/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +57 -106
  369. package/src/resources/extensions/gsd/tests/worktree.test.ts +5 -1
  370. package/src/resources/extensions/gsd/tests/write-gate.test.ts +43 -132
  371. package/src/resources/extensions/gsd/types.ts +90 -77
  372. package/src/resources/extensions/gsd/undo.ts +42 -46
  373. package/src/resources/extensions/gsd/unit-runtime.ts +14 -18
  374. package/src/resources/extensions/gsd/verification-evidence.ts +0 -2
  375. package/src/resources/extensions/gsd/verification-gate.ts +4 -16
  376. package/src/resources/extensions/gsd/worktree-command-bootstrap.ts +46 -0
  377. package/src/resources/extensions/gsd/worktree-command.ts +29 -11
  378. package/src/resources/extensions/gsd/worktree-manager.ts +2 -3
  379. package/src/resources/extensions/gsd/worktree-resolver.ts +485 -0
  380. package/src/resources/extensions/gsd/worktree.ts +7 -44
  381. package/src/resources/extensions/package.json +3 -0
  382. package/src/resources/extensions/search-the-web/command-search-provider.ts +1 -1
  383. package/src/resources/extensions/search-the-web/index.ts +35 -52
  384. package/src/resources/extensions/search-the-web/tavily.ts +1 -1
  385. package/dist/resources/extensions/ask-user-questions.ts +0 -290
  386. package/dist/resources/extensions/async-jobs/async-bash-tool.ts +0 -212
  387. package/dist/resources/extensions/async-jobs/await-tool.ts +0 -103
  388. package/dist/resources/extensions/async-jobs/cancel-job-tool.ts +0 -35
  389. package/dist/resources/extensions/async-jobs/index.ts +0 -141
  390. package/dist/resources/extensions/async-jobs/job-manager.ts +0 -211
  391. package/dist/resources/extensions/aws-auth/index.ts +0 -144
  392. package/dist/resources/extensions/bg-shell/bg-shell-command.ts +0 -219
  393. package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.ts +0 -400
  394. package/dist/resources/extensions/bg-shell/bg-shell-tool.ts +0 -985
  395. package/dist/resources/extensions/bg-shell/index.ts +0 -59
  396. package/dist/resources/extensions/bg-shell/interaction.ts +0 -198
  397. package/dist/resources/extensions/bg-shell/output-formatter.ts +0 -279
  398. package/dist/resources/extensions/bg-shell/overlay.ts +0 -437
  399. package/dist/resources/extensions/bg-shell/process-manager.ts +0 -464
  400. package/dist/resources/extensions/bg-shell/readiness-detector.ts +0 -126
  401. package/dist/resources/extensions/bg-shell/types.ts +0 -303
  402. package/dist/resources/extensions/bg-shell/utilities.ts +0 -57
  403. package/dist/resources/extensions/browser-tools/capture.ts +0 -199
  404. package/dist/resources/extensions/browser-tools/core.ts +0 -1196
  405. package/dist/resources/extensions/browser-tools/index.ts +0 -71
  406. package/dist/resources/extensions/browser-tools/lifecycle.ts +0 -270
  407. package/dist/resources/extensions/browser-tools/refs.ts +0 -264
  408. package/dist/resources/extensions/browser-tools/settle.ts +0 -197
  409. package/dist/resources/extensions/browser-tools/state.ts +0 -408
  410. package/dist/resources/extensions/browser-tools/tools/action-cache.ts +0 -216
  411. package/dist/resources/extensions/browser-tools/tools/assertions.ts +0 -342
  412. package/dist/resources/extensions/browser-tools/tools/codegen.ts +0 -274
  413. package/dist/resources/extensions/browser-tools/tools/device.ts +0 -183
  414. package/dist/resources/extensions/browser-tools/tools/extract.ts +0 -229
  415. package/dist/resources/extensions/browser-tools/tools/forms.ts +0 -801
  416. package/dist/resources/extensions/browser-tools/tools/injection-detect.ts +0 -221
  417. package/dist/resources/extensions/browser-tools/tools/inspection.ts +0 -492
  418. package/dist/resources/extensions/browser-tools/tools/intent.ts +0 -614
  419. package/dist/resources/extensions/browser-tools/tools/interaction.ts +0 -865
  420. package/dist/resources/extensions/browser-tools/tools/navigation.ts +0 -232
  421. package/dist/resources/extensions/browser-tools/tools/network-mock.ts +0 -244
  422. package/dist/resources/extensions/browser-tools/tools/pages.ts +0 -303
  423. package/dist/resources/extensions/browser-tools/tools/pdf.ts +0 -92
  424. package/dist/resources/extensions/browser-tools/tools/refs.ts +0 -541
  425. package/dist/resources/extensions/browser-tools/tools/screenshot.ts +0 -101
  426. package/dist/resources/extensions/browser-tools/tools/session.ts +0 -400
  427. package/dist/resources/extensions/browser-tools/tools/state-persistence.ts +0 -202
  428. package/dist/resources/extensions/browser-tools/tools/visual-diff.ts +0 -209
  429. package/dist/resources/extensions/browser-tools/tools/wait.ts +0 -247
  430. package/dist/resources/extensions/browser-tools/tools/zoom.ts +0 -104
  431. package/dist/resources/extensions/browser-tools/utils.ts +0 -660
  432. package/dist/resources/extensions/context7/index.ts +0 -428
  433. package/dist/resources/extensions/get-secrets-from-user.ts +0 -607
  434. package/dist/resources/extensions/google-search/index.ts +0 -466
  435. package/dist/resources/extensions/gsd/activity-log.ts +0 -162
  436. package/dist/resources/extensions/gsd/atomic-write.ts +0 -35
  437. package/dist/resources/extensions/gsd/auto/session.ts +0 -236
  438. package/dist/resources/extensions/gsd/auto-budget.ts +0 -32
  439. package/dist/resources/extensions/gsd/auto-constants.ts +0 -6
  440. package/dist/resources/extensions/gsd/auto-dashboard.ts +0 -626
  441. package/dist/resources/extensions/gsd/auto-direct-dispatch.ts +0 -224
  442. package/dist/resources/extensions/gsd/auto-dispatch.ts +0 -409
  443. package/dist/resources/extensions/gsd/auto-idempotency.ts +0 -151
  444. package/dist/resources/extensions/gsd/auto-model-selection.ts +0 -179
  445. package/dist/resources/extensions/gsd/auto-observability.ts +0 -72
  446. package/dist/resources/extensions/gsd/auto-post-unit.ts +0 -618
  447. package/dist/resources/extensions/gsd/auto-prompts.ts +0 -1273
  448. package/dist/resources/extensions/gsd/auto-recovery.ts +0 -578
  449. package/dist/resources/extensions/gsd/auto-start.ts +0 -483
  450. package/dist/resources/extensions/gsd/auto-stuck-detection.ts +0 -221
  451. package/dist/resources/extensions/gsd/auto-supervisor.ts +0 -61
  452. package/dist/resources/extensions/gsd/auto-timeout-recovery.ts +0 -263
  453. package/dist/resources/extensions/gsd/auto-timers.ts +0 -224
  454. package/dist/resources/extensions/gsd/auto-tool-tracking.ts +0 -54
  455. package/dist/resources/extensions/gsd/auto-unit-closeout.ts +0 -48
  456. package/dist/resources/extensions/gsd/auto-verification.ts +0 -229
  457. package/dist/resources/extensions/gsd/auto-worktree.ts +0 -658
  458. package/dist/resources/extensions/gsd/auto.ts +0 -1834
  459. package/dist/resources/extensions/gsd/captures.ts +0 -427
  460. package/dist/resources/extensions/gsd/claude-import.ts +0 -656
  461. package/dist/resources/extensions/gsd/collision-diagnostics.ts +0 -332
  462. package/dist/resources/extensions/gsd/commands-config.ts +0 -102
  463. package/dist/resources/extensions/gsd/commands-extensions.ts +0 -328
  464. package/dist/resources/extensions/gsd/commands-handlers.ts +0 -395
  465. package/dist/resources/extensions/gsd/commands-inspect.ts +0 -91
  466. package/dist/resources/extensions/gsd/commands-logs.ts +0 -536
  467. package/dist/resources/extensions/gsd/commands-maintenance.ts +0 -206
  468. package/dist/resources/extensions/gsd/commands-prefs-wizard.ts +0 -780
  469. package/dist/resources/extensions/gsd/commands-workflow-templates.ts +0 -543
  470. package/dist/resources/extensions/gsd/commands.ts +0 -1149
  471. package/dist/resources/extensions/gsd/complexity-classifier.ts +0 -320
  472. package/dist/resources/extensions/gsd/context-budget.ts +0 -266
  473. package/dist/resources/extensions/gsd/context-store.ts +0 -195
  474. package/dist/resources/extensions/gsd/crash-recovery.ts +0 -121
  475. package/dist/resources/extensions/gsd/dashboard-overlay.ts +0 -681
  476. package/dist/resources/extensions/gsd/db-writer.ts +0 -360
  477. package/dist/resources/extensions/gsd/debug-logger.ts +0 -178
  478. package/dist/resources/extensions/gsd/detection.ts +0 -470
  479. package/dist/resources/extensions/gsd/diff-context.ts +0 -214
  480. package/dist/resources/extensions/gsd/dispatch-guard.ts +0 -81
  481. package/dist/resources/extensions/gsd/doctor-checks.ts +0 -612
  482. package/dist/resources/extensions/gsd/doctor-environment.ts +0 -497
  483. package/dist/resources/extensions/gsd/doctor-format.ts +0 -78
  484. package/dist/resources/extensions/gsd/doctor-proactive.ts +0 -292
  485. package/dist/resources/extensions/gsd/doctor-providers.ts +0 -343
  486. package/dist/resources/extensions/gsd/doctor-types.ts +0 -87
  487. package/dist/resources/extensions/gsd/doctor.ts +0 -722
  488. package/dist/resources/extensions/gsd/error-utils.ts +0 -6
  489. package/dist/resources/extensions/gsd/exit-command.ts +0 -18
  490. package/dist/resources/extensions/gsd/export.ts +0 -317
  491. package/dist/resources/extensions/gsd/file-watcher.ts +0 -97
  492. package/dist/resources/extensions/gsd/files.ts +0 -1058
  493. package/dist/resources/extensions/gsd/forensics.ts +0 -629
  494. package/dist/resources/extensions/gsd/git-self-heal.ts +0 -127
  495. package/dist/resources/extensions/gsd/git-service.ts +0 -580
  496. package/dist/resources/extensions/gsd/gsd-db.ts +0 -685
  497. package/dist/resources/extensions/gsd/guided-flow-queue.ts +0 -440
  498. package/dist/resources/extensions/gsd/guided-flow.ts +0 -1303
  499. package/dist/resources/extensions/gsd/health-widget.ts +0 -167
  500. package/dist/resources/extensions/gsd/history.ts +0 -143
  501. package/dist/resources/extensions/gsd/index.ts +0 -1390
  502. package/dist/resources/extensions/gsd/init-wizard.ts +0 -587
  503. package/dist/resources/extensions/gsd/json-persistence.ts +0 -67
  504. package/dist/resources/extensions/gsd/key-manager.ts +0 -996
  505. package/dist/resources/extensions/gsd/marketplace-discovery.ts +0 -508
  506. package/dist/resources/extensions/gsd/md-importer.ts +0 -527
  507. package/dist/resources/extensions/gsd/mechanical-completion.ts +0 -430
  508. package/dist/resources/extensions/gsd/memory-extractor.ts +0 -352
  509. package/dist/resources/extensions/gsd/memory-store.ts +0 -441
  510. package/dist/resources/extensions/gsd/metrics.ts +0 -532
  511. package/dist/resources/extensions/gsd/migrate/command.ts +0 -219
  512. package/dist/resources/extensions/gsd/migrate/index.ts +0 -42
  513. package/dist/resources/extensions/gsd/migrate/parser.ts +0 -323
  514. package/dist/resources/extensions/gsd/migrate/parsers.ts +0 -539
  515. package/dist/resources/extensions/gsd/migrate/preview.ts +0 -48
  516. package/dist/resources/extensions/gsd/migrate/transformer.ts +0 -346
  517. package/dist/resources/extensions/gsd/migrate/types.ts +0 -370
  518. package/dist/resources/extensions/gsd/migrate/validator.ts +0 -55
  519. package/dist/resources/extensions/gsd/migrate/writer.ts +0 -579
  520. package/dist/resources/extensions/gsd/migrate-external.ts +0 -140
  521. package/dist/resources/extensions/gsd/milestone-actions.ts +0 -126
  522. package/dist/resources/extensions/gsd/model-cost-table.ts +0 -65
  523. package/dist/resources/extensions/gsd/model-router.ts +0 -256
  524. package/dist/resources/extensions/gsd/namespaced-registry.ts +0 -467
  525. package/dist/resources/extensions/gsd/namespaced-resolver.ts +0 -307
  526. package/dist/resources/extensions/gsd/native-git-bridge.ts +0 -1041
  527. package/dist/resources/extensions/gsd/native-parser-bridge.ts +0 -267
  528. package/dist/resources/extensions/gsd/notifications.ts +0 -87
  529. package/dist/resources/extensions/gsd/observability-validator.ts +0 -429
  530. package/dist/resources/extensions/gsd/parallel-eligibility.ts +0 -233
  531. package/dist/resources/extensions/gsd/parallel-merge.ts +0 -157
  532. package/dist/resources/extensions/gsd/parallel-orchestrator.ts +0 -826
  533. package/dist/resources/extensions/gsd/paths.ts +0 -449
  534. package/dist/resources/extensions/gsd/plugin-importer.ts +0 -411
  535. package/dist/resources/extensions/gsd/post-unit-hooks.ts +0 -520
  536. package/dist/resources/extensions/gsd/preferences-models.ts +0 -329
  537. package/dist/resources/extensions/gsd/preferences-skills.ts +0 -169
  538. package/dist/resources/extensions/gsd/preferences-types.ts +0 -229
  539. package/dist/resources/extensions/gsd/preferences-validation.ts +0 -590
  540. package/dist/resources/extensions/gsd/preferences.ts +0 -416
  541. package/dist/resources/extensions/gsd/progress-score.ts +0 -273
  542. package/dist/resources/extensions/gsd/prompt-cache-optimizer.ts +0 -213
  543. package/dist/resources/extensions/gsd/prompt-compressor.ts +0 -508
  544. package/dist/resources/extensions/gsd/prompt-loader.ts +0 -130
  545. package/dist/resources/extensions/gsd/prompt-ordering.ts +0 -200
  546. package/dist/resources/extensions/gsd/provider-error-pause.ts +0 -88
  547. package/dist/resources/extensions/gsd/queue-order.ts +0 -230
  548. package/dist/resources/extensions/gsd/queue-reorder-ui.ts +0 -276
  549. package/dist/resources/extensions/gsd/quick.ts +0 -212
  550. package/dist/resources/extensions/gsd/repo-identity.ts +0 -169
  551. package/dist/resources/extensions/gsd/roadmap-slices.ts +0 -149
  552. package/dist/resources/extensions/gsd/routing-history.ts +0 -286
  553. package/dist/resources/extensions/gsd/safe-fs.ts +0 -47
  554. package/dist/resources/extensions/gsd/semantic-chunker.ts +0 -336
  555. package/dist/resources/extensions/gsd/session-forensics.ts +0 -537
  556. package/dist/resources/extensions/gsd/session-lock.ts +0 -426
  557. package/dist/resources/extensions/gsd/session-status-io.ts +0 -179
  558. package/dist/resources/extensions/gsd/skill-discovery.ts +0 -139
  559. package/dist/resources/extensions/gsd/skill-health.ts +0 -417
  560. package/dist/resources/extensions/gsd/state.ts +0 -727
  561. package/dist/resources/extensions/gsd/structured-data-formatter.ts +0 -144
  562. package/dist/resources/extensions/gsd/summary-distiller.ts +0 -258
  563. package/dist/resources/extensions/gsd/tests/activity-log.test.ts +0 -213
  564. package/dist/resources/extensions/gsd/tests/agent-end-retry.test.ts +0 -107
  565. package/dist/resources/extensions/gsd/tests/all-milestones-complete-merge.test.ts +0 -200
  566. package/dist/resources/extensions/gsd/tests/auto-budget-alerts.test.ts +0 -50
  567. package/dist/resources/extensions/gsd/tests/auto-dashboard.test.ts +0 -166
  568. package/dist/resources/extensions/gsd/tests/auto-dispatch-loop.test.ts +0 -691
  569. package/dist/resources/extensions/gsd/tests/auto-lock-creation.test.ts +0 -186
  570. package/dist/resources/extensions/gsd/tests/auto-preflight.test.ts +0 -40
  571. package/dist/resources/extensions/gsd/tests/auto-recovery.test.ts +0 -640
  572. package/dist/resources/extensions/gsd/tests/auto-reentrancy-guard.test.ts +0 -127
  573. package/dist/resources/extensions/gsd/tests/auto-secrets-gate.test.ts +0 -302
  574. package/dist/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +0 -257
  575. package/dist/resources/extensions/gsd/tests/auto-skip-loop.test.ts +0 -123
  576. package/dist/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +0 -340
  577. package/dist/resources/extensions/gsd/tests/auto-worktree.test.ts +0 -167
  578. package/dist/resources/extensions/gsd/tests/budget-prediction.test.ts +0 -220
  579. package/dist/resources/extensions/gsd/tests/cache-staleness-regression.test.ts +0 -317
  580. package/dist/resources/extensions/gsd/tests/captures.test.ts +0 -438
  581. package/dist/resources/extensions/gsd/tests/claude-import-tui.test.ts +0 -351
  582. package/dist/resources/extensions/gsd/tests/collect-from-manifest.test.ts +0 -469
  583. package/dist/resources/extensions/gsd/tests/collision-diagnostics.test.ts +0 -705
  584. package/dist/resources/extensions/gsd/tests/commands-logs.test.ts +0 -241
  585. package/dist/resources/extensions/gsd/tests/complete-milestone.test.ts +0 -209
  586. package/dist/resources/extensions/gsd/tests/complexity-classifier.test.ts +0 -181
  587. package/dist/resources/extensions/gsd/tests/context-budget.test.ts +0 -352
  588. package/dist/resources/extensions/gsd/tests/context-compression.test.ts +0 -193
  589. package/dist/resources/extensions/gsd/tests/context-store.test.ts +0 -462
  590. package/dist/resources/extensions/gsd/tests/continue-here.test.ts +0 -285
  591. package/dist/resources/extensions/gsd/tests/cost-projection.test.ts +0 -134
  592. package/dist/resources/extensions/gsd/tests/crash-recovery.test.ts +0 -134
  593. package/dist/resources/extensions/gsd/tests/dashboard-budget.test.ts +0 -346
  594. package/dist/resources/extensions/gsd/tests/db-writer.test.ts +0 -602
  595. package/dist/resources/extensions/gsd/tests/debug-logger.test.ts +0 -185
  596. package/dist/resources/extensions/gsd/tests/derive-state-db.test.ts +0 -405
  597. package/dist/resources/extensions/gsd/tests/derive-state-deps.test.ts +0 -421
  598. package/dist/resources/extensions/gsd/tests/derive-state-draft.test.ts +0 -308
  599. package/dist/resources/extensions/gsd/tests/derive-state.test.ts +0 -788
  600. package/dist/resources/extensions/gsd/tests/detection.test.ts +0 -398
  601. package/dist/resources/extensions/gsd/tests/diff-context.test.ts +0 -136
  602. package/dist/resources/extensions/gsd/tests/discuss-prompt.test.ts +0 -15
  603. package/dist/resources/extensions/gsd/tests/dispatch-guard.test.ts +0 -128
  604. package/dist/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +0 -132
  605. package/dist/resources/extensions/gsd/tests/dispatch-stall-guard.test.ts +0 -126
  606. package/dist/resources/extensions/gsd/tests/doctor-environment.test.ts +0 -314
  607. package/dist/resources/extensions/gsd/tests/doctor-fixlevel.test.ts +0 -245
  608. package/dist/resources/extensions/gsd/tests/doctor-git.test.ts +0 -344
  609. package/dist/resources/extensions/gsd/tests/doctor-proactive.test.ts +0 -278
  610. package/dist/resources/extensions/gsd/tests/doctor-providers.test.ts +0 -298
  611. package/dist/resources/extensions/gsd/tests/doctor-runtime.test.ts +0 -302
  612. package/dist/resources/extensions/gsd/tests/doctor.test.ts +0 -652
  613. package/dist/resources/extensions/gsd/tests/draft-promotion.test.ts +0 -169
  614. package/dist/resources/extensions/gsd/tests/exit-command.test.ts +0 -50
  615. package/dist/resources/extensions/gsd/tests/export-html-all.test.ts +0 -105
  616. package/dist/resources/extensions/gsd/tests/export-html-enhancements.test.ts +0 -378
  617. package/dist/resources/extensions/gsd/tests/extension-selector-separator.test.ts +0 -144
  618. package/dist/resources/extensions/gsd/tests/feature-branch-lifecycle-integration.test.ts +0 -424
  619. package/dist/resources/extensions/gsd/tests/git-self-heal.test.ts +0 -131
  620. package/dist/resources/extensions/gsd/tests/git-service.test.ts +0 -1172
  621. package/dist/resources/extensions/gsd/tests/gsd-db.test.ts +0 -353
  622. package/dist/resources/extensions/gsd/tests/gsd-inspect.test.ts +0 -125
  623. package/dist/resources/extensions/gsd/tests/gsd-tools.test.ts +0 -326
  624. package/dist/resources/extensions/gsd/tests/headless-answers.test.ts +0 -340
  625. package/dist/resources/extensions/gsd/tests/headless-query.test.ts +0 -162
  626. package/dist/resources/extensions/gsd/tests/idle-recovery.test.ts +0 -485
  627. package/dist/resources/extensions/gsd/tests/in-flight-tool-tracking.test.ts +0 -32
  628. package/dist/resources/extensions/gsd/tests/init-wizard.test.ts +0 -197
  629. package/dist/resources/extensions/gsd/tests/integration/headless-command.ts +0 -534
  630. package/dist/resources/extensions/gsd/tests/integration-edge.test.ts +0 -228
  631. package/dist/resources/extensions/gsd/tests/integration-lifecycle.test.ts +0 -277
  632. package/dist/resources/extensions/gsd/tests/integration-mixed-milestones.test.ts +0 -523
  633. package/dist/resources/extensions/gsd/tests/key-manager.test.ts +0 -414
  634. package/dist/resources/extensions/gsd/tests/knowledge.test.ts +0 -161
  635. package/dist/resources/extensions/gsd/tests/loop-regression.test.ts +0 -877
  636. package/dist/resources/extensions/gsd/tests/manifest-status.test.ts +0 -283
  637. package/dist/resources/extensions/gsd/tests/marketplace-test-fixtures.ts +0 -91
  638. package/dist/resources/extensions/gsd/tests/md-importer.test.ts +0 -410
  639. package/dist/resources/extensions/gsd/tests/mechanical-completion.test.ts +0 -356
  640. package/dist/resources/extensions/gsd/tests/memory-extractor.test.ts +0 -180
  641. package/dist/resources/extensions/gsd/tests/memory-leak-guards.test.ts +0 -91
  642. package/dist/resources/extensions/gsd/tests/memory-store.test.ts +0 -345
  643. package/dist/resources/extensions/gsd/tests/metrics.test.ts +0 -253
  644. package/dist/resources/extensions/gsd/tests/migrate-command.test.ts +0 -369
  645. package/dist/resources/extensions/gsd/tests/migrate-parser.test.ts +0 -757
  646. package/dist/resources/extensions/gsd/tests/migrate-transformer.test.ts +0 -635
  647. package/dist/resources/extensions/gsd/tests/migrate-validator-parsers.test.ts +0 -414
  648. package/dist/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +0 -303
  649. package/dist/resources/extensions/gsd/tests/migrate-writer.test.ts +0 -398
  650. package/dist/resources/extensions/gsd/tests/milestone-transition-worktree.test.ts +0 -147
  651. package/dist/resources/extensions/gsd/tests/model-cost-table.test.ts +0 -69
  652. package/dist/resources/extensions/gsd/tests/model-isolation.test.ts +0 -157
  653. package/dist/resources/extensions/gsd/tests/model-router.test.ts +0 -167
  654. package/dist/resources/extensions/gsd/tests/must-have-parser.test.ts +0 -291
  655. package/dist/resources/extensions/gsd/tests/namespaced-registry.test.ts +0 -1027
  656. package/dist/resources/extensions/gsd/tests/namespaced-resolver.test.ts +0 -671
  657. package/dist/resources/extensions/gsd/tests/native-has-changes-cache.test.ts +0 -61
  658. package/dist/resources/extensions/gsd/tests/next-milestone-id.test.ts +0 -23
  659. package/dist/resources/extensions/gsd/tests/none-mode-gates.test.ts +0 -114
  660. package/dist/resources/extensions/gsd/tests/notifications.test.ts +0 -67
  661. package/dist/resources/extensions/gsd/tests/overrides.test.ts +0 -131
  662. package/dist/resources/extensions/gsd/tests/parallel-budget-atomicity.test.ts +0 -331
  663. package/dist/resources/extensions/gsd/tests/parallel-crash-recovery.test.ts +0 -298
  664. package/dist/resources/extensions/gsd/tests/parallel-merge.test.ts +0 -468
  665. package/dist/resources/extensions/gsd/tests/parallel-orchestration.test.ts +0 -685
  666. package/dist/resources/extensions/gsd/tests/parallel-worker-monitoring.test.ts +0 -171
  667. package/dist/resources/extensions/gsd/tests/parallel-workers-multi-milestone-e2e.test.ts +0 -354
  668. package/dist/resources/extensions/gsd/tests/park-edge-cases.test.ts +0 -276
  669. package/dist/resources/extensions/gsd/tests/park-milestone.test.ts +0 -401
  670. package/dist/resources/extensions/gsd/tests/parsers.test.ts +0 -1704
  671. package/dist/resources/extensions/gsd/tests/plan-milestone.test.ts +0 -133
  672. package/dist/resources/extensions/gsd/tests/plan-quality-validator.test.ts +0 -363
  673. package/dist/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +0 -42
  674. package/dist/resources/extensions/gsd/tests/plugin-importer-live.test.ts +0 -481
  675. package/dist/resources/extensions/gsd/tests/plugin-importer.test.ts +0 -1383
  676. package/dist/resources/extensions/gsd/tests/post-unit-hooks.test.ts +0 -337
  677. package/dist/resources/extensions/gsd/tests/preferences.test.ts +0 -276
  678. package/dist/resources/extensions/gsd/tests/progress-score.test.ts +0 -206
  679. package/dist/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +0 -464
  680. package/dist/resources/extensions/gsd/tests/prompt-cache-optimizer.test.ts +0 -314
  681. package/dist/resources/extensions/gsd/tests/prompt-compressor.test.ts +0 -529
  682. package/dist/resources/extensions/gsd/tests/prompt-db.test.ts +0 -385
  683. package/dist/resources/extensions/gsd/tests/prompt-ordering.test.ts +0 -296
  684. package/dist/resources/extensions/gsd/tests/provider-errors.test.ts +0 -338
  685. package/dist/resources/extensions/gsd/tests/queue-draft-detection.test.ts +0 -126
  686. package/dist/resources/extensions/gsd/tests/queue-order.test.ts +0 -204
  687. package/dist/resources/extensions/gsd/tests/queue-reorder-e2e.test.ts +0 -282
  688. package/dist/resources/extensions/gsd/tests/reassess-detection.test.ts +0 -154
  689. package/dist/resources/extensions/gsd/tests/reassess-prompt.test.ts +0 -145
  690. package/dist/resources/extensions/gsd/tests/regex-hardening.test.ts +0 -281
  691. package/dist/resources/extensions/gsd/tests/remote-questions.test.ts +0 -642
  692. package/dist/resources/extensions/gsd/tests/remote-status.test.ts +0 -99
  693. package/dist/resources/extensions/gsd/tests/replan-slice.test.ts +0 -538
  694. package/dist/resources/extensions/gsd/tests/requirements.test.ts +0 -106
  695. package/dist/resources/extensions/gsd/tests/roadmap-parse-regression.test.ts +0 -358
  696. package/dist/resources/extensions/gsd/tests/roadmap-slices.test.ts +0 -66
  697. package/dist/resources/extensions/gsd/tests/routing-history.test.ts +0 -240
  698. package/dist/resources/extensions/gsd/tests/run-uat.test.ts +0 -416
  699. package/dist/resources/extensions/gsd/tests/secure-env-collect.test.ts +0 -185
  700. package/dist/resources/extensions/gsd/tests/semantic-chunker.test.ts +0 -426
  701. package/dist/resources/extensions/gsd/tests/session-lock-regression.test.ts +0 -216
  702. package/dist/resources/extensions/gsd/tests/session-lock.test.ts +0 -434
  703. package/dist/resources/extensions/gsd/tests/skill-lifecycle.test.ts +0 -126
  704. package/dist/resources/extensions/gsd/tests/smart-entry-draft.test.ts +0 -123
  705. package/dist/resources/extensions/gsd/tests/stale-worktree-cwd.test.ts +0 -142
  706. package/dist/resources/extensions/gsd/tests/stop-auto-remote.test.ts +0 -156
  707. package/dist/resources/extensions/gsd/tests/structured-data-formatter.test.ts +0 -365
  708. package/dist/resources/extensions/gsd/tests/summary-distiller.test.ts +0 -323
  709. package/dist/resources/extensions/gsd/tests/test-helpers.ts +0 -61
  710. package/dist/resources/extensions/gsd/tests/token-counter.test.ts +0 -129
  711. package/dist/resources/extensions/gsd/tests/token-optimization-benchmark.test.ts +0 -1272
  712. package/dist/resources/extensions/gsd/tests/token-optimization-prefs.test.ts +0 -164
  713. package/dist/resources/extensions/gsd/tests/token-profile.test.ts +0 -268
  714. package/dist/resources/extensions/gsd/tests/token-savings.test.ts +0 -366
  715. package/dist/resources/extensions/gsd/tests/triage-dispatch.test.ts +0 -340
  716. package/dist/resources/extensions/gsd/tests/triage-resolution.test.ts +0 -416
  717. package/dist/resources/extensions/gsd/tests/undo.test.ts +0 -136
  718. package/dist/resources/extensions/gsd/tests/unique-milestone-ids.test.ts +0 -219
  719. package/dist/resources/extensions/gsd/tests/unit-runtime.test.ts +0 -258
  720. package/dist/resources/extensions/gsd/tests/update-command.test.ts +0 -67
  721. package/dist/resources/extensions/gsd/tests/validate-directory.test.ts +0 -222
  722. package/dist/resources/extensions/gsd/tests/validate-milestone.test.ts +0 -375
  723. package/dist/resources/extensions/gsd/tests/verification-evidence.test.ts +0 -745
  724. package/dist/resources/extensions/gsd/tests/verification-gate.test.ts +0 -1208
  725. package/dist/resources/extensions/gsd/tests/visualizer-critical-path.test.ts +0 -145
  726. package/dist/resources/extensions/gsd/tests/visualizer-data.test.ts +0 -446
  727. package/dist/resources/extensions/gsd/tests/visualizer-overlay.test.ts +0 -237
  728. package/dist/resources/extensions/gsd/tests/visualizer-views.test.ts +0 -718
  729. package/dist/resources/extensions/gsd/tests/worker-registry.test.ts +0 -148
  730. package/dist/resources/extensions/gsd/tests/workflow-templates.test.ts +0 -173
  731. package/dist/resources/extensions/gsd/tests/workspace-index.test.ts +0 -38
  732. package/dist/resources/extensions/gsd/tests/worktree-bugfix.test.ts +0 -120
  733. package/dist/resources/extensions/gsd/tests/worktree-e2e.test.ts +0 -244
  734. package/dist/resources/extensions/gsd/tests/worktree-integration.test.ts +0 -207
  735. package/dist/resources/extensions/gsd/tests/worktree-manager.test.ts +0 -141
  736. package/dist/resources/extensions/gsd/tests/worktree-post-create-hook.test.ts +0 -165
  737. package/dist/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +0 -206
  738. package/dist/resources/extensions/gsd/tests/worktree.test.ts +0 -171
  739. package/dist/resources/extensions/gsd/tests/write-gate.test.ts +0 -211
  740. package/dist/resources/extensions/gsd/token-counter.ts +0 -65
  741. package/dist/resources/extensions/gsd/triage-resolution.ts +0 -284
  742. package/dist/resources/extensions/gsd/triage-ui.ts +0 -175
  743. package/dist/resources/extensions/gsd/types.ts +0 -425
  744. package/dist/resources/extensions/gsd/undo.ts +0 -223
  745. package/dist/resources/extensions/gsd/unit-id.ts +0 -14
  746. package/dist/resources/extensions/gsd/unit-runtime.ts +0 -192
  747. package/dist/resources/extensions/gsd/validate-directory.ts +0 -164
  748. package/dist/resources/extensions/gsd/verification-evidence.ts +0 -188
  749. package/dist/resources/extensions/gsd/verification-gate.ts +0 -643
  750. package/dist/resources/extensions/gsd/visualizer-data.ts +0 -866
  751. package/dist/resources/extensions/gsd/visualizer-overlay.ts +0 -566
  752. package/dist/resources/extensions/gsd/visualizer-views.ts +0 -1171
  753. package/dist/resources/extensions/gsd/workflow-templates.ts +0 -241
  754. package/dist/resources/extensions/gsd/workspace-index.ts +0 -217
  755. package/dist/resources/extensions/gsd/worktree-command.ts +0 -807
  756. package/dist/resources/extensions/gsd/worktree-manager.ts +0 -449
  757. package/dist/resources/extensions/gsd/worktree.ts +0 -257
  758. package/dist/resources/extensions/mac-tools/index.ts +0 -852
  759. package/dist/resources/extensions/mcp-client/index.ts +0 -459
  760. package/dist/resources/extensions/remote-questions/config.ts +0 -83
  761. package/dist/resources/extensions/remote-questions/discord-adapter.ts +0 -148
  762. package/dist/resources/extensions/remote-questions/format.ts +0 -315
  763. package/dist/resources/extensions/remote-questions/http-client.ts +0 -76
  764. package/dist/resources/extensions/remote-questions/manager.ts +0 -184
  765. package/dist/resources/extensions/remote-questions/notify.ts +0 -90
  766. package/dist/resources/extensions/remote-questions/remote-command.ts +0 -457
  767. package/dist/resources/extensions/remote-questions/slack-adapter.ts +0 -141
  768. package/dist/resources/extensions/remote-questions/status.ts +0 -31
  769. package/dist/resources/extensions/remote-questions/store.ts +0 -81
  770. package/dist/resources/extensions/remote-questions/telegram-adapter.ts +0 -149
  771. package/dist/resources/extensions/remote-questions/types.ts +0 -102
  772. package/dist/resources/extensions/search-the-web/cache.ts +0 -78
  773. package/dist/resources/extensions/search-the-web/command-search-provider.ts +0 -101
  774. package/dist/resources/extensions/search-the-web/format.ts +0 -258
  775. package/dist/resources/extensions/search-the-web/http.ts +0 -238
  776. package/dist/resources/extensions/search-the-web/index.ts +0 -65
  777. package/dist/resources/extensions/search-the-web/native-search.ts +0 -193
  778. package/dist/resources/extensions/search-the-web/provider.ts +0 -148
  779. package/dist/resources/extensions/search-the-web/tavily.ts +0 -116
  780. package/dist/resources/extensions/search-the-web/tool-fetch-page.ts +0 -589
  781. package/dist/resources/extensions/search-the-web/tool-llm-context.ts +0 -608
  782. package/dist/resources/extensions/search-the-web/tool-search.ts +0 -649
  783. package/dist/resources/extensions/search-the-web/url-utils.ts +0 -125
  784. package/dist/resources/extensions/shared/confirm-ui.ts +0 -126
  785. package/dist/resources/extensions/shared/frontmatter.ts +0 -117
  786. package/dist/resources/extensions/shared/interview-ui.ts +0 -613
  787. package/dist/resources/extensions/shared/next-action-ui.ts +0 -212
  788. package/dist/resources/extensions/shared/sanitize.ts +0 -19
  789. package/dist/resources/extensions/shared/terminal.ts +0 -23
  790. package/dist/resources/extensions/shared/tests/format-utils.test.ts +0 -153
  791. package/dist/resources/extensions/shared/ui.ts +0 -400
  792. package/dist/resources/extensions/shared/wizard-ui.ts +0 -551
  793. package/dist/resources/extensions/slash-commands/audit.ts +0 -88
  794. package/dist/resources/extensions/slash-commands/clear.ts +0 -10
  795. package/dist/resources/extensions/slash-commands/create-extension.ts +0 -297
  796. package/dist/resources/extensions/slash-commands/create-slash-command.ts +0 -234
  797. package/dist/resources/extensions/slash-commands/index.ts +0 -12
  798. package/dist/resources/extensions/subagent/agents.ts +0 -126
  799. package/dist/resources/extensions/subagent/index.ts +0 -1121
  800. package/dist/resources/extensions/subagent/isolation.ts +0 -501
  801. package/dist/resources/extensions/subagent/worker-registry.ts +0 -99
  802. package/dist/resources/extensions/ttsr/index.ts +0 -168
  803. package/dist/resources/extensions/ttsr/rule-loader.ts +0 -74
  804. package/dist/resources/extensions/ttsr/ttsr-manager.ts +0 -456
  805. package/dist/resources/extensions/universal-config/discovery.ts +0 -104
  806. package/dist/resources/extensions/universal-config/format.ts +0 -191
  807. package/dist/resources/extensions/universal-config/index.ts +0 -120
  808. package/dist/resources/extensions/universal-config/scanners.ts +0 -642
  809. package/dist/resources/extensions/universal-config/tests/discovery.test.ts +0 -119
  810. package/dist/resources/extensions/universal-config/tests/format.test.ts +0 -127
  811. package/dist/resources/extensions/universal-config/tests/scanners.test.ts +0 -456
  812. package/dist/resources/extensions/universal-config/tools.ts +0 -60
  813. package/dist/resources/extensions/universal-config/types.ts +0 -135
  814. package/dist/resources/extensions/voice/index.ts +0 -272
  815. package/dist/resources/skills/create-gsd-extension/templates/extension-skeleton.ts +0 -51
  816. package/dist/resources/skills/create-gsd-extension/templates/stateful-tool-skeleton.ts +0 -143
  817. package/src/resources/extensions/gsd/auto-constants.ts +0 -6
  818. package/src/resources/extensions/gsd/auto-idempotency.ts +0 -151
  819. package/src/resources/extensions/gsd/auto-stuck-detection.ts +0 -221
  820. package/src/resources/extensions/gsd/mechanical-completion.ts +0 -430
  821. package/src/resources/extensions/gsd/tests/auto-dispatch-loop.test.ts +0 -691
  822. package/src/resources/extensions/gsd/tests/auto-reentrancy-guard.test.ts +0 -127
  823. package/src/resources/extensions/gsd/tests/auto-skip-loop.test.ts +0 -123
  824. package/src/resources/extensions/gsd/tests/dispatch-stall-guard.test.ts +0 -126
  825. package/src/resources/extensions/gsd/tests/loop-regression.test.ts +0 -877
  826. package/src/resources/extensions/gsd/tests/mechanical-completion.test.ts +0 -356
  827. package/src/resources/extensions/gsd/tests/progress-score.test.ts +0 -206
  828. package/src/resources/extensions/gsd/tests/session-lock.test.ts +0 -434
@@ -0,0 +1,956 @@
1
+ /**
2
+ * auto-loop.ts — Linear loop execution backbone for auto-mode.
3
+ *
4
+ * Replaces the recursive dispatchNextUnit → handleAgentEnd → dispatchNextUnit
5
+ * pattern with a while loop. The agent_end event resolves a promise instead
6
+ * of recursing.
7
+ *
8
+ * MAINTENANCE RULE: The only module-level mutable state here is `_activeSession`,
9
+ * used by the agent_end bridge. Promise state itself lives on AutoSession so
10
+ * concurrent auto sessions cannot corrupt each other.
11
+ */
12
+ import { NEW_SESSION_TIMEOUT_MS } from "./auto/session.js";
13
+ import { debugLog } from "./debug-logger.js";
14
+ /**
15
+ * Maximum total loop iterations before forced stop. Prevents runaway loops
16
+ * when units alternate IDs (bypassing the same-unit stuck detector).
17
+ * A milestone with 20 slices × 5 tasks × 3 phases ≈ 300 units. 500 gives
18
+ * generous headroom including retries and sidecar work.
19
+ */
20
+ const MAX_LOOP_ITERATIONS = 500;
21
+ // ─── Session-scoped promise state ───────────────────────────────────────────
22
+ //
23
+ // pendingResolve and pendingAgentEndQueue live on AutoSession (not module-level)
24
+ // so concurrent sessions cannot corrupt each other's promises.
25
+ /**
26
+ * The singleton session reference used by resolveAgentEnd. Set by autoLoop
27
+ * on entry so that the agent_end handler in index.ts can resolve the correct
28
+ * session's promise without needing a direct reference to `s`.
29
+ */
30
+ let _activeSession = null;
31
+ // ─── resolveAgentEnd ─────────────────────────────────────────────────────────
32
+ /**
33
+ * Called from the agent_end event handler in index.ts to resolve the
34
+ * in-flight unit promise. One-shot: the resolver is nulled before calling
35
+ * to prevent double-resolution from model fallback retries.
36
+ *
37
+ * If no pendingResolve exists (event arrived between loop iterations),
38
+ * the event is queued on the session so the next runUnit can drain it.
39
+ */
40
+ export function resolveAgentEnd(event) {
41
+ const s = _activeSession;
42
+ if (!s) {
43
+ debugLog("resolveAgentEnd", {
44
+ status: "no-active-session",
45
+ warning: "agent_end with no active loop session",
46
+ });
47
+ return;
48
+ }
49
+ if (s.pendingResolve) {
50
+ debugLog("resolveAgentEnd", { status: "resolving", hasEvent: true });
51
+ const r = s.pendingResolve;
52
+ s.pendingResolve = null;
53
+ r({ status: "completed", event });
54
+ }
55
+ else {
56
+ // Queue the event so the next runUnit picks it up immediately
57
+ debugLog("resolveAgentEnd", {
58
+ status: "queued",
59
+ queueLength: s.pendingAgentEndQueue.length + 1,
60
+ warning: "agent_end arrived between loop iterations — queued for next runUnit",
61
+ });
62
+ s.pendingAgentEndQueue.push(event);
63
+ }
64
+ }
65
+ export function isSessionSwitchInFlight() {
66
+ return _activeSession?.sessionSwitchInFlight ?? false;
67
+ }
68
+ // ─── resetPendingResolve (test helper) ───────────────────────────────────────
69
+ /**
70
+ * Reset session promise state. Only exported for test cleanup — production code
71
+ * should never call this.
72
+ */
73
+ export function _resetPendingResolve() {
74
+ if (_activeSession) {
75
+ _activeSession.pendingResolve = null;
76
+ _activeSession.pendingAgentEndQueue = [];
77
+ }
78
+ _activeSession = null;
79
+ }
80
+ /**
81
+ * Set the active session for resolveAgentEnd. Only exported for test setup —
82
+ * production code sets this via autoLoop entry.
83
+ */
84
+ export function _setActiveSession(session) {
85
+ _activeSession = session;
86
+ }
87
+ // ─── runUnit ─────────────────────────────────────────────────────────────────
88
+ /**
89
+ * Execute a single unit: create a new session, send the prompt, and await
90
+ * the agent_end promise. Returns a UnitResult describing what happened.
91
+ *
92
+ * The promise is one-shot: resolveAgentEnd() is the only way to resolve it.
93
+ * On session creation failure or timeout, returns { status: 'cancelled' }
94
+ * without awaiting the promise.
95
+ */
96
+ export async function runUnit(ctx, pi, s, unitType, unitId, prompt, _prefs) {
97
+ debugLog("runUnit", { phase: "start", unitType, unitId });
98
+ // ── Drain queued events from error-recovery retries ──
99
+ // If an agent_end arrived between iterations (e.g. from a model fallback
100
+ // sendMessage retry), consume it immediately instead of creating a new promise.
101
+ // Cap queue to 3 entries to prevent unbounded growth from stale events.
102
+ if (s.pendingAgentEndQueue.length > 3) {
103
+ debugLog("runUnit", {
104
+ phase: "queue-overflow",
105
+ dropped: s.pendingAgentEndQueue.length - 1,
106
+ unitType,
107
+ unitId,
108
+ });
109
+ s.pendingAgentEndQueue = [
110
+ s.pendingAgentEndQueue[s.pendingAgentEndQueue.length - 1],
111
+ ];
112
+ }
113
+ if (s.pendingAgentEndQueue.length > 0) {
114
+ const queued = s.pendingAgentEndQueue.shift();
115
+ debugLog("runUnit", {
116
+ phase: "drained-queued-event",
117
+ unitType,
118
+ unitId,
119
+ queueRemaining: s.pendingAgentEndQueue.length,
120
+ });
121
+ return { status: "completed", event: queued };
122
+ }
123
+ // ── Session creation with timeout ──
124
+ debugLog("runUnit", { phase: "session-create", unitType, unitId });
125
+ let sessionResult;
126
+ let sessionTimeoutHandle;
127
+ s.sessionSwitchInFlight = true;
128
+ try {
129
+ const sessionPromise = s.cmdCtx.newSession().finally(() => {
130
+ s.sessionSwitchInFlight = false;
131
+ });
132
+ const timeoutPromise = new Promise((resolve) => {
133
+ sessionTimeoutHandle = setTimeout(() => resolve({ cancelled: true }), NEW_SESSION_TIMEOUT_MS);
134
+ });
135
+ sessionResult = await Promise.race([sessionPromise, timeoutPromise]);
136
+ }
137
+ catch (sessionErr) {
138
+ if (sessionTimeoutHandle)
139
+ clearTimeout(sessionTimeoutHandle);
140
+ const msg = sessionErr instanceof Error ? sessionErr.message : String(sessionErr);
141
+ debugLog("runUnit", {
142
+ phase: "session-error",
143
+ unitType,
144
+ unitId,
145
+ error: msg,
146
+ });
147
+ return { status: "cancelled" };
148
+ }
149
+ if (sessionTimeoutHandle)
150
+ clearTimeout(sessionTimeoutHandle);
151
+ if (sessionResult.cancelled) {
152
+ debugLog("runUnit-session-timeout", { unitType, unitId });
153
+ return { status: "cancelled" };
154
+ }
155
+ if (!s.active) {
156
+ return { status: "cancelled" };
157
+ }
158
+ // ── Create the agent_end promise (session-scoped) ──
159
+ // This happens after newSession completes so session-switch agent_end events
160
+ // from the previous session cannot resolve the new unit.
161
+ const unitPromise = new Promise((resolve) => {
162
+ s.pendingResolve = resolve;
163
+ });
164
+ // ── Send the prompt ──
165
+ debugLog("runUnit", { phase: "send-message", unitType, unitId });
166
+ pi.sendMessage({ customType: "gsd-auto", content: prompt, display: s.verbose }, { triggerTurn: true });
167
+ // ── Await agent_end ──
168
+ debugLog("runUnit", { phase: "awaiting-agent-end", unitType, unitId });
169
+ const result = await unitPromise;
170
+ debugLog("runUnit", {
171
+ phase: "agent-end-received",
172
+ unitType,
173
+ unitId,
174
+ status: result.status,
175
+ });
176
+ return result;
177
+ }
178
+ // ─── autoLoop ────────────────────────────────────────────────────────────────
179
+ /**
180
+ * Main auto-mode execution loop. Iterates: derive → dispatch → guards →
181
+ * runUnit → finalize → repeat. Exits when s.active becomes false or a
182
+ * terminal condition is reached.
183
+ *
184
+ * This is the linear replacement for the recursive
185
+ * dispatchNextUnit → handleAgentEnd → dispatchNextUnit chain.
186
+ */
187
+ export async function autoLoop(ctx, pi, s, deps) {
188
+ debugLog("autoLoop", { phase: "enter" });
189
+ _activeSession = s;
190
+ let iteration = 0;
191
+ let lastDerivedUnit = "";
192
+ let sameUnitCount = 0;
193
+ let consecutiveErrors = 0;
194
+ while (s.active) {
195
+ iteration++;
196
+ debugLog("autoLoop", { phase: "loop-top", iteration });
197
+ if (iteration > MAX_LOOP_ITERATIONS) {
198
+ debugLog("autoLoop", {
199
+ phase: "exit",
200
+ reason: "max-iterations",
201
+ iteration,
202
+ });
203
+ await deps.stopAuto(ctx, pi, `Safety: loop exceeded ${MAX_LOOP_ITERATIONS} iterations — possible runaway`);
204
+ break;
205
+ }
206
+ if (!s.cmdCtx) {
207
+ debugLog("autoLoop", { phase: "exit", reason: "no-cmdCtx" });
208
+ break;
209
+ }
210
+ try {
211
+ // ── Blanket try/catch: one bad iteration must not kill the session
212
+ if (deps.lockBase() && !deps.validateSessionLock(deps.lockBase())) {
213
+ deps.handleLostSessionLock(ctx);
214
+ debugLog("autoLoop", { phase: "exit", reason: "session-lock-lost" });
215
+ break;
216
+ }
217
+ // ── Phase 1: Pre-dispatch ───────────────────────────────────────────
218
+ // Resource version guard
219
+ const staleMsg = deps.checkResourcesStale(s.resourceVersionOnStart);
220
+ if (staleMsg) {
221
+ await deps.stopAuto(ctx, pi, staleMsg);
222
+ debugLog("autoLoop", { phase: "exit", reason: "resources-stale" });
223
+ break;
224
+ }
225
+ deps.invalidateAllCaches();
226
+ s.lastPromptCharCount = undefined;
227
+ s.lastBaselineCharCount = undefined;
228
+ // Pre-dispatch health gate
229
+ try {
230
+ const healthGate = await deps.preDispatchHealthGate(s.basePath);
231
+ if (healthGate.fixesApplied.length > 0) {
232
+ ctx.ui.notify(`Pre-dispatch: ${healthGate.fixesApplied.join(", ")}`, "info");
233
+ }
234
+ if (!healthGate.proceed) {
235
+ ctx.ui.notify(healthGate.reason ?? "Pre-dispatch health check failed.", "error");
236
+ await deps.pauseAuto(ctx, pi);
237
+ debugLog("autoLoop", { phase: "exit", reason: "health-gate-failed" });
238
+ break;
239
+ }
240
+ }
241
+ catch {
242
+ // Non-fatal
243
+ }
244
+ // Sync project root artifacts into worktree
245
+ if (s.originalBasePath &&
246
+ s.basePath !== s.originalBasePath &&
247
+ s.currentMilestoneId) {
248
+ deps.syncProjectRootToWorktree(s.originalBasePath, s.basePath, s.currentMilestoneId);
249
+ }
250
+ // Derive state
251
+ let state = await deps.deriveState(s.basePath);
252
+ let mid = state.activeMilestone?.id;
253
+ let midTitle = state.activeMilestone?.title;
254
+ debugLog("autoLoop", {
255
+ phase: "state-derived",
256
+ iteration,
257
+ mid,
258
+ statePhase: state.phase,
259
+ });
260
+ // ── Milestone transition ────────────────────────────────────────────
261
+ if (mid && s.currentMilestoneId && mid !== s.currentMilestoneId) {
262
+ ctx.ui.notify(`Milestone ${s.currentMilestoneId} complete. Advancing to ${mid}: ${midTitle}.`, "info");
263
+ deps.sendDesktopNotification("GSD", `Milestone ${s.currentMilestoneId} complete!`, "success", "milestone");
264
+ const vizPrefs = deps.loadEffectiveGSDPreferences()?.preferences;
265
+ if (vizPrefs?.auto_visualize) {
266
+ ctx.ui.notify("Run /gsd visualize to see progress overview.", "info");
267
+ }
268
+ if (vizPrefs?.auto_report !== false) {
269
+ try {
270
+ const { loadVisualizerData } = await import("./visualizer-data.js");
271
+ const { generateHtmlReport } = await import("./export-html.js");
272
+ const { writeReportSnapshot } = await import("./reports.js");
273
+ const { basename } = await import("node:path");
274
+ const snapData = await loadVisualizerData(s.basePath);
275
+ const completedMs = snapData.milestones.find((m) => m.id === s.currentMilestoneId);
276
+ const msTitle = completedMs?.title ?? s.currentMilestoneId;
277
+ const gsdVersion = process.env.GSD_VERSION ?? "0.0.0";
278
+ const projName = basename(s.basePath);
279
+ const doneSlices = snapData.milestones.reduce((acc, m) => acc +
280
+ m.slices.filter((sl) => sl.done).length, 0);
281
+ const totalSlices = snapData.milestones.reduce((acc, m) => acc + m.slices.length, 0);
282
+ const outPath = writeReportSnapshot({
283
+ basePath: s.basePath,
284
+ html: generateHtmlReport(snapData, {
285
+ projectName: projName,
286
+ projectPath: s.basePath,
287
+ gsdVersion,
288
+ milestoneId: s.currentMilestoneId,
289
+ indexRelPath: "index.html",
290
+ }),
291
+ milestoneId: s.currentMilestoneId,
292
+ milestoneTitle: msTitle,
293
+ kind: "milestone",
294
+ projectName: projName,
295
+ projectPath: s.basePath,
296
+ gsdVersion,
297
+ totalCost: snapData.totals?.cost ?? 0,
298
+ totalTokens: snapData.totals?.tokens.total ?? 0,
299
+ totalDuration: snapData.totals?.duration ?? 0,
300
+ doneSlices,
301
+ totalSlices,
302
+ doneMilestones: snapData.milestones.filter((m) => m.status === "complete").length,
303
+ totalMilestones: snapData.milestones.length,
304
+ phase: snapData.phase,
305
+ });
306
+ ctx.ui.notify(`Report saved: .gsd/reports/${(await import("node:path")).basename(outPath)} — open index.html to browse progression.`, "info");
307
+ }
308
+ catch (err) {
309
+ ctx.ui.notify(`Report generation failed: ${err instanceof Error ? err.message : String(err)}`, "warning");
310
+ }
311
+ }
312
+ // Reset dispatch counters for new milestone
313
+ s.unitDispatchCount.clear();
314
+ s.unitRecoveryCount.clear();
315
+ s.unitLifetimeDispatches.clear();
316
+ lastDerivedUnit = "";
317
+ sameUnitCount = 0;
318
+ // Worktree lifecycle on milestone transition — merge current, enter next
319
+ deps.resolver.mergeAndExit(s.currentMilestoneId, ctx.ui);
320
+ deps.invalidateAllCaches();
321
+ state = await deps.deriveState(s.basePath);
322
+ mid = state.activeMilestone?.id;
323
+ midTitle = state.activeMilestone?.title;
324
+ if (mid) {
325
+ if (deps.getIsolationMode() !== "none") {
326
+ deps.captureIntegrationBranch(s.basePath, mid, {
327
+ commitDocs: deps.loadEffectiveGSDPreferences()?.preferences?.git
328
+ ?.commit_docs,
329
+ });
330
+ }
331
+ deps.resolver.enterMilestone(mid, ctx.ui);
332
+ }
333
+ else {
334
+ // mid is undefined — no milestone to capture integration branch for
335
+ }
336
+ const pendingIds = state.registry
337
+ .filter((m) => m.status !== "complete" && m.status !== "parked")
338
+ .map((m) => m.id);
339
+ deps.pruneQueueOrder(s.basePath, pendingIds);
340
+ }
341
+ if (mid) {
342
+ s.currentMilestoneId = mid;
343
+ deps.setActiveMilestoneId(s.basePath, mid);
344
+ }
345
+ // ── Terminal conditions ──────────────────────────────────────────────
346
+ if (!mid) {
347
+ if (s.currentUnit) {
348
+ await deps.closeoutUnit(ctx, s.basePath, s.currentUnit.type, s.currentUnit.id, s.currentUnit.startedAt, deps.buildSnapshotOpts(s.currentUnit.type, s.currentUnit.id));
349
+ }
350
+ const incomplete = state.registry.filter((m) => m.status !== "complete" && m.status !== "parked");
351
+ if (incomplete.length === 0) {
352
+ // All milestones complete — merge milestone branch before stopping
353
+ if (s.currentMilestoneId) {
354
+ deps.resolver.mergeAndExit(s.currentMilestoneId, ctx.ui);
355
+ }
356
+ deps.sendDesktopNotification("GSD", "All milestones complete!", "success", "milestone");
357
+ await deps.stopAuto(ctx, pi, "All milestones complete");
358
+ }
359
+ else if (state.phase === "blocked") {
360
+ const blockerMsg = `Blocked: ${state.blockers.join(", ")}`;
361
+ await deps.stopAuto(ctx, pi, blockerMsg);
362
+ ctx.ui.notify(`${blockerMsg}. Fix and run /gsd auto.`, "warning");
363
+ deps.sendDesktopNotification("GSD", blockerMsg, "error", "attention");
364
+ }
365
+ else {
366
+ const ids = incomplete.map((m) => m.id).join(", ");
367
+ const diag = `basePath=${s.basePath}, milestones=[${state.registry.map((m) => `${m.id}:${m.status}`).join(", ")}], phase=${state.phase}`;
368
+ ctx.ui.notify(`Unexpected: ${incomplete.length} incomplete milestone(s) (${ids}) but no active milestone.\n Diagnostic: ${diag}`, "error");
369
+ await deps.stopAuto(ctx, pi, `No active milestone — ${incomplete.length} incomplete (${ids}), see diagnostic above`);
370
+ }
371
+ debugLog("autoLoop", { phase: "exit", reason: "no-active-milestone" });
372
+ break;
373
+ }
374
+ if (!midTitle) {
375
+ midTitle = mid;
376
+ ctx.ui.notify(`Milestone ${mid} has no title in roadmap — using ID as fallback.`, "warning");
377
+ }
378
+ // Mid-merge safety check
379
+ if (deps.reconcileMergeState(s.basePath, ctx)) {
380
+ deps.invalidateAllCaches();
381
+ state = await deps.deriveState(s.basePath);
382
+ mid = state.activeMilestone?.id;
383
+ midTitle = state.activeMilestone?.title;
384
+ }
385
+ if (!mid || !midTitle) {
386
+ if (s.currentUnit) {
387
+ await deps.closeoutUnit(ctx, s.basePath, s.currentUnit.type, s.currentUnit.id, s.currentUnit.startedAt, deps.buildSnapshotOpts(s.currentUnit.type, s.currentUnit.id));
388
+ }
389
+ const noMilestoneReason = !mid
390
+ ? "No active milestone after merge reconciliation"
391
+ : `Milestone ${mid} has no title after reconciliation`;
392
+ await deps.stopAuto(ctx, pi, noMilestoneReason);
393
+ debugLog("autoLoop", {
394
+ phase: "exit",
395
+ reason: "no-milestone-after-reconciliation",
396
+ });
397
+ break;
398
+ }
399
+ // Terminal: complete
400
+ if (state.phase === "complete") {
401
+ if (s.currentUnit) {
402
+ await deps.closeoutUnit(ctx, s.basePath, s.currentUnit.type, s.currentUnit.id, s.currentUnit.startedAt, deps.buildSnapshotOpts(s.currentUnit.type, s.currentUnit.id));
403
+ }
404
+ // Milestone merge on complete
405
+ if (s.currentMilestoneId) {
406
+ deps.resolver.mergeAndExit(s.currentMilestoneId, ctx.ui);
407
+ }
408
+ deps.sendDesktopNotification("GSD", `Milestone ${mid} complete!`, "success", "milestone");
409
+ await deps.stopAuto(ctx, pi, `Milestone ${mid} complete`);
410
+ debugLog("autoLoop", { phase: "exit", reason: "milestone-complete" });
411
+ break;
412
+ }
413
+ // Terminal: blocked
414
+ if (state.phase === "blocked") {
415
+ if (s.currentUnit) {
416
+ await deps.closeoutUnit(ctx, s.basePath, s.currentUnit.type, s.currentUnit.id, s.currentUnit.startedAt, deps.buildSnapshotOpts(s.currentUnit.type, s.currentUnit.id));
417
+ }
418
+ const blockerMsg = `Blocked: ${state.blockers.join(", ")}`;
419
+ await deps.stopAuto(ctx, pi, blockerMsg);
420
+ ctx.ui.notify(`${blockerMsg}. Fix and run /gsd auto.`, "warning");
421
+ deps.sendDesktopNotification("GSD", blockerMsg, "error", "attention");
422
+ debugLog("autoLoop", { phase: "exit", reason: "blocked" });
423
+ break;
424
+ }
425
+ // ── Phase 2: Guards ─────────────────────────────────────────────────
426
+ const prefs = deps.loadEffectiveGSDPreferences()?.preferences;
427
+ // Budget ceiling guard
428
+ const budgetCeiling = prefs?.budget_ceiling;
429
+ if (budgetCeiling !== undefined && budgetCeiling > 0) {
430
+ const currentLedger = deps.getLedger();
431
+ const totalCost = currentLedger
432
+ ? deps.getProjectTotals(currentLedger.units).cost
433
+ : 0;
434
+ const budgetPct = totalCost / budgetCeiling;
435
+ const budgetAlertLevel = deps.getBudgetAlertLevel(budgetPct);
436
+ const newBudgetAlertLevel = deps.getNewBudgetAlertLevel(s.lastBudgetAlertLevel, budgetPct);
437
+ const enforcement = prefs?.budget_enforcement ?? "pause";
438
+ const budgetEnforcementAction = deps.getBudgetEnforcementAction(enforcement, budgetPct);
439
+ if (newBudgetAlertLevel === 100 && budgetEnforcementAction !== "none") {
440
+ const msg = `Budget ceiling ${deps.formatCost(budgetCeiling)} reached (spent ${deps.formatCost(totalCost)}).`;
441
+ s.lastBudgetAlertLevel =
442
+ newBudgetAlertLevel;
443
+ if (budgetEnforcementAction === "halt") {
444
+ deps.sendDesktopNotification("GSD", msg, "error", "budget");
445
+ await deps.stopAuto(ctx, pi, "Budget ceiling reached");
446
+ debugLog("autoLoop", { phase: "exit", reason: "budget-halt" });
447
+ break;
448
+ }
449
+ if (budgetEnforcementAction === "pause") {
450
+ ctx.ui.notify(`${msg} Pausing auto-mode — /gsd auto to override and continue.`, "warning");
451
+ deps.sendDesktopNotification("GSD", msg, "warning", "budget");
452
+ await deps.pauseAuto(ctx, pi);
453
+ debugLog("autoLoop", { phase: "exit", reason: "budget-pause" });
454
+ break;
455
+ }
456
+ ctx.ui.notify(`${msg} Continuing (enforcement: warn).`, "warning");
457
+ deps.sendDesktopNotification("GSD", msg, "warning", "budget");
458
+ }
459
+ else if (newBudgetAlertLevel === 90) {
460
+ s.lastBudgetAlertLevel =
461
+ newBudgetAlertLevel;
462
+ ctx.ui.notify(`Budget 90%: ${deps.formatCost(totalCost)} / ${deps.formatCost(budgetCeiling)}`, "warning");
463
+ deps.sendDesktopNotification("GSD", `Budget 90%: ${deps.formatCost(totalCost)} / ${deps.formatCost(budgetCeiling)}`, "warning", "budget");
464
+ }
465
+ else if (newBudgetAlertLevel === 80) {
466
+ s.lastBudgetAlertLevel =
467
+ newBudgetAlertLevel;
468
+ ctx.ui.notify(`Approaching budget ceiling — 80%: ${deps.formatCost(totalCost)} / ${deps.formatCost(budgetCeiling)}`, "warning");
469
+ deps.sendDesktopNotification("GSD", `Approaching budget ceiling — 80%: ${deps.formatCost(totalCost)} / ${deps.formatCost(budgetCeiling)}`, "warning", "budget");
470
+ }
471
+ else if (newBudgetAlertLevel === 75) {
472
+ s.lastBudgetAlertLevel =
473
+ newBudgetAlertLevel;
474
+ ctx.ui.notify(`Budget 75%: ${deps.formatCost(totalCost)} / ${deps.formatCost(budgetCeiling)}`, "info");
475
+ deps.sendDesktopNotification("GSD", `Budget 75%: ${deps.formatCost(totalCost)} / ${deps.formatCost(budgetCeiling)}`, "info", "budget");
476
+ }
477
+ else if (budgetAlertLevel === 0) {
478
+ s.lastBudgetAlertLevel = 0;
479
+ }
480
+ }
481
+ else {
482
+ s.lastBudgetAlertLevel = 0;
483
+ }
484
+ // Context window guard
485
+ const contextThreshold = prefs?.context_pause_threshold ?? 0;
486
+ if (contextThreshold > 0 && s.cmdCtx) {
487
+ const contextUsage = s.cmdCtx.getContextUsage();
488
+ if (contextUsage &&
489
+ contextUsage.percent !== null &&
490
+ contextUsage.percent >= contextThreshold) {
491
+ const msg = `Context window at ${contextUsage.percent}% (threshold: ${contextThreshold}%). Pausing to prevent truncated output.`;
492
+ ctx.ui.notify(`${msg} Run /gsd auto to continue (will start fresh session).`, "warning");
493
+ deps.sendDesktopNotification("GSD", `Context ${contextUsage.percent}% — paused`, "warning", "attention");
494
+ await deps.pauseAuto(ctx, pi);
495
+ debugLog("autoLoop", { phase: "exit", reason: "context-window" });
496
+ break;
497
+ }
498
+ }
499
+ // Secrets re-check gate
500
+ try {
501
+ const manifestStatus = await deps.getManifestStatus(s.basePath, mid);
502
+ if (manifestStatus && manifestStatus.pending.length > 0) {
503
+ const result = await deps.collectSecretsFromManifest(s.basePath, mid, ctx);
504
+ if (result &&
505
+ result.applied &&
506
+ result.skipped &&
507
+ result.existingSkipped) {
508
+ ctx.ui.notify(`Secrets collected: ${result.applied.length} applied, ${result.skipped.length} skipped, ${result.existingSkipped.length} already set.`, "info");
509
+ }
510
+ else {
511
+ ctx.ui.notify("Secrets collection skipped.", "info");
512
+ }
513
+ }
514
+ }
515
+ catch (err) {
516
+ ctx.ui.notify(`Secrets collection error: ${err instanceof Error ? err.message : String(err)}. Continuing with next task.`, "warning");
517
+ }
518
+ // ── Phase 3: Dispatch resolution ────────────────────────────────────
519
+ debugLog("autoLoop", { phase: "dispatch-resolve", iteration });
520
+ const dispatchResult = await deps.resolveDispatch({
521
+ basePath: s.basePath,
522
+ mid,
523
+ midTitle: midTitle,
524
+ state,
525
+ prefs,
526
+ });
527
+ if (dispatchResult.action === "stop") {
528
+ if (s.currentUnit) {
529
+ await deps.closeoutUnit(ctx, s.basePath, s.currentUnit.type, s.currentUnit.id, s.currentUnit.startedAt, deps.buildSnapshotOpts(s.currentUnit.type, s.currentUnit.id));
530
+ }
531
+ await deps.stopAuto(ctx, pi, dispatchResult.reason);
532
+ debugLog("autoLoop", { phase: "exit", reason: "dispatch-stop" });
533
+ break;
534
+ }
535
+ if (dispatchResult.action !== "dispatch") {
536
+ // Non-dispatch action (e.g. "skip") — re-derive state
537
+ await new Promise((r) => setImmediate(r));
538
+ continue;
539
+ }
540
+ let unitType = dispatchResult.unitType;
541
+ let unitId = dispatchResult.unitId;
542
+ let prompt = dispatchResult.prompt;
543
+ const pauseAfterUatDispatch = dispatchResult.pauseAfterDispatch ?? false;
544
+ // ── Same-unit stuck counter with graduated recovery ──
545
+ const derivedKey = `${unitType}/${unitId}`;
546
+ if (derivedKey === lastDerivedUnit && !s.pendingVerificationRetry) {
547
+ sameUnitCount++;
548
+ debugLog("autoLoop", {
549
+ phase: "stuck-check",
550
+ unitType,
551
+ unitId,
552
+ sameUnitCount,
553
+ });
554
+ if (sameUnitCount === 3) {
555
+ // Level 1: try verifying the artifact — maybe it was written but not detected
556
+ const artifactExists = deps.verifyExpectedArtifact(unitType, unitId, s.basePath);
557
+ if (artifactExists) {
558
+ debugLog("autoLoop", {
559
+ phase: "stuck-recovery",
560
+ level: 1,
561
+ action: "artifact-found",
562
+ });
563
+ ctx.ui.notify(`Stuck recovery: artifact for ${unitType} ${unitId} found on disk. Invalidating caches.`, "info");
564
+ deps.invalidateAllCaches();
565
+ continue;
566
+ }
567
+ ctx.ui.notify(`Stuck on ${unitType} ${unitId} (attempt ${sameUnitCount}). Invalidating caches and retrying.`, "warning");
568
+ deps.invalidateAllCaches();
569
+ }
570
+ else if (sameUnitCount === 5) {
571
+ // Level 2: hard stop — genuinely stuck
572
+ debugLog("autoLoop", {
573
+ phase: "stuck-detected",
574
+ unitType,
575
+ unitId,
576
+ sameUnitCount,
577
+ });
578
+ await deps.stopAuto(ctx, pi, `Stuck: ${unitType} ${unitId} derived ${sameUnitCount} consecutive times without progress`);
579
+ ctx.ui.notify(`Stuck on ${unitType} ${unitId} — deriveState returns the same unit after ${sameUnitCount} attempts. The expected artifact was not written.`, "error");
580
+ break;
581
+ }
582
+ }
583
+ else {
584
+ if (derivedKey !== lastDerivedUnit) {
585
+ debugLog("autoLoop", {
586
+ phase: "stuck-counter-reset",
587
+ from: lastDerivedUnit,
588
+ to: derivedKey,
589
+ });
590
+ }
591
+ lastDerivedUnit = derivedKey;
592
+ sameUnitCount = 0;
593
+ }
594
+ // Pre-dispatch hooks
595
+ const preDispatchResult = deps.runPreDispatchHooks(unitType, unitId, prompt, s.basePath);
596
+ if (preDispatchResult.firedHooks.length > 0) {
597
+ ctx.ui.notify(`Pre-dispatch hook${preDispatchResult.firedHooks.length > 1 ? "s" : ""}: ${preDispatchResult.firedHooks.join(", ")}`, "info");
598
+ }
599
+ if (preDispatchResult.action === "skip") {
600
+ ctx.ui.notify(`Skipping ${unitType} ${unitId} (pre-dispatch hook).`, "info");
601
+ await new Promise((r) => setImmediate(r));
602
+ continue;
603
+ }
604
+ if (preDispatchResult.action === "replace") {
605
+ prompt = preDispatchResult.prompt ?? prompt;
606
+ if (preDispatchResult.unitType)
607
+ unitType = preDispatchResult.unitType;
608
+ }
609
+ else if (preDispatchResult.prompt) {
610
+ prompt = preDispatchResult.prompt;
611
+ }
612
+ const priorSliceBlocker = deps.getPriorSliceCompletionBlocker(s.basePath, deps.getMainBranch(s.basePath), unitType, unitId);
613
+ if (priorSliceBlocker) {
614
+ await deps.stopAuto(ctx, pi, priorSliceBlocker);
615
+ debugLog("autoLoop", { phase: "exit", reason: "prior-slice-blocker" });
616
+ break;
617
+ }
618
+ const observabilityIssues = await deps.collectObservabilityWarnings(ctx, s.basePath, unitType, unitId);
619
+ // ── Phase 4: Unit execution ─────────────────────────────────────────
620
+ debugLog("autoLoop", {
621
+ phase: "unit-execution",
622
+ iteration,
623
+ unitType,
624
+ unitId,
625
+ });
626
+ // Closeout previous unit
627
+ if (s.currentUnit) {
628
+ await deps.closeoutUnit(ctx, s.basePath, s.currentUnit.type, s.currentUnit.id, s.currentUnit.startedAt, deps.buildSnapshotOpts(s.currentUnit.type, s.currentUnit.id));
629
+ if (s.currentUnitRouting) {
630
+ const isRetry = s.currentUnit.type === unitType && s.currentUnit.id === unitId;
631
+ deps.recordOutcome(s.currentUnit.type, s.currentUnitRouting.tier, !isRetry);
632
+ }
633
+ const closeoutKey = `${s.currentUnit.type}/${s.currentUnit.id}`;
634
+ const incomingKey = `${unitType}/${unitId}`;
635
+ const isHookUnit = s.currentUnit.type.startsWith("hook/");
636
+ const artifactVerified = isHookUnit ||
637
+ deps.verifyExpectedArtifact(s.currentUnit.type, s.currentUnit.id, s.basePath);
638
+ if (closeoutKey !== incomingKey && artifactVerified) {
639
+ s.completedUnits.push({
640
+ type: s.currentUnit.type,
641
+ id: s.currentUnit.id,
642
+ startedAt: s.currentUnit.startedAt,
643
+ finishedAt: Date.now(),
644
+ });
645
+ if (s.completedUnits.length > 200) {
646
+ s.completedUnits = s.completedUnits.slice(-200);
647
+ }
648
+ deps.clearUnitRuntimeRecord(s.basePath, s.currentUnit.type, s.currentUnit.id);
649
+ s.unitDispatchCount.delete(`${s.currentUnit.type}/${s.currentUnit.id}`);
650
+ s.unitRecoveryCount.delete(`${s.currentUnit.type}/${s.currentUnit.id}`);
651
+ }
652
+ }
653
+ s.currentUnit = { type: unitType, id: unitId, startedAt: Date.now() };
654
+ deps.captureAvailableSkills();
655
+ deps.writeUnitRuntimeRecord(s.basePath, unitType, unitId, s.currentUnit.startedAt, {
656
+ phase: "dispatched",
657
+ wrapupWarningSent: false,
658
+ timeoutAt: null,
659
+ lastProgressAt: s.currentUnit.startedAt,
660
+ progressCount: 0,
661
+ lastProgressKind: "dispatch",
662
+ });
663
+ // Status bar + progress widget
664
+ ctx.ui.setStatus("gsd-auto", "auto");
665
+ if (mid)
666
+ deps.updateSliceProgressCache(s.basePath, mid, state.activeSlice?.id);
667
+ deps.updateProgressWidget(ctx, unitType, unitId, state);
668
+ deps.ensurePreconditions(unitType, unitId, s.basePath, state);
669
+ // Prompt injection
670
+ const MAX_RECOVERY_CHARS = 50_000;
671
+ let finalPrompt = prompt;
672
+ if (s.pendingVerificationRetry) {
673
+ const retryCtx = s.pendingVerificationRetry;
674
+ s.pendingVerificationRetry = null;
675
+ const capped = retryCtx.failureContext.length > MAX_RECOVERY_CHARS
676
+ ? retryCtx.failureContext.slice(0, MAX_RECOVERY_CHARS) +
677
+ "\n\n[...failure context truncated]"
678
+ : retryCtx.failureContext;
679
+ finalPrompt = `**VERIFICATION FAILED — AUTO-FIX ATTEMPT ${retryCtx.attempt}**\n\nThe verification gate ran after your previous attempt and found failures. Fix these issues before completing the task.\n\n${capped}\n\n---\n\n${finalPrompt}`;
680
+ }
681
+ if (s.pendingCrashRecovery) {
682
+ const capped = s.pendingCrashRecovery.length > MAX_RECOVERY_CHARS
683
+ ? s.pendingCrashRecovery.slice(0, MAX_RECOVERY_CHARS) +
684
+ "\n\n[...recovery briefing truncated to prevent memory exhaustion]"
685
+ : s.pendingCrashRecovery;
686
+ finalPrompt = `${capped}\n\n---\n\n${finalPrompt}`;
687
+ s.pendingCrashRecovery = null;
688
+ }
689
+ else if ((s.unitDispatchCount.get(`${unitType}/${unitId}`) ?? 0) > 1) {
690
+ const diagnostic = deps.getDeepDiagnostic(s.basePath);
691
+ if (diagnostic) {
692
+ const cappedDiag = diagnostic.length > MAX_RECOVERY_CHARS
693
+ ? diagnostic.slice(0, MAX_RECOVERY_CHARS) +
694
+ "\n\n[...diagnostic truncated to prevent memory exhaustion]"
695
+ : diagnostic;
696
+ finalPrompt = `**RETRY — your previous attempt did not produce the required artifact.**\n\nDiagnostic from previous attempt:\n${cappedDiag}\n\nFix whatever went wrong and make sure you write the required file this time.\n\n---\n\n${finalPrompt}`;
697
+ }
698
+ }
699
+ const repairBlock = deps.buildObservabilityRepairBlock(observabilityIssues);
700
+ if (repairBlock) {
701
+ finalPrompt = `${finalPrompt}${repairBlock}`;
702
+ }
703
+ // Prompt char measurement
704
+ s.lastPromptCharCount = finalPrompt.length;
705
+ s.lastBaselineCharCount = undefined;
706
+ if (deps.isDbAvailable()) {
707
+ try {
708
+ const { inlineGsdRootFile } = await import("./auto-prompts.js");
709
+ const [decisionsContent, requirementsContent, projectContent] = await Promise.all([
710
+ inlineGsdRootFile(s.basePath, "decisions.md", "Decisions"),
711
+ inlineGsdRootFile(s.basePath, "requirements.md", "Requirements"),
712
+ inlineGsdRootFile(s.basePath, "project.md", "Project"),
713
+ ]);
714
+ s.lastBaselineCharCount =
715
+ (decisionsContent?.length ?? 0) +
716
+ (requirementsContent?.length ?? 0) +
717
+ (projectContent?.length ?? 0);
718
+ }
719
+ catch {
720
+ // Non-fatal
721
+ }
722
+ }
723
+ // Cache-optimize prompt section ordering
724
+ try {
725
+ finalPrompt = deps.reorderForCaching(finalPrompt);
726
+ }
727
+ catch (reorderErr) {
728
+ const msg = reorderErr instanceof Error ? reorderErr.message : String(reorderErr);
729
+ process.stderr.write(`[gsd] prompt reorder failed (non-fatal): ${msg}\n`);
730
+ }
731
+ // Select and apply model
732
+ const modelResult = await deps.selectAndApplyModel(ctx, pi, unitType, unitId, s.basePath, prefs, s.verbose, s.autoModeStartModel);
733
+ s.currentUnitRouting =
734
+ modelResult.routing;
735
+ // Start unit supervision
736
+ deps.clearUnitTimeout();
737
+ deps.startUnitSupervision({
738
+ s,
739
+ ctx,
740
+ pi,
741
+ unitType,
742
+ unitId,
743
+ prefs,
744
+ buildSnapshotOpts: () => deps.buildSnapshotOpts(unitType, unitId),
745
+ buildRecoveryContext: () => ({}),
746
+ pauseAuto: deps.pauseAuto,
747
+ });
748
+ // Session + send + await
749
+ const sessionFile = deps.getSessionFile(ctx);
750
+ deps.updateSessionLock(deps.lockBase(), unitType, unitId, s.completedUnits.length, sessionFile);
751
+ deps.writeLock(deps.lockBase(), unitType, unitId, s.completedUnits.length, sessionFile);
752
+ debugLog("autoLoop", {
753
+ phase: "runUnit-start",
754
+ iteration,
755
+ unitType,
756
+ unitId,
757
+ });
758
+ const unitResult = await runUnit(ctx, pi, s, unitType, unitId, finalPrompt, prefs);
759
+ debugLog("autoLoop", {
760
+ phase: "runUnit-end",
761
+ iteration,
762
+ unitType,
763
+ unitId,
764
+ status: unitResult.status,
765
+ });
766
+ if (unitResult.status === "cancelled") {
767
+ ctx.ui.notify(`Session creation timed out or was cancelled for ${unitType} ${unitId}. Will retry.`, "warning");
768
+ await deps.stopAuto(ctx, pi, "Session creation failed");
769
+ debugLog("autoLoop", { phase: "exit", reason: "session-failed" });
770
+ break;
771
+ }
772
+ // ── Phase 5: Finalize ───────────────────────────────────────────────
773
+ debugLog("autoLoop", { phase: "finalize", iteration });
774
+ // Clear unit timeout (unit completed)
775
+ deps.clearUnitTimeout();
776
+ // Post-unit context for pre/post verification
777
+ const postUnitCtx = {
778
+ s,
779
+ ctx,
780
+ pi,
781
+ buildSnapshotOpts: deps.buildSnapshotOpts,
782
+ lockBase: deps.lockBase,
783
+ stopAuto: deps.stopAuto,
784
+ pauseAuto: deps.pauseAuto,
785
+ updateProgressWidget: deps.updateProgressWidget,
786
+ };
787
+ // Pre-verification processing (commit, doctor, state rebuild, etc.)
788
+ const preResult = await deps.postUnitPreVerification(postUnitCtx);
789
+ if (preResult === "dispatched") {
790
+ debugLog("autoLoop", {
791
+ phase: "exit",
792
+ reason: "pre-verification-dispatched",
793
+ });
794
+ break;
795
+ }
796
+ if (pauseAfterUatDispatch) {
797
+ ctx.ui.notify("UAT requires human execution. Auto-mode will pause after this unit writes the result file.", "info");
798
+ await deps.pauseAuto(ctx, pi);
799
+ debugLog("autoLoop", { phase: "exit", reason: "uat-pause" });
800
+ break;
801
+ }
802
+ // Verification gate — the loop handles retries via s.pendingVerificationRetry
803
+ const verificationResult = await deps.runPostUnitVerification({ s, ctx, pi }, deps.pauseAuto);
804
+ if (verificationResult === "pause") {
805
+ debugLog("autoLoop", { phase: "exit", reason: "verification-pause" });
806
+ break;
807
+ }
808
+ if (verificationResult === "retry") {
809
+ // s.pendingVerificationRetry was set by runPostUnitVerification.
810
+ // Continue the loop — next iteration will inject the retry context into the prompt.
811
+ debugLog("autoLoop", { phase: "verification-retry", iteration });
812
+ continue;
813
+ }
814
+ // Post-verification processing (DB dual-write, hooks, triage, quick-tasks)
815
+ const postResult = await deps.postUnitPostVerification(postUnitCtx);
816
+ if (postResult === "stopped") {
817
+ debugLog("autoLoop", {
818
+ phase: "exit",
819
+ reason: "post-verification-stopped",
820
+ });
821
+ break;
822
+ }
823
+ if (postResult === "step-wizard") {
824
+ // Step mode — exit the loop (caller handles wizard)
825
+ debugLog("autoLoop", { phase: "exit", reason: "step-wizard" });
826
+ break;
827
+ }
828
+ // ── Sidecar drain: dispatch enqueued hooks/triage/quick-tasks ──
829
+ let sidecarBroke = false;
830
+ while (s.sidecarQueue.length > 0 && s.active) {
831
+ const item = s.sidecarQueue.shift();
832
+ debugLog("autoLoop", {
833
+ phase: "sidecar-dequeue",
834
+ kind: item.kind,
835
+ unitType: item.unitType,
836
+ unitId: item.unitId,
837
+ });
838
+ // Set up as current unit
839
+ const sidecarStartedAt = Date.now();
840
+ s.currentUnit = {
841
+ type: item.unitType,
842
+ id: item.unitId,
843
+ startedAt: sidecarStartedAt,
844
+ };
845
+ deps.writeUnitRuntimeRecord(s.basePath, item.unitType, item.unitId, sidecarStartedAt, {
846
+ phase: "dispatched",
847
+ wrapupWarningSent: false,
848
+ timeoutAt: null,
849
+ lastProgressAt: sidecarStartedAt,
850
+ progressCount: 0,
851
+ lastProgressKind: "dispatch",
852
+ });
853
+ // Model selection (handles hook model override)
854
+ await deps.selectAndApplyModel(ctx, pi, item.unitType, item.unitId, s.basePath, prefs, s.verbose, s.autoModeStartModel);
855
+ // Supervision
856
+ deps.clearUnitTimeout();
857
+ deps.startUnitSupervision({
858
+ s,
859
+ ctx,
860
+ pi,
861
+ unitType: item.unitType,
862
+ unitId: item.unitId,
863
+ prefs,
864
+ buildSnapshotOpts: () => deps.buildSnapshotOpts(item.unitType, item.unitId),
865
+ buildRecoveryContext: () => ({}),
866
+ pauseAuto: deps.pauseAuto,
867
+ });
868
+ // Write lock
869
+ const sidecarSessionFile = deps.getSessionFile(ctx);
870
+ deps.writeLock(deps.lockBase(), item.unitType, item.unitId, s.completedUnits.length, sidecarSessionFile);
871
+ // Execute via standard runUnit
872
+ const sidecarResult = await runUnit(ctx, pi, s, item.unitType, item.unitId, item.prompt, prefs);
873
+ deps.clearUnitTimeout();
874
+ if (sidecarResult.status === "cancelled") {
875
+ ctx.ui.notify(`Sidecar unit ${item.unitType} ${item.unitId} session cancelled. Stopping.`, "warning");
876
+ await deps.stopAuto(ctx, pi, "Sidecar session creation failed");
877
+ sidecarBroke = true;
878
+ break;
879
+ }
880
+ // Run pre-verification for the sidecar unit
881
+ const sidecarPreResult = await deps.postUnitPreVerification(postUnitCtx);
882
+ if (sidecarPreResult === "dispatched") {
883
+ // Pre-verification caused stop/pause
884
+ debugLog("autoLoop", {
885
+ phase: "exit",
886
+ reason: "sidecar-pre-verification-stop",
887
+ });
888
+ sidecarBroke = true;
889
+ break;
890
+ }
891
+ // Verification gate for non-hook sidecar units (triage, quick-tasks)
892
+ // Hook units are lightweight and don't need verification.
893
+ if (item.kind !== "hook") {
894
+ const sidecarVerification = await deps.runPostUnitVerification({ s, ctx, pi }, deps.pauseAuto);
895
+ if (sidecarVerification === "pause") {
896
+ debugLog("autoLoop", {
897
+ phase: "exit",
898
+ reason: "sidecar-verification-pause",
899
+ });
900
+ sidecarBroke = true;
901
+ break;
902
+ }
903
+ // "retry" for sidecars — skip retry, just continue (sidecar retries are not worth the complexity)
904
+ }
905
+ // Post-verification (may enqueue more sidecar items)
906
+ const sidecarPostResult = await deps.postUnitPostVerification(postUnitCtx);
907
+ if (sidecarPostResult === "stopped") {
908
+ debugLog("autoLoop", { phase: "exit", reason: "sidecar-stopped" });
909
+ sidecarBroke = true;
910
+ break;
911
+ }
912
+ if (sidecarPostResult === "step-wizard") {
913
+ debugLog("autoLoop", {
914
+ phase: "exit",
915
+ reason: "sidecar-step-wizard",
916
+ });
917
+ sidecarBroke = true;
918
+ break;
919
+ }
920
+ // "continue" — loop checks sidecarQueue again
921
+ }
922
+ if (sidecarBroke)
923
+ break;
924
+ consecutiveErrors = 0; // Iteration completed successfully
925
+ debugLog("autoLoop", { phase: "iteration-complete", iteration });
926
+ }
927
+ catch (loopErr) {
928
+ // ── Blanket catch: absorb unexpected exceptions, apply graduated recovery ──
929
+ consecutiveErrors++;
930
+ const msg = loopErr instanceof Error ? loopErr.message : String(loopErr);
931
+ debugLog("autoLoop", {
932
+ phase: "iteration-error",
933
+ iteration,
934
+ consecutiveErrors,
935
+ error: msg,
936
+ });
937
+ if (consecutiveErrors >= 3) {
938
+ // 3+ consecutive: hard stop — something is fundamentally broken
939
+ ctx.ui.notify(`Auto-mode stopped: ${consecutiveErrors} consecutive iteration failures. Last: ${msg}`, "error");
940
+ await deps.stopAuto(ctx, pi, `${consecutiveErrors} consecutive iteration failures`);
941
+ break;
942
+ }
943
+ else if (consecutiveErrors === 2) {
944
+ // 2nd consecutive: try invalidating caches + re-deriving state
945
+ ctx.ui.notify(`Iteration error (attempt ${consecutiveErrors}): ${msg}. Invalidating caches and retrying.`, "warning");
946
+ deps.invalidateAllCaches();
947
+ }
948
+ else {
949
+ // 1st error: log and retry — transient failures happen
950
+ ctx.ui.notify(`Iteration error: ${msg}. Retrying.`, "warning");
951
+ }
952
+ }
953
+ }
954
+ _activeSession = null;
955
+ debugLog("autoLoop", { phase: "exit", totalIterations: iteration });
956
+ }