@bhargavvc/sdd-cc 1.35.0 → 1.42.4

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 (1376) hide show
  1. package/README.ja-JP.md +54 -52
  2. package/README.ko-KR.md +47 -45
  3. package/README.md +86 -733
  4. package/README.pt-BR.md +14 -12
  5. package/README.zh-CN.md +31 -29
  6. package/agents/sdd-ai-researcher.md +2 -2
  7. package/agents/sdd-code-fixer.md +169 -17
  8. package/agents/sdd-code-reviewer.md +40 -8
  9. package/agents/sdd-codebase-mapper.md +89 -6
  10. package/agents/sdd-debug-session-manager.md +314 -0
  11. package/agents/sdd-debugger.md +147 -80
  12. package/agents/sdd-doc-classifier.md +168 -0
  13. package/agents/sdd-doc-synthesizer.md +204 -0
  14. package/agents/sdd-doc-verifier.md +20 -4
  15. package/agents/sdd-doc-writer.md +22 -9
  16. package/agents/sdd-domain-researcher.md +2 -2
  17. package/agents/sdd-eval-auditor.md +30 -3
  18. package/agents/sdd-eval-planner.md +2 -2
  19. package/agents/sdd-executor.md +203 -43
  20. package/agents/sdd-framework-selector.md +1 -1
  21. package/agents/sdd-integration-checker.md +30 -3
  22. package/agents/sdd-intel-updater.md +51 -23
  23. package/agents/sdd-nyquist-auditor.md +31 -4
  24. package/agents/sdd-pattern-mapper.md +335 -0
  25. package/agents/sdd-phase-researcher.md +195 -32
  26. package/agents/sdd-plan-checker.md +135 -24
  27. package/agents/sdd-planner.md +190 -205
  28. package/agents/sdd-project-researcher.md +7 -7
  29. package/agents/sdd-research-synthesizer.md +6 -6
  30. package/agents/sdd-roadmapper.md +19 -10
  31. package/agents/sdd-security-auditor.md +33 -6
  32. package/agents/sdd-ui-auditor.md +23 -7
  33. package/agents/sdd-ui-checker.md +16 -7
  34. package/agents/sdd-ui-researcher.md +8 -8
  35. package/agents/sdd-verifier.md +124 -27
  36. package/bin/install.js +5016 -372
  37. package/bin/sdd-sdk.js +37 -0
  38. package/commands/sdd/add-tests.md +5 -4
  39. package/commands/sdd/ai-integration-phase.md +4 -3
  40. package/commands/sdd/audit-fix.md +2 -1
  41. package/commands/sdd/audit-milestone.md +3 -2
  42. package/commands/sdd/autonomous.md +3 -3
  43. package/commands/sdd/capture.md +62 -0
  44. package/commands/sdd/cleanup.md +2 -1
  45. package/commands/sdd/code-review.md +8 -4
  46. package/commands/sdd/commit.md +39 -0
  47. package/commands/sdd/complete-milestone.md +15 -8
  48. package/commands/sdd/config.md +58 -0
  49. package/commands/sdd/debug.md +21 -155
  50. package/commands/sdd/discuss-phase.md +18 -11
  51. package/commands/sdd/docs-update.md +3 -2
  52. package/commands/sdd/eval-review.md +4 -3
  53. package/commands/sdd/execute-phase.md +5 -4
  54. package/commands/sdd/explore.md +3 -3
  55. package/commands/sdd/extract-learnings.md +23 -0
  56. package/commands/sdd/fast.md +4 -3
  57. package/commands/sdd/forensics.md +3 -2
  58. package/commands/sdd/graphify.md +199 -0
  59. package/commands/sdd/health.md +12 -3
  60. package/commands/sdd/help.md +1 -1
  61. package/commands/sdd/import.md +10 -5
  62. package/commands/sdd/inbox.md +39 -0
  63. package/commands/sdd/ingest-docs.md +42 -0
  64. package/commands/sdd/manager.md +8 -3
  65. package/commands/sdd/map-codebase.md +18 -6
  66. package/commands/sdd/milestone-summary.md +1 -1
  67. package/commands/sdd/mvp-phase.md +45 -0
  68. package/commands/sdd/new-milestone.md +4 -3
  69. package/commands/sdd/new-project.md +4 -3
  70. package/commands/sdd/ns-context.md +23 -0
  71. package/commands/sdd/ns-ideate.md +24 -0
  72. package/commands/sdd/ns-manage.md +29 -0
  73. package/commands/sdd/ns-project.md +22 -0
  74. package/commands/sdd/ns-review.md +26 -0
  75. package/commands/sdd/ns-workflow.md +28 -0
  76. package/commands/sdd/pause-work.md +6 -1
  77. package/commands/sdd/phase.md +56 -0
  78. package/commands/sdd/plan-phase.md +15 -5
  79. package/commands/sdd/plan-review-convergence.md +59 -0
  80. package/commands/sdd/pr-branch.md +2 -1
  81. package/commands/sdd/profile-user.md +1 -1
  82. package/commands/sdd/progress.md +27 -5
  83. package/commands/sdd/quick.md +128 -3
  84. package/commands/sdd/resume-work.md +2 -12
  85. package/commands/sdd/review-backlog.md +3 -2
  86. package/commands/sdd/review.md +3 -2
  87. package/commands/sdd/secure-phase.md +3 -2
  88. package/commands/sdd/settings.md +2 -9
  89. package/commands/sdd/ship.md +2 -1
  90. package/commands/sdd/sketch.md +60 -0
  91. package/commands/sdd/spec-phase.md +63 -0
  92. package/commands/sdd/spike.md +57 -0
  93. package/commands/sdd/stats.md +2 -1
  94. package/commands/sdd/surface.md +129 -0
  95. package/commands/sdd/thread.md +8 -111
  96. package/commands/sdd/ui-phase.md +3 -2
  97. package/commands/sdd/ui-review.md +3 -2
  98. package/commands/sdd/ultraplan-phase.md +34 -0
  99. package/commands/sdd/undo.md +2 -1
  100. package/commands/sdd/update.md +21 -10
  101. package/commands/sdd/validate-phase.md +3 -2
  102. package/commands/sdd/verify-work.md +5 -4
  103. package/commands/sdd/workspace.md +52 -0
  104. package/commands/sdd/workstreams.md +12 -11
  105. package/hooks/dist/sdd-check-update-worker.js +116 -0
  106. package/hooks/dist/sdd-check-update.js +13 -88
  107. package/hooks/dist/sdd-context-monitor.js +28 -1
  108. package/hooks/dist/sdd-phase-boundary.sh +23 -3
  109. package/hooks/dist/sdd-read-guard.js +21 -2
  110. package/hooks/dist/sdd-read-injection-scanner.js +152 -0
  111. package/hooks/dist/sdd-session-state.sh +38 -12
  112. package/hooks/dist/sdd-statusline.js +324 -28
  113. package/hooks/dist/sdd-update-banner.js +134 -0
  114. package/hooks/dist/sdd-validate-commit.sh +15 -5
  115. package/hooks/dist/sdd-workflow-guard.js +2 -2
  116. package/hooks/lib/git-cmd.js +150 -0
  117. package/hooks/sdd-check-update-worker.js +116 -0
  118. package/hooks/sdd-check-update.js +13 -88
  119. package/hooks/sdd-context-monitor.js +28 -1
  120. package/hooks/sdd-phase-boundary.sh +23 -3
  121. package/hooks/sdd-read-guard.js +21 -2
  122. package/hooks/sdd-read-injection-scanner.js +152 -0
  123. package/hooks/sdd-session-state.sh +38 -12
  124. package/hooks/sdd-statusline.js +324 -28
  125. package/hooks/sdd-update-banner.js +134 -0
  126. package/hooks/sdd-validate-commit.sh +15 -5
  127. package/hooks/sdd-workflow-guard.js +2 -2
  128. package/package.json +32 -7
  129. package/scripts/audit-workflow-script-paths.cjs +73 -0
  130. package/scripts/build-hooks.js +98 -4
  131. package/scripts/changeset/cli.cjs +269 -0
  132. package/scripts/changeset/github-release-notes.cjs +198 -0
  133. package/scripts/changeset/lint.cjs +110 -0
  134. package/scripts/changeset/new.cjs +137 -0
  135. package/scripts/changeset/parse.cjs +60 -0
  136. package/scripts/changeset/render.cjs +34 -0
  137. package/scripts/changeset/serialize.cjs +74 -0
  138. package/scripts/command-contract-helpers.cjs +61 -0
  139. package/scripts/diff-touches-shipped-paths.cjs +147 -0
  140. package/scripts/fix-slash-commands.cjs +106 -0
  141. package/scripts/gen-inventory-manifest.cjs +109 -0
  142. package/scripts/lint-command-contract.cjs +108 -0
  143. package/scripts/lint-descriptions.cjs +83 -0
  144. package/scripts/lint-no-source-grep-extras.cjs +81 -0
  145. package/scripts/lint-no-source-grep.cjs +174 -0
  146. package/scripts/lint-shell-command-projection-drift.cjs +57 -0
  147. package/scripts/lint-skill-deps.cjs +180 -0
  148. package/scripts/pr-template-policy.cjs +169 -0
  149. package/scripts/prompt-injection-scan.sh +2 -0
  150. package/scripts/rebrand-gsd-to-sdd.sh +4 -3
  151. package/scripts/strip-prose-atrefs.cjs +106 -0
  152. package/scripts/verify-tarball-sdk-dist.sh +69 -0
  153. package/sdd/bin/check-latest-version.cjs +104 -0
  154. package/sdd/bin/lib/active-workstream-store.cjs +85 -0
  155. package/sdd/bin/lib/adr-parser.cjs +394 -0
  156. package/sdd/bin/lib/artifacts.cjs +53 -0
  157. package/sdd/bin/lib/audit.cjs +755 -0
  158. package/sdd/bin/lib/cjs-command-router-adapter.cjs +39 -0
  159. package/sdd/bin/lib/clusters.cjs +136 -0
  160. package/sdd/bin/lib/command-aliases.generated.cjs +838 -0
  161. package/sdd/bin/lib/commands.cjs +108 -98
  162. package/sdd/bin/lib/config-schema.cjs +135 -0
  163. package/sdd/bin/lib/config.cjs +253 -68
  164. package/sdd/bin/lib/context-utilization.cjs +47 -0
  165. package/sdd/bin/lib/core.cjs +997 -607
  166. package/sdd/bin/lib/decisions.cjs +48 -0
  167. package/sdd/bin/lib/docs.cjs +36 -33
  168. package/sdd/bin/lib/drift.cjs +379 -0
  169. package/sdd/bin/lib/fallow-runner.cjs +109 -0
  170. package/sdd/bin/lib/frontmatter.cjs +19 -11
  171. package/sdd/bin/lib/gap-checker.cjs +197 -0
  172. package/sdd/bin/lib/graphify.cjs +577 -0
  173. package/sdd/bin/lib/init-command-router.cjs +70 -0
  174. package/sdd/bin/lib/init.cjs +603 -102
  175. package/sdd/bin/lib/install-profiles.cjs +572 -0
  176. package/sdd/bin/lib/installer-migration-authoring.cjs +117 -0
  177. package/sdd/bin/lib/installer-migration-report.cjs +328 -0
  178. package/sdd/bin/lib/installer-migrations/000-first-time-baseline.cjs +220 -0
  179. package/sdd/bin/lib/installer-migrations/001-legacy-orphan-files.cjs +41 -0
  180. package/sdd/bin/lib/installer-migrations/002-codex-legacy-hooks-json.cjs +80 -0
  181. package/sdd/bin/lib/installer-migrations.cjs +703 -0
  182. package/sdd/bin/lib/intel.cjs +35 -52
  183. package/sdd/bin/lib/learnings.cjs +2 -1
  184. package/sdd/bin/lib/milestone.cjs +313 -283
  185. package/sdd/bin/lib/model-catalog.cjs +136 -0
  186. package/sdd/bin/lib/model-profiles.cjs +25 -70
  187. package/sdd/bin/lib/phase-command-router.cjs +96 -0
  188. package/sdd/bin/lib/phase.cjs +556 -102
  189. package/sdd/bin/lib/phases-command-router.cjs +39 -0
  190. package/sdd/bin/lib/plan-scan.cjs +138 -0
  191. package/sdd/bin/lib/planning-workspace.cjs +361 -0
  192. package/sdd/bin/lib/profile-output.cjs +109 -43
  193. package/sdd/bin/lib/profile-pipeline.cjs +1 -1
  194. package/sdd/bin/lib/review-reviewer-selection.cjs +125 -0
  195. package/sdd/bin/lib/roadmap-command-router.cjs +23 -0
  196. package/sdd/bin/lib/roadmap.cjs +278 -17
  197. package/sdd/bin/lib/runtime-homes.cjs +178 -0
  198. package/sdd/bin/lib/sdd2-import.cjs +3 -3
  199. package/sdd/bin/lib/secrets.cjs +33 -0
  200. package/sdd/bin/lib/security.cjs +8 -7
  201. package/sdd/bin/lib/shell-command-projection.cjs +548 -0
  202. package/sdd/bin/lib/state-command-router.cjs +100 -0
  203. package/sdd/bin/lib/state-document.cjs +12 -0
  204. package/sdd/bin/lib/state-document.generated.cjs +127 -0
  205. package/sdd/bin/lib/state.cjs +720 -218
  206. package/sdd/bin/lib/surface.cjs +398 -0
  207. package/sdd/bin/lib/template.cjs +4 -2
  208. package/sdd/bin/lib/uat.cjs +9 -2
  209. package/sdd/bin/lib/validate-command-router.cjs +55 -0
  210. package/sdd/bin/lib/verify-command-router.cjs +34 -0
  211. package/sdd/bin/lib/verify.cjs +464 -137
  212. package/sdd/bin/lib/workstream-inventory.cjs +159 -0
  213. package/sdd/bin/lib/workstream-name-policy.cjs +33 -0
  214. package/sdd/bin/lib/workstream.cjs +73 -195
  215. package/sdd/bin/lib/worktree-safety.cjs +563 -0
  216. package/sdd/bin/sdd-tools.cjs +386 -252
  217. package/sdd/bin/verify-reapply-patches.cjs +247 -0
  218. package/sdd/contexts/review.md +1 -0
  219. package/sdd/references/artifact-types.md +18 -0
  220. package/sdd/references/autonomous-smart-discuss.md +277 -0
  221. package/sdd/references/checkpoints.md +36 -0
  222. package/sdd/references/context-budget.md +85 -49
  223. package/sdd/references/continuation-format.md +26 -22
  224. package/sdd/references/debugger-philosophy.md +76 -0
  225. package/sdd/references/decimal-phase-calculation.md +5 -5
  226. package/sdd/references/doc-conflict-engine.md +91 -0
  227. package/sdd/references/domain-probes.md +1 -1
  228. package/sdd/references/execute-mvp-tdd.md +81 -0
  229. package/sdd/references/executor-examples.md +110 -0
  230. package/sdd/references/gate-prompts.md +2 -2
  231. package/sdd/references/git-integration.md +10 -7
  232. package/sdd/references/git-planning-commit.md +6 -4
  233. package/sdd/references/mandatory-initial-read.md +2 -0
  234. package/sdd/references/model-profiles.md +106 -6
  235. package/sdd/references/mvp-concepts.md +49 -0
  236. package/sdd/references/phase-argument-parsing.md +3 -3
  237. package/sdd/references/planner-antipatterns.md +89 -0
  238. package/sdd/references/planner-chunked.md +49 -0
  239. package/sdd/references/planner-human-verify-mode.md +57 -0
  240. package/sdd/references/planner-mvp-mode.md +53 -0
  241. package/sdd/references/planner-revision.md +1 -1
  242. package/sdd/references/planner-source-audit.md +73 -0
  243. package/sdd/references/planning-config.md +30 -13
  244. package/sdd/references/project-skills-discovery.md +19 -0
  245. package/sdd/references/scout-codebase.md +51 -0
  246. package/sdd/references/skeleton-template.md +48 -0
  247. package/sdd/references/sketch-interactivity.md +41 -0
  248. package/sdd/references/sketch-theme-system.md +94 -0
  249. package/sdd/references/sketch-tooling.md +45 -0
  250. package/sdd/references/sketch-variant-patterns.md +81 -0
  251. package/sdd/references/spidr-splitting.md +69 -0
  252. package/sdd/references/tdd.md +67 -0
  253. package/sdd/references/thinking-partner.md +1 -1
  254. package/sdd/references/universal-anti-patterns.md +4 -4
  255. package/sdd/references/user-story-template.md +58 -0
  256. package/sdd/references/verification-overrides.md +3 -3
  257. package/sdd/references/verify-mvp-mode.md +85 -0
  258. package/sdd/references/workstream-flag.md +11 -11
  259. package/sdd/references/worktree-path-safety.md +89 -0
  260. package/sdd/templates/AI-SPEC.md +1 -1
  261. package/sdd/templates/DEBUG.md +8 -3
  262. package/sdd/templates/README.md +77 -0
  263. package/sdd/templates/UAT.md +4 -4
  264. package/sdd/templates/VALIDATION.md +1 -1
  265. package/sdd/templates/claude-md.md +5 -5
  266. package/sdd/templates/config.json +16 -2
  267. package/sdd/templates/debug-subagent-prompt.md +1 -1
  268. package/sdd/templates/dev-preferences.md +1 -1
  269. package/sdd/templates/discovery.md +2 -2
  270. package/sdd/templates/phase-prompt.md +1 -1
  271. package/sdd/templates/planner-subagent-prompt.md +3 -3
  272. package/sdd/templates/project.md +1 -1
  273. package/sdd/templates/research.md +41 -1
  274. package/sdd/templates/spec.md +307 -0
  275. package/sdd/templates/state.md +9 -1
  276. package/sdd/workflows/add-backlog.md +90 -0
  277. package/sdd/workflows/add-phase.md +7 -7
  278. package/sdd/workflows/add-tests.md +12 -12
  279. package/sdd/workflows/add-todo.md +4 -4
  280. package/sdd/workflows/ai-integration-phase.md +26 -16
  281. package/sdd/workflows/analyze-dependencies.md +3 -3
  282. package/sdd/workflows/audit-fix.md +23 -3
  283. package/sdd/workflows/audit-milestone.md +37 -20
  284. package/sdd/workflows/audit-uat.md +3 -3
  285. package/sdd/workflows/autonomous.md +31 -301
  286. package/sdd/workflows/check-todos.md +6 -6
  287. package/sdd/workflows/cleanup.md +1 -1
  288. package/sdd/workflows/code-review-fix.md +20 -16
  289. package/sdd/workflows/code-review.md +114 -16
  290. package/sdd/workflows/commit.md +166 -0
  291. package/sdd/workflows/complete-milestone.md +68 -15
  292. package/sdd/workflows/debug.md +231 -0
  293. package/sdd/workflows/diagnose-issues.md +8 -6
  294. package/sdd/workflows/discovery-phase.md +3 -3
  295. package/sdd/workflows/discuss-phase/modes/advisor.md +175 -0
  296. package/sdd/workflows/discuss-phase/modes/all.md +28 -0
  297. package/sdd/workflows/discuss-phase/modes/analyze.md +44 -0
  298. package/sdd/workflows/discuss-phase/modes/auto.md +56 -0
  299. package/sdd/workflows/discuss-phase/modes/batch.md +52 -0
  300. package/sdd/workflows/discuss-phase/modes/chain.md +97 -0
  301. package/sdd/workflows/discuss-phase/modes/default.md +141 -0
  302. package/sdd/workflows/discuss-phase/modes/power.md +44 -0
  303. package/sdd/workflows/discuss-phase/modes/text.md +55 -0
  304. package/sdd/workflows/discuss-phase/templates/checkpoint.json +18 -0
  305. package/sdd/workflows/discuss-phase/templates/context.md +136 -0
  306. package/sdd/workflows/discuss-phase/templates/discussion-log.md +50 -0
  307. package/sdd/workflows/discuss-phase-assumptions.md +24 -21
  308. package/sdd/workflows/discuss-phase-power.md +3 -3
  309. package/sdd/workflows/discuss-phase.md +203 -905
  310. package/sdd/workflows/do.md +25 -21
  311. package/sdd/workflows/docs-update.md +23 -17
  312. package/sdd/workflows/edit-phase.md +294 -0
  313. package/sdd/workflows/eval-review.md +7 -7
  314. package/sdd/workflows/execute-phase/steps/codebase-drift-gate.md +81 -0
  315. package/sdd/workflows/execute-phase/steps/per-plan-worktree-gate.md +94 -0
  316. package/sdd/workflows/execute-phase/steps/post-merge-gate.md +116 -0
  317. package/sdd/workflows/execute-phase.md +650 -252
  318. package/sdd/workflows/execute-plan.md +75 -35
  319. package/sdd/workflows/explore.md +7 -3
  320. package/sdd/workflows/extract-learnings.md +242 -0
  321. package/sdd/workflows/fast.md +13 -12
  322. package/sdd/workflows/forensics.md +19 -6
  323. package/sdd/workflows/graduation.md +195 -0
  324. package/sdd/workflows/health.md +49 -7
  325. package/sdd/workflows/help.md +340 -149
  326. package/sdd/workflows/import.md +20 -43
  327. package/sdd/workflows/inbox.md +5 -5
  328. package/sdd/workflows/ingest-docs.md +339 -0
  329. package/sdd/workflows/insert-phase.md +33 -12
  330. package/sdd/workflows/list-phase-assumptions.md +2 -2
  331. package/sdd/workflows/list-workspaces.md +2 -2
  332. package/sdd/workflows/manager.md +38 -11
  333. package/sdd/workflows/map-codebase.md +87 -23
  334. package/sdd/workflows/milestone-summary.md +8 -8
  335. package/sdd/workflows/mvp-phase.md +221 -0
  336. package/sdd/workflows/new-milestone.md +163 -23
  337. package/sdd/workflows/new-project.md +254 -53
  338. package/sdd/workflows/new-workspace.md +8 -8
  339. package/sdd/workflows/next.md +85 -18
  340. package/sdd/workflows/note.md +2 -2
  341. package/sdd/workflows/pause-work.md +13 -9
  342. package/sdd/workflows/plan-milestone-gaps.md +18 -11
  343. package/sdd/workflows/plan-phase.md +767 -94
  344. package/sdd/workflows/plan-review-convergence.md +329 -0
  345. package/sdd/workflows/plant-seed.md +146 -89
  346. package/sdd/workflows/pr-branch.md +1 -1
  347. package/sdd/workflows/profile-user.md +15 -15
  348. package/sdd/workflows/progress.md +198 -56
  349. package/sdd/workflows/quick.md +318 -54
  350. package/{commands/sdd → sdd/workflows}/reapply-patches.md +102 -23
  351. package/sdd/workflows/remove-phase.md +10 -10
  352. package/sdd/workflows/remove-workspace.md +21 -6
  353. package/sdd/workflows/resume-project.md +26 -23
  354. package/sdd/workflows/review.md +151 -20
  355. package/sdd/workflows/scan.md +5 -3
  356. package/sdd/workflows/secure-phase.md +26 -13
  357. package/sdd/workflows/settings-advanced.md +579 -0
  358. package/sdd/workflows/settings-integrations.md +281 -0
  359. package/sdd/workflows/settings.md +202 -23
  360. package/sdd/workflows/ship.md +131 -16
  361. package/sdd/workflows/sketch-wrap-up.md +285 -0
  362. package/sdd/workflows/sketch.md +360 -0
  363. package/sdd/workflows/spec-phase.md +262 -0
  364. package/sdd/workflows/spike-wrap-up.md +306 -0
  365. package/sdd/workflows/spike.md +452 -0
  366. package/sdd/workflows/stats.md +21 -2
  367. package/sdd/workflows/sync-skills.md +182 -0
  368. package/sdd/workflows/thread.md +221 -0
  369. package/sdd/workflows/transition.md +52 -30
  370. package/sdd/workflows/ui-phase.md +37 -20
  371. package/sdd/workflows/ui-review.md +12 -10
  372. package/sdd/workflows/ultraplan-phase.md +198 -0
  373. package/sdd/workflows/undo.md +9 -9
  374. package/sdd/workflows/update.md +187 -17
  375. package/sdd/workflows/validate-phase.md +12 -10
  376. package/sdd/workflows/verify-phase.md +112 -27
  377. package/sdd/workflows/verify-work.md +97 -28
  378. package/sdk/dist/cli-transport.d.ts +19 -0
  379. package/sdk/dist/cli-transport.d.ts.map +1 -0
  380. package/sdk/dist/cli-transport.js +104 -0
  381. package/sdk/dist/cli-transport.js.map +1 -0
  382. package/sdk/dist/cli.d.ts +46 -0
  383. package/sdk/dist/cli.d.ts.map +1 -0
  384. package/sdk/dist/cli.js +511 -0
  385. package/sdk/dist/cli.js.map +1 -0
  386. package/sdk/dist/config.d.ts +84 -0
  387. package/sdk/dist/config.d.ts.map +1 -0
  388. package/sdk/dist/config.js +135 -0
  389. package/sdk/dist/config.js.map +1 -0
  390. package/sdk/dist/context-engine.d.ts +49 -0
  391. package/sdk/dist/context-engine.d.ts.map +1 -0
  392. package/sdk/dist/context-engine.js +142 -0
  393. package/sdk/dist/context-engine.js.map +1 -0
  394. package/sdk/dist/context-truncation.d.ts +33 -0
  395. package/sdk/dist/context-truncation.d.ts.map +1 -0
  396. package/sdk/dist/context-truncation.js +197 -0
  397. package/sdk/dist/context-truncation.js.map +1 -0
  398. package/sdk/dist/errors.d.ts +46 -0
  399. package/sdk/dist/errors.d.ts.map +1 -0
  400. package/sdk/dist/errors.js +64 -0
  401. package/sdk/dist/errors.js.map +1 -0
  402. package/sdk/dist/event-stream.d.ts +53 -0
  403. package/sdk/dist/event-stream.d.ts.map +1 -0
  404. package/sdk/dist/event-stream.js +321 -0
  405. package/sdk/dist/event-stream.js.map +1 -0
  406. package/sdk/dist/golden/capture.d.ts +15 -0
  407. package/sdk/dist/golden/capture.d.ts.map +1 -0
  408. package/sdk/dist/golden/capture.js +67 -0
  409. package/sdk/dist/golden/capture.js.map +1 -0
  410. package/sdk/dist/golden/golden-integration-covered.d.ts +6 -0
  411. package/sdk/dist/golden/golden-integration-covered.d.ts.map +1 -0
  412. package/sdk/dist/golden/golden-integration-covered.js +30 -0
  413. package/sdk/dist/golden/golden-integration-covered.js.map +1 -0
  414. package/sdk/dist/golden/golden-mutation-covered.d.ts +7 -0
  415. package/sdk/dist/golden/golden-mutation-covered.d.ts.map +1 -0
  416. package/sdk/dist/golden/golden-mutation-covered.js +17 -0
  417. package/sdk/dist/golden/golden-mutation-covered.js.map +1 -0
  418. package/sdk/dist/golden/golden-policy.d.ts +10 -0
  419. package/sdk/dist/golden/golden-policy.d.ts.map +1 -0
  420. package/sdk/dist/golden/golden-policy.js +98 -0
  421. package/sdk/dist/golden/golden-policy.js.map +1 -0
  422. package/sdk/dist/golden/init-golden-normalize.d.ts +8 -0
  423. package/sdk/dist/golden/init-golden-normalize.d.ts.map +1 -0
  424. package/sdk/dist/golden/init-golden-normalize.js +14 -0
  425. package/sdk/dist/golden/init-golden-normalize.js.map +1 -0
  426. package/sdk/dist/golden/read-only-golden-rows.d.ts +20 -0
  427. package/sdk/dist/golden/read-only-golden-rows.d.ts.map +1 -0
  428. package/sdk/dist/golden/read-only-golden-rows.js +67 -0
  429. package/sdk/dist/golden/read-only-golden-rows.js.map +1 -0
  430. package/sdk/dist/golden/registry-canonical-commands.d.ts +6 -0
  431. package/sdk/dist/golden/registry-canonical-commands.d.ts.map +1 -0
  432. package/sdk/dist/golden/registry-canonical-commands.js +30 -0
  433. package/sdk/dist/golden/registry-canonical-commands.js.map +1 -0
  434. package/sdk/dist/index.d.ts +125 -0
  435. package/sdk/dist/index.d.ts.map +1 -0
  436. package/sdk/dist/index.js +298 -0
  437. package/sdk/dist/index.js.map +1 -0
  438. package/sdk/dist/init-runner.d.ts +90 -0
  439. package/sdk/dist/init-runner.d.ts.map +1 -0
  440. package/sdk/dist/init-runner.js +613 -0
  441. package/sdk/dist/init-runner.js.map +1 -0
  442. package/sdk/dist/logger.d.ts +50 -0
  443. package/sdk/dist/logger.d.ts.map +1 -0
  444. package/sdk/dist/logger.js +70 -0
  445. package/sdk/dist/logger.js.map +1 -0
  446. package/sdk/dist/model-catalog.d.ts +31 -0
  447. package/sdk/dist/model-catalog.d.ts.map +1 -0
  448. package/sdk/dist/model-catalog.js +31 -0
  449. package/sdk/dist/model-catalog.js.map +1 -0
  450. package/sdk/dist/phase-prompt.d.ts +72 -0
  451. package/sdk/dist/phase-prompt.d.ts.map +1 -0
  452. package/sdk/dist/phase-prompt.js +213 -0
  453. package/sdk/dist/phase-prompt.js.map +1 -0
  454. package/sdk/dist/phase-runner.d.ts +145 -0
  455. package/sdk/dist/phase-runner.d.ts.map +1 -0
  456. package/sdk/dist/phase-runner.js +1206 -0
  457. package/sdk/dist/phase-runner.js.map +1 -0
  458. package/sdk/dist/plan-parser.d.ts +55 -0
  459. package/sdk/dist/plan-parser.d.ts.map +1 -0
  460. package/sdk/dist/plan-parser.js +389 -0
  461. package/sdk/dist/plan-parser.js.map +1 -0
  462. package/sdk/dist/planning-journal.d.ts +64 -0
  463. package/sdk/dist/planning-journal.d.ts.map +1 -0
  464. package/sdk/dist/planning-journal.js +88 -0
  465. package/sdk/dist/planning-journal.js.map +1 -0
  466. package/sdk/dist/planning-runtime.d.ts +67 -0
  467. package/sdk/dist/planning-runtime.d.ts.map +1 -0
  468. package/sdk/dist/planning-runtime.js +58 -0
  469. package/sdk/dist/planning-runtime.js.map +1 -0
  470. package/sdk/dist/prompt-builder.d.ts +44 -0
  471. package/sdk/dist/prompt-builder.d.ts.map +1 -0
  472. package/sdk/dist/prompt-builder.js +180 -0
  473. package/sdk/dist/prompt-builder.js.map +1 -0
  474. package/sdk/dist/prompt-sanitizer.d.ts +35 -0
  475. package/sdk/dist/prompt-sanitizer.d.ts.map +1 -0
  476. package/sdk/dist/prompt-sanitizer.js +101 -0
  477. package/sdk/dist/prompt-sanitizer.js.map +1 -0
  478. package/sdk/dist/query/active-workstream-store.d.ts +7 -0
  479. package/sdk/dist/query/active-workstream-store.d.ts.map +1 -0
  480. package/sdk/dist/query/active-workstream-store.js +56 -0
  481. package/sdk/dist/query/active-workstream-store.js.map +1 -0
  482. package/sdk/dist/query/agent-failure-classifier.d.ts +38 -0
  483. package/sdk/dist/query/agent-failure-classifier.d.ts.map +1 -0
  484. package/sdk/dist/query/agent-failure-classifier.js +83 -0
  485. package/sdk/dist/query/agent-failure-classifier.js.map +1 -0
  486. package/sdk/dist/query/audit-open.d.ts +46 -0
  487. package/sdk/dist/query/audit-open.d.ts.map +1 -0
  488. package/sdk/dist/query/audit-open.js +662 -0
  489. package/sdk/dist/query/audit-open.js.map +1 -0
  490. package/sdk/dist/query/check-auto-mode.d.ts +13 -0
  491. package/sdk/dist/query/check-auto-mode.d.ts.map +1 -0
  492. package/sdk/dist/query/check-auto-mode.js +40 -0
  493. package/sdk/dist/query/check-auto-mode.js.map +1 -0
  494. package/sdk/dist/query/check-completion.d.ts +10 -0
  495. package/sdk/dist/query/check-completion.d.ts.map +1 -0
  496. package/sdk/dist/query/check-completion.js +157 -0
  497. package/sdk/dist/query/check-completion.js.map +1 -0
  498. package/sdk/dist/query/check-decision-coverage.d.ts +33 -0
  499. package/sdk/dist/query/check-decision-coverage.d.ts.map +1 -0
  500. package/sdk/dist/query/check-decision-coverage.js +472 -0
  501. package/sdk/dist/query/check-decision-coverage.js.map +1 -0
  502. package/sdk/dist/query/check-gates.d.ts +10 -0
  503. package/sdk/dist/query/check-gates.d.ts.map +1 -0
  504. package/sdk/dist/query/check-gates.js +89 -0
  505. package/sdk/dist/query/check-gates.js.map +1 -0
  506. package/sdk/dist/query/check-ship-ready.d.ts +10 -0
  507. package/sdk/dist/query/check-ship-ready.d.ts.map +1 -0
  508. package/sdk/dist/query/check-ship-ready.js +93 -0
  509. package/sdk/dist/query/check-ship-ready.js.map +1 -0
  510. package/sdk/dist/query/check-verification-status.d.ts +10 -0
  511. package/sdk/dist/query/check-verification-status.d.ts.map +1 -0
  512. package/sdk/dist/query/check-verification-status.js +142 -0
  513. package/sdk/dist/query/check-verification-status.js.map +1 -0
  514. package/sdk/dist/query/command-aliases.generated.d.ts +31 -0
  515. package/sdk/dist/query/command-aliases.generated.d.ts.map +1 -0
  516. package/sdk/dist/query/command-aliases.generated.js +135 -0
  517. package/sdk/dist/query/command-aliases.generated.js.map +1 -0
  518. package/sdk/dist/query/command-catalog.d.ts +9 -0
  519. package/sdk/dist/query/command-catalog.d.ts.map +1 -0
  520. package/sdk/dist/query/command-catalog.js +17 -0
  521. package/sdk/dist/query/command-catalog.js.map +1 -0
  522. package/sdk/dist/query/command-definition.d.ts +19 -0
  523. package/sdk/dist/query/command-definition.d.ts.map +1 -0
  524. package/sdk/dist/query/command-definition.js +44 -0
  525. package/sdk/dist/query/command-definition.js.map +1 -0
  526. package/sdk/dist/query/command-family-handlers.d.ts +3 -0
  527. package/sdk/dist/query/command-family-handlers.d.ts.map +1 -0
  528. package/sdk/dist/query/command-family-handlers.js +94 -0
  529. package/sdk/dist/query/command-family-handlers.js.map +1 -0
  530. package/sdk/dist/query/command-manifest.d.ts +2 -0
  531. package/sdk/dist/query/command-manifest.d.ts.map +1 -0
  532. package/sdk/dist/query/command-manifest.init.d.ts +6 -0
  533. package/sdk/dist/query/command-manifest.init.d.ts.map +1 -0
  534. package/sdk/dist/query/command-manifest.init.js +23 -0
  535. package/sdk/dist/query/command-manifest.init.js.map +1 -0
  536. package/sdk/dist/query/command-manifest.js +17 -0
  537. package/sdk/dist/query/command-manifest.js.map +1 -0
  538. package/sdk/dist/query/command-manifest.non-family.d.ts +9 -0
  539. package/sdk/dist/query/command-manifest.non-family.d.ts.map +1 -0
  540. package/sdk/dist/query/command-manifest.non-family.js +59 -0
  541. package/sdk/dist/query/command-manifest.non-family.js.map +1 -0
  542. package/sdk/dist/query/command-manifest.phase.d.ts +6 -0
  543. package/sdk/dist/query/command-manifest.phase.d.ts.map +1 -0
  544. package/sdk/dist/query/command-manifest.phase.js +15 -0
  545. package/sdk/dist/query/command-manifest.phase.js.map +1 -0
  546. package/sdk/dist/query/command-manifest.phases.d.ts +7 -0
  547. package/sdk/dist/query/command-manifest.phases.d.ts.map +1 -0
  548. package/sdk/dist/query/command-manifest.phases.js +10 -0
  549. package/sdk/dist/query/command-manifest.phases.js.map +1 -0
  550. package/sdk/dist/query/command-manifest.roadmap.d.ts +6 -0
  551. package/sdk/dist/query/command-manifest.roadmap.d.ts.map +1 -0
  552. package/sdk/dist/query/command-manifest.roadmap.js +10 -0
  553. package/sdk/dist/query/command-manifest.roadmap.js.map +1 -0
  554. package/sdk/dist/query/command-manifest.state.d.ts +9 -0
  555. package/sdk/dist/query/command-manifest.state.d.ts.map +1 -0
  556. package/sdk/dist/query/command-manifest.state.js +30 -0
  557. package/sdk/dist/query/command-manifest.state.js.map +1 -0
  558. package/sdk/dist/query/command-manifest.types.d.ts +12 -0
  559. package/sdk/dist/query/command-manifest.types.d.ts.map +1 -0
  560. package/sdk/dist/query/command-manifest.types.js +2 -0
  561. package/sdk/dist/query/command-manifest.types.js.map +1 -0
  562. package/sdk/dist/query/command-manifest.validate.d.ts +6 -0
  563. package/sdk/dist/query/command-manifest.validate.d.ts.map +1 -0
  564. package/sdk/dist/query/command-manifest.validate.js +10 -0
  565. package/sdk/dist/query/command-manifest.validate.js.map +1 -0
  566. package/sdk/dist/query/command-manifest.verify.d.ts +6 -0
  567. package/sdk/dist/query/command-manifest.verify.d.ts.map +1 -0
  568. package/sdk/dist/query/command-manifest.verify.js +14 -0
  569. package/sdk/dist/query/command-manifest.verify.js.map +1 -0
  570. package/sdk/dist/query/command-static-catalog-domain.d.ts +3 -0
  571. package/sdk/dist/query/command-static-catalog-domain.d.ts.map +1 -0
  572. package/sdk/dist/query/command-static-catalog-domain.js +116 -0
  573. package/sdk/dist/query/command-static-catalog-domain.js.map +1 -0
  574. package/sdk/dist/query/command-static-catalog-foundation.d.ts +7 -0
  575. package/sdk/dist/query/command-static-catalog-foundation.d.ts.map +1 -0
  576. package/sdk/dist/query/command-static-catalog-foundation.js +98 -0
  577. package/sdk/dist/query/command-static-catalog-foundation.js.map +1 -0
  578. package/sdk/dist/query/command-topology.d.ts +32 -0
  579. package/sdk/dist/query/command-topology.d.ts.map +1 -0
  580. package/sdk/dist/query/command-topology.js +66 -0
  581. package/sdk/dist/query/command-topology.js.map +1 -0
  582. package/sdk/dist/query/commands-list.d.ts +14 -0
  583. package/sdk/dist/query/commands-list.d.ts.map +1 -0
  584. package/sdk/dist/query/commands-list.js +18 -0
  585. package/sdk/dist/query/commands-list.js.map +1 -0
  586. package/sdk/dist/query/commit.d.ts +79 -0
  587. package/sdk/dist/query/commit.d.ts.map +1 -0
  588. package/sdk/dist/query/commit.js +340 -0
  589. package/sdk/dist/query/commit.js.map +1 -0
  590. package/sdk/dist/query/config-gates.d.ts +12 -0
  591. package/sdk/dist/query/config-gates.d.ts.map +1 -0
  592. package/sdk/dist/query/config-gates.js +66 -0
  593. package/sdk/dist/query/config-gates.js.map +1 -0
  594. package/sdk/dist/query/config-mutation.d.ts +86 -0
  595. package/sdk/dist/query/config-mutation.d.ts.map +1 -0
  596. package/sdk/dist/query/config-mutation.js +518 -0
  597. package/sdk/dist/query/config-mutation.js.map +1 -0
  598. package/sdk/dist/query/config-query.d.ts +57 -0
  599. package/sdk/dist/query/config-query.d.ts.map +1 -0
  600. package/sdk/dist/query/config-query.js +208 -0
  601. package/sdk/dist/query/config-query.js.map +1 -0
  602. package/sdk/dist/query/config-schema.d.ts +36 -0
  603. package/sdk/dist/query/config-schema.d.ts.map +1 -0
  604. package/sdk/dist/query/config-schema.js +147 -0
  605. package/sdk/dist/query/config-schema.js.map +1 -0
  606. package/sdk/dist/query/decisions.d.ts +58 -0
  607. package/sdk/dist/query/decisions.d.ts.map +1 -0
  608. package/sdk/dist/query/decisions.js +161 -0
  609. package/sdk/dist/query/decisions.js.map +1 -0
  610. package/sdk/dist/query/detect-custom-files.d.ts +11 -0
  611. package/sdk/dist/query/detect-custom-files.d.ts.map +1 -0
  612. package/sdk/dist/query/detect-custom-files.js +89 -0
  613. package/sdk/dist/query/detect-custom-files.js.map +1 -0
  614. package/sdk/dist/query/detect-phase-type.d.ts +9 -0
  615. package/sdk/dist/query/detect-phase-type.d.ts.map +1 -0
  616. package/sdk/dist/query/detect-phase-type.js +124 -0
  617. package/sdk/dist/query/detect-phase-type.js.map +1 -0
  618. package/sdk/dist/query/docs-init.d.ts +26 -0
  619. package/sdk/dist/query/docs-init.d.ts.map +1 -0
  620. package/sdk/dist/query/docs-init.js +231 -0
  621. package/sdk/dist/query/docs-init.js.map +1 -0
  622. package/sdk/dist/query/fallow-audit.d.ts +44 -0
  623. package/sdk/dist/query/fallow-audit.d.ts.map +1 -0
  624. package/sdk/dist/query/fallow-audit.js +44 -0
  625. package/sdk/dist/query/fallow-audit.js.map +1 -0
  626. package/sdk/dist/query/frontmatter-mutation.d.ts +77 -0
  627. package/sdk/dist/query/frontmatter-mutation.d.ts.map +1 -0
  628. package/sdk/dist/query/frontmatter-mutation.js +317 -0
  629. package/sdk/dist/query/frontmatter-mutation.js.map +1 -0
  630. package/sdk/dist/query/frontmatter.d.ts +93 -0
  631. package/sdk/dist/query/frontmatter.d.ts.map +1 -0
  632. package/sdk/dist/query/frontmatter.js +365 -0
  633. package/sdk/dist/query/frontmatter.js.map +1 -0
  634. package/sdk/dist/query/helpers.d.ts +191 -0
  635. package/sdk/dist/query/helpers.d.ts.map +1 -0
  636. package/sdk/dist/query/helpers.js +613 -0
  637. package/sdk/dist/query/helpers.js.map +1 -0
  638. package/sdk/dist/query/index.d.ts +8 -0
  639. package/sdk/dist/query/index.d.ts.map +1 -0
  640. package/sdk/dist/query/index.js +6 -0
  641. package/sdk/dist/query/index.js.map +1 -0
  642. package/sdk/dist/query/init-complex.d.ts +47 -0
  643. package/sdk/dist/query/init-complex.d.ts.map +1 -0
  644. package/sdk/dist/query/init-complex.js +718 -0
  645. package/sdk/dist/query/init-complex.js.map +1 -0
  646. package/sdk/dist/query/init.d.ts +106 -0
  647. package/sdk/dist/query/init.d.ts.map +1 -0
  648. package/sdk/dist/query/init.js +1159 -0
  649. package/sdk/dist/query/init.js.map +1 -0
  650. package/sdk/dist/query/intel.d.ts +43 -0
  651. package/sdk/dist/query/intel.d.ts.map +1 -0
  652. package/sdk/dist/query/intel.js +416 -0
  653. package/sdk/dist/query/intel.js.map +1 -0
  654. package/sdk/dist/query/mutation-event-decorator.d.ts +5 -0
  655. package/sdk/dist/query/mutation-event-decorator.d.ts.map +1 -0
  656. package/sdk/dist/query/mutation-event-decorator.js +28 -0
  657. package/sdk/dist/query/mutation-event-decorator.js.map +1 -0
  658. package/sdk/dist/query/mutation-event-mapper.d.ts +4 -0
  659. package/sdk/dist/query/mutation-event-mapper.d.ts.map +1 -0
  660. package/sdk/dist/query/mutation-event-mapper.js +70 -0
  661. package/sdk/dist/query/mutation-event-mapper.js.map +1 -0
  662. package/sdk/dist/query/mvp.d.ts +113 -0
  663. package/sdk/dist/query/mvp.d.ts.map +1 -0
  664. package/sdk/dist/query/mvp.js +225 -0
  665. package/sdk/dist/query/mvp.js.map +1 -0
  666. package/sdk/dist/query/phase-filesystem-adapter.d.ts +4 -0
  667. package/sdk/dist/query/phase-filesystem-adapter.d.ts.map +1 -0
  668. package/sdk/dist/query/phase-filesystem-adapter.js +33 -0
  669. package/sdk/dist/query/phase-filesystem-adapter.js.map +1 -0
  670. package/sdk/dist/query/phase-lifecycle-policy.d.ts +34 -0
  671. package/sdk/dist/query/phase-lifecycle-policy.d.ts.map +1 -0
  672. package/sdk/dist/query/phase-lifecycle-policy.js +138 -0
  673. package/sdk/dist/query/phase-lifecycle-policy.js.map +1 -0
  674. package/sdk/dist/query/phase-lifecycle.d.ts +116 -0
  675. package/sdk/dist/query/phase-lifecycle.d.ts.map +1 -0
  676. package/sdk/dist/query/phase-lifecycle.js +1486 -0
  677. package/sdk/dist/query/phase-lifecycle.js.map +1 -0
  678. package/sdk/dist/query/phase-list-queries.d.ts +18 -0
  679. package/sdk/dist/query/phase-list-queries.d.ts.map +1 -0
  680. package/sdk/dist/query/phase-list-queries.js +129 -0
  681. package/sdk/dist/query/phase-list-queries.js.map +1 -0
  682. package/sdk/dist/query/phase-ready.d.ts +9 -0
  683. package/sdk/dist/query/phase-ready.d.ts.map +1 -0
  684. package/sdk/dist/query/phase-ready.js +132 -0
  685. package/sdk/dist/query/phase-ready.js.map +1 -0
  686. package/sdk/dist/query/phase-roadmap-mutation.d.ts +13 -0
  687. package/sdk/dist/query/phase-roadmap-mutation.d.ts.map +1 -0
  688. package/sdk/dist/query/phase-roadmap-mutation.js +65 -0
  689. package/sdk/dist/query/phase-roadmap-mutation.js.map +1 -0
  690. package/sdk/dist/query/phase.d.ts +48 -0
  691. package/sdk/dist/query/phase.d.ts.map +1 -0
  692. package/sdk/dist/query/phase.js +451 -0
  693. package/sdk/dist/query/phase.js.map +1 -0
  694. package/sdk/dist/query/pipeline.d.ts +53 -0
  695. package/sdk/dist/query/pipeline.d.ts.map +1 -0
  696. package/sdk/dist/query/pipeline.js +198 -0
  697. package/sdk/dist/query/pipeline.js.map +1 -0
  698. package/sdk/dist/query/plan-scan.d.ts +14 -0
  699. package/sdk/dist/query/plan-scan.d.ts.map +1 -0
  700. package/sdk/dist/query/plan-scan.js +70 -0
  701. package/sdk/dist/query/plan-scan.js.map +1 -0
  702. package/sdk/dist/query/plan-task-structure.d.ts +9 -0
  703. package/sdk/dist/query/plan-task-structure.d.ts.map +1 -0
  704. package/sdk/dist/query/plan-task-structure.js +59 -0
  705. package/sdk/dist/query/plan-task-structure.js.map +1 -0
  706. package/sdk/dist/query/profile-extract-messages.d.ts +40 -0
  707. package/sdk/dist/query/profile-extract-messages.d.ts.map +1 -0
  708. package/sdk/dist/query/profile-extract-messages.js +195 -0
  709. package/sdk/dist/query/profile-extract-messages.js.map +1 -0
  710. package/sdk/dist/query/profile-output.d.ts +11 -0
  711. package/sdk/dist/query/profile-output.d.ts.map +1 -0
  712. package/sdk/dist/query/profile-output.js +873 -0
  713. package/sdk/dist/query/profile-output.js.map +1 -0
  714. package/sdk/dist/query/profile-questionnaire-data.d.ts +21 -0
  715. package/sdk/dist/query/profile-questionnaire-data.d.ts.map +1 -0
  716. package/sdk/dist/query/profile-questionnaire-data.js +171 -0
  717. package/sdk/dist/query/profile-questionnaire-data.js.map +1 -0
  718. package/sdk/dist/query/profile-sample.d.ts +22 -0
  719. package/sdk/dist/query/profile-sample.d.ts.map +1 -0
  720. package/sdk/dist/query/profile-sample.js +136 -0
  721. package/sdk/dist/query/profile-sample.js.map +1 -0
  722. package/sdk/dist/query/profile-scan-sessions.d.ts +49 -0
  723. package/sdk/dist/query/profile-scan-sessions.d.ts.map +1 -0
  724. package/sdk/dist/query/profile-scan-sessions.js +137 -0
  725. package/sdk/dist/query/profile-scan-sessions.js.map +1 -0
  726. package/sdk/dist/query/profile.d.ts +61 -0
  727. package/sdk/dist/query/profile.d.ts.map +1 -0
  728. package/sdk/dist/query/profile.js +307 -0
  729. package/sdk/dist/query/profile.js.map +1 -0
  730. package/sdk/dist/query/progress.d.ts +77 -0
  731. package/sdk/dist/query/progress.d.ts.map +1 -0
  732. package/sdk/dist/query/progress.js +481 -0
  733. package/sdk/dist/query/progress.js.map +1 -0
  734. package/sdk/dist/query/query-cli-adapter.d.ts +8 -0
  735. package/sdk/dist/query/query-cli-adapter.d.ts.map +1 -0
  736. package/sdk/dist/query/query-cli-adapter.js +32 -0
  737. package/sdk/dist/query/query-cli-adapter.js.map +1 -0
  738. package/sdk/dist/query/query-cli-output.d.ts +9 -0
  739. package/sdk/dist/query/query-cli-output.d.ts.map +1 -0
  740. package/sdk/dist/query/query-cli-output.js +28 -0
  741. package/sdk/dist/query/query-cli-output.js.map +1 -0
  742. package/sdk/dist/query/query-command-diagnosis.d.ts +6 -0
  743. package/sdk/dist/query/query-command-diagnosis.d.ts.map +1 -0
  744. package/sdk/dist/query/query-command-diagnosis.js +6 -0
  745. package/sdk/dist/query/query-command-diagnosis.js.map +1 -0
  746. package/sdk/dist/query/query-command-resolution-strategy.d.ts +29 -0
  747. package/sdk/dist/query/query-command-resolution-strategy.d.ts.map +1 -0
  748. package/sdk/dist/query/query-command-resolution-strategy.js +103 -0
  749. package/sdk/dist/query/query-command-resolution-strategy.js.map +1 -0
  750. package/sdk/dist/query/query-command-semantics.d.ts +7 -0
  751. package/sdk/dist/query/query-command-semantics.d.ts.map +1 -0
  752. package/sdk/dist/query/query-command-semantics.js +7 -0
  753. package/sdk/dist/query/query-command-semantics.js.map +1 -0
  754. package/sdk/dist/query/query-dispatch-contract.d.ts +21 -0
  755. package/sdk/dist/query/query-dispatch-contract.d.ts.map +1 -0
  756. package/sdk/dist/query/query-dispatch-contract.js +2 -0
  757. package/sdk/dist/query/query-dispatch-contract.js.map +1 -0
  758. package/sdk/dist/query/query-dispatch-error-mapper.d.ts +6 -0
  759. package/sdk/dist/query/query-dispatch-error-mapper.d.ts.map +1 -0
  760. package/sdk/dist/query/query-dispatch-error-mapper.js +6 -0
  761. package/sdk/dist/query/query-dispatch-error-mapper.js.map +1 -0
  762. package/sdk/dist/query/query-dispatch-formatting.d.ts +6 -0
  763. package/sdk/dist/query/query-dispatch-formatting.d.ts.map +1 -0
  764. package/sdk/dist/query/query-dispatch-formatting.js +6 -0
  765. package/sdk/dist/query/query-dispatch-formatting.js.map +1 -0
  766. package/sdk/dist/query/query-dispatch-input-validation.d.ts +6 -0
  767. package/sdk/dist/query/query-dispatch-input-validation.d.ts.map +1 -0
  768. package/sdk/dist/query/query-dispatch-input-validation.js +6 -0
  769. package/sdk/dist/query/query-dispatch-input-validation.js.map +1 -0
  770. package/sdk/dist/query/query-dispatch-observability.d.ts +2 -0
  771. package/sdk/dist/query/query-dispatch-observability.d.ts.map +1 -0
  772. package/sdk/dist/query/query-dispatch-observability.js +7 -0
  773. package/sdk/dist/query/query-dispatch-observability.js.map +1 -0
  774. package/sdk/dist/query/query-dispatch-plan.d.ts +6 -0
  775. package/sdk/dist/query/query-dispatch-plan.d.ts.map +1 -0
  776. package/sdk/dist/query/query-dispatch-plan.js +6 -0
  777. package/sdk/dist/query/query-dispatch-plan.js.map +1 -0
  778. package/sdk/dist/query/query-dispatch-result-builder.d.ts +6 -0
  779. package/sdk/dist/query/query-dispatch-result-builder.d.ts.map +1 -0
  780. package/sdk/dist/query/query-dispatch-result-builder.js +6 -0
  781. package/sdk/dist/query/query-dispatch-result-builder.js.map +1 -0
  782. package/sdk/dist/query/query-dispatch.d.ts +48 -0
  783. package/sdk/dist/query/query-dispatch.d.ts.map +1 -0
  784. package/sdk/dist/query/query-dispatch.js +175 -0
  785. package/sdk/dist/query/query-dispatch.js.map +1 -0
  786. package/sdk/dist/query/query-error-details-schema.d.ts +19 -0
  787. package/sdk/dist/query/query-error-details-schema.d.ts.map +1 -0
  788. package/sdk/dist/query/query-error-details-schema.js +10 -0
  789. package/sdk/dist/query/query-error-details-schema.js.map +1 -0
  790. package/sdk/dist/query/query-error-taxonomy.d.ts +38 -0
  791. package/sdk/dist/query/query-error-taxonomy.d.ts.map +1 -0
  792. package/sdk/dist/query/query-error-taxonomy.js +74 -0
  793. package/sdk/dist/query/query-error-taxonomy.js.map +1 -0
  794. package/sdk/dist/query/query-fallback-bridge-adapter.d.ts +14 -0
  795. package/sdk/dist/query/query-fallback-bridge-adapter.d.ts.map +1 -0
  796. package/sdk/dist/query/query-fallback-bridge-adapter.js +33 -0
  797. package/sdk/dist/query/query-fallback-bridge-adapter.js.map +1 -0
  798. package/sdk/dist/query/query-fallback-executor.d.ts +11 -0
  799. package/sdk/dist/query/query-fallback-executor.d.ts.map +1 -0
  800. package/sdk/dist/query/query-fallback-executor.js +31 -0
  801. package/sdk/dist/query/query-fallback-executor.js.map +1 -0
  802. package/sdk/dist/query/query-fallback-output-classifier.d.ts +6 -0
  803. package/sdk/dist/query/query-fallback-output-classifier.d.ts.map +1 -0
  804. package/sdk/dist/query/query-fallback-output-classifier.js +27 -0
  805. package/sdk/dist/query/query-fallback-output-classifier.js.map +1 -0
  806. package/sdk/dist/query/query-fallback-policy.d.ts +6 -0
  807. package/sdk/dist/query/query-fallback-policy.d.ts.map +1 -0
  808. package/sdk/dist/query/query-fallback-policy.js +7 -0
  809. package/sdk/dist/query/query-fallback-policy.js.map +1 -0
  810. package/sdk/dist/query/query-native-dispatch-adapter.d.ts +7 -0
  811. package/sdk/dist/query/query-native-dispatch-adapter.d.ts.map +1 -0
  812. package/sdk/dist/query/query-native-dispatch-adapter.js +6 -0
  813. package/sdk/dist/query/query-native-dispatch-adapter.js.map +1 -0
  814. package/sdk/dist/query/query-policy-capability.d.ts +10 -0
  815. package/sdk/dist/query/query-policy-capability.d.ts.map +1 -0
  816. package/sdk/dist/query/query-policy-capability.js +17 -0
  817. package/sdk/dist/query/query-policy-capability.js.map +1 -0
  818. package/sdk/dist/query/query-runtime-context.d.ts +19 -0
  819. package/sdk/dist/query/query-runtime-context.d.ts.map +1 -0
  820. package/sdk/dist/query/query-runtime-context.js +31 -0
  821. package/sdk/dist/query/query-runtime-context.js.map +1 -0
  822. package/sdk/dist/query/query-unknown-command-hints.d.ts +2 -0
  823. package/sdk/dist/query/query-unknown-command-hints.d.ts.map +1 -0
  824. package/sdk/dist/query/query-unknown-command-hints.js +6 -0
  825. package/sdk/dist/query/query-unknown-command-hints.js.map +1 -0
  826. package/sdk/dist/query/registry-assembly-descriptor.d.ts +12 -0
  827. package/sdk/dist/query/registry-assembly-descriptor.d.ts.map +1 -0
  828. package/sdk/dist/query/registry-assembly-descriptor.js +61 -0
  829. package/sdk/dist/query/registry-assembly-descriptor.js.map +1 -0
  830. package/sdk/dist/query/registry-assembly-invariants.d.ts +30 -0
  831. package/sdk/dist/query/registry-assembly-invariants.d.ts.map +1 -0
  832. package/sdk/dist/query/registry-assembly-invariants.js +77 -0
  833. package/sdk/dist/query/registry-assembly-invariants.js.map +1 -0
  834. package/sdk/dist/query/registry-assembly.d.ts +10 -0
  835. package/sdk/dist/query/registry-assembly.d.ts.map +1 -0
  836. package/sdk/dist/query/registry-assembly.js +53 -0
  837. package/sdk/dist/query/registry-assembly.js.map +1 -0
  838. package/sdk/dist/query/registry.d.ts +90 -0
  839. package/sdk/dist/query/registry.d.ts.map +1 -0
  840. package/sdk/dist/query/registry.js +129 -0
  841. package/sdk/dist/query/registry.js.map +1 -0
  842. package/sdk/dist/query/requirements-extract-from-plans.d.ts +9 -0
  843. package/sdk/dist/query/requirements-extract-from-plans.d.ts.map +1 -0
  844. package/sdk/dist/query/requirements-extract-from-plans.js +76 -0
  845. package/sdk/dist/query/requirements-extract-from-plans.js.map +1 -0
  846. package/sdk/dist/query/roadmap-update-plan-progress.d.ts +11 -0
  847. package/sdk/dist/query/roadmap-update-plan-progress.d.ts.map +1 -0
  848. package/sdk/dist/query/roadmap-update-plan-progress.js +124 -0
  849. package/sdk/dist/query/roadmap-update-plan-progress.js.map +1 -0
  850. package/sdk/dist/query/roadmap.d.ts +137 -0
  851. package/sdk/dist/query/roadmap.d.ts.map +1 -0
  852. package/sdk/dist/query/roadmap.js +753 -0
  853. package/sdk/dist/query/roadmap.js.map +1 -0
  854. package/sdk/dist/query/route-next-action.d.ts +9 -0
  855. package/sdk/dist/query/route-next-action.d.ts.map +1 -0
  856. package/sdk/dist/query/route-next-action.js +318 -0
  857. package/sdk/dist/query/route-next-action.js.map +1 -0
  858. package/sdk/dist/query/schema-detect.d.ts +21 -0
  859. package/sdk/dist/query/schema-detect.d.ts.map +1 -0
  860. package/sdk/dist/query/schema-detect.js +146 -0
  861. package/sdk/dist/query/schema-detect.js.map +1 -0
  862. package/sdk/dist/query/secrets.d.ts +27 -0
  863. package/sdk/dist/query/secrets.d.ts.map +1 -0
  864. package/sdk/dist/query/secrets.js +42 -0
  865. package/sdk/dist/query/secrets.js.map +1 -0
  866. package/sdk/dist/query/skill-manifest.d.ts +50 -0
  867. package/sdk/dist/query/skill-manifest.d.ts.map +1 -0
  868. package/sdk/dist/query/skill-manifest.js +171 -0
  869. package/sdk/dist/query/skill-manifest.js.map +1 -0
  870. package/sdk/dist/query/skills.d.ts +27 -0
  871. package/sdk/dist/query/skills.d.ts.map +1 -0
  872. package/sdk/dist/query/skills.js +137 -0
  873. package/sdk/dist/query/skills.js.map +1 -0
  874. package/sdk/dist/query/state-document.d.ts +14 -0
  875. package/sdk/dist/query/state-document.d.ts.map +1 -0
  876. package/sdk/dist/query/state-document.js +110 -0
  877. package/sdk/dist/query/state-document.js.map +1 -0
  878. package/sdk/dist/query/state-mutation.d.ts +224 -0
  879. package/sdk/dist/query/state-mutation.d.ts.map +1 -0
  880. package/sdk/dist/query/state-mutation.js +1539 -0
  881. package/sdk/dist/query/state-mutation.js.map +1 -0
  882. package/sdk/dist/query/state-project-load.d.ts +23 -0
  883. package/sdk/dist/query/state-project-load.d.ts.map +1 -0
  884. package/sdk/dist/query/state-project-load.js +75 -0
  885. package/sdk/dist/query/state-project-load.js.map +1 -0
  886. package/sdk/dist/query/state.d.ts +78 -0
  887. package/sdk/dist/query/state.d.ts.map +1 -0
  888. package/sdk/dist/query/state.js +430 -0
  889. package/sdk/dist/query/state.js.map +1 -0
  890. package/sdk/dist/query/summary.d.ts +18 -0
  891. package/sdk/dist/query/summary.d.ts.map +1 -0
  892. package/sdk/dist/query/summary.js +249 -0
  893. package/sdk/dist/query/summary.js.map +1 -0
  894. package/sdk/dist/query/template.d.ts +46 -0
  895. package/sdk/dist/query/template.d.ts.map +1 -0
  896. package/sdk/dist/query/template.js +210 -0
  897. package/sdk/dist/query/template.js.map +1 -0
  898. package/sdk/dist/query/uat.d.ts +34 -0
  899. package/sdk/dist/query/uat.d.ts.map +1 -0
  900. package/sdk/dist/query/uat.js +339 -0
  901. package/sdk/dist/query/uat.js.map +1 -0
  902. package/sdk/dist/query/utils.d.ts +59 -0
  903. package/sdk/dist/query/utils.d.ts.map +1 -0
  904. package/sdk/dist/query/utils.js +74 -0
  905. package/sdk/dist/query/utils.js.map +1 -0
  906. package/sdk/dist/query/validate.d.ts +67 -0
  907. package/sdk/dist/query/validate.d.ts.map +1 -0
  908. package/sdk/dist/query/validate.js +908 -0
  909. package/sdk/dist/query/validate.js.map +1 -0
  910. package/sdk/dist/query/verify.d.ts +110 -0
  911. package/sdk/dist/query/verify.d.ts.map +1 -0
  912. package/sdk/dist/query/verify.js +631 -0
  913. package/sdk/dist/query/verify.js.map +1 -0
  914. package/sdk/dist/query/websearch.d.ts +24 -0
  915. package/sdk/dist/query/websearch.d.ts.map +1 -0
  916. package/sdk/dist/query/websearch.js +68 -0
  917. package/sdk/dist/query/websearch.js.map +1 -0
  918. package/sdk/dist/query/workspace.d.ts +62 -0
  919. package/sdk/dist/query/workspace.d.ts.map +1 -0
  920. package/sdk/dist/query/workspace.js +104 -0
  921. package/sdk/dist/query/workspace.js.map +1 -0
  922. package/sdk/dist/query/workstream-inventory.d.ts +52 -0
  923. package/sdk/dist/query/workstream-inventory.d.ts.map +1 -0
  924. package/sdk/dist/query/workstream-inventory.js +141 -0
  925. package/sdk/dist/query/workstream-inventory.js.map +1 -0
  926. package/sdk/dist/query/workstream.d.ts +35 -0
  927. package/sdk/dist/query/workstream.d.ts.map +1 -0
  928. package/sdk/dist/query/workstream.js +298 -0
  929. package/sdk/dist/query/workstream.js.map +1 -0
  930. package/sdk/dist/query/worktree.d.ts +3 -0
  931. package/sdk/dist/query/worktree.d.ts.map +1 -0
  932. package/sdk/dist/query/worktree.js +36 -0
  933. package/sdk/dist/query/worktree.js.map +1 -0
  934. package/sdk/dist/query-command-executor.d.ts +22 -0
  935. package/sdk/dist/query-command-executor.d.ts.map +1 -0
  936. package/sdk/dist/query-command-executor.js +22 -0
  937. package/sdk/dist/query-command-executor.js.map +1 -0
  938. package/sdk/dist/query-execution-policy.d.ts +24 -0
  939. package/sdk/dist/query-execution-policy.d.ts.map +1 -0
  940. package/sdk/dist/query-execution-policy.js +27 -0
  941. package/sdk/dist/query-execution-policy.js.map +1 -0
  942. package/sdk/dist/query-failure-classification.d.ts +9 -0
  943. package/sdk/dist/query-failure-classification.d.ts.map +1 -0
  944. package/sdk/dist/query-failure-classification.js +32 -0
  945. package/sdk/dist/query-failure-classification.js.map +1 -0
  946. package/sdk/dist/query-hotpath-methods.d.ts +19 -0
  947. package/sdk/dist/query-hotpath-methods.d.ts.map +1 -0
  948. package/sdk/dist/query-hotpath-methods.js +34 -0
  949. package/sdk/dist/query-hotpath-methods.js.map +1 -0
  950. package/sdk/dist/query-native-direct-adapter.d.ts +20 -0
  951. package/sdk/dist/query-native-direct-adapter.d.ts.map +1 -0
  952. package/sdk/dist/query-native-direct-adapter.js +52 -0
  953. package/sdk/dist/query-native-direct-adapter.js.map +1 -0
  954. package/sdk/dist/query-native-hotpath-adapter.d.ts +15 -0
  955. package/sdk/dist/query-native-hotpath-adapter.d.ts.map +1 -0
  956. package/sdk/dist/query-native-hotpath-adapter.js +32 -0
  957. package/sdk/dist/query-native-hotpath-adapter.js.map +1 -0
  958. package/sdk/dist/query-raw-output-projection.d.ts +6 -0
  959. package/sdk/dist/query-raw-output-projection.d.ts.map +1 -0
  960. package/sdk/dist/query-raw-output-projection.js +67 -0
  961. package/sdk/dist/query-raw-output-projection.js.map +1 -0
  962. package/sdk/dist/query-runtime-bridge.d.ts +61 -0
  963. package/sdk/dist/query-runtime-bridge.d.ts.map +1 -0
  964. package/sdk/dist/query-runtime-bridge.js +144 -0
  965. package/sdk/dist/query-runtime-bridge.js.map +1 -0
  966. package/sdk/dist/query-sdd-tools-path.d.ts +2 -0
  967. package/sdk/dist/query-sdd-tools-path.d.ts.map +1 -0
  968. package/sdk/dist/query-sdd-tools-path.js +2 -0
  969. package/sdk/dist/query-sdd-tools-path.js.map +1 -0
  970. package/sdk/dist/query-sdd-tools-runtime.d.ts +20 -0
  971. package/sdk/dist/query-sdd-tools-runtime.d.ts.map +1 -0
  972. package/sdk/dist/query-sdd-tools-runtime.js +47 -0
  973. package/sdk/dist/query-sdd-tools-runtime.js.map +1 -0
  974. package/sdk/dist/query-subprocess-adapter.d.ts +18 -0
  975. package/sdk/dist/query-subprocess-adapter.d.ts.map +1 -0
  976. package/sdk/dist/query-subprocess-adapter.js +92 -0
  977. package/sdk/dist/query-subprocess-adapter.js.map +1 -0
  978. package/sdk/dist/query-tools-error-factory.d.ts +16 -0
  979. package/sdk/dist/query-tools-error-factory.d.ts.map +1 -0
  980. package/sdk/dist/query-tools-error-factory.js +33 -0
  981. package/sdk/dist/query-tools-error-factory.js.map +1 -0
  982. package/sdk/dist/research-gate.d.ts +24 -0
  983. package/sdk/dist/research-gate.d.ts.map +1 -0
  984. package/sdk/dist/research-gate.js +70 -0
  985. package/sdk/dist/research-gate.js.map +1 -0
  986. package/sdk/dist/runtime-gate.d.ts +14 -0
  987. package/sdk/dist/runtime-gate.d.ts.map +1 -0
  988. package/sdk/dist/runtime-gate.js +48 -0
  989. package/sdk/dist/runtime-gate.js.map +1 -0
  990. package/sdk/dist/sdd-tools-error.d.ts +23 -0
  991. package/sdk/dist/sdd-tools-error.d.ts.map +1 -0
  992. package/sdk/dist/sdd-tools-error.js +29 -0
  993. package/sdk/dist/sdd-tools-error.js.map +1 -0
  994. package/sdk/dist/sdd-tools.d.ts +97 -0
  995. package/sdk/dist/sdd-tools.d.ts.map +1 -0
  996. package/sdk/dist/sdd-tools.js +168 -0
  997. package/sdk/dist/sdd-tools.js.map +1 -0
  998. package/sdk/dist/sdd-transport-policy.d.ts +10 -0
  999. package/sdk/dist/sdd-transport-policy.d.ts.map +1 -0
  1000. package/sdk/dist/sdd-transport-policy.js +32 -0
  1001. package/sdk/dist/sdd-transport-policy.js.map +1 -0
  1002. package/sdk/dist/sdd-transport.d.ts +39 -0
  1003. package/sdk/dist/sdd-transport.d.ts.map +1 -0
  1004. package/sdk/dist/sdd-transport.js +78 -0
  1005. package/sdk/dist/sdd-transport.js.map +1 -0
  1006. package/sdk/dist/sdk-package-compatibility.d.ts +38 -0
  1007. package/sdk/dist/sdk-package-compatibility.d.ts.map +1 -0
  1008. package/sdk/dist/sdk-package-compatibility.js +90 -0
  1009. package/sdk/dist/sdk-package-compatibility.js.map +1 -0
  1010. package/sdk/dist/session-runner.d.ts +40 -0
  1011. package/sdk/dist/session-runner.d.ts.map +1 -0
  1012. package/sdk/dist/session-runner.js +274 -0
  1013. package/sdk/dist/session-runner.js.map +1 -0
  1014. package/sdk/dist/tool-scoping.d.ts +31 -0
  1015. package/sdk/dist/tool-scoping.d.ts.map +1 -0
  1016. package/sdk/dist/tool-scoping.js +54 -0
  1017. package/sdk/dist/tool-scoping.js.map +1 -0
  1018. package/sdk/dist/types.d.ts +794 -0
  1019. package/sdk/dist/types.d.ts.map +1 -0
  1020. package/sdk/dist/types.js +77 -0
  1021. package/sdk/dist/types.js.map +1 -0
  1022. package/sdk/dist/workstream-name-policy.d.ts +13 -0
  1023. package/sdk/dist/workstream-name-policy.d.ts.map +1 -0
  1024. package/sdk/dist/workstream-name-policy.js +24 -0
  1025. package/sdk/dist/workstream-name-policy.js.map +1 -0
  1026. package/sdk/dist/workstream-utils.d.ts +15 -0
  1027. package/sdk/dist/workstream-utils.d.ts.map +1 -0
  1028. package/sdk/dist/workstream-utils.js +21 -0
  1029. package/sdk/dist/workstream-utils.js.map +1 -0
  1030. package/sdk/dist/ws-transport.d.ts +32 -0
  1031. package/sdk/dist/ws-transport.d.ts.map +1 -0
  1032. package/sdk/dist/ws-transport.js +84 -0
  1033. package/sdk/dist/ws-transport.js.map +1 -0
  1034. package/sdk/package-lock.json +2502 -0
  1035. package/sdk/package.json +57 -0
  1036. package/sdk/prompts/templates/project.md +186 -0
  1037. package/sdk/prompts/templates/requirements.md +231 -0
  1038. package/sdk/prompts/templates/research-project/ARCHITECTURE.md +204 -0
  1039. package/sdk/prompts/templates/research-project/FEATURES.md +147 -0
  1040. package/sdk/prompts/templates/research-project/PITFALLS.md +200 -0
  1041. package/sdk/prompts/templates/research-project/STACK.md +120 -0
  1042. package/sdk/prompts/templates/research-project/SUMMARY.md +170 -0
  1043. package/sdk/prompts/templates/roadmap.md +202 -0
  1044. package/sdk/prompts/templates/state.md +175 -0
  1045. package/sdk/shared/model-catalog.json +122 -0
  1046. package/sdk/src/assembled-prompts.test.ts +349 -0
  1047. package/sdk/src/bug-3591-sddtools-runtime-workstream.test.ts +179 -0
  1048. package/sdk/src/cli-transport.test.ts +388 -0
  1049. package/sdk/src/cli-transport.ts +130 -0
  1050. package/sdk/src/cli.test.ts +426 -0
  1051. package/sdk/src/cli.ts +589 -0
  1052. package/sdk/src/config.test.ts +271 -0
  1053. package/sdk/src/config.ts +218 -0
  1054. package/sdk/src/context-engine.test.ts +295 -0
  1055. package/sdk/src/context-engine.ts +170 -0
  1056. package/sdk/src/context-truncation.test.ts +163 -0
  1057. package/sdk/src/context-truncation.ts +233 -0
  1058. package/sdk/src/e2e.integration.test.ts +181 -0
  1059. package/sdk/src/errors.ts +72 -0
  1060. package/sdk/src/event-stream.test.ts +661 -0
  1061. package/sdk/src/event-stream.ts +441 -0
  1062. package/sdk/src/golden/capture.ts +95 -0
  1063. package/sdk/src/golden/fixtures/generate-slug.golden.json +1 -0
  1064. package/sdk/src/golden/fixtures/profile-sample-sessions/demo-project/sample.jsonl +3 -0
  1065. package/sdk/src/golden/fixtures/summary-extract-sample.md +26 -0
  1066. package/sdk/src/golden/fixtures/uat-render-checkpoint-sample.md +15 -0
  1067. package/sdk/src/golden/golden-integration-covered.ts +30 -0
  1068. package/sdk/src/golden/golden-mutation-covered.ts +17 -0
  1069. package/sdk/src/golden/golden-policy.test.ts +8 -0
  1070. package/sdk/src/golden/golden-policy.ts +120 -0
  1071. package/sdk/src/golden/golden.integration.test.ts +677 -0
  1072. package/sdk/src/golden/init-golden-normalize.ts +15 -0
  1073. package/sdk/src/golden/read-only-golden-rows.ts +77 -0
  1074. package/sdk/src/golden/read-only-parity.integration.test.ts +133 -0
  1075. package/sdk/src/golden/registry-canonical-commands.ts +31 -0
  1076. package/sdk/src/index.ts +352 -0
  1077. package/sdk/src/init-e2e.integration.test.ts +138 -0
  1078. package/sdk/src/init-runner.test.ts +740 -0
  1079. package/sdk/src/init-runner.ts +734 -0
  1080. package/sdk/src/lifecycle-e2e.integration.test.ts +258 -0
  1081. package/sdk/src/logger.test.ts +149 -0
  1082. package/sdk/src/logger.ts +113 -0
  1083. package/sdk/src/milestone-runner.test.ts +421 -0
  1084. package/sdk/src/model-catalog.ts +70 -0
  1085. package/sdk/src/phase-prompt.test.ts +535 -0
  1086. package/sdk/src/phase-prompt.ts +259 -0
  1087. package/sdk/src/phase-runner-types.test.ts +421 -0
  1088. package/sdk/src/phase-runner.integration.test.ts +377 -0
  1089. package/sdk/src/phase-runner.test.ts +2720 -0
  1090. package/sdk/src/phase-runner.ts +1442 -0
  1091. package/sdk/src/plan-parser.test.ts +579 -0
  1092. package/sdk/src/plan-parser.ts +431 -0
  1093. package/sdk/src/planning-journal.test.ts +70 -0
  1094. package/sdk/src/planning-journal.ts +153 -0
  1095. package/sdk/src/planning-runtime.test.ts +29 -0
  1096. package/sdk/src/planning-runtime.ts +100 -0
  1097. package/sdk/src/prompt-builder.test.ts +318 -0
  1098. package/sdk/src/prompt-builder.ts +218 -0
  1099. package/sdk/src/prompt-sanitizer.test.ts +260 -0
  1100. package/sdk/src/prompt-sanitizer.ts +116 -0
  1101. package/sdk/src/query/QUERY-HANDLERS.md +349 -0
  1102. package/sdk/src/query/active-workstream-store.ts +50 -0
  1103. package/sdk/src/query/agent-failure-classifier.test.ts +157 -0
  1104. package/sdk/src/query/agent-failure-classifier.ts +105 -0
  1105. package/sdk/src/query/audit-open.ts +722 -0
  1106. package/sdk/src/query/check-auto-mode.test.ts +77 -0
  1107. package/sdk/src/query/check-auto-mode.ts +49 -0
  1108. package/sdk/src/query/check-completion.test.ts +113 -0
  1109. package/sdk/src/query/check-completion.ts +182 -0
  1110. package/sdk/src/query/check-decision-coverage.test.ts +519 -0
  1111. package/sdk/src/query/check-decision-coverage.ts +554 -0
  1112. package/sdk/src/query/check-gates.test.ts +103 -0
  1113. package/sdk/src/query/check-gates.ts +112 -0
  1114. package/sdk/src/query/check-ship-ready.test.ts +111 -0
  1115. package/sdk/src/query/check-ship-ready.ts +104 -0
  1116. package/sdk/src/query/check-verification-status.test.ts +143 -0
  1117. package/sdk/src/query/check-verification-status.ts +160 -0
  1118. package/sdk/src/query/command-aliases.generated.ts +156 -0
  1119. package/sdk/src/query/command-catalog.ts +31 -0
  1120. package/sdk/src/query/command-definition.test.ts +47 -0
  1121. package/sdk/src/query/command-definition.ts +70 -0
  1122. package/sdk/src/query/command-family-handlers.ts +117 -0
  1123. package/sdk/src/query/command-manifest.init.ts +24 -0
  1124. package/sdk/src/query/command-manifest.non-family.ts +85 -0
  1125. package/sdk/src/query/command-manifest.phase.ts +16 -0
  1126. package/sdk/src/query/command-manifest.phases.ts +11 -0
  1127. package/sdk/src/query/command-manifest.roadmap.ts +11 -0
  1128. package/sdk/src/query/command-manifest.state.ts +31 -0
  1129. package/sdk/src/query/command-manifest.ts +17 -0
  1130. package/sdk/src/query/command-manifest.types.ts +13 -0
  1131. package/sdk/src/query/command-manifest.validate.ts +11 -0
  1132. package/sdk/src/query/command-manifest.verify.ts +15 -0
  1133. package/sdk/src/query/command-resolution.test.ts +70 -0
  1134. package/sdk/src/query/command-seam-coverage.test.ts +118 -0
  1135. package/sdk/src/query/command-static-catalog-domain.ts +117 -0
  1136. package/sdk/src/query/command-static-catalog-foundation.ts +103 -0
  1137. package/sdk/src/query/command-topology.test.ts +28 -0
  1138. package/sdk/src/query/command-topology.ts +114 -0
  1139. package/sdk/src/query/commands-list.test.ts +36 -0
  1140. package/sdk/src/query/commands-list.ts +19 -0
  1141. package/sdk/src/query/commit.test.ts +485 -0
  1142. package/sdk/src/query/commit.ts +383 -0
  1143. package/sdk/src/query/config-gates.test.ts +89 -0
  1144. package/sdk/src/query/config-gates.ts +69 -0
  1145. package/sdk/src/query/config-mutation.test.ts +598 -0
  1146. package/sdk/src/query/config-mutation.ts +575 -0
  1147. package/sdk/src/query/config-query.test.ts +367 -0
  1148. package/sdk/src/query/config-query.ts +244 -0
  1149. package/sdk/src/query/config-schema.ts +159 -0
  1150. package/sdk/src/query/decisions.test.ts +215 -0
  1151. package/sdk/src/query/decisions.ts +192 -0
  1152. package/sdk/src/query/decomposed-handlers.test.ts +431 -0
  1153. package/sdk/src/query/detect-custom-files.test.ts +115 -0
  1154. package/sdk/src/query/detect-custom-files.ts +96 -0
  1155. package/sdk/src/query/detect-phase-type.test.ts +105 -0
  1156. package/sdk/src/query/detect-phase-type.ts +141 -0
  1157. package/sdk/src/query/docs-init.ts +258 -0
  1158. package/sdk/src/query/fallow-audit.ts +88 -0
  1159. package/sdk/src/query/frontmatter-array.test.ts +14 -0
  1160. package/sdk/src/query/frontmatter-mutation.test.ts +259 -0
  1161. package/sdk/src/query/frontmatter-mutation.ts +343 -0
  1162. package/sdk/src/query/frontmatter.test.ts +326 -0
  1163. package/sdk/src/query/frontmatter.ts +395 -0
  1164. package/sdk/src/query/helpers.test.ts +615 -0
  1165. package/sdk/src/query/helpers.ts +646 -0
  1166. package/sdk/src/query/index-thin-seam.test.ts +16 -0
  1167. package/sdk/src/query/index.ts +9 -0
  1168. package/sdk/src/query/init-complex.test.ts +616 -0
  1169. package/sdk/src/query/init-complex.ts +799 -0
  1170. package/sdk/src/query/init-progress-precedence.test.ts +177 -0
  1171. package/sdk/src/query/init-workstream-milestone-op.test.ts +321 -0
  1172. package/sdk/src/query/init.test.ts +792 -0
  1173. package/sdk/src/query/init.ts +1262 -0
  1174. package/sdk/src/query/intel.test.ts +90 -0
  1175. package/sdk/src/query/intel.ts +404 -0
  1176. package/sdk/src/query/mutation-event-decorator.test.ts +45 -0
  1177. package/sdk/src/query/mutation-event-decorator.ts +37 -0
  1178. package/sdk/src/query/mutation-event-mapper.test.ts +33 -0
  1179. package/sdk/src/query/mutation-event-mapper.ts +102 -0
  1180. package/sdk/src/query/mvp.test.ts +335 -0
  1181. package/sdk/src/query/mvp.ts +292 -0
  1182. package/sdk/src/query/normalize-query-command.test.ts +102 -0
  1183. package/sdk/src/query/phase-filesystem-adapter.ts +35 -0
  1184. package/sdk/src/query/phase-lifecycle-policy.ts +171 -0
  1185. package/sdk/src/query/phase-lifecycle.test.ts +1750 -0
  1186. package/sdk/src/query/phase-lifecycle.ts +1833 -0
  1187. package/sdk/src/query/phase-list-queries.test.ts +88 -0
  1188. package/sdk/src/query/phase-list-queries.ts +152 -0
  1189. package/sdk/src/query/phase-ready.test.ts +65 -0
  1190. package/sdk/src/query/phase-ready.ts +159 -0
  1191. package/sdk/src/query/phase-roadmap-mutation.ts +77 -0
  1192. package/sdk/src/query/phase.test.ts +651 -0
  1193. package/sdk/src/query/phase.ts +550 -0
  1194. package/sdk/src/query/pipeline.test.ts +169 -0
  1195. package/sdk/src/query/pipeline.ts +243 -0
  1196. package/sdk/src/query/plan-scan.test.ts +35 -0
  1197. package/sdk/src/query/plan-scan.ts +82 -0
  1198. package/sdk/src/query/plan-task-structure.test.ts +65 -0
  1199. package/sdk/src/query/plan-task-structure.ts +63 -0
  1200. package/sdk/src/query/policy-convergence.test.ts +28 -0
  1201. package/sdk/src/query/profile-extract-messages.ts +247 -0
  1202. package/sdk/src/query/profile-output.ts +929 -0
  1203. package/sdk/src/query/profile-questionnaire-data.ts +181 -0
  1204. package/sdk/src/query/profile-sample.ts +184 -0
  1205. package/sdk/src/query/profile-scan-sessions.ts +174 -0
  1206. package/sdk/src/query/profile.test.ts +136 -0
  1207. package/sdk/src/query/profile.ts +337 -0
  1208. package/sdk/src/query/progress.test.ts +156 -0
  1209. package/sdk/src/query/progress.ts +566 -0
  1210. package/sdk/src/query/query-cli-adapter.test.ts +79 -0
  1211. package/sdk/src/query/query-cli-adapter.ts +39 -0
  1212. package/sdk/src/query/query-cli-output.test.ts +33 -0
  1213. package/sdk/src/query/query-cli-output.ts +35 -0
  1214. package/sdk/src/query/query-command-diagnosis.test.ts +22 -0
  1215. package/sdk/src/query/query-command-diagnosis.ts +5 -0
  1216. package/sdk/src/query/query-command-resolution-strategy.test.ts +34 -0
  1217. package/sdk/src/query/query-command-resolution-strategy.ts +121 -0
  1218. package/sdk/src/query/query-command-semantics.test.ts +22 -0
  1219. package/sdk/src/query/query-command-semantics.ts +22 -0
  1220. package/sdk/src/query/query-dispatch-contract.ts +30 -0
  1221. package/sdk/src/query/query-dispatch-error-mapper.test.ts +62 -0
  1222. package/sdk/src/query/query-dispatch-error-mapper.ts +5 -0
  1223. package/sdk/src/query/query-dispatch-formatting.test.ts +28 -0
  1224. package/sdk/src/query/query-dispatch-formatting.ts +5 -0
  1225. package/sdk/src/query/query-dispatch-input-validation.test.ts +23 -0
  1226. package/sdk/src/query/query-dispatch-input-validation.ts +5 -0
  1227. package/sdk/src/query/query-dispatch-observability.test.ts +10 -0
  1228. package/sdk/src/query/query-dispatch-observability.ts +6 -0
  1229. package/sdk/src/query/query-dispatch-plan.test.ts +25 -0
  1230. package/sdk/src/query/query-dispatch-plan.ts +5 -0
  1231. package/sdk/src/query/query-dispatch-result-builder.test.ts +16 -0
  1232. package/sdk/src/query/query-dispatch-result-builder.ts +5 -0
  1233. package/sdk/src/query/query-dispatch.test.ts +399 -0
  1234. package/sdk/src/query/query-dispatch.ts +243 -0
  1235. package/sdk/src/query/query-error-details-schema.ts +29 -0
  1236. package/sdk/src/query/query-error-taxonomy.test.ts +39 -0
  1237. package/sdk/src/query/query-error-taxonomy.ts +117 -0
  1238. package/sdk/src/query/query-fallback-bridge-adapter.test.ts +32 -0
  1239. package/sdk/src/query/query-fallback-bridge-adapter.ts +54 -0
  1240. package/sdk/src/query/query-fallback-executor.test.ts +82 -0
  1241. package/sdk/src/query/query-fallback-executor.ts +44 -0
  1242. package/sdk/src/query/query-fallback-output-classifier.test.ts +36 -0
  1243. package/sdk/src/query/query-fallback-output-classifier.ts +31 -0
  1244. package/sdk/src/query/query-fallback-policy.test.ts +13 -0
  1245. package/sdk/src/query/query-fallback-policy.ts +11 -0
  1246. package/sdk/src/query/query-native-dispatch-adapter.ts +16 -0
  1247. package/sdk/src/query/query-policy-capability.test.ts +10 -0
  1248. package/sdk/src/query/query-policy-capability.ts +26 -0
  1249. package/sdk/src/query/query-policy-snapshot.test.ts +9 -0
  1250. package/sdk/src/query/query-registry-capability.test.ts +14 -0
  1251. package/sdk/src/query/query-runtime-context.ts +44 -0
  1252. package/sdk/src/query/query-unknown-command-hints.test.ts +9 -0
  1253. package/sdk/src/query/query-unknown-command-hints.ts +5 -0
  1254. package/sdk/src/query/registry-assembly-descriptor.ts +87 -0
  1255. package/sdk/src/query/registry-assembly-invariants.ts +127 -0
  1256. package/sdk/src/query/registry-assembly.test.ts +138 -0
  1257. package/sdk/src/query/registry-assembly.ts +78 -0
  1258. package/sdk/src/query/registry.test.ts +208 -0
  1259. package/sdk/src/query/registry.ts +142 -0
  1260. package/sdk/src/query/requirements-extract-from-plans.test.ts +58 -0
  1261. package/sdk/src/query/requirements-extract-from-plans.ts +86 -0
  1262. package/sdk/src/query/roadmap-update-plan-progress.test.ts +233 -0
  1263. package/sdk/src/query/roadmap-update-plan-progress.ts +159 -0
  1264. package/sdk/src/query/roadmap.test.ts +1181 -0
  1265. package/sdk/src/query/roadmap.ts +894 -0
  1266. package/sdk/src/query/route-next-action.test.ts +61 -0
  1267. package/sdk/src/query/route-next-action.ts +345 -0
  1268. package/sdk/src/query/schema-detect.ts +189 -0
  1269. package/sdk/src/query/secrets.test.ts +66 -0
  1270. package/sdk/src/query/secrets.ts +43 -0
  1271. package/sdk/src/query/skill-manifest.test.ts +62 -0
  1272. package/sdk/src/query/skill-manifest.ts +216 -0
  1273. package/sdk/src/query/skills.test.ts +234 -0
  1274. package/sdk/src/query/skills.ts +143 -0
  1275. package/sdk/src/query/state-document.test.ts +197 -0
  1276. package/sdk/src/query/state-document.ts +129 -0
  1277. package/sdk/src/query/state-mutation.test.ts +1198 -0
  1278. package/sdk/src/query/state-mutation.ts +1718 -0
  1279. package/sdk/src/query/state-project-load.ts +80 -0
  1280. package/sdk/src/query/state.test.ts +616 -0
  1281. package/sdk/src/query/state.ts +463 -0
  1282. package/sdk/src/query/sub-repos-root.integration.test.ts +79 -0
  1283. package/sdk/src/query/summary.test.ts +95 -0
  1284. package/sdk/src/query/summary.ts +296 -0
  1285. package/sdk/src/query/template.test.ts +180 -0
  1286. package/sdk/src/query/template.ts +242 -0
  1287. package/sdk/src/query/uat.test.ts +77 -0
  1288. package/sdk/src/query/uat.ts +365 -0
  1289. package/sdk/src/query/utils.test.ts +82 -0
  1290. package/sdk/src/query/utils.ts +106 -0
  1291. package/sdk/src/query/validate.test.ts +831 -0
  1292. package/sdk/src/query/validate.ts +952 -0
  1293. package/sdk/src/query/verify.test.ts +414 -0
  1294. package/sdk/src/query/verify.ts +692 -0
  1295. package/sdk/src/query/websearch.test.ts +31 -0
  1296. package/sdk/src/query/websearch.ts +82 -0
  1297. package/sdk/src/query/workspace.test.ts +120 -0
  1298. package/sdk/src/query/workspace.ts +145 -0
  1299. package/sdk/src/query/workstream-inventory.ts +195 -0
  1300. package/sdk/src/query/workstream.test.ts +153 -0
  1301. package/sdk/src/query/workstream.ts +324 -0
  1302. package/sdk/src/query/worktree.ts +39 -0
  1303. package/sdk/src/query-command-executor.ts +31 -0
  1304. package/sdk/src/query-execution-policy.test.ts +52 -0
  1305. package/sdk/src/query-execution-policy.ts +46 -0
  1306. package/sdk/src/query-failure-classification.test.ts +23 -0
  1307. package/sdk/src/query-failure-classification.ts +42 -0
  1308. package/sdk/src/query-hotpath-methods.ts +48 -0
  1309. package/sdk/src/query-native-direct-adapter.test.ts +35 -0
  1310. package/sdk/src/query-native-direct-adapter.ts +70 -0
  1311. package/sdk/src/query-native-hotpath-adapter.test.ts +43 -0
  1312. package/sdk/src/query-native-hotpath-adapter.ts +45 -0
  1313. package/sdk/src/query-raw-output-projection.test.ts +39 -0
  1314. package/sdk/src/query-raw-output-projection.ts +74 -0
  1315. package/sdk/src/query-runtime-bridge.test.ts +150 -0
  1316. package/sdk/src/query-runtime-bridge.ts +215 -0
  1317. package/sdk/src/query-runtime-seam-coverage.test.ts +20 -0
  1318. package/sdk/src/query-sdd-tools-path.ts +1 -0
  1319. package/sdk/src/query-sdd-tools-runtime.ts +89 -0
  1320. package/sdk/src/query-subprocess-adapter.test.ts +84 -0
  1321. package/sdk/src/query-subprocess-adapter.ts +146 -0
  1322. package/sdk/src/query-tools-error-factory.test.ts +35 -0
  1323. package/sdk/src/query-tools-error-factory.ts +76 -0
  1324. package/sdk/src/research-gate.test.ts +190 -0
  1325. package/sdk/src/research-gate.ts +94 -0
  1326. package/sdk/src/runtime-bridge-options.test.ts +33 -0
  1327. package/sdk/src/runtime-gate.test.ts +84 -0
  1328. package/sdk/src/runtime-gate.ts +52 -0
  1329. package/sdk/src/sdd-tools-error.test.ts +21 -0
  1330. package/sdk/src/sdd-tools-error.ts +65 -0
  1331. package/sdk/src/sdd-tools.test.ts +472 -0
  1332. package/sdk/src/sdd-tools.ts +237 -0
  1333. package/sdk/src/sdd-transport-policy.test.ts +34 -0
  1334. package/sdk/src/sdd-transport-policy.ts +48 -0
  1335. package/sdk/src/sdd-transport.test.ts +292 -0
  1336. package/sdk/src/sdd-transport.ts +117 -0
  1337. package/sdk/src/sdk-package-compatibility.test.ts +97 -0
  1338. package/sdk/src/sdk-package-compatibility.ts +141 -0
  1339. package/sdk/src/session-runner.test.ts +164 -0
  1340. package/sdk/src/session-runner.ts +327 -0
  1341. package/sdk/src/tool-scoping.test.ts +160 -0
  1342. package/sdk/src/tool-scoping.ts +61 -0
  1343. package/sdk/src/types.ts +927 -0
  1344. package/sdk/src/workflow-agent-skills-consistency.test.ts +98 -0
  1345. package/sdk/src/workstream-name-policy.ts +24 -0
  1346. package/sdk/src/workstream-utils.ts +21 -0
  1347. package/sdk/src/ws-flag.test.ts +285 -0
  1348. package/sdk/src/ws-transport.test.ts +161 -0
  1349. package/sdk/src/ws-transport.ts +93 -0
  1350. package/sdk/tsconfig.json +20 -0
  1351. package/commands/sdd/add-backlog.md +0 -76
  1352. package/commands/sdd/add-phase.md +0 -43
  1353. package/commands/sdd/add-todo.md +0 -47
  1354. package/commands/sdd/analyze-dependencies.md +0 -34
  1355. package/commands/sdd/check-todos.md +0 -45
  1356. package/commands/sdd/code-review-fix.md +0 -52
  1357. package/commands/sdd/do.md +0 -30
  1358. package/commands/sdd/from-sdd2.md +0 -45
  1359. package/commands/sdd/insert-phase.md +0 -32
  1360. package/commands/sdd/intel.md +0 -179
  1361. package/commands/sdd/join-discord.md +0 -19
  1362. package/commands/sdd/list-phase-assumptions.md +0 -46
  1363. package/commands/sdd/list-workspaces.md +0 -19
  1364. package/commands/sdd/new-workspace.md +0 -44
  1365. package/commands/sdd/next.md +0 -26
  1366. package/commands/sdd/note.md +0 -34
  1367. package/commands/sdd/plan-milestone-gaps.md +0 -34
  1368. package/commands/sdd/plant-seed.md +0 -28
  1369. package/commands/sdd/remove-phase.md +0 -31
  1370. package/commands/sdd/remove-workspace.md +0 -26
  1371. package/commands/sdd/research-phase.md +0 -195
  1372. package/commands/sdd/scan.md +0 -26
  1373. package/commands/sdd/session-report.md +0 -19
  1374. package/commands/sdd/set-profile.md +0 -12
  1375. package/scripts/sync-upstream.sh +0 -56
  1376. package/sdd/workflows/research-phase.md +0 -82
@@ -5,7 +5,9 @@
5
5
  const fs = require('fs');
6
6
  const path = require('path');
7
7
  const os = require('os');
8
- const { safeReadFile, loadConfig, normalizePhaseName, escapeRegex, execGit, findPhaseInternal, getMilestoneInfo, stripShippedMilestones, extractCurrentMilestone, planningDir, output, error, checkAgentsInstalled, CONFIG_DEFAULTS } = require('./core.cjs');
8
+ const { loadConfig, normalizePhaseName, escapeRegex, findPhaseInternal, getMilestoneInfo, stripShippedMilestones, extractCurrentMilestone, output, error, checkAgentsInstalled, CONFIG_DEFAULTS, inspectWorktreeHealth } = require('./core.cjs');
9
+ const { execGit, platformReadSync: safeReadFile, platformWriteSync } = require('./shell-command-projection.cjs');
10
+ const { planningDir } = require('./planning-workspace.cjs');
9
11
  const { extractFrontmatter, parseMustHavesBlock } = require('./frontmatter.cjs');
10
12
  const { writeStateMd } = require('./state.cjs');
11
13
 
@@ -67,8 +69,8 @@ function cmdVerifySummary(cwd, summaryPath, checkFileCount, raw) {
67
69
  let commitsExist = false;
68
70
  if (hashes.length > 0) {
69
71
  for (const hash of hashes.slice(0, 3)) {
70
- const result = execGit(cwd, ['cat-file', '-t', hash]);
71
- if (result.exitCode === 0 && result.stdout === 'commit') {
72
+ const result = execGit(['cat-file', '-t', hash], { cwd });
73
+ if (result.exitCode === 0 && result.stdout.trim() === 'commit') {
72
74
  commitsExist = true;
73
75
  break;
74
76
  }
@@ -264,7 +266,7 @@ function cmdVerifyCommits(cwd, hashes, raw) {
264
266
  const valid = [];
265
267
  const invalid = [];
266
268
  for (const hash of hashes) {
267
- const result = execGit(cwd, ['cat-file', '-t', hash]);
269
+ const result = execGit(['cat-file', '-t', hash], { cwd });
268
270
  if (result.exitCode === 0 && result.stdout.trim() === 'commit') {
269
271
  valid.push(hash);
270
272
  } else {
@@ -395,9 +397,76 @@ function cmdVerifyKeyLinks(cwd, planFilePath, raw) {
395
397
  }, raw, verified === results.length ? 'valid' : 'invalid');
396
398
  }
397
399
 
400
+ const PHASE_TOKEN_FROM_DIR_RE = /^(?:[A-Z]{1,6}-)?(\d+[A-Z]?(?:\.\d+)*)(?:-|$)/i;
401
+ const MILESTONE_ARCHIVE_DIR_RE = /^v\d+.*-phases$/i;
402
+
403
+ function listMilestoneArchiveDirs(planBase) {
404
+ const milestonesDir = path.join(planBase, 'milestones');
405
+ try {
406
+ return fs.readdirSync(milestonesDir, { withFileTypes: true })
407
+ .filter((e) => e.isDirectory() && MILESTONE_ARCHIVE_DIR_RE.test(e.name))
408
+ .map((e) => path.join(milestonesDir, e.name))
409
+ .sort((a, b) => path.basename(a).localeCompare(path.basename(b), undefined, { numeric: true }));
410
+ } catch {
411
+ return [];
412
+ }
413
+ }
414
+
415
+ function getActiveMilestoneArchiveDir(planBase) {
416
+ const archiveDirs = listMilestoneArchiveDirs(planBase);
417
+ if (archiveDirs.length === 0) return null;
418
+
419
+ // Prefer STATE.md milestone when it maps to an on-disk archive dir.
420
+ try {
421
+ const statePath = path.join(planBase, 'STATE.md');
422
+ if (fs.existsSync(statePath)) {
423
+ const state = fs.readFileSync(statePath, 'utf-8');
424
+ const m = state.match(/^\s*(?:\*\*)?milestone(?:\*\*)?:\s*([^\s\r\n#]+).*$/mi);
425
+ if (m && m[1]) {
426
+ const milestone = m[1].trim();
427
+ const candidate = path.join(planBase, 'milestones', `${milestone}-phases`);
428
+ if (archiveDirs.includes(candidate)) return candidate;
429
+ }
430
+ }
431
+ } catch { /* intentionally empty */ }
432
+
433
+ // Fallback when STATE.md is absent/stale: highest (most recent) archive by version-ish name.
434
+ return archiveDirs[archiveDirs.length - 1];
435
+ }
436
+
437
+ function collectPhaseRoots(planBase) {
438
+ const roots = [];
439
+ const flatPhasesDir = path.join(planBase, 'phases');
440
+ if (fs.existsSync(flatPhasesDir)) roots.push(flatPhasesDir);
441
+ const activeArchive = getActiveMilestoneArchiveDir(planBase);
442
+ if (activeArchive) roots.push(activeArchive);
443
+ return roots;
444
+ }
445
+
446
+ // Returns a Set of phase numbers found on disk across active phase roots.
447
+ function collectDiskPhases(planBase) {
448
+ const diskPhases = new Set();
449
+ const phaseRoots = collectPhaseRoots(planBase);
450
+ const scanDir = (dir) => {
451
+ try {
452
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
453
+ for (const e of entries) {
454
+ if (e.isDirectory()) {
455
+ const m = e.name.match(PHASE_TOKEN_FROM_DIR_RE);
456
+ if (m) diskPhases.add(m[1]);
457
+ }
458
+ }
459
+ } catch { /* dir absent */ }
460
+ };
461
+
462
+ for (const root of phaseRoots) scanDir(root);
463
+
464
+ return diskPhases;
465
+ }
466
+
398
467
  function cmdValidateConsistency(cwd, raw) {
399
- const roadmapPath = path.join(planningDir(cwd), 'ROADMAP.md');
400
- const phasesDir = path.join(planningDir(cwd), 'phases');
468
+ const planBase = planningDir(cwd);
469
+ const roadmapPath = path.join(planBase, 'ROADMAP.md');
401
470
  const errors = [];
402
471
  const warnings = [];
403
472
 
@@ -419,16 +488,8 @@ function cmdValidateConsistency(cwd, raw) {
419
488
  roadmapPhases.add(m[1]);
420
489
  }
421
490
 
422
- // Get phases on disk
423
- const diskPhases = new Set();
424
- try {
425
- const entries = fs.readdirSync(phasesDir, { withFileTypes: true });
426
- const dirs = entries.filter(e => e.isDirectory()).map(e => e.name);
427
- for (const dir of dirs) {
428
- const dm = dir.match(/^(\d+[A-Z]?(?:\.\d+)*)/i);
429
- if (dm) diskPhases.add(dm[1]);
430
- }
431
- } catch { /* intentionally empty */ }
491
+ // Get phases on disk (flat layout + milestone-archive layout)
492
+ const diskPhases = collectDiskPhases(planBase);
432
493
 
433
494
  // Check: phases in ROADMAP but not on disk
434
495
  for (const p of roadmapPhases) {
@@ -460,60 +521,53 @@ function cmdValidateConsistency(cwd, raw) {
460
521
  }
461
522
  }
462
523
 
463
- // Check: plan numbering within phases
464
- try {
465
- const entries = fs.readdirSync(phasesDir, { withFileTypes: true });
466
- const dirs = entries.filter(e => e.isDirectory()).map(e => e.name).sort();
467
-
468
- for (const dir of dirs) {
469
- const phaseFiles = fs.readdirSync(path.join(phasesDir, dir));
470
- const plans = phaseFiles.filter(f => f.endsWith('-PLAN.md')).sort();
471
-
472
- // Extract plan numbers
473
- const planNums = plans.map(p => {
474
- const pm = p.match(/-(\d{2})-PLAN\.md$/);
475
- return pm ? parseInt(pm[1], 10) : null;
476
- }).filter(n => n !== null);
477
-
478
- for (let i = 1; i < planNums.length; i++) {
479
- if (planNums[i] !== planNums[i - 1] + 1) {
480
- warnings.push(`Gap in plan numbering in ${dir}: plan ${planNums[i - 1]} → ${planNums[i]}`);
524
+ const phaseRoots = collectPhaseRoots(planBase);
525
+ for (const phaseRoot of phaseRoots) {
526
+ try {
527
+ const entries = fs.readdirSync(phaseRoot, { withFileTypes: true });
528
+ const dirs = entries.filter(e => e.isDirectory()).map(e => e.name).sort();
529
+
530
+ for (const dir of dirs) {
531
+ const phasePath = path.join(phaseRoot, dir);
532
+ const phaseLabel = path.relative(planBase, phasePath).replace(/\\/g, '/');
533
+ const phaseFiles = fs.readdirSync(phasePath);
534
+ const plans = phaseFiles.filter(f => f.endsWith('-PLAN.md')).sort();
535
+
536
+ // Extract plan numbers
537
+ const planNums = plans.map(p => {
538
+ const pm = p.match(/-(\d{2})-PLAN\.md$/);
539
+ return pm ? parseInt(pm[1], 10) : null;
540
+ }).filter(n => n !== null);
541
+
542
+ for (let i = 1; i < planNums.length; i++) {
543
+ if (planNums[i] !== planNums[i - 1] + 1) {
544
+ warnings.push(`Gap in plan numbering in ${phaseLabel}: plan ${planNums[i - 1]} → ${planNums[i]}`);
545
+ }
481
546
  }
482
- }
483
547
 
484
- // Check: plans without summaries (completed plans)
485
- const summaries = phaseFiles.filter(f => f.endsWith('-SUMMARY.md'));
486
- const planIds = new Set(plans.map(p => p.replace('-PLAN.md', '')));
487
- const summaryIds = new Set(summaries.map(s => s.replace('-SUMMARY.md', '')));
548
+ // Check: plans without summaries (completed plans)
549
+ const summaries = phaseFiles.filter(f => f.endsWith('-SUMMARY.md'));
550
+ const planIds = new Set(plans.map(p => p.replace('-PLAN.md', '')));
551
+ const summaryIds = new Set(summaries.map(s => s.replace('-SUMMARY.md', '')));
488
552
 
489
- // Summary without matching plan is suspicious
490
- for (const sid of summaryIds) {
491
- if (!planIds.has(sid)) {
492
- warnings.push(`Summary ${sid}-SUMMARY.md in ${dir} has no matching PLAN.md`);
553
+ // Summary without matching plan is suspicious
554
+ for (const sid of summaryIds) {
555
+ if (!planIds.has(sid)) {
556
+ warnings.push(`Summary ${sid}-SUMMARY.md in ${phaseLabel} has no matching PLAN.md`);
557
+ }
493
558
  }
494
- }
495
- }
496
- } catch { /* intentionally empty */ }
497
559
 
498
- // Check: frontmatter in plans has required fields
499
- try {
500
- const entries = fs.readdirSync(phasesDir, { withFileTypes: true });
501
- const dirs = entries.filter(e => e.isDirectory()).map(e => e.name);
502
-
503
- for (const dir of dirs) {
504
- const phaseFiles = fs.readdirSync(path.join(phasesDir, dir));
505
- const plans = phaseFiles.filter(f => f.endsWith('-PLAN.md'));
506
-
507
- for (const plan of plans) {
508
- const content = fs.readFileSync(path.join(phasesDir, dir, plan), 'utf-8');
509
- const fm = extractFrontmatter(content);
510
-
511
- if (!fm.wave) {
512
- warnings.push(`${dir}/${plan}: missing 'wave' in frontmatter`);
560
+ // Check: frontmatter in plans has required fields
561
+ for (const plan of plans) {
562
+ const content = fs.readFileSync(path.join(phasePath, plan), 'utf-8');
563
+ const fm = extractFrontmatter(content);
564
+ if (!fm.wave) {
565
+ warnings.push(`${phaseLabel}/${plan}: missing 'wave' in frontmatter`);
566
+ }
513
567
  }
514
568
  }
515
- }
516
- } catch { /* intentionally empty */ }
569
+ } catch { /* intentionally empty */ }
570
+ }
517
571
 
518
572
  const passed = errors.length === 0;
519
573
  output({ passed, errors, warnings, warning_count: warnings.length }, raw, passed ? 'passed' : 'failed');
@@ -555,7 +609,7 @@ function cmdValidateHealth(cwd, options, raw) {
555
609
 
556
610
  // ─── Check 1: .planning/ exists ───────────────────────────────────────────
557
611
  if (!fs.existsSync(planBase)) {
558
- addIssue('error', 'E001', '.planning/ directory not found', 'Run /sdd-new-project to initialize');
612
+ addIssue('error', 'E001', '.planning/ directory not found', 'Run /sdd:new-project to initialize');
559
613
  output({
560
614
  status: 'broken',
561
615
  errors,
@@ -568,7 +622,7 @@ function cmdValidateHealth(cwd, options, raw) {
568
622
 
569
623
  // ─── Check 2: PROJECT.md exists and has required sections ─────────────────
570
624
  if (!fs.existsSync(projectPath)) {
571
- addIssue('error', 'E002', 'PROJECT.md not found', 'Run /sdd-new-project to create');
625
+ addIssue('error', 'E002', 'PROJECT.md not found', 'Run /sdd:new-project to create');
572
626
  } else {
573
627
  const content = fs.readFileSync(projectPath, 'utf-8');
574
628
  const requiredSections = ['## What This Is', '## Core Value', '## Requirements'];
@@ -581,39 +635,59 @@ function cmdValidateHealth(cwd, options, raw) {
581
635
 
582
636
  // ─── Check 3: ROADMAP.md exists ───────────────────────────────────────────
583
637
  if (!fs.existsSync(roadmapPath)) {
584
- addIssue('error', 'E003', 'ROADMAP.md not found', 'Run /sdd-new-milestone to create roadmap');
638
+ addIssue('error', 'E003', 'ROADMAP.md not found', 'Run /sdd:new-milestone to create roadmap');
585
639
  }
586
640
 
587
641
  // ─── Check 4: STATE.md exists and references valid phases ─────────────────
588
642
  if (!fs.existsSync(statePath)) {
589
- addIssue('error', 'E004', 'STATE.md not found', 'Run /sdd-health --repair to regenerate', true);
643
+ addIssue('error', 'E004', 'STATE.md not found', 'Run /sdd:health --repair to regenerate', true);
590
644
  repairs.push('regenerateState');
591
645
  } else {
592
646
  const stateContent = fs.readFileSync(statePath, 'utf-8');
593
647
  // Extract phase references from STATE.md
594
- const phaseRefs = [...stateContent.matchAll(/[Pp]hase\s+(\d+(?:\.\d+)*)/g)].map(m => m[1]);
595
- // Get disk phases
596
- const diskPhases = new Set();
648
+ const phaseRefs = [...stateContent.matchAll(/[Pp]hase\s+(\d+[A-Z]?(?:\.\d+)*)/g)].map(m => m[1]);
649
+ // Bug #2633 — ROADMAP.md is the authority for which phases are valid.
650
+ // STATE.md may legitimately reference current-milestone future phases
651
+ // (not yet materialized on disk) and shipped-milestone history phases
652
+ // (archived / cleared off disk). Matching only against on-disk dirs
653
+ // produces false W002 warnings in both cases.
654
+ const validPhases = collectDiskPhases(planBase);
655
+ // Union in every phase declared anywhere in ROADMAP.md (current + shipped + backlog).
597
656
  try {
598
- const entries = fs.readdirSync(phasesDir, { withFileTypes: true });
599
- for (const e of entries) {
600
- if (e.isDirectory()) {
601
- const m = e.name.match(/^(\d+(?:\.\d+)*)/);
602
- if (m) diskPhases.add(m[1]);
603
- }
657
+ if (fs.existsSync(roadmapPath)) {
658
+ const roadmapRaw = fs.readFileSync(roadmapPath, 'utf-8');
659
+ const all = [...roadmapRaw.matchAll(/#{2,4}\s*Phase\s+(\d+[A-Z]?(?:\.\d+)*)/gi)];
660
+ for (const m of all) validPhases.add(m[1]);
604
661
  }
605
662
  } catch { /* intentionally empty */ }
663
+ // Compare canonical full phase tokens. Also accept a leading-zero variant
664
+ // on the integer prefix only (e.g. "03" matching "3", "03.1" matching
665
+ // "3.1") so historic STATE.md formatting still validates. Suffix tokens
666
+ // like "3A" must match exactly — never collapsed to "3".
667
+ const normalizedValid = new Set();
668
+ for (const p of validPhases) {
669
+ normalizedValid.add(p);
670
+ const dotIdx = p.indexOf('.');
671
+ const head = dotIdx === -1 ? p : p.slice(0, dotIdx);
672
+ const tail = dotIdx === -1 ? '' : p.slice(dotIdx);
673
+ if (/^\d+$/.test(head)) {
674
+ normalizedValid.add(head.padStart(2, '0') + tail);
675
+ }
676
+ }
606
677
  // Check for invalid references
607
678
  for (const ref of phaseRefs) {
608
- const normalizedRef = String(parseInt(ref, 10)).padStart(2, '0');
609
- if (!diskPhases.has(ref) && !diskPhases.has(normalizedRef) && !diskPhases.has(String(parseInt(ref, 10)))) {
610
- // Only warn if phases dir has any content (not just an empty project)
611
- if (diskPhases.size > 0) {
679
+ const dotIdx = ref.indexOf('.');
680
+ const head = dotIdx === -1 ? ref : ref.slice(0, dotIdx);
681
+ const tail = dotIdx === -1 ? '' : ref.slice(dotIdx);
682
+ const padded = /^\d+$/.test(head) ? head.padStart(2, '0') + tail : ref;
683
+ if (!normalizedValid.has(ref) && !normalizedValid.has(padded)) {
684
+ // Only warn if we know any valid phases (not just an empty project)
685
+ if (normalizedValid.size > 0) {
612
686
  addIssue(
613
687
  'warning',
614
688
  'W002',
615
- `STATE.md references phase ${ref}, but only phases ${[...diskPhases].sort().join(', ')} exist`,
616
- 'Review STATE.md manually before changing it; /sdd-health --repair will not overwrite an existing STATE.md for phase mismatches'
689
+ `STATE.md references phase ${ref}, but only phases ${[...validPhases].sort().join(', ')} are declared`,
690
+ 'Review STATE.md manually before changing it; /sdd:health --repair will not overwrite an existing STATE.md for phase mismatches'
617
691
  );
618
692
  }
619
693
  }
@@ -622,7 +696,7 @@ function cmdValidateHealth(cwd, options, raw) {
622
696
 
623
697
  // ─── Check 5: config.json valid JSON + valid schema ───────────────────────
624
698
  if (!fs.existsSync(configPath)) {
625
- addIssue('warning', 'W003', 'config.json not found', 'Run /sdd-health --repair to create with defaults', true);
699
+ addIssue('warning', 'W003', 'config.json not found', 'Run /sdd:health --repair to create with defaults', true);
626
700
  repairs.push('createConfig');
627
701
  } else {
628
702
  try {
@@ -634,7 +708,7 @@ function cmdValidateHealth(cwd, options, raw) {
634
708
  addIssue('warning', 'W004', `config.json: invalid model_profile "${parsed.model_profile}"`, `Valid values: ${validProfiles.join(', ')}`);
635
709
  }
636
710
  } catch (err) {
637
- addIssue('error', 'E005', `config.json: JSON parse error - ${err.message}`, 'Run /sdd-health --repair to reset to defaults', true);
711
+ addIssue('error', 'E005', `config.json: JSON parse error - ${err.message}`, 'Run /sdd:health --repair to reset to defaults', true);
638
712
  repairs.push('resetConfig');
639
713
  }
640
714
  }
@@ -645,62 +719,65 @@ function cmdValidateHealth(cwd, options, raw) {
645
719
  const configRaw = fs.readFileSync(configPath, 'utf-8');
646
720
  const configParsed = JSON.parse(configRaw);
647
721
  if (configParsed.workflow && configParsed.workflow.nyquist_validation === undefined) {
648
- addIssue('warning', 'W008', 'config.json: workflow.nyquist_validation absent (defaults to enabled but agents may skip)', 'Run /sdd-health --repair to add key', true);
722
+ addIssue('warning', 'W008', 'config.json: workflow.nyquist_validation absent (defaults to enabled but agents may skip)', 'Run /sdd:health --repair to add key', true);
649
723
  if (!repairs.includes('addNyquistKey')) repairs.push('addNyquistKey');
650
724
  }
651
725
  if (configParsed.workflow && configParsed.workflow.ai_integration_phase === undefined) {
652
- addIssue('warning', 'W016', 'config.json: workflow.ai_integration_phase absent (defaults to enabled — run /sdd-ai-integration-phase before planning AI system phases)', 'Run /sdd-health --repair to add key', true);
726
+ addIssue('warning', 'W016', 'config.json: workflow.ai_integration_phase absent (defaults to enabled — run /sdd:ai-integration-phase before planning AI system phases)', 'Run /sdd:health --repair to add key', true);
653
727
  if (!repairs.includes('addAiIntegrationPhaseKey')) repairs.push('addAiIntegrationPhaseKey');
654
728
  }
655
729
  } catch { /* intentionally empty */ }
656
730
  }
657
731
 
658
- // ─── Check 6: Phase directory naming (NN-name format) ─────────────────────
732
+ // ─── Read phase directories once for checks 6, 7, 7b, and 8 (#1973) ──────
733
+ let phaseDirEntries = [];
734
+ const phaseDirFiles = new Map(); // phase dir name → file list
659
735
  try {
660
- const entries = fs.readdirSync(phasesDir, { withFileTypes: true });
661
- for (const e of entries) {
662
- if (e.isDirectory() && !e.name.match(/^\d{2}(?:\.\d+)*-[\w-]+$/)) {
663
- addIssue('warning', 'W005', `Phase directory "${e.name}" doesn't follow NN-name format`, 'Rename to match pattern (e.g., 01-setup)');
664
- }
736
+ phaseDirEntries = fs.readdirSync(phasesDir, { withFileTypes: true }).filter(e => e.isDirectory());
737
+ for (const e of phaseDirEntries) {
738
+ try {
739
+ phaseDirFiles.set(e.name, fs.readdirSync(path.join(phasesDir, e.name)));
740
+ } catch { phaseDirFiles.set(e.name, []); }
665
741
  }
666
742
  } catch { /* intentionally empty */ }
667
743
 
744
+ // ─── Check 6: Phase directory naming (NN-name format) ─────────────────────
745
+ for (const e of phaseDirEntries) {
746
+ if (!e.name.match(/^\d{2}(?:\.\d+)*-[\w-]+$/)) {
747
+ addIssue('warning', 'W005', `Phase directory "${e.name}" doesn't follow NN-name format`, 'Rename to match pattern (e.g., 01-setup)');
748
+ }
749
+ }
750
+
668
751
  // ─── Check 7: Orphaned plans (PLAN without SUMMARY) ───────────────────────
669
- try {
670
- const entries = fs.readdirSync(phasesDir, { withFileTypes: true });
671
- for (const e of entries) {
672
- if (!e.isDirectory()) continue;
673
- const phaseFiles = fs.readdirSync(path.join(phasesDir, e.name));
674
- const plans = phaseFiles.filter(f => f.endsWith('-PLAN.md') || f === 'PLAN.md');
675
- const summaries = phaseFiles.filter(f => f.endsWith('-SUMMARY.md') || f === 'SUMMARY.md');
676
- const summaryBases = new Set(summaries.map(s => s.replace('-SUMMARY.md', '').replace('SUMMARY.md', '')));
677
-
678
- for (const plan of plans) {
679
- const planBase = plan.replace('-PLAN.md', '').replace('PLAN.md', '');
680
- if (!summaryBases.has(planBase)) {
681
- addIssue('info', 'I001', `${e.name}/${plan} has no SUMMARY.md`, 'May be in progress');
682
- }
752
+ for (const e of phaseDirEntries) {
753
+ const phaseFiles = phaseDirFiles.get(e.name) || [];
754
+ const plans = phaseFiles.filter(f => f.endsWith('-PLAN.md') || f === 'PLAN.md');
755
+ const summaries = phaseFiles.filter(f => f.endsWith('-SUMMARY.md') || f === 'SUMMARY.md');
756
+ const summaryBases = new Set(summaries.map(s => s.replace('-SUMMARY.md', '').replace('SUMMARY.md', '')));
757
+
758
+ for (const plan of plans) {
759
+ const planBase = plan.replace('-PLAN.md', '').replace('PLAN.md', '');
760
+ if (!summaryBases.has(planBase)) {
761
+ addIssue('info', 'I001', `${e.name}/${plan} has no SUMMARY.md`, 'May be in progress');
683
762
  }
684
763
  }
685
- } catch { /* intentionally empty */ }
764
+ }
686
765
 
687
766
  // ─── Check 7b: Nyquist VALIDATION.md consistency ────────────────────────
688
- try {
689
- const phaseEntries = fs.readdirSync(phasesDir, { withFileTypes: true });
690
- for (const e of phaseEntries) {
691
- if (!e.isDirectory()) continue;
692
- const phaseFiles = fs.readdirSync(path.join(phasesDir, e.name));
693
- const hasResearch = phaseFiles.some(f => f.endsWith('-RESEARCH.md'));
694
- const hasValidation = phaseFiles.some(f => f.endsWith('-VALIDATION.md'));
695
- if (hasResearch && !hasValidation) {
696
- const researchFile = phaseFiles.find(f => f.endsWith('-RESEARCH.md'));
767
+ for (const e of phaseDirEntries) {
768
+ const phaseFiles = phaseDirFiles.get(e.name) || [];
769
+ const hasResearch = phaseFiles.some(f => f.endsWith('-RESEARCH.md'));
770
+ const hasValidation = phaseFiles.some(f => f.endsWith('-VALIDATION.md'));
771
+ if (hasResearch && !hasValidation) {
772
+ const researchFile = phaseFiles.find(f => f.endsWith('-RESEARCH.md'));
773
+ try {
697
774
  const researchContent = fs.readFileSync(path.join(phasesDir, e.name, researchFile), 'utf-8');
698
775
  if (researchContent.includes('## Validation Architecture')) {
699
- addIssue('warning', 'W009', `Phase ${e.name}: has Validation Architecture in RESEARCH.md but no VALIDATION.md`, 'Re-run /sdd-plan-phase with --research to regenerate');
776
+ addIssue('warning', 'W009', `Phase ${e.name}: has Validation Architecture in RESEARCH.md but no VALIDATION.md`, 'Re-run /sdd:plan-phase with --research to regenerate');
700
777
  }
701
- }
778
+ } catch { /* intentionally empty */ }
702
779
  }
703
- } catch { /* intentionally empty */ }
780
+ }
704
781
 
705
782
  // ─── Check 7c: Agent installation (#1371) ──────────────────────────────────
706
783
  // Verify SDD agents are installed. Missing agents cause Task(subagent_type=...)
@@ -732,16 +809,7 @@ function cmdValidateHealth(cwd, options, raw) {
732
809
  roadmapPhases.add(m[1]);
733
810
  }
734
811
 
735
- const diskPhases = new Set();
736
- try {
737
- const entries = fs.readdirSync(phasesDir, { withFileTypes: true });
738
- for (const e of entries) {
739
- if (e.isDirectory()) {
740
- const dm = e.name.match(/^(\d+[A-Z]?(?:\.\d+)*)/i);
741
- if (dm) diskPhases.add(dm[1]);
742
- }
743
- }
744
- } catch { /* intentionally empty */ }
812
+ const diskPhases = collectDiskPhases(planBase);
745
813
 
746
814
  // Build a set of phases explicitly marked not-yet-started in the ROADMAP
747
815
  // summary list (- [ ] **Phase N:**). These phases are intentionally absent
@@ -794,7 +862,7 @@ function cmdValidateHealth(cwd, options, raw) {
794
862
  if (statusVal !== 'complete' && statusVal !== 'done') {
795
863
  addIssue('warning', 'W011',
796
864
  `STATE.md says current phase is ${statePhase} (status: ${statusVal || 'unknown'}) but ROADMAP.md shows it as [x] complete — state files may be out of sync`,
797
- 'Run /sdd-progress to re-derive current position, or manually update STATE.md');
865
+ 'Run /sdd:progress to re-derive current position, or manually update STATE.md');
798
866
  }
799
867
  }
800
868
  }
@@ -839,6 +907,94 @@ function cmdValidateHealth(cwd, options, raw) {
839
907
  } catch { /* parse error already caught in Check 5 */ }
840
908
  }
841
909
 
910
+ // ─── Check 11: Stale / orphan git worktrees (#2167) ────────────────────────
911
+ try {
912
+ const worktreeHealth = inspectWorktreeHealth(
913
+ cwd,
914
+ { staleAfterMs: 60 * 60 * 1000 },
915
+ { execGit, existsSync: fs.existsSync, statSync: fs.statSync }
916
+ );
917
+ if (!worktreeHealth.ok) {
918
+ // AC2 / AC3: surface degraded-git state as a structured warning instead
919
+ // of silently suppressing it (PRED.k302 — error-swallowing-empty-sentinel).
920
+ if (worktreeHealth.reason === 'git_timed_out') {
921
+ addIssue('warning', 'W020',
922
+ 'Worktree health check degraded: git worktree list timed out after 10s — orphan/stale worktrees could not be inspected',
923
+ 'Run: git worktree list --porcelain to diagnose; check for .git/index.lock or a hung git process');
924
+ }
925
+ if (worktreeHealth.reason === 'git_list_failed') {
926
+ addIssue('warning', 'W020',
927
+ 'Worktree health check degraded: git worktree list failed — orphan/stale worktrees could not be inspected',
928
+ 'Run: git worktree list --porcelain to diagnose; check git repository state and permissions');
929
+ }
930
+ // Other non-ok reasons (not_a_git_repo) are silent — not meaningful for
931
+ // users who have no git repo.
932
+ } else {
933
+ for (const finding of worktreeHealth.findings) {
934
+ if (finding.kind === 'orphan') {
935
+ addIssue('warning', 'W017',
936
+ `Orphan git worktree: ${finding.path} (path no longer exists on disk)`,
937
+ 'Run: git worktree prune');
938
+ continue;
939
+ }
940
+
941
+ if (finding.kind === 'stale') {
942
+ addIssue('warning', 'W017',
943
+ `Stale git worktree: ${finding.path} (last modified ${finding.ageMinutes} minutes ago)`,
944
+ `Run: git worktree remove ${finding.path} --force`);
945
+ }
946
+ }
947
+ }
948
+ } catch { /* git worktree not available or not a git repo — skip silently */ }
949
+
950
+ // ─── Check 12: MILESTONES.md / archive snapshot drift (#2446) ─────────────
951
+ const milestonesPath = path.join(planBase, 'MILESTONES.md');
952
+ const milestonesArchiveDir = path.join(planBase, 'milestones');
953
+ const missingFromRegistry = [];
954
+ try {
955
+ if (fs.existsSync(milestonesArchiveDir)) {
956
+ const archiveFiles = fs.readdirSync(milestonesArchiveDir);
957
+ const archivedVersions = archiveFiles
958
+ .map(f => f.match(/^(v\d+\.\d+(?:\.\d+)?)-ROADMAP\.md$/))
959
+ .filter(Boolean)
960
+ .map(m => m[1]);
961
+
962
+ if (archivedVersions.length > 0) {
963
+ const registryContent = fs.existsSync(milestonesPath)
964
+ ? fs.readFileSync(milestonesPath, 'utf-8')
965
+ : '';
966
+ for (const ver of archivedVersions) {
967
+ if (!registryContent.includes(`## ${ver}`)) {
968
+ missingFromRegistry.push(ver);
969
+ }
970
+ }
971
+ if (missingFromRegistry.length > 0) {
972
+ addIssue('warning', 'W018',
973
+ `MILESTONES.md missing ${missingFromRegistry.length} archived milestone(s): ${missingFromRegistry.join(', ')}`,
974
+ 'Run /sdd:health --backfill to synthesize missing entries from archive snapshots',
975
+ true);
976
+ repairs.push('backfillMilestones');
977
+ }
978
+ }
979
+ }
980
+ } catch { /* intentionally empty — milestone sync check is advisory */ }
981
+
982
+ // ─── Check 13: Unrecognized .planning/ root files (W019) ──────────────────
983
+ try {
984
+ const { isCanonicalPlanningFile } = require('./artifacts.cjs');
985
+ const entries = fs.readdirSync(planBase, { withFileTypes: true });
986
+ for (const entry of entries) {
987
+ if (!entry.isFile()) continue;
988
+ if (!entry.name.endsWith('.md')) continue;
989
+ if (!isCanonicalPlanningFile(entry.name)) {
990
+ addIssue('warning', 'W019',
991
+ `Unrecognized .planning/ file: ${entry.name} — not a canonical SDD artifact`,
992
+ 'Move to .planning/milestones/ archive subdir or delete if stale. See templates/README.md for the canonical artifact list.',
993
+ false);
994
+ }
995
+ }
996
+ } catch { /* artifact check is advisory — skip on error */ }
997
+
842
998
  // ─── Perform repairs if requested ─────────────────────────────────────────
843
999
  const repairActions = [];
844
1000
  if (options.repair && repairs.length > 0) {
@@ -864,7 +1020,7 @@ function cmdValidateHealth(cwd, options, raw) {
864
1020
  parallelization: CONFIG_DEFAULTS.parallelization,
865
1021
  brave_search: CONFIG_DEFAULTS.brave_search,
866
1022
  };
867
- fs.writeFileSync(configPath, JSON.stringify(defaults, null, 2), 'utf-8');
1023
+ platformWriteSync(configPath, JSON.stringify(defaults, null, 2));
868
1024
  repairActions.push({ action: repair, success: true, path: 'config.json' });
869
1025
  break;
870
1026
  }
@@ -889,7 +1045,7 @@ function cmdValidateHealth(cwd, options, raw) {
889
1045
  stateContent += `**Current phase:** (determining...)\n`;
890
1046
  stateContent += `**Status:** Resuming\n\n`;
891
1047
  stateContent += `## Session Log\n\n`;
892
- stateContent += `- ${new Date().toISOString().split('T')[0]}: STATE.md regenerated by /sdd-health --repair\n`;
1048
+ stateContent += `- ${new Date().toISOString().split('T')[0]}: STATE.md regenerated by /sdd:health --repair\n`;
893
1049
  writeStateMd(statePath, stateContent, cwd);
894
1050
  repairActions.push({ action: repair, success: true, path: 'STATE.md' });
895
1051
  break;
@@ -902,7 +1058,7 @@ function cmdValidateHealth(cwd, options, raw) {
902
1058
  if (!configParsed.workflow) configParsed.workflow = {};
903
1059
  if (configParsed.workflow.nyquist_validation === undefined) {
904
1060
  configParsed.workflow.nyquist_validation = true;
905
- fs.writeFileSync(configPath, JSON.stringify(configParsed, null, 2), 'utf-8');
1061
+ platformWriteSync(configPath, JSON.stringify(configParsed, null, 2));
906
1062
  }
907
1063
  repairActions.push({ action: repair, success: true, path: 'config.json' });
908
1064
  } catch (err) {
@@ -919,7 +1075,7 @@ function cmdValidateHealth(cwd, options, raw) {
919
1075
  if (!configParsed.workflow) configParsed.workflow = {};
920
1076
  if (configParsed.workflow.ai_integration_phase === undefined) {
921
1077
  configParsed.workflow.ai_integration_phase = true;
922
- fs.writeFileSync(configPath, JSON.stringify(configParsed, null, 2), 'utf-8');
1078
+ platformWriteSync(configPath, JSON.stringify(configParsed, null, 2));
923
1079
  }
924
1080
  repairActions.push({ action: repair, success: true, path: 'config.json' });
925
1081
  } catch (err) {
@@ -928,6 +1084,39 @@ function cmdValidateHealth(cwd, options, raw) {
928
1084
  }
929
1085
  break;
930
1086
  }
1087
+ case 'backfillMilestones': {
1088
+ if (!options.backfill && !options.repair) break;
1089
+ const today = new Date().toISOString().split('T')[0];
1090
+ let backfilled = 0;
1091
+ for (const ver of missingFromRegistry) {
1092
+ try {
1093
+ const snapshotPath = path.join(milestonesArchiveDir, `${ver}-ROADMAP.md`);
1094
+ const snapshot = safeReadFile(snapshotPath);
1095
+ // Build minimal entry from snapshot title or version
1096
+ const titleMatch = snapshot && snapshot.match(/^#\s+(.+)$/m);
1097
+ const milestoneName = titleMatch ? titleMatch[1].replace(/^Milestone\s+/i, '').replace(/^v[\d.]+\s*/, '').trim() : ver;
1098
+ const entry = `## ${ver}${milestoneName && milestoneName !== ver ? ` ${milestoneName}` : ''} (Backfilled: ${today})\n\n**Note:** Synthesized from archive snapshot by \`/sdd:health --backfill\`. Original completion date unknown.\n\n---\n\n`;
1099
+ const milestonesContent = fs.existsSync(milestonesPath)
1100
+ ? fs.readFileSync(milestonesPath, 'utf-8')
1101
+ : '';
1102
+ if (!milestonesContent.trim()) {
1103
+ platformWriteSync(milestonesPath, `# Milestones\n\n${entry}`);
1104
+ } else {
1105
+ const headerMatch = milestonesContent.match(/^(#{1,3}\s+[^\n]*\n\n?)/);
1106
+ if (headerMatch) {
1107
+ const header = headerMatch[1];
1108
+ const rest = milestonesContent.slice(header.length);
1109
+ platformWriteSync(milestonesPath, header + entry + rest);
1110
+ } else {
1111
+ platformWriteSync(milestonesPath, entry + milestonesContent);
1112
+ }
1113
+ }
1114
+ backfilled++;
1115
+ } catch { /* intentionally empty — partial backfill is acceptable */ }
1116
+ }
1117
+ repairActions.push({ action: repair, success: true, detail: `Backfilled ${backfilled} milestone(s) into MILESTONES.md` });
1118
+ break;
1119
+ }
931
1120
  }
932
1121
  } catch (err) {
933
1122
  repairActions.push({ action: repair, success: false, error: err.message });
@@ -948,14 +1137,16 @@ function cmdValidateHealth(cwd, options, raw) {
948
1137
  const repairableCount = errors.filter(e => e.repairable).length +
949
1138
  warnings.filter(w => w.repairable).length;
950
1139
 
951
- output({
1140
+ const result = {
952
1141
  status,
953
1142
  errors,
954
1143
  warnings,
955
1144
  info,
956
1145
  repairable_count: repairableCount,
957
1146
  repairs_performed: repairActions.length > 0 ? repairActions : undefined,
958
- }, raw);
1147
+ };
1148
+ output(result, raw);
1149
+ return result;
959
1150
  }
960
1151
 
961
1152
  /**
@@ -1036,7 +1227,7 @@ function cmdVerifySchemaDrift(cwd, phaseArg, skipFlag, raw) {
1036
1227
  }
1037
1228
 
1038
1229
  // Also check git commit messages for push evidence
1039
- const gitLog = execGit(cwd, ['log', '--oneline', '--all', '-50']);
1230
+ const gitLog = execGit(['log', '--oneline', '--all', '-50'], { cwd });
1040
1231
  if (gitLog.exitCode === 0) {
1041
1232
  executionLog += '\n' + gitLog.stdout;
1042
1233
  }
@@ -1054,6 +1245,141 @@ function cmdVerifySchemaDrift(cwd, phaseArg, skipFlag, raw) {
1054
1245
  }, raw);
1055
1246
  }
1056
1247
 
1248
+ // ─── Codebase Drift Detection (#2003) ────────────────────────────────────────
1249
+
1250
+ /**
1251
+ * Detect structural drift between the committed tree and
1252
+ * `.planning/codebase/STRUCTURE.md`. Non-blocking: any failure returns a
1253
+ * `{ skipped: true }` JSON result with a reason; the command never exits
1254
+ * non-zero so `execute-phase`'s drift gate cannot fail the phase.
1255
+ */
1256
+ function cmdVerifyCodebaseDrift(cwd, raw) {
1257
+ const drift = require('./drift.cjs');
1258
+
1259
+ const emit = (payload) => output(payload, raw);
1260
+
1261
+ try {
1262
+ const codebaseDir = path.join(planningDir(cwd), 'codebase');
1263
+ const structurePath = path.join(codebaseDir, 'STRUCTURE.md');
1264
+ if (!fs.existsSync(structurePath)) {
1265
+ emit({
1266
+ skipped: true,
1267
+ reason: 'no-structure-md',
1268
+ action_required: false,
1269
+ directive: 'none',
1270
+ elements: [],
1271
+ });
1272
+ return;
1273
+ }
1274
+
1275
+ let structureMd;
1276
+ try {
1277
+ structureMd = fs.readFileSync(structurePath, 'utf-8');
1278
+ } catch (err) {
1279
+ emit({
1280
+ skipped: true,
1281
+ reason: 'cannot-read-structure-md: ' + err.message,
1282
+ action_required: false,
1283
+ directive: 'none',
1284
+ elements: [],
1285
+ });
1286
+ return;
1287
+ }
1288
+
1289
+ const lastMapped = drift.readMappedCommit(structurePath);
1290
+
1291
+ // Verify we're inside a git repo and resolve the diff range.
1292
+ const revProbe = execGit(['rev-parse', 'HEAD'], { cwd });
1293
+ if (revProbe.exitCode !== 0) {
1294
+ emit({
1295
+ skipped: true,
1296
+ reason: 'not-a-git-repo',
1297
+ action_required: false,
1298
+ directive: 'none',
1299
+ elements: [],
1300
+ });
1301
+ return;
1302
+ }
1303
+
1304
+ // Empty-tree SHA is a stable fallback when no mapping commit is recorded.
1305
+ const EMPTY_TREE = '4b825dc642cb6eb9a060e54bf8d69288fbee4904';
1306
+ let base = lastMapped;
1307
+ if (!base) {
1308
+ base = EMPTY_TREE;
1309
+ } else {
1310
+ // Verify the commit is reachable; if not, fall back to EMPTY_TREE.
1311
+ const verify = execGit(['cat-file', '-t', base], { cwd });
1312
+ if (verify.exitCode !== 0) base = EMPTY_TREE;
1313
+ }
1314
+
1315
+ const diff = execGit(['diff', '--name-status', base, 'HEAD'], { cwd });
1316
+ if (diff.exitCode !== 0) {
1317
+ emit({
1318
+ skipped: true,
1319
+ reason: 'git-diff-failed',
1320
+ action_required: false,
1321
+ directive: 'none',
1322
+ elements: [],
1323
+ });
1324
+ return;
1325
+ }
1326
+
1327
+ const added = [];
1328
+ const modified = [];
1329
+ const deleted = [];
1330
+ for (const line of diff.stdout.split(/\r?\n/)) {
1331
+ if (!line.trim()) continue;
1332
+ const m = line.match(/^([A-Z])\d*\t(.+?)(?:\t(.+))?$/);
1333
+ if (!m) continue;
1334
+ const status = m[1];
1335
+ // For renames (R), use the new path (m[3] if present, else m[2]).
1336
+ const file = m[3] || m[2];
1337
+ if (status === 'A' || status === 'R' || status === 'C') added.push(file);
1338
+ else if (status === 'M') modified.push(file);
1339
+ else if (status === 'D') deleted.push(file);
1340
+ }
1341
+
1342
+ // Threshold and action read from config, with defaults.
1343
+ const config = loadConfig(cwd);
1344
+ const threshold = Number.isInteger(config?.workflow?.drift_threshold) && config.workflow.drift_threshold >= 1
1345
+ ? config.workflow.drift_threshold
1346
+ : 3;
1347
+ const action = config?.workflow?.drift_action === 'auto-remap' ? 'auto-remap' : 'warn';
1348
+
1349
+ const result = drift.detectDrift({
1350
+ addedFiles: added,
1351
+ modifiedFiles: modified,
1352
+ deletedFiles: deleted,
1353
+ structureMd,
1354
+ threshold,
1355
+ action,
1356
+ });
1357
+
1358
+ emit({
1359
+ skipped: !!result.skipped,
1360
+ reason: result.reason || null,
1361
+ action_required: !!result.actionRequired,
1362
+ directive: result.directive,
1363
+ spawn_mapper: !!result.spawnMapper,
1364
+ affected_paths: result.affectedPaths || [],
1365
+ elements: result.elements || [],
1366
+ threshold,
1367
+ action,
1368
+ last_mapped_commit: lastMapped,
1369
+ message: result.message || '',
1370
+ });
1371
+ } catch (err) {
1372
+ // Non-blocking: never bubble up an exception.
1373
+ emit({
1374
+ skipped: true,
1375
+ reason: 'exception: ' + (err && err.message ? err.message : String(err)),
1376
+ action_required: false,
1377
+ directive: 'none',
1378
+ elements: [],
1379
+ });
1380
+ }
1381
+ }
1382
+
1057
1383
  module.exports = {
1058
1384
  cmdVerifySummary,
1059
1385
  cmdVerifyPlanStructure,
@@ -1066,4 +1392,5 @@ module.exports = {
1066
1392
  cmdValidateHealth,
1067
1393
  cmdValidateAgents,
1068
1394
  cmdVerifySchemaDrift,
1395
+ cmdVerifyCodebaseDrift,
1069
1396
  };