gsd-pi 2.74.0 → 2.75.0-dev.063e5a3
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.js +85 -0
- package/dist/headless-query.js +4 -1
- package/dist/help-text.js +23 -0
- 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 +209 -10
- 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 +220 -17
- package/dist/resources/extensions/gsd/auto-prompts.js +12 -0
- 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 +36 -4
- package/dist/resources/extensions/gsd/bootstrap/provider-error-resume.js +5 -3
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +30 -8
- 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 +31 -1
- package/dist/resources/extensions/gsd/commands/handlers/core.js +5 -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-maintenance.js +6 -6
- package/dist/resources/extensions/gsd/commands-pr-branch.js +180 -0
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +51 -4
- 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 +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 +157 -0
- package/dist/resources/extensions/gsd/gsd-db.js +581 -2
- package/dist/resources/extensions/gsd/guided-flow.js +31 -6
- 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/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/prompts/add-tests.md +35 -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/state.js +5 -1
- package/dist/resources/extensions/gsd/templates/PREFERENCES.md +19 -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/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 +3 -3
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/required-server-files.json +3 -3
- package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
- package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- 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/page.js +2 -2
- package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +3 -3
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
- 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 +3 -3
- 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/boot/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/experimental/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/experimental/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/notifications/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/notifications/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/events/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +4 -4
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +4 -4
- package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +4 -4
- 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 +3 -3
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/page.js +2 -2
- package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +13 -13
- package/dist/web/standalone/.next/server/chunks/63.js +3 -3
- 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/middleware.js +2 -2
- package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
- package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
- 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/dist/web/standalone/.next/static/chunks/app/_not-found/{page-2f24283c162b6ab3.js → page-f2a7482d42a5614b.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/app/{layout-9ecfd95f343793f0.js → layout-a16c7a7ecdf0c2cf.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/app/page-f1e30ab6bb269149.js +1 -0
- package/dist/web/standalone/.next/static/chunks/main-app-fdab67f7802d7832.js +1 -0
- package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +1 -0
- package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
- package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
- package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
- package/dist/web/standalone/server.js +1 -1
- package/package.json +3 -2
- 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/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/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/src/workflow-tools.ts +95 -10
- 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 +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/package.json +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.json +1 -0
- package/packages/pi-ai/tsconfig.tsbuildinfo +1 -0
- 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/package.json +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 +3 -2
- package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -0
- 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/package.json +1 -1
- package/packages/pi-tui/src/tui.ts +9 -1
- 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/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 +261 -10
- 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 +238 -18
- package/src/resources/extensions/gsd/auto-prompts.ts +13 -0
- 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 +41 -2
- package/src/resources/extensions/gsd/bootstrap/provider-error-resume.ts +5 -3
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +38 -8
- 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 +31 -1
- package/src/resources/extensions/gsd/commands/handlers/core.ts +5 -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-maintenance.ts +6 -6
- package/src/resources/extensions/gsd/commands-pr-branch.ts +234 -0
- package/src/resources/extensions/gsd/commands-prefs-wizard.ts +58 -4
- 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 +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 +212 -0
- package/src/resources/extensions/gsd/gsd-db.ts +788 -3
- package/src/resources/extensions/gsd/guided-flow.ts +36 -2
- 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/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/prompts/add-tests.md +35 -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/state.ts +9 -2
- 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-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-slice.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
- 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/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/journal-integration.test.ts +71 -4
- 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/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 +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/single-writer-invariant.test.ts +180 -0
- 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/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/dist/web/standalone/.next/static/chunks/app/page-7115e62689b5fd84.js +0 -1
- package/dist/web/standalone/.next/static/chunks/main-app-d3d4c336195465f9.js +0 -1
- package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-ab5a8926e07ec673.js +0 -1
- 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/{JpjdI2QtmIkQr4xz6gbhM → j7IBD35UgrL2b298GLK3V}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{JpjdI2QtmIkQr4xz6gbhM → j7IBD35UgrL2b298GLK3V}/_ssgManifest.js +0 -0
|
@@ -33,6 +33,8 @@ import { runPostExecutionChecks, type PostExecutionResult } from "./post-executi
|
|
|
33
33
|
import type { AutoSession } from "./auto/session.js";
|
|
34
34
|
import type { VerificationResult as VerificationGateResult } from "./types.js";
|
|
35
35
|
import { join } from "node:path";
|
|
36
|
+
import { resolveUokFlags } from "./uok/flags.js";
|
|
37
|
+
import { UokGateRunner } from "./uok/gate-runner.js";
|
|
36
38
|
|
|
37
39
|
export interface VerificationContext {
|
|
38
40
|
s: AutoSession;
|
|
@@ -67,6 +69,37 @@ async function runValidateMilestonePostCheck(
|
|
|
67
69
|
pauseAuto: (ctx?: ExtensionContext, pi?: ExtensionAPI) => Promise<void>,
|
|
68
70
|
): Promise<VerificationResult> {
|
|
69
71
|
const { s, ctx, pi } = vctx;
|
|
72
|
+
const prefs = loadEffectiveGSDPreferences()?.preferences;
|
|
73
|
+
const uokFlags = resolveUokFlags(prefs);
|
|
74
|
+
const persistMilestoneValidationGate = async (
|
|
75
|
+
outcome: "pass" | "fail" | "retry" | "manual-attention",
|
|
76
|
+
failureClass: "none" | "verification" | "manual-attention",
|
|
77
|
+
rationale: string,
|
|
78
|
+
findings = "",
|
|
79
|
+
milestoneId?: string,
|
|
80
|
+
): Promise<void> => {
|
|
81
|
+
if (!uokFlags.gates || !s.currentUnit) return;
|
|
82
|
+
const gateRunner = new UokGateRunner();
|
|
83
|
+
gateRunner.register({
|
|
84
|
+
id: "milestone-validation-post-check",
|
|
85
|
+
type: "verification",
|
|
86
|
+
execute: async () => ({
|
|
87
|
+
outcome,
|
|
88
|
+
failureClass,
|
|
89
|
+
rationale,
|
|
90
|
+
findings,
|
|
91
|
+
}),
|
|
92
|
+
});
|
|
93
|
+
await gateRunner.run("milestone-validation-post-check", {
|
|
94
|
+
basePath: s.basePath,
|
|
95
|
+
traceId: `validation-post-check:${s.currentUnit.id}`,
|
|
96
|
+
turnId: s.currentUnit.id,
|
|
97
|
+
milestoneId,
|
|
98
|
+
unitType: s.currentUnit.type,
|
|
99
|
+
unitId: s.currentUnit.id,
|
|
100
|
+
});
|
|
101
|
+
};
|
|
102
|
+
|
|
70
103
|
if (!s.currentUnit) return "continue";
|
|
71
104
|
|
|
72
105
|
const { milestone: mid } = parseUnitId(s.currentUnit.id);
|
|
@@ -79,14 +112,32 @@ async function runValidateMilestonePostCheck(
|
|
|
79
112
|
if (!validationContent) return "continue";
|
|
80
113
|
|
|
81
114
|
const verdict = extractVerdict(validationContent);
|
|
82
|
-
if (verdict !== "needs-remediation")
|
|
115
|
+
if (verdict !== "needs-remediation") {
|
|
116
|
+
await persistMilestoneValidationGate(
|
|
117
|
+
"pass",
|
|
118
|
+
"none",
|
|
119
|
+
`milestone validation verdict is ${verdict}; no remediation loop risk`,
|
|
120
|
+
"",
|
|
121
|
+
mid,
|
|
122
|
+
);
|
|
123
|
+
return "continue";
|
|
124
|
+
}
|
|
83
125
|
|
|
84
126
|
const incompleteSliceCount = await countIncompleteSlices(s.basePath, mid);
|
|
85
127
|
|
|
86
128
|
// If any non-closed slices exist, the agent successfully queued remediation
|
|
87
129
|
// work — proceed normally. The state machine will execute those slices and
|
|
88
130
|
// re-validate per the #3596/#3670 fix.
|
|
89
|
-
if (incompleteSliceCount > 0)
|
|
131
|
+
if (incompleteSliceCount > 0) {
|
|
132
|
+
await persistMilestoneValidationGate(
|
|
133
|
+
"pass",
|
|
134
|
+
"none",
|
|
135
|
+
`remediation slices present (${incompleteSliceCount}); validation can continue`,
|
|
136
|
+
"",
|
|
137
|
+
mid,
|
|
138
|
+
);
|
|
139
|
+
return "continue";
|
|
140
|
+
}
|
|
90
141
|
|
|
91
142
|
ctx.ui.notify(
|
|
92
143
|
`Milestone ${mid} validation returned verdict=needs-remediation but no remediation slices were added. Pausing for human review.`,
|
|
@@ -96,6 +147,13 @@ async function runValidateMilestonePostCheck(
|
|
|
96
147
|
`validate-milestone: pausing — verdict=needs-remediation with no incomplete slices for ${mid}. ` +
|
|
97
148
|
`The agent must call gsd_reassess_roadmap to add remediation slices before re-validation.\n`,
|
|
98
149
|
);
|
|
150
|
+
await persistMilestoneValidationGate(
|
|
151
|
+
"manual-attention",
|
|
152
|
+
"manual-attention",
|
|
153
|
+
"needs-remediation verdict without queued remediation slices",
|
|
154
|
+
`No incomplete slices found for ${mid} while verdict=needs-remediation`,
|
|
155
|
+
mid,
|
|
156
|
+
);
|
|
99
157
|
await pauseAuto(ctx, pi);
|
|
100
158
|
return "pause";
|
|
101
159
|
}
|
|
@@ -158,6 +216,7 @@ export async function runPostUnitVerification(
|
|
|
158
216
|
try {
|
|
159
217
|
const effectivePrefs = loadEffectiveGSDPreferences();
|
|
160
218
|
const prefs = effectivePrefs?.preferences;
|
|
219
|
+
const uokFlags = resolveUokFlags(prefs);
|
|
161
220
|
|
|
162
221
|
// Read task plan verify field
|
|
163
222
|
const { milestone: mid, slice: sid, task: tid } = parseUnitId(s.currentUnit.id);
|
|
@@ -196,6 +255,37 @@ export async function runPostUnitVerification(
|
|
|
196
255
|
}
|
|
197
256
|
}
|
|
198
257
|
|
|
258
|
+
if (uokFlags.gates) {
|
|
259
|
+
const gateRunner = new UokGateRunner();
|
|
260
|
+
gateRunner.register({
|
|
261
|
+
id: "verification-gate",
|
|
262
|
+
type: "verification",
|
|
263
|
+
execute: async () => ({
|
|
264
|
+
outcome: result.passed ? "pass" : "fail",
|
|
265
|
+
failureClass: result.runtimeErrors?.some((e) => e.blocking)
|
|
266
|
+
? "execution"
|
|
267
|
+
: "verification",
|
|
268
|
+
rationale: result.passed
|
|
269
|
+
? "verification checks passed"
|
|
270
|
+
: "verification checks failed",
|
|
271
|
+
findings: result.passed
|
|
272
|
+
? ""
|
|
273
|
+
: formatFailureContext(result),
|
|
274
|
+
}),
|
|
275
|
+
});
|
|
276
|
+
|
|
277
|
+
await gateRunner.run("verification-gate", {
|
|
278
|
+
basePath: s.basePath,
|
|
279
|
+
traceId: `verification:${s.currentUnit.id}`,
|
|
280
|
+
turnId: s.currentUnit.id,
|
|
281
|
+
milestoneId: mid ?? undefined,
|
|
282
|
+
sliceId: sid ?? undefined,
|
|
283
|
+
taskId: tid ?? undefined,
|
|
284
|
+
unitType: s.currentUnit.type,
|
|
285
|
+
unitId: s.currentUnit.id,
|
|
286
|
+
});
|
|
287
|
+
}
|
|
288
|
+
|
|
199
289
|
// Auto-fix retry preferences
|
|
200
290
|
const autoFixEnabled = prefs?.verification_auto_fix !== false;
|
|
201
291
|
const maxRetries =
|
|
@@ -338,6 +428,43 @@ export async function runPostUnitVerification(
|
|
|
338
428
|
);
|
|
339
429
|
}
|
|
340
430
|
|
|
431
|
+
if (uokFlags.gates) {
|
|
432
|
+
const strictMode = prefs?.enhanced_verification_strict === true;
|
|
433
|
+
const warnEscalated = postExecResult.status === "warn" && strictMode;
|
|
434
|
+
const blockingFailure = postExecResult.status === "fail" || warnEscalated;
|
|
435
|
+
const findings = postExecResult.checks
|
|
436
|
+
.filter((check) => !check.passed)
|
|
437
|
+
.map((check) => `[${check.category}] ${check.target}: ${check.message}`)
|
|
438
|
+
.join("\n");
|
|
439
|
+
const gateRunner = new UokGateRunner();
|
|
440
|
+
gateRunner.register({
|
|
441
|
+
id: "post-execution-checks",
|
|
442
|
+
type: "artifact",
|
|
443
|
+
execute: async () => ({
|
|
444
|
+
outcome: blockingFailure ? "fail" : "pass",
|
|
445
|
+
failureClass: postExecResult.status === "fail"
|
|
446
|
+
? "artifact"
|
|
447
|
+
: warnEscalated
|
|
448
|
+
? "policy"
|
|
449
|
+
: "none",
|
|
450
|
+
rationale: blockingFailure
|
|
451
|
+
? `post-execution checks ${postExecResult.status}${warnEscalated ? " (strict)" : ""}`
|
|
452
|
+
: "post-execution checks passed",
|
|
453
|
+
findings,
|
|
454
|
+
}),
|
|
455
|
+
});
|
|
456
|
+
await gateRunner.run("post-execution-checks", {
|
|
457
|
+
basePath: s.basePath,
|
|
458
|
+
traceId: `verification:${s.currentUnit.id}`,
|
|
459
|
+
turnId: s.currentUnit.id,
|
|
460
|
+
milestoneId: mid,
|
|
461
|
+
sliceId: sid,
|
|
462
|
+
taskId: tid,
|
|
463
|
+
unitType: s.currentUnit.type,
|
|
464
|
+
unitId: s.currentUnit.id,
|
|
465
|
+
});
|
|
466
|
+
}
|
|
467
|
+
|
|
341
468
|
// Check for blocking failures
|
|
342
469
|
if (postExecResult.status === "fail") {
|
|
343
470
|
postExecBlockingFailure = true;
|
|
@@ -102,6 +102,7 @@ function isSamePath(a: string, b: string): boolean {
|
|
|
102
102
|
try {
|
|
103
103
|
return realpathSync(a) === realpathSync(b);
|
|
104
104
|
} catch (e) {
|
|
105
|
+
if ((e as NodeJS.ErrnoException).code === "ENOENT") return false;
|
|
105
106
|
logWarning("worktree", `isSamePath failed: ${(e as Error).message}`);
|
|
106
107
|
return false;
|
|
107
108
|
}
|
|
@@ -195,12 +195,15 @@ import { clearCmuxSidebar, logCmuxEvent, syncCmuxSidebar } from "../cmux/index.j
|
|
|
195
195
|
import { startUnitSupervision } from "./auto-timers.js";
|
|
196
196
|
import { runPostUnitVerification } from "./auto-verification.js";
|
|
197
197
|
import {
|
|
198
|
+
autoCommitUnit,
|
|
198
199
|
postUnitPreVerification,
|
|
199
200
|
postUnitPostVerification,
|
|
200
201
|
} from "./auto-post-unit.js";
|
|
201
202
|
import { bootstrapAutoSession, openProjectDbIfPresent, type BootstrapDeps } from "./auto-start.js";
|
|
202
203
|
import { initHealthWidget } from "./health-widget.js";
|
|
203
204
|
import { autoLoop, resolveAgentEnd, resolveAgentEndCancelled, _resetPendingResolve, isSessionSwitchInFlight, type LoopDeps, type ErrorContext } from "./auto-loop.js";
|
|
205
|
+
import { runAutoLoopWithUok } from "./uok/kernel.js";
|
|
206
|
+
import { resolveUokFlags } from "./uok/flags.js";
|
|
204
207
|
// Slice-level parallelism (#2340)
|
|
205
208
|
import { getEligibleSlices } from "./slice-parallel-eligibility.js";
|
|
206
209
|
import { startSliceParallel } from "./slice-parallel-orchestrator.js";
|
|
@@ -604,11 +607,29 @@ function buildSnapshotOpts(
|
|
|
604
607
|
continueHereFired?: boolean;
|
|
605
608
|
promptCharCount?: number;
|
|
606
609
|
baselineCharCount?: number;
|
|
610
|
+
traceId?: string;
|
|
611
|
+
turnId?: string;
|
|
612
|
+
gitAction?: "commit" | "snapshot" | "status-only";
|
|
613
|
+
gitPush?: boolean;
|
|
614
|
+
gitStatus?: "ok" | "failed";
|
|
615
|
+
gitError?: string;
|
|
607
616
|
} & Record<string, unknown> {
|
|
617
|
+
const prefs = loadEffectiveGSDPreferences()?.preferences;
|
|
618
|
+
const uokFlags = resolveUokFlags(prefs);
|
|
608
619
|
return {
|
|
609
620
|
...(s.autoStartTime > 0 ? { autoSessionKey: String(s.autoStartTime) } : {}),
|
|
610
621
|
promptCharCount: s.lastPromptCharCount,
|
|
611
622
|
baselineCharCount: s.lastBaselineCharCount,
|
|
623
|
+
traceId: s.currentTraceId ?? undefined,
|
|
624
|
+
turnId: s.currentTurnId ?? undefined,
|
|
625
|
+
...(uokFlags.gitops
|
|
626
|
+
? {
|
|
627
|
+
gitAction: uokFlags.gitopsTurnAction,
|
|
628
|
+
gitPush: uokFlags.gitopsTurnPush,
|
|
629
|
+
gitStatus: s.lastGitActionStatus ?? undefined,
|
|
630
|
+
gitError: s.lastGitActionFailure ?? undefined,
|
|
631
|
+
}
|
|
632
|
+
: {}),
|
|
612
633
|
...(s.currentUnitRouting ?? {}),
|
|
613
634
|
};
|
|
614
635
|
}
|
|
@@ -1180,6 +1201,7 @@ function buildLoopDeps(): LoopDeps {
|
|
|
1180
1201
|
getMainBranch,
|
|
1181
1202
|
// Unit closeout + runtime records
|
|
1182
1203
|
closeoutUnit,
|
|
1204
|
+
autoCommitUnit,
|
|
1183
1205
|
recordOutcome,
|
|
1184
1206
|
writeLock,
|
|
1185
1207
|
captureAvailableSkills,
|
|
@@ -1400,6 +1422,11 @@ export async function startAuto(
|
|
|
1400
1422
|
s.stepMode = requestedStepMode;
|
|
1401
1423
|
s.cmdCtx = ctx;
|
|
1402
1424
|
s.basePath = base;
|
|
1425
|
+
// Ensure the workflow-logger audit log is pinned to the project root
|
|
1426
|
+
// even when auto-mode is entered via a path that bypasses the
|
|
1427
|
+
// bootstrap/dynamic-tools ensureDbOpen() → setLogBasePath() chain
|
|
1428
|
+
// (e.g. /clear resume, hot-reload).
|
|
1429
|
+
setLogBasePath(base);
|
|
1403
1430
|
s.unitDispatchCount.clear();
|
|
1404
1431
|
s.unitLifetimeDispatches.clear();
|
|
1405
1432
|
if (!getLedger()) initMetrics(base);
|
|
@@ -1506,7 +1533,13 @@ export async function startAuto(
|
|
|
1506
1533
|
logCmuxEvent(loadEffectiveGSDPreferences()?.preferences, s.stepMode ? "Step-mode resumed." : "Auto-mode resumed.", "progress");
|
|
1507
1534
|
|
|
1508
1535
|
captureProjectRootEnv(s.originalBasePath || s.basePath);
|
|
1509
|
-
await
|
|
1536
|
+
await runAutoLoopWithUok({
|
|
1537
|
+
ctx,
|
|
1538
|
+
pi,
|
|
1539
|
+
s,
|
|
1540
|
+
deps: buildLoopDeps(),
|
|
1541
|
+
runLegacyLoop: autoLoop,
|
|
1542
|
+
});
|
|
1510
1543
|
cleanupAfterLoopExit(ctx);
|
|
1511
1544
|
return;
|
|
1512
1545
|
}
|
|
@@ -1541,7 +1574,13 @@ export async function startAuto(
|
|
|
1541
1574
|
logCmuxEvent(loadEffectiveGSDPreferences()?.preferences, requestedStepMode ? "Step-mode started." : "Auto-mode started.", "progress");
|
|
1542
1575
|
|
|
1543
1576
|
// Dispatch the first unit
|
|
1544
|
-
await
|
|
1577
|
+
await runAutoLoopWithUok({
|
|
1578
|
+
ctx,
|
|
1579
|
+
pi,
|
|
1580
|
+
s,
|
|
1581
|
+
deps: buildLoopDeps(),
|
|
1582
|
+
runLegacyLoop: autoLoop,
|
|
1583
|
+
});
|
|
1545
1584
|
cleanupAfterLoopExit(ctx);
|
|
1546
1585
|
}
|
|
1547
1586
|
|
|
@@ -6,6 +6,7 @@ import type {
|
|
|
6
6
|
|
|
7
7
|
import { getAutoDashboardData, startAuto, type AutoDashboardData } from "../auto.js";
|
|
8
8
|
import { resetTransientRetryState } from "./agent-end-recovery.js";
|
|
9
|
+
import { resetSessionTimeoutState } from "../auto/phases.js";
|
|
9
10
|
|
|
10
11
|
type AutoResumeSnapshot = Pick<AutoDashboardData, "active" | "paused" | "stepMode" | "basePath">;
|
|
11
12
|
|
|
@@ -43,10 +44,11 @@ export async function resumeAutoAfterProviderDelay(
|
|
|
43
44
|
return "missing-base";
|
|
44
45
|
}
|
|
45
46
|
|
|
46
|
-
// Reset
|
|
47
|
-
//
|
|
48
|
-
//
|
|
47
|
+
// Reset retry counters before restarting — without this, counters
|
|
48
|
+
// accumulate across pause/resume cycles and permanently lock out
|
|
49
|
+
// auto-resume after their respective MAX thresholds.
|
|
49
50
|
resetTransientRetryState();
|
|
51
|
+
resetSessionTimeoutState();
|
|
50
52
|
|
|
51
53
|
await deps.startAuto(
|
|
52
54
|
ctx as ExtensionCommandContext,
|
|
@@ -2,9 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
import type { ExtensionAPI, ExtensionCommandContext } from "@gsd/pi-coding-agent";
|
|
4
4
|
|
|
5
|
-
import { registerGSDCommand } from "../commands.js";
|
|
6
5
|
import { registerExitCommand } from "../exit-command.js";
|
|
7
6
|
import { registerWorktreeCommand } from "../worktree-command.js";
|
|
7
|
+
import type { GSDEcosystemBeforeAgentStartHandler } from "../ecosystem/gsd-extension-api.js";
|
|
8
|
+
import { loadEcosystemExtensions } from "../ecosystem/loader.js";
|
|
8
9
|
import { registerDbTools } from "./db-tools.js";
|
|
9
10
|
import { registerDynamicTools } from "./dynamic-tools.js";
|
|
10
11
|
import { registerJournalTools } from "./journal-tools.js";
|
|
@@ -12,6 +13,7 @@ import { registerQueryTools } from "./query-tools.js";
|
|
|
12
13
|
import { registerHooks } from "./register-hooks.js";
|
|
13
14
|
import { registerShortcuts } from "./register-shortcuts.js";
|
|
14
15
|
import { writeCrashLog } from "./crash-log.js";
|
|
16
|
+
import { logWarning } from "../workflow-logger.js";
|
|
15
17
|
|
|
16
18
|
export { writeCrashLog } from "./crash-log.js";
|
|
17
19
|
|
|
@@ -58,12 +60,17 @@ function installEpipeGuard(): void {
|
|
|
58
60
|
}
|
|
59
61
|
|
|
60
62
|
export function registerGsdExtension(pi: ExtensionAPI): void {
|
|
61
|
-
registerGSDCommand
|
|
63
|
+
// Note: registerGSDCommand is called by index.ts before this function,
|
|
64
|
+
// so we intentionally skip it here to avoid double-registration.
|
|
62
65
|
registerWorktreeCommand(pi);
|
|
63
66
|
registerExitCommand(pi);
|
|
64
67
|
|
|
65
68
|
installEpipeGuard();
|
|
66
69
|
|
|
70
|
+
// Ecosystem handlers captured by the GSDExtensionAPI wrapper for the
|
|
71
|
+
// GSD-owned `before_agent_start` dispatch step (#3338).
|
|
72
|
+
const ecosystemHandlers: GSDEcosystemBeforeAgentStartHandler[] = [];
|
|
73
|
+
|
|
67
74
|
pi.registerCommand("kill", {
|
|
68
75
|
description: "Exit GSD immediately (no cleanup)",
|
|
69
76
|
handler: async (_args: string, _ctx: ExtensionCommandContext) => {
|
|
@@ -71,10 +78,33 @@ export function registerGsdExtension(pi: ExtensionAPI): void {
|
|
|
71
78
|
},
|
|
72
79
|
});
|
|
73
80
|
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
81
|
+
// Wrap non-critical registrations individually so one failure
|
|
82
|
+
// doesn't prevent the others from loading.
|
|
83
|
+
const nonCriticalRegistrations: Array<[string, () => void]> = [
|
|
84
|
+
["dynamic-tools", () => registerDynamicTools(pi)],
|
|
85
|
+
["db-tools", () => registerDbTools(pi)],
|
|
86
|
+
["journal-tools", () => registerJournalTools(pi)],
|
|
87
|
+
["query-tools", () => registerQueryTools(pi)],
|
|
88
|
+
["shortcuts", () => registerShortcuts(pi)],
|
|
89
|
+
["hooks", () => registerHooks(pi, ecosystemHandlers)],
|
|
90
|
+
["ecosystem", () => {
|
|
91
|
+
void loadEcosystemExtensions(pi, ecosystemHandlers).catch((err) => {
|
|
92
|
+
logWarning(
|
|
93
|
+
"ecosystem",
|
|
94
|
+
`loader failed: ${err instanceof Error ? err.message : String(err)}`,
|
|
95
|
+
);
|
|
96
|
+
});
|
|
97
|
+
}],
|
|
98
|
+
];
|
|
99
|
+
|
|
100
|
+
for (const [name, register] of nonCriticalRegistrations) {
|
|
101
|
+
try {
|
|
102
|
+
register();
|
|
103
|
+
} catch (err) {
|
|
104
|
+
logWarning(
|
|
105
|
+
"bootstrap",
|
|
106
|
+
`Failed to register ${name}: ${err instanceof Error ? err.message : String(err)}`,
|
|
107
|
+
);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
80
110
|
}
|
|
@@ -3,6 +3,10 @@ import { join } from "node:path";
|
|
|
3
3
|
import type { ExtensionAPI, ExtensionContext } from "@gsd/pi-coding-agent";
|
|
4
4
|
import { isToolCallEventType } from "@gsd/pi-coding-agent";
|
|
5
5
|
|
|
6
|
+
import type { GSDEcosystemBeforeAgentStartHandler } from "../ecosystem/gsd-extension-api.js";
|
|
7
|
+
import { updateSnapshot } from "../ecosystem/gsd-extension-api.js";
|
|
8
|
+
import { getEcosystemReadyPromise } from "../ecosystem/loader.js";
|
|
9
|
+
|
|
6
10
|
import { buildMilestoneFileName, resolveMilestonePath, resolveSliceFile, resolveSlicePath } from "../paths.js";
|
|
7
11
|
import { buildBeforeAgentStartResult } from "./system-context.js";
|
|
8
12
|
import { handleAgentEnd } from "./agent-end-recovery.js";
|
|
@@ -35,7 +39,10 @@ async function syncServiceTierStatus(ctx: ExtensionContext): Promise<void> {
|
|
|
35
39
|
ctx.ui.setStatus("gsd-fast", formatServiceTierFooterStatus(getEffectiveServiceTier(), ctx.model?.id));
|
|
36
40
|
}
|
|
37
41
|
|
|
38
|
-
export function registerHooks(
|
|
42
|
+
export function registerHooks(
|
|
43
|
+
pi: ExtensionAPI,
|
|
44
|
+
ecosystemHandlers: GSDEcosystemBeforeAgentStartHandler[],
|
|
45
|
+
): void {
|
|
39
46
|
pi.on("session_start", async (_event, ctx) => {
|
|
40
47
|
initNotificationStore(process.cwd());
|
|
41
48
|
installNotifyInterceptor(ctx);
|
|
@@ -45,8 +52,12 @@ export function registerHooks(pi: ExtensionAPI): void {
|
|
|
45
52
|
resetToolCallLoopGuard();
|
|
46
53
|
resetAskUserQuestionsCache();
|
|
47
54
|
await syncServiceTierStatus(ctx);
|
|
48
|
-
|
|
49
|
-
|
|
55
|
+
// Skip MCP auto-prep when running inside an auto-worktree (see session_switch below).
|
|
56
|
+
const { isInAutoWorktree } = await import("../auto-worktree.js");
|
|
57
|
+
if (!isInAutoWorktree(process.cwd())) {
|
|
58
|
+
const { prepareWorkflowMcpForProject } = await import("../workflow-mcp-auto-prep.js");
|
|
59
|
+
prepareWorkflowMcpForProject(ctx, process.cwd());
|
|
60
|
+
}
|
|
50
61
|
|
|
51
62
|
// Apply show_token_cost preference (#1515)
|
|
52
63
|
try {
|
|
@@ -87,13 +98,63 @@ export function registerHooks(pi: ExtensionAPI): void {
|
|
|
87
98
|
resetAskUserQuestionsCache();
|
|
88
99
|
clearDiscussionFlowState();
|
|
89
100
|
await syncServiceTierStatus(ctx);
|
|
90
|
-
|
|
91
|
-
|
|
101
|
+
// Skip MCP auto-prep when running inside an auto-worktree. The worktree
|
|
102
|
+
// already has .mcp.json from createAutoWorktree, and re-running the writer
|
|
103
|
+
// post-chdir rewrites the file mid-run (non-idempotent due to cwd-relative
|
|
104
|
+
// CLI path resolution), dirtying the tree and breaking the milestone merge.
|
|
105
|
+
const { isInAutoWorktree } = await import("../auto-worktree.js");
|
|
106
|
+
if (!isInAutoWorktree(process.cwd())) {
|
|
107
|
+
const { prepareWorkflowMcpForProject } = await import("../workflow-mcp-auto-prep.js");
|
|
108
|
+
prepareWorkflowMcpForProject(ctx, process.cwd());
|
|
109
|
+
}
|
|
92
110
|
loadToolApiKeys();
|
|
93
111
|
});
|
|
94
112
|
|
|
95
113
|
pi.on("before_agent_start", async (event, ctx: ExtensionContext) => {
|
|
96
|
-
|
|
114
|
+
// Wait for ecosystem loader to finish (no-op after first turn).
|
|
115
|
+
await getEcosystemReadyPromise();
|
|
116
|
+
|
|
117
|
+
// GSD's own context injection (existing behavior — unchanged).
|
|
118
|
+
const gsdResult = await buildBeforeAgentStartResult(event, ctx);
|
|
119
|
+
|
|
120
|
+
// Refresh the snapshot used by ecosystem getPhase()/getActiveUnit().
|
|
121
|
+
// deriveState has its own ~100ms cache so this is cheap on repeat calls.
|
|
122
|
+
try {
|
|
123
|
+
const state = await deriveState(process.cwd());
|
|
124
|
+
updateSnapshot(state);
|
|
125
|
+
} catch {
|
|
126
|
+
updateSnapshot(null);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
// Chain ecosystem handlers using pi's runner.ts chaining protocol:
|
|
130
|
+
// each handler sees the systemPrompt mutated by prior handlers.
|
|
131
|
+
let currentSystemPrompt = gsdResult?.systemPrompt ?? event.systemPrompt;
|
|
132
|
+
// `any` because pi's BeforeAgentStartEventResult.message uses an internal
|
|
133
|
+
// CustomMessage type that's not re-exported (see ecosystem/gsd-extension-api.ts).
|
|
134
|
+
let lastMessage: any = gsdResult?.message;
|
|
135
|
+
|
|
136
|
+
for (const handler of ecosystemHandlers) {
|
|
137
|
+
try {
|
|
138
|
+
const r = await handler(
|
|
139
|
+
{ ...event, systemPrompt: currentSystemPrompt },
|
|
140
|
+
ctx,
|
|
141
|
+
);
|
|
142
|
+
if (r?.systemPrompt !== undefined) currentSystemPrompt = r.systemPrompt;
|
|
143
|
+
if (r?.message) lastMessage = r.message;
|
|
144
|
+
} catch (err) {
|
|
145
|
+
safetyLogWarning(
|
|
146
|
+
"ecosystem",
|
|
147
|
+
`before_agent_start handler failed: ${err instanceof Error ? err.message : String(err)}`,
|
|
148
|
+
);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
// Compose result. Return undefined if nothing changed (preserves runner contract).
|
|
153
|
+
if (currentSystemPrompt === event.systemPrompt && !lastMessage) return undefined;
|
|
154
|
+
return {
|
|
155
|
+
systemPrompt: currentSystemPrompt !== event.systemPrompt ? currentSystemPrompt : undefined,
|
|
156
|
+
message: lastMessage,
|
|
157
|
+
};
|
|
97
158
|
});
|
|
98
159
|
|
|
99
160
|
pi.on("agent_end", async (event, ctx: ExtensionContext) => {
|
|
@@ -125,7 +186,10 @@ export function registerHooks(pi: ExtensionAPI): void {
|
|
|
125
186
|
await ensureDbOpen();
|
|
126
187
|
const state = await deriveState(basePath);
|
|
127
188
|
if (!state.activeMilestone || !state.activeSlice || !state.activeTask) return;
|
|
128
|
-
|
|
189
|
+
// Write checkpoint for ALL phases, not just "executing" — discuss, research,
|
|
190
|
+
// and planning also carry in-memory state (user answers, gate verification)
|
|
191
|
+
// that would be lost on compaction (#4258).
|
|
192
|
+
// if (state.phase !== "executing") return;
|
|
129
193
|
|
|
130
194
|
const sliceDir = resolveSlicePath(basePath, state.activeMilestone.id, state.activeSlice.id);
|
|
131
195
|
if (!sliceDir) return;
|
|
@@ -261,7 +325,7 @@ export function registerHooks(pi: ExtensionAPI): void {
|
|
|
261
325
|
// ── Safety harness: evidence collection + destructive command warnings ──
|
|
262
326
|
pi.on("tool_call", async (event, ctx) => {
|
|
263
327
|
if (!isAutoActive()) return;
|
|
264
|
-
safetyRecordToolCall(event.toolName, event.input as Record<string, unknown>);
|
|
328
|
+
safetyRecordToolCall(event.toolCallId, event.toolName, event.input as Record<string, unknown>);
|
|
265
329
|
|
|
266
330
|
// Destructive command classification (warn only, never block)
|
|
267
331
|
if (isToolCallEventType("bash", event)) {
|
|
@@ -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,22 +8,33 @@
|
|
|
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
|
|
|
12
25
|
import { invalidateStateCache } from './state.js';
|
|
13
26
|
import { clearPathCache } from './paths.js';
|
|
14
27
|
import { clearParseCache } from './files.js';
|
|
15
|
-
import { clearArtifacts } from './gsd-db.js';
|
|
16
28
|
|
|
17
29
|
/**
|
|
18
|
-
* Invalidate all GSD runtime caches in one call.
|
|
30
|
+
* Invalidate all GSD runtime read caches in one call.
|
|
19
31
|
*
|
|
20
32
|
* Call this after file writes, milestone transitions, merge reconciliation,
|
|
21
33
|
* or any operation that changes .gsd/ contents on disk. Forgetting to clear
|
|
22
|
-
* any single cache causes stale reads (see #431
|
|
34
|
+
* any single cache causes stale reads (see #431).
|
|
23
35
|
*/
|
|
24
36
|
export function invalidateAllCaches(): void {
|
|
25
37
|
invalidateStateCache();
|
|
26
38
|
clearPathCache();
|
|
27
39
|
clearParseCache();
|
|
28
|
-
clearArtifacts();
|
|
29
40
|
}
|
|
@@ -15,7 +15,7 @@ export interface GsdCommandDefinition {
|
|
|
15
15
|
type CompletionMap = Record<string, readonly GsdCommandDefinition[]>;
|
|
16
16
|
|
|
17
17
|
export const GSD_COMMAND_DESCRIPTION =
|
|
18
|
-
"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";
|
|
18
|
+
"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";
|
|
19
19
|
|
|
20
20
|
export const TOP_LEVEL_SUBCOMMANDS: readonly GsdCommandDefinition[] = [
|
|
21
21
|
{ cmd: "help", desc: "Categorized command reference with descriptions" },
|
|
@@ -74,6 +74,13 @@ export const TOP_LEVEL_SUBCOMMANDS: readonly GsdCommandDefinition[] = [
|
|
|
74
74
|
{ cmd: "rethink", desc: "Conversational project reorganization — reorder, park, discard, add milestones" },
|
|
75
75
|
{ cmd: "workflow", desc: "Custom workflow lifecycle (new, run, list, validate, pause, resume)" },
|
|
76
76
|
{ cmd: "codebase", desc: "Generate, refresh, and inspect the codebase map cache (.gsd/CODEBASE.md)" },
|
|
77
|
+
{ cmd: "ship", desc: "Create PR from milestone artifacts and open for review" },
|
|
78
|
+
{ cmd: "do", desc: "Route freeform text to the right GSD command" },
|
|
79
|
+
{ cmd: "session-report", desc: "Session cost, tokens, and work summary" },
|
|
80
|
+
{ cmd: "backlog", desc: "Manage backlog items (add, promote, remove, list)" },
|
|
81
|
+
{ cmd: "pr-branch", desc: "Create clean PR branch filtering .gsd/ commits" },
|
|
82
|
+
{ cmd: "add-tests", desc: "Generate tests for completed slices" },
|
|
83
|
+
{ cmd: "language", desc: "Set or clear the global response language (e.g. /gsd language Chinese)" },
|
|
77
84
|
];
|
|
78
85
|
|
|
79
86
|
const NESTED_COMPLETIONS: CompletionMap = {
|
|
@@ -244,6 +251,29 @@ const NESTED_COMPLETIONS: CompletionMap = {
|
|
|
244
251
|
{ cmd: "stats", desc: "Show file count, description coverage, and generation time" },
|
|
245
252
|
{ cmd: "help", desc: "Show usage and available subcommands" },
|
|
246
253
|
],
|
|
254
|
+
ship: [
|
|
255
|
+
{ cmd: "--dry-run", desc: "Preview PR without creating" },
|
|
256
|
+
{ cmd: "--draft", desc: "Open as draft PR" },
|
|
257
|
+
{ cmd: "--base", desc: "Override target branch (default: main)" },
|
|
258
|
+
{ cmd: "--force", desc: "Ship even with pending tasks" },
|
|
259
|
+
],
|
|
260
|
+
"session-report": [
|
|
261
|
+
{ cmd: "--json", desc: "Machine-readable JSON output" },
|
|
262
|
+
{ cmd: "--save", desc: "Save report to .gsd/reports/" },
|
|
263
|
+
],
|
|
264
|
+
backlog: [
|
|
265
|
+
{ cmd: "add", desc: "Add item to backlog" },
|
|
266
|
+
{ cmd: "promote", desc: "Promote backlog item to active slice" },
|
|
267
|
+
{ cmd: "remove", desc: "Remove backlog item" },
|
|
268
|
+
],
|
|
269
|
+
"pr-branch": [
|
|
270
|
+
{ cmd: "--dry-run", desc: "Preview what would be filtered" },
|
|
271
|
+
{ cmd: "--name", desc: "Custom branch name" },
|
|
272
|
+
],
|
|
273
|
+
language: [
|
|
274
|
+
{ cmd: "off", desc: "Clear the language preference (revert to default)" },
|
|
275
|
+
{ cmd: "clear", desc: "Alias for off — clear the language preference" },
|
|
276
|
+
],
|
|
247
277
|
};
|
|
248
278
|
|
|
249
279
|
function filterOptions(
|
|
@@ -4,7 +4,7 @@ import type { GSDState } from "../../types.js";
|
|
|
4
4
|
|
|
5
5
|
import { computeProgressScore, formatProgressLine } from "../../progress-score.js";
|
|
6
6
|
import { loadEffectiveGSDPreferences, getGlobalGSDPreferencesPath, getProjectGSDPreferencesPath } from "../../preferences.js";
|
|
7
|
-
import { ensurePreferencesFile, handlePrefs, handlePrefsMode, handlePrefsWizard } from "../../commands-prefs-wizard.js";
|
|
7
|
+
import { ensurePreferencesFile, handlePrefs, handlePrefsMode, handlePrefsWizard, handleLanguage } from "../../commands-prefs-wizard.js";
|
|
8
8
|
import { runEnvironmentChecks } from "../../doctor-environment.js";
|
|
9
9
|
import { deriveState } from "../../state.js";
|
|
10
10
|
import { handleCmux } from "../../commands-cmux.js";
|
|
@@ -395,6 +395,10 @@ export async function handleCoreCommand(
|
|
|
395
395
|
await handlePrefs(trimmed.replace(/^prefs\s*/, "").trim(), ctx);
|
|
396
396
|
return true;
|
|
397
397
|
}
|
|
398
|
+
if (trimmed === "language" || trimmed.startsWith("language ")) {
|
|
399
|
+
await handleLanguage(trimmed.replace(/^language\s*/, "").trim(), ctx);
|
|
400
|
+
return true;
|
|
401
|
+
}
|
|
398
402
|
if (trimmed === "cmux" || trimmed.startsWith("cmux ")) {
|
|
399
403
|
await handleCmux(trimmed.replace(/^cmux\s*/, "").trim(), ctx);
|
|
400
404
|
return true;
|