gsd-pi 2.67.0-dev.43b0159 → 2.67.0-dev.4fb8afe
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/README.md +42 -32
- package/dist/resource-loader.d.ts +1 -1
- package/dist/resource-loader.js +20 -5
- package/dist/resources/GSD-WORKFLOW.md +3 -1
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +73 -42
- package/dist/resources/extensions/get-secrets-from-user.js +18 -2
- package/dist/resources/extensions/gsd/auto/phases.js +17 -0
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +12 -0
- package/dist/resources/extensions/gsd/auto-post-unit.js +26 -0
- package/dist/resources/extensions/gsd/bootstrap/db-tools.js +11 -435
- package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +1 -4
- package/dist/resources/extensions/gsd/bootstrap/query-tools.js +7 -64
- package/dist/resources/extensions/gsd/bootstrap/system-context.js +18 -3
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +88 -8
- package/dist/resources/extensions/gsd/codebase-generator.js +173 -12
- package/dist/resources/extensions/gsd/commands/catalog.js +2 -2
- package/dist/resources/extensions/gsd/commands/handlers/core.js +1 -0
- package/dist/resources/extensions/gsd/commands-bootstrap.js +9 -0
- package/dist/resources/extensions/gsd/commands-codebase.js +4 -3
- package/dist/resources/extensions/gsd/doctor-git-checks.js +4 -4
- package/dist/resources/extensions/gsd/doctor-proactive.js +3 -3
- package/dist/resources/extensions/gsd/guided-flow.js +16 -0
- package/dist/resources/extensions/gsd/prompts/system.md +3 -0
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +508 -0
- package/dist/resources/extensions/gsd/workflow-mcp.js +190 -0
- package/dist/resources/extensions/gsd/workflow-reconcile.js +0 -4
- package/dist/resources/extensions/gsd/worktree-manager.js +6 -2
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +19 -19
- package/dist/web/standalone/.next/build-manifest.json +5 -5
- package/dist/web/standalone/.next/prerender-manifest.json +13 -13
- package/dist/web/standalone/.next/react-loadable-manifest.json +6 -6
- package/dist/web/standalone/.next/required-server-files.json +18 -6
- package/dist/web/standalone/.next/routes-manifest.json +1 -0
- package/dist/web/standalone/.next/server/app/_global-error/page.js +32 -3
- package/dist/web/standalone/.next/server/app/_global-error/page.js.nft.json +1 -1
- 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 -2
- package/dist/web/standalone/.next/server/app/_global-error.rsc +8 -6
- package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +8 -6
- 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 +2 -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 +2 -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.js.nft.json +1 -1
- 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 +9 -7
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +9 -7
- 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 +2 -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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +1 -1
- 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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +1 -1
- 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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +1 -1
- 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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +1 -1
- 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.js.nft.json +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.js.nft.json +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.js.nft.json +1 -1
- 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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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 +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/input/route.js.nft.json +1 -1
- 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.js.nft.json +1 -1
- 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.js.nft.json +1 -1
- 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.js.nft.json +1 -1
- 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.js.nft.json +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.js.nft.json +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.js.nft.json +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.js.nft.json +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 +2 -2
- 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 +2 -2
- 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/page.js +2 -2
- package/dist/web/standalone/.next/server/app/page.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +19 -19
- package/dist/web/standalone/.next/server/chunks/2331.js +7 -7
- package/dist/web/standalone/.next/server/chunks/4741.js +5 -9
- package/dist/web/standalone/.next/server/chunks/63.js +45 -0
- package/dist/web/standalone/.next/server/chunks/6897.js +1 -1
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware.js +11 -8
- package/dist/web/standalone/.next/server/pages/404.html +1 -1
- package/dist/web/standalone/.next/server/pages/500.html +1 -2
- package/dist/web/standalone/.next/server/prefetch-hints.json +1 -0
- package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
- package/dist/web/standalone/.next/static/IBTC_HlEpTBAa4HXMoV_A/_buildManifest.js +1 -0
- package/dist/web/standalone/.next/static/chunks/2008.71ee9230ad78df21.js +20 -0
- package/dist/web/standalone/.next/static/chunks/{363642f4.f9053a63f1b97508.js → 363642f4.cf8b455e0d94b478.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/3794-42fdce068d44fa4f.js +32 -0
- package/dist/web/standalone/.next/static/chunks/{4447.f86b52aea068b189.js → 4447.5bad7871be61ca73.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/4bd1b696-e356ca5ba0218e27.js +1 -0
- package/dist/web/standalone/.next/static/chunks/{e868780c.f7831045ac345aaa.js → e868780c.abc48b70a10fc2d6.js} +3 -3
- package/dist/web/standalone/.next/static/chunks/framework-711ef29bc66f648c.js +1 -0
- package/dist/web/standalone/.next/static/chunks/main-6919d9dd919bd15f.js +5 -0
- package/dist/web/standalone/.next/static/chunks/{webpack-65f0501b197d1c49.js → webpack-b49b09f97429b5d0.js} +1 -1
- package/dist/web/standalone/node_modules/@next/env/package.json +1 -1
- package/dist/web/standalone/node_modules/next/dist/build/adapter/setup-node-env.external.js +15 -0
- package/dist/web/standalone/node_modules/next/dist/build/analysis/extract-const-value.js +78 -63
- package/dist/web/standalone/node_modules/next/dist/build/analysis/get-page-static-info.js +64 -40
- package/dist/web/standalone/node_modules/next/dist/build/create-compiler-aliases.js +2 -0
- package/dist/web/standalone/node_modules/next/dist/build/define-env.js +29 -11
- package/dist/web/standalone/node_modules/next/dist/build/duration-to-string.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/build/entries.js +55 -295
- package/dist/web/standalone/node_modules/next/dist/build/file-classifier.js +76 -0
- package/dist/web/standalone/node_modules/next/dist/build/get-supported-browsers.js +38 -0
- package/dist/web/standalone/node_modules/next/dist/build/load-jsconfig.js +7 -7
- package/dist/web/standalone/node_modules/next/dist/build/lockfile.js +90 -9
- package/dist/web/standalone/node_modules/next/dist/build/next-config-ts/transpile-config.js +128 -49
- package/dist/web/standalone/node_modules/next/dist/build/print-build-errors.js +72 -0
- package/dist/web/standalone/node_modules/next/dist/build/route-discovery.js +353 -0
- package/dist/web/standalone/node_modules/next/dist/build/segment-config/app/app-segment-config.js +34 -17
- package/dist/web/standalone/node_modules/next/dist/build/static-paths/app.js +68 -15
- package/dist/web/standalone/node_modules/next/dist/build/static-paths/pages.js +3 -3
- package/dist/web/standalone/node_modules/next/dist/build/swc/index.js +125 -48
- package/dist/web/standalone/node_modules/next/dist/build/swc/loaderWorkerPool.js +40 -0
- package/dist/web/standalone/node_modules/next/dist/build/swc/options.js +23 -6
- package/dist/web/standalone/node_modules/next/dist/build/utils.js +48 -94
- package/dist/web/standalone/node_modules/next/dist/build/webpack/config/blocks/css/index.js +14 -3
- package/dist/web/standalone/node_modules/next/dist/build/webpack/config/blocks/css/loaders/global.js +4 -2
- package/dist/web/standalone/node_modules/next/dist/build/webpack/config/blocks/css/loaders/modules.js +4 -2
- package/dist/web/standalone/node_modules/next/dist/build/webpack/config/blocks/css/loaders/next-font.js +1 -0
- package/dist/web/standalone/node_modules/next/dist/build/webpack/config/blocks/css/plugins.js +5 -5
- package/dist/web/standalone/node_modules/next/dist/build/webpack/config/index.js +3 -2
- package/dist/web/standalone/node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js +2 -1
- package/dist/web/standalone/node_modules/next/dist/build/webpack/loaders/css-loader/src/plugins/postcss-url-parser.js +8 -1
- package/dist/web/standalone/node_modules/next/dist/build/webpack/loaders/lightningcss-loader/src/loader.js +13 -4
- package/dist/web/standalone/node_modules/next/dist/build/webpack/loaders/next-middleware-loader.js +3 -1
- package/dist/web/standalone/node_modules/next/dist/build/webpack/plugins/build-manifest-plugin-utils.js +2 -16
- package/dist/web/standalone/node_modules/next/dist/build/webpack/plugins/build-manifest-plugin.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/build/webpack/plugins/deferred-entries-plugin.js +106 -0
- package/dist/web/standalone/node_modules/next/dist/build/webpack/plugins/flight-client-entry-plugin.js +16 -8
- package/dist/web/standalone/node_modules/next/dist/build/webpack/plugins/flight-manifest-plugin.js +24 -11
- package/dist/web/standalone/node_modules/next/dist/build/webpack/plugins/middleware-plugin.js +21 -2
- package/dist/web/standalone/node_modules/next/dist/build/webpack/plugins/next-types-plugin/index.js +6 -5
- package/dist/web/standalone/node_modules/next/dist/build/webpack/plugins/nextjs-require-cache-hot-reloader.js +10 -14
- package/dist/web/standalone/node_modules/next/dist/build/webpack/plugins/wellknown-errors-plugin/parseNotFoundError.js +18 -4
- package/dist/web/standalone/node_modules/next/dist/build/webpack/plugins/wellknown-errors-plugin/parseScss.js +5 -4
- package/dist/web/standalone/node_modules/next/dist/build/webpack-config.js +18 -8
- package/dist/web/standalone/node_modules/next/dist/cli/next-test.js +4 -3
- package/dist/web/standalone/node_modules/next/dist/client/app-find-source-map-url.js +2 -1
- package/dist/web/standalone/node_modules/next/dist/client/components/app-router-headers.js +10 -0
- package/dist/web/standalone/node_modules/next/dist/client/components/app-router-instance.js +82 -4
- package/dist/web/standalone/node_modules/next/dist/client/components/app-router.js +39 -20
- package/dist/web/standalone/node_modules/next/dist/client/components/builtin/app-error.js +29 -65
- package/dist/web/standalone/node_modules/next/dist/client/components/builtin/error-styles.js +165 -0
- package/dist/web/standalone/node_modules/next/dist/client/components/builtin/global-error.js +56 -38
- package/dist/web/standalone/node_modules/next/dist/client/components/error-boundary.js +16 -6
- package/dist/web/standalone/node_modules/next/dist/client/components/forbidden.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/client/components/handle-isr-error.js +3 -4
- package/dist/web/standalone/node_modules/next/dist/client/components/links.js +7 -0
- package/dist/web/standalone/node_modules/next/dist/client/components/navigation-untracked.js +2 -0
- package/dist/web/standalone/node_modules/next/dist/client/components/navigation.js +27 -0
- package/dist/web/standalone/node_modules/next/dist/client/components/navigation.react-server.js +5 -2
- package/dist/web/standalone/node_modules/next/dist/client/components/not-found.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/client/components/redirect-boundary.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/client/components/redirect-error.js +0 -9
- package/dist/web/standalone/node_modules/next/dist/client/components/redirect.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/compute-changed-path.js +73 -0
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/create-initial-router-state.js +102 -8
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/fetch-server-response.js +165 -48
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/is-navigating-to-new-root-layout.js +19 -11
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/ppr-navigations.js +669 -457
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/reducers/committed-state.js +49 -0
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/reducers/find-head-in-cache.js +19 -20
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/reducers/navigate-reducer.js +5 -117
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/reducers/refresh-reducer.js +34 -19
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/reducers/restore-reducer.js +16 -32
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/reducers/server-action-reducer.js +85 -57
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/reducers/server-patch-reducer.js +12 -10
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/router-reducer-types.js +10 -1
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/router-reducer.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/client/components/segment-cache/bfcache.js +128 -0
- package/dist/web/standalone/node_modules/next/dist/client/components/segment-cache/cache.js +732 -231
- package/dist/web/standalone/node_modules/next/dist/client/components/segment-cache/lru.js +13 -6
- package/dist/web/standalone/node_modules/next/dist/client/components/segment-cache/navigation-testing-lock.js +194 -0
- package/dist/web/standalone/node_modules/next/dist/client/components/segment-cache/navigation.js +388 -250
- package/dist/web/standalone/node_modules/next/dist/client/components/segment-cache/optimistic-routes.js +543 -0
- package/dist/web/standalone/node_modules/next/dist/client/components/segment-cache/scheduler.js +154 -55
- package/dist/web/standalone/node_modules/next/dist/client/components/segment-cache/vary-path.js +63 -1
- package/dist/web/standalone/node_modules/next/dist/client/components/unauthorized.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/client/components/use-action-queue.js +49 -3
- package/dist/web/standalone/node_modules/next/dist/client/dev/hot-reloader/app/hot-reloader-app.js +9 -1
- package/dist/web/standalone/node_modules/next/dist/client/flight-data-helpers.js +42 -29
- package/dist/web/standalone/node_modules/next/dist/client/lib/javascript-url.js +32 -0
- package/dist/web/standalone/node_modules/next/dist/client/lib/promise.js +53 -0
- package/dist/web/standalone/node_modules/next/dist/client/{app-build-id.js → navigation-build-id.js} +17 -13
- package/dist/web/standalone/node_modules/next/dist/client/react-client-callbacks/on-recoverable-error.js +14 -0
- package/dist/web/standalone/node_modules/next/dist/client/route-loader.js +9 -46
- package/dist/web/standalone/node_modules/next/dist/client/router.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/compiled/@next/font/dist/google/font-data.json +74 -3
- package/dist/web/standalone/node_modules/next/dist/compiled/babel/bundle.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/compiled/babel-packages/packages-bundle.js +5 -5
- package/dist/web/standalone/node_modules/next/dist/compiled/browserslist/index.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/compiled/http-proxy/index.js +5 -5
- package/dist/web/standalone/node_modules/next/dist/compiled/jsonwebtoken/index.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/compiled/next-devtools/index.js +2209 -23
- package/dist/web/standalone/node_modules/next/dist/compiled/next-server/app-page-experimental.runtime.prod.js +42 -12
- package/dist/web/standalone/node_modules/next/dist/compiled/next-server/app-page-turbo-experimental.runtime.prod.js +42 -12
- package/dist/web/standalone/node_modules/next/dist/compiled/next-server/app-page-turbo.runtime.prod.js +42 -12
- package/dist/web/standalone/node_modules/next/dist/compiled/next-server/app-page.runtime.prod.js +42 -12
- package/dist/web/standalone/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/compiled/next-server/pages-turbo.runtime.prod.js +10 -10
- package/dist/web/standalone/node_modules/next/dist/compiled/next-server/pages.runtime.prod.js +10 -10
- package/dist/web/standalone/node_modules/next/dist/compiled/react-is/package.json +1 -1
- package/dist/web/standalone/node_modules/next/dist/compiled/tar/index.min.js +1 -0
- package/dist/web/standalone/node_modules/next/dist/compiled/tar/package.json +1 -1
- package/dist/web/standalone/node_modules/next/dist/compiled/unistore/unistore.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/lib/bundler.js +97 -0
- package/dist/web/standalone/node_modules/next/dist/lib/constants.js +19 -4
- package/dist/web/standalone/node_modules/next/dist/lib/download-swc.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/lib/find-root.js +11 -7
- package/dist/web/standalone/node_modules/next/dist/lib/format-server-error.js +1 -0
- package/dist/web/standalone/node_modules/next/dist/lib/generate-interception-routes-rewrites.js +3 -20
- package/dist/web/standalone/node_modules/next/dist/lib/interop-default.js +1 -0
- package/dist/web/standalone/node_modules/next/dist/lib/is-interception-route-rewrite.js +18 -0
- package/dist/web/standalone/node_modules/next/dist/lib/load-custom-routes.js +49 -5
- package/dist/web/standalone/node_modules/next/dist/lib/memory/trace.js +109 -0
- package/dist/web/standalone/node_modules/next/dist/lib/metadata/get-metadata-route.js +11 -2
- package/dist/web/standalone/node_modules/next/dist/lib/needs-experimental-react.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/lib/patch-incorrect-lockfile.js +5 -5
- package/dist/web/standalone/node_modules/next/dist/lib/try-to-parse-path.js +1 -2
- package/dist/web/standalone/node_modules/next/dist/lib/turbopack-warning.js +0 -1
- package/dist/web/standalone/node_modules/next/dist/lib/typescript/diagnosticFormatter.js +6 -3
- package/dist/web/standalone/node_modules/next/dist/lib/typescript/getTypeScriptConfiguration.js +81 -1
- package/dist/web/standalone/node_modules/next/dist/lib/typescript/missingDependencyError.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/lib/typescript/runTypeCheck.js +6 -8
- package/dist/web/standalone/node_modules/next/dist/lib/typescript/type-paths.js +7 -12
- package/dist/web/standalone/node_modules/next/dist/lib/typescript/writeAppTypeDeclarations.js +17 -7
- package/dist/web/standalone/node_modules/next/dist/lib/typescript/writeConfigurationDefaults.js +33 -32
- package/dist/web/standalone/node_modules/next/dist/lib/verify-typescript-setup.js +66 -16
- package/dist/web/standalone/node_modules/next/dist/next-devtools/server/shared.js +6 -10
- package/dist/web/standalone/node_modules/next/dist/next-devtools/shared/webpack-module-path.js +4 -4
- package/dist/web/standalone/node_modules/next/dist/next-devtools/userspace/app/app-dev-overlay-error-boundary.js +22 -4
- package/dist/web/standalone/node_modules/next/dist/next-devtools/userspace/app/errors/stitched-error.js +7 -1
- package/dist/web/standalone/node_modules/next/dist/next-devtools/userspace/app/forward-logs.js +18 -13
- package/dist/web/standalone/node_modules/next/dist/next-devtools/userspace/app/segment-explorer-node.js +7 -4
- package/dist/web/standalone/node_modules/next/dist/server/app-render/action-handler.js +83 -15
- package/dist/web/standalone/node_modules/next/dist/server/app-render/app-render-prerender-utils.js +0 -82
- package/dist/web/standalone/node_modules/next/dist/server/app-render/app-render-render-utils.js +45 -81
- package/dist/web/standalone/node_modules/next/dist/server/app-render/app-render.js +1746 -803
- package/dist/web/standalone/node_modules/next/dist/server/app-render/create-component-tree.js +136 -50
- package/dist/web/standalone/node_modules/next/dist/server/app-render/create-error-handler.js +6 -4
- package/dist/web/standalone/node_modules/next/dist/server/app-render/create-flight-router-state-from-loader-tree.js +52 -26
- package/dist/web/standalone/node_modules/next/dist/server/app-render/csrf-protection.js +14 -3
- package/dist/web/standalone/node_modules/next/dist/server/app-render/debug-channel-server.js +30 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/debug-channel-server.web.js +71 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/dynamic-rendering.js +353 -37
- package/dist/web/standalone/node_modules/next/dist/server/app-render/get-asset-query-string.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/server/app-render/get-layer-assets.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/server/app-render/instant-validation/boundary-constants.js +13 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/instant-validation/boundary-tracking.js +18 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/instant-validation/instant-config.js +181 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/instant-validation/instant-samples-client.js +128 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/instant-validation/instant-samples.js +432 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/instant-validation/instant-validation-error.js +33 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/instant-validation/stream-utils.js +96 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/manifests-singleton.js +8 -1
- package/dist/web/standalone/node_modules/next/dist/server/app-render/postponed-state.js +2 -1
- package/dist/web/standalone/node_modules/next/dist/server/app-render/prospective-render-utils.js +1 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/segment-explorer-path.js +35 -10
- package/dist/web/standalone/node_modules/next/dist/server/app-render/staged-rendering.js +142 -72
- package/dist/web/standalone/node_modules/next/dist/server/app-render/stale-time.js +111 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/stream-ops.js +106 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/stream-ops.web.js +163 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/types.js +10 -4
- package/dist/web/standalone/node_modules/next/dist/server/app-render/use-flight-response.js +3 -1
- package/dist/web/standalone/node_modules/next/dist/server/app-render/vary-params.js +336 -0
- package/dist/web/standalone/node_modules/next/dist/server/app-render/walk-tree-with-flight-router-state.js +59 -12
- package/dist/web/standalone/node_modules/next/dist/server/app-render/work-unit-async-storage.external.js +54 -26
- package/dist/web/standalone/node_modules/next/dist/server/async-storage/request-store.js +4 -4
- package/dist/web/standalone/node_modules/next/dist/server/async-storage/work-store.js +2 -5
- package/dist/web/standalone/node_modules/next/dist/server/base-server.js +65 -53
- package/dist/web/standalone/node_modules/next/dist/server/config-schema.js +94 -8
- package/dist/web/standalone/node_modules/next/dist/server/config-shared.js +57 -7
- package/dist/web/standalone/node_modules/next/dist/server/config.js +96 -25
- package/dist/web/standalone/node_modules/next/dist/server/dev/browser-logs/file-logger.js +9 -6
- package/dist/web/standalone/node_modules/next/dist/server/dev/browser-logs/receive-logs.js +46 -0
- package/dist/web/standalone/node_modules/next/dist/server/dev/browser-logs/source-map.js +1 -4
- package/dist/web/standalone/node_modules/next/dist/server/dev/hot-reloader-turbopack.js +266 -33
- package/dist/web/standalone/node_modules/next/dist/server/dev/hot-reloader-webpack.js +8 -4
- package/dist/web/standalone/node_modules/next/dist/server/dev/log-requests.js +10 -2
- package/dist/web/standalone/node_modules/next/dist/server/dev/middleware-turbopack.js +20 -10
- package/dist/web/standalone/node_modules/next/dist/server/dev/middleware-webpack.js +13 -3
- package/dist/web/standalone/node_modules/next/dist/server/dev/next-dev-server.js +19 -6
- package/dist/web/standalone/node_modules/next/dist/server/dev/on-demand-entry-handler.js +69 -0
- package/dist/web/standalone/node_modules/next/dist/server/dev/require-cache.js +51 -21
- package/dist/web/standalone/node_modules/next/dist/server/dev/server-action-logger.js +37 -0
- package/dist/web/standalone/node_modules/next/dist/server/dev/static-paths-worker.js +1 -0
- package/dist/web/standalone/node_modules/next/dist/server/dev/turbopack-utils.js +6 -15
- package/dist/web/standalone/node_modules/next/dist/server/dynamic-rendering-utils.js +22 -0
- package/dist/web/standalone/node_modules/next/dist/server/image-optimizer.js +157 -27
- package/dist/web/standalone/node_modules/next/dist/server/lib/app-info-log.js +16 -38
- package/dist/web/standalone/node_modules/next/dist/server/lib/cache-control.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/server/lib/clone-response.js +16 -16
- package/dist/web/standalone/node_modules/next/dist/server/lib/cpu-profile.js +47 -16
- package/dist/web/standalone/node_modules/next/dist/server/lib/dev-bundler-service.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/server/lib/disk-lru-cache.external.js +57 -0
- package/dist/web/standalone/node_modules/next/dist/server/lib/find-page-file.js +27 -7
- package/dist/web/standalone/node_modules/next/dist/server/lib/implicit-tags.js +3 -3
- package/dist/web/standalone/node_modules/next/dist/server/lib/incremental-cache/file-system-cache.js +5 -3
- package/dist/web/standalone/node_modules/next/dist/server/lib/incremental-cache/index.js +32 -10
- package/dist/web/standalone/node_modules/next/dist/server/lib/incremental-cache/memory-cache.external.js +18 -1
- package/dist/web/standalone/node_modules/next/dist/server/lib/install-code-frame.js +22 -0
- package/dist/web/standalone/node_modules/next/dist/server/lib/lru-cache.js +9 -1
- package/dist/web/standalone/node_modules/next/dist/server/lib/patch-fetch.js +40 -7
- package/dist/web/standalone/node_modules/next/dist/server/lib/postponed-request-body.js +64 -0
- package/dist/web/standalone/node_modules/next/dist/server/lib/render-server.js +4 -1
- package/dist/web/standalone/node_modules/next/dist/server/lib/router-server.js +37 -13
- package/dist/web/standalone/node_modules/next/dist/server/lib/router-utils/block-cross-site-dev.js +110 -0
- package/dist/web/standalone/node_modules/next/dist/server/lib/router-utils/filesystem.js +16 -15
- package/dist/web/standalone/node_modules/next/dist/server/lib/router-utils/resolve-routes.js +32 -11
- package/dist/web/standalone/node_modules/next/dist/server/lib/router-utils/route-types-utils.js +3 -3
- package/dist/web/standalone/node_modules/next/dist/server/lib/router-utils/setup-dev-bundler.js +71 -71
- package/dist/web/standalone/node_modules/next/dist/server/lib/router-utils/typegen.js +247 -2
- package/dist/web/standalone/node_modules/next/dist/server/lib/server-ipc/utils.js +2 -1
- package/dist/web/standalone/node_modules/next/dist/server/lib/start-server.js +73 -39
- package/dist/web/standalone/node_modules/next/dist/server/lib/trace/tracer.js +11 -1
- package/dist/web/standalone/node_modules/next/dist/server/lib/utils.js +40 -11
- package/dist/web/standalone/node_modules/next/dist/server/load-components.js +2 -0
- package/dist/web/standalone/node_modules/next/dist/server/load-manifest.external.js +37 -17
- package/dist/web/standalone/node_modules/next/dist/server/mcp/tools/get-errors.js +11 -4
- package/dist/web/standalone/node_modules/next/dist/server/mcp/tools/get-logs.js +9 -3
- package/dist/web/standalone/node_modules/next/dist/server/mcp/tools/get-page-metadata.js +52 -44
- package/dist/web/standalone/node_modules/next/dist/server/mcp/tools/get-project-metadata.js +6 -2
- package/dist/web/standalone/node_modules/next/dist/server/mcp/tools/get-routes.js +44 -79
- package/dist/web/standalone/node_modules/next/dist/server/mcp/tools/get-server-action-by-id.js +12 -4
- package/dist/web/standalone/node_modules/next/dist/server/mcp/tools/utils/format-errors.js +62 -72
- package/dist/web/standalone/node_modules/next/dist/server/next-server.js +69 -99
- package/dist/web/standalone/node_modules/next/dist/server/next.js +3 -0
- package/dist/web/standalone/node_modules/next/dist/server/node-environment-extensions/console-dim.external.js +61 -6
- package/dist/web/standalone/node_modules/next/dist/server/node-environment-extensions/date.js +4 -4
- package/dist/web/standalone/node_modules/next/dist/server/node-environment-extensions/fast-set-immediate.external.js +13 -6
- package/dist/web/standalone/node_modules/next/dist/server/node-environment-extensions/{utils.js → io-utils.js} +14 -5
- package/dist/web/standalone/node_modules/next/dist/server/node-environment-extensions/node-crypto.js +8 -8
- package/dist/web/standalone/node_modules/next/dist/server/node-environment-extensions/process-error-handlers.js +91 -0
- package/dist/web/standalone/node_modules/next/dist/server/node-environment-extensions/random.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/server/node-environment-extensions/{unhandled-rejection.js → unhandled-rejection.external.js} +23 -4
- package/dist/web/standalone/node_modules/next/dist/server/node-environment-extensions/web-crypto.js +3 -3
- package/dist/web/standalone/node_modules/next/dist/server/node-environment.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/server/normalizers/request/segment-prefix-rsc.js +2 -1
- package/dist/web/standalone/node_modules/next/dist/server/patch-error-inspect.js +37 -20
- package/dist/web/standalone/node_modules/next/dist/server/render-result.js +9 -0
- package/dist/web/standalone/node_modules/next/dist/server/render.js +47 -44
- package/dist/web/standalone/node_modules/next/dist/server/require-hook.js +19 -8
- package/dist/web/standalone/node_modules/next/dist/server/response-cache/utils.js +1 -0
- package/dist/web/standalone/node_modules/next/dist/server/resume-data-cache/cache-store.js +35 -23
- package/dist/web/standalone/node_modules/next/dist/server/resume-data-cache/resume-data-cache.js +16 -7
- package/dist/web/standalone/node_modules/next/dist/server/revalidation-utils.js +12 -7
- package/dist/web/standalone/node_modules/next/dist/server/route-matcher-providers/dev/dev-app-page-route-matcher-provider.js +2 -1
- package/dist/web/standalone/node_modules/next/dist/server/route-modules/app-page/helpers/prerender-manifest-matcher.js +4 -1
- package/dist/web/standalone/node_modules/next/dist/server/route-modules/app-page/module.js +31 -1
- package/dist/web/standalone/node_modules/next/dist/server/route-modules/app-page/normalize-request-url.js +25 -0
- package/dist/web/standalone/node_modules/next/dist/server/route-modules/pages/pages-handler.js +31 -8
- package/dist/web/standalone/node_modules/next/dist/server/route-modules/route-module.js +71 -18
- package/dist/web/standalone/node_modules/next/dist/server/stream-utils/encoded-tags.js +8 -0
- package/dist/web/standalone/node_modules/next/dist/server/stream-utils/node-web-streams-helper.js +239 -58
- package/dist/web/standalone/node_modules/next/dist/server/stream-utils/uint8array-helpers.js +7 -2
- package/dist/web/standalone/node_modules/next/dist/server/typescript/constant.js +1 -0
- package/dist/web/standalone/node_modules/next/dist/server/typescript/rules/config.js +14 -3
- package/dist/web/standalone/node_modules/next/dist/server/web/adapter.js +7 -3
- package/dist/web/standalone/node_modules/next/dist/server/web/next-url.js +6 -2
- package/dist/web/standalone/node_modules/next/dist/server/web/sandbox/sandbox.js +3 -0
- package/dist/web/standalone/node_modules/next/dist/shared/lib/app-router-types.js +30 -11
- package/dist/web/standalone/node_modules/next/dist/shared/lib/constants.js +7 -7
- package/dist/web/standalone/node_modules/next/dist/shared/lib/deployment-id.js +37 -10
- package/dist/web/standalone/node_modules/next/dist/shared/lib/errors/canary-only-config-error.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/shared/lib/errors/code-frame.js +20 -0
- package/dist/web/standalone/node_modules/next/dist/shared/lib/format-webpack-messages.js +22 -2
- package/dist/web/standalone/node_modules/next/dist/shared/lib/image-config.js +3 -1
- package/dist/web/standalone/node_modules/next/dist/shared/lib/is-internal.js +2 -0
- package/dist/web/standalone/node_modules/next/dist/shared/lib/magic-identifier.js +6 -6
- package/dist/web/standalone/node_modules/next/dist/shared/lib/router/router.js +32 -0
- package/dist/web/standalone/node_modules/next/dist/shared/lib/router/utils/app-paths.js +11 -0
- package/dist/web/standalone/node_modules/next/dist/shared/lib/router/utils/get-dynamic-param.js +11 -4
- package/dist/web/standalone/node_modules/next/dist/shared/lib/router/utils/parse-loader-tree.js +3 -2
- package/dist/web/standalone/node_modules/next/dist/shared/lib/router/utils/parse-relative-url.js +9 -2
- package/dist/web/standalone/node_modules/next/dist/shared/lib/router/utils/parse-url.js +8 -2
- package/dist/web/standalone/node_modules/next/dist/shared/lib/segment-cache/vary-params-decoding.js +32 -0
- package/dist/web/standalone/node_modules/next/dist/shared/lib/server-reference-info.js +4 -0
- package/dist/web/standalone/node_modules/next/dist/shared/lib/size-limit.js +6 -1
- package/dist/web/standalone/node_modules/next/dist/shared/lib/turbopack/compilation-events.js +47 -10
- package/dist/web/standalone/node_modules/next/dist/shared/lib/turbopack/manifest-loader.js +90 -116
- package/dist/web/standalone/node_modules/next/dist/shared/lib/turbopack/utils.js +14 -26
- package/dist/web/standalone/node_modules/next/dist/shared/lib/utils/reflect-utils.js +69 -0
- package/dist/web/standalone/node_modules/next/dist/shared/lib/utils.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/telemetry/anonymous-meta.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/telemetry/events/swc-load-failure.js +1 -1
- package/dist/web/standalone/node_modules/next/dist/telemetry/events/version.js +2 -2
- package/dist/web/standalone/node_modules/next/dist/trace/index.js +4 -0
- package/dist/web/standalone/node_modules/next/dist/trace/report/to-json-build.js +11 -108
- package/dist/web/standalone/node_modules/next/dist/trace/report/to-json.js +52 -38
- package/dist/web/standalone/node_modules/next/dist/trace/trace.js +15 -1
- package/dist/web/standalone/node_modules/next/package.json +21 -23
- package/dist/web/standalone/node_modules/react/cjs/react.development.js +1284 -0
- package/dist/web/standalone/package.json +2 -2
- package/dist/web/standalone/server.js +1 -1
- package/package.json +1 -1
- package/packages/mcp-server/README.md +38 -0
- package/packages/mcp-server/src/server.ts +6 -2
- package/packages/mcp-server/src/workflow-tools.test.ts +976 -0
- package/packages/mcp-server/src/workflow-tools.ts +986 -0
- package/packages/pi-ai/dist/utils/event-stream.d.ts +2 -0
- package/packages/pi-ai/dist/utils/event-stream.d.ts.map +1 -1
- package/packages/pi-ai/dist/utils/event-stream.js +4 -0
- package/packages/pi-ai/dist/utils/event-stream.js.map +1 -1
- package/packages/pi-ai/src/utils/event-stream.ts +5 -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 +12 -2
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/provider-auth-setup.d.ts +13 -0
- package/packages/pi-coding-agent/dist/modes/interactive/provider-auth-setup.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/provider-auth-setup.js +27 -0
- package/packages/pi-coding-agent/dist/modes/interactive/provider-auth-setup.js.map +1 -0
- package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +15 -2
- package/packages/pi-coding-agent/src/modes/interactive/provider-auth-setup.ts +40 -0
- package/src/resources/GSD-WORKFLOW.md +3 -1
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +96 -44
- package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +211 -2
- package/src/resources/extensions/get-secrets-from-user.ts +20 -2
- package/src/resources/extensions/gsd/auto/phases.ts +25 -0
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +20 -0
- package/src/resources/extensions/gsd/auto-post-unit.ts +30 -1
- package/src/resources/extensions/gsd/bootstrap/db-tools.ts +22 -435
- package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +1 -5
- package/src/resources/extensions/gsd/bootstrap/query-tools.ts +7 -72
- package/src/resources/extensions/gsd/bootstrap/system-context.ts +18 -4
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +122 -6
- package/src/resources/extensions/gsd/codebase-generator.ts +261 -16
- package/src/resources/extensions/gsd/commands/catalog.ts +2 -2
- package/src/resources/extensions/gsd/commands/handlers/core.ts +1 -0
- package/src/resources/extensions/gsd/commands-bootstrap.ts +10 -0
- package/src/resources/extensions/gsd/commands-codebase.ts +4 -3
- package/src/resources/extensions/gsd/doctor-git-checks.ts +4 -4
- package/src/resources/extensions/gsd/doctor-proactive.ts +3 -3
- package/src/resources/extensions/gsd/guided-flow.ts +24 -0
- package/src/resources/extensions/gsd/prompts/system.md +3 -0
- package/src/resources/extensions/gsd/tests/codebase-generator.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +66 -0
- package/src/resources/extensions/gsd/tests/integration/doctor-git.test.ts +9 -2
- package/src/resources/extensions/gsd/tests/integration/doctor-proactive.test.ts +33 -0
- package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +7 -0
- package/src/resources/extensions/gsd/tests/update-command.test.ts +19 -0
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +301 -0
- package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +625 -0
- package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +629 -0
- package/src/resources/extensions/gsd/workflow-mcp.ts +233 -0
- package/src/resources/extensions/gsd/workflow-reconcile.ts +0 -5
- package/src/resources/extensions/gsd/worktree-manager.ts +6 -2
- package/dist/web/standalone/.next/server/chunks/7471.js +0 -13
- package/dist/web/standalone/.next/static/CrKrzIIxk55witDF1eS0L/_buildManifest.js +0 -1
- package/dist/web/standalone/.next/static/chunks/2008.817d0885545aaea9.js +0 -20
- package/dist/web/standalone/.next/static/chunks/3794-337d1ca25ad99a89.js +0 -2
- package/dist/web/standalone/.next/static/chunks/4bd1b696-e5d7c65570c947b7.js +0 -1
- package/dist/web/standalone/.next/static/chunks/framework-0675a4b5b92df616.js +0 -1
- package/dist/web/standalone/.next/static/chunks/main-cb72b7c5b8014fa5.js +0 -5
- package/dist/web/standalone/node_modules/next/dist/client/components/router-reducer/handle-mutable.js +0 -66
- package/dist/web/standalone/node_modules/next/dist/compiled/babel/code-frame.js +0 -1
- package/dist/web/standalone/node_modules/next/dist/compiled/babel-code-frame/index.js +0 -1
- package/dist/web/standalone/node_modules/next/dist/compiled/babel-code-frame/package.json +0 -1
- package/dist/web/standalone/node_modules/next/dist/compiled/tar/index.js +0 -1
- package/dist/web/standalone/node_modules/next/dist/server/app-render/staged-validation.js +0 -32
- package/dist/web/standalone/node_modules/next/dist/server/lib/router-utils/block-cross-site.js +0 -76
- package/dist/web/standalone/node_modules/next/dist/shared/lib/segment-cache/output-export-prefetch-encoding.js +0 -52
- package/dist/web/standalone/node_modules/typescript/lib/typescript.js +0 -198668
- package/dist/web/standalone/node_modules/typescript/package.json +0 -120
- /package/dist/web/standalone/.next/static/{CrKrzIIxk55witDF1eS0L → IBTC_HlEpTBAa4HXMoV_A}/_ssgManifest.js +0 -0
|
@@ -29,6 +29,10 @@ import {
|
|
|
29
29
|
} from "./auto-prompts.js";
|
|
30
30
|
import { loadEffectiveGSDPreferences } from "./preferences.js";
|
|
31
31
|
import { pauseAuto } from "./auto.js";
|
|
32
|
+
import {
|
|
33
|
+
getWorkflowTransportSupportError,
|
|
34
|
+
getRequiredWorkflowToolsForAutoUnit,
|
|
35
|
+
} from "./workflow-mcp.js";
|
|
32
36
|
|
|
33
37
|
export async function dispatchDirectPhase(
|
|
34
38
|
ctx: ExtensionCommandContext,
|
|
@@ -243,6 +247,22 @@ export async function dispatchDirectPhase(
|
|
|
243
247
|
return;
|
|
244
248
|
}
|
|
245
249
|
|
|
250
|
+
const compatibilityError = getWorkflowTransportSupportError(
|
|
251
|
+
ctx.model?.provider,
|
|
252
|
+
getRequiredWorkflowToolsForAutoUnit(unitType),
|
|
253
|
+
{
|
|
254
|
+
projectRoot: base,
|
|
255
|
+
surface: "direct phase dispatch",
|
|
256
|
+
unitType,
|
|
257
|
+
authMode: ctx.model?.provider ? ctx.modelRegistry.getProviderAuthMode(ctx.model.provider) : undefined,
|
|
258
|
+
baseUrl: ctx.model?.baseUrl,
|
|
259
|
+
},
|
|
260
|
+
);
|
|
261
|
+
if (compatibilityError) {
|
|
262
|
+
ctx.ui.notify(compatibilityError, "error");
|
|
263
|
+
return;
|
|
264
|
+
}
|
|
265
|
+
|
|
246
266
|
ctx.ui.notify(`Dispatching ${unitType} for ${unitId}...`, "info");
|
|
247
267
|
const result = await ctx.newSession();
|
|
248
268
|
if (result.cancelled) {
|
|
@@ -64,6 +64,7 @@ import { loadEffectiveGSDPreferences } from "./preferences.js";
|
|
|
64
64
|
import { getSliceTasks } from "./gsd-db.js";
|
|
65
65
|
import { runPreExecutionChecks, type PreExecutionResult } from "./pre-execution-checks.js";
|
|
66
66
|
import { writePreExecutionEvidence } from "./verification-evidence.js";
|
|
67
|
+
import { ensureCodebaseMapFresh } from "./codebase-generator.js";
|
|
67
68
|
|
|
68
69
|
/** Maximum verification retry attempts before escalating to blocker placeholder (#2653). */
|
|
69
70
|
const MAX_VERIFICATION_RETRIES = 3;
|
|
@@ -669,6 +670,35 @@ export async function postUnitPreVerification(pctx: PostUnitContext, opts?: PreV
|
|
|
669
670
|
export async function postUnitPostVerification(pctx: PostUnitContext): Promise<"continue" | "step-wizard" | "stopped"> {
|
|
670
671
|
const { s, ctx, pi, buildSnapshotOpts, lockBase, stopAuto, pauseAuto, updateProgressWidget } = pctx;
|
|
671
672
|
|
|
673
|
+
if (s.currentUnit) {
|
|
674
|
+
try {
|
|
675
|
+
const codebasePrefs = loadEffectiveGSDPreferences()?.preferences?.codebase;
|
|
676
|
+
const refresh = ensureCodebaseMapFresh(
|
|
677
|
+
s.basePath,
|
|
678
|
+
codebasePrefs
|
|
679
|
+
? {
|
|
680
|
+
excludePatterns: codebasePrefs.exclude_patterns,
|
|
681
|
+
maxFiles: codebasePrefs.max_files,
|
|
682
|
+
collapseThreshold: codebasePrefs.collapse_threshold,
|
|
683
|
+
}
|
|
684
|
+
: undefined,
|
|
685
|
+
{ force: true, ttlMs: 0 },
|
|
686
|
+
);
|
|
687
|
+
if (refresh.status === "generated" || refresh.status === "updated") {
|
|
688
|
+
debugLog("postUnit", {
|
|
689
|
+
phase: "codebase-refresh",
|
|
690
|
+
unitType: s.currentUnit.type,
|
|
691
|
+
unitId: s.currentUnit.id,
|
|
692
|
+
status: refresh.status,
|
|
693
|
+
fileCount: refresh.fileCount,
|
|
694
|
+
reason: refresh.reason,
|
|
695
|
+
});
|
|
696
|
+
}
|
|
697
|
+
} catch (e) {
|
|
698
|
+
logWarning("engine", `CODEBASE refresh failed: ${(e as Error).message}`);
|
|
699
|
+
}
|
|
700
|
+
}
|
|
701
|
+
|
|
672
702
|
// ── Post-unit hooks ──
|
|
673
703
|
if (s.currentUnit && !s.stepMode) {
|
|
674
704
|
const hookUnit = checkPostUnitHooks(s.currentUnit.type, s.currentUnit.id, s.basePath);
|
|
@@ -995,4 +1025,3 @@ export async function postUnitPostVerification(pctx: PostUnitContext): Promise<"
|
|
|
995
1025
|
|
|
996
1026
|
return "continue";
|
|
997
1027
|
}
|
|
998
|
-
|
|
@@ -8,15 +8,18 @@ import { ensureDbOpen } from "./dynamic-tools.js";
|
|
|
8
8
|
import { StringEnum } from "@gsd/pi-ai";
|
|
9
9
|
import { logError } from "../workflow-logger.js";
|
|
10
10
|
import { getErrorMessage } from "../error-utils.js";
|
|
11
|
-
import {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
11
|
+
import {
|
|
12
|
+
executeCompleteMilestone,
|
|
13
|
+
executePlanMilestone,
|
|
14
|
+
executePlanSlice,
|
|
15
|
+
executeReplanSlice,
|
|
16
|
+
executeReassessRoadmap,
|
|
17
|
+
executeSaveGateResult,
|
|
18
|
+
executeSliceComplete,
|
|
19
|
+
executeSummarySave,
|
|
20
|
+
executeTaskComplete,
|
|
21
|
+
executeValidateMilestone,
|
|
22
|
+
} from "../tools/workflow-tool-executors.js";
|
|
20
23
|
|
|
21
24
|
/**
|
|
22
25
|
* Register an alias tool that shares the same execute function as its canonical counterpart.
|
|
@@ -286,63 +289,7 @@ export function registerDbTools(pi: ExtensionAPI): void {
|
|
|
286
289
|
// ─── gsd_summary_save (formerly gsd_save_summary) ──────────────────────
|
|
287
290
|
|
|
288
291
|
const summarySaveExecute = async (_toolCallId: string, params: any, _signal: AbortSignal | undefined, _onUpdate: unknown, _ctx: unknown) => {
|
|
289
|
-
|
|
290
|
-
if (!dbAvailable) {
|
|
291
|
-
return {
|
|
292
|
-
content: [{ type: "text" as const, text: "Error: GSD database is not available. Cannot save artifact." }],
|
|
293
|
-
details: { operation: "save_summary", error: "db_unavailable" } as any,
|
|
294
|
-
};
|
|
295
|
-
}
|
|
296
|
-
if (!isSupportedSummaryArtifactType(params.artifact_type)) {
|
|
297
|
-
return {
|
|
298
|
-
content: [{ type: "text" as const, text: `Error: Invalid artifact_type "${params.artifact_type}". Must be one of: ${SUPPORTED_SUMMARY_ARTIFACT_TYPES.join(", ")}` }],
|
|
299
|
-
details: { operation: "save_summary", error: "invalid_artifact_type" } as any,
|
|
300
|
-
};
|
|
301
|
-
}
|
|
302
|
-
const contextGuard = shouldBlockContextArtifactSave(
|
|
303
|
-
params.artifact_type,
|
|
304
|
-
params.milestone_id ?? null,
|
|
305
|
-
params.slice_id ?? null,
|
|
306
|
-
);
|
|
307
|
-
if (contextGuard.block) {
|
|
308
|
-
return {
|
|
309
|
-
content: [{ type: "text" as const, text: `Error saving artifact: ${contextGuard.reason ?? "context write blocked"}` }],
|
|
310
|
-
details: { operation: "save_summary", error: "context_write_blocked" } as any,
|
|
311
|
-
};
|
|
312
|
-
}
|
|
313
|
-
try {
|
|
314
|
-
let relativePath: string;
|
|
315
|
-
if (params.task_id && params.slice_id) {
|
|
316
|
-
relativePath = `milestones/${params.milestone_id}/slices/${params.slice_id}/tasks/${params.task_id}-${params.artifact_type}.md`;
|
|
317
|
-
} else if (params.slice_id) {
|
|
318
|
-
relativePath = `milestones/${params.milestone_id}/slices/${params.slice_id}/${params.slice_id}-${params.artifact_type}.md`;
|
|
319
|
-
} else {
|
|
320
|
-
relativePath = `milestones/${params.milestone_id}/${params.milestone_id}-${params.artifact_type}.md`;
|
|
321
|
-
}
|
|
322
|
-
const { saveArtifactToDb } = await import("../db-writer.js");
|
|
323
|
-
await saveArtifactToDb(
|
|
324
|
-
{
|
|
325
|
-
path: relativePath,
|
|
326
|
-
artifact_type: params.artifact_type,
|
|
327
|
-
content: params.content,
|
|
328
|
-
milestone_id: params.milestone_id,
|
|
329
|
-
slice_id: params.slice_id,
|
|
330
|
-
task_id: params.task_id,
|
|
331
|
-
},
|
|
332
|
-
process.cwd(),
|
|
333
|
-
);
|
|
334
|
-
return {
|
|
335
|
-
content: [{ type: "text" as const, text: `Saved ${params.artifact_type} artifact to ${relativePath}` }],
|
|
336
|
-
details: { operation: "save_summary", path: relativePath, artifact_type: params.artifact_type } as any,
|
|
337
|
-
};
|
|
338
|
-
} catch (err) {
|
|
339
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
340
|
-
logError("tool", `gsd_summary_save tool failed: ${msg}`, { tool: "gsd_summary_save", error: String(err) });
|
|
341
|
-
return {
|
|
342
|
-
content: [{ type: "text" as const, text: `Error saving artifact: ${msg}` }],
|
|
343
|
-
details: { operation: "save_summary", error: msg } as any,
|
|
344
|
-
};
|
|
345
|
-
}
|
|
292
|
+
return executeSummarySave(params, process.cwd());
|
|
346
293
|
};
|
|
347
294
|
|
|
348
295
|
const summarySaveTool = {
|
|
@@ -475,38 +422,7 @@ export function registerDbTools(pi: ExtensionAPI): void {
|
|
|
475
422
|
// ─── gsd_plan_milestone (gsd_milestone_plan alias) ─────────────────────
|
|
476
423
|
|
|
477
424
|
const planMilestoneExecute = async (_toolCallId: string, params: any, _signal: AbortSignal | undefined, _onUpdate: unknown, _ctx: unknown) => {
|
|
478
|
-
|
|
479
|
-
if (!dbAvailable) {
|
|
480
|
-
return {
|
|
481
|
-
content: [{ type: "text" as const, text: "Error: GSD database is not available. Cannot plan milestone." }],
|
|
482
|
-
details: { operation: "plan_milestone", error: "db_unavailable" } as any,
|
|
483
|
-
};
|
|
484
|
-
}
|
|
485
|
-
try {
|
|
486
|
-
const { handlePlanMilestone } = await import("../tools/plan-milestone.js");
|
|
487
|
-
const result = await handlePlanMilestone(params, process.cwd());
|
|
488
|
-
if ("error" in result) {
|
|
489
|
-
return {
|
|
490
|
-
content: [{ type: "text" as const, text: `Error planning milestone: ${result.error}` }],
|
|
491
|
-
details: { operation: "plan_milestone", error: result.error } as any,
|
|
492
|
-
};
|
|
493
|
-
}
|
|
494
|
-
return {
|
|
495
|
-
content: [{ type: "text" as const, text: `Planned milestone ${result.milestoneId}` }],
|
|
496
|
-
details: {
|
|
497
|
-
operation: "plan_milestone",
|
|
498
|
-
milestoneId: result.milestoneId,
|
|
499
|
-
roadmapPath: result.roadmapPath,
|
|
500
|
-
} as any,
|
|
501
|
-
};
|
|
502
|
-
} catch (err) {
|
|
503
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
504
|
-
logError("tool", `plan_milestone tool failed: ${msg}`, { tool: "gsd_plan_milestone", error: String(err) });
|
|
505
|
-
return {
|
|
506
|
-
content: [{ type: "text" as const, text: `Error planning milestone: ${msg}` }],
|
|
507
|
-
details: { operation: "plan_milestone", error: msg } as any,
|
|
508
|
-
};
|
|
509
|
-
}
|
|
425
|
+
return executePlanMilestone(params, process.cwd());
|
|
510
426
|
};
|
|
511
427
|
|
|
512
428
|
const planMilestoneTool = {
|
|
@@ -568,40 +484,7 @@ export function registerDbTools(pi: ExtensionAPI): void {
|
|
|
568
484
|
// ─── gsd_plan_slice (gsd_slice_plan alias) ─────────────────────────────
|
|
569
485
|
|
|
570
486
|
const planSliceExecute = async (_toolCallId: string, params: any, _signal: AbortSignal | undefined, _onUpdate: unknown, _ctx: unknown) => {
|
|
571
|
-
|
|
572
|
-
if (!dbAvailable) {
|
|
573
|
-
return {
|
|
574
|
-
content: [{ type: "text" as const, text: "Error: GSD database is not available. Cannot plan slice." }],
|
|
575
|
-
details: { operation: "plan_slice", error: "db_unavailable" } as any,
|
|
576
|
-
};
|
|
577
|
-
}
|
|
578
|
-
try {
|
|
579
|
-
const { handlePlanSlice } = await import("../tools/plan-slice.js");
|
|
580
|
-
const result = await handlePlanSlice(params, process.cwd());
|
|
581
|
-
if ("error" in result) {
|
|
582
|
-
return {
|
|
583
|
-
content: [{ type: "text" as const, text: `Error planning slice: ${result.error}` }],
|
|
584
|
-
details: { operation: "plan_slice", error: result.error } as any,
|
|
585
|
-
};
|
|
586
|
-
}
|
|
587
|
-
return {
|
|
588
|
-
content: [{ type: "text" as const, text: `Planned slice ${result.sliceId} (${result.milestoneId})` }],
|
|
589
|
-
details: {
|
|
590
|
-
operation: "plan_slice",
|
|
591
|
-
milestoneId: result.milestoneId,
|
|
592
|
-
sliceId: result.sliceId,
|
|
593
|
-
planPath: result.planPath,
|
|
594
|
-
taskPlanPaths: result.taskPlanPaths,
|
|
595
|
-
} as any,
|
|
596
|
-
};
|
|
597
|
-
} catch (err) {
|
|
598
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
599
|
-
logError("tool", `plan_slice tool failed: ${msg}`, { tool: "gsd_plan_slice", error: String(err) });
|
|
600
|
-
return {
|
|
601
|
-
content: [{ type: "text" as const, text: `Error planning slice: ${msg}` }],
|
|
602
|
-
details: { operation: "plan_slice", error: msg } as any,
|
|
603
|
-
};
|
|
604
|
-
}
|
|
487
|
+
return executePlanSlice(params, process.cwd());
|
|
605
488
|
};
|
|
606
489
|
|
|
607
490
|
const planSliceTool = {
|
|
@@ -717,46 +600,7 @@ export function registerDbTools(pi: ExtensionAPI): void {
|
|
|
717
600
|
// ─── gsd_task_complete (gsd_complete_task alias) ────────────────────────
|
|
718
601
|
|
|
719
602
|
const taskCompleteExecute = async (_toolCallId: string, params: any, _signal: AbortSignal | undefined, _onUpdate: unknown, _ctx: unknown) => {
|
|
720
|
-
|
|
721
|
-
if (!dbAvailable) {
|
|
722
|
-
return {
|
|
723
|
-
content: [{ type: "text" as const, text: "Error: GSD database is not available. Cannot complete task." }],
|
|
724
|
-
details: { operation: "complete_task", error: "db_unavailable" } as any,
|
|
725
|
-
};
|
|
726
|
-
}
|
|
727
|
-
try {
|
|
728
|
-
// Coerce string items to objects for verificationEvidence (#3541).
|
|
729
|
-
const coerced = { ...params };
|
|
730
|
-
coerced.verificationEvidence = (params.verificationEvidence ?? []).map((v: any) =>
|
|
731
|
-
typeof v === "string" ? { command: v, exitCode: -1, verdict: "unknown (coerced from string)", durationMs: 0 } : v,
|
|
732
|
-
);
|
|
733
|
-
|
|
734
|
-
const { handleCompleteTask } = await import("../tools/complete-task.js");
|
|
735
|
-
const result = await handleCompleteTask(coerced, process.cwd());
|
|
736
|
-
if ("error" in result) {
|
|
737
|
-
return {
|
|
738
|
-
content: [{ type: "text" as const, text: `Error completing task: ${result.error}` }],
|
|
739
|
-
details: { operation: "complete_task", error: result.error } as any,
|
|
740
|
-
};
|
|
741
|
-
}
|
|
742
|
-
return {
|
|
743
|
-
content: [{ type: "text" as const, text: `Completed task ${result.taskId} (${result.sliceId}/${result.milestoneId})` }],
|
|
744
|
-
details: {
|
|
745
|
-
operation: "complete_task",
|
|
746
|
-
taskId: result.taskId,
|
|
747
|
-
sliceId: result.sliceId,
|
|
748
|
-
milestoneId: result.milestoneId,
|
|
749
|
-
summaryPath: result.summaryPath,
|
|
750
|
-
} as any,
|
|
751
|
-
};
|
|
752
|
-
} catch (err) {
|
|
753
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
754
|
-
logError("tool", `complete_task tool failed: ${msg}`, { tool: "gsd_task_complete", error: String(err) });
|
|
755
|
-
return {
|
|
756
|
-
content: [{ type: "text" as const, text: `Error completing task: ${msg}` }],
|
|
757
|
-
details: { operation: "complete_task", error: msg } as any,
|
|
758
|
-
};
|
|
759
|
-
}
|
|
603
|
+
return executeTaskComplete(params, process.cwd());
|
|
760
604
|
};
|
|
761
605
|
|
|
762
606
|
const taskCompleteTool = {
|
|
@@ -809,86 +653,7 @@ export function registerDbTools(pi: ExtensionAPI): void {
|
|
|
809
653
|
// ─── gsd_slice_complete (gsd_complete_slice alias) ─────────────────────
|
|
810
654
|
|
|
811
655
|
const sliceCompleteExecute = async (_toolCallId: string, params: any, _signal: AbortSignal | undefined, _onUpdate: unknown, _ctx: unknown) => {
|
|
812
|
-
|
|
813
|
-
if (!dbAvailable) {
|
|
814
|
-
return {
|
|
815
|
-
content: [{ type: "text" as const, text: "Error: GSD database is not available. Cannot complete slice." }],
|
|
816
|
-
details: { operation: "complete_slice", error: "db_unavailable" } as any,
|
|
817
|
-
};
|
|
818
|
-
}
|
|
819
|
-
try {
|
|
820
|
-
// Coerce string items to objects for fields where LLMs sometimes pass
|
|
821
|
-
// plain strings instead of the expected { key, value } shape (#3541).
|
|
822
|
-
// Parses "key — value" or "key - value" format when possible.
|
|
823
|
-
const splitPair = (s: string): [string, string] => {
|
|
824
|
-
const m = s.match(/^(.+?)\s*(?:—|-)\s+(.+)$/);
|
|
825
|
-
return m ? [m[1].trim(), m[2].trim()] : [s.trim(), ""];
|
|
826
|
-
};
|
|
827
|
-
const coerced = { ...params };
|
|
828
|
-
// Coerce simple string-array fields: LLMs sometimes pass a plain string
|
|
829
|
-
// instead of a single-element array (#3585).
|
|
830
|
-
const wrapArray = (v: any): any[] =>
|
|
831
|
-
v == null ? [] : Array.isArray(v) ? v : [v];
|
|
832
|
-
coerced.provides = wrapArray(params.provides);
|
|
833
|
-
coerced.keyFiles = wrapArray(params.keyFiles);
|
|
834
|
-
coerced.keyDecisions = wrapArray(params.keyDecisions);
|
|
835
|
-
coerced.patternsEstablished = wrapArray(params.patternsEstablished);
|
|
836
|
-
coerced.observabilitySurfaces = wrapArray(params.observabilitySurfaces);
|
|
837
|
-
coerced.requirementsSurfaced = wrapArray(params.requirementsSurfaced);
|
|
838
|
-
coerced.drillDownPaths = wrapArray(params.drillDownPaths);
|
|
839
|
-
coerced.affects = wrapArray(params.affects);
|
|
840
|
-
coerced.filesModified = wrapArray(params.filesModified).map((f: any) => {
|
|
841
|
-
if (typeof f !== "string") return f;
|
|
842
|
-
const [path, description] = splitPair(f);
|
|
843
|
-
return { path, description };
|
|
844
|
-
});
|
|
845
|
-
coerced.requires = wrapArray(params.requires).map((r: any) => {
|
|
846
|
-
if (typeof r !== "string") return r;
|
|
847
|
-
const [slice, provides] = splitPair(r);
|
|
848
|
-
return { slice, provides };
|
|
849
|
-
});
|
|
850
|
-
coerced.requirementsAdvanced = wrapArray(params.requirementsAdvanced).map((r: any) => {
|
|
851
|
-
if (typeof r !== "string") return r;
|
|
852
|
-
const [id, how] = splitPair(r);
|
|
853
|
-
return { id, how };
|
|
854
|
-
});
|
|
855
|
-
coerced.requirementsValidated = wrapArray(params.requirementsValidated).map((r: any) => {
|
|
856
|
-
if (typeof r !== "string") return r;
|
|
857
|
-
const [id, proof] = splitPair(r);
|
|
858
|
-
return { id, proof };
|
|
859
|
-
});
|
|
860
|
-
coerced.requirementsInvalidated = wrapArray(params.requirementsInvalidated).map((r: any) => {
|
|
861
|
-
if (typeof r !== "string") return r;
|
|
862
|
-
const [id, what] = splitPair(r);
|
|
863
|
-
return { id, what };
|
|
864
|
-
});
|
|
865
|
-
|
|
866
|
-
const { handleCompleteSlice } = await import("../tools/complete-slice.js");
|
|
867
|
-
const result = await handleCompleteSlice(coerced, process.cwd());
|
|
868
|
-
if ("error" in result) {
|
|
869
|
-
return {
|
|
870
|
-
content: [{ type: "text" as const, text: `Error completing slice: ${result.error}` }],
|
|
871
|
-
details: { operation: "complete_slice", error: result.error } as any,
|
|
872
|
-
};
|
|
873
|
-
}
|
|
874
|
-
return {
|
|
875
|
-
content: [{ type: "text" as const, text: `Completed slice ${result.sliceId} (${result.milestoneId})` }],
|
|
876
|
-
details: {
|
|
877
|
-
operation: "complete_slice",
|
|
878
|
-
sliceId: result.sliceId,
|
|
879
|
-
milestoneId: result.milestoneId,
|
|
880
|
-
summaryPath: result.summaryPath,
|
|
881
|
-
uatPath: result.uatPath,
|
|
882
|
-
} as any,
|
|
883
|
-
};
|
|
884
|
-
} catch (err) {
|
|
885
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
886
|
-
logError("tool", `complete_slice tool failed: ${msg}`, { tool: "gsd_slice_complete", error: String(err) });
|
|
887
|
-
return {
|
|
888
|
-
content: [{ type: "text" as const, text: `Error completing slice: ${msg}` }],
|
|
889
|
-
details: { operation: "complete_slice", error: msg } as any,
|
|
890
|
-
};
|
|
891
|
-
}
|
|
656
|
+
return executeSliceComplete(params, process.cwd());
|
|
892
657
|
};
|
|
893
658
|
|
|
894
659
|
const sliceCompleteTool = {
|
|
@@ -1073,42 +838,7 @@ export function registerDbTools(pi: ExtensionAPI): void {
|
|
|
1073
838
|
// ─── gsd_complete_milestone ────────────────────────────────────────────
|
|
1074
839
|
|
|
1075
840
|
const milestoneCompleteExecute = async (_toolCallId: string, params: any, _signal: AbortSignal | undefined, _onUpdate: unknown, _ctx: unknown) => {
|
|
1076
|
-
|
|
1077
|
-
if (!dbAvailable) {
|
|
1078
|
-
return {
|
|
1079
|
-
content: [{ type: "text" as const, text: "Error: GSD database is not available. Cannot complete milestone." }],
|
|
1080
|
-
details: { operation: "complete_milestone", error: "db_unavailable" } as any,
|
|
1081
|
-
};
|
|
1082
|
-
}
|
|
1083
|
-
try {
|
|
1084
|
-
// ── Input sanitization: normalize markdown parameters (#3013) ──────
|
|
1085
|
-
const { sanitizeCompleteMilestoneParams } = await import("./sanitize-complete-milestone.js");
|
|
1086
|
-
const sanitized = sanitizeCompleteMilestoneParams(params);
|
|
1087
|
-
|
|
1088
|
-
const { handleCompleteMilestone } = await import("../tools/complete-milestone.js");
|
|
1089
|
-
const result = await handleCompleteMilestone(sanitized, process.cwd());
|
|
1090
|
-
if ("error" in result) {
|
|
1091
|
-
return {
|
|
1092
|
-
content: [{ type: "text" as const, text: `Error completing milestone: ${result.error}` }],
|
|
1093
|
-
details: { operation: "complete_milestone", error: result.error } as any,
|
|
1094
|
-
};
|
|
1095
|
-
}
|
|
1096
|
-
return {
|
|
1097
|
-
content: [{ type: "text" as const, text: `Completed milestone ${result.milestoneId}. Summary written to ${result.summaryPath}` }],
|
|
1098
|
-
details: {
|
|
1099
|
-
operation: "complete_milestone",
|
|
1100
|
-
milestoneId: result.milestoneId,
|
|
1101
|
-
summaryPath: result.summaryPath,
|
|
1102
|
-
} as any,
|
|
1103
|
-
};
|
|
1104
|
-
} catch (err) {
|
|
1105
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
1106
|
-
logError("tool", `complete_milestone tool failed: ${msg}`, { tool: "gsd_complete_milestone", error: String(err) });
|
|
1107
|
-
return {
|
|
1108
|
-
content: [{ type: "text" as const, text: `Error completing milestone: ${msg}` }],
|
|
1109
|
-
details: { operation: "complete_milestone", error: msg } as any,
|
|
1110
|
-
};
|
|
1111
|
-
}
|
|
841
|
+
return executeCompleteMilestone(params, process.cwd());
|
|
1112
842
|
};
|
|
1113
843
|
|
|
1114
844
|
const milestoneCompleteTool = {
|
|
@@ -1150,39 +880,7 @@ export function registerDbTools(pi: ExtensionAPI): void {
|
|
|
1150
880
|
// ─── gsd_validate_milestone (gsd_milestone_validate alias) ─────────────
|
|
1151
881
|
|
|
1152
882
|
const milestoneValidateExecute = async (_toolCallId: string, params: any, _signal: AbortSignal | undefined, _onUpdate: unknown, _ctx: unknown) => {
|
|
1153
|
-
|
|
1154
|
-
if (!dbAvailable) {
|
|
1155
|
-
return {
|
|
1156
|
-
content: [{ type: "text" as const, text: "Error: GSD database is not available. Cannot validate milestone." }],
|
|
1157
|
-
details: { operation: "validate_milestone", error: "db_unavailable" } as any,
|
|
1158
|
-
};
|
|
1159
|
-
}
|
|
1160
|
-
try {
|
|
1161
|
-
const { handleValidateMilestone } = await import("../tools/validate-milestone.js");
|
|
1162
|
-
const result = await handleValidateMilestone(params, process.cwd());
|
|
1163
|
-
if ("error" in result) {
|
|
1164
|
-
return {
|
|
1165
|
-
content: [{ type: "text" as const, text: `Error validating milestone: ${result.error}` }],
|
|
1166
|
-
details: { operation: "validate_milestone", error: result.error } as any,
|
|
1167
|
-
};
|
|
1168
|
-
}
|
|
1169
|
-
return {
|
|
1170
|
-
content: [{ type: "text" as const, text: `Validated milestone ${result.milestoneId} — verdict: ${result.verdict}. Written to ${result.validationPath}` }],
|
|
1171
|
-
details: {
|
|
1172
|
-
operation: "validate_milestone",
|
|
1173
|
-
milestoneId: result.milestoneId,
|
|
1174
|
-
verdict: result.verdict,
|
|
1175
|
-
validationPath: result.validationPath,
|
|
1176
|
-
} as any,
|
|
1177
|
-
};
|
|
1178
|
-
} catch (err) {
|
|
1179
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
1180
|
-
logError("tool", `validate_milestone tool failed: ${msg}`, { tool: "gsd_validate_milestone", error: String(err) });
|
|
1181
|
-
return {
|
|
1182
|
-
content: [{ type: "text" as const, text: `Error validating milestone: ${msg}` }],
|
|
1183
|
-
details: { operation: "validate_milestone", error: msg } as any,
|
|
1184
|
-
};
|
|
1185
|
-
}
|
|
883
|
+
return executeValidateMilestone(params, process.cwd());
|
|
1186
884
|
};
|
|
1187
885
|
|
|
1188
886
|
const milestoneValidateTool = {
|
|
@@ -1219,40 +917,7 @@ export function registerDbTools(pi: ExtensionAPI): void {
|
|
|
1219
917
|
// ─── gsd_replan_slice (gsd_slice_replan alias) ─────────────────────────
|
|
1220
918
|
|
|
1221
919
|
const replanSliceExecute = async (_toolCallId: string, params: any, _signal: AbortSignal | undefined, _onUpdate: unknown, _ctx: unknown) => {
|
|
1222
|
-
|
|
1223
|
-
if (!dbAvailable) {
|
|
1224
|
-
return {
|
|
1225
|
-
content: [{ type: "text" as const, text: "Error: GSD database is not available. Cannot replan slice." }],
|
|
1226
|
-
details: { operation: "replan_slice", error: "db_unavailable" } as any,
|
|
1227
|
-
};
|
|
1228
|
-
}
|
|
1229
|
-
try {
|
|
1230
|
-
const { handleReplanSlice } = await import("../tools/replan-slice.js");
|
|
1231
|
-
const result = await handleReplanSlice(params, process.cwd());
|
|
1232
|
-
if ("error" in result) {
|
|
1233
|
-
return {
|
|
1234
|
-
content: [{ type: "text" as const, text: `Error replanning slice: ${result.error}` }],
|
|
1235
|
-
details: { operation: "replan_slice", error: result.error } as any,
|
|
1236
|
-
};
|
|
1237
|
-
}
|
|
1238
|
-
return {
|
|
1239
|
-
content: [{ type: "text" as const, text: `Replanned slice ${result.sliceId} (${result.milestoneId})` }],
|
|
1240
|
-
details: {
|
|
1241
|
-
operation: "replan_slice",
|
|
1242
|
-
milestoneId: result.milestoneId,
|
|
1243
|
-
sliceId: result.sliceId,
|
|
1244
|
-
replanPath: result.replanPath,
|
|
1245
|
-
planPath: result.planPath,
|
|
1246
|
-
} as any,
|
|
1247
|
-
};
|
|
1248
|
-
} catch (err) {
|
|
1249
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
1250
|
-
logError("tool", `replan_slice tool failed: ${msg}`, { tool: "gsd_replan_slice", error: String(err) });
|
|
1251
|
-
return {
|
|
1252
|
-
content: [{ type: "text" as const, text: `Error replanning slice: ${msg}` }],
|
|
1253
|
-
details: { operation: "replan_slice", error: msg } as any,
|
|
1254
|
-
};
|
|
1255
|
-
}
|
|
920
|
+
return executeReplanSlice(params, process.cwd());
|
|
1256
921
|
};
|
|
1257
922
|
|
|
1258
923
|
const replanSliceTool = {
|
|
@@ -1299,40 +964,7 @@ export function registerDbTools(pi: ExtensionAPI): void {
|
|
|
1299
964
|
// ─── gsd_reassess_roadmap (gsd_roadmap_reassess alias) ─────────────────
|
|
1300
965
|
|
|
1301
966
|
const reassessRoadmapExecute = async (_toolCallId: string, params: any, _signal: AbortSignal | undefined, _onUpdate: unknown, _ctx: unknown) => {
|
|
1302
|
-
|
|
1303
|
-
if (!dbAvailable) {
|
|
1304
|
-
return {
|
|
1305
|
-
content: [{ type: "text" as const, text: "Error: GSD database is not available. Cannot reassess roadmap." }],
|
|
1306
|
-
details: { operation: "reassess_roadmap", error: "db_unavailable" } as any,
|
|
1307
|
-
};
|
|
1308
|
-
}
|
|
1309
|
-
try {
|
|
1310
|
-
const { handleReassessRoadmap } = await import("../tools/reassess-roadmap.js");
|
|
1311
|
-
const result = await handleReassessRoadmap(params, process.cwd());
|
|
1312
|
-
if ("error" in result) {
|
|
1313
|
-
return {
|
|
1314
|
-
content: [{ type: "text" as const, text: `Error reassessing roadmap: ${result.error}` }],
|
|
1315
|
-
details: { operation: "reassess_roadmap", error: result.error } as any,
|
|
1316
|
-
};
|
|
1317
|
-
}
|
|
1318
|
-
return {
|
|
1319
|
-
content: [{ type: "text" as const, text: `Reassessed roadmap for milestone ${result.milestoneId} after ${result.completedSliceId}` }],
|
|
1320
|
-
details: {
|
|
1321
|
-
operation: "reassess_roadmap",
|
|
1322
|
-
milestoneId: result.milestoneId,
|
|
1323
|
-
completedSliceId: result.completedSliceId,
|
|
1324
|
-
assessmentPath: result.assessmentPath,
|
|
1325
|
-
roadmapPath: result.roadmapPath,
|
|
1326
|
-
} as any,
|
|
1327
|
-
};
|
|
1328
|
-
} catch (err) {
|
|
1329
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
1330
|
-
logError("tool", `reassess_roadmap tool failed: ${msg}`, { tool: "gsd_reassess_roadmap", error: String(err) });
|
|
1331
|
-
return {
|
|
1332
|
-
content: [{ type: "text" as const, text: `Error reassessing roadmap: ${msg}` }],
|
|
1333
|
-
details: { operation: "reassess_roadmap", error: msg } as any,
|
|
1334
|
-
};
|
|
1335
|
-
}
|
|
967
|
+
return executeReassessRoadmap(params, process.cwd());
|
|
1336
968
|
};
|
|
1337
969
|
|
|
1338
970
|
const reassessRoadmapTool = {
|
|
@@ -1387,52 +1019,7 @@ export function registerDbTools(pi: ExtensionAPI): void {
|
|
|
1387
1019
|
// ─── gsd_save_gate_result ──────────────────────────────────────────────
|
|
1388
1020
|
|
|
1389
1021
|
const saveGateResultExecute = async (_toolCallId: string, params: any, _signal: AbortSignal | undefined, _onUpdate: unknown, _ctx: unknown) => {
|
|
1390
|
-
|
|
1391
|
-
if (!dbAvailable) {
|
|
1392
|
-
return {
|
|
1393
|
-
content: [{ type: "text" as const, text: "Error: GSD database is not available." }],
|
|
1394
|
-
details: { operation: "save_gate_result", error: "db_unavailable" } as any,
|
|
1395
|
-
};
|
|
1396
|
-
}
|
|
1397
|
-
const validGates = ["Q3", "Q4", "Q5", "Q6", "Q7", "Q8"];
|
|
1398
|
-
if (!validGates.includes(params.gateId)) {
|
|
1399
|
-
return {
|
|
1400
|
-
content: [{ type: "text" as const, text: `Error: Invalid gateId "${params.gateId}". Must be one of: ${validGates.join(", ")}` }],
|
|
1401
|
-
details: { operation: "save_gate_result", error: "invalid_gate_id" } as any,
|
|
1402
|
-
};
|
|
1403
|
-
}
|
|
1404
|
-
const validVerdicts = ["pass", "flag", "omitted"];
|
|
1405
|
-
if (!validVerdicts.includes(params.verdict)) {
|
|
1406
|
-
return {
|
|
1407
|
-
content: [{ type: "text" as const, text: `Error: Invalid verdict "${params.verdict}". Must be one of: ${validVerdicts.join(", ")}` }],
|
|
1408
|
-
details: { operation: "save_gate_result", error: "invalid_verdict" } as any,
|
|
1409
|
-
};
|
|
1410
|
-
}
|
|
1411
|
-
try {
|
|
1412
|
-
const { saveGateResult } = await import("../gsd-db.js");
|
|
1413
|
-
const { invalidateStateCache } = await import("../state.js");
|
|
1414
|
-
saveGateResult({
|
|
1415
|
-
milestoneId: params.milestoneId,
|
|
1416
|
-
sliceId: params.sliceId,
|
|
1417
|
-
gateId: params.gateId,
|
|
1418
|
-
taskId: params.taskId ?? "",
|
|
1419
|
-
verdict: params.verdict,
|
|
1420
|
-
rationale: params.rationale,
|
|
1421
|
-
findings: params.findings ?? "",
|
|
1422
|
-
});
|
|
1423
|
-
invalidateStateCache();
|
|
1424
|
-
return {
|
|
1425
|
-
content: [{ type: "text" as const, text: `Gate ${params.gateId} result saved: verdict=${params.verdict}` }],
|
|
1426
|
-
details: { operation: "save_gate_result", gateId: params.gateId, verdict: params.verdict } as any,
|
|
1427
|
-
};
|
|
1428
|
-
} catch (err) {
|
|
1429
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
1430
|
-
logError("tool", `gsd_save_gate_result failed: ${msg}`, { tool: "gsd_save_gate_result", error: String(err) });
|
|
1431
|
-
return {
|
|
1432
|
-
content: [{ type: "text" as const, text: `Error saving gate result: ${msg}` }],
|
|
1433
|
-
details: { operation: "save_gate_result", error: msg } as any,
|
|
1434
|
-
};
|
|
1435
|
-
}
|
|
1022
|
+
return executeSaveGateResult(params, process.cwd());
|
|
1436
1023
|
};
|
|
1437
1024
|
|
|
1438
1025
|
const saveGateResultTool = {
|
|
@@ -75,12 +75,9 @@ export function resolveProjectRootDbPath(basePath: string): string {
|
|
|
75
75
|
return join(basePath, ".gsd", "gsd.db");
|
|
76
76
|
}
|
|
77
77
|
|
|
78
|
-
export async function ensureDbOpen(): Promise<boolean> {
|
|
78
|
+
export async function ensureDbOpen(basePath: string = process.cwd()): Promise<boolean> {
|
|
79
79
|
try {
|
|
80
80
|
const db = await import("../gsd-db.js");
|
|
81
|
-
if (db.isDbAvailable()) return true;
|
|
82
|
-
|
|
83
|
-
const basePath = process.cwd();
|
|
84
81
|
const dbPath = resolveProjectRootDbPath(basePath);
|
|
85
82
|
const gsdDir = join(basePath, ".gsd");
|
|
86
83
|
|
|
@@ -194,4 +191,3 @@ export function registerDynamicTools(pi: ExtensionAPI): void {
|
|
|
194
191
|
},
|
|
195
192
|
} as any);
|
|
196
193
|
}
|
|
197
|
-
|