@therocketcode/gsd-core 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (568) hide show
  1. package/.claude-plugin/plugin.json +23 -0
  2. package/GEMINI.md +53 -0
  3. package/LICENSE +21 -0
  4. package/README.ja-JP.md +125 -0
  5. package/README.ko-KR.md +125 -0
  6. package/README.md +144 -0
  7. package/README.pt-BR.md +125 -0
  8. package/README.zh-CN.md +125 -0
  9. package/agents/gsd-advisor-researcher.md +108 -0
  10. package/agents/gsd-ai-researcher.md +114 -0
  11. package/agents/gsd-assumptions-analyzer.md +105 -0
  12. package/agents/gsd-code-fixer.md +668 -0
  13. package/agents/gsd-code-reviewer.md +387 -0
  14. package/agents/gsd-codebase-mapper.md +853 -0
  15. package/agents/gsd-debug-session-manager.md +314 -0
  16. package/agents/gsd-debugger.md +1452 -0
  17. package/agents/gsd-doc-classifier.md +168 -0
  18. package/agents/gsd-doc-synthesizer.md +204 -0
  19. package/agents/gsd-doc-verifier.md +217 -0
  20. package/agents/gsd-doc-writer.md +616 -0
  21. package/agents/gsd-domain-researcher.md +147 -0
  22. package/agents/gsd-eval-auditor.md +191 -0
  23. package/agents/gsd-eval-planner.md +154 -0
  24. package/agents/gsd-executor.md +785 -0
  25. package/agents/gsd-framework-selector.md +160 -0
  26. package/agents/gsd-integration-checker.md +470 -0
  27. package/agents/gsd-intel-updater.md +342 -0
  28. package/agents/gsd-nyquist-auditor.md +203 -0
  29. package/agents/gsd-pattern-mapper.md +335 -0
  30. package/agents/gsd-phase-researcher.md +867 -0
  31. package/agents/gsd-plan-checker.md +978 -0
  32. package/agents/gsd-planner.md +1204 -0
  33. package/agents/gsd-project-researcher.md +611 -0
  34. package/agents/gsd-research-synthesizer.md +259 -0
  35. package/agents/gsd-roadmapper.md +688 -0
  36. package/agents/gsd-security-auditor.md +155 -0
  37. package/agents/gsd-ui-auditor.md +495 -0
  38. package/agents/gsd-ui-checker.md +309 -0
  39. package/agents/gsd-ui-researcher.md +374 -0
  40. package/agents/gsd-user-profiler.md +171 -0
  41. package/agents/gsd-verifier.md +923 -0
  42. package/assets/gsd-logo-2000-transparent.png +0 -0
  43. package/assets/gsd-logo-2000-transparent.svg +17 -0
  44. package/assets/gsd-logo-2000.png +0 -0
  45. package/assets/gsd-logo-2000.svg +21 -0
  46. package/assets/terminal.svg +68 -0
  47. package/bin/install.js +12726 -0
  48. package/bin/lib/ui-safety-gate.cjs +107 -0
  49. package/commands/gsd/add-tests.md +42 -0
  50. package/commands/gsd/ai-integration-phase.md +37 -0
  51. package/commands/gsd/audit-fix.md +34 -0
  52. package/commands/gsd/audit-milestone.md +37 -0
  53. package/commands/gsd/audit-uat.md +24 -0
  54. package/commands/gsd/autonomous.md +48 -0
  55. package/commands/gsd/capture.md +62 -0
  56. package/commands/gsd/cleanup.md +24 -0
  57. package/commands/gsd/code-review.md +59 -0
  58. package/commands/gsd/complete-milestone.md +143 -0
  59. package/commands/gsd/config.md +56 -0
  60. package/commands/gsd/debug.md +52 -0
  61. package/commands/gsd/discover-product.md +65 -0
  62. package/commands/gsd/discuss-phase.md +77 -0
  63. package/commands/gsd/docs-update.md +49 -0
  64. package/commands/gsd/eval-review.md +33 -0
  65. package/commands/gsd/execute-phase.md +66 -0
  66. package/commands/gsd/explore.md +27 -0
  67. package/commands/gsd/extract-learnings.md +23 -0
  68. package/commands/gsd/fast.md +31 -0
  69. package/commands/gsd/forensics.md +57 -0
  70. package/commands/gsd/graphify.md +204 -0
  71. package/commands/gsd/health.md +31 -0
  72. package/commands/gsd/help.md +28 -0
  73. package/commands/gsd/import.md +45 -0
  74. package/commands/gsd/inbox.md +39 -0
  75. package/commands/gsd/ingest-docs.md +42 -0
  76. package/commands/gsd/manager.md +45 -0
  77. package/commands/gsd/map-codebase.md +83 -0
  78. package/commands/gsd/milestone-summary.md +51 -0
  79. package/commands/gsd/model-domain.md +65 -0
  80. package/commands/gsd/mvp-phase.md +45 -0
  81. package/commands/gsd/new-milestone.md +45 -0
  82. package/commands/gsd/new-project.md +47 -0
  83. package/commands/gsd/ns-context.md +23 -0
  84. package/commands/gsd/ns-ideate.md +24 -0
  85. package/commands/gsd/ns-manage.md +29 -0
  86. package/commands/gsd/ns-project.md +22 -0
  87. package/commands/gsd/ns-review.md +26 -0
  88. package/commands/gsd/ns-workflow.md +28 -0
  89. package/commands/gsd/pause-work.md +43 -0
  90. package/commands/gsd/phase.md +56 -0
  91. package/commands/gsd/plan-phase.md +64 -0
  92. package/commands/gsd/plan-review-convergence.md +59 -0
  93. package/commands/gsd/pr-branch.md +26 -0
  94. package/commands/gsd/profile-user.md +46 -0
  95. package/commands/gsd/progress.md +48 -0
  96. package/commands/gsd/quick.md +174 -0
  97. package/commands/gsd/recommend-architecture.md +64 -0
  98. package/commands/gsd/resume-work.md +30 -0
  99. package/commands/gsd/review-backlog.md +63 -0
  100. package/commands/gsd/review.md +42 -0
  101. package/commands/gsd/secure-phase.md +36 -0
  102. package/commands/gsd/settings.md +29 -0
  103. package/commands/gsd/ship.md +24 -0
  104. package/commands/gsd/sketch.md +60 -0
  105. package/commands/gsd/spec-phase.md +63 -0
  106. package/commands/gsd/spike.md +57 -0
  107. package/commands/gsd/stats.md +20 -0
  108. package/commands/gsd/surface.md +155 -0
  109. package/commands/gsd/testing-strategy.md +65 -0
  110. package/commands/gsd/thread.md +24 -0
  111. package/commands/gsd/ui-phase.md +35 -0
  112. package/commands/gsd/ui-review.md +33 -0
  113. package/commands/gsd/ultraplan-phase.md +34 -0
  114. package/commands/gsd/undo.md +35 -0
  115. package/commands/gsd/update.md +49 -0
  116. package/commands/gsd/validate-phase.md +36 -0
  117. package/commands/gsd/verify-work.md +39 -0
  118. package/commands/gsd/workspace.md +52 -0
  119. package/commands/gsd/workstreams.md +70 -0
  120. package/gemini-extension.json +6 -0
  121. package/gsd-core/bin/check-latest-version.cjs +161 -0
  122. package/gsd-core/bin/gsd-tools.cjs +1928 -0
  123. package/gsd-core/bin/lib/active-workstream-store.cjs +291 -0
  124. package/gsd-core/bin/lib/adr-parser.cjs +399 -0
  125. package/gsd-core/bin/lib/agent-command-router.cjs +68 -0
  126. package/gsd-core/bin/lib/artifacts.cjs +51 -0
  127. package/gsd-core/bin/lib/audit.cjs +743 -0
  128. package/gsd-core/bin/lib/check-command-router.cjs +343 -0
  129. package/gsd-core/bin/lib/cjs-command-router-adapter.cjs +81 -0
  130. package/gsd-core/bin/lib/cli-exit.cjs +42 -0
  131. package/gsd-core/bin/lib/clock.cjs +95 -0
  132. package/gsd-core/bin/lib/clusters.cjs +132 -0
  133. package/gsd-core/bin/lib/code-review-flags.cjs +59 -0
  134. package/gsd-core/bin/lib/command-aliases.cjs +809 -0
  135. package/gsd-core/bin/lib/command-arg-projection.cjs +55 -0
  136. package/gsd-core/bin/lib/command-routing-hub.cjs +300 -0
  137. package/gsd-core/bin/lib/commands.cjs +1203 -0
  138. package/gsd-core/bin/lib/config-schema.cjs +29 -0
  139. package/gsd-core/bin/lib/config-types.cjs +19 -0
  140. package/gsd-core/bin/lib/config.cjs +738 -0
  141. package/gsd-core/bin/lib/configuration.cjs +239 -0
  142. package/gsd-core/bin/lib/context-utilization.cjs +48 -0
  143. package/gsd-core/bin/lib/core.cjs +2051 -0
  144. package/gsd-core/bin/lib/decisions.cjs +118 -0
  145. package/gsd-core/bin/lib/docs.cjs +252 -0
  146. package/gsd-core/bin/lib/drift.cjs +364 -0
  147. package/gsd-core/bin/lib/fallow-runner.cjs +115 -0
  148. package/gsd-core/bin/lib/frontmatter.cjs +442 -0
  149. package/gsd-core/bin/lib/gap-checker.cjs +257 -0
  150. package/gsd-core/bin/lib/graphify.cjs +496 -0
  151. package/gsd-core/bin/lib/gsd2-import.cjs +456 -0
  152. package/gsd-core/bin/lib/init-command-router.cjs +62 -0
  153. package/gsd-core/bin/lib/init.cjs +1815 -0
  154. package/gsd-core/bin/lib/install-profiles.cjs +584 -0
  155. package/gsd-core/bin/lib/installer-migration-authoring.cjs +122 -0
  156. package/gsd-core/bin/lib/installer-migration-report.cjs +350 -0
  157. package/gsd-core/bin/lib/installer-migrations/000-first-time-baseline.cjs +218 -0
  158. package/gsd-core/bin/lib/installer-migrations/001-legacy-orphan-files.cjs +48 -0
  159. package/gsd-core/bin/lib/installer-migrations/002-codex-legacy-hooks-json.cjs +94 -0
  160. package/gsd-core/bin/lib/installer-migrations/003-rename-get-shit-done-to-gsd-core.cjs +108 -0
  161. package/gsd-core/bin/lib/installer-migrations.cjs +823 -0
  162. package/gsd-core/bin/lib/intel.cjs +590 -0
  163. package/gsd-core/bin/lib/learnings.cjs +270 -0
  164. package/gsd-core/bin/lib/legacy-cleanup.cjs +253 -0
  165. package/gsd-core/bin/lib/milestone.cjs +373 -0
  166. package/gsd-core/bin/lib/model-catalog.cjs +154 -0
  167. package/gsd-core/bin/lib/model-profiles.cjs +24 -0
  168. package/gsd-core/bin/lib/observability/event.cjs +51 -0
  169. package/gsd-core/bin/lib/observability/logger.cjs +146 -0
  170. package/gsd-core/bin/lib/observability/redaction.cjs +48 -0
  171. package/gsd-core/bin/lib/package-identity.cjs +35 -0
  172. package/gsd-core/bin/lib/package-legitimacy.cjs +368 -0
  173. package/gsd-core/bin/lib/phase-command-router.cjs +189 -0
  174. package/gsd-core/bin/lib/phase-lifecycle.cjs +74 -0
  175. package/gsd-core/bin/lib/phase.cjs +1307 -0
  176. package/gsd-core/bin/lib/phases-command-router.cjs +43 -0
  177. package/gsd-core/bin/lib/plan-scan.cjs +91 -0
  178. package/gsd-core/bin/lib/planning-workspace.cjs +245 -0
  179. package/gsd-core/bin/lib/profile-output.cjs +1120 -0
  180. package/gsd-core/bin/lib/profile-pipeline.cjs +517 -0
  181. package/gsd-core/bin/lib/project-root.cjs +119 -0
  182. package/gsd-core/bin/lib/prompt-budget.cjs +305 -0
  183. package/gsd-core/bin/lib/research-provider.cjs +137 -0
  184. package/gsd-core/bin/lib/research-store.cjs +167 -0
  185. package/gsd-core/bin/lib/review-reviewer-selection.cjs +121 -0
  186. package/gsd-core/bin/lib/roadmap-command-router.cjs +166 -0
  187. package/gsd-core/bin/lib/roadmap-upgrade.cjs +476 -0
  188. package/gsd-core/bin/lib/roadmap.cjs +600 -0
  189. package/gsd-core/bin/lib/runtime-artifact-layout.cjs +312 -0
  190. package/gsd-core/bin/lib/runtime-config-adapter-registry.cjs +56 -0
  191. package/gsd-core/bin/lib/runtime-homes.cjs +190 -0
  192. package/gsd-core/bin/lib/runtime-name-policy.cjs +96 -0
  193. package/gsd-core/bin/lib/runtime-slash.cjs +119 -0
  194. package/gsd-core/bin/lib/schema-detect.cjs +159 -0
  195. package/gsd-core/bin/lib/secrets.cjs +34 -0
  196. package/gsd-core/bin/lib/security.cjs +480 -0
  197. package/gsd-core/bin/lib/semver-compare.cjs +42 -0
  198. package/gsd-core/bin/lib/shell-command-projection.cjs +533 -0
  199. package/gsd-core/bin/lib/state-command-router.cjs +160 -0
  200. package/gsd-core/bin/lib/state-document.cjs +259 -0
  201. package/gsd-core/bin/lib/state.cjs +2010 -0
  202. package/gsd-core/bin/lib/surface.cjs +449 -0
  203. package/gsd-core/bin/lib/task-command-router.cjs +85 -0
  204. package/gsd-core/bin/lib/template.cjs +237 -0
  205. package/gsd-core/bin/lib/uat.cjs +297 -0
  206. package/gsd-core/bin/lib/ui-safety-gate.cjs +98 -0
  207. package/gsd-core/bin/lib/update-context.cjs +218 -0
  208. package/gsd-core/bin/lib/validate-command-router.cjs +91 -0
  209. package/gsd-core/bin/lib/validate.cjs +112 -0
  210. package/gsd-core/bin/lib/verification-command-router.cjs +31 -0
  211. package/gsd-core/bin/lib/verification.cjs +193 -0
  212. package/gsd-core/bin/lib/verify-command-router.cjs +44 -0
  213. package/gsd-core/bin/lib/verify.cjs +1451 -0
  214. package/gsd-core/bin/lib/workstream-inventory-builder.cjs +81 -0
  215. package/gsd-core/bin/lib/workstream-inventory.cjs +147 -0
  216. package/gsd-core/bin/lib/workstream-name-policy.cjs +91 -0
  217. package/gsd-core/bin/lib/workstream.cjs +380 -0
  218. package/gsd-core/bin/lib/worktree-base-ref.cjs +325 -0
  219. package/gsd-core/bin/lib/worktree-safety.cjs +943 -0
  220. package/gsd-core/bin/shared/config-defaults.manifest.json +98 -0
  221. package/gsd-core/bin/shared/config-schema.manifest.json +192 -0
  222. package/gsd-core/bin/shared/model-catalog.json +149 -0
  223. package/gsd-core/bin/shared/runtime-aliases.manifest.json +75 -0
  224. package/gsd-core/bin/verify-reapply-patches.cjs +349 -0
  225. package/gsd-core/contexts/dev.md +21 -0
  226. package/gsd-core/contexts/research.md +22 -0
  227. package/gsd-core/contexts/review.md +23 -0
  228. package/gsd-core/references/agent-contracts.md +79 -0
  229. package/gsd-core/references/ai-evals.md +156 -0
  230. package/gsd-core/references/ai-frameworks.md +186 -0
  231. package/gsd-core/references/architecture-decision.md +74 -0
  232. package/gsd-core/references/artifact-types.md +131 -0
  233. package/gsd-core/references/auth-in-tests.md +91 -0
  234. package/gsd-core/references/autonomous-smart-discuss.md +277 -0
  235. package/gsd-core/references/checkpoints.md +814 -0
  236. package/gsd-core/references/common-bug-patterns.md +114 -0
  237. package/gsd-core/references/context-budget.md +85 -0
  238. package/gsd-core/references/continuation-format.md +253 -0
  239. package/gsd-core/references/db-test-isolation.md +54 -0
  240. package/gsd-core/references/debugger-philosophy.md +76 -0
  241. package/gsd-core/references/decimal-phase-calculation.md +64 -0
  242. package/gsd-core/references/doc-conflict-engine.md +91 -0
  243. package/gsd-core/references/domain-modeling.md +80 -0
  244. package/gsd-core/references/domain-probes.md +125 -0
  245. package/gsd-core/references/e2e-tiering.md +35 -0
  246. package/gsd-core/references/execute-mvp-tdd.md +81 -0
  247. package/gsd-core/references/executor-examples.md +110 -0
  248. package/gsd-core/references/few-shot-examples/plan-checker.md +73 -0
  249. package/gsd-core/references/few-shot-examples/verifier.md +109 -0
  250. package/gsd-core/references/flaky-test-checklist.md +22 -0
  251. package/gsd-core/references/gate-prompts.md +100 -0
  252. package/gsd-core/references/gates.md +70 -0
  253. package/gsd-core/references/git-integration.md +298 -0
  254. package/gsd-core/references/git-planning-commit.md +40 -0
  255. package/gsd-core/references/ios-scaffold.md +123 -0
  256. package/gsd-core/references/mandatory-initial-read.md +2 -0
  257. package/gsd-core/references/model-profile-resolution.md +38 -0
  258. package/gsd-core/references/model-profiles.md +245 -0
  259. package/gsd-core/references/mvp-concepts.md +49 -0
  260. package/gsd-core/references/phase-argument-parsing.md +61 -0
  261. package/gsd-core/references/planner-antipatterns.md +89 -0
  262. package/gsd-core/references/planner-chunked.md +49 -0
  263. package/gsd-core/references/planner-gap-closure.md +62 -0
  264. package/gsd-core/references/planner-graphify-auto-update.md +67 -0
  265. package/gsd-core/references/planner-human-verify-mode.md +57 -0
  266. package/gsd-core/references/planner-interface-context.md +62 -0
  267. package/gsd-core/references/planner-load-graph-context.md +36 -0
  268. package/gsd-core/references/planner-mvp-mode.md +53 -0
  269. package/gsd-core/references/planner-reviews.md +39 -0
  270. package/gsd-core/references/planner-revision.md +87 -0
  271. package/gsd-core/references/planner-source-audit.md +73 -0
  272. package/gsd-core/references/planning-config.md +473 -0
  273. package/gsd-core/references/product-discovery.md +49 -0
  274. package/gsd-core/references/project-skills-discovery.md +19 -0
  275. package/gsd-core/references/questioning.md +162 -0
  276. package/gsd-core/references/realistic-test-data.md +44 -0
  277. package/gsd-core/references/research-documentation-lookup.md +29 -0
  278. package/gsd-core/references/research-philosophy.md +29 -0
  279. package/gsd-core/references/research-verification-protocol.md +27 -0
  280. package/gsd-core/references/revision-loop.md +97 -0
  281. package/gsd-core/references/scout-codebase.md +51 -0
  282. package/gsd-core/references/skeleton-template.md +48 -0
  283. package/gsd-core/references/sketch-interactivity.md +41 -0
  284. package/gsd-core/references/sketch-theme-system.md +94 -0
  285. package/gsd-core/references/sketch-tooling.md +45 -0
  286. package/gsd-core/references/sketch-variant-patterns.md +81 -0
  287. package/gsd-core/references/spidr-splitting.md +69 -0
  288. package/gsd-core/references/tdd.md +330 -0
  289. package/gsd-core/references/test-containers.md +55 -0
  290. package/gsd-core/references/test-strategy.md +75 -0
  291. package/gsd-core/references/thinking-models-debug.md +44 -0
  292. package/gsd-core/references/thinking-models-execution.md +50 -0
  293. package/gsd-core/references/thinking-models-planning.md +62 -0
  294. package/gsd-core/references/thinking-models-research.md +50 -0
  295. package/gsd-core/references/thinking-models-verification.md +55 -0
  296. package/gsd-core/references/thinking-partner.md +96 -0
  297. package/gsd-core/references/ui-brand.md +162 -0
  298. package/gsd-core/references/universal-anti-patterns.md +63 -0
  299. package/gsd-core/references/user-profiling.md +681 -0
  300. package/gsd-core/references/user-story-template.md +58 -0
  301. package/gsd-core/references/verification-overrides.md +227 -0
  302. package/gsd-core/references/verification-patterns.md +612 -0
  303. package/gsd-core/references/verify-mvp-mode.md +85 -0
  304. package/gsd-core/references/workstream-flag.md +111 -0
  305. package/gsd-core/references/worktree-branch-check.md +38 -0
  306. package/gsd-core/references/worktree-path-safety.md +67 -0
  307. package/gsd-core/templates/AI-SPEC.md +246 -0
  308. package/gsd-core/templates/DEBUG.md +169 -0
  309. package/gsd-core/templates/README.md +77 -0
  310. package/gsd-core/templates/SECURITY.md +61 -0
  311. package/gsd-core/templates/UAT.md +265 -0
  312. package/gsd-core/templates/UI-SPEC.md +100 -0
  313. package/gsd-core/templates/VALIDATION.md +76 -0
  314. package/gsd-core/templates/adr.md +58 -0
  315. package/gsd-core/templates/claude-md.md +145 -0
  316. package/gsd-core/templates/codebase/architecture.md +255 -0
  317. package/gsd-core/templates/codebase/concerns.md +310 -0
  318. package/gsd-core/templates/codebase/conventions.md +307 -0
  319. package/gsd-core/templates/codebase/integrations.md +280 -0
  320. package/gsd-core/templates/codebase/stack.md +186 -0
  321. package/gsd-core/templates/codebase/structure.md +285 -0
  322. package/gsd-core/templates/codebase/testing.md +480 -0
  323. package/gsd-core/templates/config.json +62 -0
  324. package/gsd-core/templates/context.md +352 -0
  325. package/gsd-core/templates/continue-here.md +78 -0
  326. package/gsd-core/templates/copilot-instructions.md +7 -0
  327. package/gsd-core/templates/debug-subagent-prompt.md +91 -0
  328. package/gsd-core/templates/dev-preferences.md +21 -0
  329. package/gsd-core/templates/discovery.md +146 -0
  330. package/gsd-core/templates/discussion-log.md +63 -0
  331. package/gsd-core/templates/domain-model.md +54 -0
  332. package/gsd-core/templates/milestone-archive.md +123 -0
  333. package/gsd-core/templates/milestone.md +115 -0
  334. package/gsd-core/templates/phase-prompt.md +610 -0
  335. package/gsd-core/templates/planner-subagent-prompt.md +117 -0
  336. package/gsd-core/templates/product-brief.md +55 -0
  337. package/gsd-core/templates/project.md +186 -0
  338. package/gsd-core/templates/requirements.md +231 -0
  339. package/gsd-core/templates/research-project/ARCHITECTURE.md +204 -0
  340. package/gsd-core/templates/research-project/FEATURES.md +147 -0
  341. package/gsd-core/templates/research-project/PITFALLS.md +200 -0
  342. package/gsd-core/templates/research-project/STACK.md +120 -0
  343. package/gsd-core/templates/research-project/SUMMARY.md +170 -0
  344. package/gsd-core/templates/research.md +592 -0
  345. package/gsd-core/templates/retrospective.md +54 -0
  346. package/gsd-core/templates/roadmap.md +202 -0
  347. package/gsd-core/templates/spec.md +307 -0
  348. package/gsd-core/templates/state.md +195 -0
  349. package/gsd-core/templates/summary-complex.md +59 -0
  350. package/gsd-core/templates/summary-minimal.md +41 -0
  351. package/gsd-core/templates/summary-standard.md +48 -0
  352. package/gsd-core/templates/summary.md +248 -0
  353. package/gsd-core/templates/test-strategy.md +50 -0
  354. package/gsd-core/templates/user-profile.md +146 -0
  355. package/gsd-core/templates/user-setup.md +311 -0
  356. package/gsd-core/templates/verification-report.md +322 -0
  357. package/gsd-core/workflows/_runtime-launcher.snippet.sh +1 -0
  358. package/gsd-core/workflows/add-backlog.md +91 -0
  359. package/gsd-core/workflows/add-phase.md +113 -0
  360. package/gsd-core/workflows/add-tests.md +355 -0
  361. package/gsd-core/workflows/add-todo.md +161 -0
  362. package/gsd-core/workflows/ai-integration-phase.md +295 -0
  363. package/gsd-core/workflows/analyze-dependencies.md +96 -0
  364. package/gsd-core/workflows/audit-fix.md +178 -0
  365. package/gsd-core/workflows/audit-milestone.md +360 -0
  366. package/gsd-core/workflows/audit-uat.md +110 -0
  367. package/gsd-core/workflows/autonomous.md +797 -0
  368. package/gsd-core/workflows/check-todos.md +180 -0
  369. package/gsd-core/workflows/cleanup.md +195 -0
  370. package/gsd-core/workflows/code-review-fix.md +502 -0
  371. package/gsd-core/workflows/code-review.md +658 -0
  372. package/gsd-core/workflows/complete-milestone.md +855 -0
  373. package/gsd-core/workflows/debug.md +237 -0
  374. package/gsd-core/workflows/diagnose-issues.md +245 -0
  375. package/gsd-core/workflows/discover-product.md +112 -0
  376. package/gsd-core/workflows/discovery-phase.md +291 -0
  377. package/gsd-core/workflows/discuss-phase/modes/advisor.md +176 -0
  378. package/gsd-core/workflows/discuss-phase/modes/all.md +28 -0
  379. package/gsd-core/workflows/discuss-phase/modes/analyze.md +44 -0
  380. package/gsd-core/workflows/discuss-phase/modes/auto.md +57 -0
  381. package/gsd-core/workflows/discuss-phase/modes/batch.md +52 -0
  382. package/gsd-core/workflows/discuss-phase/modes/chain.md +98 -0
  383. package/gsd-core/workflows/discuss-phase/modes/default.md +141 -0
  384. package/gsd-core/workflows/discuss-phase/modes/power.md +44 -0
  385. package/gsd-core/workflows/discuss-phase/modes/text.md +55 -0
  386. package/gsd-core/workflows/discuss-phase/templates/checkpoint.json +18 -0
  387. package/gsd-core/workflows/discuss-phase/templates/context.md +136 -0
  388. package/gsd-core/workflows/discuss-phase/templates/discussion-log.md +50 -0
  389. package/gsd-core/workflows/discuss-phase-assumptions.md +675 -0
  390. package/gsd-core/workflows/discuss-phase-power.md +291 -0
  391. package/gsd-core/workflows/discuss-phase.md +499 -0
  392. package/gsd-core/workflows/do.md +111 -0
  393. package/gsd-core/workflows/docs-update.md +1176 -0
  394. package/gsd-core/workflows/edit-phase.md +295 -0
  395. package/gsd-core/workflows/eval-review.md +156 -0
  396. package/gsd-core/workflows/execute-phase/steps/codebase-drift-gate.md +95 -0
  397. package/gsd-core/workflows/execute-phase/steps/per-plan-worktree-gate.md +94 -0
  398. package/gsd-core/workflows/execute-phase/steps/post-merge-gate.md +117 -0
  399. package/gsd-core/workflows/execute-phase.md +1752 -0
  400. package/gsd-core/workflows/execute-plan.md +526 -0
  401. package/gsd-core/workflows/explore.md +146 -0
  402. package/gsd-core/workflows/extract-learnings.md +243 -0
  403. package/gsd-core/workflows/fast.md +124 -0
  404. package/gsd-core/workflows/forensics.md +279 -0
  405. package/gsd-core/workflows/graduation.md +196 -0
  406. package/gsd-core/workflows/health.md +224 -0
  407. package/gsd-core/workflows/help/modes/brief.md +22 -0
  408. package/gsd-core/workflows/help/modes/default.md +50 -0
  409. package/gsd-core/workflows/help/modes/full.md +789 -0
  410. package/gsd-core/workflows/help/modes/topic.md +74 -0
  411. package/gsd-core/workflows/help.md +24 -0
  412. package/gsd-core/workflows/import.md +256 -0
  413. package/gsd-core/workflows/inbox.md +387 -0
  414. package/gsd-core/workflows/ingest-docs.md +340 -0
  415. package/gsd-core/workflows/insert-phase.md +152 -0
  416. package/gsd-core/workflows/list-phase-assumptions.md +178 -0
  417. package/gsd-core/workflows/list-workspaces.md +57 -0
  418. package/gsd-core/workflows/manager.md +393 -0
  419. package/gsd-core/workflows/map-codebase.md +446 -0
  420. package/gsd-core/workflows/milestone-summary.md +224 -0
  421. package/gsd-core/workflows/model-domain.md +162 -0
  422. package/gsd-core/workflows/mvp-phase.md +222 -0
  423. package/gsd-core/workflows/new-milestone.md +635 -0
  424. package/gsd-core/workflows/new-project.md +1555 -0
  425. package/gsd-core/workflows/new-workspace.md +240 -0
  426. package/gsd-core/workflows/next.md +299 -0
  427. package/gsd-core/workflows/node-repair.md +92 -0
  428. package/gsd-core/workflows/note.md +158 -0
  429. package/gsd-core/workflows/pause-work.md +244 -0
  430. package/gsd-core/workflows/plan-milestone-gaps.md +281 -0
  431. package/gsd-core/workflows/plan-phase.md +1814 -0
  432. package/gsd-core/workflows/plan-review-convergence.md +346 -0
  433. package/gsd-core/workflows/plant-seed.md +230 -0
  434. package/gsd-core/workflows/pr-branch.md +157 -0
  435. package/gsd-core/workflows/profile-user.md +453 -0
  436. package/gsd-core/workflows/progress.md +699 -0
  437. package/gsd-core/workflows/quick.md +1017 -0
  438. package/gsd-core/workflows/reapply-patches.md +426 -0
  439. package/gsd-core/workflows/recommend-architecture.md +135 -0
  440. package/gsd-core/workflows/remove-phase.md +156 -0
  441. package/gsd-core/workflows/remove-workspace.md +108 -0
  442. package/gsd-core/workflows/resume-project.md +332 -0
  443. package/gsd-core/workflows/review.md +748 -0
  444. package/gsd-core/workflows/scan.md +107 -0
  445. package/gsd-core/workflows/secure-phase.md +182 -0
  446. package/gsd-core/workflows/session-report.md +146 -0
  447. package/gsd-core/workflows/settings-advanced.md +810 -0
  448. package/gsd-core/workflows/settings-integrations.md +312 -0
  449. package/gsd-core/workflows/settings.md +566 -0
  450. package/gsd-core/workflows/ship.md +405 -0
  451. package/gsd-core/workflows/sketch-wrap-up.md +286 -0
  452. package/gsd-core/workflows/sketch.md +361 -0
  453. package/gsd-core/workflows/spec-phase.md +263 -0
  454. package/gsd-core/workflows/spike-wrap-up.md +307 -0
  455. package/gsd-core/workflows/spike.md +453 -0
  456. package/gsd-core/workflows/stats.md +80 -0
  457. package/gsd-core/workflows/sync-skills.md +182 -0
  458. package/gsd-core/workflows/testing-strategy.md +122 -0
  459. package/gsd-core/workflows/thread.md +222 -0
  460. package/gsd-core/workflows/transition.md +694 -0
  461. package/gsd-core/workflows/ui-phase.md +328 -0
  462. package/gsd-core/workflows/ui-review.md +193 -0
  463. package/gsd-core/workflows/ultraplan-phase.md +199 -0
  464. package/gsd-core/workflows/undo.md +314 -0
  465. package/gsd-core/workflows/update.md +496 -0
  466. package/gsd-core/workflows/validate-phase.md +181 -0
  467. package/gsd-core/workflows/verify-phase.md +544 -0
  468. package/gsd-core/workflows/verify-work.md +781 -0
  469. package/hooks/dist/gsd-check-update-worker.js +108 -0
  470. package/hooks/dist/gsd-check-update.js +66 -0
  471. package/hooks/dist/gsd-config-reload.js +133 -0
  472. package/hooks/dist/gsd-context-monitor.js +195 -0
  473. package/hooks/dist/gsd-cursor-post-tool.js +75 -0
  474. package/hooks/dist/gsd-cursor-session-start.js +52 -0
  475. package/hooks/dist/gsd-graphify-update.sh +158 -0
  476. package/hooks/dist/gsd-phase-boundary.sh +47 -0
  477. package/hooks/dist/gsd-prompt-guard.js +97 -0
  478. package/hooks/dist/gsd-read-guard.js +101 -0
  479. package/hooks/dist/gsd-read-injection-scanner.js +203 -0
  480. package/hooks/dist/gsd-session-state.sh +59 -0
  481. package/hooks/dist/gsd-statusline.js +566 -0
  482. package/hooks/dist/gsd-update-banner.js +138 -0
  483. package/hooks/dist/gsd-validate-commit.sh +57 -0
  484. package/hooks/dist/gsd-workflow-guard.js +167 -0
  485. package/hooks/dist/gsd-worktree-path-guard.js +169 -0
  486. package/hooks/dist/lib/git-cmd.js +150 -0
  487. package/hooks/dist/lib/gsd-graphify-rebuild.sh +65 -0
  488. package/hooks/dist/managed-hooks-registry.cjs +38 -0
  489. package/hooks/gsd-check-update-worker.js +108 -0
  490. package/hooks/gsd-check-update.js +66 -0
  491. package/hooks/gsd-config-reload.js +133 -0
  492. package/hooks/gsd-context-monitor.js +195 -0
  493. package/hooks/gsd-cursor-post-tool.js +75 -0
  494. package/hooks/gsd-cursor-session-start.js +52 -0
  495. package/hooks/gsd-graphify-update.sh +158 -0
  496. package/hooks/gsd-phase-boundary.sh +47 -0
  497. package/hooks/gsd-prompt-guard.js +97 -0
  498. package/hooks/gsd-read-guard.js +101 -0
  499. package/hooks/gsd-read-injection-scanner.js +203 -0
  500. package/hooks/gsd-session-state.sh +59 -0
  501. package/hooks/gsd-statusline.js +566 -0
  502. package/hooks/gsd-update-banner.js +138 -0
  503. package/hooks/gsd-validate-commit.sh +57 -0
  504. package/hooks/gsd-workflow-guard.js +167 -0
  505. package/hooks/gsd-worktree-path-guard.js +169 -0
  506. package/hooks/hooks.json +69 -0
  507. package/hooks/lib/git-cmd.js +150 -0
  508. package/hooks/lib/gsd-graphify-rebuild.sh +65 -0
  509. package/hooks/managed-hooks-registry.cjs +38 -0
  510. package/package.json +115 -0
  511. package/scripts/affected-tests-lib.cjs +542 -0
  512. package/scripts/audit-workflow-script-paths.cjs +73 -0
  513. package/scripts/base64-scan.sh +351 -0
  514. package/scripts/build-hooks.js +247 -0
  515. package/scripts/changeset/README.md +129 -0
  516. package/scripts/changeset/cli.cjs +590 -0
  517. package/scripts/changeset/github-release-notes.cjs +199 -0
  518. package/scripts/changeset/lint.cjs +111 -0
  519. package/scripts/changeset/new.cjs +137 -0
  520. package/scripts/changeset/parse.cjs +114 -0
  521. package/scripts/changeset/render.cjs +34 -0
  522. package/scripts/changeset/serialize.cjs +130 -0
  523. package/scripts/check-alias-drift.cjs +114 -0
  524. package/scripts/check-env.cjs +312 -0
  525. package/scripts/check-npm-integrity.cjs +215 -0
  526. package/scripts/ci-guard-runner.cjs +22 -0
  527. package/scripts/ci-prepare-test-scope.cjs +51 -0
  528. package/scripts/ci-rebase-check.cjs +86 -0
  529. package/scripts/ci-test-scope.cjs +431 -0
  530. package/scripts/command-contract-helpers.cjs +64 -0
  531. package/scripts/diff-touches-shipped-paths.cjs +155 -0
  532. package/scripts/fix-slash-commands.cjs +147 -0
  533. package/scripts/gen-inventory-manifest.cjs +115 -0
  534. package/scripts/gen-research-agents.cjs +276 -0
  535. package/scripts/generate-package-identity.cjs +125 -0
  536. package/scripts/issue-dedupe.cjs +278 -0
  537. package/scripts/lib/allowlist-ratchet.cjs +136 -0
  538. package/scripts/lib/cli-exit.cjs +56 -0
  539. package/scripts/lint-command-contract.cjs +114 -0
  540. package/scripts/lint-descriptions.cjs +87 -0
  541. package/scripts/lint-docs-required.cjs +222 -0
  542. package/scripts/lint-legacy-dir-name.cjs +160 -0
  543. package/scripts/lint-package-identity-drift.cjs +141 -0
  544. package/scripts/lint-pr-check-project-dir.cjs +99 -0
  545. package/scripts/lint-shell-command-projection-drift.cjs +62 -0
  546. package/scripts/lint-skill-deps.cjs +185 -0
  547. package/scripts/lint-test-file-count.allowlist.json +135 -0
  548. package/scripts/lint-test-file-count.cjs +246 -0
  549. package/scripts/mutation-matrix.cjs +222 -0
  550. package/scripts/pr-template-policy.cjs +268 -0
  551. package/scripts/prompt-injection-scan.sh +207 -0
  552. package/scripts/release-notes/discord-release-summary.cjs +373 -0
  553. package/scripts/release-notes/format-github-release-notes.cjs +261 -0
  554. package/scripts/release-tarball-smoke.cjs +629 -0
  555. package/scripts/research-profiles.cjs +149 -0
  556. package/scripts/run-affected-tests.cjs +7 -0
  557. package/scripts/run-cross-platform-tests.cjs +67 -0
  558. package/scripts/run-tests.cjs +315 -0
  559. package/scripts/secret-scan-lint.sh +231 -0
  560. package/scripts/secret-scan.sh +358 -0
  561. package/scripts/setup-branch-protection.sh +236 -0
  562. package/scripts/strip-prose-atrefs.cjs +106 -0
  563. package/scripts/sync-manifest-versions.cjs +119 -0
  564. package/scripts/sync-rulesets.sh +34 -0
  565. package/scripts/sync-runtime-launcher.cjs +399 -0
  566. package/scripts/test-failure-reasons.cjs +34 -0
  567. package/scripts/verify-npm-publish.cjs +240 -0
  568. package/scripts/workflow-policy.cjs +450 -0
@@ -0,0 +1,364 @@
1
+ /**
2
+ * Codebase Drift Detection (#2003)
3
+ *
4
+ * Detects structural drift between a committed codebase and the
5
+ * `.planning/codebase/STRUCTURE.md` map produced by `gsd-codebase-mapper`.
6
+ *
7
+ * Four categories of drift element:
8
+ * - new_dir → a newly-added file whose directory prefix does not appear
9
+ * in STRUCTURE.md
10
+ * - barrel → a newly-added barrel export at
11
+ * (packages|apps)/<name>/src/index.(ts|tsx|js|mjs|cjs)
12
+ * - migration → a newly-added migration file under one of the recognized
13
+ * migration directories (supabase, prisma, drizzle, src/migrations, …)
14
+ * - route → a newly-added route module under a `routes/` or `api/` dir
15
+ *
16
+ * Each file is counted at most once; when a file matches multiple categories
17
+ * the most specific category wins (migration > route > barrel > new_dir).
18
+ *
19
+ * Design decisions (see PR for full rubber-duck):
20
+ * - The library is pure. It takes parsed git diff output and returns a
21
+ * structured result. The CLI/workflow layer is responsible for running
22
+ * git and for spawning mappers.
23
+ * - `last_mapped_commit` is stored as YAML-style frontmatter at the top of
24
+ * each `.planning/codebase/*.md` file. This keeps the baseline attached
25
+ * to the file, survives git moves, and avoids a sidecar JSON.
26
+ * - The detector NEVER throws on malformed input — it returns a
27
+ * `{ skipped: true }` result. The phase workflow depends on this
28
+ * non-blocking guarantee.
29
+ *
30
+ * ADR-457 build-at-publish: the hand-written bin/lib/drift.cjs collapsed to
31
+ * a TypeScript source of truth. Behaviour is preserved byte-for-behaviour from
32
+ * the prior hand-written .cjs; only types are added.
33
+ */
34
+ 'use strict';
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ const node_fs_1 = __importDefault(require("node:fs"));
39
+ const shell_command_projection_cjs_1 = require("./shell-command-projection.cjs");
40
+ const runtime_slash_cjs_1 = require("./runtime-slash.cjs");
41
+ // ─── Constants ───────────────────────────────────────────────────────────────
42
+ const DRIFT_CATEGORIES = Object.freeze(['new_dir', 'barrel', 'migration', 'route']);
43
+ // Category priority when a single file matches multiple rules.
44
+ // Higher index = more specific = wins.
45
+ const CATEGORY_PRIORITY = { new_dir: 0, barrel: 1, route: 2, migration: 3 };
46
+ const BARREL_RE = /^(packages|apps)\/[^/]+\/src\/index\.(ts|tsx|js|mjs|cjs)$/;
47
+ const MIGRATION_RES = [
48
+ /^supabase\/migrations\/.+\.sql$/,
49
+ /^prisma\/migrations\/.+/,
50
+ /^drizzle\/meta\/.+/,
51
+ /^drizzle\/migrations\/.+/,
52
+ /^src\/migrations\/.+\.(ts|js|sql)$/,
53
+ /^db\/migrations\/.+\.(sql|ts|js)$/,
54
+ /^migrations\/.+\.(sql|ts|js)$/,
55
+ ];
56
+ const ROUTE_RES = [
57
+ /^(apps|packages)\/[^/]+\/src\/routes\/.+\.(ts|tsx|js|jsx|mjs|cjs)$/,
58
+ /^src\/routes\/.+\.(ts|tsx|js|jsx|mjs|cjs)$/,
59
+ /^src\/api\/.+\.(ts|tsx|js|jsx|mjs|cjs)$/,
60
+ /^(apps|packages)\/[^/]+\/src\/api\/.+\.(ts|tsx|js|jsx|mjs|cjs)$/,
61
+ ];
62
+ // A conservative allowlist for `--paths` arguments passed to the mapper:
63
+ // repo-relative path components separated by /, containing only
64
+ // alphanumerics, dash, underscore, and dot (no `..`, no `/..`).
65
+ const SAFE_PATH_RE = /^(?!.*\.\.)(?:[A-Za-z0-9_.][A-Za-z0-9_.\-]*)(?:\/[A-Za-z0-9_.][A-Za-z0-9_.\-]*)*$/;
66
+ /**
67
+ * Classify a single file path into a drift category or null.
68
+ */
69
+ function classifyFile(file) {
70
+ if (typeof file !== 'string' || !file)
71
+ return null;
72
+ const norm = file.replace(/\\/g, '/');
73
+ if (MIGRATION_RES.some((r) => r.test(norm)))
74
+ return 'migration';
75
+ if (ROUTE_RES.some((r) => r.test(norm)))
76
+ return 'route';
77
+ if (BARREL_RE.test(norm))
78
+ return 'barrel';
79
+ return null;
80
+ }
81
+ /**
82
+ * True iff any prefix of `file` (dir1, dir1/dir2, …) appears as a substring
83
+ * of `structureMd`. Used to decide whether a file is in "mapped territory".
84
+ *
85
+ * Matching is deliberately substring-based — STRUCTURE.md is free-form
86
+ * markdown, not a structured manifest. If the map mentions `src/lib/` the
87
+ * check `structureMd.includes('src/lib')` holds.
88
+ */
89
+ function isPathMapped(file, structureMd) {
90
+ const norm = file.replace(/\\/g, '/');
91
+ const parts = norm.split('/');
92
+ // Check prefixes from longest to shortest; any hit means "mapped".
93
+ for (let i = parts.length - 1; i >= 1; i--) {
94
+ const prefix = parts.slice(0, i).join('/');
95
+ if (structureMd.includes(prefix))
96
+ return true;
97
+ }
98
+ // Finally, if even the top-level dir is mentioned, count as mapped.
99
+ if (parts.length > 0 && structureMd.includes(parts[0] + '/'))
100
+ return true;
101
+ if (parts.length > 0 && structureMd.includes('`' + parts[0] + '`'))
102
+ return true;
103
+ return false;
104
+ }
105
+ // ─── Main detection ──────────────────────────────────────────────────────────
106
+ /**
107
+ * Detect codebase drift.
108
+ */
109
+ function detectDrift(input) {
110
+ try {
111
+ if (!input || typeof input !== 'object') {
112
+ return skipped('invalid-input');
113
+ }
114
+ const inp = input;
115
+ const { addedFiles, modifiedFiles, deletedFiles, structureMd, } = inp;
116
+ const threshold = Number.isInteger(inp.threshold) && inp.threshold >= 1
117
+ ? inp.threshold
118
+ : 3;
119
+ const action = inp.action === 'auto-remap' ? 'auto-remap' : 'warn';
120
+ if (structureMd === null || structureMd === undefined) {
121
+ return skipped('missing-structure-md');
122
+ }
123
+ if (typeof structureMd !== 'string') {
124
+ return skipped('invalid-structure-md');
125
+ }
126
+ const added = Array.isArray(addedFiles) ? addedFiles.filter((x) => typeof x === 'string') : [];
127
+ const modified = Array.isArray(modifiedFiles) ? modifiedFiles : [];
128
+ const deleted = Array.isArray(deletedFiles) ? deletedFiles : [];
129
+ // Build elements. One element per file, highest-priority category wins.
130
+ const elements = [];
131
+ const seen = new Map();
132
+ for (const rawFile of added) {
133
+ const file = rawFile.replace(/\\/g, '/');
134
+ const specific = classifyFile(file);
135
+ let category = specific;
136
+ if (!category) {
137
+ if (!isPathMapped(file, structureMd)) {
138
+ category = 'new_dir';
139
+ }
140
+ else {
141
+ continue; // mapped, known, ordinary file — not drift
142
+ }
143
+ }
144
+ // Dedup: if we've already counted this path at higher-or-equal priority, skip
145
+ const prior = seen.get(file);
146
+ if (prior && CATEGORY_PRIORITY[prior] >= CATEGORY_PRIORITY[category])
147
+ continue;
148
+ seen.set(file, category);
149
+ }
150
+ for (const [file, category] of seen.entries()) {
151
+ elements.push({ category, path: file });
152
+ }
153
+ // Sort for stable output.
154
+ elements.sort((a, b) => a.category === b.category
155
+ ? a.path.localeCompare(b.path)
156
+ : a.category.localeCompare(b.category));
157
+ const actionRequired = elements.length >= threshold;
158
+ let directive = 'none';
159
+ let spawnMapper = false;
160
+ let affectedPaths = [];
161
+ let message = '';
162
+ if (actionRequired) {
163
+ directive = action;
164
+ affectedPaths = chooseAffectedPaths(elements.map((e) => e.path));
165
+ if (action === 'auto-remap') {
166
+ spawnMapper = true;
167
+ }
168
+ message = buildMessage(elements, affectedPaths, action, inp.runtime);
169
+ }
170
+ return {
171
+ skipped: false,
172
+ elements,
173
+ actionRequired,
174
+ directive,
175
+ spawnMapper,
176
+ affectedPaths,
177
+ threshold,
178
+ action,
179
+ message,
180
+ counts: {
181
+ added: added.length,
182
+ modified: modified.length,
183
+ deleted: deleted.length,
184
+ },
185
+ };
186
+ }
187
+ catch (err) {
188
+ // Non-blocking: never throw from this function.
189
+ const errMsg = err?.message ? err.message : String(err);
190
+ return skipped('exception:' + errMsg);
191
+ }
192
+ }
193
+ function skipped(reason) {
194
+ return {
195
+ skipped: true,
196
+ reason,
197
+ elements: [],
198
+ actionRequired: false,
199
+ directive: 'none',
200
+ spawnMapper: false,
201
+ affectedPaths: [],
202
+ message: '',
203
+ };
204
+ }
205
+ function buildMessage(elements, affectedPaths, action, runtime) {
206
+ const byCat = {};
207
+ for (const e of elements) {
208
+ if (!byCat[e.category])
209
+ byCat[e.category] = [];
210
+ byCat[e.category].push(e.path);
211
+ }
212
+ const lines = [
213
+ `Codebase drift detected: ${elements.length} structural element(s) since last mapping.`,
214
+ '',
215
+ ];
216
+ const labels = {
217
+ new_dir: 'New directories',
218
+ barrel: 'New barrel exports',
219
+ migration: 'New migrations',
220
+ route: 'New route modules',
221
+ };
222
+ for (const cat of ['new_dir', 'barrel', 'migration', 'route']) {
223
+ if (byCat[cat]) {
224
+ lines.push(`${labels[cat]}:`);
225
+ for (const p of byCat[cat])
226
+ lines.push(` - ${p}`);
227
+ }
228
+ }
229
+ lines.push('');
230
+ if (action === 'auto-remap') {
231
+ lines.push(`Auto-remap scheduled for paths: ${affectedPaths.join(', ')}`);
232
+ }
233
+ else {
234
+ // drift.cts is a pure library — it must never read env/config. The
235
+ // caller (verify.cmdVerifyCodebaseDrift) resolves the runtime once and
236
+ // passes it in via input.runtime so emitted commands match the project
237
+ // the caller is targeting, not the current process directory.
238
+ const mapCmd = (0, runtime_slash_cjs_1.formatGsdSlash)('map-codebase', runtime || 'claude');
239
+ lines.push(`Run ${String(mapCmd)} --paths ${affectedPaths.join(',')} to refresh planning context.`);
240
+ }
241
+ return lines.join('\n');
242
+ }
243
+ // ─── Affected paths ──────────────────────────────────────────────────────────
244
+ /**
245
+ * Collapse a list of drifted file paths into a sorted, deduplicated list of
246
+ * the top-level directory prefixes (depth 2 when the repo uses an
247
+ * `<apps|packages>/<name>/…` layout; depth 1 otherwise).
248
+ */
249
+ function chooseAffectedPaths(paths) {
250
+ const out = new Set();
251
+ for (const raw of paths || []) {
252
+ if (typeof raw !== 'string' || !raw)
253
+ continue;
254
+ const file = raw.replace(/\\/g, '/');
255
+ const parts = file.split('/');
256
+ if (parts.length === 0)
257
+ continue;
258
+ const top = parts[0];
259
+ if ((top === 'apps' || top === 'packages') && parts.length >= 2) {
260
+ out.add(`${top}/${parts[1]}`);
261
+ }
262
+ else {
263
+ out.add(top);
264
+ }
265
+ }
266
+ return [...out].sort();
267
+ }
268
+ /**
269
+ * Filter `paths` to only those that are safe to splice into a mapper prompt.
270
+ * Any path that is absolute, contains traversal, or includes shell
271
+ * metacharacters is dropped.
272
+ */
273
+ function sanitizePaths(paths) {
274
+ if (!Array.isArray(paths))
275
+ return [];
276
+ const out = [];
277
+ for (const p of paths) {
278
+ if (typeof p !== 'string')
279
+ continue;
280
+ if (p.startsWith('/'))
281
+ continue;
282
+ if (!SAFE_PATH_RE.test(p))
283
+ continue;
284
+ out.push(p);
285
+ }
286
+ return out;
287
+ }
288
+ // ─── Frontmatter helpers ─────────────────────────────────────────────────────
289
+ const FRONTMATTER_RE = /^---\r?\n([\s\S]*?)\r?\n---\r?\n?/;
290
+ function parseFrontmatter(content) {
291
+ if (typeof content !== 'string')
292
+ return { data: {}, body: '' };
293
+ const m = content.match(FRONTMATTER_RE);
294
+ if (!m)
295
+ return { data: {}, body: content };
296
+ const data = {};
297
+ for (const line of m[1].split(/\r?\n/)) {
298
+ const kv = line.match(/^([A-Za-z0-9_][A-Za-z0-9_-]*):\s*(.*)$/);
299
+ if (!kv)
300
+ continue;
301
+ data[kv[1]] = kv[2];
302
+ }
303
+ return { data, body: content.slice(m[0].length) };
304
+ }
305
+ function serializeFrontmatter(data, body) {
306
+ const keys = Object.keys(data);
307
+ if (keys.length === 0)
308
+ return body;
309
+ const lines = ['---'];
310
+ for (const k of keys)
311
+ lines.push(`${k}: ${data[k]}`);
312
+ lines.push('---');
313
+ return lines.join('\n') + '\n' + body;
314
+ }
315
+ /**
316
+ * Read `last_mapped_commit` from the frontmatter of a `.planning/codebase/*.md`
317
+ * file. Returns null if the file does not exist or has no frontmatter.
318
+ */
319
+ function readMappedCommit(filePath) {
320
+ let content;
321
+ try {
322
+ content = node_fs_1.default.readFileSync(filePath, 'utf8');
323
+ }
324
+ catch {
325
+ return null;
326
+ }
327
+ const { data } = parseFrontmatter(content);
328
+ const sha = data['last_mapped_commit'];
329
+ return typeof sha === 'string' && sha.length > 0 ? sha : null;
330
+ }
331
+ /**
332
+ * Upsert `last_mapped_commit` and `last_mapped_at` into the frontmatter of
333
+ * the given file, preserving any other frontmatter keys and the body.
334
+ */
335
+ function writeMappedCommit(filePath, commitSha, isoDate) {
336
+ // Symmetric with readMappedCommit (which returns null on missing files):
337
+ // tolerate a missing target by creating a minimal frontmatter-only file
338
+ // rather than throwing ENOENT. This matters when a mapper produces a new
339
+ // doc and the caller stamps it before any prior content existed.
340
+ let content = '';
341
+ try {
342
+ content = node_fs_1.default.readFileSync(filePath, 'utf8');
343
+ }
344
+ catch (err) {
345
+ if (err.code !== 'ENOENT')
346
+ throw err;
347
+ }
348
+ const { data, body } = parseFrontmatter(content);
349
+ data['last_mapped_commit'] = commitSha;
350
+ if (isoDate)
351
+ data['last_mapped_at'] = isoDate;
352
+ (0, shell_command_projection_cjs_1.platformWriteSync)(filePath, serializeFrontmatter(data, body));
353
+ }
354
+ module.exports = {
355
+ DRIFT_CATEGORIES,
356
+ classifyFile,
357
+ detectDrift,
358
+ chooseAffectedPaths,
359
+ sanitizePaths,
360
+ readMappedCommit,
361
+ writeMappedCommit,
362
+ // Exposed for the CLI layer to reuse the same parser.
363
+ parseFrontmatter,
364
+ };
@@ -0,0 +1,115 @@
1
+ "use strict";
2
+ /**
3
+ * Fallow binary resolution and report normalisation.
4
+ *
5
+ * ADR-457 build-at-publish: the hand-written bin/lib/fallow-runner.cjs
6
+ * collapsed to a TypeScript source of truth. Behaviour is preserved
7
+ * byte-for-behaviour from the prior hand-written .cjs; only types are added.
8
+ */
9
+ var __importDefault = (this && this.__importDefault) || function (mod) {
10
+ return (mod && mod.__esModule) ? mod : { "default": mod };
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.resolveFallowBinary = resolveFallowBinary;
14
+ exports.requireFallowBinary = requireFallowBinary;
15
+ exports.normalizeFallowReport = normalizeFallowReport;
16
+ const node_fs_1 = __importDefault(require("node:fs"));
17
+ const node_path_1 = __importDefault(require("node:path"));
18
+ function candidateNames() {
19
+ return process.platform === 'win32'
20
+ ? ['fallow.exe', 'fallow.cmd', 'fallow.bat', 'fallow']
21
+ : ['fallow'];
22
+ }
23
+ function isExecutableFile(filePath) {
24
+ try {
25
+ const stat = node_fs_1.default.statSync(filePath);
26
+ if (!stat.isFile())
27
+ return false;
28
+ if (process.platform === 'win32')
29
+ return true;
30
+ node_fs_1.default.accessSync(filePath, node_fs_1.default.constants.X_OK);
31
+ return true;
32
+ }
33
+ catch {
34
+ return false;
35
+ }
36
+ }
37
+ function findInPath(envPath) {
38
+ if (!envPath)
39
+ return null;
40
+ const names = candidateNames();
41
+ const segments = envPath.split(node_path_1.default.delimiter).filter(Boolean);
42
+ for (const segment of segments) {
43
+ for (const name of names) {
44
+ const candidate = node_path_1.default.join(segment, name);
45
+ if (isExecutableFile(candidate))
46
+ return candidate;
47
+ }
48
+ }
49
+ return null;
50
+ }
51
+ function findInNodeModules(cwd) {
52
+ const names = candidateNames();
53
+ const binDir = node_path_1.default.join(cwd, 'node_modules', '.bin');
54
+ for (const name of names) {
55
+ const candidate = node_path_1.default.join(binDir, name);
56
+ if (isExecutableFile(candidate))
57
+ return candidate;
58
+ }
59
+ return null;
60
+ }
61
+ function resolveFallowBinary({ cwd, envPath = process.env['PATH'] ?? '' }) {
62
+ return findInNodeModules(cwd) || findInPath(envPath) || null;
63
+ }
64
+ function requireFallowBinary({ cwd, envPath = process.env['PATH'] ?? '' }) {
65
+ const binary = resolveFallowBinary({ cwd, envPath });
66
+ if (binary)
67
+ return binary;
68
+ throw new Error('Fallow is enabled but no binary was found. Please install fallow via `npm install -D fallow` or `cargo install fallow`.');
69
+ }
70
+ function normalizeFallowReport(report) {
71
+ const unused = Array.isArray(report?.unusedExports)
72
+ ? report.unusedExports
73
+ : [];
74
+ const duplicates = Array.isArray(report?.duplicates)
75
+ ? report.duplicates
76
+ : [];
77
+ const circular = Array.isArray(report?.circularDependencies)
78
+ ? report.circularDependencies
79
+ : [];
80
+ const findings = [];
81
+ for (const item of unused) {
82
+ findings.push({
83
+ type: 'unused_export',
84
+ message: `Unused export ${item.symbol ?? '<unknown>'}`,
85
+ file: item.file ?? '',
86
+ line: item.line ?? null,
87
+ });
88
+ }
89
+ for (const item of duplicates) {
90
+ findings.push({
91
+ type: 'duplicate_block',
92
+ message: `Duplicate block (${Math.round((item.similarity ?? 0) * 100)}% similarity)`,
93
+ file: item.left?.file ?? '',
94
+ line: item.left?.start ?? null,
95
+ related_file: item.right?.file ?? '',
96
+ });
97
+ }
98
+ for (const item of circular) {
99
+ findings.push({
100
+ type: 'circular_dependency',
101
+ message: `Circular dependency: ${(item.cycle ?? []).join(' -> ')}`,
102
+ file: Array.isArray(item.cycle) && item.cycle.length > 0 ? item.cycle[0] : '',
103
+ line: null,
104
+ });
105
+ }
106
+ return {
107
+ summary: {
108
+ unused_exports: unused.length,
109
+ duplicates: duplicates.length,
110
+ circular_dependencies: circular.length,
111
+ total: findings.length,
112
+ },
113
+ findings,
114
+ };
115
+ }