gsd-pi 2.43.0 → 2.44.0-dev.62b5d6c

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (568) hide show
  1. package/dist/cli.js +13 -1
  2. package/dist/help-text.js +24 -0
  3. package/dist/resources/extensions/bg-shell/overlay.js +3 -0
  4. package/dist/resources/extensions/github-sync/sync.js +2 -1
  5. package/dist/resources/extensions/gsd/auto/loop.js +0 -2
  6. package/dist/resources/extensions/gsd/auto/phases.js +7 -12
  7. package/dist/resources/extensions/gsd/auto-dashboard.js +19 -18
  8. package/dist/resources/extensions/gsd/auto-direct-dispatch.js +34 -19
  9. package/dist/resources/extensions/gsd/auto-dispatch.js +36 -21
  10. package/dist/resources/extensions/gsd/auto-post-unit.js +128 -14
  11. package/dist/resources/extensions/gsd/auto-prompts.js +202 -92
  12. package/dist/resources/extensions/gsd/auto-recovery.js +83 -135
  13. package/dist/resources/extensions/gsd/auto-supervisor.js +14 -0
  14. package/dist/resources/extensions/gsd/auto-timeout-recovery.js +4 -7
  15. package/dist/resources/extensions/gsd/auto-verification.js +5 -10
  16. package/dist/resources/extensions/gsd/auto-worktree.js +123 -30
  17. package/dist/resources/extensions/gsd/auto.js +1 -4
  18. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +611 -0
  19. package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +28 -3
  20. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +7 -0
  21. package/dist/resources/extensions/gsd/commands/catalog.js +3 -1
  22. package/dist/resources/extensions/gsd/commands/handlers/ops.js +15 -1
  23. package/dist/resources/extensions/gsd/commands-handlers.js +1 -1
  24. package/dist/resources/extensions/gsd/commands-maintenance.js +78 -3
  25. package/dist/resources/extensions/gsd/dashboard-overlay.js +32 -31
  26. package/dist/resources/extensions/gsd/db-writer.js +95 -4
  27. package/dist/resources/extensions/gsd/dispatch-guard.js +35 -30
  28. package/dist/resources/extensions/gsd/doctor-checks.js +28 -11
  29. package/dist/resources/extensions/gsd/doctor-environment.js +28 -0
  30. package/dist/resources/extensions/gsd/doctor-types.js +0 -15
  31. package/dist/resources/extensions/gsd/doctor.js +46 -282
  32. package/dist/resources/extensions/gsd/file-watcher.js +5 -1
  33. package/dist/resources/extensions/gsd/files.js +14 -198
  34. package/dist/resources/extensions/gsd/git-service.js +4 -0
  35. package/dist/resources/extensions/gsd/gitignore.js +4 -0
  36. package/dist/resources/extensions/gsd/gsd-db.js +819 -197
  37. package/dist/resources/extensions/gsd/guided-flow.js +18 -8
  38. package/dist/resources/extensions/gsd/markdown-renderer.js +862 -0
  39. package/dist/resources/extensions/gsd/md-importer.js +182 -4
  40. package/dist/resources/extensions/gsd/native-git-bridge.js +10 -1
  41. package/dist/resources/extensions/gsd/parallel-eligibility.js +14 -19
  42. package/dist/resources/extensions/gsd/parallel-orchestrator.js +38 -0
  43. package/dist/resources/extensions/gsd/parsers-legacy.js +239 -0
  44. package/dist/resources/extensions/gsd/preferences-types.js +1 -0
  45. package/dist/resources/extensions/gsd/preferences-validation.js +9 -0
  46. package/dist/resources/extensions/gsd/preferences.js +1 -0
  47. package/dist/resources/extensions/gsd/prompts/complete-slice.md +22 -9
  48. package/dist/resources/extensions/gsd/prompts/discuss.md +2 -2
  49. package/dist/resources/extensions/gsd/prompts/execute-task.md +15 -5
  50. package/dist/resources/extensions/gsd/prompts/guided-complete-slice.md +1 -1
  51. package/dist/resources/extensions/gsd/prompts/guided-execute-task.md +1 -1
  52. package/dist/resources/extensions/gsd/prompts/guided-plan-milestone.md +1 -1
  53. package/dist/resources/extensions/gsd/prompts/plan-milestone.md +6 -10
  54. package/dist/resources/extensions/gsd/prompts/plan-slice.md +4 -7
  55. package/dist/resources/extensions/gsd/prompts/reactive-execute.md +3 -3
  56. package/dist/resources/extensions/gsd/prompts/reassess-roadmap.md +6 -7
  57. package/dist/resources/extensions/gsd/prompts/replan-slice.md +6 -6
  58. package/dist/resources/extensions/gsd/reactive-graph.js +33 -3
  59. package/dist/resources/extensions/gsd/skill-health.js +3 -1
  60. package/dist/resources/extensions/gsd/state.js +484 -30
  61. package/dist/resources/extensions/gsd/tools/complete-milestone.js +128 -0
  62. package/dist/resources/extensions/gsd/tools/complete-slice.js +244 -0
  63. package/dist/resources/extensions/gsd/tools/complete-task.js +204 -0
  64. package/dist/resources/extensions/gsd/tools/plan-milestone.js +205 -0
  65. package/dist/resources/extensions/gsd/tools/plan-slice.js +155 -0
  66. package/dist/resources/extensions/gsd/tools/plan-task.js +94 -0
  67. package/dist/resources/extensions/gsd/tools/reassess-roadmap.js +152 -0
  68. package/dist/resources/extensions/gsd/tools/replan-slice.js +146 -0
  69. package/dist/resources/extensions/gsd/triage-resolution.js +17 -1
  70. package/dist/resources/extensions/gsd/undo.js +197 -3
  71. package/dist/resources/extensions/gsd/visualizer-data.js +53 -16
  72. package/dist/resources/extensions/gsd/workspace-index.js +63 -39
  73. package/dist/web/standalone/.next/BUILD_ID +1 -1
  74. package/dist/web/standalone/.next/app-path-routes-manifest.json +17 -16
  75. package/dist/web/standalone/.next/build-manifest.json +4 -4
  76. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  77. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  78. package/dist/web/standalone/.next/required-server-files.json +4 -4
  79. package/dist/web/standalone/.next/routes-manifest.json +6 -0
  80. package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
  81. package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  82. package/dist/web/standalone/.next/server/app/_global-error.html +2 -2
  83. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  84. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  85. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  86. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  87. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  88. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  89. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  90. package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
  91. package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  92. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  93. package/dist/web/standalone/.next/server/app/_not-found.rsc +4 -4
  94. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +4 -4
  95. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  96. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +4 -4
  97. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  98. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  99. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  100. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  101. package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
  102. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  103. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
  104. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  105. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
  106. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
  107. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
  108. package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
  109. package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
  110. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  111. package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
  112. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  113. package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
  114. package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
  115. package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
  116. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  117. package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
  118. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  119. package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
  120. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  121. package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
  122. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  123. package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
  124. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  125. package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
  126. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  127. package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
  128. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  129. package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
  130. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  131. package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
  132. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  133. package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
  134. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  135. package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
  136. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  137. package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
  138. package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
  139. package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
  140. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  141. package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
  142. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  143. package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
  144. package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +5 -5
  145. package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
  146. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  147. package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
  148. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  149. package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
  150. package/dist/web/standalone/.next/server/app/api/session/events/route.js +2 -2
  151. package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
  152. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  153. package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
  154. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  155. package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
  156. package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
  157. package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  158. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  159. package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
  160. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  161. package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
  162. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -0
  163. package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -0
  164. package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -0
  165. package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +1 -1
  166. package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
  167. package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
  168. package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
  169. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +2 -2
  170. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
  171. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +4 -4
  172. package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
  173. package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
  174. package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
  175. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  176. package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
  177. package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
  178. package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
  179. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  180. package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
  181. package/dist/web/standalone/.next/server/app/index.html +1 -1
  182. package/dist/web/standalone/.next/server/app/index.rsc +5 -5
  183. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  184. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +5 -5
  185. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  186. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +4 -4
  187. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  188. package/dist/web/standalone/.next/server/app/page.js +2 -2
  189. package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  190. package/dist/web/standalone/.next/server/app-paths-manifest.json +17 -16
  191. package/dist/web/standalone/.next/server/chunks/229.js +3 -3
  192. package/dist/web/standalone/.next/server/chunks/471.js +3 -3
  193. package/dist/web/standalone/.next/server/functions-config-manifest.json +1 -0
  194. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  195. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  196. package/dist/web/standalone/.next/server/middleware.js +2 -2
  197. package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
  198. package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
  199. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  200. package/dist/web/standalone/.next/server/pages/500.html +2 -2
  201. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  202. package/dist/web/standalone/.next/static/chunks/{4024.c195dc1fdd2adbea.js → 4024.0de81b543b28b9fe.js} +2 -2
  203. package/dist/web/standalone/.next/static/chunks/app/_global-error/{page-d07a2c023f1aef1e.js → page-d83ba70a25a85472.js} +1 -1
  204. package/dist/web/standalone/.next/static/chunks/app/_not-found/page-f2a7482d42a5614b.js +1 -0
  205. package/dist/web/standalone/.next/static/chunks/app/api/boot/{route-d07a2c023f1aef1e.js → route-d83ba70a25a85472.js} +1 -1
  206. package/dist/web/standalone/.next/static/chunks/app/api/bridge-terminal/input/{route-d07a2c023f1aef1e.js → route-d83ba70a25a85472.js} +1 -1
  207. package/dist/web/standalone/.next/static/chunks/app/api/bridge-terminal/resize/{route-d07a2c023f1aef1e.js → route-d83ba70a25a85472.js} +1 -1
  208. package/dist/web/standalone/.next/static/chunks/app/api/bridge-terminal/stream/route-d83ba70a25a85472.js +1 -0
  209. package/dist/web/standalone/.next/static/chunks/app/api/browse-directories/route-d83ba70a25a85472.js +1 -0
  210. package/dist/web/standalone/.next/static/chunks/app/api/captures/route-d83ba70a25a85472.js +1 -0
  211. package/dist/web/standalone/.next/static/chunks/app/api/cleanup/route-d83ba70a25a85472.js +1 -0
  212. package/dist/web/standalone/.next/static/chunks/app/api/dev-mode/route-d83ba70a25a85472.js +1 -0
  213. package/dist/web/standalone/.next/static/chunks/app/api/doctor/route-d83ba70a25a85472.js +1 -0
  214. package/dist/web/standalone/.next/static/chunks/app/api/export-data/route-d83ba70a25a85472.js +1 -0
  215. package/dist/web/standalone/.next/static/chunks/app/api/files/route-d83ba70a25a85472.js +1 -0
  216. package/dist/web/standalone/.next/static/chunks/app/api/forensics/route-d83ba70a25a85472.js +1 -0
  217. package/dist/web/standalone/.next/static/chunks/app/api/git/route-d83ba70a25a85472.js +1 -0
  218. package/dist/web/standalone/.next/static/chunks/app/api/history/route-d83ba70a25a85472.js +1 -0
  219. package/dist/web/standalone/.next/static/chunks/app/api/hooks/route-d83ba70a25a85472.js +1 -0
  220. package/dist/web/standalone/.next/static/chunks/app/api/inspect/route-d83ba70a25a85472.js +1 -0
  221. package/dist/web/standalone/.next/static/chunks/app/api/knowledge/route-d83ba70a25a85472.js +1 -0
  222. package/dist/web/standalone/.next/static/chunks/app/api/live-state/route-d83ba70a25a85472.js +1 -0
  223. package/dist/web/standalone/.next/static/chunks/app/api/onboarding/route-d83ba70a25a85472.js +1 -0
  224. package/dist/web/standalone/.next/static/chunks/app/api/preferences/route-d83ba70a25a85472.js +1 -0
  225. package/dist/web/standalone/.next/static/chunks/app/api/projects/route-d83ba70a25a85472.js +1 -0
  226. package/dist/web/standalone/.next/static/chunks/app/api/recovery/route-d83ba70a25a85472.js +1 -0
  227. package/dist/web/standalone/.next/static/chunks/app/api/remote-questions/route-d83ba70a25a85472.js +1 -0
  228. package/dist/web/standalone/.next/static/chunks/app/api/session/browser/route-d83ba70a25a85472.js +1 -0
  229. package/dist/web/standalone/.next/static/chunks/app/api/session/command/route-d83ba70a25a85472.js +1 -0
  230. package/dist/web/standalone/.next/static/chunks/app/api/session/events/route-d83ba70a25a85472.js +1 -0
  231. package/dist/web/standalone/.next/static/chunks/app/api/session/manage/route-d83ba70a25a85472.js +1 -0
  232. package/dist/web/standalone/.next/static/chunks/app/api/settings-data/route-d83ba70a25a85472.js +1 -0
  233. package/dist/web/standalone/.next/static/chunks/app/api/shutdown/route-d83ba70a25a85472.js +1 -0
  234. package/dist/web/standalone/.next/static/chunks/app/api/skill-health/route-d83ba70a25a85472.js +1 -0
  235. package/dist/web/standalone/.next/static/chunks/app/api/steer/route-d83ba70a25a85472.js +1 -0
  236. package/dist/web/standalone/.next/static/chunks/app/api/switch-root/route-d83ba70a25a85472.js +1 -0
  237. package/dist/web/standalone/.next/static/chunks/app/api/terminal/input/route-d83ba70a25a85472.js +1 -0
  238. package/dist/web/standalone/.next/static/chunks/app/api/terminal/resize/route-d83ba70a25a85472.js +1 -0
  239. package/dist/web/standalone/.next/static/chunks/app/api/terminal/sessions/route-d83ba70a25a85472.js +1 -0
  240. package/dist/web/standalone/.next/static/chunks/app/api/terminal/stream/route-d83ba70a25a85472.js +1 -0
  241. package/dist/web/standalone/.next/static/chunks/app/api/terminal/upload/route-d83ba70a25a85472.js +1 -0
  242. package/dist/web/standalone/.next/static/chunks/app/api/undo/route-d83ba70a25a85472.js +1 -0
  243. package/dist/web/standalone/.next/static/chunks/app/api/update/route-d83ba70a25a85472.js +1 -0
  244. package/dist/web/standalone/.next/static/chunks/app/api/visualizer/route-d83ba70a25a85472.js +1 -0
  245. package/dist/web/standalone/.next/static/chunks/app/layout-a16c7a7ecdf0c2cf.js +1 -0
  246. package/dist/web/standalone/.next/static/chunks/app/page-b9367c5ae13b99c6.js +1 -0
  247. package/dist/web/standalone/.next/static/chunks/{main-app-2f2ee7b85712c2bd.js → main-app-fdab67f7802d7832.js} +1 -1
  248. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/app-error-d83ba70a25a85472.js +1 -0
  249. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/forbidden-d83ba70a25a85472.js +1 -0
  250. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +1 -0
  251. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/not-found-d83ba70a25a85472.js +1 -0
  252. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/unauthorized-d83ba70a25a85472.js +1 -0
  253. package/dist/web/standalone/.next/static/chunks/{webpack-fa307370fcf9fb2c.js → webpack-9014b5adb127a98a.js} +1 -1
  254. package/dist/web/standalone/.next/static/css/8a727f372cf53002.css +1 -0
  255. package/dist/web/standalone/.next/static/fOnWQBjWXMKUs4bqTg530/_buildManifest.js +1 -0
  256. package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
  257. package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
  258. package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
  259. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
  260. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
  261. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
  262. package/dist/web/standalone/server.js +1 -1
  263. package/package.json +4 -4
  264. package/packages/pi-ai/dist/models.custom.d.ts +173 -0
  265. package/packages/pi-ai/dist/models.custom.d.ts.map +1 -0
  266. package/packages/pi-ai/dist/models.custom.js +170 -0
  267. package/packages/pi-ai/dist/models.custom.js.map +1 -0
  268. package/packages/pi-ai/dist/models.d.ts.map +1 -1
  269. package/packages/pi-ai/dist/models.js +16 -1
  270. package/packages/pi-ai/dist/models.js.map +1 -1
  271. package/packages/pi-ai/dist/models.test.d.ts +2 -0
  272. package/packages/pi-ai/dist/models.test.d.ts.map +1 -0
  273. package/packages/pi-ai/dist/models.test.js +67 -0
  274. package/packages/pi-ai/dist/models.test.js.map +1 -0
  275. package/packages/pi-ai/src/models.custom.ts +172 -0
  276. package/packages/pi-ai/src/models.test.ts +85 -0
  277. package/packages/pi-ai/src/models.ts +17 -1
  278. package/packages/pi-coding-agent/dist/core/agent-session.d.ts +10 -3
  279. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  280. package/packages/pi-coding-agent/dist/core/agent-session.js +21 -34
  281. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  282. package/packages/pi-coding-agent/dist/core/compaction/branch-summarization.d.ts +2 -2
  283. package/packages/pi-coding-agent/dist/core/compaction/branch-summarization.d.ts.map +1 -1
  284. package/packages/pi-coding-agent/dist/core/compaction/branch-summarization.js.map +1 -1
  285. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts +2 -2
  286. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
  287. package/packages/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
  288. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js +4 -4
  289. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js.map +1 -1
  290. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts +1 -1
  291. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
  292. package/packages/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
  293. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +6 -0
  294. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  295. package/packages/pi-coding-agent/dist/core/extensions/loader.js +80 -0
  296. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  297. package/packages/pi-coding-agent/dist/core/extensions/loader.test.js +63 -0
  298. package/packages/pi-coding-agent/dist/core/extensions/loader.test.js.map +1 -1
  299. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +37 -0
  300. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
  301. package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
  302. package/packages/pi-coding-agent/dist/core/fallback-resolver.d.ts.map +1 -1
  303. package/packages/pi-coding-agent/dist/core/fallback-resolver.js +2 -3
  304. package/packages/pi-coding-agent/dist/core/fallback-resolver.js.map +1 -1
  305. package/packages/pi-coding-agent/dist/core/fallback-resolver.test.js +12 -2
  306. package/packages/pi-coding-agent/dist/core/fallback-resolver.test.js.map +1 -1
  307. package/packages/pi-coding-agent/dist/core/lifecycle-hooks.d.ts +38 -0
  308. package/packages/pi-coding-agent/dist/core/lifecycle-hooks.d.ts.map +1 -0
  309. package/packages/pi-coding-agent/dist/core/lifecycle-hooks.js +192 -0
  310. package/packages/pi-coding-agent/dist/core/lifecycle-hooks.js.map +1 -0
  311. package/packages/pi-coding-agent/dist/core/lsp/client.d.ts +5 -0
  312. package/packages/pi-coding-agent/dist/core/lsp/client.d.ts.map +1 -1
  313. package/packages/pi-coding-agent/dist/core/lsp/client.js +69 -21
  314. package/packages/pi-coding-agent/dist/core/lsp/client.js.map +1 -1
  315. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.d.ts +2 -0
  316. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.d.ts.map +1 -0
  317. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +255 -0
  318. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -0
  319. package/packages/pi-coding-agent/dist/core/model-registry.d.ts +15 -0
  320. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  321. package/packages/pi-coding-agent/dist/core/model-registry.js +40 -3
  322. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  323. package/packages/pi-coding-agent/dist/core/package-commands.d.ts +25 -0
  324. package/packages/pi-coding-agent/dist/core/package-commands.d.ts.map +1 -0
  325. package/packages/pi-coding-agent/dist/core/package-commands.js +253 -0
  326. package/packages/pi-coding-agent/dist/core/package-commands.js.map +1 -0
  327. package/packages/pi-coding-agent/dist/core/package-commands.test.d.ts +2 -0
  328. package/packages/pi-coding-agent/dist/core/package-commands.test.d.ts.map +1 -0
  329. package/packages/pi-coding-agent/dist/core/package-commands.test.js +225 -0
  330. package/packages/pi-coding-agent/dist/core/package-commands.test.js.map +1 -0
  331. package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
  332. package/packages/pi-coding-agent/dist/core/sdk.js +4 -0
  333. package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
  334. package/packages/pi-coding-agent/dist/index.d.ts +3 -1
  335. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  336. package/packages/pi-coding-agent/dist/index.js +1 -0
  337. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  338. package/packages/pi-coding-agent/dist/main.d.ts.map +1 -1
  339. package/packages/pi-coding-agent/dist/main.js +11 -199
  340. package/packages/pi-coding-agent/dist/main.js.map +1 -1
  341. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts +6 -0
  342. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
  343. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +21 -0
  344. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
  345. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts +1 -1
  346. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  347. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js +8 -15
  348. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js.map +1 -1
  349. package/packages/pi-coding-agent/dist/modes/print-mode.d.ts.map +1 -1
  350. package/packages/pi-coding-agent/dist/modes/print-mode.js +45 -34
  351. package/packages/pi-coding-agent/dist/modes/print-mode.js.map +1 -1
  352. package/packages/pi-coding-agent/dist/modes/rpc/rpc-client.d.ts +1 -0
  353. package/packages/pi-coding-agent/dist/modes/rpc/rpc-client.d.ts.map +1 -1
  354. package/packages/pi-coding-agent/dist/modes/rpc/rpc-client.js +7 -2
  355. package/packages/pi-coding-agent/dist/modes/rpc/rpc-client.js.map +1 -1
  356. package/packages/pi-coding-agent/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
  357. package/packages/pi-coding-agent/dist/modes/rpc/rpc-mode.js +2 -1
  358. package/packages/pi-coding-agent/dist/modes/rpc/rpc-mode.js.map +1 -1
  359. package/packages/pi-coding-agent/package.json +1 -1
  360. package/packages/pi-coding-agent/src/core/agent-session.ts +26 -37
  361. package/packages/pi-coding-agent/src/core/compaction/branch-summarization.ts +2 -2
  362. package/packages/pi-coding-agent/src/core/compaction/compaction.ts +3 -3
  363. package/packages/pi-coding-agent/src/core/compaction-orchestrator.ts +4 -4
  364. package/packages/pi-coding-agent/src/core/extensions/index.ts +5 -0
  365. package/packages/pi-coding-agent/src/core/extensions/loader.test.ts +96 -0
  366. package/packages/pi-coding-agent/src/core/extensions/loader.ts +89 -0
  367. package/packages/pi-coding-agent/src/core/extensions/types.ts +44 -0
  368. package/packages/pi-coding-agent/src/core/fallback-resolver.test.ts +15 -2
  369. package/packages/pi-coding-agent/src/core/fallback-resolver.ts +2 -3
  370. package/packages/pi-coding-agent/src/core/lifecycle-hooks.ts +274 -0
  371. package/packages/pi-coding-agent/src/core/lsp/client.ts +83 -21
  372. package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +288 -0
  373. package/packages/pi-coding-agent/src/core/model-registry.ts +39 -3
  374. package/packages/pi-coding-agent/src/core/package-commands.test.ts +240 -0
  375. package/packages/pi-coding-agent/src/core/package-commands.ts +310 -0
  376. package/packages/pi-coding-agent/src/core/sdk.ts +4 -0
  377. package/packages/pi-coding-agent/src/index.ts +7 -0
  378. package/packages/pi-coding-agent/src/main.ts +11 -232
  379. package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +20 -0
  380. package/packages/pi-coding-agent/src/modes/interactive/theme/theme.ts +9 -16
  381. package/packages/pi-coding-agent/src/modes/print-mode.ts +42 -32
  382. package/packages/pi-coding-agent/src/modes/rpc/rpc-client.ts +8 -2
  383. package/packages/pi-coding-agent/src/modes/rpc/rpc-mode.ts +2 -1
  384. package/pkg/dist/modes/interactive/theme/theme.d.ts +1 -1
  385. package/pkg/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  386. package/pkg/dist/modes/interactive/theme/theme.js +8 -15
  387. package/pkg/dist/modes/interactive/theme/theme.js.map +1 -1
  388. package/pkg/package.json +1 -1
  389. package/src/resources/extensions/bg-shell/overlay.ts +4 -0
  390. package/src/resources/extensions/github-sync/sync.ts +2 -1
  391. package/src/resources/extensions/gsd/auto/loop-deps.ts +0 -8
  392. package/src/resources/extensions/gsd/auto/loop.ts +0 -2
  393. package/src/resources/extensions/gsd/auto/phases.ts +7 -20
  394. package/src/resources/extensions/gsd/auto/types.ts +0 -1
  395. package/src/resources/extensions/gsd/auto-dashboard.ts +20 -16
  396. package/src/resources/extensions/gsd/auto-direct-dispatch.ts +34 -19
  397. package/src/resources/extensions/gsd/auto-dispatch.ts +38 -21
  398. package/src/resources/extensions/gsd/auto-post-unit.ts +150 -15
  399. package/src/resources/extensions/gsd/auto-prompts.ts +186 -103
  400. package/src/resources/extensions/gsd/auto-recovery.ts +77 -142
  401. package/src/resources/extensions/gsd/auto-supervisor.ts +14 -0
  402. package/src/resources/extensions/gsd/auto-timeout-recovery.ts +6 -7
  403. package/src/resources/extensions/gsd/auto-verification.ts +4 -9
  404. package/src/resources/extensions/gsd/auto-worktree.ts +126 -30
  405. package/src/resources/extensions/gsd/auto.ts +0 -9
  406. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +675 -4
  407. package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +31 -3
  408. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +7 -0
  409. package/src/resources/extensions/gsd/commands/catalog.ts +3 -1
  410. package/src/resources/extensions/gsd/commands/handlers/ops.ts +15 -1
  411. package/src/resources/extensions/gsd/commands-handlers.ts +1 -1
  412. package/src/resources/extensions/gsd/commands-maintenance.ts +86 -3
  413. package/src/resources/extensions/gsd/dashboard-overlay.ts +17 -13
  414. package/src/resources/extensions/gsd/db-writer.ts +105 -4
  415. package/src/resources/extensions/gsd/dispatch-guard.ts +32 -30
  416. package/src/resources/extensions/gsd/doctor-checks.ts +25 -11
  417. package/src/resources/extensions/gsd/doctor-environment.ts +31 -0
  418. package/src/resources/extensions/gsd/doctor-types.ts +0 -23
  419. package/src/resources/extensions/gsd/doctor.ts +45 -295
  420. package/src/resources/extensions/gsd/file-watcher.ts +4 -1
  421. package/src/resources/extensions/gsd/files.ts +16 -220
  422. package/src/resources/extensions/gsd/git-service.ts +4 -0
  423. package/src/resources/extensions/gsd/gitignore.ts +4 -0
  424. package/src/resources/extensions/gsd/gsd-db.ts +1157 -370
  425. package/src/resources/extensions/gsd/guided-flow.ts +20 -8
  426. package/src/resources/extensions/gsd/markdown-renderer.ts +1098 -0
  427. package/src/resources/extensions/gsd/md-importer.ts +211 -2
  428. package/src/resources/extensions/gsd/native-git-bridge.ts +12 -1
  429. package/src/resources/extensions/gsd/parallel-eligibility.ts +14 -18
  430. package/src/resources/extensions/gsd/parallel-orchestrator.ts +43 -0
  431. package/src/resources/extensions/gsd/parsers-legacy.ts +271 -0
  432. package/src/resources/extensions/gsd/preferences-types.ts +3 -0
  433. package/src/resources/extensions/gsd/preferences-validation.ts +9 -0
  434. package/src/resources/extensions/gsd/preferences.ts +1 -0
  435. package/src/resources/extensions/gsd/prompts/complete-slice.md +22 -9
  436. package/src/resources/extensions/gsd/prompts/discuss.md +2 -2
  437. package/src/resources/extensions/gsd/prompts/execute-task.md +15 -5
  438. package/src/resources/extensions/gsd/prompts/guided-complete-slice.md +1 -1
  439. package/src/resources/extensions/gsd/prompts/guided-execute-task.md +1 -1
  440. package/src/resources/extensions/gsd/prompts/guided-plan-milestone.md +1 -1
  441. package/src/resources/extensions/gsd/prompts/plan-milestone.md +6 -10
  442. package/src/resources/extensions/gsd/prompts/plan-slice.md +4 -7
  443. package/src/resources/extensions/gsd/prompts/reactive-execute.md +3 -3
  444. package/src/resources/extensions/gsd/prompts/reassess-roadmap.md +6 -7
  445. package/src/resources/extensions/gsd/prompts/replan-slice.md +6 -6
  446. package/src/resources/extensions/gsd/reactive-graph.ts +33 -3
  447. package/src/resources/extensions/gsd/skill-health.ts +2 -1
  448. package/src/resources/extensions/gsd/state.ts +547 -29
  449. package/src/resources/extensions/gsd/tests/atomic-task-closeout.test.ts +8 -120
  450. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +20 -11
  451. package/src/resources/extensions/gsd/tests/auto-preflight.test.ts +1 -1
  452. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +150 -5
  453. package/src/resources/extensions/gsd/tests/auto-stash-merge.test.ts +121 -0
  454. package/src/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +15 -20
  455. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +1 -1
  456. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +410 -0
  457. package/src/resources/extensions/gsd/tests/complete-task.test.ts +439 -0
  458. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +0 -2
  459. package/src/resources/extensions/gsd/tests/derive-state-crossval.test.ts +527 -0
  460. package/src/resources/extensions/gsd/tests/derive-state-db.test.ts +593 -2
  461. package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +104 -57
  462. package/src/resources/extensions/gsd/tests/doctor-completion-deferral.test.ts +22 -80
  463. package/src/resources/extensions/gsd/tests/doctor-enhancements.test.ts +5 -7
  464. package/src/resources/extensions/gsd/tests/doctor-environment-worktree.test.ts +175 -0
  465. package/src/resources/extensions/gsd/tests/doctor-fixlevel.test.ts +38 -130
  466. package/src/resources/extensions/gsd/tests/doctor-roadmap-summary-atomicity.test.ts +38 -76
  467. package/src/resources/extensions/gsd/tests/doctor.test.ts +9 -19
  468. package/src/resources/extensions/gsd/tests/flag-file-db.test.ts +290 -0
  469. package/src/resources/extensions/gsd/tests/freeform-decisions.test.ts +240 -0
  470. package/src/resources/extensions/gsd/tests/git-service.test.ts +6 -2
  471. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +1 -1
  472. package/src/resources/extensions/gsd/tests/gsd-recover.test.ts +462 -0
  473. package/src/resources/extensions/gsd/tests/idle-recovery.test.ts +4 -172
  474. package/src/resources/extensions/gsd/tests/integration-proof.test.ts +643 -0
  475. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +0 -3
  476. package/src/resources/extensions/gsd/tests/markdown-renderer.test.ts +1205 -0
  477. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -1
  478. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
  479. package/src/resources/extensions/gsd/tests/migrate-hierarchy.test.ts +439 -0
  480. package/src/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +2 -1
  481. package/src/resources/extensions/gsd/tests/migrate-writer.test.ts +2 -0
  482. package/src/resources/extensions/gsd/tests/parsers.test.ts +2 -1
  483. package/src/resources/extensions/gsd/tests/plan-milestone.test.ts +176 -113
  484. package/src/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +7 -0
  485. package/src/resources/extensions/gsd/tests/plan-slice.test.ts +179 -0
  486. package/src/resources/extensions/gsd/tests/plan-task.test.ts +145 -0
  487. package/src/resources/extensions/gsd/tests/planning-crossval.test.ts +305 -0
  488. package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +139 -0
  489. package/src/resources/extensions/gsd/tests/reassess-handler.test.ts +325 -0
  490. package/src/resources/extensions/gsd/tests/replan-handler.test.ts +410 -0
  491. package/src/resources/extensions/gsd/tests/roadmap-slices.test.ts +1 -1
  492. package/src/resources/extensions/gsd/tests/rogue-file-detection.test.ts +296 -0
  493. package/src/resources/extensions/gsd/tests/schema-v9-sequence.test.ts +176 -0
  494. package/src/resources/extensions/gsd/tests/shared-wal.test.ts +216 -0
  495. package/src/resources/extensions/gsd/tests/token-cost-display.test.ts +118 -0
  496. package/src/resources/extensions/gsd/tests/tool-naming.test.ts +11 -3
  497. package/src/resources/extensions/gsd/tests/undo.test.ts +321 -1
  498. package/src/resources/extensions/gsd/tests/validate-milestone.test.ts +1 -1
  499. package/src/resources/extensions/gsd/tests/verification-evidence.test.ts +0 -142
  500. package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +12 -5
  501. package/src/resources/extensions/gsd/tools/complete-milestone.ts +176 -0
  502. package/src/resources/extensions/gsd/tools/complete-slice.ts +300 -0
  503. package/src/resources/extensions/gsd/tools/complete-task.ts +245 -0
  504. package/src/resources/extensions/gsd/tools/plan-milestone.ts +249 -0
  505. package/src/resources/extensions/gsd/tools/plan-slice.ts +194 -0
  506. package/src/resources/extensions/gsd/tools/plan-task.ts +116 -0
  507. package/src/resources/extensions/gsd/tools/reassess-roadmap.ts +203 -0
  508. package/src/resources/extensions/gsd/tools/replan-slice.ts +192 -0
  509. package/src/resources/extensions/gsd/triage-resolution.ts +20 -1
  510. package/src/resources/extensions/gsd/types.ts +50 -0
  511. package/src/resources/extensions/gsd/undo.ts +247 -3
  512. package/src/resources/extensions/gsd/visualizer-data.ts +54 -17
  513. package/src/resources/extensions/gsd/workspace-index.ts +64 -46
  514. package/dist/resources/extensions/gsd/auto-observability.js +0 -56
  515. package/dist/resources/extensions/gsd/observability-validator.js +0 -422
  516. package/dist/resources/extensions/gsd/roadmap-mutations.js +0 -110
  517. package/dist/web/standalone/.next/static/VvclDCW6TAWjEyLU-EYL1/_buildManifest.js +0 -1
  518. package/dist/web/standalone/.next/static/chunks/app/_not-found/page-e07acdb7dd069836.js +0 -1
  519. package/dist/web/standalone/.next/static/chunks/app/api/bridge-terminal/stream/route-d07a2c023f1aef1e.js +0 -1
  520. package/dist/web/standalone/.next/static/chunks/app/api/browse-directories/route-d07a2c023f1aef1e.js +0 -1
  521. package/dist/web/standalone/.next/static/chunks/app/api/captures/route-d07a2c023f1aef1e.js +0 -1
  522. package/dist/web/standalone/.next/static/chunks/app/api/cleanup/route-d07a2c023f1aef1e.js +0 -1
  523. package/dist/web/standalone/.next/static/chunks/app/api/dev-mode/route-d07a2c023f1aef1e.js +0 -1
  524. package/dist/web/standalone/.next/static/chunks/app/api/doctor/route-d07a2c023f1aef1e.js +0 -1
  525. package/dist/web/standalone/.next/static/chunks/app/api/export-data/route-d07a2c023f1aef1e.js +0 -1
  526. package/dist/web/standalone/.next/static/chunks/app/api/files/route-d07a2c023f1aef1e.js +0 -1
  527. package/dist/web/standalone/.next/static/chunks/app/api/forensics/route-d07a2c023f1aef1e.js +0 -1
  528. package/dist/web/standalone/.next/static/chunks/app/api/git/route-d07a2c023f1aef1e.js +0 -1
  529. package/dist/web/standalone/.next/static/chunks/app/api/history/route-d07a2c023f1aef1e.js +0 -1
  530. package/dist/web/standalone/.next/static/chunks/app/api/hooks/route-d07a2c023f1aef1e.js +0 -1
  531. package/dist/web/standalone/.next/static/chunks/app/api/inspect/route-d07a2c023f1aef1e.js +0 -1
  532. package/dist/web/standalone/.next/static/chunks/app/api/knowledge/route-d07a2c023f1aef1e.js +0 -1
  533. package/dist/web/standalone/.next/static/chunks/app/api/live-state/route-d07a2c023f1aef1e.js +0 -1
  534. package/dist/web/standalone/.next/static/chunks/app/api/onboarding/route-d07a2c023f1aef1e.js +0 -1
  535. package/dist/web/standalone/.next/static/chunks/app/api/preferences/route-d07a2c023f1aef1e.js +0 -1
  536. package/dist/web/standalone/.next/static/chunks/app/api/projects/route-d07a2c023f1aef1e.js +0 -1
  537. package/dist/web/standalone/.next/static/chunks/app/api/recovery/route-d07a2c023f1aef1e.js +0 -1
  538. package/dist/web/standalone/.next/static/chunks/app/api/remote-questions/route-d07a2c023f1aef1e.js +0 -1
  539. package/dist/web/standalone/.next/static/chunks/app/api/session/browser/route-d07a2c023f1aef1e.js +0 -1
  540. package/dist/web/standalone/.next/static/chunks/app/api/session/command/route-d07a2c023f1aef1e.js +0 -1
  541. package/dist/web/standalone/.next/static/chunks/app/api/session/events/route-d07a2c023f1aef1e.js +0 -1
  542. package/dist/web/standalone/.next/static/chunks/app/api/session/manage/route-d07a2c023f1aef1e.js +0 -1
  543. package/dist/web/standalone/.next/static/chunks/app/api/settings-data/route-d07a2c023f1aef1e.js +0 -1
  544. package/dist/web/standalone/.next/static/chunks/app/api/shutdown/route-d07a2c023f1aef1e.js +0 -1
  545. package/dist/web/standalone/.next/static/chunks/app/api/skill-health/route-d07a2c023f1aef1e.js +0 -1
  546. package/dist/web/standalone/.next/static/chunks/app/api/steer/route-d07a2c023f1aef1e.js +0 -1
  547. package/dist/web/standalone/.next/static/chunks/app/api/terminal/input/route-d07a2c023f1aef1e.js +0 -1
  548. package/dist/web/standalone/.next/static/chunks/app/api/terminal/resize/route-d07a2c023f1aef1e.js +0 -1
  549. package/dist/web/standalone/.next/static/chunks/app/api/terminal/sessions/route-d07a2c023f1aef1e.js +0 -1
  550. package/dist/web/standalone/.next/static/chunks/app/api/terminal/stream/route-d07a2c023f1aef1e.js +0 -1
  551. package/dist/web/standalone/.next/static/chunks/app/api/terminal/upload/route-d07a2c023f1aef1e.js +0 -1
  552. package/dist/web/standalone/.next/static/chunks/app/api/undo/route-d07a2c023f1aef1e.js +0 -1
  553. package/dist/web/standalone/.next/static/chunks/app/api/update/route-d07a2c023f1aef1e.js +0 -1
  554. package/dist/web/standalone/.next/static/chunks/app/api/visualizer/route-d07a2c023f1aef1e.js +0 -1
  555. package/dist/web/standalone/.next/static/chunks/app/layout-745c6ed5fea5fb06.js +0 -1
  556. package/dist/web/standalone/.next/static/chunks/app/page-801b53eff6e83579.js +0 -1
  557. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/app-error-d07a2c023f1aef1e.js +0 -1
  558. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/forbidden-d07a2c023f1aef1e.js +0 -1
  559. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-e6255954dccfcf0a.js +0 -1
  560. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/not-found-d07a2c023f1aef1e.js +0 -1
  561. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/unauthorized-d07a2c023f1aef1e.js +0 -1
  562. package/dist/web/standalone/.next/static/css/123c0bb039697968.css +0 -1
  563. package/src/resources/extensions/gsd/auto-observability.ts +0 -74
  564. package/src/resources/extensions/gsd/observability-validator.ts +0 -456
  565. package/src/resources/extensions/gsd/roadmap-mutations.ts +0 -134
  566. package/src/resources/extensions/gsd/tests/doctor-task-done-missing-summary-slice-loop.test.ts +0 -174
  567. package/src/resources/extensions/gsd/tests/plan-quality-validator.test.ts +0 -474
  568. /package/dist/web/standalone/.next/static/{VvclDCW6TAWjEyLU-EYL1 → fOnWQBjWXMKUs4bqTg530}/_ssgManifest.js +0 -0
@@ -0,0 +1,245 @@
1
+ /**
2
+ * complete-task handler — the core operation behind gsd_complete_task.
3
+ *
4
+ * Validates inputs, writes task row to DB in a transaction, then (outside
5
+ * the transaction) renders SUMMARY.md to disk, toggles the plan checkbox,
6
+ * stores the rendered markdown in the DB for D004 recovery, and invalidates
7
+ * caches.
8
+ */
9
+
10
+ import { join } from "node:path";
11
+ import { mkdirSync, existsSync } from "node:fs";
12
+
13
+ import type { CompleteTaskParams } from "../types.js";
14
+ import {
15
+ transaction,
16
+ insertMilestone,
17
+ insertSlice,
18
+ insertTask,
19
+ insertVerificationEvidence,
20
+ _getAdapter,
21
+ } from "../gsd-db.js";
22
+ import { resolveSliceFile, resolveTasksDir, clearPathCache } from "../paths.js";
23
+ import { saveFile, clearParseCache } from "../files.js";
24
+ import { invalidateStateCache } from "../state.js";
25
+ import { renderPlanCheckboxes } from "../markdown-renderer.js";
26
+
27
+ export interface CompleteTaskResult {
28
+ taskId: string;
29
+ sliceId: string;
30
+ milestoneId: string;
31
+ summaryPath: string;
32
+ }
33
+
34
+ /**
35
+ * Render task summary markdown matching the template format.
36
+ * YAML frontmatter uses snake_case keys for parseSummary() compatibility.
37
+ */
38
+ function renderSummaryMarkdown(params: CompleteTaskParams): string {
39
+ const now = new Date().toISOString();
40
+ const keyFilesYaml = params.keyFiles.length > 0
41
+ ? params.keyFiles.map(f => ` - ${f}`).join("\n")
42
+ : " - (none)";
43
+ const keyDecisionsYaml = params.keyDecisions.length > 0
44
+ ? params.keyDecisions.map(d => ` - ${d}`).join("\n")
45
+ : " - (none)";
46
+
47
+ // Build verification evidence table rows
48
+ let evidenceTable = "| # | Command | Exit Code | Verdict | Duration |\n|---|---------|-----------|---------|----------|\n";
49
+ if (params.verificationEvidence.length > 0) {
50
+ params.verificationEvidence.forEach((e, i) => {
51
+ evidenceTable += `| ${i + 1} | \`${e.command}\` | ${e.exitCode} | ${e.verdict} | ${e.durationMs}ms |\n`;
52
+ });
53
+ } else {
54
+ evidenceTable += "| — | No verification commands discovered | — | — | — |\n";
55
+ }
56
+
57
+ // Determine verification_result from evidence
58
+ const allPassed = params.verificationEvidence.length > 0 &&
59
+ params.verificationEvidence.every(e => e.exitCode === 0 || e.verdict.includes("✅") || e.verdict.toLowerCase().includes("pass"));
60
+ const verificationResult = allPassed ? "passed" : (params.verificationEvidence.length === 0 ? "untested" : "mixed");
61
+
62
+ // Extract a title from the oneLiner or taskId
63
+ const title = params.oneLiner || params.taskId;
64
+
65
+ return `---
66
+ id: ${params.taskId}
67
+ parent: ${params.sliceId}
68
+ milestone: ${params.milestoneId}
69
+ key_files:
70
+ ${keyFilesYaml}
71
+ key_decisions:
72
+ ${keyDecisionsYaml}
73
+ duration: ""
74
+ verification_result: ${verificationResult}
75
+ completed_at: ${now}
76
+ blocker_discovered: ${params.blockerDiscovered}
77
+ ---
78
+
79
+ # ${params.taskId}: ${title}
80
+
81
+ **${params.oneLiner}**
82
+
83
+ ## What Happened
84
+
85
+ ${params.narrative}
86
+
87
+ ## Verification
88
+
89
+ ${params.verification}
90
+
91
+ ## Verification Evidence
92
+
93
+ ${evidenceTable}
94
+
95
+ ## Deviations
96
+
97
+ ${params.deviations || "None."}
98
+
99
+ ## Known Issues
100
+
101
+ ${params.knownIssues || "None."}
102
+
103
+ ## Files Created/Modified
104
+
105
+ ${params.keyFiles.map(f => `- \`${f}\``).join("\n") || "None."}
106
+ `;
107
+ }
108
+
109
+ /**
110
+ * Handle the complete_task operation end-to-end.
111
+ *
112
+ * 1. Validate required fields
113
+ * 2. Write DB in a transaction (milestone, slice, task, verification evidence)
114
+ * 3. Render SUMMARY.md to disk
115
+ * 4. Toggle plan checkbox
116
+ * 5. Store rendered markdown back in DB (for D004 recovery)
117
+ * 6. Invalidate caches
118
+ */
119
+ export async function handleCompleteTask(
120
+ params: CompleteTaskParams,
121
+ basePath: string,
122
+ ): Promise<CompleteTaskResult | { error: string }> {
123
+ // ── Validate required fields ────────────────────────────────────────────
124
+ if (!params.taskId || typeof params.taskId !== "string" || params.taskId.trim() === "") {
125
+ return { error: "taskId is required and must be a non-empty string" };
126
+ }
127
+ if (!params.sliceId || typeof params.sliceId !== "string" || params.sliceId.trim() === "") {
128
+ return { error: "sliceId is required and must be a non-empty string" };
129
+ }
130
+ if (!params.milestoneId || typeof params.milestoneId !== "string" || params.milestoneId.trim() === "") {
131
+ return { error: "milestoneId is required and must be a non-empty string" };
132
+ }
133
+
134
+ // ── DB writes inside a transaction ──────────────────────────────────────
135
+ const completedAt = new Date().toISOString();
136
+
137
+ transaction(() => {
138
+ insertMilestone({ id: params.milestoneId });
139
+ insertSlice({ id: params.sliceId, milestoneId: params.milestoneId });
140
+ insertTask({
141
+ id: params.taskId,
142
+ sliceId: params.sliceId,
143
+ milestoneId: params.milestoneId,
144
+ title: params.oneLiner,
145
+ status: "complete",
146
+ oneLiner: params.oneLiner,
147
+ narrative: params.narrative,
148
+ verificationResult: params.verification,
149
+ duration: "",
150
+ blockerDiscovered: params.blockerDiscovered,
151
+ deviations: params.deviations,
152
+ knownIssues: params.knownIssues,
153
+ keyFiles: params.keyFiles,
154
+ keyDecisions: params.keyDecisions,
155
+ });
156
+
157
+ for (const evidence of params.verificationEvidence) {
158
+ insertVerificationEvidence({
159
+ taskId: params.taskId,
160
+ sliceId: params.sliceId,
161
+ milestoneId: params.milestoneId,
162
+ command: evidence.command,
163
+ exitCode: evidence.exitCode,
164
+ verdict: evidence.verdict,
165
+ durationMs: evidence.durationMs,
166
+ });
167
+ }
168
+ });
169
+
170
+ // ── Filesystem operations (outside transaction) ─────────────────────────
171
+ // If disk render fails, roll back the DB status so deriveState() and
172
+ // verifyExpectedArtifact() stay consistent (both say "not done").
173
+
174
+ // Render summary markdown
175
+ const summaryMd = renderSummaryMarkdown(params);
176
+
177
+ // Resolve and write summary to disk
178
+ let summaryPath: string;
179
+ const tasksDir = resolveTasksDir(basePath, params.milestoneId, params.sliceId);
180
+ if (tasksDir) {
181
+ summaryPath = join(tasksDir, `${params.taskId}-SUMMARY.md`);
182
+ } else {
183
+ // Tasks dir doesn't exist on disk yet — build path manually and ensure dirs
184
+ const gsdDir = join(basePath, ".gsd");
185
+ const manualTasksDir = join(gsdDir, "milestones", params.milestoneId, "slices", params.sliceId, "tasks");
186
+ mkdirSync(manualTasksDir, { recursive: true });
187
+ summaryPath = join(manualTasksDir, `${params.taskId}-SUMMARY.md`);
188
+ }
189
+
190
+ try {
191
+ await saveFile(summaryPath, summaryMd);
192
+
193
+ // Toggle plan checkbox via renderer module
194
+ const planPath = resolveSliceFile(basePath, params.milestoneId, params.sliceId, "PLAN");
195
+ if (planPath) {
196
+ await renderPlanCheckboxes(basePath, params.milestoneId, params.sliceId);
197
+ } else {
198
+ process.stderr.write(
199
+ `gsd-db: complete_task — could not find plan file for ${params.sliceId}/${params.milestoneId}, skipping checkbox toggle\n`,
200
+ );
201
+ }
202
+ } catch (renderErr) {
203
+ // Disk render failed — roll back DB status so state stays consistent
204
+ process.stderr.write(
205
+ `gsd-db: complete_task — disk render failed, rolling back DB status: ${(renderErr as Error).message}\n`,
206
+ );
207
+ const rollbackAdapter = _getAdapter();
208
+ if (rollbackAdapter) {
209
+ rollbackAdapter.prepare(
210
+ `UPDATE tasks SET status = 'pending' WHERE milestone_id = :mid AND slice_id = :sid AND id = :tid`,
211
+ ).run({
212
+ ":mid": params.milestoneId,
213
+ ":sid": params.sliceId,
214
+ ":tid": params.taskId,
215
+ });
216
+ }
217
+ invalidateStateCache();
218
+ return { error: `disk render failed: ${(renderErr as Error).message}` };
219
+ }
220
+
221
+ // Store rendered markdown in DB for D004 recovery
222
+ const adapter = _getAdapter();
223
+ if (adapter) {
224
+ adapter.prepare(
225
+ `UPDATE tasks SET full_summary_md = :md WHERE milestone_id = :mid AND slice_id = :sid AND id = :tid`,
226
+ ).run({
227
+ ":md": summaryMd,
228
+ ":mid": params.milestoneId,
229
+ ":sid": params.sliceId,
230
+ ":tid": params.taskId,
231
+ });
232
+ }
233
+
234
+ // Invalidate all caches
235
+ invalidateStateCache();
236
+ clearPathCache();
237
+ clearParseCache();
238
+
239
+ return {
240
+ taskId: params.taskId,
241
+ sliceId: params.sliceId,
242
+ milestoneId: params.milestoneId,
243
+ summaryPath,
244
+ };
245
+ }
@@ -0,0 +1,249 @@
1
+ import { clearParseCache } from "../files.js";
2
+ import {
3
+ transaction,
4
+ insertMilestone,
5
+ insertSlice,
6
+ upsertMilestonePlanning,
7
+ upsertSlicePlanning,
8
+ _getAdapter,
9
+ } from "../gsd-db.js";
10
+ import { invalidateStateCache } from "../state.js";
11
+ import { renderRoadmapFromDb } from "../markdown-renderer.js";
12
+
13
+ export interface PlanMilestoneSliceInput {
14
+ sliceId: string;
15
+ title: string;
16
+ risk: string;
17
+ depends: string[];
18
+ demo: string;
19
+ goal: string;
20
+ successCriteria: string;
21
+ proofLevel: string;
22
+ integrationClosure: string;
23
+ observabilityImpact: string;
24
+ }
25
+
26
+ export interface PlanMilestoneParams {
27
+ milestoneId: string;
28
+ title: string;
29
+ status?: string;
30
+ dependsOn?: string[];
31
+ vision: string;
32
+ successCriteria: string[];
33
+ keyRisks: Array<{ risk: string; whyItMatters: string }>;
34
+ proofStrategy: Array<{ riskOrUnknown: string; retireIn: string; whatWillBeProven: string }>;
35
+ verificationContract: string;
36
+ verificationIntegration: string;
37
+ verificationOperational: string;
38
+ verificationUat: string;
39
+ definitionOfDone: string[];
40
+ requirementCoverage: string;
41
+ boundaryMapMarkdown: string;
42
+ slices: PlanMilestoneSliceInput[];
43
+ }
44
+
45
+ export interface PlanMilestoneResult {
46
+ milestoneId: string;
47
+ roadmapPath: string;
48
+ }
49
+
50
+ function isNonEmptyString(value: unknown): value is string {
51
+ return typeof value === "string" && value.trim().length > 0;
52
+ }
53
+
54
+ function validateStringArray(value: unknown, field: string): string[] {
55
+ if (!Array.isArray(value)) {
56
+ throw new Error(`${field} must be an array`);
57
+ }
58
+ if (value.some((item) => !isNonEmptyString(item))) {
59
+ throw new Error(`${field} must contain only non-empty strings`);
60
+ }
61
+ return value;
62
+ }
63
+
64
+ function validateRiskEntries(value: unknown): Array<{ risk: string; whyItMatters: string }> {
65
+ if (!Array.isArray(value)) {
66
+ throw new Error("keyRisks must be an array");
67
+ }
68
+ return value.map((entry, index) => {
69
+ if (!entry || typeof entry !== "object") {
70
+ throw new Error(`keyRisks[${index}] must be an object`);
71
+ }
72
+ const risk = (entry as Record<string, unknown>).risk;
73
+ const whyItMatters = (entry as Record<string, unknown>).whyItMatters;
74
+ if (!isNonEmptyString(risk) || !isNonEmptyString(whyItMatters)) {
75
+ throw new Error(`keyRisks[${index}] must include non-empty risk and whyItMatters`);
76
+ }
77
+ return { risk, whyItMatters };
78
+ });
79
+ }
80
+
81
+ function validateProofStrategy(value: unknown): Array<{ riskOrUnknown: string; retireIn: string; whatWillBeProven: string }> {
82
+ if (!Array.isArray(value)) {
83
+ throw new Error("proofStrategy must be an array");
84
+ }
85
+ return value.map((entry, index) => {
86
+ if (!entry || typeof entry !== "object") {
87
+ throw new Error(`proofStrategy[${index}] must be an object`);
88
+ }
89
+ const riskOrUnknown = (entry as Record<string, unknown>).riskOrUnknown;
90
+ const retireIn = (entry as Record<string, unknown>).retireIn;
91
+ const whatWillBeProven = (entry as Record<string, unknown>).whatWillBeProven;
92
+ if (!isNonEmptyString(riskOrUnknown) || !isNonEmptyString(retireIn) || !isNonEmptyString(whatWillBeProven)) {
93
+ throw new Error(`proofStrategy[${index}] must include non-empty riskOrUnknown, retireIn, and whatWillBeProven`);
94
+ }
95
+ return { riskOrUnknown, retireIn, whatWillBeProven };
96
+ });
97
+ }
98
+
99
+ function validateSlices(value: unknown): PlanMilestoneSliceInput[] {
100
+ if (!Array.isArray(value) || value.length === 0) {
101
+ throw new Error("slices must be a non-empty array");
102
+ }
103
+
104
+ const seen = new Set<string>();
105
+ return value.map((entry, index) => {
106
+ if (!entry || typeof entry !== "object") {
107
+ throw new Error(`slices[${index}] must be an object`);
108
+ }
109
+ const obj = entry as Record<string, unknown>;
110
+ const sliceId = obj.sliceId;
111
+ const title = obj.title;
112
+ const risk = obj.risk;
113
+ const depends = obj.depends;
114
+ const demo = obj.demo;
115
+ const goal = obj.goal;
116
+ const successCriteria = obj.successCriteria;
117
+ const proofLevel = obj.proofLevel;
118
+ const integrationClosure = obj.integrationClosure;
119
+ const observabilityImpact = obj.observabilityImpact;
120
+
121
+ if (!isNonEmptyString(sliceId)) throw new Error(`slices[${index}].sliceId must be a non-empty string`);
122
+ if (seen.has(sliceId)) throw new Error(`slices[${index}].sliceId must be unique`);
123
+ seen.add(sliceId);
124
+ if (!isNonEmptyString(title)) throw new Error(`slices[${index}].title must be a non-empty string`);
125
+ if (!isNonEmptyString(risk)) throw new Error(`slices[${index}].risk must be a non-empty string`);
126
+ if (!Array.isArray(depends) || depends.some((item) => !isNonEmptyString(item))) {
127
+ throw new Error(`slices[${index}].depends must be an array of non-empty strings`);
128
+ }
129
+ if (!isNonEmptyString(demo)) throw new Error(`slices[${index}].demo must be a non-empty string`);
130
+ if (!isNonEmptyString(goal)) throw new Error(`slices[${index}].goal must be a non-empty string`);
131
+ if (!isNonEmptyString(successCriteria)) throw new Error(`slices[${index}].successCriteria must be a non-empty string`);
132
+ if (!isNonEmptyString(proofLevel)) throw new Error(`slices[${index}].proofLevel must be a non-empty string`);
133
+ if (!isNonEmptyString(integrationClosure)) throw new Error(`slices[${index}].integrationClosure must be a non-empty string`);
134
+ if (!isNonEmptyString(observabilityImpact)) throw new Error(`slices[${index}].observabilityImpact must be a non-empty string`);
135
+
136
+ return {
137
+ sliceId,
138
+ title,
139
+ risk,
140
+ depends,
141
+ demo,
142
+ goal,
143
+ successCriteria,
144
+ proofLevel,
145
+ integrationClosure,
146
+ observabilityImpact,
147
+ };
148
+ });
149
+ }
150
+
151
+ function validateParams(params: PlanMilestoneParams): PlanMilestoneParams {
152
+ if (!isNonEmptyString(params?.milestoneId)) throw new Error("milestoneId is required");
153
+ if (!isNonEmptyString(params?.title)) throw new Error("title is required");
154
+ if (!isNonEmptyString(params?.vision)) throw new Error("vision is required");
155
+ if (!isNonEmptyString(params?.verificationContract)) throw new Error("verificationContract is required");
156
+ if (!isNonEmptyString(params?.verificationIntegration)) throw new Error("verificationIntegration is required");
157
+ if (!isNonEmptyString(params?.verificationOperational)) throw new Error("verificationOperational is required");
158
+ if (!isNonEmptyString(params?.verificationUat)) throw new Error("verificationUat is required");
159
+ if (!isNonEmptyString(params?.requirementCoverage)) throw new Error("requirementCoverage is required");
160
+ if (!isNonEmptyString(params?.boundaryMapMarkdown)) throw new Error("boundaryMapMarkdown is required");
161
+
162
+ return {
163
+ ...params,
164
+ dependsOn: params.dependsOn ? validateStringArray(params.dependsOn, "dependsOn") : [],
165
+ successCriteria: validateStringArray(params.successCriteria, "successCriteria"),
166
+ keyRisks: validateRiskEntries(params.keyRisks),
167
+ proofStrategy: validateProofStrategy(params.proofStrategy),
168
+ definitionOfDone: validateStringArray(params.definitionOfDone, "definitionOfDone"),
169
+ slices: validateSlices(params.slices),
170
+ };
171
+ }
172
+
173
+ export async function handlePlanMilestone(
174
+ rawParams: PlanMilestoneParams,
175
+ basePath: string,
176
+ ): Promise<PlanMilestoneResult | { error: string }> {
177
+ let params: PlanMilestoneParams;
178
+ try {
179
+ params = validateParams(rawParams);
180
+ } catch (err) {
181
+ return { error: `validation failed: ${(err as Error).message}` };
182
+ }
183
+
184
+ try {
185
+ transaction(() => {
186
+ insertMilestone({
187
+ id: params.milestoneId,
188
+ title: params.title,
189
+ status: params.status ?? "active",
190
+ depends_on: params.dependsOn ?? [],
191
+ });
192
+
193
+ upsertMilestonePlanning(params.milestoneId, {
194
+ vision: params.vision,
195
+ successCriteria: params.successCriteria,
196
+ keyRisks: params.keyRisks,
197
+ proofStrategy: params.proofStrategy,
198
+ verificationContract: params.verificationContract,
199
+ verificationIntegration: params.verificationIntegration,
200
+ verificationOperational: params.verificationOperational,
201
+ verificationUat: params.verificationUat,
202
+ definitionOfDone: params.definitionOfDone,
203
+ requirementCoverage: params.requirementCoverage,
204
+ boundaryMapMarkdown: params.boundaryMapMarkdown,
205
+ });
206
+
207
+ for (const slice of params.slices) {
208
+ insertSlice({
209
+ id: slice.sliceId,
210
+ milestoneId: params.milestoneId,
211
+ title: slice.title,
212
+ status: "pending",
213
+ risk: slice.risk,
214
+ depends: slice.depends,
215
+ demo: slice.demo,
216
+ });
217
+ upsertSlicePlanning(params.milestoneId, slice.sliceId, {
218
+ goal: slice.goal,
219
+ successCriteria: slice.successCriteria,
220
+ proofLevel: slice.proofLevel,
221
+ integrationClosure: slice.integrationClosure,
222
+ observabilityImpact: slice.observabilityImpact,
223
+ });
224
+ }
225
+ });
226
+ } catch (err) {
227
+ return { error: `db write failed: ${(err as Error).message}` };
228
+ }
229
+
230
+ let roadmapPath: string;
231
+ try {
232
+ const renderResult = await renderRoadmapFromDb(basePath, params.milestoneId);
233
+ roadmapPath = renderResult.roadmapPath;
234
+ } catch (renderErr) {
235
+ process.stderr.write(
236
+ `gsd-db: plan_milestone — render failed (DB rows preserved for debugging): ${(renderErr as Error).message}\n`,
237
+ );
238
+ invalidateStateCache();
239
+ return { error: `render failed: ${(renderErr as Error).message}` };
240
+ }
241
+
242
+ invalidateStateCache();
243
+ clearParseCache();
244
+
245
+ return {
246
+ milestoneId: params.milestoneId,
247
+ roadmapPath,
248
+ };
249
+ }
@@ -0,0 +1,194 @@
1
+ import { clearParseCache } from "../files.js";
2
+ import {
3
+ transaction,
4
+ getSlice,
5
+ insertTask,
6
+ upsertSlicePlanning,
7
+ upsertTaskPlanning,
8
+ _getAdapter,
9
+ } from "../gsd-db.js";
10
+ import { invalidateStateCache } from "../state.js";
11
+ import { renderPlanFromDb } from "../markdown-renderer.js";
12
+
13
+ export interface PlanSliceTaskInput {
14
+ taskId: string;
15
+ title: string;
16
+ description: string;
17
+ estimate: string;
18
+ files: string[];
19
+ verify: string;
20
+ inputs: string[];
21
+ expectedOutput: string[];
22
+ observabilityImpact?: string;
23
+ }
24
+
25
+ export interface PlanSliceParams {
26
+ milestoneId: string;
27
+ sliceId: string;
28
+ goal: string;
29
+ successCriteria: string;
30
+ proofLevel: string;
31
+ integrationClosure: string;
32
+ observabilityImpact: string;
33
+ tasks: PlanSliceTaskInput[];
34
+ }
35
+
36
+ export interface PlanSliceResult {
37
+ milestoneId: string;
38
+ sliceId: string;
39
+ planPath: string;
40
+ taskPlanPaths: string[];
41
+ }
42
+
43
+ function isNonEmptyString(value: unknown): value is string {
44
+ return typeof value === "string" && value.trim().length > 0;
45
+ }
46
+
47
+ function validateStringArray(value: unknown, field: string): string[] {
48
+ if (!Array.isArray(value)) {
49
+ throw new Error(`${field} must be an array`);
50
+ }
51
+ if (value.some((item) => !isNonEmptyString(item))) {
52
+ throw new Error(`${field} must contain only non-empty strings`);
53
+ }
54
+ return value;
55
+ }
56
+
57
+ function validateTasks(value: unknown): PlanSliceTaskInput[] {
58
+ if (!Array.isArray(value) || value.length === 0) {
59
+ throw new Error("tasks must be a non-empty array");
60
+ }
61
+
62
+ const seen = new Set<string>();
63
+ return value.map((entry, index) => {
64
+ if (!entry || typeof entry !== "object") {
65
+ throw new Error(`tasks[${index}] must be an object`);
66
+ }
67
+ const obj = entry as Record<string, unknown>;
68
+ const taskId = obj.taskId;
69
+ const title = obj.title;
70
+ const description = obj.description;
71
+ const estimate = obj.estimate;
72
+ const files = obj.files;
73
+ const verify = obj.verify;
74
+ const inputs = obj.inputs;
75
+ const expectedOutput = obj.expectedOutput;
76
+ const observabilityImpact = obj.observabilityImpact;
77
+
78
+ if (!isNonEmptyString(taskId)) throw new Error(`tasks[${index}].taskId must be a non-empty string`);
79
+ if (seen.has(taskId)) throw new Error(`tasks[${index}].taskId must be unique`);
80
+ seen.add(taskId);
81
+ if (!isNonEmptyString(title)) throw new Error(`tasks[${index}].title must be a non-empty string`);
82
+ if (!isNonEmptyString(description)) throw new Error(`tasks[${index}].description must be a non-empty string`);
83
+ if (!isNonEmptyString(estimate)) throw new Error(`tasks[${index}].estimate must be a non-empty string`);
84
+ if (!Array.isArray(files) || files.some((item) => !isNonEmptyString(item))) {
85
+ throw new Error(`tasks[${index}].files must be an array of non-empty strings`);
86
+ }
87
+ if (!isNonEmptyString(verify)) throw new Error(`tasks[${index}].verify must be a non-empty string`);
88
+ if (!Array.isArray(inputs) || inputs.some((item) => !isNonEmptyString(item))) {
89
+ throw new Error(`tasks[${index}].inputs must be an array of non-empty strings`);
90
+ }
91
+ if (!Array.isArray(expectedOutput) || expectedOutput.some((item) => !isNonEmptyString(item))) {
92
+ throw new Error(`tasks[${index}].expectedOutput must be an array of non-empty strings`);
93
+ }
94
+ if (observabilityImpact !== undefined && !isNonEmptyString(observabilityImpact)) {
95
+ throw new Error(`tasks[${index}].observabilityImpact must be a non-empty string when provided`);
96
+ }
97
+
98
+ return {
99
+ taskId,
100
+ title,
101
+ description,
102
+ estimate,
103
+ files,
104
+ verify,
105
+ inputs,
106
+ expectedOutput,
107
+ observabilityImpact: typeof observabilityImpact === "string" ? observabilityImpact : "",
108
+ };
109
+ });
110
+ }
111
+
112
+ function validateParams(params: PlanSliceParams): PlanSliceParams {
113
+ if (!isNonEmptyString(params?.milestoneId)) throw new Error("milestoneId is required");
114
+ if (!isNonEmptyString(params?.sliceId)) throw new Error("sliceId is required");
115
+ if (!isNonEmptyString(params?.goal)) throw new Error("goal is required");
116
+ if (!isNonEmptyString(params?.successCriteria)) throw new Error("successCriteria is required");
117
+ if (!isNonEmptyString(params?.proofLevel)) throw new Error("proofLevel is required");
118
+ if (!isNonEmptyString(params?.integrationClosure)) throw new Error("integrationClosure is required");
119
+ if (!isNonEmptyString(params?.observabilityImpact)) throw new Error("observabilityImpact is required");
120
+
121
+ return {
122
+ ...params,
123
+ tasks: validateTasks(params.tasks),
124
+ };
125
+ }
126
+
127
+ export async function handlePlanSlice(
128
+ rawParams: PlanSliceParams,
129
+ basePath: string,
130
+ ): Promise<PlanSliceResult | { error: string }> {
131
+ let params: PlanSliceParams;
132
+ try {
133
+ params = validateParams(rawParams);
134
+ } catch (err) {
135
+ return { error: `validation failed: ${(err as Error).message}` };
136
+ }
137
+
138
+ const parentSlice = getSlice(params.milestoneId, params.sliceId);
139
+ if (!parentSlice) {
140
+ return { error: `missing parent slice: ${params.milestoneId}/${params.sliceId}` };
141
+ }
142
+
143
+ try {
144
+ transaction(() => {
145
+ upsertSlicePlanning(params.milestoneId, params.sliceId, {
146
+ goal: params.goal,
147
+ successCriteria: params.successCriteria,
148
+ proofLevel: params.proofLevel,
149
+ integrationClosure: params.integrationClosure,
150
+ observabilityImpact: params.observabilityImpact,
151
+ });
152
+
153
+ for (const task of params.tasks) {
154
+ insertTask({
155
+ id: task.taskId,
156
+ sliceId: params.sliceId,
157
+ milestoneId: params.milestoneId,
158
+ title: task.title,
159
+ status: "pending",
160
+ });
161
+ upsertTaskPlanning(params.milestoneId, params.sliceId, task.taskId, {
162
+ title: task.title,
163
+ description: task.description,
164
+ estimate: task.estimate,
165
+ files: task.files,
166
+ verify: task.verify,
167
+ inputs: task.inputs,
168
+ expectedOutput: task.expectedOutput,
169
+ observabilityImpact: task.observabilityImpact ?? "",
170
+ });
171
+ }
172
+ });
173
+ } catch (err) {
174
+ return { error: `db write failed: ${(err as Error).message}` };
175
+ }
176
+
177
+ try {
178
+ const renderResult = await renderPlanFromDb(basePath, params.milestoneId, params.sliceId);
179
+ invalidateStateCache();
180
+ clearParseCache();
181
+ return {
182
+ milestoneId: params.milestoneId,
183
+ sliceId: params.sliceId,
184
+ planPath: renderResult.planPath,
185
+ taskPlanPaths: renderResult.taskPlanPaths,
186
+ };
187
+ } catch (renderErr) {
188
+ process.stderr.write(
189
+ `gsd-db: plan_slice — render failed (DB rows preserved for debugging): ${(renderErr as Error).message}\n`,
190
+ );
191
+ invalidateStateCache();
192
+ return { error: `render failed: ${(renderErr as Error).message}` };
193
+ }
194
+ }