@opengsd/gsd-core 1.2.0-rc.1

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 (503) hide show
  1. package/LICENSE +21 -0
  2. package/README.ja-JP.md +870 -0
  3. package/README.ko-KR.md +861 -0
  4. package/README.md +301 -0
  5. package/README.pt-BR.md +492 -0
  6. package/README.zh-CN.md +842 -0
  7. package/agents/gsd-advisor-researcher.md +127 -0
  8. package/agents/gsd-ai-researcher.md +133 -0
  9. package/agents/gsd-assumptions-analyzer.md +105 -0
  10. package/agents/gsd-code-fixer.md +668 -0
  11. package/agents/gsd-code-reviewer.md +387 -0
  12. package/agents/gsd-codebase-mapper.md +853 -0
  13. package/agents/gsd-debug-session-manager.md +314 -0
  14. package/agents/gsd-debugger.md +1452 -0
  15. package/agents/gsd-doc-classifier.md +168 -0
  16. package/agents/gsd-doc-synthesizer.md +204 -0
  17. package/agents/gsd-doc-verifier.md +217 -0
  18. package/agents/gsd-doc-writer.md +615 -0
  19. package/agents/gsd-domain-researcher.md +153 -0
  20. package/agents/gsd-eval-auditor.md +191 -0
  21. package/agents/gsd-eval-planner.md +154 -0
  22. package/agents/gsd-executor.md +772 -0
  23. package/agents/gsd-framework-selector.md +160 -0
  24. package/agents/gsd-integration-checker.md +470 -0
  25. package/agents/gsd-intel-updater.md +342 -0
  26. package/agents/gsd-nyquist-auditor.md +203 -0
  27. package/agents/gsd-pattern-mapper.md +335 -0
  28. package/agents/gsd-phase-researcher.md +928 -0
  29. package/agents/gsd-plan-checker.md +978 -0
  30. package/agents/gsd-planner.md +1218 -0
  31. package/agents/gsd-project-researcher.md +677 -0
  32. package/agents/gsd-research-synthesizer.md +255 -0
  33. package/agents/gsd-roadmapper.md +688 -0
  34. package/agents/gsd-security-auditor.md +155 -0
  35. package/agents/gsd-ui-auditor.md +495 -0
  36. package/agents/gsd-ui-checker.md +309 -0
  37. package/agents/gsd-ui-researcher.md +380 -0
  38. package/agents/gsd-user-profiler.md +171 -0
  39. package/agents/gsd-verifier.md +917 -0
  40. package/bin/install.js +10936 -0
  41. package/bin/lib/ui-safety-gate.cjs +107 -0
  42. package/commands/gsd/add-tests.md +42 -0
  43. package/commands/gsd/ai-integration-phase.md +37 -0
  44. package/commands/gsd/audit-fix.md +34 -0
  45. package/commands/gsd/audit-milestone.md +37 -0
  46. package/commands/gsd/audit-uat.md +24 -0
  47. package/commands/gsd/autonomous.md +46 -0
  48. package/commands/gsd/capture.md +62 -0
  49. package/commands/gsd/cleanup.md +24 -0
  50. package/commands/gsd/code-review.md +59 -0
  51. package/commands/gsd/complete-milestone.md +143 -0
  52. package/commands/gsd/config.md +56 -0
  53. package/commands/gsd/debug.md +52 -0
  54. package/commands/gsd/discuss-phase.md +76 -0
  55. package/commands/gsd/docs-update.md +49 -0
  56. package/commands/gsd/eval-review.md +33 -0
  57. package/commands/gsd/execute-phase.md +64 -0
  58. package/commands/gsd/explore.md +27 -0
  59. package/commands/gsd/extract-learnings.md +23 -0
  60. package/commands/gsd/fast.md +31 -0
  61. package/commands/gsd/forensics.md +57 -0
  62. package/commands/gsd/graphify.md +199 -0
  63. package/commands/gsd/health.md +31 -0
  64. package/commands/gsd/help.md +28 -0
  65. package/commands/gsd/import.md +41 -0
  66. package/commands/gsd/inbox.md +39 -0
  67. package/commands/gsd/ingest-docs.md +42 -0
  68. package/commands/gsd/manager.md +45 -0
  69. package/commands/gsd/map-codebase.md +83 -0
  70. package/commands/gsd/milestone-summary.md +51 -0
  71. package/commands/gsd/mvp-phase.md +45 -0
  72. package/commands/gsd/new-milestone.md +45 -0
  73. package/commands/gsd/new-project.md +47 -0
  74. package/commands/gsd/ns-context.md +23 -0
  75. package/commands/gsd/ns-ideate.md +24 -0
  76. package/commands/gsd/ns-manage.md +29 -0
  77. package/commands/gsd/ns-project.md +22 -0
  78. package/commands/gsd/ns-review.md +26 -0
  79. package/commands/gsd/ns-workflow.md +28 -0
  80. package/commands/gsd/pause-work.md +43 -0
  81. package/commands/gsd/phase.md +56 -0
  82. package/commands/gsd/plan-phase.md +62 -0
  83. package/commands/gsd/plan-review-convergence.md +59 -0
  84. package/commands/gsd/pr-branch.md +26 -0
  85. package/commands/gsd/profile-user.md +46 -0
  86. package/commands/gsd/progress.md +47 -0
  87. package/commands/gsd/quick.md +174 -0
  88. package/commands/gsd/resume-work.md +30 -0
  89. package/commands/gsd/review-backlog.md +63 -0
  90. package/commands/gsd/review.md +41 -0
  91. package/commands/gsd/secure-phase.md +36 -0
  92. package/commands/gsd/settings.md +29 -0
  93. package/commands/gsd/ship.md +24 -0
  94. package/commands/gsd/sketch.md +60 -0
  95. package/commands/gsd/spec-phase.md +63 -0
  96. package/commands/gsd/spike.md +57 -0
  97. package/commands/gsd/stats.md +19 -0
  98. package/commands/gsd/surface.md +155 -0
  99. package/commands/gsd/thread.md +24 -0
  100. package/commands/gsd/ui-phase.md +35 -0
  101. package/commands/gsd/ui-review.md +33 -0
  102. package/commands/gsd/ultraplan-phase.md +34 -0
  103. package/commands/gsd/undo.md +35 -0
  104. package/commands/gsd/update.md +48 -0
  105. package/commands/gsd/validate-phase.md +36 -0
  106. package/commands/gsd/verify-work.md +39 -0
  107. package/commands/gsd/workspace.md +52 -0
  108. package/commands/gsd/workstreams.md +70 -0
  109. package/get-shit-done/bin/check-latest-version.cjs +106 -0
  110. package/get-shit-done/bin/gsd-tools.cjs +1676 -0
  111. package/get-shit-done/bin/lib/active-workstream-store.cjs +302 -0
  112. package/get-shit-done/bin/lib/adr-parser.cjs +394 -0
  113. package/get-shit-done/bin/lib/agent-command-router.cjs +65 -0
  114. package/get-shit-done/bin/lib/artifacts.cjs +53 -0
  115. package/get-shit-done/bin/lib/audit.cjs +755 -0
  116. package/get-shit-done/bin/lib/check-command-router.cjs +333 -0
  117. package/get-shit-done/bin/lib/cjs-command-router-adapter.cjs +118 -0
  118. package/get-shit-done/bin/lib/clock.cjs +96 -0
  119. package/get-shit-done/bin/lib/clusters.cjs +135 -0
  120. package/get-shit-done/bin/lib/code-review-flags.cjs +74 -0
  121. package/get-shit-done/bin/lib/command-aliases.cjs +815 -0
  122. package/get-shit-done/bin/lib/command-arg-projection.cjs +62 -0
  123. package/get-shit-done/bin/lib/command-routing-hub.cjs +388 -0
  124. package/get-shit-done/bin/lib/commands.cjs +1188 -0
  125. package/get-shit-done/bin/lib/config-schema.cjs +31 -0
  126. package/get-shit-done/bin/lib/config.cjs +728 -0
  127. package/get-shit-done/bin/lib/configuration.cjs +248 -0
  128. package/get-shit-done/bin/lib/context-utilization.cjs +47 -0
  129. package/get-shit-done/bin/lib/core.cjs +2121 -0
  130. package/get-shit-done/bin/lib/decisions.cjs +116 -0
  131. package/get-shit-done/bin/lib/docs.cjs +270 -0
  132. package/get-shit-done/bin/lib/drift.cjs +388 -0
  133. package/get-shit-done/bin/lib/fallow-runner.cjs +109 -0
  134. package/get-shit-done/bin/lib/frontmatter.cjs +389 -0
  135. package/get-shit-done/bin/lib/gap-checker.cjs +205 -0
  136. package/get-shit-done/bin/lib/graphify.cjs +592 -0
  137. package/get-shit-done/bin/lib/gsd2-import.cjs +514 -0
  138. package/get-shit-done/bin/lib/init-command-router.cjs +58 -0
  139. package/get-shit-done/bin/lib/init.cjs +2112 -0
  140. package/get-shit-done/bin/lib/install-profiles.cjs +603 -0
  141. package/get-shit-done/bin/lib/installer-migration-authoring.cjs +117 -0
  142. package/get-shit-done/bin/lib/installer-migration-report.cjs +354 -0
  143. package/get-shit-done/bin/lib/installer-migrations/000-first-time-baseline.cjs +220 -0
  144. package/get-shit-done/bin/lib/installer-migrations/001-legacy-orphan-files.cjs +41 -0
  145. package/get-shit-done/bin/lib/installer-migrations/002-codex-legacy-hooks-json.cjs +80 -0
  146. package/get-shit-done/bin/lib/installer-migrations.cjs +778 -0
  147. package/get-shit-done/bin/lib/intel.cjs +708 -0
  148. package/get-shit-done/bin/lib/learnings.cjs +421 -0
  149. package/get-shit-done/bin/lib/milestone.cjs +314 -0
  150. package/get-shit-done/bin/lib/model-catalog.cjs +212 -0
  151. package/get-shit-done/bin/lib/model-profiles.cjs +31 -0
  152. package/get-shit-done/bin/lib/observability/event.cjs +82 -0
  153. package/get-shit-done/bin/lib/observability/logger.cjs +174 -0
  154. package/get-shit-done/bin/lib/observability/redaction.cjs +50 -0
  155. package/get-shit-done/bin/lib/package-identity.cjs +31 -0
  156. package/get-shit-done/bin/lib/phase-command-router.cjs +191 -0
  157. package/get-shit-done/bin/lib/phase-lifecycle.cjs +80 -0
  158. package/get-shit-done/bin/lib/phase.cjs +1607 -0
  159. package/get-shit-done/bin/lib/phases-command-router.cjs +39 -0
  160. package/get-shit-done/bin/lib/plan-scan.cjs +97 -0
  161. package/get-shit-done/bin/lib/planning-workspace.cjs +238 -0
  162. package/get-shit-done/bin/lib/profile-output.cjs +1141 -0
  163. package/get-shit-done/bin/lib/profile-pipeline.cjs +539 -0
  164. package/get-shit-done/bin/lib/project-root.cjs +112 -0
  165. package/get-shit-done/bin/lib/prompt-budget.cjs +399 -0
  166. package/get-shit-done/bin/lib/review-reviewer-selection.cjs +125 -0
  167. package/get-shit-done/bin/lib/roadmap-command-router.cjs +28 -0
  168. package/get-shit-done/bin/lib/roadmap.cjs +650 -0
  169. package/get-shit-done/bin/lib/runtime-artifact-layout.cjs +301 -0
  170. package/get-shit-done/bin/lib/runtime-homes.cjs +222 -0
  171. package/get-shit-done/bin/lib/runtime-name-policy.cjs +83 -0
  172. package/get-shit-done/bin/lib/runtime-slash.cjs +112 -0
  173. package/get-shit-done/bin/lib/schema-detect.cjs +165 -0
  174. package/get-shit-done/bin/lib/secrets.cjs +32 -0
  175. package/get-shit-done/bin/lib/security.cjs +600 -0
  176. package/get-shit-done/bin/lib/semver-compare.cjs +35 -0
  177. package/get-shit-done/bin/lib/shell-command-projection.cjs +500 -0
  178. package/get-shit-done/bin/lib/state-command-router.cjs +252 -0
  179. package/get-shit-done/bin/lib/state-document.cjs +263 -0
  180. package/get-shit-done/bin/lib/state.cjs +2038 -0
  181. package/get-shit-done/bin/lib/surface.cjs +470 -0
  182. package/get-shit-done/bin/lib/task-command-router.cjs +81 -0
  183. package/get-shit-done/bin/lib/template.cjs +228 -0
  184. package/get-shit-done/bin/lib/uat.cjs +289 -0
  185. package/get-shit-done/bin/lib/update-context.cjs +209 -0
  186. package/get-shit-done/bin/lib/validate-command-router.cjs +83 -0
  187. package/get-shit-done/bin/lib/validate.cjs +92 -0
  188. package/get-shit-done/bin/lib/verify-command-router.cjs +40 -0
  189. package/get-shit-done/bin/lib/verify.cjs +1511 -0
  190. package/get-shit-done/bin/lib/workstream-inventory-builder.cjs +74 -0
  191. package/get-shit-done/bin/lib/workstream-inventory.cjs +146 -0
  192. package/get-shit-done/bin/lib/workstream-name-policy.cjs +94 -0
  193. package/get-shit-done/bin/lib/workstream.cjs +389 -0
  194. package/get-shit-done/bin/lib/worktree-safety.cjs +985 -0
  195. package/get-shit-done/bin/shared/config-defaults.manifest.json +97 -0
  196. package/get-shit-done/bin/shared/config-schema.manifest.json +175 -0
  197. package/get-shit-done/bin/shared/model-catalog.json +122 -0
  198. package/get-shit-done/bin/shared/runtime-aliases.manifest.json +75 -0
  199. package/get-shit-done/bin/verify-reapply-patches.cjs +352 -0
  200. package/get-shit-done/contexts/dev.md +21 -0
  201. package/get-shit-done/contexts/research.md +22 -0
  202. package/get-shit-done/contexts/review.md +23 -0
  203. package/get-shit-done/references/agent-contracts.md +79 -0
  204. package/get-shit-done/references/ai-evals.md +156 -0
  205. package/get-shit-done/references/ai-frameworks.md +186 -0
  206. package/get-shit-done/references/artifact-types.md +131 -0
  207. package/get-shit-done/references/autonomous-smart-discuss.md +277 -0
  208. package/get-shit-done/references/checkpoints.md +814 -0
  209. package/get-shit-done/references/common-bug-patterns.md +114 -0
  210. package/get-shit-done/references/context-budget.md +85 -0
  211. package/get-shit-done/references/continuation-format.md +253 -0
  212. package/get-shit-done/references/debugger-philosophy.md +76 -0
  213. package/get-shit-done/references/decimal-phase-calculation.md +64 -0
  214. package/get-shit-done/references/doc-conflict-engine.md +91 -0
  215. package/get-shit-done/references/domain-probes.md +125 -0
  216. package/get-shit-done/references/execute-mvp-tdd.md +81 -0
  217. package/get-shit-done/references/executor-examples.md +110 -0
  218. package/get-shit-done/references/few-shot-examples/plan-checker.md +73 -0
  219. package/get-shit-done/references/few-shot-examples/verifier.md +109 -0
  220. package/get-shit-done/references/gate-prompts.md +100 -0
  221. package/get-shit-done/references/gates.md +70 -0
  222. package/get-shit-done/references/git-integration.md +298 -0
  223. package/get-shit-done/references/git-planning-commit.md +40 -0
  224. package/get-shit-done/references/ios-scaffold.md +123 -0
  225. package/get-shit-done/references/mandatory-initial-read.md +2 -0
  226. package/get-shit-done/references/model-profile-resolution.md +38 -0
  227. package/get-shit-done/references/model-profiles.md +245 -0
  228. package/get-shit-done/references/mvp-concepts.md +49 -0
  229. package/get-shit-done/references/phase-argument-parsing.md +61 -0
  230. package/get-shit-done/references/planner-antipatterns.md +89 -0
  231. package/get-shit-done/references/planner-chunked.md +49 -0
  232. package/get-shit-done/references/planner-gap-closure.md +62 -0
  233. package/get-shit-done/references/planner-graphify-auto-update.md +67 -0
  234. package/get-shit-done/references/planner-human-verify-mode.md +57 -0
  235. package/get-shit-done/references/planner-interface-context.md +62 -0
  236. package/get-shit-done/references/planner-mvp-mode.md +53 -0
  237. package/get-shit-done/references/planner-reviews.md +39 -0
  238. package/get-shit-done/references/planner-revision.md +87 -0
  239. package/get-shit-done/references/planner-source-audit.md +73 -0
  240. package/get-shit-done/references/planning-config.md +471 -0
  241. package/get-shit-done/references/project-skills-discovery.md +19 -0
  242. package/get-shit-done/references/questioning.md +162 -0
  243. package/get-shit-done/references/revision-loop.md +97 -0
  244. package/get-shit-done/references/scout-codebase.md +51 -0
  245. package/get-shit-done/references/skeleton-template.md +48 -0
  246. package/get-shit-done/references/sketch-interactivity.md +41 -0
  247. package/get-shit-done/references/sketch-theme-system.md +94 -0
  248. package/get-shit-done/references/sketch-tooling.md +45 -0
  249. package/get-shit-done/references/sketch-variant-patterns.md +81 -0
  250. package/get-shit-done/references/spidr-splitting.md +69 -0
  251. package/get-shit-done/references/tdd.md +330 -0
  252. package/get-shit-done/references/thinking-models-debug.md +44 -0
  253. package/get-shit-done/references/thinking-models-execution.md +50 -0
  254. package/get-shit-done/references/thinking-models-planning.md +62 -0
  255. package/get-shit-done/references/thinking-models-research.md +50 -0
  256. package/get-shit-done/references/thinking-models-verification.md +55 -0
  257. package/get-shit-done/references/thinking-partner.md +96 -0
  258. package/get-shit-done/references/ui-brand.md +160 -0
  259. package/get-shit-done/references/universal-anti-patterns.md +63 -0
  260. package/get-shit-done/references/user-profiling.md +681 -0
  261. package/get-shit-done/references/user-story-template.md +58 -0
  262. package/get-shit-done/references/verification-overrides.md +227 -0
  263. package/get-shit-done/references/verification-patterns.md +612 -0
  264. package/get-shit-done/references/verify-mvp-mode.md +85 -0
  265. package/get-shit-done/references/workstream-flag.md +111 -0
  266. package/get-shit-done/references/worktree-path-safety.md +89 -0
  267. package/get-shit-done/templates/AI-SPEC.md +246 -0
  268. package/get-shit-done/templates/DEBUG.md +169 -0
  269. package/get-shit-done/templates/README.md +77 -0
  270. package/get-shit-done/templates/SECURITY.md +61 -0
  271. package/get-shit-done/templates/UAT.md +265 -0
  272. package/get-shit-done/templates/UI-SPEC.md +100 -0
  273. package/get-shit-done/templates/VALIDATION.md +76 -0
  274. package/get-shit-done/templates/claude-md.md +145 -0
  275. package/get-shit-done/templates/codebase/architecture.md +255 -0
  276. package/get-shit-done/templates/codebase/concerns.md +310 -0
  277. package/get-shit-done/templates/codebase/conventions.md +307 -0
  278. package/get-shit-done/templates/codebase/integrations.md +280 -0
  279. package/get-shit-done/templates/codebase/stack.md +186 -0
  280. package/get-shit-done/templates/codebase/structure.md +285 -0
  281. package/get-shit-done/templates/codebase/testing.md +480 -0
  282. package/get-shit-done/templates/config.json +62 -0
  283. package/get-shit-done/templates/context.md +352 -0
  284. package/get-shit-done/templates/continue-here.md +78 -0
  285. package/get-shit-done/templates/copilot-instructions.md +7 -0
  286. package/get-shit-done/templates/debug-subagent-prompt.md +91 -0
  287. package/get-shit-done/templates/dev-preferences.md +21 -0
  288. package/get-shit-done/templates/discovery.md +146 -0
  289. package/get-shit-done/templates/discussion-log.md +63 -0
  290. package/get-shit-done/templates/milestone-archive.md +123 -0
  291. package/get-shit-done/templates/milestone.md +115 -0
  292. package/get-shit-done/templates/phase-prompt.md +610 -0
  293. package/get-shit-done/templates/planner-subagent-prompt.md +117 -0
  294. package/get-shit-done/templates/project.md +186 -0
  295. package/get-shit-done/templates/requirements.md +231 -0
  296. package/get-shit-done/templates/research-project/ARCHITECTURE.md +204 -0
  297. package/get-shit-done/templates/research-project/FEATURES.md +147 -0
  298. package/get-shit-done/templates/research-project/PITFALLS.md +200 -0
  299. package/get-shit-done/templates/research-project/STACK.md +120 -0
  300. package/get-shit-done/templates/research-project/SUMMARY.md +170 -0
  301. package/get-shit-done/templates/research.md +592 -0
  302. package/get-shit-done/templates/retrospective.md +54 -0
  303. package/get-shit-done/templates/roadmap.md +202 -0
  304. package/get-shit-done/templates/spec.md +307 -0
  305. package/get-shit-done/templates/state.md +195 -0
  306. package/get-shit-done/templates/summary-complex.md +59 -0
  307. package/get-shit-done/templates/summary-minimal.md +41 -0
  308. package/get-shit-done/templates/summary-standard.md +48 -0
  309. package/get-shit-done/templates/summary.md +248 -0
  310. package/get-shit-done/templates/user-profile.md +146 -0
  311. package/get-shit-done/templates/user-setup.md +311 -0
  312. package/get-shit-done/templates/verification-report.md +322 -0
  313. package/get-shit-done/workflows/_runtime-launcher.snippet.sh +1 -0
  314. package/get-shit-done/workflows/add-backlog.md +91 -0
  315. package/get-shit-done/workflows/add-phase.md +113 -0
  316. package/get-shit-done/workflows/add-tests.md +355 -0
  317. package/get-shit-done/workflows/add-todo.md +161 -0
  318. package/get-shit-done/workflows/ai-integration-phase.md +295 -0
  319. package/get-shit-done/workflows/analyze-dependencies.md +96 -0
  320. package/get-shit-done/workflows/audit-fix.md +178 -0
  321. package/get-shit-done/workflows/audit-milestone.md +358 -0
  322. package/get-shit-done/workflows/audit-uat.md +110 -0
  323. package/get-shit-done/workflows/autonomous.md +795 -0
  324. package/get-shit-done/workflows/check-todos.md +180 -0
  325. package/get-shit-done/workflows/cleanup.md +155 -0
  326. package/get-shit-done/workflows/code-review-fix.md +502 -0
  327. package/get-shit-done/workflows/code-review.md +656 -0
  328. package/get-shit-done/workflows/complete-milestone.md +855 -0
  329. package/get-shit-done/workflows/debug.md +232 -0
  330. package/get-shit-done/workflows/diagnose-issues.md +241 -0
  331. package/get-shit-done/workflows/discovery-phase.md +291 -0
  332. package/get-shit-done/workflows/discuss-phase/modes/advisor.md +176 -0
  333. package/get-shit-done/workflows/discuss-phase/modes/all.md +28 -0
  334. package/get-shit-done/workflows/discuss-phase/modes/analyze.md +44 -0
  335. package/get-shit-done/workflows/discuss-phase/modes/auto.md +57 -0
  336. package/get-shit-done/workflows/discuss-phase/modes/batch.md +52 -0
  337. package/get-shit-done/workflows/discuss-phase/modes/chain.md +98 -0
  338. package/get-shit-done/workflows/discuss-phase/modes/default.md +141 -0
  339. package/get-shit-done/workflows/discuss-phase/modes/power.md +44 -0
  340. package/get-shit-done/workflows/discuss-phase/modes/text.md +55 -0
  341. package/get-shit-done/workflows/discuss-phase/templates/checkpoint.json +18 -0
  342. package/get-shit-done/workflows/discuss-phase/templates/context.md +136 -0
  343. package/get-shit-done/workflows/discuss-phase/templates/discussion-log.md +50 -0
  344. package/get-shit-done/workflows/discuss-phase-assumptions.md +675 -0
  345. package/get-shit-done/workflows/discuss-phase-power.md +291 -0
  346. package/get-shit-done/workflows/discuss-phase.md +499 -0
  347. package/get-shit-done/workflows/do.md +111 -0
  348. package/get-shit-done/workflows/docs-update.md +1162 -0
  349. package/get-shit-done/workflows/edit-phase.md +295 -0
  350. package/get-shit-done/workflows/eval-review.md +156 -0
  351. package/get-shit-done/workflows/execute-phase/steps/codebase-drift-gate.md +82 -0
  352. package/get-shit-done/workflows/execute-phase/steps/per-plan-worktree-gate.md +94 -0
  353. package/get-shit-done/workflows/execute-phase/steps/post-merge-gate.md +117 -0
  354. package/get-shit-done/workflows/execute-phase.md +1709 -0
  355. package/get-shit-done/workflows/execute-plan.md +526 -0
  356. package/get-shit-done/workflows/explore.md +144 -0
  357. package/get-shit-done/workflows/extract-learnings.md +243 -0
  358. package/get-shit-done/workflows/fast.md +124 -0
  359. package/get-shit-done/workflows/forensics.md +279 -0
  360. package/get-shit-done/workflows/graduation.md +196 -0
  361. package/get-shit-done/workflows/health.md +224 -0
  362. package/get-shit-done/workflows/help/modes/brief.md +22 -0
  363. package/get-shit-done/workflows/help/modes/default.md +50 -0
  364. package/get-shit-done/workflows/help/modes/full.md +784 -0
  365. package/get-shit-done/workflows/help/modes/topic.md +74 -0
  366. package/get-shit-done/workflows/help.md +24 -0
  367. package/get-shit-done/workflows/import.md +254 -0
  368. package/get-shit-done/workflows/inbox.md +387 -0
  369. package/get-shit-done/workflows/ingest-docs.md +339 -0
  370. package/get-shit-done/workflows/insert-phase.md +152 -0
  371. package/get-shit-done/workflows/list-phase-assumptions.md +178 -0
  372. package/get-shit-done/workflows/list-workspaces.md +57 -0
  373. package/get-shit-done/workflows/manager.md +393 -0
  374. package/get-shit-done/workflows/map-codebase.md +444 -0
  375. package/get-shit-done/workflows/milestone-summary.md +224 -0
  376. package/get-shit-done/workflows/mvp-phase.md +222 -0
  377. package/get-shit-done/workflows/new-milestone.md +635 -0
  378. package/get-shit-done/workflows/new-project.md +1555 -0
  379. package/get-shit-done/workflows/new-workspace.md +240 -0
  380. package/get-shit-done/workflows/next.md +299 -0
  381. package/get-shit-done/workflows/node-repair.md +92 -0
  382. package/get-shit-done/workflows/note.md +158 -0
  383. package/get-shit-done/workflows/pause-work.md +244 -0
  384. package/get-shit-done/workflows/plan-milestone-gaps.md +281 -0
  385. package/get-shit-done/workflows/plan-phase.md +1809 -0
  386. package/get-shit-done/workflows/plan-review-convergence.md +346 -0
  387. package/get-shit-done/workflows/plant-seed.md +230 -0
  388. package/get-shit-done/workflows/pr-branch.md +157 -0
  389. package/get-shit-done/workflows/profile-user.md +453 -0
  390. package/get-shit-done/workflows/progress.md +699 -0
  391. package/get-shit-done/workflows/quick.md +1039 -0
  392. package/get-shit-done/workflows/reapply-patches.md +426 -0
  393. package/get-shit-done/workflows/remove-phase.md +156 -0
  394. package/get-shit-done/workflows/remove-workspace.md +108 -0
  395. package/get-shit-done/workflows/resume-project.md +332 -0
  396. package/get-shit-done/workflows/review.md +623 -0
  397. package/get-shit-done/workflows/scan.md +105 -0
  398. package/get-shit-done/workflows/secure-phase.md +180 -0
  399. package/get-shit-done/workflows/session-report.md +146 -0
  400. package/get-shit-done/workflows/settings-advanced.md +620 -0
  401. package/get-shit-done/workflows/settings-integrations.md +312 -0
  402. package/get-shit-done/workflows/settings.md +552 -0
  403. package/get-shit-done/workflows/ship.md +356 -0
  404. package/get-shit-done/workflows/sketch-wrap-up.md +286 -0
  405. package/get-shit-done/workflows/sketch.md +361 -0
  406. package/get-shit-done/workflows/spec-phase.md +262 -0
  407. package/get-shit-done/workflows/spike-wrap-up.md +307 -0
  408. package/get-shit-done/workflows/spike.md +453 -0
  409. package/get-shit-done/workflows/stats.md +80 -0
  410. package/get-shit-done/workflows/sync-skills.md +182 -0
  411. package/get-shit-done/workflows/thread.md +222 -0
  412. package/get-shit-done/workflows/transition.md +694 -0
  413. package/get-shit-done/workflows/ui-phase.md +328 -0
  414. package/get-shit-done/workflows/ui-review.md +193 -0
  415. package/get-shit-done/workflows/ultraplan-phase.md +199 -0
  416. package/get-shit-done/workflows/undo.md +314 -0
  417. package/get-shit-done/workflows/update.md +443 -0
  418. package/get-shit-done/workflows/validate-phase.md +179 -0
  419. package/get-shit-done/workflows/verify-phase.md +544 -0
  420. package/get-shit-done/workflows/verify-work.md +781 -0
  421. package/hooks/dist/gsd-check-update-worker.js +95 -0
  422. package/hooks/dist/gsd-check-update.js +64 -0
  423. package/hooks/dist/gsd-context-monitor.js +195 -0
  424. package/hooks/dist/gsd-graphify-update.sh +158 -0
  425. package/hooks/dist/gsd-phase-boundary.sh +47 -0
  426. package/hooks/dist/gsd-prompt-guard.js +97 -0
  427. package/hooks/dist/gsd-read-guard.js +101 -0
  428. package/hooks/dist/gsd-read-injection-scanner.js +203 -0
  429. package/hooks/dist/gsd-session-state.sh +59 -0
  430. package/hooks/dist/gsd-statusline.js +548 -0
  431. package/hooks/dist/gsd-update-banner.js +134 -0
  432. package/hooks/dist/gsd-validate-commit.sh +57 -0
  433. package/hooks/dist/gsd-workflow-guard.js +166 -0
  434. package/hooks/dist/lib/git-cmd.js +150 -0
  435. package/hooks/dist/lib/gsd-graphify-rebuild.sh +65 -0
  436. package/hooks/gsd-check-update-worker.js +95 -0
  437. package/hooks/gsd-check-update.js +64 -0
  438. package/hooks/gsd-context-monitor.js +195 -0
  439. package/hooks/gsd-graphify-update.sh +158 -0
  440. package/hooks/gsd-phase-boundary.sh +47 -0
  441. package/hooks/gsd-prompt-guard.js +97 -0
  442. package/hooks/gsd-read-guard.js +101 -0
  443. package/hooks/gsd-read-injection-scanner.js +203 -0
  444. package/hooks/gsd-session-state.sh +59 -0
  445. package/hooks/gsd-statusline.js +548 -0
  446. package/hooks/gsd-update-banner.js +134 -0
  447. package/hooks/gsd-validate-commit.sh +57 -0
  448. package/hooks/gsd-workflow-guard.js +166 -0
  449. package/hooks/lib/git-cmd.js +150 -0
  450. package/hooks/lib/gsd-graphify-rebuild.sh +65 -0
  451. package/hooks/managed-hooks-registry.cjs +34 -0
  452. package/package.json +102 -0
  453. package/scripts/affected-tests-lib.cjs +541 -0
  454. package/scripts/audit-workflow-script-paths.cjs +73 -0
  455. package/scripts/base64-scan.sh +339 -0
  456. package/scripts/build-hooks.js +236 -0
  457. package/scripts/changeset/README.md +129 -0
  458. package/scripts/changeset/cli.cjs +392 -0
  459. package/scripts/changeset/github-release-notes.cjs +199 -0
  460. package/scripts/changeset/lint.cjs +110 -0
  461. package/scripts/changeset/new.cjs +137 -0
  462. package/scripts/changeset/parse.cjs +114 -0
  463. package/scripts/changeset/render.cjs +34 -0
  464. package/scripts/changeset/serialize.cjs +130 -0
  465. package/scripts/check-alias-drift.cjs +108 -0
  466. package/scripts/check-env.cjs +302 -0
  467. package/scripts/check-npm-integrity.cjs +209 -0
  468. package/scripts/ci-guard-runner.cjs +16 -0
  469. package/scripts/ci-prepare-test-scope.cjs +46 -0
  470. package/scripts/ci-rebase-check.cjs +85 -0
  471. package/scripts/ci-test-scope.cjs +302 -0
  472. package/scripts/command-contract-helpers.cjs +64 -0
  473. package/scripts/diff-touches-shipped-paths.cjs +147 -0
  474. package/scripts/fix-slash-commands.cjs +147 -0
  475. package/scripts/gen-inventory-manifest.cjs +109 -0
  476. package/scripts/generate-package-identity.cjs +104 -0
  477. package/scripts/lint-command-contract.cjs +108 -0
  478. package/scripts/lint-descriptions.cjs +83 -0
  479. package/scripts/lint-docs-required.cjs +222 -0
  480. package/scripts/lint-no-source-grep-extras.cjs +81 -0
  481. package/scripts/lint-no-source-grep.cjs +174 -0
  482. package/scripts/lint-package-identity-drift.cjs +141 -0
  483. package/scripts/lint-pr-check-project-dir.cjs +98 -0
  484. package/scripts/lint-shared-module-handsync.cjs +388 -0
  485. package/scripts/lint-shell-command-projection-drift.cjs +57 -0
  486. package/scripts/lint-skill-deps.cjs +180 -0
  487. package/scripts/lint-test-file-count.allowlist.json +36 -0
  488. package/scripts/lint-test-file-count.cjs +190 -0
  489. package/scripts/pr-template-policy.cjs +268 -0
  490. package/scripts/prompt-injection-scan.sh +203 -0
  491. package/scripts/release-tarball-smoke.cjs +627 -0
  492. package/scripts/run-affected-tests.cjs +6 -0
  493. package/scripts/run-cross-platform-tests.cjs +63 -0
  494. package/scripts/run-tests.cjs +282 -0
  495. package/scripts/secret-scan-lint.sh +231 -0
  496. package/scripts/secret-scan.sh +358 -0
  497. package/scripts/setup-branch-protection.sh +236 -0
  498. package/scripts/shared-module-handsync-allowlist.json +183 -0
  499. package/scripts/strip-prose-atrefs.cjs +106 -0
  500. package/scripts/sync-rulesets.sh +34 -0
  501. package/scripts/sync-runtime-launcher.cjs +402 -0
  502. package/scripts/test-failure-reasons.cjs +34 -0
  503. package/scripts/workflow-policy.cjs +450 -0
@@ -0,0 +1,656 @@
1
+ <purpose>
2
+ Review source files changed during a phase for bugs, security issues, and code quality problems. Computes file scope (--files override > SUMMARY.md > git diff fallback), checks config gate, spawns gsd-code-reviewer agent, commits REVIEW.md, and presents results to user. When --fix is passed, delegates to code-review-fix.md after review to auto-apply findings via gsd-code-fixer.
3
+ </purpose>
4
+
5
+ <required_reading>
6
+ Read all files referenced by the invoking prompt's execution_context before starting.
7
+ </required_reading>
8
+
9
+ <available_agent_types>
10
+ - gsd-code-reviewer: Reviews source files for bugs and quality issues
11
+ - gsd-code-fixer: Applies fixes to code review findings (used via dispatch_fix → code-review-fix.md when --fix is passed)
12
+ </available_agent_types>
13
+
14
+ <process>
15
+
16
+ <step name="initialize">
17
+ Parse arguments and load project state:
18
+
19
+ ```bash
20
+ _GSD_SHIM_NAME="gsd-tools.cjs"; _GSD_RUNTIME_ROOT="${RUNTIME_DIR:-$(git rev-parse --show-toplevel 2>/dev/null || pwd)}"; GSD_TOOLS="${_GSD_RUNTIME_ROOT}/get-shit-done/bin/${_GSD_SHIM_NAME}"; if [ -f "$GSD_TOOLS" ]; then gsd_run() { node "$GSD_TOOLS" "$@"; }; elif [ -f "${_GSD_RUNTIME_ROOT}/.claude/get-shit-done/bin/${_GSD_SHIM_NAME}" ]; then GSD_TOOLS="${_GSD_RUNTIME_ROOT}/.claude/get-shit-done/bin/${_GSD_SHIM_NAME}"; gsd_run() { node "$GSD_TOOLS" "$@"; }; elif command -v gsd-tools >/dev/null 2>&1; then GSD_TOOLS="$(command -v gsd-tools)"; gsd_run() { "$GSD_TOOLS" "$@"; }; elif [ -f "$HOME/.claude/get-shit-done/bin/${_GSD_SHIM_NAME}" ]; then GSD_TOOLS="$HOME/.claude/get-shit-done/bin/${_GSD_SHIM_NAME}"; gsd_run() { node "$GSD_TOOLS" "$@"; }; else echo "ERROR: gsd-tools.cjs not found at $GSD_TOOLS and gsd-tools is not on PATH. Run: npx -y @opengsd/gsd-core@latest --claude --local" >&2; exit 1; fi
21
+ PHASE_ARG="${1}"
22
+ INIT=$(gsd_run query init.phase-op "${PHASE_ARG}")
23
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
24
+ ```
25
+
26
+ Parse from init JSON: `phase_found`, `phase_dir`, `phase_number`, `phase_name`, `padded_phase`, `commit_docs`.
27
+
28
+ **Input sanitization (defense-in-depth):**
29
+ ```bash
30
+ # Validate PADDED_PHASE contains only digits and optional dot (e.g., "02", "03.1")
31
+ if ! [[ "$PADDED_PHASE" =~ ^[0-9]+(\.[0-9]+)?$ ]]; then
32
+ echo "Error: Invalid phase number format: '${PADDED_PHASE}'. Expected digits (e.g., 02, 03.1)."
33
+ # Exit workflow
34
+ fi
35
+ ```
36
+
37
+ **Phase validation (before config gate):**
38
+ If `phase_found` is false, report error and exit:
39
+ ```
40
+ Error: Phase ${PHASE_ARG} not found. Run /gsd:progress to see available phases.
41
+ ```
42
+
43
+ This runs BEFORE config gate check so user errors are surfaced immediately regardless of config state.
44
+
45
+ Parse optional flags from $ARGUMENTS using the typed flag parser:
46
+
47
+ ```bash
48
+ # Parse all code-review flags into a structured IR via code-review-flags.cjs.
49
+ # This is the canonical flag-parsing surface — do not replicate inline bash parsing
50
+ # for --fix/--all/--auto here; the module handles all flag extraction and implication
51
+ # logic (e.g., --all and --auto imply --fix).
52
+ FLAGS_JSON=$(node -e "
53
+ const { parseCodeReviewFlags } = require('./get-shit-done/bin/lib/code-review-flags.cjs');
54
+ const flags = parseCodeReviewFlags(process.argv.slice(1));
55
+ process.stdout.write(JSON.stringify(flags));
56
+ " -- "$@" 2>/dev/null)
57
+
58
+ # Extract individual flag values from the IR
59
+ FIX_FLAG=$(echo "$FLAGS_JSON" | node -e "process.stdout.write(String(JSON.parse(require('fs').readFileSync('/dev/stdin','utf-8')).fix))")
60
+ FIX_ALL=$(echo "$FLAGS_JSON" | node -e "process.stdout.write(String(JSON.parse(require('fs').readFileSync('/dev/stdin','utf-8')).all))")
61
+ FIX_AUTO=$(echo "$FLAGS_JSON" | node -e "process.stdout.write(String(JSON.parse(require('fs').readFileSync('/dev/stdin','utf-8')).auto))")
62
+ DEPTH_OVERRIDE=$(echo "$FLAGS_JSON" | node -e "process.stdout.write(JSON.parse(require('fs').readFileSync('/dev/stdin','utf-8')).depth)")
63
+ FILES_OVERRIDE=$(echo "$FLAGS_JSON" | node -e "process.stdout.write(JSON.parse(require('fs').readFileSync('/dev/stdin','utf-8')).files)")
64
+ ```
65
+
66
+ If FILES_OVERRIDE is set, split by comma into array:
67
+ ```bash
68
+ if [ -n "$FILES_OVERRIDE" ]; then
69
+ IFS=',' read -ra FILES_ARRAY <<< "$FILES_OVERRIDE"
70
+ fi
71
+ ```
72
+ </step>
73
+
74
+ <step name="check_config_gate">
75
+ Check if code review is enabled via config:
76
+
77
+ ```bash
78
+ CODE_REVIEW_ENABLED=$(gsd_run query config-get workflow.code_review 2>/dev/null || echo "true")
79
+ ```
80
+
81
+ If CODE_REVIEW_ENABLED is "false":
82
+ ```
83
+ Code review skipped (workflow.code_review=false in config)
84
+ ```
85
+ Exit workflow.
86
+
87
+ Default is true — only skip on explicit false. This check runs AFTER phase validation so invalid phase errors are shown first.
88
+ </step>
89
+
90
+ <step name="resolve_depth">
91
+ Determine review depth with priority order:
92
+
93
+ 1. DEPTH_OVERRIDE from --depth flag (highest priority)
94
+ 2. Config value: `gsd-tools.cjs query config-get workflow.code_review_depth 2>/dev/null`
95
+ 3. Default: "standard"
96
+
97
+ ```bash
98
+ if [ -n "$DEPTH_OVERRIDE" ]; then
99
+ REVIEW_DEPTH="$DEPTH_OVERRIDE"
100
+ else
101
+ CONFIG_DEPTH=$(gsd_run query config-get workflow.code_review_depth 2>/dev/null || echo "")
102
+ REVIEW_DEPTH="${CONFIG_DEPTH:-standard}"
103
+ fi
104
+ ```
105
+
106
+ **Validate depth value:**
107
+ ```bash
108
+ case "$REVIEW_DEPTH" in
109
+ quick|standard|deep)
110
+ # Valid
111
+ ;;
112
+ *)
113
+ echo "Warning: Invalid depth '${REVIEW_DEPTH}'. Valid values: quick, standard, deep. Using 'standard'."
114
+ REVIEW_DEPTH="standard"
115
+ ;;
116
+ esac
117
+ ```
118
+ </step>
119
+
120
+ <step name="compute_file_scope">
121
+ Three-tier scoping with explicit precedence:
122
+
123
+ **Tier 1 — --files override (highest precedence per D-08):**
124
+
125
+ If FILES_OVERRIDE is set (from --files flag):
126
+ ```bash
127
+ if [ -n "$FILES_OVERRIDE" ]; then
128
+ REVIEW_FILES=()
129
+ REPO_ROOT=$(git rev-parse --show-toplevel 2>/dev/null)
130
+
131
+ for file_path in "${FILES_ARRAY[@]}"; do
132
+ # Security: validate path is within repository (prevent path traversal)
133
+ ABS_PATH=$(realpath -m "${file_path}" 2>/dev/null || echo "${file_path}")
134
+ if [[ "$ABS_PATH" != "$REPO_ROOT"* ]]; then
135
+ echo "Error: File path outside repository, skipping: ${file_path}"
136
+ continue
137
+ fi
138
+
139
+ # Validate path exists (relative to repo root)
140
+ if [ -f "${REPO_ROOT}/${file_path}" ] || [ -f "${file_path}" ]; then
141
+ REVIEW_FILES+=("$file_path")
142
+ else
143
+ echo "Warning: File not found, skipping: ${file_path}"
144
+ fi
145
+ done
146
+
147
+ echo "File scope: ${#REVIEW_FILES[@]} files from --files override"
148
+ fi
149
+ ```
150
+
151
+ Skip SUMMARY/git scoping entirely when --files is provided.
152
+
153
+ **Tier 2 — SUMMARY.md extraction (primary per D-01):**
154
+
155
+ If --files NOT provided:
156
+ ```bash
157
+ if [ -z "$FILES_OVERRIDE" ]; then
158
+ SUMMARIES=$(ls "${PHASE_DIR}"/*-SUMMARY.md 2>/dev/null)
159
+ REVIEW_FILES=()
160
+
161
+ if [ -n "$SUMMARIES" ]; then
162
+ for summary in $SUMMARIES; do
163
+ # Extract key_files.created and key_files.modified using node for reliable YAML parsing
164
+ # This avoids fragile awk parsing that breaks on indentation differences
165
+ EXTRACTED=$(node -e "
166
+ const fs = require('fs');
167
+ const content = fs.readFileSync('$summary', 'utf-8');
168
+ const match = content.match(/^---\n([\s\S]*?)\n---/);
169
+ if (!match) { process.exit(0); }
170
+ const yaml = match[1];
171
+ const files = [];
172
+ let inSection = null;
173
+ for (const line of yaml.split('\n')) {
174
+ if (/^\s+created:/.test(line)) { inSection = 'created'; continue; }
175
+ if (/^\s+modified:/.test(line)) { inSection = 'modified'; continue; }
176
+ if (/^\s*[\w-]+:/.test(line) && !/^\s*-/.test(line)) { inSection = null; continue; }
177
+ if (inSection && /^\s+-\s+(.+)/.test(line)) {
178
+ let raw = line.match(/^\s+-\s+(.+)/)[1].trim();
179
+ raw = raw.replace(/^['"]|['"]$/g, '');
180
+ raw = raw.replace(/\s+\([^)]*\)\s*$/, '');
181
+ raw = raw.split(/\s+—\s/)[0].trim();
182
+ if (/\//.test(raw) && /\.[A-Za-z0-9]+$/.test(raw)) {
183
+ files.push(raw);
184
+ }
185
+ }
186
+ }
187
+ if (files.length) console.log(files.join('\n'));
188
+ " 2>/dev/null)
189
+
190
+ # Add extracted files to REVIEW_FILES array
191
+ if [ -n "$EXTRACTED" ]; then
192
+ while IFS= read -r file; do
193
+ if [ -n "$file" ]; then
194
+ REVIEW_FILES+=("$file")
195
+ fi
196
+ done <<< "$EXTRACTED"
197
+ fi
198
+ done
199
+
200
+ if [ ${#REVIEW_FILES[@]} -eq 0 ]; then
201
+ echo "Warning: SUMMARY artifacts found but contained no file paths. Falling back to git diff."
202
+ fi
203
+ fi
204
+ fi
205
+ ```
206
+
207
+ **Tier 3 — Git diff fallback (per D-02):**
208
+
209
+ If no SUMMARY.md files found OR no files extracted from them:
210
+ ```bash
211
+ if [ ${#REVIEW_FILES[@]} -eq 0 ]; then
212
+ # Compute diff base from phase commits — fail closed if no reliable base found
213
+ PHASE_COMMITS=$(git log --oneline --all --grep="${PADDED_PHASE}" --format="%H" 2>/dev/null)
214
+
215
+ if [ -n "$PHASE_COMMITS" ]; then
216
+ DIFF_BASE=$(echo "$PHASE_COMMITS" | tail -1)^
217
+
218
+ # Verify the parent commit exists (first commit in repo has no parent)
219
+ if ! git rev-parse "${DIFF_BASE}" >/dev/null 2>&1; then
220
+ DIFF_BASE=$(echo "$PHASE_COMMITS" | tail -1)
221
+ fi
222
+
223
+ # Run git diff with specific exclusions (per D-03)
224
+ DIFF_FILES=$(git diff --name-only "${DIFF_BASE}..HEAD" -- . \
225
+ ':!.planning/' ':!ROADMAP.md' ':!STATE.md' \
226
+ ':!*-SUMMARY.md' ':!*-VERIFICATION.md' ':!*-PLAN.md' \
227
+ ':!package-lock.json' ':!yarn.lock' ':!Gemfile.lock' ':!poetry.lock' 2>/dev/null)
228
+
229
+ while IFS= read -r file; do
230
+ [ -n "$file" ] && REVIEW_FILES+=("$file")
231
+ done <<< "$DIFF_FILES"
232
+
233
+ echo "File scope: ${#REVIEW_FILES[@]} files from git diff (base: ${DIFF_BASE})"
234
+ else
235
+ # Fail closed — no reliable diff base found. Do not use arbitrary HEAD~N.
236
+ echo "Warning: No phase commits found for '${PADDED_PHASE}'. Cannot determine reliable diff scope."
237
+ echo "Use --files flag to specify files explicitly: /gsd:code-review ${PHASE_ARG} --files=file1,file2,..."
238
+ fi
239
+ fi
240
+ ```
241
+
242
+ **Post-processing (all tiers):**
243
+
244
+ 1. **Apply exclusions (per D-03):** Remove paths matching planning artifacts
245
+ ```bash
246
+ FILTERED_FILES=()
247
+ for file in "${REVIEW_FILES[@]}"; do
248
+ # Skip planning directory and specific artifacts
249
+ if [[ "$file" == .planning/* ]] || \
250
+ [[ "$file" == ROADMAP.md ]] || \
251
+ [[ "$file" == STATE.md ]] || \
252
+ [[ "$file" == *-SUMMARY.md ]] || \
253
+ [[ "$file" == *-VERIFICATION.md ]] || \
254
+ [[ "$file" == *-PLAN.md ]]; then
255
+ continue
256
+ fi
257
+ FILTERED_FILES+=("$file")
258
+ done
259
+ REVIEW_FILES=("${FILTERED_FILES[@]}")
260
+ ```
261
+
262
+ 2. **Filter deleted files:** Remove paths that don't exist on disk
263
+ ```bash
264
+ EXISTING_FILES=()
265
+ DELETED_COUNT=0
266
+ for file in "${REVIEW_FILES[@]}"; do
267
+ if [ -f "$file" ]; then
268
+ EXISTING_FILES+=("$file")
269
+ else
270
+ DELETED_COUNT=$((DELETED_COUNT + 1))
271
+ fi
272
+ done
273
+ REVIEW_FILES=("${EXISTING_FILES[@]}")
274
+
275
+ if [ $DELETED_COUNT -gt 0 ]; then
276
+ echo "Filtered $DELETED_COUNT deleted files from review scope"
277
+ fi
278
+ ```
279
+
280
+ 3. **Deduplicate:** Remove duplicate paths (portable — bash 3.2+ compatible, handles spaces in paths)
281
+ ```bash
282
+ DEDUPED=()
283
+ while IFS= read -r line; do
284
+ [ -n "$line" ] && DEDUPED+=("$line")
285
+ done < <(printf '%s\n' "${REVIEW_FILES[@]}" | sort -u)
286
+ REVIEW_FILES=("${DEDUPED[@]}")
287
+ ```
288
+
289
+ 4. **Sort:** Alphabetical sort for reproducible agent input (already sorted by sort -u above)
290
+
291
+ **Log final scope and warn if large:**
292
+ ```bash
293
+ if [ -n "$FILES_OVERRIDE" ]; then
294
+ TIER="--files override"
295
+ elif [ -n "$SUMMARIES" ] && [ ${#REVIEW_FILES[@]} -gt 0 ]; then
296
+ TIER="SUMMARY.md"
297
+ else
298
+ TIER="git diff"
299
+ fi
300
+ echo "File scope: ${#REVIEW_FILES[@]} files from ${TIER}"
301
+
302
+ # Warn if file count is very large — may exceed agent context or produce superficial review
303
+ if [ ${#REVIEW_FILES[@]} -gt 50 ]; then
304
+ echo "Warning: ${#REVIEW_FILES[@]} files is a large review scope."
305
+ echo "Consider using --files to narrow scope, or --depth=quick for a faster pass."
306
+ if [ "$REVIEW_DEPTH" = "deep" ]; then
307
+ echo "Switching from deep to standard depth for large file count."
308
+ REVIEW_DEPTH="standard"
309
+ fi
310
+ fi
311
+ ```
312
+ </step>
313
+
314
+ <step name="check_empty_scope">
315
+ If REVIEW_FILES is empty:
316
+ ```
317
+ No source files changed in phase ${PHASE_ARG}. Skipping review.
318
+ ```
319
+ Exit workflow. Do NOT spawn agent or create REVIEW.md.
320
+ </step>
321
+
322
+ <step name="structural_pre_pass">
323
+ Optional structural cross-module pass powered by fallow.
324
+
325
+ Read fallow config gates:
326
+ ```bash
327
+ FALLOW_ENABLED=$(gsd_run query config-get code_quality.fallow.enabled 2>/dev/null || echo "false")
328
+ FALLOW_SCOPE=$(gsd_run query config-get code_quality.fallow.scope 2>/dev/null || echo "phase")
329
+ FALLOW_PROFILE=$(gsd_run query config-get code_quality.fallow.profile 2>/dev/null || echo "standard")
330
+ FALLOW_MCP=$(gsd_run query config-get code_quality.fallow.mcp 2>/dev/null || echo "false")
331
+ ```
332
+
333
+ Defaults are fail-closed and opt-in:
334
+ - `enabled=false` (skip entirely)
335
+ - `scope=phase`
336
+ - `profile=standard`
337
+ - `mcp=false`
338
+
339
+ When `FALLOW_ENABLED=true`:
340
+
341
+ 1) Resolve binary via PATH first, then `node_modules/.bin/fallow`.
342
+ ```bash
343
+ FALLOW_BIN=$(FALLOW_CWD="$(pwd)" node -e "
344
+ const { resolveFallowBinary } = require('./get-shit-done/bin/lib/fallow-runner.cjs');
345
+ const resolved = resolveFallowBinary({ cwd: process.env.FALLOW_CWD });
346
+ if (resolved) process.stdout.write(resolved);
347
+ ")
348
+ ```
349
+
350
+ 2) If binary is missing, fail with actionable message:
351
+ ```bash
352
+ if [ -z \"$FALLOW_BIN\" ]; then
353
+ echo \"Error: fallow is enabled but no binary was found.\"
354
+ echo \"Install fallow via \`npm install -D fallow\` or \`cargo install fallow\`.\"
355
+ # Exit workflow
356
+ fi
357
+ ```
358
+
359
+ 3) Execute structural pass and persist JSON (bounded at 120s; on timeout, behaves as a fallow crash):
360
+ ```bash
361
+ FALLOW_JSON_PATH="${PHASE_DIR}/FALLOW.json"
362
+ FALLOW_STDERR_TMP=$(mktemp)
363
+ if [ \"$FALLOW_SCOPE\" = \"repo\" ]; then
364
+ timeout 120 \"$FALLOW_BIN\" audit --json --profile \"$FALLOW_PROFILE\" > \"${FALLOW_JSON_PATH}.tmp\" 2>\"$FALLOW_STDERR_TMP\"
365
+ FALLOW_EXIT=$?
366
+ else
367
+ # phase scope: pass the already-computed review file set
368
+ printf '%s\n' \"${REVIEW_FILES[@]}\" | timeout 120 \"$FALLOW_BIN\" audit --json --profile \"$FALLOW_PROFILE\" --stdin-files > \"${FALLOW_JSON_PATH}.tmp\" 2>\"$FALLOW_STDERR_TMP\"
369
+ FALLOW_EXIT=$?
370
+ fi
371
+ if [ $FALLOW_EXIT -ne 0 ]; then
372
+ FALLOW_STDERR_SUMMARY=$(head -5 \"$FALLOW_STDERR_TMP\")
373
+ rm -f \"${FALLOW_JSON_PATH}.tmp\" \"$FALLOW_STDERR_TMP\"
374
+ echo \"WARNING: fallow structural pre-pass failed: ${FALLOW_STDERR_SUMMARY}\"
375
+ FALLOW_JSON_PATH=""
376
+ else
377
+ mv \"${FALLOW_JSON_PATH}.tmp\" \"$FALLOW_JSON_PATH\"
378
+ rm -f \"$FALLOW_STDERR_TMP\"
379
+ fi
380
+ ```
381
+
382
+ On any failure of the structural pre-pass (binary missing, non-zero exit, timeout, or JSON parse error), the workflow continues with no `<structural_findings>` injection; the reviewer agent receives a normal review request.
383
+
384
+ 4) Optional MCP bridge path (runtime-dependent):
385
+ - If `FALLOW_MCP=true`, set reviewer input mode to MCP-backed structural findings.
386
+ - Otherwise pass static JSON findings from `FALLOW.json`.
387
+
388
+ When disabled, set:
389
+ ```bash
390
+ FALLOW_JSON_PATH=""
391
+ ```
392
+ </step>
393
+
394
+ <step name="spawn_reviewer">
395
+ Compute the review output path:
396
+ ```bash
397
+ REVIEW_PATH="${PHASE_DIR}/${PADDED_PHASE}-REVIEW.md"
398
+ ```
399
+
400
+ Compute DIFF_BASE for agent context (in case agent needs it):
401
+ ```bash
402
+ PHASE_COMMITS=$(git log --oneline --all --grep="${PADDED_PHASE}" --format="%H" 2>/dev/null)
403
+ if [ -n "$PHASE_COMMITS" ]; then
404
+ DIFF_BASE=$(echo "$PHASE_COMMITS" | tail -1)^
405
+ else
406
+ DIFF_BASE=""
407
+ fi
408
+ ```
409
+
410
+ Build files_to_read block for agent:
411
+ ```bash
412
+ FILES_TO_READ=""
413
+ for file in "${REVIEW_FILES[@]}"; do
414
+ FILES_TO_READ+="- ${file}\n"
415
+ done
416
+ ```
417
+
418
+ Build config block for agent:
419
+ ```bash
420
+ CONFIG_FILES=""
421
+ for file in "${REVIEW_FILES[@]}"; do
422
+ CONFIG_FILES+=" - ${file}\n"
423
+ done
424
+ ```
425
+
426
+ Build structural findings block for agent:
427
+ ```bash
428
+ STRUCTURAL_FINDINGS_BLOCK=""
429
+ MAX_FINDINGS_SIZE=50000
430
+ if [ -n "$FALLOW_JSON_PATH" ] && [ -f "$FALLOW_JSON_PATH" ]; then
431
+ FALLOW_JSON_SIZE=$(wc -c < "$FALLOW_JSON_PATH" | tr -d '[:space:]')
432
+ if [ "$FALLOW_JSON_SIZE" -le "$MAX_FINDINGS_SIZE" ]; then
433
+ # Escape any literal closing tag before embedding; the closing tag literal is escaped to prevent prompt-structure breakage if a fallow finding's file path or message contains the sequence.
434
+ SAFE_FALLOW_JSON=$(sed 's#</structural_findings>#<\/structural_findings>#g' "$FALLOW_JSON_PATH")
435
+ STRUCTURAL_FINDINGS_BLOCK=$(printf '<structural_findings>\n%s\n</structural_findings>\n' "$SAFE_FALLOW_JSON")
436
+ else
437
+ echo "Warning: skipping structural findings embed (${FALLOW_JSON_SIZE} bytes > ${MAX_FINDINGS_SIZE} bytes). Re-run with narrower scope/profile if needed."
438
+ fi
439
+ fi
440
+ ```
441
+
442
+ Spawn the gsd-code-reviewer agent:
443
+
444
+ ```
445
+ Agent(subagent_type="gsd-code-reviewer", prompt="
446
+ <files_to_read>
447
+ ${FILES_TO_READ}
448
+ </files_to_read>
449
+
450
+ ${STRUCTURAL_FINDINGS_BLOCK}
451
+
452
+ <config>
453
+ depth: ${REVIEW_DEPTH}
454
+ phase_dir: ${PHASE_DIR}
455
+ review_path: ${REVIEW_PATH}
456
+ ${DIFF_BASE:+diff_base: ${DIFF_BASE}}
457
+ files:
458
+ ${CONFIG_FILES}
459
+ </config>
460
+
461
+ Review the listed source files at ${REVIEW_DEPTH} depth. Write findings to ${REVIEW_PATH}.
462
+ Do NOT commit the output — the orchestrator handles that.
463
+ ")
464
+ ```
465
+
466
+ > **ORCHESTRATOR RULE — CODEX RUNTIME**: After calling Agent() above, stop working on this task immediately. Do not read more files, edit code, or run tests related to this task while the subagent is active. Wait for the subagent to return its result. This prevents duplicate work, conflicting edits, and wasted context. Only resume when the subagent result is available.
467
+
468
+ **Agent failure handling:**
469
+
470
+ If the Agent() call fails (agent error, timeout, or exception):
471
+ ```
472
+ Error: Code review agent failed: ${error_message}
473
+
474
+ No REVIEW.md created. You can retry with /gsd:code-review ${PHASE_ARG} or check agent logs.
475
+ ```
476
+
477
+ Do NOT proceed to commit_review step. Do NOT create a partial or empty REVIEW.md. Exit workflow.
478
+ </step>
479
+
480
+ <step name="commit_review">
481
+ After agent completes successfully, verify REVIEW.md was created and has valid structure:
482
+
483
+ ```bash
484
+ if [ -f "${REVIEW_PATH}" ]; then
485
+ # Validate REVIEW.md has valid YAML frontmatter with status field
486
+ HAS_STATUS=$(REVIEW_PATH="${REVIEW_PATH}" node -e "
487
+ const fs = require('fs');
488
+ const content = fs.readFileSync(process.env.REVIEW_PATH, 'utf-8');
489
+ const match = content.match(/^---\n([\s\S]*?)\n---/);
490
+ if (match && /status:/.test(match[1])) { console.log('valid'); } else { console.log('invalid'); }
491
+ " 2>/dev/null)
492
+
493
+ if [ "$HAS_STATUS" = "valid" ]; then
494
+ echo "REVIEW.md created at ${REVIEW_PATH}"
495
+
496
+ if [ "$COMMIT_DOCS" = "true" ]; then
497
+ gsd_run query commit \
498
+ "docs(${PADDED_PHASE}): add code review report" \
499
+ --files "${REVIEW_PATH}"
500
+ fi
501
+ else
502
+ echo "Warning: REVIEW.md exists but has invalid or missing frontmatter (no status field)."
503
+ echo "Agent may have produced malformed output. Not committing. Review manually: ${REVIEW_PATH}"
504
+ fi
505
+ else
506
+ echo "Warning: Agent completed but REVIEW.md not found at ${REVIEW_PATH}. This may indicate an agent issue."
507
+ echo "No REVIEW.md to commit. Please retry with /gsd:code-review ${PHASE_ARG}"
508
+ fi
509
+ ```
510
+ </step>
511
+
512
+ <step name="dispatch_fix">
513
+ If the `--fix` flag was passed (`FIX_FLAG=true`), delegate to the `code-review-fix.md` workflow
514
+ to auto-apply findings from the REVIEW.md that was just written (or that already existed).
515
+
516
+ This step runs AFTER `commit_review` so REVIEW.md is guaranteed to be on disk before the fixer
517
+ is invoked. If REVIEW.md was not created (agent failed, scope was empty, etc.), the `code-review-fix.md`
518
+ workflow handles the missing-review error and exits cleanly.
519
+
520
+ ```bash
521
+ if [ "$FIX_FLAG" = "true" ]; then
522
+ echo ""
523
+ echo "─────────────────────────────────────────────────────────────────"
524
+ echo " --fix: delegating to code-review-fix.md"
525
+ echo "─────────────────────────────────────────────────────────────────"
526
+ echo ""
527
+
528
+ # Build the fix sub-arguments: pass phase arg plus any --all/--auto flags
529
+ FIX_ARGS="${PHASE_ARG}"
530
+ if [ "$FIX_ALL" = "true" ]; then
531
+ FIX_ARGS="${FIX_ARGS} --all"
532
+ fi
533
+ if [ "$FIX_AUTO" = "true" ]; then
534
+ FIX_ARGS="${FIX_ARGS} --auto"
535
+ fi
536
+
537
+ # Load and execute the code-review-fix workflow.
538
+ # The fix workflow is the canonical implementation for all fix logic:
539
+ # gsd-code-fixer agent dispatch, --auto iteration loop, REVIEW-FIX.md commit,
540
+ # and result presentation. Do not duplicate that logic here.
541
+ Workflow(workflow="get-shit-done/workflows/code-review-fix.md", args="${FIX_ARGS}")
542
+
543
+ # Exit after fix workflow completes — present_results is for review-only output.
544
+ # The fix workflow has its own present_results step.
545
+ # Exit workflow.
546
+ fi
547
+ ```
548
+
549
+ If `FIX_FLAG` is false, skip this step entirely and proceed to `present_results`.
550
+ </step>
551
+
552
+ <step name="present_results">
553
+ Read the REVIEW.md YAML frontmatter to extract finding counts.
554
+
555
+ Extract frontmatter between `---` delimiters first to avoid matching values in the review body:
556
+
557
+ ```bash
558
+ # Extract only the YAML frontmatter block (between first two --- lines)
559
+ FRONTMATTER=$(REVIEW_PATH="${REVIEW_PATH}" node -e "
560
+ const fs = require('fs');
561
+ const content = fs.readFileSync(process.env.REVIEW_PATH, 'utf-8');
562
+ const match = content.match(/^---\n([\s\S]*?)\n---/);
563
+ if (match) process.stdout.write(match[1]);
564
+ " 2>/dev/null)
565
+
566
+ # Parse fields from frontmatter only (not full file)
567
+ STATUS=$(echo "$FRONTMATTER" | grep "^status:" | cut -d: -f2 | xargs)
568
+ FILES_REVIEWED=$(echo "$FRONTMATTER" | grep "^files_reviewed:" | cut -d: -f2 | xargs)
569
+ CRITICAL=$(echo "$FRONTMATTER" | grep -E "^[[:space:]]*(critical|blocker):" | head -1 | cut -d: -f2 | xargs)
570
+ WARNING=$(echo "$FRONTMATTER" | grep "warning:" | head -1 | cut -d: -f2 | xargs)
571
+ INFO=$(echo "$FRONTMATTER" | grep "info:" | head -1 | cut -d: -f2 | xargs)
572
+ TOTAL=$(echo "$FRONTMATTER" | grep "total:" | head -1 | cut -d: -f2 | xargs)
573
+ ```
574
+
575
+ Display inline summary to user:
576
+
577
+ ```
578
+ ═══════════════════════════════════════════════════════════════
579
+
580
+ Code Review Complete: Phase ${PHASE_NUMBER} (${PHASE_NAME})
581
+
582
+ ───────────────────────────────────────────────────────────────
583
+
584
+ Depth: ${REVIEW_DEPTH}
585
+ Files Reviewed: ${FILES_REVIEWED}
586
+
587
+ Findings:
588
+ Critical: ${CRITICAL}
589
+ Warning: ${WARNING}
590
+ Info: ${INFO}
591
+ ──────────
592
+ Total: ${TOTAL}
593
+
594
+ ───────────────────────────────────────────────────────────────
595
+ ```
596
+
597
+ If status is "clean":
598
+ ```
599
+ ✓ No issues found. All ${FILES_REVIEWED} files pass review at ${REVIEW_DEPTH} depth.
600
+
601
+ Full report: ${REVIEW_PATH}
602
+ ```
603
+
604
+ If total findings > 0:
605
+ ```
606
+ ⚠ Issues found. Review the report for details.
607
+
608
+ Full report: ${REVIEW_PATH}
609
+
610
+ Next steps:
611
+ /gsd:code-review ${PHASE_NUMBER} --fix — Auto-fix issues
612
+ cat ${REVIEW_PATH} — View full report
613
+ ```
614
+
615
+ If critical > 0 or warning > 0, list top 3 issues inline:
616
+ ```bash
617
+ echo "Top issues:"
618
+ grep -A 3 "^### CR-\|^### BL-\|^### WR-" "${REVIEW_PATH}" | head -n 12
619
+ ```
620
+
621
+ **Note on tests:** Automated tests for this command and workflow are planned for Phase 4 (Pipeline Integration & Testing, requirement INFR-03). Phase 2 focuses on correct implementation; Phase 4 adds regression coverage across platforms.
622
+
623
+ ═══════════════════════════════════════════════════════════════
624
+ </step>
625
+
626
+ </process>
627
+
628
+ <platform_notes>
629
+ **Windows:** This workflow uses bash features (arrays, process substitution). On Windows, it requires
630
+ Git Bash or WSL. Native PowerShell is not supported. The CI matrix (Ubuntu/macOS/Windows)
631
+ runs under Git Bash on Windows runners, which provides bash compatibility.
632
+
633
+ **macOS:** macOS ships with bash 3.2 (GPL licensing). This workflow does NOT use `mapfile` (bash 4+
634
+ only) — all array construction uses portable `while IFS= read -r` loops compatible with bash 3.2.
635
+ The `--files` path validation uses `realpath -m` which requires GNU coreutils (install via
636
+ `brew install coreutils`). Without coreutils, the path guard falls back to fail-closed behavior
637
+ (rejects paths it cannot verify), so security is maintained but valid relative paths may be rejected.
638
+ If `--files` validation fails unexpectedly on macOS, install coreutils or use absolute paths.
639
+ </platform_notes>
640
+
641
+ <success_criteria>
642
+ - [ ] Phase validated before config gate check
643
+ - [ ] Config gate checked (workflow.code_review)
644
+ - [ ] --fix/--all/--auto flags parsed via code-review-flags.cjs typed IR (not ad-hoc bash)
645
+ - [ ] Depth resolved with validation (quick|standard|deep)
646
+ - [ ] File scope computed with 3 tiers: --files > SUMMARY.md > git diff
647
+ - [ ] Malformed/missing SUMMARY.md handled gracefully with fallback
648
+ - [ ] Deleted files filtered from scope
649
+ - [ ] Files deduplicated and sorted
650
+ - [ ] Empty scope results in skip (no agent spawn)
651
+ - [ ] Agent spawned with explicit file list, depth, review_path, diff_base
652
+ - [ ] Agent failure handled without partial commits
653
+ - [ ] REVIEW.md committed if created
654
+ - [ ] When --fix: dispatch_fix step delegates to code-review-fix.md with --all/--auto forwarded
655
+ - [ ] Results presented inline with next step suggestion (review-only path)
656
+ </success_criteria>