@opengsd/gsd-core 1.2.0-rc.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.ja-JP.md +870 -0
- package/README.ko-KR.md +861 -0
- package/README.md +301 -0
- package/README.pt-BR.md +492 -0
- package/README.zh-CN.md +842 -0
- package/agents/gsd-advisor-researcher.md +127 -0
- package/agents/gsd-ai-researcher.md +133 -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 +615 -0
- package/agents/gsd-domain-researcher.md +153 -0
- package/agents/gsd-eval-auditor.md +191 -0
- package/agents/gsd-eval-planner.md +154 -0
- package/agents/gsd-executor.md +772 -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 +928 -0
- package/agents/gsd-plan-checker.md +978 -0
- package/agents/gsd-planner.md +1218 -0
- package/agents/gsd-project-researcher.md +677 -0
- package/agents/gsd-research-synthesizer.md +255 -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 +380 -0
- package/agents/gsd-user-profiler.md +171 -0
- package/agents/gsd-verifier.md +917 -0
- package/bin/install.js +10936 -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 +46 -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/discuss-phase.md +76 -0
- package/commands/gsd/docs-update.md +49 -0
- package/commands/gsd/eval-review.md +33 -0
- package/commands/gsd/execute-phase.md +64 -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 +199 -0
- package/commands/gsd/health.md +31 -0
- package/commands/gsd/help.md +28 -0
- package/commands/gsd/import.md +41 -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/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 +62 -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 +47 -0
- package/commands/gsd/quick.md +174 -0
- package/commands/gsd/resume-work.md +30 -0
- package/commands/gsd/review-backlog.md +63 -0
- package/commands/gsd/review.md +41 -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 +19 -0
- package/commands/gsd/surface.md +155 -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 +48 -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/get-shit-done/bin/check-latest-version.cjs +106 -0
- package/get-shit-done/bin/gsd-tools.cjs +1676 -0
- package/get-shit-done/bin/lib/active-workstream-store.cjs +302 -0
- package/get-shit-done/bin/lib/adr-parser.cjs +394 -0
- package/get-shit-done/bin/lib/agent-command-router.cjs +65 -0
- package/get-shit-done/bin/lib/artifacts.cjs +53 -0
- package/get-shit-done/bin/lib/audit.cjs +755 -0
- package/get-shit-done/bin/lib/check-command-router.cjs +333 -0
- package/get-shit-done/bin/lib/cjs-command-router-adapter.cjs +118 -0
- package/get-shit-done/bin/lib/clock.cjs +96 -0
- package/get-shit-done/bin/lib/clusters.cjs +135 -0
- package/get-shit-done/bin/lib/code-review-flags.cjs +74 -0
- package/get-shit-done/bin/lib/command-aliases.cjs +815 -0
- package/get-shit-done/bin/lib/command-arg-projection.cjs +62 -0
- package/get-shit-done/bin/lib/command-routing-hub.cjs +388 -0
- package/get-shit-done/bin/lib/commands.cjs +1188 -0
- package/get-shit-done/bin/lib/config-schema.cjs +31 -0
- package/get-shit-done/bin/lib/config.cjs +728 -0
- package/get-shit-done/bin/lib/configuration.cjs +248 -0
- package/get-shit-done/bin/lib/context-utilization.cjs +47 -0
- package/get-shit-done/bin/lib/core.cjs +2121 -0
- package/get-shit-done/bin/lib/decisions.cjs +116 -0
- package/get-shit-done/bin/lib/docs.cjs +270 -0
- package/get-shit-done/bin/lib/drift.cjs +388 -0
- package/get-shit-done/bin/lib/fallow-runner.cjs +109 -0
- package/get-shit-done/bin/lib/frontmatter.cjs +389 -0
- package/get-shit-done/bin/lib/gap-checker.cjs +205 -0
- package/get-shit-done/bin/lib/graphify.cjs +592 -0
- package/get-shit-done/bin/lib/gsd2-import.cjs +514 -0
- package/get-shit-done/bin/lib/init-command-router.cjs +58 -0
- package/get-shit-done/bin/lib/init.cjs +2112 -0
- package/get-shit-done/bin/lib/install-profiles.cjs +603 -0
- package/get-shit-done/bin/lib/installer-migration-authoring.cjs +117 -0
- package/get-shit-done/bin/lib/installer-migration-report.cjs +354 -0
- package/get-shit-done/bin/lib/installer-migrations/000-first-time-baseline.cjs +220 -0
- package/get-shit-done/bin/lib/installer-migrations/001-legacy-orphan-files.cjs +41 -0
- package/get-shit-done/bin/lib/installer-migrations/002-codex-legacy-hooks-json.cjs +80 -0
- package/get-shit-done/bin/lib/installer-migrations.cjs +778 -0
- package/get-shit-done/bin/lib/intel.cjs +708 -0
- package/get-shit-done/bin/lib/learnings.cjs +421 -0
- package/get-shit-done/bin/lib/milestone.cjs +314 -0
- package/get-shit-done/bin/lib/model-catalog.cjs +212 -0
- package/get-shit-done/bin/lib/model-profiles.cjs +31 -0
- package/get-shit-done/bin/lib/observability/event.cjs +82 -0
- package/get-shit-done/bin/lib/observability/logger.cjs +174 -0
- package/get-shit-done/bin/lib/observability/redaction.cjs +50 -0
- package/get-shit-done/bin/lib/package-identity.cjs +31 -0
- package/get-shit-done/bin/lib/phase-command-router.cjs +191 -0
- package/get-shit-done/bin/lib/phase-lifecycle.cjs +80 -0
- package/get-shit-done/bin/lib/phase.cjs +1607 -0
- package/get-shit-done/bin/lib/phases-command-router.cjs +39 -0
- package/get-shit-done/bin/lib/plan-scan.cjs +97 -0
- package/get-shit-done/bin/lib/planning-workspace.cjs +238 -0
- package/get-shit-done/bin/lib/profile-output.cjs +1141 -0
- package/get-shit-done/bin/lib/profile-pipeline.cjs +539 -0
- package/get-shit-done/bin/lib/project-root.cjs +112 -0
- package/get-shit-done/bin/lib/prompt-budget.cjs +399 -0
- package/get-shit-done/bin/lib/review-reviewer-selection.cjs +125 -0
- package/get-shit-done/bin/lib/roadmap-command-router.cjs +28 -0
- package/get-shit-done/bin/lib/roadmap.cjs +650 -0
- package/get-shit-done/bin/lib/runtime-artifact-layout.cjs +301 -0
- package/get-shit-done/bin/lib/runtime-homes.cjs +222 -0
- package/get-shit-done/bin/lib/runtime-name-policy.cjs +83 -0
- package/get-shit-done/bin/lib/runtime-slash.cjs +112 -0
- package/get-shit-done/bin/lib/schema-detect.cjs +165 -0
- package/get-shit-done/bin/lib/secrets.cjs +32 -0
- package/get-shit-done/bin/lib/security.cjs +600 -0
- package/get-shit-done/bin/lib/semver-compare.cjs +35 -0
- package/get-shit-done/bin/lib/shell-command-projection.cjs +500 -0
- package/get-shit-done/bin/lib/state-command-router.cjs +252 -0
- package/get-shit-done/bin/lib/state-document.cjs +263 -0
- package/get-shit-done/bin/lib/state.cjs +2038 -0
- package/get-shit-done/bin/lib/surface.cjs +470 -0
- package/get-shit-done/bin/lib/task-command-router.cjs +81 -0
- package/get-shit-done/bin/lib/template.cjs +228 -0
- package/get-shit-done/bin/lib/uat.cjs +289 -0
- package/get-shit-done/bin/lib/update-context.cjs +209 -0
- package/get-shit-done/bin/lib/validate-command-router.cjs +83 -0
- package/get-shit-done/bin/lib/validate.cjs +92 -0
- package/get-shit-done/bin/lib/verify-command-router.cjs +40 -0
- package/get-shit-done/bin/lib/verify.cjs +1511 -0
- package/get-shit-done/bin/lib/workstream-inventory-builder.cjs +74 -0
- package/get-shit-done/bin/lib/workstream-inventory.cjs +146 -0
- package/get-shit-done/bin/lib/workstream-name-policy.cjs +94 -0
- package/get-shit-done/bin/lib/workstream.cjs +389 -0
- package/get-shit-done/bin/lib/worktree-safety.cjs +985 -0
- package/get-shit-done/bin/shared/config-defaults.manifest.json +97 -0
- package/get-shit-done/bin/shared/config-schema.manifest.json +175 -0
- package/get-shit-done/bin/shared/model-catalog.json +122 -0
- package/get-shit-done/bin/shared/runtime-aliases.manifest.json +75 -0
- package/get-shit-done/bin/verify-reapply-patches.cjs +352 -0
- package/get-shit-done/contexts/dev.md +21 -0
- package/get-shit-done/contexts/research.md +22 -0
- package/get-shit-done/contexts/review.md +23 -0
- package/get-shit-done/references/agent-contracts.md +79 -0
- package/get-shit-done/references/ai-evals.md +156 -0
- package/get-shit-done/references/ai-frameworks.md +186 -0
- package/get-shit-done/references/artifact-types.md +131 -0
- package/get-shit-done/references/autonomous-smart-discuss.md +277 -0
- package/get-shit-done/references/checkpoints.md +814 -0
- package/get-shit-done/references/common-bug-patterns.md +114 -0
- package/get-shit-done/references/context-budget.md +85 -0
- package/get-shit-done/references/continuation-format.md +253 -0
- package/get-shit-done/references/debugger-philosophy.md +76 -0
- package/get-shit-done/references/decimal-phase-calculation.md +64 -0
- package/get-shit-done/references/doc-conflict-engine.md +91 -0
- package/get-shit-done/references/domain-probes.md +125 -0
- package/get-shit-done/references/execute-mvp-tdd.md +81 -0
- package/get-shit-done/references/executor-examples.md +110 -0
- package/get-shit-done/references/few-shot-examples/plan-checker.md +73 -0
- package/get-shit-done/references/few-shot-examples/verifier.md +109 -0
- package/get-shit-done/references/gate-prompts.md +100 -0
- package/get-shit-done/references/gates.md +70 -0
- package/get-shit-done/references/git-integration.md +298 -0
- package/get-shit-done/references/git-planning-commit.md +40 -0
- package/get-shit-done/references/ios-scaffold.md +123 -0
- package/get-shit-done/references/mandatory-initial-read.md +2 -0
- package/get-shit-done/references/model-profile-resolution.md +38 -0
- package/get-shit-done/references/model-profiles.md +245 -0
- package/get-shit-done/references/mvp-concepts.md +49 -0
- package/get-shit-done/references/phase-argument-parsing.md +61 -0
- package/get-shit-done/references/planner-antipatterns.md +89 -0
- package/get-shit-done/references/planner-chunked.md +49 -0
- package/get-shit-done/references/planner-gap-closure.md +62 -0
- package/get-shit-done/references/planner-graphify-auto-update.md +67 -0
- package/get-shit-done/references/planner-human-verify-mode.md +57 -0
- package/get-shit-done/references/planner-interface-context.md +62 -0
- package/get-shit-done/references/planner-mvp-mode.md +53 -0
- package/get-shit-done/references/planner-reviews.md +39 -0
- package/get-shit-done/references/planner-revision.md +87 -0
- package/get-shit-done/references/planner-source-audit.md +73 -0
- package/get-shit-done/references/planning-config.md +471 -0
- package/get-shit-done/references/project-skills-discovery.md +19 -0
- package/get-shit-done/references/questioning.md +162 -0
- package/get-shit-done/references/revision-loop.md +97 -0
- package/get-shit-done/references/scout-codebase.md +51 -0
- package/get-shit-done/references/skeleton-template.md +48 -0
- package/get-shit-done/references/sketch-interactivity.md +41 -0
- package/get-shit-done/references/sketch-theme-system.md +94 -0
- package/get-shit-done/references/sketch-tooling.md +45 -0
- package/get-shit-done/references/sketch-variant-patterns.md +81 -0
- package/get-shit-done/references/spidr-splitting.md +69 -0
- package/get-shit-done/references/tdd.md +330 -0
- package/get-shit-done/references/thinking-models-debug.md +44 -0
- package/get-shit-done/references/thinking-models-execution.md +50 -0
- package/get-shit-done/references/thinking-models-planning.md +62 -0
- package/get-shit-done/references/thinking-models-research.md +50 -0
- package/get-shit-done/references/thinking-models-verification.md +55 -0
- package/get-shit-done/references/thinking-partner.md +96 -0
- package/get-shit-done/references/ui-brand.md +160 -0
- package/get-shit-done/references/universal-anti-patterns.md +63 -0
- package/get-shit-done/references/user-profiling.md +681 -0
- package/get-shit-done/references/user-story-template.md +58 -0
- package/get-shit-done/references/verification-overrides.md +227 -0
- package/get-shit-done/references/verification-patterns.md +612 -0
- package/get-shit-done/references/verify-mvp-mode.md +85 -0
- package/get-shit-done/references/workstream-flag.md +111 -0
- package/get-shit-done/references/worktree-path-safety.md +89 -0
- package/get-shit-done/templates/AI-SPEC.md +246 -0
- package/get-shit-done/templates/DEBUG.md +169 -0
- package/get-shit-done/templates/README.md +77 -0
- package/get-shit-done/templates/SECURITY.md +61 -0
- package/get-shit-done/templates/UAT.md +265 -0
- package/get-shit-done/templates/UI-SPEC.md +100 -0
- package/get-shit-done/templates/VALIDATION.md +76 -0
- package/get-shit-done/templates/claude-md.md +145 -0
- package/get-shit-done/templates/codebase/architecture.md +255 -0
- package/get-shit-done/templates/codebase/concerns.md +310 -0
- package/get-shit-done/templates/codebase/conventions.md +307 -0
- package/get-shit-done/templates/codebase/integrations.md +280 -0
- package/get-shit-done/templates/codebase/stack.md +186 -0
- package/get-shit-done/templates/codebase/structure.md +285 -0
- package/get-shit-done/templates/codebase/testing.md +480 -0
- package/get-shit-done/templates/config.json +62 -0
- package/get-shit-done/templates/context.md +352 -0
- package/get-shit-done/templates/continue-here.md +78 -0
- package/get-shit-done/templates/copilot-instructions.md +7 -0
- package/get-shit-done/templates/debug-subagent-prompt.md +91 -0
- package/get-shit-done/templates/dev-preferences.md +21 -0
- package/get-shit-done/templates/discovery.md +146 -0
- package/get-shit-done/templates/discussion-log.md +63 -0
- package/get-shit-done/templates/milestone-archive.md +123 -0
- package/get-shit-done/templates/milestone.md +115 -0
- package/get-shit-done/templates/phase-prompt.md +610 -0
- package/get-shit-done/templates/planner-subagent-prompt.md +117 -0
- package/get-shit-done/templates/project.md +186 -0
- package/get-shit-done/templates/requirements.md +231 -0
- package/get-shit-done/templates/research-project/ARCHITECTURE.md +204 -0
- package/get-shit-done/templates/research-project/FEATURES.md +147 -0
- package/get-shit-done/templates/research-project/PITFALLS.md +200 -0
- package/get-shit-done/templates/research-project/STACK.md +120 -0
- package/get-shit-done/templates/research-project/SUMMARY.md +170 -0
- package/get-shit-done/templates/research.md +592 -0
- package/get-shit-done/templates/retrospective.md +54 -0
- package/get-shit-done/templates/roadmap.md +202 -0
- package/get-shit-done/templates/spec.md +307 -0
- package/get-shit-done/templates/state.md +195 -0
- package/get-shit-done/templates/summary-complex.md +59 -0
- package/get-shit-done/templates/summary-minimal.md +41 -0
- package/get-shit-done/templates/summary-standard.md +48 -0
- package/get-shit-done/templates/summary.md +248 -0
- package/get-shit-done/templates/user-profile.md +146 -0
- package/get-shit-done/templates/user-setup.md +311 -0
- package/get-shit-done/templates/verification-report.md +322 -0
- package/get-shit-done/workflows/_runtime-launcher.snippet.sh +1 -0
- package/get-shit-done/workflows/add-backlog.md +91 -0
- package/get-shit-done/workflows/add-phase.md +113 -0
- package/get-shit-done/workflows/add-tests.md +355 -0
- package/get-shit-done/workflows/add-todo.md +161 -0
- package/get-shit-done/workflows/ai-integration-phase.md +295 -0
- package/get-shit-done/workflows/analyze-dependencies.md +96 -0
- package/get-shit-done/workflows/audit-fix.md +178 -0
- package/get-shit-done/workflows/audit-milestone.md +358 -0
- package/get-shit-done/workflows/audit-uat.md +110 -0
- package/get-shit-done/workflows/autonomous.md +795 -0
- package/get-shit-done/workflows/check-todos.md +180 -0
- package/get-shit-done/workflows/cleanup.md +155 -0
- package/get-shit-done/workflows/code-review-fix.md +502 -0
- package/get-shit-done/workflows/code-review.md +656 -0
- package/get-shit-done/workflows/complete-milestone.md +855 -0
- package/get-shit-done/workflows/debug.md +232 -0
- package/get-shit-done/workflows/diagnose-issues.md +241 -0
- package/get-shit-done/workflows/discovery-phase.md +291 -0
- package/get-shit-done/workflows/discuss-phase/modes/advisor.md +176 -0
- package/get-shit-done/workflows/discuss-phase/modes/all.md +28 -0
- package/get-shit-done/workflows/discuss-phase/modes/analyze.md +44 -0
- package/get-shit-done/workflows/discuss-phase/modes/auto.md +57 -0
- package/get-shit-done/workflows/discuss-phase/modes/batch.md +52 -0
- package/get-shit-done/workflows/discuss-phase/modes/chain.md +98 -0
- package/get-shit-done/workflows/discuss-phase/modes/default.md +141 -0
- package/get-shit-done/workflows/discuss-phase/modes/power.md +44 -0
- package/get-shit-done/workflows/discuss-phase/modes/text.md +55 -0
- package/get-shit-done/workflows/discuss-phase/templates/checkpoint.json +18 -0
- package/get-shit-done/workflows/discuss-phase/templates/context.md +136 -0
- package/get-shit-done/workflows/discuss-phase/templates/discussion-log.md +50 -0
- package/get-shit-done/workflows/discuss-phase-assumptions.md +675 -0
- package/get-shit-done/workflows/discuss-phase-power.md +291 -0
- package/get-shit-done/workflows/discuss-phase.md +499 -0
- package/get-shit-done/workflows/do.md +111 -0
- package/get-shit-done/workflows/docs-update.md +1162 -0
- package/get-shit-done/workflows/edit-phase.md +295 -0
- package/get-shit-done/workflows/eval-review.md +156 -0
- package/get-shit-done/workflows/execute-phase/steps/codebase-drift-gate.md +82 -0
- package/get-shit-done/workflows/execute-phase/steps/per-plan-worktree-gate.md +94 -0
- package/get-shit-done/workflows/execute-phase/steps/post-merge-gate.md +117 -0
- package/get-shit-done/workflows/execute-phase.md +1709 -0
- package/get-shit-done/workflows/execute-plan.md +526 -0
- package/get-shit-done/workflows/explore.md +144 -0
- package/get-shit-done/workflows/extract-learnings.md +243 -0
- package/get-shit-done/workflows/fast.md +124 -0
- package/get-shit-done/workflows/forensics.md +279 -0
- package/get-shit-done/workflows/graduation.md +196 -0
- package/get-shit-done/workflows/health.md +224 -0
- package/get-shit-done/workflows/help/modes/brief.md +22 -0
- package/get-shit-done/workflows/help/modes/default.md +50 -0
- package/get-shit-done/workflows/help/modes/full.md +784 -0
- package/get-shit-done/workflows/help/modes/topic.md +74 -0
- package/get-shit-done/workflows/help.md +24 -0
- package/get-shit-done/workflows/import.md +254 -0
- package/get-shit-done/workflows/inbox.md +387 -0
- package/get-shit-done/workflows/ingest-docs.md +339 -0
- package/get-shit-done/workflows/insert-phase.md +152 -0
- package/get-shit-done/workflows/list-phase-assumptions.md +178 -0
- package/get-shit-done/workflows/list-workspaces.md +57 -0
- package/get-shit-done/workflows/manager.md +393 -0
- package/get-shit-done/workflows/map-codebase.md +444 -0
- package/get-shit-done/workflows/milestone-summary.md +224 -0
- package/get-shit-done/workflows/mvp-phase.md +222 -0
- package/get-shit-done/workflows/new-milestone.md +635 -0
- package/get-shit-done/workflows/new-project.md +1555 -0
- package/get-shit-done/workflows/new-workspace.md +240 -0
- package/get-shit-done/workflows/next.md +299 -0
- package/get-shit-done/workflows/node-repair.md +92 -0
- package/get-shit-done/workflows/note.md +158 -0
- package/get-shit-done/workflows/pause-work.md +244 -0
- package/get-shit-done/workflows/plan-milestone-gaps.md +281 -0
- package/get-shit-done/workflows/plan-phase.md +1809 -0
- package/get-shit-done/workflows/plan-review-convergence.md +346 -0
- package/get-shit-done/workflows/plant-seed.md +230 -0
- package/get-shit-done/workflows/pr-branch.md +157 -0
- package/get-shit-done/workflows/profile-user.md +453 -0
- package/get-shit-done/workflows/progress.md +699 -0
- package/get-shit-done/workflows/quick.md +1039 -0
- package/get-shit-done/workflows/reapply-patches.md +426 -0
- package/get-shit-done/workflows/remove-phase.md +156 -0
- package/get-shit-done/workflows/remove-workspace.md +108 -0
- package/get-shit-done/workflows/resume-project.md +332 -0
- package/get-shit-done/workflows/review.md +623 -0
- package/get-shit-done/workflows/scan.md +105 -0
- package/get-shit-done/workflows/secure-phase.md +180 -0
- package/get-shit-done/workflows/session-report.md +146 -0
- package/get-shit-done/workflows/settings-advanced.md +620 -0
- package/get-shit-done/workflows/settings-integrations.md +312 -0
- package/get-shit-done/workflows/settings.md +552 -0
- package/get-shit-done/workflows/ship.md +356 -0
- package/get-shit-done/workflows/sketch-wrap-up.md +286 -0
- package/get-shit-done/workflows/sketch.md +361 -0
- package/get-shit-done/workflows/spec-phase.md +262 -0
- package/get-shit-done/workflows/spike-wrap-up.md +307 -0
- package/get-shit-done/workflows/spike.md +453 -0
- package/get-shit-done/workflows/stats.md +80 -0
- package/get-shit-done/workflows/sync-skills.md +182 -0
- package/get-shit-done/workflows/thread.md +222 -0
- package/get-shit-done/workflows/transition.md +694 -0
- package/get-shit-done/workflows/ui-phase.md +328 -0
- package/get-shit-done/workflows/ui-review.md +193 -0
- package/get-shit-done/workflows/ultraplan-phase.md +199 -0
- package/get-shit-done/workflows/undo.md +314 -0
- package/get-shit-done/workflows/update.md +443 -0
- package/get-shit-done/workflows/validate-phase.md +179 -0
- package/get-shit-done/workflows/verify-phase.md +544 -0
- package/get-shit-done/workflows/verify-work.md +781 -0
- package/hooks/dist/gsd-check-update-worker.js +95 -0
- package/hooks/dist/gsd-check-update.js +64 -0
- package/hooks/dist/gsd-context-monitor.js +195 -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 +548 -0
- package/hooks/dist/gsd-update-banner.js +134 -0
- package/hooks/dist/gsd-validate-commit.sh +57 -0
- package/hooks/dist/gsd-workflow-guard.js +166 -0
- package/hooks/dist/lib/git-cmd.js +150 -0
- package/hooks/dist/lib/gsd-graphify-rebuild.sh +65 -0
- package/hooks/gsd-check-update-worker.js +95 -0
- package/hooks/gsd-check-update.js +64 -0
- package/hooks/gsd-context-monitor.js +195 -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 +548 -0
- package/hooks/gsd-update-banner.js +134 -0
- package/hooks/gsd-validate-commit.sh +57 -0
- package/hooks/gsd-workflow-guard.js +166 -0
- package/hooks/lib/git-cmd.js +150 -0
- package/hooks/lib/gsd-graphify-rebuild.sh +65 -0
- package/hooks/managed-hooks-registry.cjs +34 -0
- package/package.json +102 -0
- package/scripts/affected-tests-lib.cjs +541 -0
- package/scripts/audit-workflow-script-paths.cjs +73 -0
- package/scripts/base64-scan.sh +339 -0
- package/scripts/build-hooks.js +236 -0
- package/scripts/changeset/README.md +129 -0
- package/scripts/changeset/cli.cjs +392 -0
- package/scripts/changeset/github-release-notes.cjs +199 -0
- package/scripts/changeset/lint.cjs +110 -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 +108 -0
- package/scripts/check-env.cjs +302 -0
- package/scripts/check-npm-integrity.cjs +209 -0
- package/scripts/ci-guard-runner.cjs +16 -0
- package/scripts/ci-prepare-test-scope.cjs +46 -0
- package/scripts/ci-rebase-check.cjs +85 -0
- package/scripts/ci-test-scope.cjs +302 -0
- package/scripts/command-contract-helpers.cjs +64 -0
- package/scripts/diff-touches-shipped-paths.cjs +147 -0
- package/scripts/fix-slash-commands.cjs +147 -0
- package/scripts/gen-inventory-manifest.cjs +109 -0
- package/scripts/generate-package-identity.cjs +104 -0
- package/scripts/lint-command-contract.cjs +108 -0
- package/scripts/lint-descriptions.cjs +83 -0
- package/scripts/lint-docs-required.cjs +222 -0
- package/scripts/lint-no-source-grep-extras.cjs +81 -0
- package/scripts/lint-no-source-grep.cjs +174 -0
- package/scripts/lint-package-identity-drift.cjs +141 -0
- package/scripts/lint-pr-check-project-dir.cjs +98 -0
- package/scripts/lint-shared-module-handsync.cjs +388 -0
- package/scripts/lint-shell-command-projection-drift.cjs +57 -0
- package/scripts/lint-skill-deps.cjs +180 -0
- package/scripts/lint-test-file-count.allowlist.json +36 -0
- package/scripts/lint-test-file-count.cjs +190 -0
- package/scripts/pr-template-policy.cjs +268 -0
- package/scripts/prompt-injection-scan.sh +203 -0
- package/scripts/release-tarball-smoke.cjs +627 -0
- package/scripts/run-affected-tests.cjs +6 -0
- package/scripts/run-cross-platform-tests.cjs +63 -0
- package/scripts/run-tests.cjs +282 -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/shared-module-handsync-allowlist.json +183 -0
- package/scripts/strip-prose-atrefs.cjs +106 -0
- package/scripts/sync-rulesets.sh +34 -0
- package/scripts/sync-runtime-launcher.cjs +402 -0
- package/scripts/test-failure-reasons.cjs +34 -0
- package/scripts/workflow-policy.cjs +450 -0
|
@@ -0,0 +1,502 @@
|
|
|
1
|
+
<purpose>
|
|
2
|
+
Auto-fix issues from REVIEW.md. Validates phase, checks config gate, verifies REVIEW.md exists and has fixable issues, spawns gsd-code-fixer agent, handles --auto iteration loop (capped at 3), commits REVIEW-FIX.md once at the end, and presents results.
|
|
3
|
+
</purpose>
|
|
4
|
+
|
|
5
|
+
<required_reading>
|
|
6
|
+
Read all files referenced by the invoking prompt's execution_context before starting.
|
|
7
|
+
</required_reading>
|
|
8
|
+
|
|
9
|
+
<available_agent_types>
|
|
10
|
+
- gsd-code-fixer: Applies fixes to code review findings
|
|
11
|
+
- gsd-code-reviewer: Reviews source files for bugs and issues
|
|
12
|
+
</available_agent_types>
|
|
13
|
+
|
|
14
|
+
<process>
|
|
15
|
+
|
|
16
|
+
<step name="initialize">
|
|
17
|
+
Parse arguments and load project state:
|
|
18
|
+
|
|
19
|
+
```bash
|
|
20
|
+
_GSD_SHIM_NAME="gsd-tools.cjs"; _GSD_RUNTIME_ROOT="${RUNTIME_DIR:-$(git rev-parse --show-toplevel 2>/dev/null || pwd)}"; GSD_TOOLS="${_GSD_RUNTIME_ROOT}/get-shit-done/bin/${_GSD_SHIM_NAME}"; if [ -f "$GSD_TOOLS" ]; then gsd_run() { node "$GSD_TOOLS" "$@"; }; elif [ -f "${_GSD_RUNTIME_ROOT}/.claude/get-shit-done/bin/${_GSD_SHIM_NAME}" ]; then GSD_TOOLS="${_GSD_RUNTIME_ROOT}/.claude/get-shit-done/bin/${_GSD_SHIM_NAME}"; gsd_run() { node "$GSD_TOOLS" "$@"; }; elif command -v gsd-tools >/dev/null 2>&1; then GSD_TOOLS="$(command -v gsd-tools)"; gsd_run() { "$GSD_TOOLS" "$@"; }; elif [ -f "$HOME/.claude/get-shit-done/bin/${_GSD_SHIM_NAME}" ]; then GSD_TOOLS="$HOME/.claude/get-shit-done/bin/${_GSD_SHIM_NAME}"; gsd_run() { node "$GSD_TOOLS" "$@"; }; else echo "ERROR: gsd-tools.cjs not found at $GSD_TOOLS and gsd-tools is not on PATH. Run: npx -y @opengsd/gsd-core@latest --claude --local" >&2; exit 1; fi
|
|
21
|
+
PHASE_ARG="${1}"
|
|
22
|
+
INIT=$(gsd_run query init.phase-op "${PHASE_ARG}")
|
|
23
|
+
if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
Parse from init JSON: `phase_found`, `phase_dir`, `phase_number`, `phase_name`, `padded_phase`, `commit_docs`.
|
|
27
|
+
|
|
28
|
+
**Input sanitization (defense-in-depth):**
|
|
29
|
+
```bash
|
|
30
|
+
# Validate PADDED_PHASE contains only digits and optional dot (e.g., "02", "03.1")
|
|
31
|
+
if ! [[ "$PADDED_PHASE" =~ ^[0-9]+(\.[0-9]+)?$ ]]; then
|
|
32
|
+
echo "Error: Invalid phase number format: '${PADDED_PHASE}'. Expected digits (e.g., 02, 03.1)."
|
|
33
|
+
# Exit workflow
|
|
34
|
+
fi
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
**Phase validation (before config gate):**
|
|
38
|
+
If `phase_found` is false, report error and exit:
|
|
39
|
+
```
|
|
40
|
+
Error: Phase ${PHASE_ARG} not found. Run /gsd:progress to see available phases.
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
This runs BEFORE config gate check so user errors are surfaced immediately regardless of config state.
|
|
44
|
+
|
|
45
|
+
Parse optional flags from $ARGUMENTS:
|
|
46
|
+
|
|
47
|
+
```bash
|
|
48
|
+
FIX_ALL=false
|
|
49
|
+
AUTO_MODE=false
|
|
50
|
+
for arg in "$@"; do
|
|
51
|
+
if [[ "$arg" == "--all" ]]; then FIX_ALL=true; fi
|
|
52
|
+
if [[ "$arg" == "--auto" ]]; then AUTO_MODE=true; fi
|
|
53
|
+
done
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
Compute scope variable:
|
|
57
|
+
|
|
58
|
+
```bash
|
|
59
|
+
if [ "$FIX_ALL" = "true" ]; then
|
|
60
|
+
FIX_SCOPE="all"
|
|
61
|
+
else
|
|
62
|
+
FIX_SCOPE="critical_warning"
|
|
63
|
+
fi
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
Compute review and fix report paths:
|
|
67
|
+
|
|
68
|
+
```bash
|
|
69
|
+
REVIEW_PATH="${PHASE_DIR}/${PADDED_PHASE}-REVIEW.md"
|
|
70
|
+
FIX_REPORT_PATH="${PHASE_DIR}/${PADDED_PHASE}-REVIEW-FIX.md"
|
|
71
|
+
```
|
|
72
|
+
</step>
|
|
73
|
+
|
|
74
|
+
<step name="check_config_gate">
|
|
75
|
+
Check if code review is enabled via config:
|
|
76
|
+
|
|
77
|
+
```bash
|
|
78
|
+
CODE_REVIEW_ENABLED=$(gsd_run query config-get workflow.code_review 2>/dev/null || echo "true")
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
If CODE_REVIEW_ENABLED is "false":
|
|
82
|
+
```
|
|
83
|
+
Code review fix skipped (workflow.code_review=false in config)
|
|
84
|
+
```
|
|
85
|
+
Exit workflow.
|
|
86
|
+
|
|
87
|
+
Default is true — only skip on explicit false. This check runs AFTER phase validation so invalid phase errors are shown first.
|
|
88
|
+
|
|
89
|
+
Note: This reuses the `workflow.code_review` config key rather than introducing a separate `workflow.code_review_fix` key. Rationale: fixes are meaningless without review, so a single toggle makes sense. If independent control is needed later, a separate key can be added in v2.
|
|
90
|
+
</step>
|
|
91
|
+
|
|
92
|
+
<step name="check_review_exists">
|
|
93
|
+
Verify that REVIEW.md exists:
|
|
94
|
+
|
|
95
|
+
```bash
|
|
96
|
+
if [ ! -f "${REVIEW_PATH}" ]; then
|
|
97
|
+
echo "Error: No REVIEW.md found for Phase ${PHASE_ARG}. Run /gsd:code-review ${PHASE_ARG} first."
|
|
98
|
+
exit 1
|
|
99
|
+
fi
|
|
100
|
+
```
|
|
101
|
+
|
|
102
|
+
Do NOT auto-run code-review. Require explicit user action to ensure review intent is clear.
|
|
103
|
+
</step>
|
|
104
|
+
|
|
105
|
+
<step name="check_review_status">
|
|
106
|
+
Parse REVIEW.md frontmatter to check status and extract context for --auto loop:
|
|
107
|
+
|
|
108
|
+
```bash
|
|
109
|
+
# Parse status field
|
|
110
|
+
REVIEW_STATUS=$(REVIEW_PATH="${REVIEW_PATH}" node -e "
|
|
111
|
+
const fs = require('fs');
|
|
112
|
+
const content = fs.readFileSync(process.env.REVIEW_PATH, 'utf-8');
|
|
113
|
+
const match = content.match(/^---\n([\s\S]*?)\n---/);
|
|
114
|
+
if (match && /status:\s*(\S+)/.test(match[1])) {
|
|
115
|
+
console.log(match[1].match(/status:\s*(\S+)/)[1]);
|
|
116
|
+
} else {
|
|
117
|
+
console.log('unknown');
|
|
118
|
+
}
|
|
119
|
+
" 2>/dev/null)
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
If status is "clean" or "skipped":
|
|
123
|
+
```
|
|
124
|
+
No issues to fix in Phase ${PHASE_ARG} REVIEW.md (status: ${REVIEW_STATUS}).
|
|
125
|
+
```
|
|
126
|
+
Exit workflow.
|
|
127
|
+
|
|
128
|
+
If status is "unknown":
|
|
129
|
+
```
|
|
130
|
+
Warning: Could not parse REVIEW.md status. Proceeding with fix attempt.
|
|
131
|
+
```
|
|
132
|
+
|
|
133
|
+
Extract review depth for --auto re-review:
|
|
134
|
+
|
|
135
|
+
```bash
|
|
136
|
+
REVIEW_DEPTH=$(REVIEW_PATH="${REVIEW_PATH}" node -e "
|
|
137
|
+
const fs = require('fs');
|
|
138
|
+
const content = fs.readFileSync(process.env.REVIEW_PATH, 'utf-8');
|
|
139
|
+
const match = content.match(/^---\n([\s\S]*?)\n---/);
|
|
140
|
+
if (match && /depth:\s*(\S+)/.test(match[1])) {
|
|
141
|
+
console.log(match[1].match(/depth:\s*(\S+)/)[1]);
|
|
142
|
+
} else {
|
|
143
|
+
console.log('standard');
|
|
144
|
+
}
|
|
145
|
+
" 2>/dev/null)
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
Extract original review file list for --auto re-review scope persistence:
|
|
149
|
+
|
|
150
|
+
```bash
|
|
151
|
+
# Extract review file list — portable bash 3.2+ (no mapfile, handles spaces in paths)
|
|
152
|
+
REVIEW_FILES_ARRAY=()
|
|
153
|
+
while IFS= read -r line; do
|
|
154
|
+
[ -n "$line" ] && REVIEW_FILES_ARRAY+=("$line")
|
|
155
|
+
done < <(REVIEW_PATH="${REVIEW_PATH}" node -e "
|
|
156
|
+
const fs = require('fs');
|
|
157
|
+
const content = fs.readFileSync(process.env.REVIEW_PATH, 'utf-8');
|
|
158
|
+
const match = content.match(/^---\n([\s\S]*?)\n---/);
|
|
159
|
+
if (match) {
|
|
160
|
+
const fm = match[1];
|
|
161
|
+
// Try YAML array format: files_reviewed_list: [file1, file2]
|
|
162
|
+
const bracketMatch = fm.match(/files_reviewed_list:\s*\[([^\]]+)\]/);
|
|
163
|
+
if (bracketMatch) {
|
|
164
|
+
bracketMatch[1].split(',').map(f => f.trim()).filter(Boolean).forEach(f => console.log(f));
|
|
165
|
+
} else {
|
|
166
|
+
// Try YAML list format: files_reviewed_list:\n - file1\n - file2
|
|
167
|
+
let inList = false;
|
|
168
|
+
for (const line of fm.split('\n')) {
|
|
169
|
+
if (/files_reviewed_list:/.test(line)) { inList = true; continue; }
|
|
170
|
+
if (inList && /^\s+-\s+(.+)/.test(line)) { console.log(line.match(/^\s+-\s+(.+)/)[1].trim()); }
|
|
171
|
+
else if (inList && /^\S/.test(line)) { break; }
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
" 2>/dev/null)
|
|
176
|
+
```
|
|
177
|
+
|
|
178
|
+
If REVIEW.md contains a `files_reviewed_list` frontmatter field, use that as the re-review scope. If not present, fall back to re-reviewing the full phase (same behavior as initial code-review).
|
|
179
|
+
</step>
|
|
180
|
+
|
|
181
|
+
<step name="spawn_fixer">
|
|
182
|
+
Spawn the gsd-code-fixer agent with config:
|
|
183
|
+
|
|
184
|
+
```bash
|
|
185
|
+
# Build config for agent
|
|
186
|
+
echo "Applying fixes from ${REVIEW_PATH}..."
|
|
187
|
+
echo "Fix scope: ${FIX_SCOPE}"
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
Use Agent() to spawn agent:
|
|
191
|
+
|
|
192
|
+
```text
|
|
193
|
+
Agent(subagent_type="gsd-code-fixer", prompt="
|
|
194
|
+
<files_to_read>
|
|
195
|
+
${REVIEW_PATH}
|
|
196
|
+
</files_to_read>
|
|
197
|
+
|
|
198
|
+
<config>
|
|
199
|
+
phase_dir: ${PHASE_DIR}
|
|
200
|
+
padded_phase: ${PADDED_PHASE}
|
|
201
|
+
review_path: ${REVIEW_PATH}
|
|
202
|
+
fix_scope: ${FIX_SCOPE}
|
|
203
|
+
fix_report_path: ${FIX_REPORT_PATH}
|
|
204
|
+
iteration: 1
|
|
205
|
+
</config>
|
|
206
|
+
|
|
207
|
+
Read REVIEW.md findings, apply fixes, commit each atomically, write REVIEW-FIX.md. Do NOT commit REVIEW-FIX.md (orchestrator handles that).
|
|
208
|
+
")
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
> **ORCHESTRATOR RULE — CODEX RUNTIME**: After calling Agent() above, stop working on this task immediately. Do not read more files, edit code, or run tests related to this task while the subagent is active. Wait for the subagent to return its result. This prevents duplicate work, conflicting edits, and wasted context. Only resume when the subagent result is available.
|
|
212
|
+
|
|
213
|
+
**Agent failure handling:**
|
|
214
|
+
|
|
215
|
+
If Agent() fails:
|
|
216
|
+
```
|
|
217
|
+
Error: Code fix agent failed: ${error_message}
|
|
218
|
+
```
|
|
219
|
+
|
|
220
|
+
Check if FIX_REPORT_PATH exists:
|
|
221
|
+
- If yes: "Partial success — some fixes may have been committed."
|
|
222
|
+
- If no: "No fixes applied."
|
|
223
|
+
|
|
224
|
+
Either way:
|
|
225
|
+
```
|
|
226
|
+
Some fix commits may already exist in git history — check git log for fix(${PADDED_PHASE}) commits.
|
|
227
|
+
You can retry with /gsd:code-review ${PHASE_ARG} --fix.
|
|
228
|
+
```
|
|
229
|
+
|
|
230
|
+
Exit workflow (skip auto loop).
|
|
231
|
+
</step>
|
|
232
|
+
|
|
233
|
+
<step name="auto_iteration_loop">
|
|
234
|
+
Only runs if AUTO_MODE is true. If AUTO_MODE is false, skip this step entirely.
|
|
235
|
+
|
|
236
|
+
```bash
|
|
237
|
+
if [ "$AUTO_MODE" = "true" ]; then
|
|
238
|
+
# Iteration semantics: the initial fix pass (step 5) is iteration 1.
|
|
239
|
+
# This loop runs iterations 2..MAX_ITERATIONS (re-review + re-fix cycles).
|
|
240
|
+
# Total fix passes = MAX_ITERATIONS. Loop uses -lt (not -le) intentionally.
|
|
241
|
+
ITERATION=1
|
|
242
|
+
MAX_ITERATIONS=3
|
|
243
|
+
|
|
244
|
+
while [ $ITERATION -lt $MAX_ITERATIONS ]; do
|
|
245
|
+
ITERATION=$((ITERATION + 1))
|
|
246
|
+
|
|
247
|
+
echo ""
|
|
248
|
+
echo "═══════════════════════════════════════════════════════"
|
|
249
|
+
echo " --auto: Starting iteration ${ITERATION}/${MAX_ITERATIONS}"
|
|
250
|
+
echo "═══════════════════════════════════════════════════════"
|
|
251
|
+
echo ""
|
|
252
|
+
|
|
253
|
+
# Re-review using same depth and file scope as original review
|
|
254
|
+
echo "Re-reviewing phase ${PHASE_ARG} at ${REVIEW_DEPTH} depth..."
|
|
255
|
+
|
|
256
|
+
# Backup previous REVIEW.md and REVIEW-FIX.md before overwriting
|
|
257
|
+
if [ -f "${REVIEW_PATH}" ]; then
|
|
258
|
+
cp "${REVIEW_PATH}" "${REVIEW_PATH%.md}.iter${ITERATION}.md" 2>/dev/null || true
|
|
259
|
+
fi
|
|
260
|
+
if [ -f "${FIX_REPORT_PATH}" ]; then
|
|
261
|
+
cp "${FIX_REPORT_PATH}" "${FIX_REPORT_PATH%.md}.iter${ITERATION}.md" 2>/dev/null || true
|
|
262
|
+
fi
|
|
263
|
+
|
|
264
|
+
# If original review had explicit file list, pass it safely to re-review agent
|
|
265
|
+
FILES_CONFIG=""
|
|
266
|
+
if [ ${#REVIEW_FILES_ARRAY[@]} -gt 0 ]; then
|
|
267
|
+
FILES_CONFIG="files:"
|
|
268
|
+
for f in "${REVIEW_FILES_ARRAY[@]}"; do
|
|
269
|
+
FILES_CONFIG="${FILES_CONFIG}
|
|
270
|
+
- ${f}"
|
|
271
|
+
done
|
|
272
|
+
fi
|
|
273
|
+
|
|
274
|
+
# Spawn gsd-code-reviewer agent to re-review
|
|
275
|
+
# (This overwrites REVIEW_PATH with latest review state)
|
|
276
|
+
Agent(subagent_type="gsd-code-reviewer", prompt="
|
|
277
|
+
<config>
|
|
278
|
+
depth: ${REVIEW_DEPTH}
|
|
279
|
+
phase_dir: ${PHASE_DIR}
|
|
280
|
+
review_path: ${REVIEW_PATH}
|
|
281
|
+
${FILES_CONFIG}
|
|
282
|
+
</config>
|
|
283
|
+
|
|
284
|
+
Re-review the phase at ${REVIEW_DEPTH} depth. Write findings to ${REVIEW_PATH}.
|
|
285
|
+
Do NOT commit the output — the orchestrator handles that.
|
|
286
|
+
")
|
|
287
|
+
# ORCHESTRATOR RULE — CODEX RUNTIME: After calling Agent() above, stop working on this task immediately. Do not read more files, edit code, or run tests related to this task while the subagent is active. Wait for the subagent to return its result before proceeding.
|
|
288
|
+
|
|
289
|
+
# Check new REVIEW.md status
|
|
290
|
+
NEW_STATUS=$(REVIEW_PATH="${REVIEW_PATH}" node -e "
|
|
291
|
+
const fs = require('fs');
|
|
292
|
+
const content = fs.readFileSync(process.env.REVIEW_PATH, 'utf-8');
|
|
293
|
+
const match = content.match(/^---\n([\s\S]*?)\n---/);
|
|
294
|
+
if (match && /status:\s*(\S+)/.test(match[1])) {
|
|
295
|
+
console.log(match[1].match(/status:\s*(\S+)/)[1]);
|
|
296
|
+
} else {
|
|
297
|
+
console.log('unknown');
|
|
298
|
+
}
|
|
299
|
+
" 2>/dev/null)
|
|
300
|
+
|
|
301
|
+
if [ "$NEW_STATUS" = "clean" ]; then
|
|
302
|
+
echo ""
|
|
303
|
+
echo "✓ All issues resolved after iteration ${ITERATION}."
|
|
304
|
+
break
|
|
305
|
+
fi
|
|
306
|
+
|
|
307
|
+
# Still has issues — spawn fixer again
|
|
308
|
+
echo "Issues remain. Applying fixes for iteration ${ITERATION}..."
|
|
309
|
+
|
|
310
|
+
Agent(subagent_type="gsd-code-fixer", prompt="
|
|
311
|
+
<files_to_read>
|
|
312
|
+
${REVIEW_PATH}
|
|
313
|
+
</files_to_read>
|
|
314
|
+
|
|
315
|
+
<config>
|
|
316
|
+
phase_dir: ${PHASE_DIR}
|
|
317
|
+
padded_phase: ${PADDED_PHASE}
|
|
318
|
+
review_path: ${REVIEW_PATH}
|
|
319
|
+
fix_scope: ${FIX_SCOPE}
|
|
320
|
+
fix_report_path: ${FIX_REPORT_PATH}
|
|
321
|
+
iteration: ${ITERATION}
|
|
322
|
+
</config>
|
|
323
|
+
|
|
324
|
+
Read REVIEW.md findings, apply fixes, commit each atomically, write REVIEW-FIX.md (overwrite previous). Do NOT commit REVIEW-FIX.md.
|
|
325
|
+
")
|
|
326
|
+
# ORCHESTRATOR RULE — CODEX RUNTIME: After calling Agent() above, stop working on this task immediately. Do not read more files, edit code, or run tests related to this task while the subagent is active. Wait for the subagent to return its result before proceeding.
|
|
327
|
+
|
|
328
|
+
# Check if fixer succeeded
|
|
329
|
+
if [ ! -f "${FIX_REPORT_PATH}" ]; then
|
|
330
|
+
echo "Warning: Iteration ${ITERATION} fixer failed to produce fix report. Stopping auto-loop."
|
|
331
|
+
break
|
|
332
|
+
fi
|
|
333
|
+
done
|
|
334
|
+
|
|
335
|
+
# After loop completes
|
|
336
|
+
if [ $ITERATION -ge $MAX_ITERATIONS ]; then
|
|
337
|
+
echo ""
|
|
338
|
+
echo "⚠ Reached maximum iterations (${MAX_ITERATIONS}). Remaining issues documented in REVIEW-FIX.md."
|
|
339
|
+
fi
|
|
340
|
+
fi
|
|
341
|
+
```
|
|
342
|
+
|
|
343
|
+
Key design decisions for --auto (addresses ALL review HIGH concerns):
|
|
344
|
+
1. **Re-review scope**: Uses REVIEW_FILES_ARRAY from original REVIEW.md frontmatter, falling back to full phase scope. Scope is NOT lost between iterations. Uses portable while-read loop (bash 3.2+ compatible, handles spaces in paths).
|
|
345
|
+
2. **Artifact semantics**: REVIEW.md is overwritten by each re-review (latest review state). REVIEW-FIX.md is overwritten by each fixer iteration (latest fix state with iteration count). There is ONE final version of each artifact, not per-iteration copies.
|
|
346
|
+
Backup files (.iterN.md) preserve history for post-mortem analysis if iterations degrade.
|
|
347
|
+
3. **Commit timing**: Fix commits happen per-finding inside the agent. REVIEW-FIX.md is NOT committed until step 7 (after ALL iterations complete). Only ONE docs commit for REVIEW-FIX.md, not one per iteration.
|
|
348
|
+
</step>
|
|
349
|
+
|
|
350
|
+
<step name="commit_fix_report">
|
|
351
|
+
After ALL iterations complete (or single pass in non-auto mode), validate and commit REVIEW-FIX.md:
|
|
352
|
+
|
|
353
|
+
```bash
|
|
354
|
+
if [ -f "${FIX_REPORT_PATH}" ]; then
|
|
355
|
+
# Validate REVIEW-FIX.md has valid YAML frontmatter with status field
|
|
356
|
+
HAS_STATUS=$(REVIEW_PATH="${REVIEW_PATH}" node -e "
|
|
357
|
+
const fs = require('fs');
|
|
358
|
+
const content = fs.readFileSync(process.env.FIX_REPORT_PATH, 'utf-8');
|
|
359
|
+
const match = content.match(/^---\n([\s\S]*?)\n---/);
|
|
360
|
+
if (match && /status:/.test(match[1])) { console.log('valid'); } else { console.log('invalid'); }
|
|
361
|
+
" 2>/dev/null)
|
|
362
|
+
|
|
363
|
+
if [ "$HAS_STATUS" = "valid" ]; then
|
|
364
|
+
echo "REVIEW-FIX.md created at ${FIX_REPORT_PATH}"
|
|
365
|
+
|
|
366
|
+
if [ "$COMMIT_DOCS" = "true" ]; then
|
|
367
|
+
gsd_run query commit \
|
|
368
|
+
"docs(${PADDED_PHASE}): add code review fix report" \
|
|
369
|
+
--files "${FIX_REPORT_PATH}"
|
|
370
|
+
fi
|
|
371
|
+
else
|
|
372
|
+
echo "Warning: REVIEW-FIX.md has invalid frontmatter (no status field). Not committing."
|
|
373
|
+
echo "Agent may have produced malformed output. Review manually: ${FIX_REPORT_PATH}"
|
|
374
|
+
fi
|
|
375
|
+
else
|
|
376
|
+
echo "Warning: REVIEW-FIX.md not found at ${FIX_REPORT_PATH}."
|
|
377
|
+
echo "Agent may have failed before writing report."
|
|
378
|
+
echo "Check git log for any fix(${PADDED_PHASE}) commits that were applied."
|
|
379
|
+
fi
|
|
380
|
+
```
|
|
381
|
+
|
|
382
|
+
This commit happens ONCE at the end of the workflow, after all iterations (if --auto) complete. Not per-iteration.
|
|
383
|
+
</step>
|
|
384
|
+
|
|
385
|
+
<step name="present_results">
|
|
386
|
+
Parse REVIEW-FIX.md frontmatter and present formatted summary to user.
|
|
387
|
+
|
|
388
|
+
First check if fix report exists:
|
|
389
|
+
|
|
390
|
+
```bash
|
|
391
|
+
if [ ! -f "${FIX_REPORT_PATH}" ]; then
|
|
392
|
+
echo ""
|
|
393
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
394
|
+
echo ""
|
|
395
|
+
echo " ⚠ No fix report generated"
|
|
396
|
+
echo ""
|
|
397
|
+
echo "───────────────────────────────────────────────────────────────"
|
|
398
|
+
echo ""
|
|
399
|
+
echo "The fixer agent may have failed before completing."
|
|
400
|
+
echo "Check git log for any fix(${PADDED_PHASE}) commits."
|
|
401
|
+
echo ""
|
|
402
|
+
echo "Retry: /gsd:code-review ${PHASE_ARG} --fix"
|
|
403
|
+
echo ""
|
|
404
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
405
|
+
exit 1
|
|
406
|
+
fi
|
|
407
|
+
```
|
|
408
|
+
|
|
409
|
+
Extract frontmatter fields:
|
|
410
|
+
|
|
411
|
+
```bash
|
|
412
|
+
# Extract only the YAML frontmatter block (between first two --- lines)
|
|
413
|
+
FIX_FRONTMATTER=$(REVIEW_PATH="${REVIEW_PATH}" node -e "
|
|
414
|
+
const fs = require('fs');
|
|
415
|
+
const content = fs.readFileSync(process.env.FIX_REPORT_PATH, 'utf-8');
|
|
416
|
+
const match = content.match(/^---\n([\s\S]*?)\n---/);
|
|
417
|
+
if (match) process.stdout.write(match[1]);
|
|
418
|
+
" 2>/dev/null)
|
|
419
|
+
|
|
420
|
+
# Parse fields from frontmatter only (not full file)
|
|
421
|
+
FIX_STATUS=$(echo "$FIX_FRONTMATTER" | grep "^status:" | cut -d: -f2 | xargs)
|
|
422
|
+
FINDINGS_IN_SCOPE=$(echo "$FIX_FRONTMATTER" | grep "^findings_in_scope:" | cut -d: -f2 | xargs)
|
|
423
|
+
FIXED_COUNT=$(echo "$FIX_FRONTMATTER" | grep "^fixed:" | cut -d: -f2 | xargs)
|
|
424
|
+
SKIPPED_COUNT=$(echo "$FIX_FRONTMATTER" | grep "^skipped:" | cut -d: -f2 | xargs)
|
|
425
|
+
ITERATION_COUNT=$(echo "$FIX_FRONTMATTER" | grep "^iteration:" | cut -d: -f2 | xargs)
|
|
426
|
+
```
|
|
427
|
+
|
|
428
|
+
Display formatted inline summary:
|
|
429
|
+
|
|
430
|
+
```bash
|
|
431
|
+
echo ""
|
|
432
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
433
|
+
echo ""
|
|
434
|
+
echo " Code Review Fix Complete: Phase ${PHASE_NUMBER} (${PHASE_NAME})"
|
|
435
|
+
echo ""
|
|
436
|
+
echo "───────────────────────────────────────────────────────────────"
|
|
437
|
+
echo ""
|
|
438
|
+
echo " Fix Scope: ${FIX_SCOPE}"
|
|
439
|
+
echo " Findings: ${FINDINGS_IN_SCOPE}"
|
|
440
|
+
echo " Fixed: ${FIXED_COUNT}"
|
|
441
|
+
echo " Skipped: ${SKIPPED_COUNT}"
|
|
442
|
+
if [ "$AUTO_MODE" = "true" ]; then
|
|
443
|
+
echo " Iterations: ${ITERATION_COUNT}"
|
|
444
|
+
fi
|
|
445
|
+
echo " Status: ${FIX_STATUS}"
|
|
446
|
+
echo ""
|
|
447
|
+
echo "───────────────────────────────────────────────────────────────"
|
|
448
|
+
echo ""
|
|
449
|
+
```
|
|
450
|
+
|
|
451
|
+
If status is "all_fixed":
|
|
452
|
+
```bash
|
|
453
|
+
if [ "$FIX_STATUS" = "all_fixed" ]; then
|
|
454
|
+
echo "✓ All issues resolved."
|
|
455
|
+
echo ""
|
|
456
|
+
echo "Full report: ${FIX_REPORT_PATH}"
|
|
457
|
+
echo ""
|
|
458
|
+
echo "Next step:"
|
|
459
|
+
echo " /gsd:verify-work — Verify phase completion"
|
|
460
|
+
echo ""
|
|
461
|
+
fi
|
|
462
|
+
```
|
|
463
|
+
|
|
464
|
+
If status is "partial" or "none_fixed":
|
|
465
|
+
```bash
|
|
466
|
+
if [ "$FIX_STATUS" = "partial" ] || [ "$FIX_STATUS" = "none_fixed" ]; then
|
|
467
|
+
echo "⚠ Some issues could not be fixed automatically."
|
|
468
|
+
echo ""
|
|
469
|
+
echo "Full report: ${FIX_REPORT_PATH}"
|
|
470
|
+
echo ""
|
|
471
|
+
echo "Next steps:"
|
|
472
|
+
echo " cat ${FIX_REPORT_PATH} — View fix report"
|
|
473
|
+
echo " /gsd:code-review ${PHASE_NUMBER} — Re-review code"
|
|
474
|
+
echo " /gsd:verify-work — Verify phase completion"
|
|
475
|
+
echo ""
|
|
476
|
+
fi
|
|
477
|
+
```
|
|
478
|
+
|
|
479
|
+
```bash
|
|
480
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
481
|
+
```
|
|
482
|
+
</step>
|
|
483
|
+
|
|
484
|
+
</process>
|
|
485
|
+
|
|
486
|
+
<platform_notes>
|
|
487
|
+
**Windows:** This workflow uses bash features (arrays, variable expansion, while loops). On Windows, it requires Git Bash or WSL. Native PowerShell is not supported. The CI matrix (Ubuntu/macOS/Windows) runs under Git Bash on Windows runners, which provides bash compatibility.
|
|
488
|
+
</platform_notes>
|
|
489
|
+
|
|
490
|
+
<success_criteria>
|
|
491
|
+
- [ ] Phase validated before config gate check
|
|
492
|
+
- [ ] Config gate checked (workflow.code_review)
|
|
493
|
+
- [ ] REVIEW.md existence verified (error if missing)
|
|
494
|
+
- [ ] REVIEW.md status checked (skip if clean/skipped)
|
|
495
|
+
- [ ] Agent spawned with correct config (review_path, fix_scope, fix_report_path)
|
|
496
|
+
- [ ] Agent failure handled with partial-success awareness (some fix commits may exist)
|
|
497
|
+
- [ ] --auto iteration loop respects 3-iteration cap
|
|
498
|
+
- [ ] --auto re-review uses persisted file scope (not lost between iterations)
|
|
499
|
+
- [ ] REVIEW-FIX.md committed ONCE after all iterations (not per-iteration)
|
|
500
|
+
- [ ] Missing fix report handled with explicit error message in present_results
|
|
501
|
+
- [ ] Results presented inline with next step suggestion
|
|
502
|
+
</success_criteria>
|