@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,748 @@
1
+ <purpose>
2
+ Cross-AI peer review — invoke external AI CLIs to independently review phase plans.
3
+ Each CLI gets the same prompt (PROJECT.md context, phase plans, requirements) and
4
+ produces structured feedback. Results are combined into REVIEWS.md for the planner
5
+ to incorporate via --reviews flag.
6
+
7
+ This implements adversarial review: different AI models catch different blind spots.
8
+ A plan that survives review from 2-3 independent AI systems is more robust.
9
+ </purpose>
10
+
11
+ <process>
12
+
13
+ <step name="detect_clis">
14
+ Check which AI CLIs are available on the system:
15
+
16
+ ```bash
17
+ _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}/gsd-core/bin/${_GSD_SHIM_NAME}"; if [ -f "$GSD_TOOLS" ]; then gsd_run() { node "$GSD_TOOLS" "$@"; }; elif [ -f "${_GSD_RUNTIME_ROOT}/.claude/gsd-core/bin/${_GSD_SHIM_NAME}" ]; then GSD_TOOLS="${_GSD_RUNTIME_ROOT}/.claude/gsd-core/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/gsd-core/bin/${_GSD_SHIM_NAME}" ]; then GSD_TOOLS="$HOME/.claude/gsd-core/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 @therocketcode/gsd-core@latest --claude --local" >&2; exit 1; fi
18
+ # Check each CLI
19
+ command -v gemini >/dev/null 2>&1 && echo "gemini:available" || echo "gemini:missing"
20
+ command -v claude >/dev/null 2>&1 && echo "claude:available" || echo "claude:missing"
21
+ command -v codex >/dev/null 2>&1 && echo "codex:available" || echo "codex:missing"
22
+ command -v coderabbit >/dev/null 2>&1 && echo "coderabbit:available" || echo "coderabbit:missing"
23
+ command -v opencode >/dev/null 2>&1 && echo "opencode:available" || echo "opencode:missing"
24
+ command -v qwen >/dev/null 2>&1 && echo "qwen:available" || echo "qwen:missing"
25
+ command -v cursor-agent >/dev/null 2>&1 && echo "cursor:available" || echo "cursor:missing"
26
+ command -v agy >/dev/null 2>&1 && echo "antigravity:available" || echo "antigravity:missing"
27
+
28
+ # Check local model servers (OpenAI-compatible HTTP API — no CLI binary required)
29
+ OLLAMA_HOST=$(gsd_run query config-get review.ollama_host 2>/dev/null | jq -r '.' 2>/dev/null || echo "")
30
+ if [ -z "$OLLAMA_HOST" ] || [ "$OLLAMA_HOST" = "null" ]; then OLLAMA_HOST="http://localhost:11434"; fi
31
+ curl -s --max-time 2 "${OLLAMA_HOST}/v1/models" >/dev/null 2>&1 && echo "ollama:available" || echo "ollama:missing"
32
+
33
+ LM_STUDIO_HOST=$(gsd_run query config-get review.lm_studio_host 2>/dev/null | jq -r '.' 2>/dev/null || echo "")
34
+ if [ -z "$LM_STUDIO_HOST" ] || [ "$LM_STUDIO_HOST" = "null" ]; then LM_STUDIO_HOST="http://localhost:1234"; fi
35
+ curl -s --max-time 2 "${LM_STUDIO_HOST}/v1/models" >/dev/null 2>&1 && echo "lm_studio:available" || echo "lm_studio:missing"
36
+
37
+ LLAMA_CPP_HOST=$(gsd_run query config-get review.llama_cpp_host 2>/dev/null | jq -r '.' 2>/dev/null || echo "")
38
+ if [ -z "$LLAMA_CPP_HOST" ] || [ "$LLAMA_CPP_HOST" = "null" ]; then LLAMA_CPP_HOST="http://localhost:8080"; fi
39
+ curl -s --max-time 2 "${LLAMA_CPP_HOST}/v1/models" >/dev/null 2>&1 && echo "llama_cpp:available" || echo "llama_cpp:missing"
40
+ ```
41
+
42
+ Parse flags from `$ARGUMENTS`:
43
+ - `--gemini` → include Gemini
44
+ - `--claude` → include Claude
45
+ - `--codex` → include Codex
46
+ - `--coderabbit` → include CodeRabbit
47
+ - `--opencode` → include OpenCode
48
+ - `--qwen` → include Qwen Code
49
+ - `--cursor` → include Cursor
50
+ - `--agy` or `--antigravity` → include Antigravity CLI
51
+ - `--ollama` → include Ollama (local server, OpenAI-compatible)
52
+ - `--lm-studio` → include LM Studio (local server, OpenAI-compatible)
53
+ - `--llama-cpp` → include llama.cpp (local server, OpenAI-compatible)
54
+ - `--all` → include all available (CLIs + running local servers)
55
+ - No flags → if `review.default_reviewers` is set, include only configured reviewers that are detected; otherwise include all available
56
+
57
+ Reviewer-selection precedence:
58
+ 1. Individual reviewer flags (`--gemini`, `--codex`, etc.)
59
+ 2. `--all`
60
+ 3. `review.default_reviewers`
61
+ 4. No key + no flags → all detected reviewers
62
+
63
+ `review.default_reviewers` behavior:
64
+ - Value must be a non-empty array of slug strings (configured via `gsd config-set review.default_reviewers '["gemini","codex"]'`)
65
+ - Unknown slugs warn and are ignored
66
+ - Known-but-undetected slugs emit an info note and are ignored
67
+ - If all configured reviewers are unavailable, fail with an actionable message
68
+
69
+ If no CLIs are available:
70
+ ```
71
+ No external AI CLIs found. Install at least one:
72
+ - gemini: https://github.com/google-gemini/gemini-cli
73
+ - codex: https://github.com/openai/codex
74
+ - claude: https://github.com/anthropics/claude-code
75
+ - opencode: https://opencode.ai (leverages GitHub Copilot subscription models)
76
+ - qwen: https://github.com/nicepkg/qwen-code (Alibaba Qwen models)
77
+ - cursor: https://cursor.com (Cursor IDE agent mode)
78
+ - agy: curl -fsSL https://antigravity.google/cli/install.sh | bash (Antigravity CLI — free with Google credentials)
79
+
80
+ Then run /gsd:review again.
81
+ ```
82
+ Exit.
83
+
84
+ Determine which CLI to skip based on the current runtime environment:
85
+
86
+ ```bash
87
+ # Environment-based runtime detection (priority order)
88
+ if [ "$ANTIGRAVITY_AGENT" = "1" ]; then
89
+ # Antigravity is a separate client — all CLIs are external, skip none
90
+ SELF_CLI="none"
91
+ elif [ -n "$CURSOR_SESSION_ID" ]; then
92
+ # Running inside Cursor agent — skip cursor for independence
93
+ SELF_CLI="cursor"
94
+ elif [ -n "$CLAUDE_CODE_ENTRYPOINT" ]; then
95
+ # Running inside Claude Code CLI — skip claude for independence
96
+ SELF_CLI="claude"
97
+ else
98
+ # Other environments (Gemini CLI, Codex CLI, etc.)
99
+ # Fall back to AI self-identification to decide which CLI to skip
100
+ SELF_CLI="auto"
101
+ fi
102
+ ```
103
+
104
+ Rules:
105
+ - If `SELF_CLI="none"` → invoke ALL available CLIs (no skip)
106
+ - If `SELF_CLI="claude"` → skip claude, use gemini/codex
107
+ - If `SELF_CLI="auto"` → the executing AI identifies itself and skips its own CLI
108
+ - At least one DIFFERENT CLI must be available for the review to proceed.
109
+ </step>
110
+
111
+ <step name="gather_context">
112
+ Collect phase artifacts for the review prompt:
113
+
114
+ ```bash
115
+ INIT=$(gsd_run query init.phase-op "${PHASE_ARG}")
116
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
117
+ ```
118
+
119
+ Read from init: `phase_dir`, `phase_number`, `padded_phase`.
120
+
121
+ Then read:
122
+ 1. `.planning/PROJECT.md` (first 80 lines — project context)
123
+ 2. Phase section from `.planning/ROADMAP.md`
124
+ 3. All `*-PLAN.md` files in the phase directory
125
+ 4. `*-CONTEXT.md` if present (user decisions)
126
+ 5. `*-RESEARCH.md` if present (domain research)
127
+ 6. `.planning/REQUIREMENTS.md` (requirements this phase addresses)
128
+ </step>
129
+
130
+ <step name="build_prompt">
131
+ Build a structured review prompt:
132
+
133
+ ```markdown
134
+ # Cross-AI Plan Review Request
135
+
136
+ You are reviewing implementation plans for a software project phase.
137
+ Provide structured feedback on plan quality, completeness, and risks.
138
+
139
+ ## Project Context
140
+ {first 80 lines of PROJECT.md}
141
+
142
+ ## Phase {N}: {phase name}
143
+ ### Roadmap Section
144
+ {roadmap phase section}
145
+
146
+ ### Requirements Addressed
147
+ {requirements for this phase}
148
+
149
+ ### User Decisions (CONTEXT.md)
150
+ {context if present}
151
+
152
+ ### Research Findings
153
+ {research if present}
154
+
155
+ ### Plans to Review
156
+ {all PLAN.md contents}
157
+
158
+ ## Review Instructions
159
+
160
+ Analyze each plan and provide:
161
+
162
+ 1. **Summary** — One-paragraph assessment
163
+ 2. **Strengths** — What's well-designed (bullet points)
164
+ 3. **Concerns** — Potential issues, gaps, risks (bullet points with severity: HIGH/MEDIUM/LOW)
165
+ 4. **Suggestions** — Specific improvements (bullet points)
166
+ 5. **Risk Assessment** — Overall risk level (LOW/MEDIUM/HIGH) with justification
167
+
168
+ Focus on:
169
+ - Missing edge cases or error handling
170
+ - Dependency ordering issues
171
+ - Scope creep or over-engineering
172
+ - Security considerations
173
+ - Performance implications
174
+ - Whether the plans actually achieve the phase goals
175
+
176
+ Output your review in markdown format.
177
+ ```
178
+
179
+ Write to a temp file: `/tmp/gsd-review-prompt-{phase}.md`
180
+
181
+ Also write individual section files so the budget tool can re-trim per reviewer:
182
+
183
+ ```bash
184
+ # Write individual section files for per-reviewer budget trimming
185
+ # These are always written so reviewers with a budget can invoke prompt-budget
186
+ cp "$INSTRUCTIONS_BLOCK_FILE" "/tmp/gsd-review-${PHASE}-instructions.md"
187
+ cp "$ROADMAP_SECTION_FILE" "/tmp/gsd-review-${PHASE}-roadmap.md"
188
+
189
+ # Plan files: copy each PLAN.md to a predictable numbered path
190
+ PLAN_INDEX=0
191
+ for PLAN_FILE in "${PHASE_DIR}"/*-PLAN.md; do
192
+ PADDED_IDX=$(printf '%02d' "$PLAN_INDEX")
193
+ cp "$PLAN_FILE" "/tmp/gsd-review-${PHASE}-plan-${PADDED_IDX}.md"
194
+ PLAN_INDEX=$((PLAN_INDEX + 1))
195
+ done
196
+
197
+ # Optional section files (only if content was included in the combined prompt)
198
+ if [ -f ".planning/PROJECT.md" ]; then
199
+ cp .planning/PROJECT.md "/tmp/gsd-review-${PHASE}-project.md"
200
+ fi
201
+ if ls "${PHASE_DIR}/"*"-CONTEXT.md" >/dev/null 2>&1; then
202
+ cat "${PHASE_DIR}/"*"-CONTEXT.md" > "/tmp/gsd-review-${PHASE}-context.md"
203
+ fi
204
+ if ls "${PHASE_DIR}/"*"-RESEARCH.md" >/dev/null 2>&1; then
205
+ cat "${PHASE_DIR}/"*"-RESEARCH.md" > "/tmp/gsd-review-${PHASE}-research.md"
206
+ fi
207
+ if [ -f ".planning/REQUIREMENTS.md" ]; then
208
+ cp .planning/REQUIREMENTS.md "/tmp/gsd-review-${PHASE}-requirements.md"
209
+ fi
210
+ ```
211
+
212
+ Note: The variable names above (`INSTRUCTIONS_BLOCK_FILE`, `ROADMAP_SECTION_FILE`, `PHASE_DIR`, `PHASE`) reference the variables already established during prompt assembly. In practice the AI implementing this step writes the instruction and roadmap blocks to temp files while assembling the combined prompt, then copies those same temp files to the per-reviewer section paths. If the assembled prompt was built inline (string concatenation rather than file-by-file), write each section to the corresponding path after writing the combined file.
213
+ </step>
214
+
215
+ <step name="invoke_reviewers">
216
+ Read model preferences from planning config. Null/missing values fall back to CLI defaults.
217
+
218
+ ```bash
219
+ # JSON scalars from gsd-tools.cjs query; use jq -r to strip JSON string quotes (install jq if missing)
220
+ GEMINI_MODEL=$(gsd_run query config-get review.models.gemini 2>/dev/null | jq -r '.' 2>/dev/null || true)
221
+ CLAUDE_MODEL=$(gsd_run query config-get review.models.claude 2>/dev/null | jq -r '.' 2>/dev/null || true)
222
+ CODEX_MODEL=$(gsd_run query config-get review.models.codex 2>/dev/null | jq -r '.' 2>/dev/null || true)
223
+ OPENCODE_MODEL=$(gsd_run query config-get review.models.opencode 2>/dev/null | jq -r '.' 2>/dev/null || true)
224
+ # review.models.agy is reserved for future model-pinning support; agy selects its model internally
225
+ AGY_MODEL=$(gsd_run query config-get review.models.agy 2>/dev/null | jq -r '.' 2>/dev/null || true)
226
+ ```
227
+
228
+ For each selected CLI, invoke in sequence (not parallel — avoid rate limits):
229
+
230
+ **Gemini:**
231
+ ```bash
232
+ if [ -n "$GEMINI_MODEL" ] && [ "$GEMINI_MODEL" != "null" ]; then
233
+ cat /tmp/gsd-review-prompt-{phase}.md | gemini -m "$GEMINI_MODEL" -p - 2>/dev/null > /tmp/gsd-review-gemini-{phase}.md
234
+ else
235
+ cat /tmp/gsd-review-prompt-{phase}.md | gemini -p - 2>/dev/null > /tmp/gsd-review-gemini-{phase}.md
236
+ fi
237
+ ```
238
+
239
+ **Claude (separate session):**
240
+ ```bash
241
+ if [ -n "$CLAUDE_MODEL" ] && [ "$CLAUDE_MODEL" != "null" ]; then
242
+ cat /tmp/gsd-review-prompt-{phase}.md | claude --model "$CLAUDE_MODEL" -p - 2>/dev/null > /tmp/gsd-review-claude-{phase}.md
243
+ else
244
+ cat /tmp/gsd-review-prompt-{phase}.md | claude -p - 2>/dev/null > /tmp/gsd-review-claude-{phase}.md
245
+ fi
246
+ ```
247
+
248
+ **Codex:**
249
+ ```bash
250
+ if [ -n "$CODEX_MODEL" ] && [ "$CODEX_MODEL" != "null" ]; then
251
+ cat /tmp/gsd-review-prompt-{phase}.md | codex exec --ephemeral --dangerously-bypass-hook-trust --model "$CODEX_MODEL" --skip-git-repo-check - 2>/dev/null > /tmp/gsd-review-codex-{phase}.md
252
+ else
253
+ cat /tmp/gsd-review-prompt-{phase}.md | codex exec --ephemeral --dangerously-bypass-hook-trust --skip-git-repo-check - 2>/dev/null > /tmp/gsd-review-codex-{phase}.md
254
+ fi
255
+ ```
256
+
257
+ **CodeRabbit:**
258
+
259
+ Note: CodeRabbit reviews the current git diff/working tree — it does not accept a prompt or model flag. It may take up to 5 minutes. Use `timeout: 360000` on the Bash tool call.
260
+
261
+ ```bash
262
+ coderabbit review --prompt-only 2>/dev/null > /tmp/gsd-review-coderabbit-{phase}.md
263
+ ```
264
+
265
+ **OpenCode (via GitHub Copilot):**
266
+ ```bash
267
+ if [ -n "$OPENCODE_MODEL" ] && [ "$OPENCODE_MODEL" != "null" ]; then
268
+ cat /tmp/gsd-review-prompt-{phase}.md | opencode run --model "$OPENCODE_MODEL" - 2>/dev/null > /tmp/gsd-review-opencode-{phase}.md
269
+ else
270
+ cat /tmp/gsd-review-prompt-{phase}.md | opencode run - 2>/dev/null > /tmp/gsd-review-opencode-{phase}.md
271
+ fi
272
+ if [ ! -s /tmp/gsd-review-opencode-{phase}.md ]; then
273
+ echo "OpenCode review failed or returned empty output." > /tmp/gsd-review-opencode-{phase}.md
274
+ fi
275
+ ```
276
+
277
+ **Qwen Code:**
278
+ ```bash
279
+ cat /tmp/gsd-review-prompt-{phase}.md | qwen - 2>/dev/null > /tmp/gsd-review-qwen-{phase}.md
280
+ if [ ! -s /tmp/gsd-review-qwen-{phase}.md ]; then
281
+ echo "Qwen review failed or returned empty output." > /tmp/gsd-review-qwen-{phase}.md
282
+ fi
283
+ ```
284
+
285
+ **Cursor:**
286
+ ```bash
287
+ # cursor-agent is a SEPARATE binary from the `cursor` IDE launcher; print mode (-p) takes the
288
+ # prompt as an ARGUMENT, not stdin. A full review prompt can exceed the OS argument limit, so
289
+ # reference the prompt file by path rather than inlining it. Capture stderr so a failure is
290
+ # diagnosable instead of a silent empty result.
291
+ CURSOR_PROMPT_ARG="Read the file at /tmp/gsd-review-prompt-{phase}.md in full and carry out the review request it contains. Output only the resulting markdown review. Do not edit any files."
292
+ cursor-agent -p --mode ask --trust --output-format text "$CURSOR_PROMPT_ARG" 2>/tmp/gsd-review-cursor-{phase}.err > /tmp/gsd-review-cursor-{phase}.md
293
+ if [ ! -s /tmp/gsd-review-cursor-{phase}.md ]; then
294
+ echo "Cursor review failed or returned empty output. stderr:" > /tmp/gsd-review-cursor-{phase}.md
295
+ cat /tmp/gsd-review-cursor-{phase}.err >> /tmp/gsd-review-cursor-{phase}.md
296
+ fi
297
+ ```
298
+
299
+ **Antigravity CLI:**
300
+
301
+ **Maintainer note — why this block has three layers (last updated against agy 1.0.2):**
302
+
303
+ `agy -p` (the `--print` non-interactive flag) works correctly on macOS and Linux: it sends the
304
+ prompt, receives the model response, and writes it to stdout. On **native Windows** it silently
305
+ produces no stdout output despite the API call succeeding — a bug in `text_drip.go`'s non-TTY
306
+ flush path, tracked at https://github.com/google-antigravity/antigravity-cli/issues/27466 and
307
+ still open as of agy 1.0.2.
308
+
309
+ Regardless of platform, `agy` always persists the full exchange to a transcript file on disk.
310
+ The transcript fallback (Step 2 below) reads that file directly, giving Windows users full review
311
+ coverage without any extra tooling. This pattern was first documented by the community MCP bridge
312
+ at https://github.com/SinanTufekci/Claude-Code-Antigravity-CLI-MCP-Server — we inline the same
313
+ logic here in pure bash/jq so no additional dependency is required.
314
+
315
+ **Stale-response guard (why the pre-flight watermark matters):**
316
+ Without a watermark, the fallback would read the last `PLANNER_RESPONSE` entry in the transcript
317
+ regardless of when it was written — including entries from a previous invocation in the same
318
+ workspace. To prevent that, we record the transcript's line count *before* calling `agy -p`. In
319
+ the fallback, we only read lines appended after that count. If no new lines were written (agy
320
+ failed before producing a response), `_AGY_RESULT` is empty and Step 3 fires — never stale. If
321
+ the conv-id changed (agy started a fresh session), all lines in the new file are new and we use
322
+ skip=0.
323
+
324
+ **If the upstream stdout bug is fixed** (check the issue above): Step 2 silently becomes
325
+ unreachable; stdout is non-empty and Step 1 handles it. No code change needed.
326
+
327
+ **If the transcript paths change** in a future `agy` release: Step 2 silently becomes a no-op
328
+ and Step 3 fires with a clear error message in REVIEWS.md. No silent corruption. To debug:
329
+ - `~/.gemini/antigravity-cli/cache/last_conversations.json` — workspace → conv-id map
330
+ - `~/.gemini/antigravity-cli/brain/<id>/.system_generated/logs/transcript.jsonl`
331
+ Filter: `source=="MODEL"`, `status=="DONE"`, `type=="PLANNER_RESPONSE"`, take the last match's `content` field.
332
+
333
+ Invocation specifics (verified agy 1.0.0, macOS arm64 and Linux amd64):
334
+ - `-p` takes the prompt as a **flag value** — `echo X | agy -p` errors with "flag needs an argument: -p"
335
+ - `--print-timeout` defaults to 5m, aligning with this workflow's global timeout
336
+ - No `-m` / `--model` flag — agy selects the model internally
337
+
338
+ ```bash
339
+ # Pre-flight: snapshot the transcript watermark before invoking agy.
340
+ # Must run BEFORE agy -p — this is what prevents the fallback from reading a stale prior response.
341
+ _AGY_WS=$(git rev-parse --show-toplevel 2>/dev/null || pwd)
342
+ _AGY_CACHE="$HOME/.gemini/antigravity-cli/cache/last_conversations.json"
343
+ _AGY_MARK_CONV=""
344
+ _AGY_MARK_LINES=0
345
+ if [ -f "$_AGY_CACHE" ]; then
346
+ _AGY_MARK_CONV=$(jq -r --arg ws "$_AGY_WS" '
347
+ .[$ws] //
348
+ (to_entries
349
+ | map(select(.key | ascii_downcase == ($ws | ascii_downcase)))
350
+ | first | .value) //
351
+ empty
352
+ ' "$_AGY_CACHE" 2>/dev/null)
353
+ if [ -n "$_AGY_MARK_CONV" ] && [ "$_AGY_MARK_CONV" != "null" ]; then
354
+ _AGY_MARK_TX="$HOME/.gemini/antigravity-cli/brain/${_AGY_MARK_CONV}/.system_generated/logs/transcript.jsonl"
355
+ [ -f "$_AGY_MARK_TX" ] && _AGY_MARK_LINES=$(wc -l < "$_AGY_MARK_TX" | tr -d ' ')
356
+ fi
357
+ fi
358
+
359
+ # Step 1 — primary invocation: stdout works on macOS, Linux, and WSL.
360
+ # Bound the run with agy's OWN `--print-timeout` (issue #687). On a large,
361
+ # file-path-rich prompt agy's agentic Cascade can loop on its code_search/grep
362
+ # steps and never converge; `--print-timeout` is agy's native cap for print mode
363
+ # (defaults to 5m — see maintainer note above), so we pass it explicitly to let a
364
+ # stalled run self-terminate through the tool's own mechanism. A non-zero exit
365
+ # (timeout or crash) discards any partial output so the Step 2 transcript fallback
366
+ # / Step 3 stub take over.
367
+ agy --print-timeout 300s -p "$(cat /tmp/gsd-review-prompt-{phase}.md)" 2>/dev/null > /tmp/gsd-review-antigravity-{phase}.md
368
+ _AGY_RC=$?
369
+ if [ "$_AGY_RC" -ne 0 ]; then
370
+ : > /tmp/gsd-review-antigravity-{phase}.md
371
+ fi
372
+
373
+ # Step 2 — transcript fallback: catches Windows agy -p stdout bug (and any future stdout-silent edge cases).
374
+ # Reads only lines appended AFTER the pre-flight watermark. If agy failed before writing a new response,
375
+ # _AGY_RESULT is empty and Step 3 fires — no stale content can leak through.
376
+ # Undocumented paths, verified agy 1.0.0–1.0.2. See maintainer note above if these break.
377
+ if [ ! -s /tmp/gsd-review-antigravity-{phase}.md ]; then
378
+ if [ -f "$_AGY_CACHE" ]; then
379
+ _AGY_CONV=$(jq -r --arg ws "$_AGY_WS" '
380
+ .[$ws] //
381
+ (to_entries
382
+ | map(select(.key | ascii_downcase == ($ws | ascii_downcase)))
383
+ | first | .value) //
384
+ empty
385
+ ' "$_AGY_CACHE" 2>/dev/null)
386
+ if [ -n "$_AGY_CONV" ] && [ "$_AGY_CONV" != "null" ]; then
387
+ _AGY_TX="$HOME/.gemini/antigravity-cli/brain/${_AGY_CONV}/.system_generated/logs/transcript.jsonl"
388
+ if [ -f "$_AGY_TX" ]; then
389
+ # If conv-id changed, agy started a new session — all lines are new, skip 0.
390
+ # If same conv-id, only read lines beyond the watermark.
391
+ [ "$_AGY_CONV" = "$_AGY_MARK_CONV" ] && _AGY_SKIP=$_AGY_MARK_LINES || _AGY_SKIP=0
392
+ _AGY_RESULT=$(tail -n +"$((_AGY_SKIP + 1))" "$_AGY_TX" 2>/dev/null | \
393
+ jq -r 'select(.source=="MODEL" and .status=="DONE" and .type=="PLANNER_RESPONSE") | .content' \
394
+ 2>/dev/null | tail -1)
395
+ [ -n "$_AGY_RESULT" ] && echo "$_AGY_RESULT" > /tmp/gsd-review-antigravity-{phase}.md
396
+ fi
397
+ fi
398
+ fi
399
+ fi
400
+
401
+ # Step 3 — final guard: both approaches yielded nothing (auth error, first-run setup, path schema changed, etc.)
402
+ if [ ! -s /tmp/gsd-review-antigravity-{phase}.md ]; then
403
+ echo "Antigravity review failed or returned empty output." > /tmp/gsd-review-antigravity-{phase}.md
404
+ fi
405
+ ```
406
+
407
+ **Ollama (local, OpenAI-compatible):**
408
+
409
+ Read host and model from config. All three local backends share the same `/v1/chat/completions` endpoint — only host and model differ. Use `jq --rawfile` to safely encode the multi-line prompt as JSON without shell-escaping issues.
410
+
411
+ ```bash
412
+ # Shared helper: apply prompt-budget trimming for local reviewers
413
+ prepare_trimmed_prompt_for_reviewer() {
414
+ REVIEWER_KEY="$1"
415
+ REVIEWER_BUDGET="$2"
416
+ OUTPUT_PROMPT="$3"
417
+ OUTPUT_META="$4"
418
+
419
+ [ -z "$REVIEWER_BUDGET" ] && return 0
420
+ [ "$REVIEWER_BUDGET" = "null" ] && return 0
421
+ [ "$REVIEWER_BUDGET" = "0" ] && return 0
422
+
423
+ PLAN_FILE_ARGS=""
424
+ for p in /tmp/gsd-review-{phase}-plan-*.md; do
425
+ [ -f "$p" ] && PLAN_FILE_ARGS="$PLAN_FILE_ARGS --plan-file $p"
426
+ done
427
+ PROJECT_ARG=""
428
+ [ -f "/tmp/gsd-review-{phase}-project.md" ] && PROJECT_ARG="--project-file /tmp/gsd-review-{phase}-project.md"
429
+ CONTEXT_ARG=""
430
+ [ -f "/tmp/gsd-review-{phase}-context.md" ] && CONTEXT_ARG="--context-file /tmp/gsd-review-{phase}-context.md"
431
+ RESEARCH_ARG=""
432
+ [ -f "/tmp/gsd-review-{phase}-research.md" ] && RESEARCH_ARG="--research-file /tmp/gsd-review-{phase}-research.md"
433
+ REQUIREMENTS_ARG=""
434
+ [ -f "/tmp/gsd-review-{phase}-requirements.md" ] && REQUIREMENTS_ARG="--requirements-file /tmp/gsd-review-{phase}-requirements.md"
435
+
436
+ gsd_run query prompt-budget \
437
+ --budget "$REVIEWER_BUDGET" \
438
+ --instructions-file "/tmp/gsd-review-{phase}-instructions.md" \
439
+ --roadmap-file "/tmp/gsd-review-{phase}-roadmap.md" \
440
+ $PLAN_FILE_ARGS $PROJECT_ARG $CONTEXT_ARG $RESEARCH_ARG $REQUIREMENTS_ARG \
441
+ --output-prompt "$OUTPUT_PROMPT" \
442
+ --output-metadata "$OUTPUT_META"
443
+ return $?
444
+ }
445
+
446
+ # Resolve prompt budget for Ollama: per-reviewer override > global default > null
447
+ OLLAMA_REVIEWER_BUDGET=$(gsd_run query config-get review.max_prompt_tokens_per_reviewer.ollama 2>/dev/null | jq -r '.' 2>/dev/null || echo "null")
448
+ if [ -z "$OLLAMA_REVIEWER_BUDGET" ] || [ "$OLLAMA_REVIEWER_BUDGET" = "null" ]; then
449
+ OLLAMA_REVIEWER_BUDGET=$(gsd_run query config-get review.max_prompt_tokens 2>/dev/null | jq -r '.' 2>/dev/null || echo "null")
450
+ fi
451
+
452
+ # Apply budget trim for Ollama if a budget is configured
453
+ OLLAMA_PROMPT_FILE="/tmp/gsd-review-prompt-{phase}.md"
454
+ OLLAMA_SKIP=0
455
+ if [ -n "$OLLAMA_REVIEWER_BUDGET" ] && [ "$OLLAMA_REVIEWER_BUDGET" != "null" ] && [ "$OLLAMA_REVIEWER_BUDGET" != "0" ]; then
456
+ OLLAMA_TRIMMED_PROMPT="/tmp/gsd-review-prompt-{phase}-ollama.md"
457
+ OLLAMA_TRIM_META="/tmp/gsd-review-prompt-{phase}-ollama.metadata.json"
458
+ prepare_trimmed_prompt_for_reviewer "ollama" "$OLLAMA_REVIEWER_BUDGET" "$OLLAMA_TRIMMED_PROMPT" "$OLLAMA_TRIM_META"
459
+ OLLAMA_EXIT=$?
460
+ if [ $OLLAMA_EXIT -ne 0 ]; then
461
+ if [ $OLLAMA_EXIT -eq 2 ] || [ $OLLAMA_EXIT -eq 11 ]; then
462
+ echo "WARNING: prompt budget for ollama (${OLLAMA_REVIEWER_BUDGET} tokens) is too small for the minimum review set. Skipping Ollama reviewer." >&2
463
+ else
464
+ echo "WARNING: prompt-budget returned unexpected exit code ${OLLAMA_EXIT} for ollama. Skipping Ollama reviewer." >&2
465
+ fi
466
+ OLLAMA_SKIP=1
467
+ else
468
+ OLLAMA_PROMPT_FILE="$OLLAMA_TRIMMED_PROMPT"
469
+ fi
470
+ fi
471
+
472
+ if [ "$OLLAMA_SKIP" != "1" ]; then
473
+ OLLAMA_HOST=$(gsd_run query config-get review.ollama_host 2>/dev/null | jq -r '.' 2>/dev/null || echo "")
474
+ if [ -z "$OLLAMA_HOST" ] || [ "$OLLAMA_HOST" = "null" ]; then OLLAMA_HOST="http://localhost:11434"; fi
475
+ OLLAMA_MODEL=$(gsd_run query config-get review.models.ollama 2>/dev/null | jq -r '.' 2>/dev/null || echo "")
476
+ if [ -z "$OLLAMA_MODEL" ] || [ "$OLLAMA_MODEL" = "null" ]; then
477
+ OLLAMA_MODEL=$(curl -s --max-time 2 "${OLLAMA_HOST}/v1/models" 2>/dev/null | jq -r '.data[0].id // "llama3"' 2>/dev/null || echo "llama3")
478
+ fi
479
+ jq -n --rawfile content "$OLLAMA_PROMPT_FILE" \
480
+ --arg model "$OLLAMA_MODEL" \
481
+ '{model: $model, messages: [{role: "user", content: $content}]}' | \
482
+ curl -s --max-time 120 -X POST "${OLLAMA_HOST}/v1/chat/completions" \
483
+ -H "Content-Type: application/json" -d @- 2>/dev/null | \
484
+ jq -r '.choices[0].message.content // "Ollama review failed or returned empty output."' \
485
+ > /tmp/gsd-review-ollama-{phase}.md
486
+ if [ ! -s /tmp/gsd-review-ollama-{phase}.md ]; then
487
+ echo "Ollama review failed or returned empty output." > /tmp/gsd-review-ollama-{phase}.md
488
+ fi
489
+ fi
490
+ ```
491
+
492
+ **LM Studio (local, OpenAI-compatible):**
493
+ ```bash
494
+ # Resolve prompt budget for LM Studio: per-reviewer override > global default > null
495
+ LM_STUDIO_REVIEWER_BUDGET=$(gsd_run query config-get review.max_prompt_tokens_per_reviewer.lm_studio 2>/dev/null | jq -r '.' 2>/dev/null || echo "null")
496
+ if [ -z "$LM_STUDIO_REVIEWER_BUDGET" ] || [ "$LM_STUDIO_REVIEWER_BUDGET" = "null" ]; then
497
+ LM_STUDIO_REVIEWER_BUDGET=$(gsd_run query config-get review.max_prompt_tokens 2>/dev/null | jq -r '.' 2>/dev/null || echo "null")
498
+ fi
499
+
500
+ # Apply budget trim for LM Studio if a budget is configured
501
+ LM_STUDIO_PROMPT_FILE="/tmp/gsd-review-prompt-{phase}.md"
502
+ LM_STUDIO_SKIP=0
503
+ if [ -n "$LM_STUDIO_REVIEWER_BUDGET" ] && [ "$LM_STUDIO_REVIEWER_BUDGET" != "null" ] && [ "$LM_STUDIO_REVIEWER_BUDGET" != "0" ]; then
504
+ LM_STUDIO_TRIMMED_PROMPT="/tmp/gsd-review-prompt-{phase}-lm_studio.md"
505
+ LM_STUDIO_TRIM_META="/tmp/gsd-review-prompt-{phase}-lm_studio.metadata.json"
506
+ prepare_trimmed_prompt_for_reviewer "lm_studio" "$LM_STUDIO_REVIEWER_BUDGET" "$LM_STUDIO_TRIMMED_PROMPT" "$LM_STUDIO_TRIM_META"
507
+ LM_STUDIO_EXIT=$?
508
+ if [ $LM_STUDIO_EXIT -ne 0 ]; then
509
+ if [ $LM_STUDIO_EXIT -eq 2 ] || [ $LM_STUDIO_EXIT -eq 11 ]; then
510
+ echo "WARNING: prompt budget for lm_studio (${LM_STUDIO_REVIEWER_BUDGET} tokens) is too small for the minimum review set. Skipping LM Studio reviewer." >&2
511
+ else
512
+ echo "WARNING: prompt-budget returned unexpected exit code ${LM_STUDIO_EXIT} for lm_studio. Skipping LM Studio reviewer." >&2
513
+ fi
514
+ LM_STUDIO_SKIP=1
515
+ else
516
+ LM_STUDIO_PROMPT_FILE="$LM_STUDIO_TRIMMED_PROMPT"
517
+ fi
518
+ fi
519
+
520
+ if [ "$LM_STUDIO_SKIP" != "1" ]; then
521
+ LM_STUDIO_HOST=$(gsd_run query config-get review.lm_studio_host 2>/dev/null | jq -r '.' 2>/dev/null || echo "")
522
+ if [ -z "$LM_STUDIO_HOST" ] || [ "$LM_STUDIO_HOST" = "null" ]; then LM_STUDIO_HOST="http://localhost:1234"; fi
523
+ LM_STUDIO_MODEL=$(gsd_run query config-get review.models.lm_studio 2>/dev/null | jq -r '.' 2>/dev/null || echo "")
524
+ if [ -z "$LM_STUDIO_MODEL" ] || [ "$LM_STUDIO_MODEL" = "null" ]; then
525
+ LM_STUDIO_MODEL=$(curl -s --max-time 2 "${LM_STUDIO_HOST}/v1/models" 2>/dev/null | jq -r '.data[0].id // "local-model"' 2>/dev/null || echo "local-model")
526
+ fi
527
+ LM_STUDIO_RESPONSE=$(jq -n --rawfile content "$LM_STUDIO_PROMPT_FILE" \
528
+ --arg model "$LM_STUDIO_MODEL" \
529
+ '{model: $model, messages: [{role: "user", content: $content}]}' | \
530
+ curl -s --max-time 120 -X POST "${LM_STUDIO_HOST}/v1/chat/completions" \
531
+ -H "Content-Type: application/json" -d @- 2>/dev/null)
532
+ LM_STUDIO_ACTUAL_MODEL=$(echo "$LM_STUDIO_RESPONSE" | jq -r '.model // ""' 2>/dev/null || echo "")
533
+ if [ -n "$LM_STUDIO_ACTUAL_MODEL" ] && [ "$LM_STUDIO_ACTUAL_MODEL" != "null" ] && [ "$LM_STUDIO_ACTUAL_MODEL" != "$LM_STUDIO_MODEL" ]; then
534
+ echo "Warning: LM Studio served model '$LM_STUDIO_ACTUAL_MODEL' but '$LM_STUDIO_MODEL' was requested. Review may be from a different model." >&2
535
+ fi
536
+ LM_STUDIO_CONTENT=$(echo "$LM_STUDIO_RESPONSE" | jq -r '.choices[0].message.content // ""' 2>/dev/null || echo "")
537
+ if [ -n "$LM_STUDIO_CONTENT" ]; then
538
+ echo "$LM_STUDIO_CONTENT" > /tmp/gsd-review-lm_studio-{phase}.md
539
+ else
540
+ echo "Warning: LM Studio returned empty content — skipping review." >&2
541
+ fi
542
+ fi
543
+ ```
544
+
545
+ **llama.cpp (local, OpenAI-compatible):**
546
+ ```bash
547
+ # Resolve prompt budget for llama.cpp: per-reviewer override > global default > null
548
+ LLAMA_CPP_REVIEWER_BUDGET=$(gsd_run query config-get review.max_prompt_tokens_per_reviewer.llama_cpp 2>/dev/null | jq -r '.' 2>/dev/null || echo "null")
549
+ if [ -z "$LLAMA_CPP_REVIEWER_BUDGET" ] || [ "$LLAMA_CPP_REVIEWER_BUDGET" = "null" ]; then
550
+ LLAMA_CPP_REVIEWER_BUDGET=$(gsd_run query config-get review.max_prompt_tokens 2>/dev/null | jq -r '.' 2>/dev/null || echo "null")
551
+ fi
552
+
553
+ # Apply budget trim for llama.cpp if a budget is configured
554
+ LLAMA_CPP_PROMPT_FILE="/tmp/gsd-review-prompt-{phase}.md"
555
+ LLAMA_CPP_SKIP=0
556
+ if [ -n "$LLAMA_CPP_REVIEWER_BUDGET" ] && [ "$LLAMA_CPP_REVIEWER_BUDGET" != "null" ] && [ "$LLAMA_CPP_REVIEWER_BUDGET" != "0" ]; then
557
+ LLAMA_CPP_TRIMMED_PROMPT="/tmp/gsd-review-prompt-{phase}-llama_cpp.md"
558
+ LLAMA_CPP_TRIM_META="/tmp/gsd-review-prompt-{phase}-llama_cpp.metadata.json"
559
+ prepare_trimmed_prompt_for_reviewer "llama_cpp" "$LLAMA_CPP_REVIEWER_BUDGET" "$LLAMA_CPP_TRIMMED_PROMPT" "$LLAMA_CPP_TRIM_META"
560
+ LLAMA_CPP_EXIT=$?
561
+ if [ $LLAMA_CPP_EXIT -ne 0 ]; then
562
+ if [ $LLAMA_CPP_EXIT -eq 2 ] || [ $LLAMA_CPP_EXIT -eq 11 ]; then
563
+ echo "WARNING: prompt budget for llama_cpp (${LLAMA_CPP_REVIEWER_BUDGET} tokens) is too small for the minimum review set. Skipping llama.cpp reviewer." >&2
564
+ else
565
+ echo "WARNING: prompt-budget returned unexpected exit code ${LLAMA_CPP_EXIT} for llama_cpp. Skipping llama.cpp reviewer." >&2
566
+ fi
567
+ LLAMA_CPP_SKIP=1
568
+ else
569
+ LLAMA_CPP_PROMPT_FILE="$LLAMA_CPP_TRIMMED_PROMPT"
570
+ fi
571
+ fi
572
+
573
+ if [ "$LLAMA_CPP_SKIP" != "1" ]; then
574
+ LLAMA_CPP_HOST=$(gsd_run query config-get review.llama_cpp_host 2>/dev/null | jq -r '.' 2>/dev/null || echo "")
575
+ if [ -z "$LLAMA_CPP_HOST" ] || [ "$LLAMA_CPP_HOST" = "null" ]; then LLAMA_CPP_HOST="http://localhost:8080"; fi
576
+ LLAMA_CPP_MODEL=$(gsd_run query config-get review.models.llama_cpp 2>/dev/null | jq -r '.' 2>/dev/null || echo "")
577
+ if [ -z "$LLAMA_CPP_MODEL" ] || [ "$LLAMA_CPP_MODEL" = "null" ]; then
578
+ LLAMA_CPP_MODEL=$(curl -s --max-time 2 "${LLAMA_CPP_HOST}/v1/models" 2>/dev/null | jq -r '.data[0].id // "local-model"' 2>/dev/null || echo "local-model")
579
+ fi
580
+ LLAMA_CPP_CONTENT=$(jq -n --rawfile content "$LLAMA_CPP_PROMPT_FILE" \
581
+ --arg model "$LLAMA_CPP_MODEL" \
582
+ '{model: $model, messages: [{role: "user", content: $content}]}' | \
583
+ curl -s --max-time 120 -X POST "${LLAMA_CPP_HOST}/v1/chat/completions" \
584
+ -H "Content-Type: application/json" -d @- 2>/dev/null | \
585
+ jq -r '.choices[0].message.content // ""' 2>/dev/null || echo "")
586
+ if [ -n "$LLAMA_CPP_CONTENT" ]; then
587
+ echo "$LLAMA_CPP_CONTENT" > /tmp/gsd-review-llama_cpp-{phase}.md
588
+ else
589
+ echo "Warning: llama.cpp returned empty content — skipping review." >&2
590
+ fi
591
+ fi
592
+ ```
593
+
594
+ If a CLI or local server fails, log the error and continue with remaining reviewers.
595
+
596
+ Display progress:
597
+ ```
598
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
599
+ GSD ► CROSS-AI REVIEW — Phase {N}
600
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
601
+
602
+ ◆ Reviewing with {CLI}... done ✓
603
+ ◆ Reviewing with {CLI}... done ✓
604
+ ```
605
+ </step>
606
+
607
+ <step name="write_reviews">
608
+ Combine all review responses into `{phase_dir}/{padded_phase}-REVIEWS.md`:
609
+
610
+ After all reviewers complete, collect trim metadata files written during the run. For each reviewer that was trimmed (i.e. a `.metadata.json` file exists and `hardFailed` or `omitted` is non-empty, or `projectMdShrunk` is true, or `planTruncationPct > 0`), include a `trimmed_reviewers` block in the frontmatter. Omit the key entirely if no reviewer was trimmed.
611
+
612
+ ```markdown
613
+ ---
614
+ phase: {N}
615
+ reviewers: [gemini, claude, codex, coderabbit, opencode, qwen, cursor, antigravity, ollama, lm_studio, llama_cpp] # populate at runtime with only the reviewers actually invoked
616
+ reviewed_at: {ISO timestamp}
617
+ plans_reviewed: [{list of PLAN.md files}]
618
+ trimmed_reviewers: # only present if at least one reviewer was trimmed
619
+ ollama:
620
+ budget: 6000
621
+ effective_budget: 5400
622
+ estimated_tokens: 5380
623
+ omitted: [context, research]
624
+ project_md_shrunk: true
625
+ plan_truncation_pct: 22
626
+ hard_failed: false
627
+ note_injected: true
628
+ ---
629
+
630
+ # Cross-AI Plan Review — Phase {N}
631
+
632
+ ## Gemini Review
633
+
634
+ {gemini review content}
635
+
636
+ ---
637
+
638
+ ## Claude Review
639
+
640
+ {claude review content}
641
+
642
+ ---
643
+
644
+ ## Codex Review
645
+
646
+ {codex review content}
647
+
648
+ ---
649
+
650
+ ## CodeRabbit Review
651
+
652
+ {coderabbit review content}
653
+
654
+ ---
655
+
656
+ ## OpenCode Review
657
+
658
+ {opencode review content}
659
+
660
+ ---
661
+
662
+ ## Qwen Review
663
+
664
+ {qwen review content}
665
+
666
+ ---
667
+
668
+ ## Cursor Review
669
+
670
+ {cursor review content}
671
+
672
+ ---
673
+
674
+ ## Antigravity Review
675
+
676
+ {antigravity review content}
677
+
678
+ ---
679
+
680
+ ## Ollama Review
681
+
682
+ {ollama review content}
683
+
684
+ ---
685
+
686
+ ## LM Studio Review
687
+
688
+ {lm_studio review content}
689
+
690
+ ---
691
+
692
+ ## llama.cpp Review
693
+
694
+ {llama_cpp review content}
695
+
696
+ ---
697
+
698
+ ## Consensus Summary
699
+
700
+ {synthesize common concerns across all reviewers}
701
+
702
+ ### Agreed Strengths
703
+ {strengths mentioned by 2+ reviewers}
704
+
705
+ ### Agreed Concerns
706
+ {concerns raised by 2+ reviewers — highest priority}
707
+
708
+ ### Divergent Views
709
+ {where reviewers disagreed — worth investigating}
710
+ ```
711
+
712
+ Commit:
713
+ ```bash
714
+ gsd_run query commit "docs: cross-AI review for phase {N}" --files {phase_dir}/{padded_phase}-REVIEWS.md
715
+ ```
716
+ </step>
717
+
718
+ <step name="present_results">
719
+ Display summary:
720
+
721
+ ```
722
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
723
+ GSD ► REVIEW COMPLETE
724
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
725
+
726
+ Phase {N} reviewed by {count} AI systems.
727
+
728
+ Consensus concerns:
729
+ {top 3 shared concerns}
730
+
731
+ Full review: {padded_phase}-REVIEWS.md
732
+
733
+ To incorporate feedback into planning:
734
+ /gsd:plan-phase {N} --reviews
735
+ ```
736
+
737
+ Clean up temp files.
738
+ </step>
739
+
740
+ </process>
741
+
742
+ <success_criteria>
743
+ - [ ] At least one external CLI invoked successfully
744
+ - [ ] REVIEWS.md written with structured feedback
745
+ - [ ] Consensus summary synthesized from multiple reviewers
746
+ - [ ] Temp files cleaned up
747
+ - [ ] User knows how to use feedback (/gsd:plan-phase --reviews)
748
+ </success_criteria>