@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.
- package/.claude-plugin/plugin.json +23 -0
- package/GEMINI.md +53 -0
- package/LICENSE +21 -0
- package/README.ja-JP.md +125 -0
- package/README.ko-KR.md +125 -0
- package/README.md +144 -0
- package/README.pt-BR.md +125 -0
- package/README.zh-CN.md +125 -0
- package/agents/gsd-advisor-researcher.md +108 -0
- package/agents/gsd-ai-researcher.md +114 -0
- package/agents/gsd-assumptions-analyzer.md +105 -0
- package/agents/gsd-code-fixer.md +668 -0
- package/agents/gsd-code-reviewer.md +387 -0
- package/agents/gsd-codebase-mapper.md +853 -0
- package/agents/gsd-debug-session-manager.md +314 -0
- package/agents/gsd-debugger.md +1452 -0
- package/agents/gsd-doc-classifier.md +168 -0
- package/agents/gsd-doc-synthesizer.md +204 -0
- package/agents/gsd-doc-verifier.md +217 -0
- package/agents/gsd-doc-writer.md +616 -0
- package/agents/gsd-domain-researcher.md +147 -0
- package/agents/gsd-eval-auditor.md +191 -0
- package/agents/gsd-eval-planner.md +154 -0
- package/agents/gsd-executor.md +785 -0
- package/agents/gsd-framework-selector.md +160 -0
- package/agents/gsd-integration-checker.md +470 -0
- package/agents/gsd-intel-updater.md +342 -0
- package/agents/gsd-nyquist-auditor.md +203 -0
- package/agents/gsd-pattern-mapper.md +335 -0
- package/agents/gsd-phase-researcher.md +867 -0
- package/agents/gsd-plan-checker.md +978 -0
- package/agents/gsd-planner.md +1204 -0
- package/agents/gsd-project-researcher.md +611 -0
- package/agents/gsd-research-synthesizer.md +259 -0
- package/agents/gsd-roadmapper.md +688 -0
- package/agents/gsd-security-auditor.md +155 -0
- package/agents/gsd-ui-auditor.md +495 -0
- package/agents/gsd-ui-checker.md +309 -0
- package/agents/gsd-ui-researcher.md +374 -0
- package/agents/gsd-user-profiler.md +171 -0
- package/agents/gsd-verifier.md +923 -0
- package/assets/gsd-logo-2000-transparent.png +0 -0
- package/assets/gsd-logo-2000-transparent.svg +17 -0
- package/assets/gsd-logo-2000.png +0 -0
- package/assets/gsd-logo-2000.svg +21 -0
- package/assets/terminal.svg +68 -0
- package/bin/install.js +12726 -0
- package/bin/lib/ui-safety-gate.cjs +107 -0
- package/commands/gsd/add-tests.md +42 -0
- package/commands/gsd/ai-integration-phase.md +37 -0
- package/commands/gsd/audit-fix.md +34 -0
- package/commands/gsd/audit-milestone.md +37 -0
- package/commands/gsd/audit-uat.md +24 -0
- package/commands/gsd/autonomous.md +48 -0
- package/commands/gsd/capture.md +62 -0
- package/commands/gsd/cleanup.md +24 -0
- package/commands/gsd/code-review.md +59 -0
- package/commands/gsd/complete-milestone.md +143 -0
- package/commands/gsd/config.md +56 -0
- package/commands/gsd/debug.md +52 -0
- package/commands/gsd/discover-product.md +65 -0
- package/commands/gsd/discuss-phase.md +77 -0
- package/commands/gsd/docs-update.md +49 -0
- package/commands/gsd/eval-review.md +33 -0
- package/commands/gsd/execute-phase.md +66 -0
- package/commands/gsd/explore.md +27 -0
- package/commands/gsd/extract-learnings.md +23 -0
- package/commands/gsd/fast.md +31 -0
- package/commands/gsd/forensics.md +57 -0
- package/commands/gsd/graphify.md +204 -0
- package/commands/gsd/health.md +31 -0
- package/commands/gsd/help.md +28 -0
- package/commands/gsd/import.md +45 -0
- package/commands/gsd/inbox.md +39 -0
- package/commands/gsd/ingest-docs.md +42 -0
- package/commands/gsd/manager.md +45 -0
- package/commands/gsd/map-codebase.md +83 -0
- package/commands/gsd/milestone-summary.md +51 -0
- package/commands/gsd/model-domain.md +65 -0
- package/commands/gsd/mvp-phase.md +45 -0
- package/commands/gsd/new-milestone.md +45 -0
- package/commands/gsd/new-project.md +47 -0
- package/commands/gsd/ns-context.md +23 -0
- package/commands/gsd/ns-ideate.md +24 -0
- package/commands/gsd/ns-manage.md +29 -0
- package/commands/gsd/ns-project.md +22 -0
- package/commands/gsd/ns-review.md +26 -0
- package/commands/gsd/ns-workflow.md +28 -0
- package/commands/gsd/pause-work.md +43 -0
- package/commands/gsd/phase.md +56 -0
- package/commands/gsd/plan-phase.md +64 -0
- package/commands/gsd/plan-review-convergence.md +59 -0
- package/commands/gsd/pr-branch.md +26 -0
- package/commands/gsd/profile-user.md +46 -0
- package/commands/gsd/progress.md +48 -0
- package/commands/gsd/quick.md +174 -0
- package/commands/gsd/recommend-architecture.md +64 -0
- package/commands/gsd/resume-work.md +30 -0
- package/commands/gsd/review-backlog.md +63 -0
- package/commands/gsd/review.md +42 -0
- package/commands/gsd/secure-phase.md +36 -0
- package/commands/gsd/settings.md +29 -0
- package/commands/gsd/ship.md +24 -0
- package/commands/gsd/sketch.md +60 -0
- package/commands/gsd/spec-phase.md +63 -0
- package/commands/gsd/spike.md +57 -0
- package/commands/gsd/stats.md +20 -0
- package/commands/gsd/surface.md +155 -0
- package/commands/gsd/testing-strategy.md +65 -0
- package/commands/gsd/thread.md +24 -0
- package/commands/gsd/ui-phase.md +35 -0
- package/commands/gsd/ui-review.md +33 -0
- package/commands/gsd/ultraplan-phase.md +34 -0
- package/commands/gsd/undo.md +35 -0
- package/commands/gsd/update.md +49 -0
- package/commands/gsd/validate-phase.md +36 -0
- package/commands/gsd/verify-work.md +39 -0
- package/commands/gsd/workspace.md +52 -0
- package/commands/gsd/workstreams.md +70 -0
- package/gemini-extension.json +6 -0
- package/gsd-core/bin/check-latest-version.cjs +161 -0
- package/gsd-core/bin/gsd-tools.cjs +1928 -0
- package/gsd-core/bin/lib/active-workstream-store.cjs +291 -0
- package/gsd-core/bin/lib/adr-parser.cjs +399 -0
- package/gsd-core/bin/lib/agent-command-router.cjs +68 -0
- package/gsd-core/bin/lib/artifacts.cjs +51 -0
- package/gsd-core/bin/lib/audit.cjs +743 -0
- package/gsd-core/bin/lib/check-command-router.cjs +343 -0
- package/gsd-core/bin/lib/cjs-command-router-adapter.cjs +81 -0
- package/gsd-core/bin/lib/cli-exit.cjs +42 -0
- package/gsd-core/bin/lib/clock.cjs +95 -0
- package/gsd-core/bin/lib/clusters.cjs +132 -0
- package/gsd-core/bin/lib/code-review-flags.cjs +59 -0
- package/gsd-core/bin/lib/command-aliases.cjs +809 -0
- package/gsd-core/bin/lib/command-arg-projection.cjs +55 -0
- package/gsd-core/bin/lib/command-routing-hub.cjs +300 -0
- package/gsd-core/bin/lib/commands.cjs +1203 -0
- package/gsd-core/bin/lib/config-schema.cjs +29 -0
- package/gsd-core/bin/lib/config-types.cjs +19 -0
- package/gsd-core/bin/lib/config.cjs +738 -0
- package/gsd-core/bin/lib/configuration.cjs +239 -0
- package/gsd-core/bin/lib/context-utilization.cjs +48 -0
- package/gsd-core/bin/lib/core.cjs +2051 -0
- package/gsd-core/bin/lib/decisions.cjs +118 -0
- package/gsd-core/bin/lib/docs.cjs +252 -0
- package/gsd-core/bin/lib/drift.cjs +364 -0
- package/gsd-core/bin/lib/fallow-runner.cjs +115 -0
- package/gsd-core/bin/lib/frontmatter.cjs +442 -0
- package/gsd-core/bin/lib/gap-checker.cjs +257 -0
- package/gsd-core/bin/lib/graphify.cjs +496 -0
- package/gsd-core/bin/lib/gsd2-import.cjs +456 -0
- package/gsd-core/bin/lib/init-command-router.cjs +62 -0
- package/gsd-core/bin/lib/init.cjs +1815 -0
- package/gsd-core/bin/lib/install-profiles.cjs +584 -0
- package/gsd-core/bin/lib/installer-migration-authoring.cjs +122 -0
- package/gsd-core/bin/lib/installer-migration-report.cjs +350 -0
- package/gsd-core/bin/lib/installer-migrations/000-first-time-baseline.cjs +218 -0
- package/gsd-core/bin/lib/installer-migrations/001-legacy-orphan-files.cjs +48 -0
- package/gsd-core/bin/lib/installer-migrations/002-codex-legacy-hooks-json.cjs +94 -0
- package/gsd-core/bin/lib/installer-migrations/003-rename-get-shit-done-to-gsd-core.cjs +108 -0
- package/gsd-core/bin/lib/installer-migrations.cjs +823 -0
- package/gsd-core/bin/lib/intel.cjs +590 -0
- package/gsd-core/bin/lib/learnings.cjs +270 -0
- package/gsd-core/bin/lib/legacy-cleanup.cjs +253 -0
- package/gsd-core/bin/lib/milestone.cjs +373 -0
- package/gsd-core/bin/lib/model-catalog.cjs +154 -0
- package/gsd-core/bin/lib/model-profiles.cjs +24 -0
- package/gsd-core/bin/lib/observability/event.cjs +51 -0
- package/gsd-core/bin/lib/observability/logger.cjs +146 -0
- package/gsd-core/bin/lib/observability/redaction.cjs +48 -0
- package/gsd-core/bin/lib/package-identity.cjs +35 -0
- package/gsd-core/bin/lib/package-legitimacy.cjs +368 -0
- package/gsd-core/bin/lib/phase-command-router.cjs +189 -0
- package/gsd-core/bin/lib/phase-lifecycle.cjs +74 -0
- package/gsd-core/bin/lib/phase.cjs +1307 -0
- package/gsd-core/bin/lib/phases-command-router.cjs +43 -0
- package/gsd-core/bin/lib/plan-scan.cjs +91 -0
- package/gsd-core/bin/lib/planning-workspace.cjs +245 -0
- package/gsd-core/bin/lib/profile-output.cjs +1120 -0
- package/gsd-core/bin/lib/profile-pipeline.cjs +517 -0
- package/gsd-core/bin/lib/project-root.cjs +119 -0
- package/gsd-core/bin/lib/prompt-budget.cjs +305 -0
- package/gsd-core/bin/lib/research-provider.cjs +137 -0
- package/gsd-core/bin/lib/research-store.cjs +167 -0
- package/gsd-core/bin/lib/review-reviewer-selection.cjs +121 -0
- package/gsd-core/bin/lib/roadmap-command-router.cjs +166 -0
- package/gsd-core/bin/lib/roadmap-upgrade.cjs +476 -0
- package/gsd-core/bin/lib/roadmap.cjs +600 -0
- package/gsd-core/bin/lib/runtime-artifact-layout.cjs +312 -0
- package/gsd-core/bin/lib/runtime-config-adapter-registry.cjs +56 -0
- package/gsd-core/bin/lib/runtime-homes.cjs +190 -0
- package/gsd-core/bin/lib/runtime-name-policy.cjs +96 -0
- package/gsd-core/bin/lib/runtime-slash.cjs +119 -0
- package/gsd-core/bin/lib/schema-detect.cjs +159 -0
- package/gsd-core/bin/lib/secrets.cjs +34 -0
- package/gsd-core/bin/lib/security.cjs +480 -0
- package/gsd-core/bin/lib/semver-compare.cjs +42 -0
- package/gsd-core/bin/lib/shell-command-projection.cjs +533 -0
- package/gsd-core/bin/lib/state-command-router.cjs +160 -0
- package/gsd-core/bin/lib/state-document.cjs +259 -0
- package/gsd-core/bin/lib/state.cjs +2010 -0
- package/gsd-core/bin/lib/surface.cjs +449 -0
- package/gsd-core/bin/lib/task-command-router.cjs +85 -0
- package/gsd-core/bin/lib/template.cjs +237 -0
- package/gsd-core/bin/lib/uat.cjs +297 -0
- package/gsd-core/bin/lib/ui-safety-gate.cjs +98 -0
- package/gsd-core/bin/lib/update-context.cjs +218 -0
- package/gsd-core/bin/lib/validate-command-router.cjs +91 -0
- package/gsd-core/bin/lib/validate.cjs +112 -0
- package/gsd-core/bin/lib/verification-command-router.cjs +31 -0
- package/gsd-core/bin/lib/verification.cjs +193 -0
- package/gsd-core/bin/lib/verify-command-router.cjs +44 -0
- package/gsd-core/bin/lib/verify.cjs +1451 -0
- package/gsd-core/bin/lib/workstream-inventory-builder.cjs +81 -0
- package/gsd-core/bin/lib/workstream-inventory.cjs +147 -0
- package/gsd-core/bin/lib/workstream-name-policy.cjs +91 -0
- package/gsd-core/bin/lib/workstream.cjs +380 -0
- package/gsd-core/bin/lib/worktree-base-ref.cjs +325 -0
- package/gsd-core/bin/lib/worktree-safety.cjs +943 -0
- package/gsd-core/bin/shared/config-defaults.manifest.json +98 -0
- package/gsd-core/bin/shared/config-schema.manifest.json +192 -0
- package/gsd-core/bin/shared/model-catalog.json +149 -0
- package/gsd-core/bin/shared/runtime-aliases.manifest.json +75 -0
- package/gsd-core/bin/verify-reapply-patches.cjs +349 -0
- package/gsd-core/contexts/dev.md +21 -0
- package/gsd-core/contexts/research.md +22 -0
- package/gsd-core/contexts/review.md +23 -0
- package/gsd-core/references/agent-contracts.md +79 -0
- package/gsd-core/references/ai-evals.md +156 -0
- package/gsd-core/references/ai-frameworks.md +186 -0
- package/gsd-core/references/architecture-decision.md +74 -0
- package/gsd-core/references/artifact-types.md +131 -0
- package/gsd-core/references/auth-in-tests.md +91 -0
- package/gsd-core/references/autonomous-smart-discuss.md +277 -0
- package/gsd-core/references/checkpoints.md +814 -0
- package/gsd-core/references/common-bug-patterns.md +114 -0
- package/gsd-core/references/context-budget.md +85 -0
- package/gsd-core/references/continuation-format.md +253 -0
- package/gsd-core/references/db-test-isolation.md +54 -0
- package/gsd-core/references/debugger-philosophy.md +76 -0
- package/gsd-core/references/decimal-phase-calculation.md +64 -0
- package/gsd-core/references/doc-conflict-engine.md +91 -0
- package/gsd-core/references/domain-modeling.md +80 -0
- package/gsd-core/references/domain-probes.md +125 -0
- package/gsd-core/references/e2e-tiering.md +35 -0
- package/gsd-core/references/execute-mvp-tdd.md +81 -0
- package/gsd-core/references/executor-examples.md +110 -0
- package/gsd-core/references/few-shot-examples/plan-checker.md +73 -0
- package/gsd-core/references/few-shot-examples/verifier.md +109 -0
- package/gsd-core/references/flaky-test-checklist.md +22 -0
- package/gsd-core/references/gate-prompts.md +100 -0
- package/gsd-core/references/gates.md +70 -0
- package/gsd-core/references/git-integration.md +298 -0
- package/gsd-core/references/git-planning-commit.md +40 -0
- package/gsd-core/references/ios-scaffold.md +123 -0
- package/gsd-core/references/mandatory-initial-read.md +2 -0
- package/gsd-core/references/model-profile-resolution.md +38 -0
- package/gsd-core/references/model-profiles.md +245 -0
- package/gsd-core/references/mvp-concepts.md +49 -0
- package/gsd-core/references/phase-argument-parsing.md +61 -0
- package/gsd-core/references/planner-antipatterns.md +89 -0
- package/gsd-core/references/planner-chunked.md +49 -0
- package/gsd-core/references/planner-gap-closure.md +62 -0
- package/gsd-core/references/planner-graphify-auto-update.md +67 -0
- package/gsd-core/references/planner-human-verify-mode.md +57 -0
- package/gsd-core/references/planner-interface-context.md +62 -0
- package/gsd-core/references/planner-load-graph-context.md +36 -0
- package/gsd-core/references/planner-mvp-mode.md +53 -0
- package/gsd-core/references/planner-reviews.md +39 -0
- package/gsd-core/references/planner-revision.md +87 -0
- package/gsd-core/references/planner-source-audit.md +73 -0
- package/gsd-core/references/planning-config.md +473 -0
- package/gsd-core/references/product-discovery.md +49 -0
- package/gsd-core/references/project-skills-discovery.md +19 -0
- package/gsd-core/references/questioning.md +162 -0
- package/gsd-core/references/realistic-test-data.md +44 -0
- package/gsd-core/references/research-documentation-lookup.md +29 -0
- package/gsd-core/references/research-philosophy.md +29 -0
- package/gsd-core/references/research-verification-protocol.md +27 -0
- package/gsd-core/references/revision-loop.md +97 -0
- package/gsd-core/references/scout-codebase.md +51 -0
- package/gsd-core/references/skeleton-template.md +48 -0
- package/gsd-core/references/sketch-interactivity.md +41 -0
- package/gsd-core/references/sketch-theme-system.md +94 -0
- package/gsd-core/references/sketch-tooling.md +45 -0
- package/gsd-core/references/sketch-variant-patterns.md +81 -0
- package/gsd-core/references/spidr-splitting.md +69 -0
- package/gsd-core/references/tdd.md +330 -0
- package/gsd-core/references/test-containers.md +55 -0
- package/gsd-core/references/test-strategy.md +75 -0
- package/gsd-core/references/thinking-models-debug.md +44 -0
- package/gsd-core/references/thinking-models-execution.md +50 -0
- package/gsd-core/references/thinking-models-planning.md +62 -0
- package/gsd-core/references/thinking-models-research.md +50 -0
- package/gsd-core/references/thinking-models-verification.md +55 -0
- package/gsd-core/references/thinking-partner.md +96 -0
- package/gsd-core/references/ui-brand.md +162 -0
- package/gsd-core/references/universal-anti-patterns.md +63 -0
- package/gsd-core/references/user-profiling.md +681 -0
- package/gsd-core/references/user-story-template.md +58 -0
- package/gsd-core/references/verification-overrides.md +227 -0
- package/gsd-core/references/verification-patterns.md +612 -0
- package/gsd-core/references/verify-mvp-mode.md +85 -0
- package/gsd-core/references/workstream-flag.md +111 -0
- package/gsd-core/references/worktree-branch-check.md +38 -0
- package/gsd-core/references/worktree-path-safety.md +67 -0
- package/gsd-core/templates/AI-SPEC.md +246 -0
- package/gsd-core/templates/DEBUG.md +169 -0
- package/gsd-core/templates/README.md +77 -0
- package/gsd-core/templates/SECURITY.md +61 -0
- package/gsd-core/templates/UAT.md +265 -0
- package/gsd-core/templates/UI-SPEC.md +100 -0
- package/gsd-core/templates/VALIDATION.md +76 -0
- package/gsd-core/templates/adr.md +58 -0
- package/gsd-core/templates/claude-md.md +145 -0
- package/gsd-core/templates/codebase/architecture.md +255 -0
- package/gsd-core/templates/codebase/concerns.md +310 -0
- package/gsd-core/templates/codebase/conventions.md +307 -0
- package/gsd-core/templates/codebase/integrations.md +280 -0
- package/gsd-core/templates/codebase/stack.md +186 -0
- package/gsd-core/templates/codebase/structure.md +285 -0
- package/gsd-core/templates/codebase/testing.md +480 -0
- package/gsd-core/templates/config.json +62 -0
- package/gsd-core/templates/context.md +352 -0
- package/gsd-core/templates/continue-here.md +78 -0
- package/gsd-core/templates/copilot-instructions.md +7 -0
- package/gsd-core/templates/debug-subagent-prompt.md +91 -0
- package/gsd-core/templates/dev-preferences.md +21 -0
- package/gsd-core/templates/discovery.md +146 -0
- package/gsd-core/templates/discussion-log.md +63 -0
- package/gsd-core/templates/domain-model.md +54 -0
- package/gsd-core/templates/milestone-archive.md +123 -0
- package/gsd-core/templates/milestone.md +115 -0
- package/gsd-core/templates/phase-prompt.md +610 -0
- package/gsd-core/templates/planner-subagent-prompt.md +117 -0
- package/gsd-core/templates/product-brief.md +55 -0
- package/gsd-core/templates/project.md +186 -0
- package/gsd-core/templates/requirements.md +231 -0
- package/gsd-core/templates/research-project/ARCHITECTURE.md +204 -0
- package/gsd-core/templates/research-project/FEATURES.md +147 -0
- package/gsd-core/templates/research-project/PITFALLS.md +200 -0
- package/gsd-core/templates/research-project/STACK.md +120 -0
- package/gsd-core/templates/research-project/SUMMARY.md +170 -0
- package/gsd-core/templates/research.md +592 -0
- package/gsd-core/templates/retrospective.md +54 -0
- package/gsd-core/templates/roadmap.md +202 -0
- package/gsd-core/templates/spec.md +307 -0
- package/gsd-core/templates/state.md +195 -0
- package/gsd-core/templates/summary-complex.md +59 -0
- package/gsd-core/templates/summary-minimal.md +41 -0
- package/gsd-core/templates/summary-standard.md +48 -0
- package/gsd-core/templates/summary.md +248 -0
- package/gsd-core/templates/test-strategy.md +50 -0
- package/gsd-core/templates/user-profile.md +146 -0
- package/gsd-core/templates/user-setup.md +311 -0
- package/gsd-core/templates/verification-report.md +322 -0
- package/gsd-core/workflows/_runtime-launcher.snippet.sh +1 -0
- package/gsd-core/workflows/add-backlog.md +91 -0
- package/gsd-core/workflows/add-phase.md +113 -0
- package/gsd-core/workflows/add-tests.md +355 -0
- package/gsd-core/workflows/add-todo.md +161 -0
- package/gsd-core/workflows/ai-integration-phase.md +295 -0
- package/gsd-core/workflows/analyze-dependencies.md +96 -0
- package/gsd-core/workflows/audit-fix.md +178 -0
- package/gsd-core/workflows/audit-milestone.md +360 -0
- package/gsd-core/workflows/audit-uat.md +110 -0
- package/gsd-core/workflows/autonomous.md +797 -0
- package/gsd-core/workflows/check-todos.md +180 -0
- package/gsd-core/workflows/cleanup.md +195 -0
- package/gsd-core/workflows/code-review-fix.md +502 -0
- package/gsd-core/workflows/code-review.md +658 -0
- package/gsd-core/workflows/complete-milestone.md +855 -0
- package/gsd-core/workflows/debug.md +237 -0
- package/gsd-core/workflows/diagnose-issues.md +245 -0
- package/gsd-core/workflows/discover-product.md +112 -0
- package/gsd-core/workflows/discovery-phase.md +291 -0
- package/gsd-core/workflows/discuss-phase/modes/advisor.md +176 -0
- package/gsd-core/workflows/discuss-phase/modes/all.md +28 -0
- package/gsd-core/workflows/discuss-phase/modes/analyze.md +44 -0
- package/gsd-core/workflows/discuss-phase/modes/auto.md +57 -0
- package/gsd-core/workflows/discuss-phase/modes/batch.md +52 -0
- package/gsd-core/workflows/discuss-phase/modes/chain.md +98 -0
- package/gsd-core/workflows/discuss-phase/modes/default.md +141 -0
- package/gsd-core/workflows/discuss-phase/modes/power.md +44 -0
- package/gsd-core/workflows/discuss-phase/modes/text.md +55 -0
- package/gsd-core/workflows/discuss-phase/templates/checkpoint.json +18 -0
- package/gsd-core/workflows/discuss-phase/templates/context.md +136 -0
- package/gsd-core/workflows/discuss-phase/templates/discussion-log.md +50 -0
- package/gsd-core/workflows/discuss-phase-assumptions.md +675 -0
- package/gsd-core/workflows/discuss-phase-power.md +291 -0
- package/gsd-core/workflows/discuss-phase.md +499 -0
- package/gsd-core/workflows/do.md +111 -0
- package/gsd-core/workflows/docs-update.md +1176 -0
- package/gsd-core/workflows/edit-phase.md +295 -0
- package/gsd-core/workflows/eval-review.md +156 -0
- package/gsd-core/workflows/execute-phase/steps/codebase-drift-gate.md +95 -0
- package/gsd-core/workflows/execute-phase/steps/per-plan-worktree-gate.md +94 -0
- package/gsd-core/workflows/execute-phase/steps/post-merge-gate.md +117 -0
- package/gsd-core/workflows/execute-phase.md +1752 -0
- package/gsd-core/workflows/execute-plan.md +526 -0
- package/gsd-core/workflows/explore.md +146 -0
- package/gsd-core/workflows/extract-learnings.md +243 -0
- package/gsd-core/workflows/fast.md +124 -0
- package/gsd-core/workflows/forensics.md +279 -0
- package/gsd-core/workflows/graduation.md +196 -0
- package/gsd-core/workflows/health.md +224 -0
- package/gsd-core/workflows/help/modes/brief.md +22 -0
- package/gsd-core/workflows/help/modes/default.md +50 -0
- package/gsd-core/workflows/help/modes/full.md +789 -0
- package/gsd-core/workflows/help/modes/topic.md +74 -0
- package/gsd-core/workflows/help.md +24 -0
- package/gsd-core/workflows/import.md +256 -0
- package/gsd-core/workflows/inbox.md +387 -0
- package/gsd-core/workflows/ingest-docs.md +340 -0
- package/gsd-core/workflows/insert-phase.md +152 -0
- package/gsd-core/workflows/list-phase-assumptions.md +178 -0
- package/gsd-core/workflows/list-workspaces.md +57 -0
- package/gsd-core/workflows/manager.md +393 -0
- package/gsd-core/workflows/map-codebase.md +446 -0
- package/gsd-core/workflows/milestone-summary.md +224 -0
- package/gsd-core/workflows/model-domain.md +162 -0
- package/gsd-core/workflows/mvp-phase.md +222 -0
- package/gsd-core/workflows/new-milestone.md +635 -0
- package/gsd-core/workflows/new-project.md +1555 -0
- package/gsd-core/workflows/new-workspace.md +240 -0
- package/gsd-core/workflows/next.md +299 -0
- package/gsd-core/workflows/node-repair.md +92 -0
- package/gsd-core/workflows/note.md +158 -0
- package/gsd-core/workflows/pause-work.md +244 -0
- package/gsd-core/workflows/plan-milestone-gaps.md +281 -0
- package/gsd-core/workflows/plan-phase.md +1814 -0
- package/gsd-core/workflows/plan-review-convergence.md +346 -0
- package/gsd-core/workflows/plant-seed.md +230 -0
- package/gsd-core/workflows/pr-branch.md +157 -0
- package/gsd-core/workflows/profile-user.md +453 -0
- package/gsd-core/workflows/progress.md +699 -0
- package/gsd-core/workflows/quick.md +1017 -0
- package/gsd-core/workflows/reapply-patches.md +426 -0
- package/gsd-core/workflows/recommend-architecture.md +135 -0
- package/gsd-core/workflows/remove-phase.md +156 -0
- package/gsd-core/workflows/remove-workspace.md +108 -0
- package/gsd-core/workflows/resume-project.md +332 -0
- package/gsd-core/workflows/review.md +748 -0
- package/gsd-core/workflows/scan.md +107 -0
- package/gsd-core/workflows/secure-phase.md +182 -0
- package/gsd-core/workflows/session-report.md +146 -0
- package/gsd-core/workflows/settings-advanced.md +810 -0
- package/gsd-core/workflows/settings-integrations.md +312 -0
- package/gsd-core/workflows/settings.md +566 -0
- package/gsd-core/workflows/ship.md +405 -0
- package/gsd-core/workflows/sketch-wrap-up.md +286 -0
- package/gsd-core/workflows/sketch.md +361 -0
- package/gsd-core/workflows/spec-phase.md +263 -0
- package/gsd-core/workflows/spike-wrap-up.md +307 -0
- package/gsd-core/workflows/spike.md +453 -0
- package/gsd-core/workflows/stats.md +80 -0
- package/gsd-core/workflows/sync-skills.md +182 -0
- package/gsd-core/workflows/testing-strategy.md +122 -0
- package/gsd-core/workflows/thread.md +222 -0
- package/gsd-core/workflows/transition.md +694 -0
- package/gsd-core/workflows/ui-phase.md +328 -0
- package/gsd-core/workflows/ui-review.md +193 -0
- package/gsd-core/workflows/ultraplan-phase.md +199 -0
- package/gsd-core/workflows/undo.md +314 -0
- package/gsd-core/workflows/update.md +496 -0
- package/gsd-core/workflows/validate-phase.md +181 -0
- package/gsd-core/workflows/verify-phase.md +544 -0
- package/gsd-core/workflows/verify-work.md +781 -0
- package/hooks/dist/gsd-check-update-worker.js +108 -0
- package/hooks/dist/gsd-check-update.js +66 -0
- package/hooks/dist/gsd-config-reload.js +133 -0
- package/hooks/dist/gsd-context-monitor.js +195 -0
- package/hooks/dist/gsd-cursor-post-tool.js +75 -0
- package/hooks/dist/gsd-cursor-session-start.js +52 -0
- package/hooks/dist/gsd-graphify-update.sh +158 -0
- package/hooks/dist/gsd-phase-boundary.sh +47 -0
- package/hooks/dist/gsd-prompt-guard.js +97 -0
- package/hooks/dist/gsd-read-guard.js +101 -0
- package/hooks/dist/gsd-read-injection-scanner.js +203 -0
- package/hooks/dist/gsd-session-state.sh +59 -0
- package/hooks/dist/gsd-statusline.js +566 -0
- package/hooks/dist/gsd-update-banner.js +138 -0
- package/hooks/dist/gsd-validate-commit.sh +57 -0
- package/hooks/dist/gsd-workflow-guard.js +167 -0
- package/hooks/dist/gsd-worktree-path-guard.js +169 -0
- package/hooks/dist/lib/git-cmd.js +150 -0
- package/hooks/dist/lib/gsd-graphify-rebuild.sh +65 -0
- package/hooks/dist/managed-hooks-registry.cjs +38 -0
- package/hooks/gsd-check-update-worker.js +108 -0
- package/hooks/gsd-check-update.js +66 -0
- package/hooks/gsd-config-reload.js +133 -0
- package/hooks/gsd-context-monitor.js +195 -0
- package/hooks/gsd-cursor-post-tool.js +75 -0
- package/hooks/gsd-cursor-session-start.js +52 -0
- package/hooks/gsd-graphify-update.sh +158 -0
- package/hooks/gsd-phase-boundary.sh +47 -0
- package/hooks/gsd-prompt-guard.js +97 -0
- package/hooks/gsd-read-guard.js +101 -0
- package/hooks/gsd-read-injection-scanner.js +203 -0
- package/hooks/gsd-session-state.sh +59 -0
- package/hooks/gsd-statusline.js +566 -0
- package/hooks/gsd-update-banner.js +138 -0
- package/hooks/gsd-validate-commit.sh +57 -0
- package/hooks/gsd-workflow-guard.js +167 -0
- package/hooks/gsd-worktree-path-guard.js +169 -0
- package/hooks/hooks.json +69 -0
- package/hooks/lib/git-cmd.js +150 -0
- package/hooks/lib/gsd-graphify-rebuild.sh +65 -0
- package/hooks/managed-hooks-registry.cjs +38 -0
- package/package.json +115 -0
- package/scripts/affected-tests-lib.cjs +542 -0
- package/scripts/audit-workflow-script-paths.cjs +73 -0
- package/scripts/base64-scan.sh +351 -0
- package/scripts/build-hooks.js +247 -0
- package/scripts/changeset/README.md +129 -0
- package/scripts/changeset/cli.cjs +590 -0
- package/scripts/changeset/github-release-notes.cjs +199 -0
- package/scripts/changeset/lint.cjs +111 -0
- package/scripts/changeset/new.cjs +137 -0
- package/scripts/changeset/parse.cjs +114 -0
- package/scripts/changeset/render.cjs +34 -0
- package/scripts/changeset/serialize.cjs +130 -0
- package/scripts/check-alias-drift.cjs +114 -0
- package/scripts/check-env.cjs +312 -0
- package/scripts/check-npm-integrity.cjs +215 -0
- package/scripts/ci-guard-runner.cjs +22 -0
- package/scripts/ci-prepare-test-scope.cjs +51 -0
- package/scripts/ci-rebase-check.cjs +86 -0
- package/scripts/ci-test-scope.cjs +431 -0
- package/scripts/command-contract-helpers.cjs +64 -0
- package/scripts/diff-touches-shipped-paths.cjs +155 -0
- package/scripts/fix-slash-commands.cjs +147 -0
- package/scripts/gen-inventory-manifest.cjs +115 -0
- package/scripts/gen-research-agents.cjs +276 -0
- package/scripts/generate-package-identity.cjs +125 -0
- package/scripts/issue-dedupe.cjs +278 -0
- package/scripts/lib/allowlist-ratchet.cjs +136 -0
- package/scripts/lib/cli-exit.cjs +56 -0
- package/scripts/lint-command-contract.cjs +114 -0
- package/scripts/lint-descriptions.cjs +87 -0
- package/scripts/lint-docs-required.cjs +222 -0
- package/scripts/lint-legacy-dir-name.cjs +160 -0
- package/scripts/lint-package-identity-drift.cjs +141 -0
- package/scripts/lint-pr-check-project-dir.cjs +99 -0
- package/scripts/lint-shell-command-projection-drift.cjs +62 -0
- package/scripts/lint-skill-deps.cjs +185 -0
- package/scripts/lint-test-file-count.allowlist.json +135 -0
- package/scripts/lint-test-file-count.cjs +246 -0
- package/scripts/mutation-matrix.cjs +222 -0
- package/scripts/pr-template-policy.cjs +268 -0
- package/scripts/prompt-injection-scan.sh +207 -0
- package/scripts/release-notes/discord-release-summary.cjs +373 -0
- package/scripts/release-notes/format-github-release-notes.cjs +261 -0
- package/scripts/release-tarball-smoke.cjs +629 -0
- package/scripts/research-profiles.cjs +149 -0
- package/scripts/run-affected-tests.cjs +7 -0
- package/scripts/run-cross-platform-tests.cjs +67 -0
- package/scripts/run-tests.cjs +315 -0
- package/scripts/secret-scan-lint.sh +231 -0
- package/scripts/secret-scan.sh +358 -0
- package/scripts/setup-branch-protection.sh +236 -0
- package/scripts/strip-prose-atrefs.cjs +106 -0
- package/scripts/sync-manifest-versions.cjs +119 -0
- package/scripts/sync-rulesets.sh +34 -0
- package/scripts/sync-runtime-launcher.cjs +399 -0
- package/scripts/test-failure-reasons.cjs +34 -0
- package/scripts/verify-npm-publish.cjs +240 -0
- 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>
|