gsd-pi 2.73.1-dev.d987996 → 2.74.0-dev.0306a2e
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/dist/cli-web-branch.d.ts +4 -3
- package/dist/cli-web-branch.js +10 -7
- package/dist/cli.js +184 -206
- package/dist/headless-query.js +4 -1
- package/dist/help-text.js +23 -0
- package/dist/logo.d.ts +1 -1
- package/dist/logo.js +1 -1
- package/dist/onboarding.js +59 -53
- package/dist/resource-loader.js +2 -2
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +68 -4
- package/dist/resources/extensions/gsd/activity-log.js +16 -0
- package/dist/resources/extensions/gsd/auto/detect-stuck.js +11 -4
- package/dist/resources/extensions/gsd/auto/loop.js +147 -10
- package/dist/resources/extensions/gsd/auto/phases.js +173 -13
- package/dist/resources/extensions/gsd/auto/session.js +10 -0
- package/dist/resources/extensions/gsd/auto-dispatch.js +22 -4
- package/dist/resources/extensions/gsd/auto-model-selection.js +105 -16
- package/dist/resources/extensions/gsd/auto-post-unit.js +254 -15
- package/dist/resources/extensions/gsd/auto-prompts.js +12 -0
- package/dist/resources/extensions/gsd/auto-start.js +23 -6
- package/dist/resources/extensions/gsd/auto-timeout-recovery.js +13 -0
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +18 -0
- package/dist/resources/extensions/gsd/auto-verification.js +186 -3
- package/dist/resources/extensions/gsd/auto.js +65 -12
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +30 -8
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +41 -2
- package/dist/resources/extensions/gsd/commands/catalog.js +26 -1
- package/dist/resources/extensions/gsd/commands/handlers/ops.js +25 -0
- package/dist/resources/extensions/gsd/commands/handlers/workflow.js +68 -9
- package/dist/resources/extensions/gsd/commands-add-tests.js +111 -0
- package/dist/resources/extensions/gsd/commands-backlog.js +140 -0
- package/dist/resources/extensions/gsd/commands-do.js +79 -0
- package/dist/resources/extensions/gsd/commands-extract-learnings.js +225 -0
- package/dist/resources/extensions/gsd/commands-handlers.js +8 -2
- package/dist/resources/extensions/gsd/commands-maintenance.js +6 -6
- package/dist/resources/extensions/gsd/commands-pr-branch.js +180 -0
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +1 -1
- package/dist/resources/extensions/gsd/commands-session-report.js +82 -0
- package/dist/resources/extensions/gsd/commands-ship.js +187 -0
- package/dist/resources/extensions/gsd/db-writer.js +3 -5
- package/dist/resources/extensions/gsd/docs/preferences-reference.md +15 -2
- package/dist/resources/extensions/gsd/ecosystem/gsd-extension-api.js +144 -0
- package/dist/resources/extensions/gsd/ecosystem/loader.js +145 -0
- package/dist/resources/extensions/gsd/git-service.js +49 -1
- package/dist/resources/extensions/gsd/graph-context.js +157 -0
- package/dist/resources/extensions/gsd/gsd-db.js +581 -2
- package/dist/resources/extensions/gsd/guided-flow.js +23 -0
- package/dist/resources/extensions/gsd/index.js +15 -2
- package/dist/resources/extensions/gsd/init-wizard.js +1 -0
- package/dist/resources/extensions/gsd/journal.js +27 -0
- package/dist/resources/extensions/gsd/md-importer.js +3 -4
- package/dist/resources/extensions/gsd/memory-store.js +19 -51
- package/dist/resources/extensions/gsd/metrics.js +19 -0
- package/dist/resources/extensions/gsd/milestone-validation-gates.js +13 -12
- package/dist/resources/extensions/gsd/native-git-bridge.js +7 -4
- package/dist/resources/extensions/gsd/notification-widget.js +2 -2
- package/dist/resources/extensions/gsd/parallel-orchestrator.js +33 -1
- package/dist/resources/extensions/gsd/preferences-models.js +63 -3
- package/dist/resources/extensions/gsd/preferences-types.js +2 -0
- package/dist/resources/extensions/gsd/preferences-validation.js +130 -2
- package/dist/resources/extensions/gsd/preferences.js +26 -0
- package/dist/resources/extensions/gsd/prompts/add-tests.md +35 -0
- package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +12 -2
- package/dist/resources/extensions/gsd/state.js +66 -15
- package/dist/resources/extensions/gsd/templates/PREFERENCES.md +18 -0
- package/dist/resources/extensions/gsd/tools/complete-slice.js +20 -0
- package/dist/resources/extensions/gsd/tools/validate-milestone.js +39 -4
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +3 -14
- package/dist/resources/extensions/gsd/triage-resolution.js +2 -5
- package/dist/resources/extensions/gsd/unit-ownership.js +1 -1
- package/dist/resources/extensions/gsd/uok/audit-toggle.js +7 -0
- package/dist/resources/extensions/gsd/uok/audit.js +40 -0
- package/dist/resources/extensions/gsd/uok/contracts.js +1 -0
- package/dist/resources/extensions/gsd/uok/execution-graph.js +179 -0
- package/dist/resources/extensions/gsd/uok/flags.js +29 -0
- package/dist/resources/extensions/gsd/uok/gate-runner.js +109 -0
- package/dist/resources/extensions/gsd/uok/gitops.js +53 -0
- package/dist/resources/extensions/gsd/uok/kernel.js +80 -0
- package/dist/resources/extensions/gsd/uok/loop-adapter.js +133 -0
- package/dist/resources/extensions/gsd/uok/model-policy.js +66 -0
- package/dist/resources/extensions/gsd/uok/plan-v2.js +132 -0
- package/dist/resources/extensions/gsd/workflow-logger.js +22 -0
- package/dist/resources/extensions/gsd/workflow-manifest.js +8 -69
- package/dist/resources/extensions/gsd/workflow-migration.js +21 -22
- package/dist/resources/extensions/gsd/workflow-projections.js +4 -1
- package/dist/resources/extensions/gsd/workflow-reconcile.js +14 -11
- package/dist/resources/extensions/ttsr/ttsr-manager.js +3 -1
- package/dist/tsconfig.extensions.tsbuildinfo +1 -0
- package/dist/update-check.d.ts +1 -0
- package/dist/update-check.js +13 -5
- package/dist/update-cmd.js +4 -3
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +13 -13
- package/dist/web/standalone/.next/build-manifest.json +2 -2
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +1 -1
- package/dist/web/standalone/.next/server/app/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +13 -13
- package/dist/web/standalone/.next/server/chunks/6897.js +3 -3
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
- package/dist/web/standalone/.next/server/pages/404.html +1 -1
- package/dist/web/standalone/.next/server/pages/500.html +1 -1
- package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
- package/package.json +3 -3
- package/packages/daemon/package.json +2 -2
- package/packages/mcp-server/dist/index.d.ts +3 -0
- package/packages/mcp-server/dist/index.d.ts.map +1 -1
- package/packages/mcp-server/dist/index.js +3 -0
- package/packages/mcp-server/dist/index.js.map +1 -1
- package/packages/mcp-server/dist/readers/graph.d.ts +87 -0
- package/packages/mcp-server/dist/readers/graph.d.ts.map +1 -0
- package/packages/mcp-server/dist/readers/graph.js +655 -0
- package/packages/mcp-server/dist/readers/graph.js.map +1 -0
- package/packages/mcp-server/dist/readers/index.d.ts +2 -0
- package/packages/mcp-server/dist/readers/index.d.ts.map +1 -1
- package/packages/mcp-server/dist/readers/index.js +1 -0
- package/packages/mcp-server/dist/readers/index.js.map +1 -1
- package/packages/mcp-server/dist/server.d.ts.map +1 -1
- package/packages/mcp-server/dist/server.js +65 -0
- package/packages/mcp-server/dist/server.js.map +1 -1
- package/packages/mcp-server/package.json +2 -2
- package/packages/mcp-server/src/index.ts +15 -0
- package/packages/mcp-server/src/readers/graph.test.ts +604 -0
- package/packages/mcp-server/src/readers/graph.ts +855 -0
- package/packages/mcp-server/src/readers/index.ts +12 -0
- package/packages/mcp-server/src/server.ts +83 -0
- package/packages/mcp-server/tsconfig.json +1 -0
- package/packages/mcp-server/tsconfig.tsbuildinfo +1 -0
- package/packages/native/package.json +2 -2
- package/packages/native/tsconfig.tsbuildinfo +1 -0
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-agent-core/tsconfig.json +1 -0
- package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -0
- package/packages/pi-ai/dist/index.d.ts +2 -9
- package/packages/pi-ai/dist/index.d.ts.map +1 -1
- package/packages/pi-ai/dist/index.js +2 -9
- package/packages/pi-ai/dist/index.js.map +1 -1
- package/packages/pi-ai/dist/models/capability-patches.d.ts +19 -0
- package/packages/pi-ai/dist/models/capability-patches.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/capability-patches.js +36 -0
- package/packages/pi-ai/dist/models/capability-patches.js.map +1 -0
- package/packages/pi-ai/dist/{models.custom.d.ts → models/custom.d.ts} +1 -1
- package/packages/pi-ai/dist/models/custom.d.ts.map +1 -0
- package/packages/pi-ai/dist/{models.custom.js → models/custom.js} +4 -4
- package/packages/pi-ai/dist/models/custom.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts +1482 -0
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.js +1484 -0
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/anthropic.d.ts +377 -0
- package/packages/pi-ai/dist/models/generated/anthropic.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/anthropic.js +379 -0
- package/packages/pi-ai/dist/models/generated/anthropic.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/azure-openai-responses.d.ts +700 -0
- package/packages/pi-ai/dist/models/generated/azure-openai-responses.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/azure-openai-responses.js +702 -0
- package/packages/pi-ai/dist/models/generated/azure-openai-responses.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/cerebras.d.ts +71 -0
- package/packages/pi-ai/dist/models/generated/cerebras.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/cerebras.js +73 -0
- package/packages/pi-ai/dist/models/generated/cerebras.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/github-copilot.d.ts +590 -0
- package/packages/pi-ai/dist/models/generated/github-copilot.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/github-copilot.js +444 -0
- package/packages/pi-ai/dist/models/generated/github-copilot.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts +156 -0
- package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-antigravity.js +158 -0
- package/packages/pi-ai/dist/models/generated/google-antigravity.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-gemini-cli.d.ts +105 -0
- package/packages/pi-ai/dist/models/generated/google-gemini-cli.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-gemini-cli.js +107 -0
- package/packages/pi-ai/dist/models/generated/google-gemini-cli.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-vertex.d.ts +207 -0
- package/packages/pi-ai/dist/models/generated/google-vertex.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-vertex.js +209 -0
- package/packages/pi-ai/dist/models/generated/google-vertex.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/google.d.ts +462 -0
- package/packages/pi-ai/dist/models/generated/google.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/google.js +464 -0
- package/packages/pi-ai/dist/models/generated/google.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/groq.d.ts +309 -0
- package/packages/pi-ai/dist/models/generated/groq.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/groq.js +311 -0
- package/packages/pi-ai/dist/models/generated/groq.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/huggingface.d.ts +383 -0
- package/packages/pi-ai/dist/models/generated/huggingface.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/huggingface.js +347 -0
- package/packages/pi-ai/dist/models/generated/huggingface.js.map +1 -0
- package/packages/pi-ai/dist/{models.generated.d.ts → models/generated/index.d.ts} +1 -1
- package/packages/pi-ai/dist/{models.generated.d.ts.map → models/generated/index.d.ts.map} +1 -1
- package/packages/pi-ai/dist/models/generated/index.js +51 -0
- package/packages/pi-ai/dist/models/generated/index.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/kimi-coding.d.ts +37 -0
- package/packages/pi-ai/dist/models/generated/kimi-coding.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/kimi-coding.js +39 -0
- package/packages/pi-ai/dist/models/generated/kimi-coding.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/minimax-cn.d.ts +105 -0
- package/packages/pi-ai/dist/models/generated/minimax-cn.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/minimax-cn.js +107 -0
- package/packages/pi-ai/dist/models/generated/minimax-cn.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/minimax.d.ts +105 -0
- package/packages/pi-ai/dist/models/generated/minimax.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/minimax.js +107 -0
- package/packages/pi-ai/dist/models/generated/minimax.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/mistral.d.ts +445 -0
- package/packages/pi-ai/dist/models/generated/mistral.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/mistral.js +447 -0
- package/packages/pi-ai/dist/models/generated/mistral.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/openai-codex.d.ts +139 -0
- package/packages/pi-ai/dist/models/generated/openai-codex.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/openai-codex.js +141 -0
- package/packages/pi-ai/dist/models/generated/openai-codex.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/openai.d.ts +700 -0
- package/packages/pi-ai/dist/models/generated/openai.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/openai.js +702 -0
- package/packages/pi-ai/dist/models/generated/openai.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/opencode-go.d.ts +122 -0
- package/packages/pi-ai/dist/models/generated/opencode-go.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/opencode-go.js +124 -0
- package/packages/pi-ai/dist/models/generated/opencode-go.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/opencode.d.ts +530 -0
- package/packages/pi-ai/dist/models/generated/opencode.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/opencode.js +532 -0
- package/packages/pi-ai/dist/models/generated/opencode.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/openrouter.d.ts +4270 -0
- package/packages/pi-ai/dist/models/generated/openrouter.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/openrouter.js +4272 -0
- package/packages/pi-ai/dist/models/generated/openrouter.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.d.ts +2604 -0
- package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.js +2606 -0
- package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/xai.d.ts +411 -0
- package/packages/pi-ai/dist/models/generated/xai.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/xai.js +413 -0
- package/packages/pi-ai/dist/models/generated/xai.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/zai.d.ts +276 -0
- package/packages/pi-ai/dist/models/generated/zai.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/zai.js +239 -0
- package/packages/pi-ai/dist/models/generated/zai.js.map +1 -0
- package/packages/pi-ai/dist/models/index.d.ts +27 -0
- package/packages/pi-ai/dist/models/index.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/index.js +80 -0
- package/packages/pi-ai/dist/models/index.js.map +1 -0
- package/packages/pi-ai/dist/models.d.ts +1 -36
- package/packages/pi-ai/dist/models.d.ts.map +1 -1
- package/packages/pi-ai/dist/models.generated.test.js +1 -2
- package/packages/pi-ai/dist/models.generated.test.js.map +1 -1
- package/packages/pi-ai/dist/models.js +3 -112
- package/packages/pi-ai/dist/models.js.map +1 -1
- package/packages/pi-ai/dist/models.test.js +6 -5
- package/packages/pi-ai/dist/models.test.js.map +1 -1
- package/packages/pi-ai/dist/utils/overflow.d.ts.map +1 -1
- package/packages/pi-ai/dist/utils/overflow.js +12 -0
- package/packages/pi-ai/dist/utils/overflow.js.map +1 -1
- package/packages/pi-ai/dist/utils/tests/overflow.test.d.ts +2 -0
- package/packages/pi-ai/dist/utils/tests/overflow.test.d.ts.map +1 -0
- package/packages/pi-ai/dist/utils/tests/overflow.test.js +50 -0
- package/packages/pi-ai/dist/utils/tests/overflow.test.js.map +1 -0
- package/packages/pi-ai/package.json +1 -1
- package/packages/pi-ai/scripts/generate-models.ts +74 -40
- package/packages/pi-ai/src/index.ts +5 -9
- package/packages/pi-ai/src/models/capability-patches.ts +40 -0
- package/packages/pi-ai/src/{models.custom.ts → models/custom.ts} +4 -4
- package/packages/pi-ai/src/models/generated/amazon-bedrock.ts +1486 -0
- package/packages/pi-ai/src/models/generated/anthropic.ts +381 -0
- package/packages/pi-ai/src/models/generated/azure-openai-responses.ts +704 -0
- package/packages/pi-ai/src/models/generated/cerebras.ts +75 -0
- package/packages/pi-ai/src/models/generated/github-copilot.ts +446 -0
- package/packages/pi-ai/src/models/generated/google-antigravity.ts +160 -0
- package/packages/pi-ai/src/models/generated/google-gemini-cli.ts +109 -0
- package/packages/pi-ai/src/models/generated/google-vertex.ts +211 -0
- package/packages/pi-ai/src/models/generated/google.ts +466 -0
- package/packages/pi-ai/src/models/generated/groq.ts +313 -0
- package/packages/pi-ai/src/models/generated/huggingface.ts +349 -0
- package/packages/pi-ai/src/models/generated/index.ts +52 -0
- package/packages/pi-ai/src/models/generated/kimi-coding.ts +41 -0
- package/packages/pi-ai/src/models/generated/minimax-cn.ts +109 -0
- package/packages/pi-ai/src/models/generated/minimax.ts +109 -0
- package/packages/pi-ai/src/models/generated/mistral.ts +449 -0
- package/packages/pi-ai/src/models/generated/openai-codex.ts +143 -0
- package/packages/pi-ai/src/models/generated/openai.ts +704 -0
- package/packages/pi-ai/src/models/generated/opencode-go.ts +126 -0
- package/packages/pi-ai/src/models/generated/opencode.ts +534 -0
- package/packages/pi-ai/src/models/generated/openrouter.ts +4274 -0
- package/packages/pi-ai/src/models/generated/vercel-ai-gateway.ts +2608 -0
- package/packages/pi-ai/src/models/generated/xai.ts +415 -0
- package/packages/pi-ai/src/models/generated/zai.ts +241 -0
- package/packages/pi-ai/src/models/index.ts +106 -0
- package/packages/pi-ai/src/models.generated.test.ts +1 -2
- package/packages/pi-ai/src/models.test.ts +6 -5
- package/packages/pi-ai/src/models.ts +3 -153
- package/packages/pi-ai/src/utils/overflow.ts +14 -1
- package/packages/pi-ai/src/utils/tests/overflow.test.ts +58 -0
- package/packages/pi-ai/tsconfig.json +1 -0
- package/packages/pi-ai/tsconfig.tsbuildinfo +1 -0
- package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js +721 -8
- package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction/utils.js +5 -5
- package/packages/pi-coding-agent/dist/core/compaction/utils.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction-utils.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/compaction-utils.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/compaction-utils.test.js +45 -0
- package/packages/pi-coding-agent/dist/core/compaction-utils.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.js +52 -0
- package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry.js +2 -2
- package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts +12 -2
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js +65 -28
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.d.ts +2 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.js +9 -3
- package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.test.js +52 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +305 -20
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js +38 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +13 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +59 -6
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/core/chat-controller-ordering.test.ts +884 -8
- package/packages/pi-coding-agent/src/core/compaction/utils.ts +5 -5
- package/packages/pi-coding-agent/src/core/compaction-utils.test.ts +50 -0
- package/packages/pi-coding-agent/src/core/model-registry-env-fallback.test.ts +59 -0
- package/packages/pi-coding-agent/src/core/model-registry.ts +2 -1
- package/packages/pi-coding-agent/src/modes/interactive/components/assistant-message.ts +78 -32
- package/packages/pi-coding-agent/src/modes/interactive/components/dynamic-border.test.ts +73 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/dynamic-border.ts +9 -3
- package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +381 -39
- package/packages/pi-coding-agent/src/modes/interactive/interactive-mode-ordering.test.ts +44 -0
- package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +79 -6
- package/packages/pi-coding-agent/src/types/ambient-modules.d.ts +69 -0
- package/packages/pi-coding-agent/tsconfig.json +3 -2
- package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -0
- package/packages/pi-tui/dist/__tests__/tui.test.js +60 -1
- package/packages/pi-tui/dist/__tests__/tui.test.js.map +1 -1
- package/packages/pi-tui/dist/tui.d.ts +8 -0
- package/packages/pi-tui/dist/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +32 -3
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/package.json +1 -1
- package/packages/pi-tui/src/__tests__/tui.test.ts +76 -1
- package/packages/pi-tui/src/tui.ts +31 -3
- package/packages/pi-tui/tsconfig.json +1 -0
- package/packages/pi-tui/tsconfig.tsbuildinfo +1 -0
- package/packages/rpc-client/package.json +1 -1
- package/packages/rpc-client/tsconfig.json +1 -0
- package/packages/rpc-client/tsconfig.tsbuildinfo +1 -0
- package/pkg/package.json +1 -1
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +107 -5
- package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +111 -2
- package/src/resources/extensions/gsd/activity-log.ts +21 -0
- package/src/resources/extensions/gsd/auto/detect-stuck.ts +12 -4
- package/src/resources/extensions/gsd/auto/loop-deps.ts +10 -0
- package/src/resources/extensions/gsd/auto/loop.ts +159 -10
- package/src/resources/extensions/gsd/auto/phases.ts +213 -13
- package/src/resources/extensions/gsd/auto/session.ts +10 -0
- package/src/resources/extensions/gsd/auto-dispatch.ts +26 -10
- package/src/resources/extensions/gsd/auto-model-selection.ts +151 -16
- package/src/resources/extensions/gsd/auto-post-unit.ts +278 -16
- package/src/resources/extensions/gsd/auto-prompts.ts +13 -0
- package/src/resources/extensions/gsd/auto-start.ts +30 -6
- package/src/resources/extensions/gsd/auto-timeout-recovery.ts +17 -0
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +25 -1
- package/src/resources/extensions/gsd/auto-verification.ts +225 -3
- package/src/resources/extensions/gsd/auto.ts +72 -16
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +38 -8
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +52 -2
- package/src/resources/extensions/gsd/commands/catalog.ts +26 -1
- package/src/resources/extensions/gsd/commands/handlers/ops.ts +25 -0
- package/src/resources/extensions/gsd/commands/handlers/workflow.ts +74 -9
- package/src/resources/extensions/gsd/commands-add-tests.ts +137 -0
- package/src/resources/extensions/gsd/commands-backlog.ts +182 -0
- package/src/resources/extensions/gsd/commands-do.ts +109 -0
- package/src/resources/extensions/gsd/commands-extract-learnings.ts +304 -0
- package/src/resources/extensions/gsd/commands-handlers.ts +8 -2
- package/src/resources/extensions/gsd/commands-maintenance.ts +6 -6
- package/src/resources/extensions/gsd/commands-pr-branch.ts +234 -0
- package/src/resources/extensions/gsd/commands-prefs-wizard.ts +1 -1
- package/src/resources/extensions/gsd/commands-session-report.ts +101 -0
- package/src/resources/extensions/gsd/commands-ship.ts +219 -0
- package/src/resources/extensions/gsd/db-writer.ts +3 -5
- package/src/resources/extensions/gsd/docs/preferences-reference.md +15 -2
- package/src/resources/extensions/gsd/ecosystem/gsd-extension-api.ts +228 -0
- package/src/resources/extensions/gsd/ecosystem/loader.ts +201 -0
- package/src/resources/extensions/gsd/git-service.ts +68 -0
- package/src/resources/extensions/gsd/graph-context.ts +212 -0
- package/src/resources/extensions/gsd/gsd-db.ts +788 -3
- package/src/resources/extensions/gsd/guided-flow.ts +32 -0
- package/src/resources/extensions/gsd/index.ts +18 -2
- package/src/resources/extensions/gsd/init-wizard.ts +3 -2
- package/src/resources/extensions/gsd/journal.ts +30 -0
- package/src/resources/extensions/gsd/md-importer.ts +3 -5
- package/src/resources/extensions/gsd/memory-store.ts +31 -62
- package/src/resources/extensions/gsd/metrics.ts +26 -0
- package/src/resources/extensions/gsd/milestone-validation-gates.ts +13 -14
- package/src/resources/extensions/gsd/native-git-bridge.ts +11 -12
- package/src/resources/extensions/gsd/notification-widget.ts +2 -2
- package/src/resources/extensions/gsd/parallel-orchestrator.ts +40 -1
- package/src/resources/extensions/gsd/preferences-models.ts +61 -3
- package/src/resources/extensions/gsd/preferences-types.ts +44 -0
- package/src/resources/extensions/gsd/preferences-validation.ts +130 -2
- package/src/resources/extensions/gsd/preferences.ts +28 -0
- package/src/resources/extensions/gsd/prompts/add-tests.md +35 -0
- package/src/resources/extensions/gsd/session-lock.ts +14 -2
- package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +20 -1
- package/src/resources/extensions/gsd/state.ts +80 -17
- package/src/resources/extensions/gsd/templates/PREFERENCES.md +18 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +9 -5
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +20 -0
- package/src/resources/extensions/gsd/tests/auto-post-unit-step-message.test.ts +53 -0
- package/src/resources/extensions/gsd/tests/auto-project-root-env.test.ts +7 -3
- package/src/resources/extensions/gsd/tests/auto-start-model-capture.test.ts +51 -2
- package/src/resources/extensions/gsd/tests/cold-resume-db-reopen.test.ts +6 -2
- package/src/resources/extensions/gsd/tests/commands-backlog.test.ts +158 -0
- package/src/resources/extensions/gsd/tests/commands-do.test.ts +127 -0
- package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +340 -0
- package/src/resources/extensions/gsd/tests/commands-pr-branch.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/commands-session-report.test.ts +82 -0
- package/src/resources/extensions/gsd/tests/commands-ship.test.ts +71 -0
- package/src/resources/extensions/gsd/tests/commands-workflow-custom.test.ts +14 -0
- package/src/resources/extensions/gsd/tests/complete-milestone-false-merge.test.ts +142 -0
- package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/completed-at-reconcile.test.ts +42 -0
- package/src/resources/extensions/gsd/tests/derive-state-crossval.test.ts +3 -2
- package/src/resources/extensions/gsd/tests/derive-state-db.test.ts +3 -2
- package/src/resources/extensions/gsd/tests/derive-state-helpers.test.ts +68 -8
- package/src/resources/extensions/gsd/tests/derive-state.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +154 -0
- package/src/resources/extensions/gsd/tests/finalize-timeout-guard.test.ts +10 -7
- package/src/resources/extensions/gsd/tests/flat-rate-routing-guard.test.ts +137 -1
- package/src/resources/extensions/gsd/tests/graph-context.test.ts +337 -0
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/health-widget.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/integration/state-machine-edge-cases.test.ts +4 -2
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +68 -1
- package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -2
- package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -3
- package/src/resources/extensions/gsd/tests/model-isolation.test.ts +91 -2
- package/src/resources/extensions/gsd/tests/native-git-bridge-exec-fallback.test.ts +140 -0
- package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +79 -1
- package/src/resources/extensions/gsd/tests/post-unit-state-rebuild.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/pre-execution-pause-wiring.test.ts +40 -1
- package/src/resources/extensions/gsd/tests/preferences.test.ts +47 -0
- package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/single-writer-invariant.test.ts +180 -0
- package/src/resources/extensions/gsd/tests/state-machine-full-walkthrough.test.ts +5 -7
- package/src/resources/extensions/gsd/tests/token-profile.test.ts +9 -6
- package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +101 -0
- package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +85 -0
- package/src/resources/extensions/gsd/tests/uok-execution-graph.test.ts +69 -0
- package/src/resources/extensions/gsd/tests/uok-flags.test.ts +39 -0
- package/src/resources/extensions/gsd/tests/uok-gate-runner.test.ts +70 -0
- package/src/resources/extensions/gsd/tests/uok-gitops-turn-action.test.ts +85 -0
- package/src/resources/extensions/gsd/tests/uok-gitops-wiring.test.ts +35 -0
- package/src/resources/extensions/gsd/tests/uok-model-policy.test.ts +89 -0
- package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +167 -0
- package/src/resources/extensions/gsd/tests/uok-preferences.test.ts +42 -0
- package/src/resources/extensions/gsd/tests/validate-milestone-stuck-guard.test.ts +179 -0
- package/src/resources/extensions/gsd/tests/validate-milestone-write-order.test.ts +39 -0
- package/src/resources/extensions/gsd/tests/workflow-logger-wiring.test.ts +223 -0
- package/src/resources/extensions/gsd/tools/complete-slice.ts +26 -0
- package/src/resources/extensions/gsd/tools/validate-milestone.ts +48 -3
- package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +3 -11
- package/src/resources/extensions/gsd/triage-resolution.ts +2 -7
- package/src/resources/extensions/gsd/types.ts +14 -1
- package/src/resources/extensions/gsd/unit-ownership.ts +2 -2
- package/src/resources/extensions/gsd/uok/audit-toggle.ts +9 -0
- package/src/resources/extensions/gsd/uok/audit.ts +51 -0
- package/src/resources/extensions/gsd/uok/contracts.ts +135 -0
- package/src/resources/extensions/gsd/uok/execution-graph.ts +241 -0
- package/src/resources/extensions/gsd/uok/flags.ts +45 -0
- package/src/resources/extensions/gsd/uok/gate-runner.ts +146 -0
- package/src/resources/extensions/gsd/uok/gitops.ts +75 -0
- package/src/resources/extensions/gsd/uok/kernel.ts +105 -0
- package/src/resources/extensions/gsd/uok/loop-adapter.ts +162 -0
- package/src/resources/extensions/gsd/uok/model-policy.ts +112 -0
- package/src/resources/extensions/gsd/uok/plan-v2.ts +156 -0
- package/src/resources/extensions/gsd/workflow-logger.ts +27 -1
- package/src/resources/extensions/gsd/workflow-manifest.ts +9 -104
- package/src/resources/extensions/gsd/workflow-migration.ts +21 -29
- package/src/resources/extensions/gsd/workflow-projections.ts +8 -1
- package/src/resources/extensions/gsd/workflow-reconcile.ts +15 -15
- package/src/resources/extensions/ttsr/ttsr-manager.ts +10 -5
- package/packages/pi-ai/dist/models.custom.d.ts.map +0 -1
- package/packages/pi-ai/dist/models.custom.js.map +0 -1
- package/packages/pi-ai/dist/models.generated.js +0 -14343
- package/packages/pi-ai/dist/models.generated.js.map +0 -1
- package/packages/pi-ai/src/models.generated.ts +0 -14345
- /package/dist/web/standalone/.next/static/{cGmbVq2su4f9tMpgIkG8u → tqdo0yKKYz6fJXQnIgbdx}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{cGmbVq2su4f9tMpgIkG8u → tqdo0yKKYz6fJXQnIgbdx}/_ssgManifest.js +0 -0
|
@@ -10,18 +10,129 @@
|
|
|
10
10
|
* checks the result and handles control flow.
|
|
11
11
|
*/
|
|
12
12
|
import { mkdirSync, writeFileSync } from "node:fs";
|
|
13
|
-
import { resolveSlicePath } from "./paths.js";
|
|
13
|
+
import { resolveSlicePath, resolveMilestoneFile } from "./paths.js";
|
|
14
14
|
import { parseUnitId } from "./unit-id.js";
|
|
15
|
-
import { isDbAvailable, getTask, getSliceTasks } from "./gsd-db.js";
|
|
15
|
+
import { isDbAvailable, getTask, getSliceTasks, getMilestoneSlices } from "./gsd-db.js";
|
|
16
16
|
import { loadEffectiveGSDPreferences } from "./preferences.js";
|
|
17
|
+
import { extractVerdict } from "./verdict-parser.js";
|
|
18
|
+
import { isClosedStatus } from "./status-guards.js";
|
|
19
|
+
import { loadFile } from "./files.js";
|
|
20
|
+
import { parseRoadmap } from "./parsers-legacy.js";
|
|
21
|
+
import { isMilestoneComplete } from "./state.js";
|
|
17
22
|
import { runVerificationGate, formatFailureContext, captureRuntimeErrors, runDependencyAudit, } from "./verification-gate.js";
|
|
18
23
|
import { writeVerificationJSON } from "./verification-evidence.js";
|
|
19
24
|
import { logWarning } from "./workflow-logger.js";
|
|
20
25
|
import { runPostExecutionChecks } from "./post-execution-checks.js";
|
|
21
26
|
import { join } from "node:path";
|
|
27
|
+
import { resolveUokFlags } from "./uok/flags.js";
|
|
28
|
+
import { UokGateRunner } from "./uok/gate-runner.js";
|
|
22
29
|
function isInfraVerificationFailure(stderr) {
|
|
23
30
|
return /\b(ENOENT|ENOTFOUND|ETIMEDOUT|ECONNRESET|EAI_AGAIN|spawn\s+\S+\s+ENOENT|command not found)\b/i.test(stderr);
|
|
24
31
|
}
|
|
32
|
+
/**
|
|
33
|
+
* Post-unit guard for `validate-milestone` units (#4094).
|
|
34
|
+
*
|
|
35
|
+
* When validate-milestone writes verdict=needs-remediation, the agent is
|
|
36
|
+
* expected to also call gsd_reassess_roadmap in the same turn to add
|
|
37
|
+
* remediation slices. If they don't, the state machine re-derives
|
|
38
|
+
* `phase: validating-milestone` indefinitely (all slices still complete +
|
|
39
|
+
* verdict still needs-remediation), wasting ~3 dispatches before the stuck
|
|
40
|
+
* detector fires.
|
|
41
|
+
*
|
|
42
|
+
* This guard fires immediately on the first occurrence: if VALIDATION.md
|
|
43
|
+
* verdict is needs-remediation and no incomplete slices exist for the
|
|
44
|
+
* milestone, pause the auto-loop with a clear blocker.
|
|
45
|
+
*/
|
|
46
|
+
async function runValidateMilestonePostCheck(vctx, pauseAuto) {
|
|
47
|
+
const { s, ctx, pi } = vctx;
|
|
48
|
+
const prefs = loadEffectiveGSDPreferences()?.preferences;
|
|
49
|
+
const uokFlags = resolveUokFlags(prefs);
|
|
50
|
+
const persistMilestoneValidationGate = async (outcome, failureClass, rationale, findings = "", milestoneId) => {
|
|
51
|
+
if (!uokFlags.gates || !s.currentUnit)
|
|
52
|
+
return;
|
|
53
|
+
const gateRunner = new UokGateRunner();
|
|
54
|
+
gateRunner.register({
|
|
55
|
+
id: "milestone-validation-post-check",
|
|
56
|
+
type: "verification",
|
|
57
|
+
execute: async () => ({
|
|
58
|
+
outcome,
|
|
59
|
+
failureClass,
|
|
60
|
+
rationale,
|
|
61
|
+
findings,
|
|
62
|
+
}),
|
|
63
|
+
});
|
|
64
|
+
await gateRunner.run("milestone-validation-post-check", {
|
|
65
|
+
basePath: s.basePath,
|
|
66
|
+
traceId: `validation-post-check:${s.currentUnit.id}`,
|
|
67
|
+
turnId: s.currentUnit.id,
|
|
68
|
+
milestoneId,
|
|
69
|
+
unitType: s.currentUnit.type,
|
|
70
|
+
unitId: s.currentUnit.id,
|
|
71
|
+
});
|
|
72
|
+
};
|
|
73
|
+
if (!s.currentUnit)
|
|
74
|
+
return "continue";
|
|
75
|
+
const { milestone: mid } = parseUnitId(s.currentUnit.id);
|
|
76
|
+
if (!mid)
|
|
77
|
+
return "continue";
|
|
78
|
+
const validationFile = resolveMilestoneFile(s.basePath, mid, "VALIDATION");
|
|
79
|
+
if (!validationFile)
|
|
80
|
+
return "continue";
|
|
81
|
+
const validationContent = await loadFile(validationFile);
|
|
82
|
+
if (!validationContent)
|
|
83
|
+
return "continue";
|
|
84
|
+
const verdict = extractVerdict(validationContent);
|
|
85
|
+
if (verdict !== "needs-remediation") {
|
|
86
|
+
await persistMilestoneValidationGate("pass", "none", `milestone validation verdict is ${verdict}; no remediation loop risk`, "", mid);
|
|
87
|
+
return "continue";
|
|
88
|
+
}
|
|
89
|
+
const incompleteSliceCount = await countIncompleteSlices(s.basePath, mid);
|
|
90
|
+
// If any non-closed slices exist, the agent successfully queued remediation
|
|
91
|
+
// work — proceed normally. The state machine will execute those slices and
|
|
92
|
+
// re-validate per the #3596/#3670 fix.
|
|
93
|
+
if (incompleteSliceCount > 0) {
|
|
94
|
+
await persistMilestoneValidationGate("pass", "none", `remediation slices present (${incompleteSliceCount}); validation can continue`, "", mid);
|
|
95
|
+
return "continue";
|
|
96
|
+
}
|
|
97
|
+
ctx.ui.notify(`Milestone ${mid} validation returned verdict=needs-remediation but no remediation slices were added. Pausing for human review.`, "error");
|
|
98
|
+
process.stderr.write(`validate-milestone: pausing — verdict=needs-remediation with no incomplete slices for ${mid}. ` +
|
|
99
|
+
`The agent must call gsd_reassess_roadmap to add remediation slices before re-validation.\n`);
|
|
100
|
+
await persistMilestoneValidationGate("manual-attention", "manual-attention", "needs-remediation verdict without queued remediation slices", `No incomplete slices found for ${mid} while verdict=needs-remediation`, mid);
|
|
101
|
+
await pauseAuto(ctx, pi);
|
|
102
|
+
return "pause";
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Count slices for a milestone that are not in a closed status.
|
|
106
|
+
* DB-backed projects are authoritative (#4094 peer review); falls back to
|
|
107
|
+
* roadmap parsing only when the DB is unavailable.
|
|
108
|
+
*/
|
|
109
|
+
async function countIncompleteSlices(basePath, milestoneId) {
|
|
110
|
+
if (isDbAvailable()) {
|
|
111
|
+
const slices = getMilestoneSlices(milestoneId);
|
|
112
|
+
if (slices.length === 0) {
|
|
113
|
+
// No DB rows — treat as "unknown", do not pause.
|
|
114
|
+
return 1;
|
|
115
|
+
}
|
|
116
|
+
return slices.filter((slice) => !isClosedStatus(slice.status)).length;
|
|
117
|
+
}
|
|
118
|
+
// Filesystem fallback: parse the roadmap markdown.
|
|
119
|
+
try {
|
|
120
|
+
const roadmapFile = resolveMilestoneFile(basePath, milestoneId, "ROADMAP");
|
|
121
|
+
if (!roadmapFile)
|
|
122
|
+
return 1;
|
|
123
|
+
const roadmapContent = await loadFile(roadmapFile);
|
|
124
|
+
if (!roadmapContent)
|
|
125
|
+
return 1;
|
|
126
|
+
const roadmap = parseRoadmap(roadmapContent);
|
|
127
|
+
if (roadmap.slices.length === 0)
|
|
128
|
+
return 1;
|
|
129
|
+
return isMilestoneComplete(roadmap) ? 0 : 1;
|
|
130
|
+
}
|
|
131
|
+
catch {
|
|
132
|
+
// Parsing failures should not cause false-positive pauses.
|
|
133
|
+
return 1;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
25
136
|
/**
|
|
26
137
|
* Run the verification gate for the current execute-task unit.
|
|
27
138
|
* Returns:
|
|
@@ -31,12 +142,19 @@ function isInfraVerificationFailure(stderr) {
|
|
|
31
142
|
*/
|
|
32
143
|
export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
33
144
|
const { s, ctx, pi } = vctx;
|
|
34
|
-
if (!s.currentUnit
|
|
145
|
+
if (!s.currentUnit) {
|
|
146
|
+
return "continue";
|
|
147
|
+
}
|
|
148
|
+
if (s.currentUnit.type === "validate-milestone") {
|
|
149
|
+
return await runValidateMilestonePostCheck(vctx, pauseAuto);
|
|
150
|
+
}
|
|
151
|
+
if (s.currentUnit.type !== "execute-task") {
|
|
35
152
|
return "continue";
|
|
36
153
|
}
|
|
37
154
|
try {
|
|
38
155
|
const effectivePrefs = loadEffectiveGSDPreferences();
|
|
39
156
|
const prefs = effectivePrefs?.preferences;
|
|
157
|
+
const uokFlags = resolveUokFlags(prefs);
|
|
40
158
|
// Read task plan verify field
|
|
41
159
|
const { milestone: mid, slice: sid, task: tid } = parseUnitId(s.currentUnit.id);
|
|
42
160
|
let taskPlanVerify;
|
|
@@ -68,6 +186,35 @@ export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
|
68
186
|
process.stderr.write(` [${w.severity}] ${w.name}: ${w.title}\n`);
|
|
69
187
|
}
|
|
70
188
|
}
|
|
189
|
+
if (uokFlags.gates) {
|
|
190
|
+
const gateRunner = new UokGateRunner();
|
|
191
|
+
gateRunner.register({
|
|
192
|
+
id: "verification-gate",
|
|
193
|
+
type: "verification",
|
|
194
|
+
execute: async () => ({
|
|
195
|
+
outcome: result.passed ? "pass" : "fail",
|
|
196
|
+
failureClass: result.runtimeErrors?.some((e) => e.blocking)
|
|
197
|
+
? "execution"
|
|
198
|
+
: "verification",
|
|
199
|
+
rationale: result.passed
|
|
200
|
+
? "verification checks passed"
|
|
201
|
+
: "verification checks failed",
|
|
202
|
+
findings: result.passed
|
|
203
|
+
? ""
|
|
204
|
+
: formatFailureContext(result),
|
|
205
|
+
}),
|
|
206
|
+
});
|
|
207
|
+
await gateRunner.run("verification-gate", {
|
|
208
|
+
basePath: s.basePath,
|
|
209
|
+
traceId: `verification:${s.currentUnit.id}`,
|
|
210
|
+
turnId: s.currentUnit.id,
|
|
211
|
+
milestoneId: mid ?? undefined,
|
|
212
|
+
sliceId: sid ?? undefined,
|
|
213
|
+
taskId: tid ?? undefined,
|
|
214
|
+
unitType: s.currentUnit.type,
|
|
215
|
+
unitId: s.currentUnit.id,
|
|
216
|
+
});
|
|
217
|
+
}
|
|
71
218
|
// Auto-fix retry preferences
|
|
72
219
|
const autoFixEnabled = prefs?.verification_auto_fix !== false;
|
|
73
220
|
const maxRetries = typeof prefs?.verification_max_retries === "number"
|
|
@@ -168,6 +315,42 @@ export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
|
168
315
|
: "⚠";
|
|
169
316
|
process.stderr.write(`gsd-post-exec: ${checkEmoji} [${check.category}] ${check.target}: ${check.message}\n`);
|
|
170
317
|
}
|
|
318
|
+
if (uokFlags.gates) {
|
|
319
|
+
const strictMode = prefs?.enhanced_verification_strict === true;
|
|
320
|
+
const warnEscalated = postExecResult.status === "warn" && strictMode;
|
|
321
|
+
const blockingFailure = postExecResult.status === "fail" || warnEscalated;
|
|
322
|
+
const findings = postExecResult.checks
|
|
323
|
+
.filter((check) => !check.passed)
|
|
324
|
+
.map((check) => `[${check.category}] ${check.target}: ${check.message}`)
|
|
325
|
+
.join("\n");
|
|
326
|
+
const gateRunner = new UokGateRunner();
|
|
327
|
+
gateRunner.register({
|
|
328
|
+
id: "post-execution-checks",
|
|
329
|
+
type: "artifact",
|
|
330
|
+
execute: async () => ({
|
|
331
|
+
outcome: blockingFailure ? "fail" : "pass",
|
|
332
|
+
failureClass: postExecResult.status === "fail"
|
|
333
|
+
? "artifact"
|
|
334
|
+
: warnEscalated
|
|
335
|
+
? "policy"
|
|
336
|
+
: "none",
|
|
337
|
+
rationale: blockingFailure
|
|
338
|
+
? `post-execution checks ${postExecResult.status}${warnEscalated ? " (strict)" : ""}`
|
|
339
|
+
: "post-execution checks passed",
|
|
340
|
+
findings,
|
|
341
|
+
}),
|
|
342
|
+
});
|
|
343
|
+
await gateRunner.run("post-execution-checks", {
|
|
344
|
+
basePath: s.basePath,
|
|
345
|
+
traceId: `verification:${s.currentUnit.id}`,
|
|
346
|
+
turnId: s.currentUnit.id,
|
|
347
|
+
milestoneId: mid,
|
|
348
|
+
sliceId: sid,
|
|
349
|
+
taskId: tid,
|
|
350
|
+
unitType: s.currentUnit.type,
|
|
351
|
+
unitId: s.currentUnit.id,
|
|
352
|
+
});
|
|
353
|
+
}
|
|
171
354
|
// Check for blocking failures
|
|
172
355
|
if (postExecResult.status === "fail") {
|
|
173
356
|
postExecBlockingFailure = true;
|
|
@@ -36,7 +36,7 @@ import { captureAvailableSkills, resetSkillTelemetry, } from "./skill-telemetry.
|
|
|
36
36
|
import { getRtkSessionSavings } from "../shared/rtk-session-stats.js";
|
|
37
37
|
import { deactivateGSD } from "../shared/gsd-phase-state.js";
|
|
38
38
|
import { initMetrics, resetMetrics, getLedger, getProjectTotals, formatCost, formatTokenCount, } from "./metrics.js";
|
|
39
|
-
import { logWarning } from "./workflow-logger.js";
|
|
39
|
+
import { setLogBasePath, logWarning } from "./workflow-logger.js";
|
|
40
40
|
import { homedir } from "node:os";
|
|
41
41
|
import { join } from "node:path";
|
|
42
42
|
import { pathToFileURL } from "node:url";
|
|
@@ -55,15 +55,18 @@ import { initRegistry, convertDispatchRules } from "./rule-registry.js";
|
|
|
55
55
|
import { emitJournalEvent as _emitJournalEvent } from "./journal.js";
|
|
56
56
|
import { updateProgressWidget as _updateProgressWidget, updateSliceProgressCache, clearSliceProgressCache, hideFooter, } from "./auto-dashboard.js";
|
|
57
57
|
import { registerSigtermHandler as _registerSigtermHandler, deregisterSigtermHandler as _deregisterSigtermHandler, } from "./auto-supervisor.js";
|
|
58
|
-
import { isDbAvailable } from "./gsd-db.js";
|
|
58
|
+
import { isDbAvailable, getMilestone } from "./gsd-db.js";
|
|
59
59
|
import { countPendingCaptures } from "./captures.js";
|
|
60
60
|
import { clearCmuxSidebar, logCmuxEvent, syncCmuxSidebar } from "../cmux/index.js";
|
|
61
61
|
// ── Extracted modules ──────────────────────────────────────────────────────
|
|
62
62
|
import { startUnitSupervision } from "./auto-timers.js";
|
|
63
63
|
import { runPostUnitVerification } from "./auto-verification.js";
|
|
64
|
-
import { postUnitPreVerification, postUnitPostVerification, } from "./auto-post-unit.js";
|
|
64
|
+
import { autoCommitUnit, postUnitPreVerification, postUnitPostVerification, } from "./auto-post-unit.js";
|
|
65
65
|
import { bootstrapAutoSession, openProjectDbIfPresent } from "./auto-start.js";
|
|
66
|
+
import { initHealthWidget } from "./health-widget.js";
|
|
66
67
|
import { autoLoop, resolveAgentEnd, resolveAgentEndCancelled, _resetPendingResolve, isSessionSwitchInFlight } from "./auto-loop.js";
|
|
68
|
+
import { runAutoLoopWithUok } from "./uok/kernel.js";
|
|
69
|
+
import { resolveUokFlags } from "./uok/flags.js";
|
|
67
70
|
import { WorktreeResolver, } from "./worktree-resolver.js";
|
|
68
71
|
import { reorderForCaching } from "./prompt-ordering.js";
|
|
69
72
|
// ─── Session State ─────────────────────────────────────────────────────────
|
|
@@ -359,10 +362,22 @@ function clearUnitTimeout() {
|
|
|
359
362
|
}
|
|
360
363
|
/** Build snapshot metric opts. */
|
|
361
364
|
function buildSnapshotOpts(_unitType, _unitId) {
|
|
365
|
+
const prefs = loadEffectiveGSDPreferences()?.preferences;
|
|
366
|
+
const uokFlags = resolveUokFlags(prefs);
|
|
362
367
|
return {
|
|
363
368
|
...(s.autoStartTime > 0 ? { autoSessionKey: String(s.autoStartTime) } : {}),
|
|
364
369
|
promptCharCount: s.lastPromptCharCount,
|
|
365
370
|
baselineCharCount: s.lastBaselineCharCount,
|
|
371
|
+
traceId: s.currentTraceId ?? undefined,
|
|
372
|
+
turnId: s.currentTurnId ?? undefined,
|
|
373
|
+
...(uokFlags.gitops
|
|
374
|
+
? {
|
|
375
|
+
gitAction: uokFlags.gitopsTurnAction,
|
|
376
|
+
gitPush: uokFlags.gitopsTurnPush,
|
|
377
|
+
gitStatus: s.lastGitActionStatus ?? undefined,
|
|
378
|
+
gitError: s.lastGitActionFailure ?? undefined,
|
|
379
|
+
}
|
|
380
|
+
: {}),
|
|
366
381
|
...(s.currentUnitRouting ?? {}),
|
|
367
382
|
};
|
|
368
383
|
}
|
|
@@ -397,6 +412,8 @@ function handleLostSessionLock(ctx, lockStatus) {
|
|
|
397
412
|
ctx?.ui.setStatus("gsd-auto", undefined);
|
|
398
413
|
ctx?.ui.setWidget("gsd-progress", undefined);
|
|
399
414
|
ctx?.ui.setFooter(undefined);
|
|
415
|
+
if (ctx)
|
|
416
|
+
initHealthWidget(ctx);
|
|
400
417
|
}
|
|
401
418
|
/**
|
|
402
419
|
* Lightweight cleanup after autoLoop exits via step-wizard break.
|
|
@@ -431,6 +448,7 @@ function cleanupAfterLoopExit(ctx) {
|
|
|
431
448
|
ctx.ui.setStatus("gsd-auto", undefined);
|
|
432
449
|
ctx.ui.setWidget("gsd-progress", undefined);
|
|
433
450
|
ctx.ui.setFooter(undefined);
|
|
451
|
+
initHealthWidget(ctx);
|
|
434
452
|
}
|
|
435
453
|
// Restore CWD out of worktree back to original project root
|
|
436
454
|
if (s.originalBasePath) {
|
|
@@ -501,17 +519,30 @@ export async function stopAuto(ctx, pi, reason) {
|
|
|
501
519
|
? { notify: ctx.ui.notify.bind(ctx.ui) }
|
|
502
520
|
: { notify: () => { } };
|
|
503
521
|
const resolver = buildResolver();
|
|
504
|
-
// Check if the milestone is complete
|
|
522
|
+
// Check if the milestone is complete. DB status is the authoritative
|
|
523
|
+
// signal — only a successful gsd_complete_milestone call flips it to
|
|
524
|
+
// "complete" (tools/complete-milestone.ts). SUMMARY file presence is
|
|
525
|
+
// NOT sufficient: a blocker placeholder stub or a partial write can
|
|
526
|
+
// leave a file behind without the milestone actually being done,
|
|
527
|
+
// which previously caused stopAuto to merge a failed milestone and
|
|
528
|
+
// emit a misleading metadata-only merge warning (#4175).
|
|
529
|
+
// DB-unavailable projects fall back to SUMMARY-file presence.
|
|
505
530
|
let milestoneComplete = false;
|
|
506
531
|
try {
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
const wtSummaryPath = resolveMilestoneFile(s.basePath, s.currentMilestoneId, "SUMMARY");
|
|
511
|
-
milestoneComplete = wtSummaryPath !== null;
|
|
532
|
+
if (isDbAvailable()) {
|
|
533
|
+
const dbRow = getMilestone(s.currentMilestoneId);
|
|
534
|
+
milestoneComplete = dbRow?.status === "complete";
|
|
512
535
|
}
|
|
513
536
|
else {
|
|
514
|
-
|
|
537
|
+
const summaryPath = resolveMilestoneFile(s.originalBasePath || s.basePath, s.currentMilestoneId, "SUMMARY");
|
|
538
|
+
if (!summaryPath) {
|
|
539
|
+
// Also check in the worktree path (SUMMARY may not be synced yet)
|
|
540
|
+
const wtSummaryPath = resolveMilestoneFile(s.basePath, s.currentMilestoneId, "SUMMARY");
|
|
541
|
+
milestoneComplete = wtSummaryPath !== null;
|
|
542
|
+
}
|
|
543
|
+
else {
|
|
544
|
+
milestoneComplete = true;
|
|
545
|
+
}
|
|
515
546
|
}
|
|
516
547
|
}
|
|
517
548
|
catch (err) {
|
|
@@ -676,6 +707,8 @@ export async function stopAuto(ctx, pi, reason) {
|
|
|
676
707
|
ctx?.ui.setStatus("gsd-auto", undefined);
|
|
677
708
|
ctx?.ui.setWidget("gsd-progress", undefined);
|
|
678
709
|
ctx?.ui.setFooter(undefined);
|
|
710
|
+
if (ctx)
|
|
711
|
+
initHealthWidget(ctx);
|
|
679
712
|
restoreProjectRootEnv();
|
|
680
713
|
restoreMilestoneLockEnv();
|
|
681
714
|
// Reset all session state in one call
|
|
@@ -762,6 +795,8 @@ export async function pauseAuto(ctx, _pi, _errorContext) {
|
|
|
762
795
|
ctx?.ui.setStatus("gsd-auto", "paused");
|
|
763
796
|
ctx?.ui.setWidget("gsd-progress", undefined);
|
|
764
797
|
ctx?.ui.setFooter(undefined);
|
|
798
|
+
if (ctx)
|
|
799
|
+
initHealthWidget(ctx);
|
|
765
800
|
const resumeCmd = s.stepMode ? "/gsd next" : "/gsd auto";
|
|
766
801
|
ctx?.ui.notify(`${s.stepMode ? "Step" : "Auto"}-mode paused (Escape). Type to interact, or ${resumeCmd} to resume.`, "info");
|
|
767
802
|
}
|
|
@@ -863,6 +898,7 @@ function buildLoopDeps() {
|
|
|
863
898
|
getMainBranch,
|
|
864
899
|
// Unit closeout + runtime records
|
|
865
900
|
closeoutUnit,
|
|
901
|
+
autoCommitUnit,
|
|
866
902
|
recordOutcome,
|
|
867
903
|
writeLock,
|
|
868
904
|
captureAvailableSkills,
|
|
@@ -1060,6 +1096,11 @@ export async function startAuto(ctx, pi, base, verboseMode, options) {
|
|
|
1060
1096
|
s.stepMode = requestedStepMode;
|
|
1061
1097
|
s.cmdCtx = ctx;
|
|
1062
1098
|
s.basePath = base;
|
|
1099
|
+
// Ensure the workflow-logger audit log is pinned to the project root
|
|
1100
|
+
// even when auto-mode is entered via a path that bypasses the
|
|
1101
|
+
// bootstrap/dynamic-tools ensureDbOpen() → setLogBasePath() chain
|
|
1102
|
+
// (e.g. /clear resume, hot-reload).
|
|
1103
|
+
setLogBasePath(base);
|
|
1063
1104
|
s.unitDispatchCount.clear();
|
|
1064
1105
|
s.unitLifetimeDispatches.clear();
|
|
1065
1106
|
if (!getLedger())
|
|
@@ -1138,7 +1179,13 @@ export async function startAuto(ctx, pi, base, verboseMode, options) {
|
|
|
1138
1179
|
writeLock(lockBase(), "resuming", s.currentMilestoneId ?? "unknown");
|
|
1139
1180
|
logCmuxEvent(loadEffectiveGSDPreferences()?.preferences, s.stepMode ? "Step-mode resumed." : "Auto-mode resumed.", "progress");
|
|
1140
1181
|
captureProjectRootEnv(s.originalBasePath || s.basePath);
|
|
1141
|
-
await
|
|
1182
|
+
await runAutoLoopWithUok({
|
|
1183
|
+
ctx,
|
|
1184
|
+
pi,
|
|
1185
|
+
s,
|
|
1186
|
+
deps: buildLoopDeps(),
|
|
1187
|
+
runLegacyLoop: autoLoop,
|
|
1188
|
+
});
|
|
1142
1189
|
cleanupAfterLoopExit(ctx);
|
|
1143
1190
|
return;
|
|
1144
1191
|
}
|
|
@@ -1162,7 +1209,13 @@ export async function startAuto(ctx, pi, base, verboseMode, options) {
|
|
|
1162
1209
|
}
|
|
1163
1210
|
logCmuxEvent(loadEffectiveGSDPreferences()?.preferences, requestedStepMode ? "Step-mode started." : "Auto-mode started.", "progress");
|
|
1164
1211
|
// Dispatch the first unit
|
|
1165
|
-
await
|
|
1212
|
+
await runAutoLoopWithUok({
|
|
1213
|
+
ctx,
|
|
1214
|
+
pi,
|
|
1215
|
+
s,
|
|
1216
|
+
deps: buildLoopDeps(),
|
|
1217
|
+
runLegacyLoop: autoLoop,
|
|
1218
|
+
});
|
|
1166
1219
|
cleanupAfterLoopExit(ctx);
|
|
1167
1220
|
}
|
|
1168
1221
|
// ─── Agent End Handler ────────────────────────────────────────────────────────
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
// GSD2 — Extension registration: wires all GSD tools, commands, and hooks into pi
|
|
2
|
-
import { registerGSDCommand } from "../commands.js";
|
|
3
2
|
import { registerExitCommand } from "../exit-command.js";
|
|
4
3
|
import { registerWorktreeCommand } from "../worktree-command.js";
|
|
4
|
+
import { loadEcosystemExtensions } from "../ecosystem/loader.js";
|
|
5
5
|
import { registerDbTools } from "./db-tools.js";
|
|
6
6
|
import { registerDynamicTools } from "./dynamic-tools.js";
|
|
7
7
|
import { registerJournalTools } from "./journal-tools.js";
|
|
@@ -9,6 +9,7 @@ import { registerQueryTools } from "./query-tools.js";
|
|
|
9
9
|
import { registerHooks } from "./register-hooks.js";
|
|
10
10
|
import { registerShortcuts } from "./register-shortcuts.js";
|
|
11
11
|
import { writeCrashLog } from "./crash-log.js";
|
|
12
|
+
import { logWarning } from "../workflow-logger.js";
|
|
12
13
|
export { writeCrashLog } from "./crash-log.js";
|
|
13
14
|
export function handleRecoverableExtensionProcessError(err) {
|
|
14
15
|
if (err.code === "EPIPE") {
|
|
@@ -52,20 +53,41 @@ function installEpipeGuard() {
|
|
|
52
53
|
}
|
|
53
54
|
}
|
|
54
55
|
export function registerGsdExtension(pi) {
|
|
55
|
-
registerGSDCommand
|
|
56
|
+
// Note: registerGSDCommand is called by index.ts before this function,
|
|
57
|
+
// so we intentionally skip it here to avoid double-registration.
|
|
56
58
|
registerWorktreeCommand(pi);
|
|
57
59
|
registerExitCommand(pi);
|
|
58
60
|
installEpipeGuard();
|
|
61
|
+
// Ecosystem handlers captured by the GSDExtensionAPI wrapper for the
|
|
62
|
+
// GSD-owned `before_agent_start` dispatch step (#3338).
|
|
63
|
+
const ecosystemHandlers = [];
|
|
59
64
|
pi.registerCommand("kill", {
|
|
60
65
|
description: "Exit GSD immediately (no cleanup)",
|
|
61
66
|
handler: async (_args, _ctx) => {
|
|
62
67
|
process.exit(0);
|
|
63
68
|
},
|
|
64
69
|
});
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
70
|
+
// Wrap non-critical registrations individually so one failure
|
|
71
|
+
// doesn't prevent the others from loading.
|
|
72
|
+
const nonCriticalRegistrations = [
|
|
73
|
+
["dynamic-tools", () => registerDynamicTools(pi)],
|
|
74
|
+
["db-tools", () => registerDbTools(pi)],
|
|
75
|
+
["journal-tools", () => registerJournalTools(pi)],
|
|
76
|
+
["query-tools", () => registerQueryTools(pi)],
|
|
77
|
+
["shortcuts", () => registerShortcuts(pi)],
|
|
78
|
+
["hooks", () => registerHooks(pi, ecosystemHandlers)],
|
|
79
|
+
["ecosystem", () => {
|
|
80
|
+
void loadEcosystemExtensions(pi, ecosystemHandlers).catch((err) => {
|
|
81
|
+
logWarning("ecosystem", `loader failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
82
|
+
});
|
|
83
|
+
}],
|
|
84
|
+
];
|
|
85
|
+
for (const [name, register] of nonCriticalRegistrations) {
|
|
86
|
+
try {
|
|
87
|
+
register();
|
|
88
|
+
}
|
|
89
|
+
catch (err) {
|
|
90
|
+
logWarning("bootstrap", `Failed to register ${name}: ${err instanceof Error ? err.message : String(err)}`);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
71
93
|
}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { join } from "node:path";
|
|
2
2
|
import { isToolCallEventType } from "@gsd/pi-coding-agent";
|
|
3
|
+
import { updateSnapshot } from "../ecosystem/gsd-extension-api.js";
|
|
4
|
+
import { getEcosystemReadyPromise } from "../ecosystem/loader.js";
|
|
3
5
|
import { buildMilestoneFileName, resolveMilestonePath, resolveSliceFile, resolveSlicePath } from "../paths.js";
|
|
4
6
|
import { buildBeforeAgentStartResult } from "./system-context.js";
|
|
5
7
|
import { handleAgentEnd } from "./agent-end-recovery.js";
|
|
@@ -29,7 +31,7 @@ async function syncServiceTierStatus(ctx) {
|
|
|
29
31
|
const { getEffectiveServiceTier, formatServiceTierFooterStatus } = await import("../service-tier.js");
|
|
30
32
|
ctx.ui.setStatus("gsd-fast", formatServiceTierFooterStatus(getEffectiveServiceTier(), ctx.model?.id));
|
|
31
33
|
}
|
|
32
|
-
export function registerHooks(pi) {
|
|
34
|
+
export function registerHooks(pi, ecosystemHandlers) {
|
|
33
35
|
pi.on("session_start", async (_event, ctx) => {
|
|
34
36
|
initNotificationStore(process.cwd());
|
|
35
37
|
installNotifyInterceptor(ctx);
|
|
@@ -85,7 +87,44 @@ export function registerHooks(pi) {
|
|
|
85
87
|
loadToolApiKeys();
|
|
86
88
|
});
|
|
87
89
|
pi.on("before_agent_start", async (event, ctx) => {
|
|
88
|
-
|
|
90
|
+
// Wait for ecosystem loader to finish (no-op after first turn).
|
|
91
|
+
await getEcosystemReadyPromise();
|
|
92
|
+
// GSD's own context injection (existing behavior — unchanged).
|
|
93
|
+
const gsdResult = await buildBeforeAgentStartResult(event, ctx);
|
|
94
|
+
// Refresh the snapshot used by ecosystem getPhase()/getActiveUnit().
|
|
95
|
+
// deriveState has its own ~100ms cache so this is cheap on repeat calls.
|
|
96
|
+
try {
|
|
97
|
+
const state = await deriveState(process.cwd());
|
|
98
|
+
updateSnapshot(state);
|
|
99
|
+
}
|
|
100
|
+
catch {
|
|
101
|
+
updateSnapshot(null);
|
|
102
|
+
}
|
|
103
|
+
// Chain ecosystem handlers using pi's runner.ts chaining protocol:
|
|
104
|
+
// each handler sees the systemPrompt mutated by prior handlers.
|
|
105
|
+
let currentSystemPrompt = gsdResult?.systemPrompt ?? event.systemPrompt;
|
|
106
|
+
// `any` because pi's BeforeAgentStartEventResult.message uses an internal
|
|
107
|
+
// CustomMessage type that's not re-exported (see ecosystem/gsd-extension-api.ts).
|
|
108
|
+
let lastMessage = gsdResult?.message;
|
|
109
|
+
for (const handler of ecosystemHandlers) {
|
|
110
|
+
try {
|
|
111
|
+
const r = await handler({ ...event, systemPrompt: currentSystemPrompt }, ctx);
|
|
112
|
+
if (r?.systemPrompt !== undefined)
|
|
113
|
+
currentSystemPrompt = r.systemPrompt;
|
|
114
|
+
if (r?.message)
|
|
115
|
+
lastMessage = r.message;
|
|
116
|
+
}
|
|
117
|
+
catch (err) {
|
|
118
|
+
safetyLogWarning("ecosystem", `before_agent_start handler failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
// Compose result. Return undefined if nothing changed (preserves runner contract).
|
|
122
|
+
if (currentSystemPrompt === event.systemPrompt && !lastMessage)
|
|
123
|
+
return undefined;
|
|
124
|
+
return {
|
|
125
|
+
systemPrompt: currentSystemPrompt !== event.systemPrompt ? currentSystemPrompt : undefined,
|
|
126
|
+
message: lastMessage,
|
|
127
|
+
};
|
|
89
128
|
});
|
|
90
129
|
pi.on("agent_end", async (event, ctx) => {
|
|
91
130
|
resetToolCallLoopGuard();
|
|
@@ -4,7 +4,7 @@ import { join } from "node:path";
|
|
|
4
4
|
import { loadRegistry } from "../workflow-templates.js";
|
|
5
5
|
import { resolveProjectRoot } from "../worktree.js";
|
|
6
6
|
const gsdHome = process.env.GSD_HOME || join(homedir(), ".gsd");
|
|
7
|
-
export const GSD_COMMAND_DESCRIPTION = "GSD — Get Shit Done: /gsd help|start|templates|next|auto|stop|pause|status|widget|visualize|queue|quick|discuss|capture|triage|dispatch|history|undo|undo-task|reset-slice|rate|skip|export|cleanup|model|mode|prefs|config|keys|hooks|run-hook|skill-health|doctor|logs|forensics|changelog|migrate|remote|steer|knowledge|new-milestone|parallel|cmux|park|unpark|init|setup|inspect|extensions|update|fast|mcp|rethink|codebase|notifications";
|
|
7
|
+
export const GSD_COMMAND_DESCRIPTION = "GSD — Get Shit Done: /gsd help|start|templates|next|auto|stop|pause|status|widget|visualize|queue|quick|discuss|capture|triage|dispatch|history|undo|undo-task|reset-slice|rate|skip|export|cleanup|model|mode|prefs|config|keys|hooks|run-hook|skill-health|doctor|logs|forensics|changelog|migrate|remote|steer|knowledge|new-milestone|parallel|cmux|park|unpark|init|setup|inspect|extensions|update|fast|mcp|rethink|codebase|notifications|ship|do|session-report|backlog|pr-branch|add-tests";
|
|
8
8
|
export const TOP_LEVEL_SUBCOMMANDS = [
|
|
9
9
|
{ cmd: "help", desc: "Categorized command reference with descriptions" },
|
|
10
10
|
{ cmd: "next", desc: "Explicit step mode (same as /gsd)" },
|
|
@@ -62,6 +62,12 @@ export const TOP_LEVEL_SUBCOMMANDS = [
|
|
|
62
62
|
{ cmd: "rethink", desc: "Conversational project reorganization — reorder, park, discard, add milestones" },
|
|
63
63
|
{ cmd: "workflow", desc: "Custom workflow lifecycle (new, run, list, validate, pause, resume)" },
|
|
64
64
|
{ cmd: "codebase", desc: "Generate, refresh, and inspect the codebase map cache (.gsd/CODEBASE.md)" },
|
|
65
|
+
{ cmd: "ship", desc: "Create PR from milestone artifacts and open for review" },
|
|
66
|
+
{ cmd: "do", desc: "Route freeform text to the right GSD command" },
|
|
67
|
+
{ cmd: "session-report", desc: "Session cost, tokens, and work summary" },
|
|
68
|
+
{ cmd: "backlog", desc: "Manage backlog items (add, promote, remove, list)" },
|
|
69
|
+
{ cmd: "pr-branch", desc: "Create clean PR branch filtering .gsd/ commits" },
|
|
70
|
+
{ cmd: "add-tests", desc: "Generate tests for completed slices" },
|
|
65
71
|
];
|
|
66
72
|
const NESTED_COMPLETIONS = {
|
|
67
73
|
auto: [
|
|
@@ -231,6 +237,25 @@ const NESTED_COMPLETIONS = {
|
|
|
231
237
|
{ cmd: "stats", desc: "Show file count, description coverage, and generation time" },
|
|
232
238
|
{ cmd: "help", desc: "Show usage and available subcommands" },
|
|
233
239
|
],
|
|
240
|
+
ship: [
|
|
241
|
+
{ cmd: "--dry-run", desc: "Preview PR without creating" },
|
|
242
|
+
{ cmd: "--draft", desc: "Open as draft PR" },
|
|
243
|
+
{ cmd: "--base", desc: "Override target branch (default: main)" },
|
|
244
|
+
{ cmd: "--force", desc: "Ship even with pending tasks" },
|
|
245
|
+
],
|
|
246
|
+
"session-report": [
|
|
247
|
+
{ cmd: "--json", desc: "Machine-readable JSON output" },
|
|
248
|
+
{ cmd: "--save", desc: "Save report to .gsd/reports/" },
|
|
249
|
+
],
|
|
250
|
+
backlog: [
|
|
251
|
+
{ cmd: "add", desc: "Add item to backlog" },
|
|
252
|
+
{ cmd: "promote", desc: "Promote backlog item to active slice" },
|
|
253
|
+
{ cmd: "remove", desc: "Remove backlog item" },
|
|
254
|
+
],
|
|
255
|
+
"pr-branch": [
|
|
256
|
+
{ cmd: "--dry-run", desc: "Preview what would be filtered" },
|
|
257
|
+
{ cmd: "--name", desc: "Custom branch name" },
|
|
258
|
+
],
|
|
234
259
|
};
|
|
235
260
|
function filterOptions(partial, options, prefix = "") {
|
|
236
261
|
const normalizedPrefix = prefix ? `${prefix} ` : "";
|
|
@@ -8,6 +8,9 @@ import { handleExport } from "../../export.js";
|
|
|
8
8
|
import { handleHistory } from "../../history.js";
|
|
9
9
|
import { handleUndo } from "../../undo.js";
|
|
10
10
|
import { handleRemote } from "../../../remote-questions/mod.js";
|
|
11
|
+
import { handleShip } from "../../commands-ship.js";
|
|
12
|
+
import { handleSessionReport } from "../../commands-session-report.js";
|
|
13
|
+
import { handlePrBranch } from "../../commands-pr-branch.js";
|
|
11
14
|
import { projectRoot } from "../context.js";
|
|
12
15
|
export async function handleOpsCommand(trimmed, ctx, pi) {
|
|
13
16
|
if (trimmed === "init") {
|
|
@@ -213,5 +216,27 @@ Examples:
|
|
|
213
216
|
await handleCodebase(trimmed.replace(/^codebase\s*/, "").trim(), ctx, pi);
|
|
214
217
|
return true;
|
|
215
218
|
}
|
|
219
|
+
if (trimmed === "ship" || trimmed.startsWith("ship ")) {
|
|
220
|
+
await handleShip(trimmed.replace(/^ship\s*/, "").trim(), ctx, pi);
|
|
221
|
+
return true;
|
|
222
|
+
}
|
|
223
|
+
if (trimmed === "session-report" || trimmed.startsWith("session-report ")) {
|
|
224
|
+
await handleSessionReport(trimmed.replace(/^session-report\s*/, "").trim(), ctx);
|
|
225
|
+
return true;
|
|
226
|
+
}
|
|
227
|
+
if (trimmed === "pr-branch" || trimmed.startsWith("pr-branch ")) {
|
|
228
|
+
await handlePrBranch(trimmed.replace(/^pr-branch\s*/, "").trim(), ctx);
|
|
229
|
+
return true;
|
|
230
|
+
}
|
|
231
|
+
if (trimmed === "add-tests" || trimmed.startsWith("add-tests ")) {
|
|
232
|
+
const { handleAddTests } = await import("../../commands-add-tests.js");
|
|
233
|
+
await handleAddTests(trimmed.replace(/^add-tests\s*/, "").trim(), ctx, pi);
|
|
234
|
+
return true;
|
|
235
|
+
}
|
|
236
|
+
if (trimmed === "extract-learnings" || trimmed.startsWith("extract-learnings ")) {
|
|
237
|
+
const { handleExtractLearnings } = await import("../../commands-extract-learnings.js");
|
|
238
|
+
await handleExtractLearnings(trimmed.replace(/^extract-learnings\s*/, "").trim(), ctx, pi);
|
|
239
|
+
return true;
|
|
240
|
+
}
|
|
216
241
|
return false;
|
|
217
242
|
}
|