gsd-pi 2.74.0-dev.b741afb → 2.74.0-dev.b7c5f96
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/resources/extensions/gsd/activity-log.js +16 -0
- package/dist/resources/extensions/gsd/auto/loop.js +147 -10
- package/dist/resources/extensions/gsd/auto/phases.js +164 -9
- package/dist/resources/extensions/gsd/auto/session.js +10 -0
- package/dist/resources/extensions/gsd/auto-dispatch.js +11 -1
- package/dist/resources/extensions/gsd/auto-model-selection.js +54 -8
- package/dist/resources/extensions/gsd/auto-post-unit.js +215 -8
- package/dist/resources/extensions/gsd/auto-recovery.js +24 -10
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +18 -0
- package/dist/resources/extensions/gsd/auto-verification.js +100 -2
- package/dist/resources/extensions/gsd/auto-worktree.js +2 -0
- package/dist/resources/extensions/gsd/auto.js +28 -2
- package/dist/resources/extensions/gsd/bootstrap/provider-error-resume.js +5 -3
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +10 -1
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +61 -9
- package/dist/resources/extensions/gsd/cache.js +16 -5
- package/dist/resources/extensions/gsd/commands/catalog.js +6 -1
- package/dist/resources/extensions/gsd/commands/handlers/core.js +5 -1
- package/dist/resources/extensions/gsd/commands/handlers/ops.js +5 -0
- package/dist/resources/extensions/gsd/commands-extract-learnings.js +225 -0
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +51 -4
- package/dist/resources/extensions/gsd/docs/preferences-reference.md +16 -1
- 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 +98 -7
- package/dist/resources/extensions/gsd/gsd-db.js +260 -2
- package/dist/resources/extensions/gsd/guided-flow.js +31 -6
- package/dist/resources/extensions/gsd/init-wizard.js +1 -0
- package/dist/resources/extensions/gsd/journal.js +27 -0
- package/dist/resources/extensions/gsd/metrics.js +19 -0
- package/dist/resources/extensions/gsd/parallel-orchestrator.js +33 -1
- package/dist/resources/extensions/gsd/preferences-models.js +20 -3
- package/dist/resources/extensions/gsd/preferences-types.js +2 -0
- package/dist/resources/extensions/gsd/preferences-validation.js +118 -2
- package/dist/resources/extensions/gsd/preferences.js +31 -0
- package/dist/resources/extensions/gsd/safety/evidence-collector.js +15 -30
- package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +12 -2
- package/dist/resources/extensions/gsd/templates/PREFERENCES.md +19 -0
- package/dist/resources/extensions/gsd/tools/complete-slice.js +5 -0
- package/dist/resources/extensions/gsd/tools/validate-milestone.js +39 -4
- 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/ttsr/ttsr-manager.js +3 -1
- package/dist/tsconfig.extensions.tsbuildinfo +1 -1
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +8 -8
- 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 +8 -8
- 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 +1 -1
- package/packages/mcp-server/dist/readers/graph.d.ts +1 -1
- package/packages/mcp-server/dist/readers/graph.d.ts.map +1 -1
- package/packages/mcp-server/dist/readers/graph.js +107 -0
- package/packages/mcp-server/dist/readers/graph.js.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +88 -6
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/src/readers/graph.test.ts +178 -0
- package/packages/mcp-server/src/readers/graph.ts +148 -1
- package/packages/mcp-server/src/workflow-tools.ts +95 -10
- package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-ai/dist/index.d.ts +1 -9
- package/packages/pi-ai/dist/index.d.ts.map +1 -1
- package/packages/pi-ai/dist/index.js +1 -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/scripts/generate-models.ts +74 -40
- package/packages/pi-ai/src/index.ts +1 -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/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.js +8 -2
- package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js +472 -0
- package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js.map +1 -1
- 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/__tests__/chat-frame-compaction-tone.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.js +61 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +11 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts +1 -0
- 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 +23 -9
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts +11 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js +53 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.d.ts +8 -5
- package/packages/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.js +27 -13
- package/packages/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts +8 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +68 -8
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js +22 -22
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js.map +1 -1
- 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 +232 -18
- 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 +14 -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 +70 -6
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/pi-coding-agent/src/core/agent-session.ts +12 -6
- package/packages/pi-coding-agent/src/core/chat-controller-ordering.test.ts +612 -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/__tests__/chat-frame-compaction-tone.test.ts +92 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +19 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/assistant-message.ts +25 -10
- package/packages/pi-coding-agent/src/modes/interactive/components/chat-frame.ts +75 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/compaction-summary-message.ts +36 -15
- package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +83 -7
- package/packages/pi-coding-agent/src/modes/interactive/components/user-message.ts +23 -26
- package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +298 -41
- 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 +92 -6
- package/packages/pi-coding-agent/src/types/ambient-modules.d.ts +69 -0
- package/packages/pi-coding-agent/tsconfig.json +2 -2
- package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-tui/dist/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +9 -2
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/src/tui.ts +9 -1
- package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
- package/src/resources/extensions/gsd/activity-log.ts +21 -0
- package/src/resources/extensions/gsd/auto/loop-deps.ts +4 -0
- package/src/resources/extensions/gsd/auto/loop.ts +159 -10
- package/src/resources/extensions/gsd/auto/phases.ts +193 -9
- package/src/resources/extensions/gsd/auto/session.ts +10 -0
- package/src/resources/extensions/gsd/auto-dispatch.ts +16 -6
- package/src/resources/extensions/gsd/auto-model-selection.ts +69 -8
- package/src/resources/extensions/gsd/auto-post-unit.ts +226 -9
- package/src/resources/extensions/gsd/auto-recovery.ts +29 -9
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +25 -1
- package/src/resources/extensions/gsd/auto-verification.ts +129 -2
- package/src/resources/extensions/gsd/auto-worktree.ts +1 -0
- package/src/resources/extensions/gsd/auto.ts +34 -2
- package/src/resources/extensions/gsd/bootstrap/provider-error-resume.ts +5 -3
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +15 -1
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +72 -8
- package/src/resources/extensions/gsd/cache.ts +16 -5
- package/src/resources/extensions/gsd/commands/catalog.ts +6 -1
- package/src/resources/extensions/gsd/commands/handlers/core.ts +5 -1
- package/src/resources/extensions/gsd/commands/handlers/ops.ts +5 -0
- package/src/resources/extensions/gsd/commands-extract-learnings.ts +304 -0
- package/src/resources/extensions/gsd/commands-prefs-wizard.ts +58 -4
- package/src/resources/extensions/gsd/docs/preferences-reference.md +16 -1
- 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 +139 -12
- package/src/resources/extensions/gsd/gsd-db.ts +321 -3
- package/src/resources/extensions/gsd/guided-flow.ts +36 -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/metrics.ts +26 -0
- package/src/resources/extensions/gsd/parallel-orchestrator.ts +40 -1
- package/src/resources/extensions/gsd/preferences-models.ts +20 -3
- package/src/resources/extensions/gsd/preferences-types.ts +38 -0
- package/src/resources/extensions/gsd/preferences-validation.ts +117 -2
- package/src/resources/extensions/gsd/preferences.ts +34 -0
- package/src/resources/extensions/gsd/safety/evidence-collector.ts +15 -31
- 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/templates/PREFERENCES.md +19 -0
- package/src/resources/extensions/gsd/tests/artifacts-table-preserved-on-cache-invalidate.test.ts +177 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +7 -3
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +20 -0
- package/src/resources/extensions/gsd/tests/auto-project-root-env.test.ts +7 -3
- package/src/resources/extensions/gsd/tests/auto-retry-mcp-churn-fixes.test.ts +272 -0
- package/src/resources/extensions/gsd/tests/auto-warning-noise-regression.test.ts +117 -0
- package/src/resources/extensions/gsd/tests/cold-resume-db-reopen.test.ts +6 -2
- package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +340 -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/finalize-timeout-guard.test.ts +10 -7
- 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/journal-integration.test.ts +3 -3
- 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/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 +145 -0
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +57 -2
- package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/token-profile.test.ts +8 -5
- 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-write-order.test.ts +39 -0
- package/src/resources/extensions/gsd/tools/complete-slice.ts +9 -2
- package/src/resources/extensions/gsd/tools/validate-milestone.ts +48 -3
- 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/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/{XnHY5eXUsTCFmNodWHetD → k1VZ0h-SB6uWSZgPhgNwi}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{XnHY5eXUsTCFmNodWHetD → k1VZ0h-SB6uWSZgPhgNwi}/_ssgManifest.js +0 -0
|
@@ -24,6 +24,8 @@ import { writeVerificationJSON } from "./verification-evidence.js";
|
|
|
24
24
|
import { logWarning } from "./workflow-logger.js";
|
|
25
25
|
import { runPostExecutionChecks } from "./post-execution-checks.js";
|
|
26
26
|
import { join } from "node:path";
|
|
27
|
+
import { resolveUokFlags } from "./uok/flags.js";
|
|
28
|
+
import { UokGateRunner } from "./uok/gate-runner.js";
|
|
27
29
|
function isInfraVerificationFailure(stderr) {
|
|
28
30
|
return /\b(ENOENT|ENOTFOUND|ETIMEDOUT|ECONNRESET|EAI_AGAIN|spawn\s+\S+\s+ENOENT|command not found)\b/i.test(stderr);
|
|
29
31
|
}
|
|
@@ -43,6 +45,31 @@ function isInfraVerificationFailure(stderr) {
|
|
|
43
45
|
*/
|
|
44
46
|
async function runValidateMilestonePostCheck(vctx, pauseAuto) {
|
|
45
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
|
+
};
|
|
46
73
|
if (!s.currentUnit)
|
|
47
74
|
return "continue";
|
|
48
75
|
const { milestone: mid } = parseUnitId(s.currentUnit.id);
|
|
@@ -55,17 +82,22 @@ async function runValidateMilestonePostCheck(vctx, pauseAuto) {
|
|
|
55
82
|
if (!validationContent)
|
|
56
83
|
return "continue";
|
|
57
84
|
const verdict = extractVerdict(validationContent);
|
|
58
|
-
if (verdict !== "needs-remediation")
|
|
85
|
+
if (verdict !== "needs-remediation") {
|
|
86
|
+
await persistMilestoneValidationGate("pass", "none", `milestone validation verdict is ${verdict}; no remediation loop risk`, "", mid);
|
|
59
87
|
return "continue";
|
|
88
|
+
}
|
|
60
89
|
const incompleteSliceCount = await countIncompleteSlices(s.basePath, mid);
|
|
61
90
|
// If any non-closed slices exist, the agent successfully queued remediation
|
|
62
91
|
// work — proceed normally. The state machine will execute those slices and
|
|
63
92
|
// re-validate per the #3596/#3670 fix.
|
|
64
|
-
if (incompleteSliceCount > 0)
|
|
93
|
+
if (incompleteSliceCount > 0) {
|
|
94
|
+
await persistMilestoneValidationGate("pass", "none", `remediation slices present (${incompleteSliceCount}); validation can continue`, "", mid);
|
|
65
95
|
return "continue";
|
|
96
|
+
}
|
|
66
97
|
ctx.ui.notify(`Milestone ${mid} validation returned verdict=needs-remediation but no remediation slices were added. Pausing for human review.`, "error");
|
|
67
98
|
process.stderr.write(`validate-milestone: pausing — verdict=needs-remediation with no incomplete slices for ${mid}. ` +
|
|
68
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);
|
|
69
101
|
await pauseAuto(ctx, pi);
|
|
70
102
|
return "pause";
|
|
71
103
|
}
|
|
@@ -122,6 +154,7 @@ export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
|
122
154
|
try {
|
|
123
155
|
const effectivePrefs = loadEffectiveGSDPreferences();
|
|
124
156
|
const prefs = effectivePrefs?.preferences;
|
|
157
|
+
const uokFlags = resolveUokFlags(prefs);
|
|
125
158
|
// Read task plan verify field
|
|
126
159
|
const { milestone: mid, slice: sid, task: tid } = parseUnitId(s.currentUnit.id);
|
|
127
160
|
let taskPlanVerify;
|
|
@@ -153,6 +186,35 @@ export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
|
153
186
|
process.stderr.write(` [${w.severity}] ${w.name}: ${w.title}\n`);
|
|
154
187
|
}
|
|
155
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
|
+
}
|
|
156
218
|
// Auto-fix retry preferences
|
|
157
219
|
const autoFixEnabled = prefs?.verification_auto_fix !== false;
|
|
158
220
|
const maxRetries = typeof prefs?.verification_max_retries === "number"
|
|
@@ -253,6 +315,42 @@ export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
|
253
315
|
: "⚠";
|
|
254
316
|
process.stderr.write(`gsd-post-exec: ${checkEmoji} [${check.category}] ${check.target}: ${check.message}\n`);
|
|
255
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
|
+
}
|
|
256
354
|
// Check for blocking failures
|
|
257
355
|
if (postExecResult.status === "fail") {
|
|
258
356
|
postExecBlockingFailure = true;
|
|
@@ -65,6 +65,8 @@ import { autoCommitUnit, postUnitPreVerification, postUnitPostVerification, } fr
|
|
|
65
65
|
import { bootstrapAutoSession, openProjectDbIfPresent } from "./auto-start.js";
|
|
66
66
|
import { initHealthWidget } from "./health-widget.js";
|
|
67
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";
|
|
68
70
|
import { WorktreeResolver, } from "./worktree-resolver.js";
|
|
69
71
|
import { reorderForCaching } from "./prompt-ordering.js";
|
|
70
72
|
// ─── Session State ─────────────────────────────────────────────────────────
|
|
@@ -360,10 +362,22 @@ function clearUnitTimeout() {
|
|
|
360
362
|
}
|
|
361
363
|
/** Build snapshot metric opts. */
|
|
362
364
|
function buildSnapshotOpts(_unitType, _unitId) {
|
|
365
|
+
const prefs = loadEffectiveGSDPreferences()?.preferences;
|
|
366
|
+
const uokFlags = resolveUokFlags(prefs);
|
|
363
367
|
return {
|
|
364
368
|
...(s.autoStartTime > 0 ? { autoSessionKey: String(s.autoStartTime) } : {}),
|
|
365
369
|
promptCharCount: s.lastPromptCharCount,
|
|
366
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
|
+
: {}),
|
|
367
381
|
...(s.currentUnitRouting ?? {}),
|
|
368
382
|
};
|
|
369
383
|
}
|
|
@@ -1165,7 +1179,13 @@ export async function startAuto(ctx, pi, base, verboseMode, options) {
|
|
|
1165
1179
|
writeLock(lockBase(), "resuming", s.currentMilestoneId ?? "unknown");
|
|
1166
1180
|
logCmuxEvent(loadEffectiveGSDPreferences()?.preferences, s.stepMode ? "Step-mode resumed." : "Auto-mode resumed.", "progress");
|
|
1167
1181
|
captureProjectRootEnv(s.originalBasePath || s.basePath);
|
|
1168
|
-
await
|
|
1182
|
+
await runAutoLoopWithUok({
|
|
1183
|
+
ctx,
|
|
1184
|
+
pi,
|
|
1185
|
+
s,
|
|
1186
|
+
deps: buildLoopDeps(),
|
|
1187
|
+
runLegacyLoop: autoLoop,
|
|
1188
|
+
});
|
|
1169
1189
|
cleanupAfterLoopExit(ctx);
|
|
1170
1190
|
return;
|
|
1171
1191
|
}
|
|
@@ -1189,7 +1209,13 @@ export async function startAuto(ctx, pi, base, verboseMode, options) {
|
|
|
1189
1209
|
}
|
|
1190
1210
|
logCmuxEvent(loadEffectiveGSDPreferences()?.preferences, requestedStepMode ? "Step-mode started." : "Auto-mode started.", "progress");
|
|
1191
1211
|
// Dispatch the first unit
|
|
1192
|
-
await
|
|
1212
|
+
await runAutoLoopWithUok({
|
|
1213
|
+
ctx,
|
|
1214
|
+
pi,
|
|
1215
|
+
s,
|
|
1216
|
+
deps: buildLoopDeps(),
|
|
1217
|
+
runLegacyLoop: autoLoop,
|
|
1218
|
+
});
|
|
1193
1219
|
cleanupAfterLoopExit(ctx);
|
|
1194
1220
|
}
|
|
1195
1221
|
// ─── Agent End Handler ────────────────────────────────────────────────────────
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { getAutoDashboardData, startAuto } from "../auto.js";
|
|
2
2
|
import { resetTransientRetryState } from "./agent-end-recovery.js";
|
|
3
|
+
import { resetSessionTimeoutState } from "../auto/phases.js";
|
|
3
4
|
const defaultDeps = {
|
|
4
5
|
getSnapshot: () => getAutoDashboardData(),
|
|
5
6
|
startAuto,
|
|
@@ -14,10 +15,11 @@ export async function resumeAutoAfterProviderDelay(pi, ctx, deps = defaultDeps)
|
|
|
14
15
|
ctx.ui.notify("Provider error recovery delay elapsed, but no paused auto-mode base path was available. Leaving auto-mode paused.", "warning");
|
|
15
16
|
return "missing-base";
|
|
16
17
|
}
|
|
17
|
-
// Reset
|
|
18
|
-
//
|
|
19
|
-
//
|
|
18
|
+
// Reset retry counters before restarting — without this, counters
|
|
19
|
+
// accumulate across pause/resume cycles and permanently lock out
|
|
20
|
+
// auto-resume after their respective MAX thresholds.
|
|
20
21
|
resetTransientRetryState();
|
|
22
|
+
resetSessionTimeoutState();
|
|
21
23
|
await deps.startAuto(ctx, pi, snapshot.basePath, false, { step: snapshot.stepMode });
|
|
22
24
|
return "resumed";
|
|
23
25
|
}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
// GSD2 — Extension registration: wires all GSD tools, commands, and hooks into pi
|
|
2
2
|
import { registerExitCommand } from "../exit-command.js";
|
|
3
3
|
import { registerWorktreeCommand } from "../worktree-command.js";
|
|
4
|
+
import { loadEcosystemExtensions } from "../ecosystem/loader.js";
|
|
4
5
|
import { registerDbTools } from "./db-tools.js";
|
|
5
6
|
import { registerDynamicTools } from "./dynamic-tools.js";
|
|
6
7
|
import { registerJournalTools } from "./journal-tools.js";
|
|
@@ -57,6 +58,9 @@ export function registerGsdExtension(pi) {
|
|
|
57
58
|
registerWorktreeCommand(pi);
|
|
58
59
|
registerExitCommand(pi);
|
|
59
60
|
installEpipeGuard();
|
|
61
|
+
// Ecosystem handlers captured by the GSDExtensionAPI wrapper for the
|
|
62
|
+
// GSD-owned `before_agent_start` dispatch step (#3338).
|
|
63
|
+
const ecosystemHandlers = [];
|
|
60
64
|
pi.registerCommand("kill", {
|
|
61
65
|
description: "Exit GSD immediately (no cleanup)",
|
|
62
66
|
handler: async (_args, _ctx) => {
|
|
@@ -71,7 +75,12 @@ export function registerGsdExtension(pi) {
|
|
|
71
75
|
["journal-tools", () => registerJournalTools(pi)],
|
|
72
76
|
["query-tools", () => registerQueryTools(pi)],
|
|
73
77
|
["shortcuts", () => registerShortcuts(pi)],
|
|
74
|
-
["hooks", () => registerHooks(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
|
+
}],
|
|
75
84
|
];
|
|
76
85
|
for (const [name, register] of nonCriticalRegistrations) {
|
|
77
86
|
try {
|
|
@@ -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);
|
|
@@ -39,8 +41,12 @@ export function registerHooks(pi) {
|
|
|
39
41
|
resetToolCallLoopGuard();
|
|
40
42
|
resetAskUserQuestionsCache();
|
|
41
43
|
await syncServiceTierStatus(ctx);
|
|
42
|
-
|
|
43
|
-
|
|
44
|
+
// Skip MCP auto-prep when running inside an auto-worktree (see session_switch below).
|
|
45
|
+
const { isInAutoWorktree } = await import("../auto-worktree.js");
|
|
46
|
+
if (!isInAutoWorktree(process.cwd())) {
|
|
47
|
+
const { prepareWorkflowMcpForProject } = await import("../workflow-mcp-auto-prep.js");
|
|
48
|
+
prepareWorkflowMcpForProject(ctx, process.cwd());
|
|
49
|
+
}
|
|
44
50
|
// Apply show_token_cost preference (#1515)
|
|
45
51
|
try {
|
|
46
52
|
const { loadEffectiveGSDPreferences } = await import("../preferences.js");
|
|
@@ -80,12 +86,56 @@ export function registerHooks(pi) {
|
|
|
80
86
|
resetAskUserQuestionsCache();
|
|
81
87
|
clearDiscussionFlowState();
|
|
82
88
|
await syncServiceTierStatus(ctx);
|
|
83
|
-
|
|
84
|
-
|
|
89
|
+
// Skip MCP auto-prep when running inside an auto-worktree. The worktree
|
|
90
|
+
// already has .mcp.json from createAutoWorktree, and re-running the writer
|
|
91
|
+
// post-chdir rewrites the file mid-run (non-idempotent due to cwd-relative
|
|
92
|
+
// CLI path resolution), dirtying the tree and breaking the milestone merge.
|
|
93
|
+
const { isInAutoWorktree } = await import("../auto-worktree.js");
|
|
94
|
+
if (!isInAutoWorktree(process.cwd())) {
|
|
95
|
+
const { prepareWorkflowMcpForProject } = await import("../workflow-mcp-auto-prep.js");
|
|
96
|
+
prepareWorkflowMcpForProject(ctx, process.cwd());
|
|
97
|
+
}
|
|
85
98
|
loadToolApiKeys();
|
|
86
99
|
});
|
|
87
100
|
pi.on("before_agent_start", async (event, ctx) => {
|
|
88
|
-
|
|
101
|
+
// Wait for ecosystem loader to finish (no-op after first turn).
|
|
102
|
+
await getEcosystemReadyPromise();
|
|
103
|
+
// GSD's own context injection (existing behavior — unchanged).
|
|
104
|
+
const gsdResult = await buildBeforeAgentStartResult(event, ctx);
|
|
105
|
+
// Refresh the snapshot used by ecosystem getPhase()/getActiveUnit().
|
|
106
|
+
// deriveState has its own ~100ms cache so this is cheap on repeat calls.
|
|
107
|
+
try {
|
|
108
|
+
const state = await deriveState(process.cwd());
|
|
109
|
+
updateSnapshot(state);
|
|
110
|
+
}
|
|
111
|
+
catch {
|
|
112
|
+
updateSnapshot(null);
|
|
113
|
+
}
|
|
114
|
+
// Chain ecosystem handlers using pi's runner.ts chaining protocol:
|
|
115
|
+
// each handler sees the systemPrompt mutated by prior handlers.
|
|
116
|
+
let currentSystemPrompt = gsdResult?.systemPrompt ?? event.systemPrompt;
|
|
117
|
+
// `any` because pi's BeforeAgentStartEventResult.message uses an internal
|
|
118
|
+
// CustomMessage type that's not re-exported (see ecosystem/gsd-extension-api.ts).
|
|
119
|
+
let lastMessage = gsdResult?.message;
|
|
120
|
+
for (const handler of ecosystemHandlers) {
|
|
121
|
+
try {
|
|
122
|
+
const r = await handler({ ...event, systemPrompt: currentSystemPrompt }, ctx);
|
|
123
|
+
if (r?.systemPrompt !== undefined)
|
|
124
|
+
currentSystemPrompt = r.systemPrompt;
|
|
125
|
+
if (r?.message)
|
|
126
|
+
lastMessage = r.message;
|
|
127
|
+
}
|
|
128
|
+
catch (err) {
|
|
129
|
+
safetyLogWarning("ecosystem", `before_agent_start handler failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
// Compose result. Return undefined if nothing changed (preserves runner contract).
|
|
133
|
+
if (currentSystemPrompt === event.systemPrompt && !lastMessage)
|
|
134
|
+
return undefined;
|
|
135
|
+
return {
|
|
136
|
+
systemPrompt: currentSystemPrompt !== event.systemPrompt ? currentSystemPrompt : undefined,
|
|
137
|
+
message: lastMessage,
|
|
138
|
+
};
|
|
89
139
|
});
|
|
90
140
|
pi.on("agent_end", async (event, ctx) => {
|
|
91
141
|
resetToolCallLoopGuard();
|
|
@@ -116,8 +166,10 @@ export function registerHooks(pi) {
|
|
|
116
166
|
const state = await deriveState(basePath);
|
|
117
167
|
if (!state.activeMilestone || !state.activeSlice || !state.activeTask)
|
|
118
168
|
return;
|
|
119
|
-
|
|
120
|
-
|
|
169
|
+
// Write checkpoint for ALL phases, not just "executing" — discuss, research,
|
|
170
|
+
// and planning also carry in-memory state (user answers, gate verification)
|
|
171
|
+
// that would be lost on compaction (#4258).
|
|
172
|
+
// if (state.phase !== "executing") return;
|
|
121
173
|
const sliceDir = resolveSlicePath(basePath, state.activeMilestone.id, state.activeSlice.id);
|
|
122
174
|
if (!sliceDir)
|
|
123
175
|
return;
|
|
@@ -240,7 +292,7 @@ export function registerHooks(pi) {
|
|
|
240
292
|
pi.on("tool_call", async (event, ctx) => {
|
|
241
293
|
if (!isAutoActive())
|
|
242
294
|
return;
|
|
243
|
-
safetyRecordToolCall(event.toolName, event.input);
|
|
295
|
+
safetyRecordToolCall(event.toolCallId, event.toolName, event.input);
|
|
244
296
|
// Destructive command classification (warn only, never block)
|
|
245
297
|
if (isToolCallEventType("bash", event)) {
|
|
246
298
|
const classification = classifyCommand(event.input.command);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// GSD Extension — Unified Cache Invalidation
|
|
2
2
|
//
|
|
3
|
-
// Three module-scoped caches exist across the GSD extension:
|
|
3
|
+
// Three module-scoped read caches exist across the GSD extension:
|
|
4
4
|
// 1. State cache (state.ts) — memoized deriveState() result
|
|
5
5
|
// 2. Path cache (paths.ts) — directory listing results (readdirSync)
|
|
6
6
|
// 3. Parse cache (files.ts) — parsed markdown file results
|
|
@@ -8,20 +8,31 @@
|
|
|
8
8
|
// After any file write that changes .gsd/ contents, all three must be
|
|
9
9
|
// invalidated together to prevent stale reads. This module provides a
|
|
10
10
|
// single function that clears all three atomically.
|
|
11
|
+
//
|
|
12
|
+
// NOTE: The DB `artifacts` table is NOT included here. Earlier versions
|
|
13
|
+
// called clearArtifacts() as part of this bundle (#793), intending to
|
|
14
|
+
// force deriveState() to re-parse from disk when files were edited
|
|
15
|
+
// out-of-band. But invalidateAllCaches() fires on every post-unit pass,
|
|
16
|
+
// so bundling a DESTRUCTIVE `DELETE FROM artifacts` with routine cache
|
|
17
|
+
// invalidation meant every row written by saveArtifactToDb / writeAndStore
|
|
18
|
+
// was wiped within seconds — leaving the milestone completed on disk but
|
|
19
|
+
// the `artifacts` table empty and the agent looping on "file exists but
|
|
20
|
+
// DB record missing" recovery calls. If a call site genuinely needs the
|
|
21
|
+
// artifact table cleared after an out-of-band file mutation, it should
|
|
22
|
+
// invoke clearArtifacts() from gsd-db.js explicitly — do not add it back
|
|
23
|
+
// here.
|
|
11
24
|
import { invalidateStateCache } from './state.js';
|
|
12
25
|
import { clearPathCache } from './paths.js';
|
|
13
26
|
import { clearParseCache } from './files.js';
|
|
14
|
-
import { clearArtifacts } from './gsd-db.js';
|
|
15
27
|
/**
|
|
16
|
-
* Invalidate all GSD runtime caches in one call.
|
|
28
|
+
* Invalidate all GSD runtime read caches in one call.
|
|
17
29
|
*
|
|
18
30
|
* Call this after file writes, milestone transitions, merge reconciliation,
|
|
19
31
|
* or any operation that changes .gsd/ contents on disk. Forgetting to clear
|
|
20
|
-
* any single cache causes stale reads (see #431
|
|
32
|
+
* any single cache causes stale reads (see #431).
|
|
21
33
|
*/
|
|
22
34
|
export function invalidateAllCaches() {
|
|
23
35
|
invalidateStateCache();
|
|
24
36
|
clearPathCache();
|
|
25
37
|
clearParseCache();
|
|
26
|
-
clearArtifacts();
|
|
27
38
|
}
|
|
@@ -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|ship|do|session-report|backlog|pr-branch|add-tests";
|
|
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|language";
|
|
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)" },
|
|
@@ -68,6 +68,7 @@ export const TOP_LEVEL_SUBCOMMANDS = [
|
|
|
68
68
|
{ cmd: "backlog", desc: "Manage backlog items (add, promote, remove, list)" },
|
|
69
69
|
{ cmd: "pr-branch", desc: "Create clean PR branch filtering .gsd/ commits" },
|
|
70
70
|
{ cmd: "add-tests", desc: "Generate tests for completed slices" },
|
|
71
|
+
{ cmd: "language", desc: "Set or clear the global response language (e.g. /gsd language Chinese)" },
|
|
71
72
|
];
|
|
72
73
|
const NESTED_COMPLETIONS = {
|
|
73
74
|
auto: [
|
|
@@ -256,6 +257,10 @@ const NESTED_COMPLETIONS = {
|
|
|
256
257
|
{ cmd: "--dry-run", desc: "Preview what would be filtered" },
|
|
257
258
|
{ cmd: "--name", desc: "Custom branch name" },
|
|
258
259
|
],
|
|
260
|
+
language: [
|
|
261
|
+
{ cmd: "off", desc: "Clear the language preference (revert to default)" },
|
|
262
|
+
{ cmd: "clear", desc: "Alias for off — clear the language preference" },
|
|
263
|
+
],
|
|
259
264
|
};
|
|
260
265
|
function filterOptions(partial, options, prefix = "") {
|
|
261
266
|
const normalizedPrefix = prefix ? `${prefix} ` : "";
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { computeProgressScore, formatProgressLine } from "../../progress-score.js";
|
|
2
2
|
import { getGlobalGSDPreferencesPath, getProjectGSDPreferencesPath } from "../../preferences.js";
|
|
3
|
-
import { ensurePreferencesFile, handlePrefs, handlePrefsMode, handlePrefsWizard } from "../../commands-prefs-wizard.js";
|
|
3
|
+
import { ensurePreferencesFile, handlePrefs, handlePrefsMode, handlePrefsWizard, handleLanguage } from "../../commands-prefs-wizard.js";
|
|
4
4
|
import { runEnvironmentChecks } from "../../doctor-environment.js";
|
|
5
5
|
import { deriveState } from "../../state.js";
|
|
6
6
|
import { handleCmux } from "../../commands-cmux.js";
|
|
@@ -339,6 +339,10 @@ export async function handleCoreCommand(trimmed, ctx, pi) {
|
|
|
339
339
|
await handlePrefs(trimmed.replace(/^prefs\s*/, "").trim(), ctx);
|
|
340
340
|
return true;
|
|
341
341
|
}
|
|
342
|
+
if (trimmed === "language" || trimmed.startsWith("language ")) {
|
|
343
|
+
await handleLanguage(trimmed.replace(/^language\s*/, "").trim(), ctx);
|
|
344
|
+
return true;
|
|
345
|
+
}
|
|
342
346
|
if (trimmed === "cmux" || trimmed.startsWith("cmux ")) {
|
|
343
347
|
await handleCmux(trimmed.replace(/^cmux\s*/, "").trim(), ctx);
|
|
344
348
|
return true;
|
|
@@ -233,5 +233,10 @@ Examples:
|
|
|
233
233
|
await handleAddTests(trimmed.replace(/^add-tests\s*/, "").trim(), ctx, pi);
|
|
234
234
|
return true;
|
|
235
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
|
+
}
|
|
236
241
|
return false;
|
|
237
242
|
}
|