gsd-pi 2.67.0-dev.46f9884 → 2.67.0-dev.509bd95
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 +4 -3
- package/dist/resources/extensions/gsd/commands/dispatcher.js +1 -1
- package/dist/resources/extensions/gsd/commands/handlers/core.js +106 -1
- package/dist/resources/extensions/gsd/commands/index.js +8 -1
- 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/commands-prefs-wizard.js +39 -5
- 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/complete-slice.md +3 -3
- package/dist/resources/extensions/gsd/prompts/execute-task.md +3 -3
- package/dist/resources/extensions/gsd/prompts/system.md +3 -0
- package/dist/resources/extensions/gsd/prompts/validate-milestone.md +7 -5
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +508 -0
- package/dist/resources/extensions/gsd/workflow-logger.js +18 -3
- 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 +14 -14
- 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 +7 -7
- 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 +14 -14
- 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/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/{6502.8874bcae249c02e1.js → 6502.b804e48b7919f55e.js} +3 -3
- 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-9fed74684e1c5bb1.js → webpack-b49b09f97429b5d0.js} +1 -1
- package/dist/web/standalone/.next/static/mHJZ3Z8yGRzZ32BmQs-I7/_buildManifest.js +1 -0
- 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 +4 -3
- package/src/resources/extensions/gsd/commands/dispatcher.ts +1 -2
- package/src/resources/extensions/gsd/commands/handlers/core.ts +135 -2
- package/src/resources/extensions/gsd/commands/index.ts +7 -1
- 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/commands-prefs-wizard.ts +38 -7
- 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/complete-slice.md +3 -3
- package/src/resources/extensions/gsd/prompts/execute-task.md +3 -3
- package/src/resources/extensions/gsd/prompts/system.md +3 -0
- package/src/resources/extensions/gsd/prompts/validate-milestone.md +7 -5
- package/src/resources/extensions/gsd/tests/codebase-generator.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/commands-workflow-custom.test.ts +12 -0
- package/src/resources/extensions/gsd/tests/core-overlay-fallback.test.ts +133 -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/preferences.test.ts +17 -0
- package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +25 -3
- package/src/resources/extensions/gsd/tests/update-command.test.ts +19 -0
- package/src/resources/extensions/gsd/tests/workflow-logger.test.ts +16 -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-logger.ts +19 -3
- 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/FRT6f5ou3wPxpZ7ojoB7E/_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/{FRT6f5ou3wPxpZ7ojoB7E → mHJZ3Z8yGRzZ32BmQs-I7}/_ssgManifest.js +0 -0
|
@@ -5,11 +5,7 @@ import { loadEffectiveGSDPreferences } from "../preferences.js";
|
|
|
5
5
|
import { ensureDbOpen } from "./dynamic-tools.js";
|
|
6
6
|
import { StringEnum } from "@gsd/pi-ai";
|
|
7
7
|
import { logError } from "../workflow-logger.js";
|
|
8
|
-
import {
|
|
9
|
-
const SUPPORTED_SUMMARY_ARTIFACT_TYPES = ["SUMMARY", "RESEARCH", "CONTEXT", "ASSESSMENT", "CONTEXT-DRAFT"];
|
|
10
|
-
export function isSupportedSummaryArtifactType(artifactType) {
|
|
11
|
-
return SUPPORTED_SUMMARY_ARTIFACT_TYPES.includes(artifactType);
|
|
12
|
-
}
|
|
8
|
+
import { executeCompleteMilestone, executePlanMilestone, executePlanSlice, executeReplanSlice, executeReassessRoadmap, executeSaveGateResult, executeSliceComplete, executeSummarySave, executeTaskComplete, executeValidateMilestone, } from "../tools/workflow-tool-executors.js";
|
|
13
9
|
/**
|
|
14
10
|
* Register an alias tool that shares the same execute function as its canonical counterpart.
|
|
15
11
|
* The alias description and promptGuidelines direct the LLM to prefer the canonical name.
|
|
@@ -272,59 +268,7 @@ export function registerDbTools(pi) {
|
|
|
272
268
|
registerAlias(pi, requirementSaveTool, "gsd_save_requirement", "gsd_requirement_save");
|
|
273
269
|
// ─── gsd_summary_save (formerly gsd_save_summary) ──────────────────────
|
|
274
270
|
const summarySaveExecute = async (_toolCallId, params, _signal, _onUpdate, _ctx) => {
|
|
275
|
-
|
|
276
|
-
if (!dbAvailable) {
|
|
277
|
-
return {
|
|
278
|
-
content: [{ type: "text", text: "Error: GSD database is not available. Cannot save artifact." }],
|
|
279
|
-
details: { operation: "save_summary", error: "db_unavailable" },
|
|
280
|
-
};
|
|
281
|
-
}
|
|
282
|
-
if (!isSupportedSummaryArtifactType(params.artifact_type)) {
|
|
283
|
-
return {
|
|
284
|
-
content: [{ type: "text", text: `Error: Invalid artifact_type "${params.artifact_type}". Must be one of: ${SUPPORTED_SUMMARY_ARTIFACT_TYPES.join(", ")}` }],
|
|
285
|
-
details: { operation: "save_summary", error: "invalid_artifact_type" },
|
|
286
|
-
};
|
|
287
|
-
}
|
|
288
|
-
const contextGuard = shouldBlockContextArtifactSave(params.artifact_type, params.milestone_id ?? null, params.slice_id ?? null);
|
|
289
|
-
if (contextGuard.block) {
|
|
290
|
-
return {
|
|
291
|
-
content: [{ type: "text", text: `Error saving artifact: ${contextGuard.reason ?? "context write blocked"}` }],
|
|
292
|
-
details: { operation: "save_summary", error: "context_write_blocked" },
|
|
293
|
-
};
|
|
294
|
-
}
|
|
295
|
-
try {
|
|
296
|
-
let relativePath;
|
|
297
|
-
if (params.task_id && params.slice_id) {
|
|
298
|
-
relativePath = `milestones/${params.milestone_id}/slices/${params.slice_id}/tasks/${params.task_id}-${params.artifact_type}.md`;
|
|
299
|
-
}
|
|
300
|
-
else if (params.slice_id) {
|
|
301
|
-
relativePath = `milestones/${params.milestone_id}/slices/${params.slice_id}/${params.slice_id}-${params.artifact_type}.md`;
|
|
302
|
-
}
|
|
303
|
-
else {
|
|
304
|
-
relativePath = `milestones/${params.milestone_id}/${params.milestone_id}-${params.artifact_type}.md`;
|
|
305
|
-
}
|
|
306
|
-
const { saveArtifactToDb } = await import("../db-writer.js");
|
|
307
|
-
await saveArtifactToDb({
|
|
308
|
-
path: relativePath,
|
|
309
|
-
artifact_type: params.artifact_type,
|
|
310
|
-
content: params.content,
|
|
311
|
-
milestone_id: params.milestone_id,
|
|
312
|
-
slice_id: params.slice_id,
|
|
313
|
-
task_id: params.task_id,
|
|
314
|
-
}, process.cwd());
|
|
315
|
-
return {
|
|
316
|
-
content: [{ type: "text", text: `Saved ${params.artifact_type} artifact to ${relativePath}` }],
|
|
317
|
-
details: { operation: "save_summary", path: relativePath, artifact_type: params.artifact_type },
|
|
318
|
-
};
|
|
319
|
-
}
|
|
320
|
-
catch (err) {
|
|
321
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
322
|
-
logError("tool", `gsd_summary_save tool failed: ${msg}`, { tool: "gsd_summary_save", error: String(err) });
|
|
323
|
-
return {
|
|
324
|
-
content: [{ type: "text", text: `Error saving artifact: ${msg}` }],
|
|
325
|
-
details: { operation: "save_summary", error: msg },
|
|
326
|
-
};
|
|
327
|
-
}
|
|
271
|
+
return executeSummarySave(params, process.cwd());
|
|
328
272
|
};
|
|
329
273
|
const summarySaveTool = {
|
|
330
274
|
name: "gsd_summary_save",
|
|
@@ -452,39 +396,7 @@ export function registerDbTools(pi) {
|
|
|
452
396
|
registerAlias(pi, milestoneGenerateIdTool, "gsd_generate_milestone_id", "gsd_milestone_generate_id");
|
|
453
397
|
// ─── gsd_plan_milestone (gsd_milestone_plan alias) ─────────────────────
|
|
454
398
|
const planMilestoneExecute = async (_toolCallId, params, _signal, _onUpdate, _ctx) => {
|
|
455
|
-
|
|
456
|
-
if (!dbAvailable) {
|
|
457
|
-
return {
|
|
458
|
-
content: [{ type: "text", text: "Error: GSD database is not available. Cannot plan milestone." }],
|
|
459
|
-
details: { operation: "plan_milestone", error: "db_unavailable" },
|
|
460
|
-
};
|
|
461
|
-
}
|
|
462
|
-
try {
|
|
463
|
-
const { handlePlanMilestone } = await import("../tools/plan-milestone.js");
|
|
464
|
-
const result = await handlePlanMilestone(params, process.cwd());
|
|
465
|
-
if ("error" in result) {
|
|
466
|
-
return {
|
|
467
|
-
content: [{ type: "text", text: `Error planning milestone: ${result.error}` }],
|
|
468
|
-
details: { operation: "plan_milestone", error: result.error },
|
|
469
|
-
};
|
|
470
|
-
}
|
|
471
|
-
return {
|
|
472
|
-
content: [{ type: "text", text: `Planned milestone ${result.milestoneId}` }],
|
|
473
|
-
details: {
|
|
474
|
-
operation: "plan_milestone",
|
|
475
|
-
milestoneId: result.milestoneId,
|
|
476
|
-
roadmapPath: result.roadmapPath,
|
|
477
|
-
},
|
|
478
|
-
};
|
|
479
|
-
}
|
|
480
|
-
catch (err) {
|
|
481
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
482
|
-
logError("tool", `plan_milestone tool failed: ${msg}`, { tool: "gsd_plan_milestone", error: String(err) });
|
|
483
|
-
return {
|
|
484
|
-
content: [{ type: "text", text: `Error planning milestone: ${msg}` }],
|
|
485
|
-
details: { operation: "plan_milestone", error: msg },
|
|
486
|
-
};
|
|
487
|
-
}
|
|
399
|
+
return executePlanMilestone(params, process.cwd());
|
|
488
400
|
};
|
|
489
401
|
const planMilestoneTool = {
|
|
490
402
|
name: "gsd_plan_milestone",
|
|
@@ -541,41 +453,7 @@ export function registerDbTools(pi) {
|
|
|
541
453
|
registerAlias(pi, planMilestoneTool, "gsd_milestone_plan", "gsd_plan_milestone");
|
|
542
454
|
// ─── gsd_plan_slice (gsd_slice_plan alias) ─────────────────────────────
|
|
543
455
|
const planSliceExecute = async (_toolCallId, params, _signal, _onUpdate, _ctx) => {
|
|
544
|
-
|
|
545
|
-
if (!dbAvailable) {
|
|
546
|
-
return {
|
|
547
|
-
content: [{ type: "text", text: "Error: GSD database is not available. Cannot plan slice." }],
|
|
548
|
-
details: { operation: "plan_slice", error: "db_unavailable" },
|
|
549
|
-
};
|
|
550
|
-
}
|
|
551
|
-
try {
|
|
552
|
-
const { handlePlanSlice } = await import("../tools/plan-slice.js");
|
|
553
|
-
const result = await handlePlanSlice(params, process.cwd());
|
|
554
|
-
if ("error" in result) {
|
|
555
|
-
return {
|
|
556
|
-
content: [{ type: "text", text: `Error planning slice: ${result.error}` }],
|
|
557
|
-
details: { operation: "plan_slice", error: result.error },
|
|
558
|
-
};
|
|
559
|
-
}
|
|
560
|
-
return {
|
|
561
|
-
content: [{ type: "text", text: `Planned slice ${result.sliceId} (${result.milestoneId})` }],
|
|
562
|
-
details: {
|
|
563
|
-
operation: "plan_slice",
|
|
564
|
-
milestoneId: result.milestoneId,
|
|
565
|
-
sliceId: result.sliceId,
|
|
566
|
-
planPath: result.planPath,
|
|
567
|
-
taskPlanPaths: result.taskPlanPaths,
|
|
568
|
-
},
|
|
569
|
-
};
|
|
570
|
-
}
|
|
571
|
-
catch (err) {
|
|
572
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
573
|
-
logError("tool", `plan_slice tool failed: ${msg}`, { tool: "gsd_plan_slice", error: String(err) });
|
|
574
|
-
return {
|
|
575
|
-
content: [{ type: "text", text: `Error planning slice: ${msg}` }],
|
|
576
|
-
details: { operation: "plan_slice", error: msg },
|
|
577
|
-
};
|
|
578
|
-
}
|
|
456
|
+
return executePlanSlice(params, process.cwd());
|
|
579
457
|
};
|
|
580
458
|
const planSliceTool = {
|
|
581
459
|
name: "gsd_plan_slice",
|
|
@@ -682,44 +560,7 @@ export function registerDbTools(pi) {
|
|
|
682
560
|
registerAlias(pi, planTaskTool, "gsd_task_plan", "gsd_plan_task");
|
|
683
561
|
// ─── gsd_task_complete (gsd_complete_task alias) ────────────────────────
|
|
684
562
|
const taskCompleteExecute = async (_toolCallId, params, _signal, _onUpdate, _ctx) => {
|
|
685
|
-
|
|
686
|
-
if (!dbAvailable) {
|
|
687
|
-
return {
|
|
688
|
-
content: [{ type: "text", text: "Error: GSD database is not available. Cannot complete task." }],
|
|
689
|
-
details: { operation: "complete_task", error: "db_unavailable" },
|
|
690
|
-
};
|
|
691
|
-
}
|
|
692
|
-
try {
|
|
693
|
-
// Coerce string items to objects for verificationEvidence (#3541).
|
|
694
|
-
const coerced = { ...params };
|
|
695
|
-
coerced.verificationEvidence = (params.verificationEvidence ?? []).map((v) => typeof v === "string" ? { command: v, exitCode: -1, verdict: "unknown (coerced from string)", durationMs: 0 } : v);
|
|
696
|
-
const { handleCompleteTask } = await import("../tools/complete-task.js");
|
|
697
|
-
const result = await handleCompleteTask(coerced, process.cwd());
|
|
698
|
-
if ("error" in result) {
|
|
699
|
-
return {
|
|
700
|
-
content: [{ type: "text", text: `Error completing task: ${result.error}` }],
|
|
701
|
-
details: { operation: "complete_task", error: result.error },
|
|
702
|
-
};
|
|
703
|
-
}
|
|
704
|
-
return {
|
|
705
|
-
content: [{ type: "text", text: `Completed task ${result.taskId} (${result.sliceId}/${result.milestoneId})` }],
|
|
706
|
-
details: {
|
|
707
|
-
operation: "complete_task",
|
|
708
|
-
taskId: result.taskId,
|
|
709
|
-
sliceId: result.sliceId,
|
|
710
|
-
milestoneId: result.milestoneId,
|
|
711
|
-
summaryPath: result.summaryPath,
|
|
712
|
-
},
|
|
713
|
-
};
|
|
714
|
-
}
|
|
715
|
-
catch (err) {
|
|
716
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
717
|
-
logError("tool", `complete_task tool failed: ${msg}`, { tool: "gsd_task_complete", error: String(err) });
|
|
718
|
-
return {
|
|
719
|
-
content: [{ type: "text", text: `Error completing task: ${msg}` }],
|
|
720
|
-
details: { operation: "complete_task", error: msg },
|
|
721
|
-
};
|
|
722
|
-
}
|
|
563
|
+
return executeTaskComplete(params, process.cwd());
|
|
723
564
|
};
|
|
724
565
|
const taskCompleteTool = {
|
|
725
566
|
name: "gsd_task_complete",
|
|
@@ -764,90 +605,7 @@ export function registerDbTools(pi) {
|
|
|
764
605
|
registerAlias(pi, taskCompleteTool, "gsd_complete_task", "gsd_task_complete");
|
|
765
606
|
// ─── gsd_slice_complete (gsd_complete_slice alias) ─────────────────────
|
|
766
607
|
const sliceCompleteExecute = async (_toolCallId, params, _signal, _onUpdate, _ctx) => {
|
|
767
|
-
|
|
768
|
-
if (!dbAvailable) {
|
|
769
|
-
return {
|
|
770
|
-
content: [{ type: "text", text: "Error: GSD database is not available. Cannot complete slice." }],
|
|
771
|
-
details: { operation: "complete_slice", error: "db_unavailable" },
|
|
772
|
-
};
|
|
773
|
-
}
|
|
774
|
-
try {
|
|
775
|
-
// Coerce string items to objects for fields where LLMs sometimes pass
|
|
776
|
-
// plain strings instead of the expected { key, value } shape (#3541).
|
|
777
|
-
// Parses "key — value" or "key - value" format when possible.
|
|
778
|
-
const splitPair = (s) => {
|
|
779
|
-
const m = s.match(/^(.+?)\s*(?:—|-)\s+(.+)$/);
|
|
780
|
-
return m ? [m[1].trim(), m[2].trim()] : [s.trim(), ""];
|
|
781
|
-
};
|
|
782
|
-
const coerced = { ...params };
|
|
783
|
-
// Coerce simple string-array fields: LLMs sometimes pass a plain string
|
|
784
|
-
// instead of a single-element array (#3585).
|
|
785
|
-
const wrapArray = (v) => v == null ? [] : Array.isArray(v) ? v : [v];
|
|
786
|
-
coerced.provides = wrapArray(params.provides);
|
|
787
|
-
coerced.keyFiles = wrapArray(params.keyFiles);
|
|
788
|
-
coerced.keyDecisions = wrapArray(params.keyDecisions);
|
|
789
|
-
coerced.patternsEstablished = wrapArray(params.patternsEstablished);
|
|
790
|
-
coerced.observabilitySurfaces = wrapArray(params.observabilitySurfaces);
|
|
791
|
-
coerced.requirementsSurfaced = wrapArray(params.requirementsSurfaced);
|
|
792
|
-
coerced.drillDownPaths = wrapArray(params.drillDownPaths);
|
|
793
|
-
coerced.affects = wrapArray(params.affects);
|
|
794
|
-
coerced.filesModified = wrapArray(params.filesModified).map((f) => {
|
|
795
|
-
if (typeof f !== "string")
|
|
796
|
-
return f;
|
|
797
|
-
const [path, description] = splitPair(f);
|
|
798
|
-
return { path, description };
|
|
799
|
-
});
|
|
800
|
-
coerced.requires = wrapArray(params.requires).map((r) => {
|
|
801
|
-
if (typeof r !== "string")
|
|
802
|
-
return r;
|
|
803
|
-
const [slice, provides] = splitPair(r);
|
|
804
|
-
return { slice, provides };
|
|
805
|
-
});
|
|
806
|
-
coerced.requirementsAdvanced = wrapArray(params.requirementsAdvanced).map((r) => {
|
|
807
|
-
if (typeof r !== "string")
|
|
808
|
-
return r;
|
|
809
|
-
const [id, how] = splitPair(r);
|
|
810
|
-
return { id, how };
|
|
811
|
-
});
|
|
812
|
-
coerced.requirementsValidated = wrapArray(params.requirementsValidated).map((r) => {
|
|
813
|
-
if (typeof r !== "string")
|
|
814
|
-
return r;
|
|
815
|
-
const [id, proof] = splitPair(r);
|
|
816
|
-
return { id, proof };
|
|
817
|
-
});
|
|
818
|
-
coerced.requirementsInvalidated = wrapArray(params.requirementsInvalidated).map((r) => {
|
|
819
|
-
if (typeof r !== "string")
|
|
820
|
-
return r;
|
|
821
|
-
const [id, what] = splitPair(r);
|
|
822
|
-
return { id, what };
|
|
823
|
-
});
|
|
824
|
-
const { handleCompleteSlice } = await import("../tools/complete-slice.js");
|
|
825
|
-
const result = await handleCompleteSlice(coerced, process.cwd());
|
|
826
|
-
if ("error" in result) {
|
|
827
|
-
return {
|
|
828
|
-
content: [{ type: "text", text: `Error completing slice: ${result.error}` }],
|
|
829
|
-
details: { operation: "complete_slice", error: result.error },
|
|
830
|
-
};
|
|
831
|
-
}
|
|
832
|
-
return {
|
|
833
|
-
content: [{ type: "text", text: `Completed slice ${result.sliceId} (${result.milestoneId})` }],
|
|
834
|
-
details: {
|
|
835
|
-
operation: "complete_slice",
|
|
836
|
-
sliceId: result.sliceId,
|
|
837
|
-
milestoneId: result.milestoneId,
|
|
838
|
-
summaryPath: result.summaryPath,
|
|
839
|
-
uatPath: result.uatPath,
|
|
840
|
-
},
|
|
841
|
-
};
|
|
842
|
-
}
|
|
843
|
-
catch (err) {
|
|
844
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
845
|
-
logError("tool", `complete_slice tool failed: ${msg}`, { tool: "gsd_slice_complete", error: String(err) });
|
|
846
|
-
return {
|
|
847
|
-
content: [{ type: "text", text: `Error completing slice: ${msg}` }],
|
|
848
|
-
details: { operation: "complete_slice", error: msg },
|
|
849
|
-
};
|
|
850
|
-
}
|
|
608
|
+
return executeSliceComplete(params, process.cwd());
|
|
851
609
|
};
|
|
852
610
|
const sliceCompleteTool = {
|
|
853
611
|
name: "gsd_slice_complete",
|
|
@@ -1004,42 +762,7 @@ export function registerDbTools(pi) {
|
|
|
1004
762
|
});
|
|
1005
763
|
// ─── gsd_complete_milestone ────────────────────────────────────────────
|
|
1006
764
|
const milestoneCompleteExecute = async (_toolCallId, params, _signal, _onUpdate, _ctx) => {
|
|
1007
|
-
|
|
1008
|
-
if (!dbAvailable) {
|
|
1009
|
-
return {
|
|
1010
|
-
content: [{ type: "text", text: "Error: GSD database is not available. Cannot complete milestone." }],
|
|
1011
|
-
details: { operation: "complete_milestone", error: "db_unavailable" },
|
|
1012
|
-
};
|
|
1013
|
-
}
|
|
1014
|
-
try {
|
|
1015
|
-
// ── Input sanitization: normalize markdown parameters (#3013) ──────
|
|
1016
|
-
const { sanitizeCompleteMilestoneParams } = await import("./sanitize-complete-milestone.js");
|
|
1017
|
-
const sanitized = sanitizeCompleteMilestoneParams(params);
|
|
1018
|
-
const { handleCompleteMilestone } = await import("../tools/complete-milestone.js");
|
|
1019
|
-
const result = await handleCompleteMilestone(sanitized, process.cwd());
|
|
1020
|
-
if ("error" in result) {
|
|
1021
|
-
return {
|
|
1022
|
-
content: [{ type: "text", text: `Error completing milestone: ${result.error}` }],
|
|
1023
|
-
details: { operation: "complete_milestone", error: result.error },
|
|
1024
|
-
};
|
|
1025
|
-
}
|
|
1026
|
-
return {
|
|
1027
|
-
content: [{ type: "text", text: `Completed milestone ${result.milestoneId}. Summary written to ${result.summaryPath}` }],
|
|
1028
|
-
details: {
|
|
1029
|
-
operation: "complete_milestone",
|
|
1030
|
-
milestoneId: result.milestoneId,
|
|
1031
|
-
summaryPath: result.summaryPath,
|
|
1032
|
-
},
|
|
1033
|
-
};
|
|
1034
|
-
}
|
|
1035
|
-
catch (err) {
|
|
1036
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
1037
|
-
logError("tool", `complete_milestone tool failed: ${msg}`, { tool: "gsd_complete_milestone", error: String(err) });
|
|
1038
|
-
return {
|
|
1039
|
-
content: [{ type: "text", text: `Error completing milestone: ${msg}` }],
|
|
1040
|
-
details: { operation: "complete_milestone", error: msg },
|
|
1041
|
-
};
|
|
1042
|
-
}
|
|
765
|
+
return executeCompleteMilestone(params, process.cwd());
|
|
1043
766
|
};
|
|
1044
767
|
const milestoneCompleteTool = {
|
|
1045
768
|
name: "gsd_complete_milestone",
|
|
@@ -1076,40 +799,7 @@ export function registerDbTools(pi) {
|
|
|
1076
799
|
registerAlias(pi, milestoneCompleteTool, "gsd_milestone_complete", "gsd_complete_milestone");
|
|
1077
800
|
// ─── gsd_validate_milestone (gsd_milestone_validate alias) ─────────────
|
|
1078
801
|
const milestoneValidateExecute = async (_toolCallId, params, _signal, _onUpdate, _ctx) => {
|
|
1079
|
-
|
|
1080
|
-
if (!dbAvailable) {
|
|
1081
|
-
return {
|
|
1082
|
-
content: [{ type: "text", text: "Error: GSD database is not available. Cannot validate milestone." }],
|
|
1083
|
-
details: { operation: "validate_milestone", error: "db_unavailable" },
|
|
1084
|
-
};
|
|
1085
|
-
}
|
|
1086
|
-
try {
|
|
1087
|
-
const { handleValidateMilestone } = await import("../tools/validate-milestone.js");
|
|
1088
|
-
const result = await handleValidateMilestone(params, process.cwd());
|
|
1089
|
-
if ("error" in result) {
|
|
1090
|
-
return {
|
|
1091
|
-
content: [{ type: "text", text: `Error validating milestone: ${result.error}` }],
|
|
1092
|
-
details: { operation: "validate_milestone", error: result.error },
|
|
1093
|
-
};
|
|
1094
|
-
}
|
|
1095
|
-
return {
|
|
1096
|
-
content: [{ type: "text", text: `Validated milestone ${result.milestoneId} — verdict: ${result.verdict}. Written to ${result.validationPath}` }],
|
|
1097
|
-
details: {
|
|
1098
|
-
operation: "validate_milestone",
|
|
1099
|
-
milestoneId: result.milestoneId,
|
|
1100
|
-
verdict: result.verdict,
|
|
1101
|
-
validationPath: result.validationPath,
|
|
1102
|
-
},
|
|
1103
|
-
};
|
|
1104
|
-
}
|
|
1105
|
-
catch (err) {
|
|
1106
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
1107
|
-
logError("tool", `validate_milestone tool failed: ${msg}`, { tool: "gsd_validate_milestone", error: String(err) });
|
|
1108
|
-
return {
|
|
1109
|
-
content: [{ type: "text", text: `Error validating milestone: ${msg}` }],
|
|
1110
|
-
details: { operation: "validate_milestone", error: msg },
|
|
1111
|
-
};
|
|
1112
|
-
}
|
|
802
|
+
return executeValidateMilestone(params, process.cwd());
|
|
1113
803
|
};
|
|
1114
804
|
const milestoneValidateTool = {
|
|
1115
805
|
name: "gsd_validate_milestone",
|
|
@@ -1141,41 +831,7 @@ export function registerDbTools(pi) {
|
|
|
1141
831
|
registerAlias(pi, milestoneValidateTool, "gsd_milestone_validate", "gsd_validate_milestone");
|
|
1142
832
|
// ─── gsd_replan_slice (gsd_slice_replan alias) ─────────────────────────
|
|
1143
833
|
const replanSliceExecute = async (_toolCallId, params, _signal, _onUpdate, _ctx) => {
|
|
1144
|
-
|
|
1145
|
-
if (!dbAvailable) {
|
|
1146
|
-
return {
|
|
1147
|
-
content: [{ type: "text", text: "Error: GSD database is not available. Cannot replan slice." }],
|
|
1148
|
-
details: { operation: "replan_slice", error: "db_unavailable" },
|
|
1149
|
-
};
|
|
1150
|
-
}
|
|
1151
|
-
try {
|
|
1152
|
-
const { handleReplanSlice } = await import("../tools/replan-slice.js");
|
|
1153
|
-
const result = await handleReplanSlice(params, process.cwd());
|
|
1154
|
-
if ("error" in result) {
|
|
1155
|
-
return {
|
|
1156
|
-
content: [{ type: "text", text: `Error replanning slice: ${result.error}` }],
|
|
1157
|
-
details: { operation: "replan_slice", error: result.error },
|
|
1158
|
-
};
|
|
1159
|
-
}
|
|
1160
|
-
return {
|
|
1161
|
-
content: [{ type: "text", text: `Replanned slice ${result.sliceId} (${result.milestoneId})` }],
|
|
1162
|
-
details: {
|
|
1163
|
-
operation: "replan_slice",
|
|
1164
|
-
milestoneId: result.milestoneId,
|
|
1165
|
-
sliceId: result.sliceId,
|
|
1166
|
-
replanPath: result.replanPath,
|
|
1167
|
-
planPath: result.planPath,
|
|
1168
|
-
},
|
|
1169
|
-
};
|
|
1170
|
-
}
|
|
1171
|
-
catch (err) {
|
|
1172
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
1173
|
-
logError("tool", `replan_slice tool failed: ${msg}`, { tool: "gsd_replan_slice", error: String(err) });
|
|
1174
|
-
return {
|
|
1175
|
-
content: [{ type: "text", text: `Error replanning slice: ${msg}` }],
|
|
1176
|
-
details: { operation: "replan_slice", error: msg },
|
|
1177
|
-
};
|
|
1178
|
-
}
|
|
834
|
+
return executeReplanSlice(params, process.cwd());
|
|
1179
835
|
};
|
|
1180
836
|
const replanSliceTool = {
|
|
1181
837
|
name: "gsd_replan_slice",
|
|
@@ -1214,41 +870,7 @@ export function registerDbTools(pi) {
|
|
|
1214
870
|
registerAlias(pi, replanSliceTool, "gsd_slice_replan", "gsd_replan_slice");
|
|
1215
871
|
// ─── gsd_reassess_roadmap (gsd_roadmap_reassess alias) ─────────────────
|
|
1216
872
|
const reassessRoadmapExecute = async (_toolCallId, params, _signal, _onUpdate, _ctx) => {
|
|
1217
|
-
|
|
1218
|
-
if (!dbAvailable) {
|
|
1219
|
-
return {
|
|
1220
|
-
content: [{ type: "text", text: "Error: GSD database is not available. Cannot reassess roadmap." }],
|
|
1221
|
-
details: { operation: "reassess_roadmap", error: "db_unavailable" },
|
|
1222
|
-
};
|
|
1223
|
-
}
|
|
1224
|
-
try {
|
|
1225
|
-
const { handleReassessRoadmap } = await import("../tools/reassess-roadmap.js");
|
|
1226
|
-
const result = await handleReassessRoadmap(params, process.cwd());
|
|
1227
|
-
if ("error" in result) {
|
|
1228
|
-
return {
|
|
1229
|
-
content: [{ type: "text", text: `Error reassessing roadmap: ${result.error}` }],
|
|
1230
|
-
details: { operation: "reassess_roadmap", error: result.error },
|
|
1231
|
-
};
|
|
1232
|
-
}
|
|
1233
|
-
return {
|
|
1234
|
-
content: [{ type: "text", text: `Reassessed roadmap for milestone ${result.milestoneId} after ${result.completedSliceId}` }],
|
|
1235
|
-
details: {
|
|
1236
|
-
operation: "reassess_roadmap",
|
|
1237
|
-
milestoneId: result.milestoneId,
|
|
1238
|
-
completedSliceId: result.completedSliceId,
|
|
1239
|
-
assessmentPath: result.assessmentPath,
|
|
1240
|
-
roadmapPath: result.roadmapPath,
|
|
1241
|
-
},
|
|
1242
|
-
};
|
|
1243
|
-
}
|
|
1244
|
-
catch (err) {
|
|
1245
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
1246
|
-
logError("tool", `reassess_roadmap tool failed: ${msg}`, { tool: "gsd_reassess_roadmap", error: String(err) });
|
|
1247
|
-
return {
|
|
1248
|
-
content: [{ type: "text", text: `Error reassessing roadmap: ${msg}` }],
|
|
1249
|
-
details: { operation: "reassess_roadmap", error: msg },
|
|
1250
|
-
};
|
|
1251
|
-
}
|
|
873
|
+
return executeReassessRoadmap(params, process.cwd());
|
|
1252
874
|
};
|
|
1253
875
|
const reassessRoadmapTool = {
|
|
1254
876
|
name: "gsd_reassess_roadmap",
|
|
@@ -1292,53 +914,7 @@ export function registerDbTools(pi) {
|
|
|
1292
914
|
registerAlias(pi, reassessRoadmapTool, "gsd_roadmap_reassess", "gsd_reassess_roadmap");
|
|
1293
915
|
// ─── gsd_save_gate_result ──────────────────────────────────────────────
|
|
1294
916
|
const saveGateResultExecute = async (_toolCallId, params, _signal, _onUpdate, _ctx) => {
|
|
1295
|
-
|
|
1296
|
-
if (!dbAvailable) {
|
|
1297
|
-
return {
|
|
1298
|
-
content: [{ type: "text", text: "Error: GSD database is not available." }],
|
|
1299
|
-
details: { operation: "save_gate_result", error: "db_unavailable" },
|
|
1300
|
-
};
|
|
1301
|
-
}
|
|
1302
|
-
const validGates = ["Q3", "Q4", "Q5", "Q6", "Q7", "Q8"];
|
|
1303
|
-
if (!validGates.includes(params.gateId)) {
|
|
1304
|
-
return {
|
|
1305
|
-
content: [{ type: "text", text: `Error: Invalid gateId "${params.gateId}". Must be one of: ${validGates.join(", ")}` }],
|
|
1306
|
-
details: { operation: "save_gate_result", error: "invalid_gate_id" },
|
|
1307
|
-
};
|
|
1308
|
-
}
|
|
1309
|
-
const validVerdicts = ["pass", "flag", "omitted"];
|
|
1310
|
-
if (!validVerdicts.includes(params.verdict)) {
|
|
1311
|
-
return {
|
|
1312
|
-
content: [{ type: "text", text: `Error: Invalid verdict "${params.verdict}". Must be one of: ${validVerdicts.join(", ")}` }],
|
|
1313
|
-
details: { operation: "save_gate_result", error: "invalid_verdict" },
|
|
1314
|
-
};
|
|
1315
|
-
}
|
|
1316
|
-
try {
|
|
1317
|
-
const { saveGateResult } = await import("../gsd-db.js");
|
|
1318
|
-
const { invalidateStateCache } = await import("../state.js");
|
|
1319
|
-
saveGateResult({
|
|
1320
|
-
milestoneId: params.milestoneId,
|
|
1321
|
-
sliceId: params.sliceId,
|
|
1322
|
-
gateId: params.gateId,
|
|
1323
|
-
taskId: params.taskId ?? "",
|
|
1324
|
-
verdict: params.verdict,
|
|
1325
|
-
rationale: params.rationale,
|
|
1326
|
-
findings: params.findings ?? "",
|
|
1327
|
-
});
|
|
1328
|
-
invalidateStateCache();
|
|
1329
|
-
return {
|
|
1330
|
-
content: [{ type: "text", text: `Gate ${params.gateId} result saved: verdict=${params.verdict}` }],
|
|
1331
|
-
details: { operation: "save_gate_result", gateId: params.gateId, verdict: params.verdict },
|
|
1332
|
-
};
|
|
1333
|
-
}
|
|
1334
|
-
catch (err) {
|
|
1335
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
1336
|
-
logError("tool", `gsd_save_gate_result failed: ${msg}`, { tool: "gsd_save_gate_result", error: String(err) });
|
|
1337
|
-
return {
|
|
1338
|
-
content: [{ type: "text", text: `Error saving gate result: ${msg}` }],
|
|
1339
|
-
details: { operation: "save_gate_result", error: msg },
|
|
1340
|
-
};
|
|
1341
|
-
}
|
|
917
|
+
return executeSaveGateResult(params, process.cwd());
|
|
1342
918
|
};
|
|
1343
919
|
const saveGateResultTool = {
|
|
1344
920
|
name: "gsd_save_gate_result",
|
|
@@ -64,12 +64,9 @@ export function resolveProjectRootDbPath(basePath) {
|
|
|
64
64
|
}
|
|
65
65
|
return join(basePath, ".gsd", "gsd.db");
|
|
66
66
|
}
|
|
67
|
-
export async function ensureDbOpen() {
|
|
67
|
+
export async function ensureDbOpen(basePath = process.cwd()) {
|
|
68
68
|
try {
|
|
69
69
|
const db = await import("../gsd-db.js");
|
|
70
|
-
if (db.isDbAvailable())
|
|
71
|
-
return true;
|
|
72
|
-
const basePath = process.cwd();
|
|
73
70
|
const dbPath = resolveProjectRootDbPath(basePath);
|
|
74
71
|
const gsdDir = join(basePath, ".gsd");
|
|
75
72
|
// Derive the project root from the DB path (strip .gsd/gsd.db)
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
// GSD2 — Read-only query tools exposing DB state to the LLM via the WAL connection
|
|
2
2
|
import { Type } from "@sinclair/typebox";
|
|
3
|
-
import {
|
|
3
|
+
import { ensureDbOpen } from "./dynamic-tools.js";
|
|
4
|
+
import { executeMilestoneStatus } from "../tools/workflow-tool-executors.js";
|
|
4
5
|
export function registerQueryTools(pi) {
|
|
5
6
|
pi.registerTool({
|
|
6
7
|
name: "gsd_milestone_status",
|
|
@@ -16,72 +17,14 @@ export function registerQueryTools(pi) {
|
|
|
16
17
|
milestoneId: Type.String({ description: "Milestone ID to query (e.g. M001)" }),
|
|
17
18
|
}),
|
|
18
19
|
async execute(_toolCallId, params, _signal, _onUpdate, _ctx) {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
// ensureDbOpen() only creates/migrates when .gsd/ has content (#3644).
|
|
22
|
-
const { ensureDbOpen } = await import("./dynamic-tools.js");
|
|
23
|
-
const dbAvailable = await ensureDbOpen();
|
|
24
|
-
const { getMilestone, getSliceStatusSummary, getSliceTaskCounts, _getAdapter, } = await import("../gsd-db.js");
|
|
25
|
-
if (!dbAvailable) {
|
|
26
|
-
return {
|
|
27
|
-
content: [{ type: "text", text: "Error: GSD database is not available." }],
|
|
28
|
-
details: { operation: "milestone_status", error: "db_unavailable" },
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
// Wrap all reads in a single transaction for snapshot consistency.
|
|
32
|
-
// SQLite WAL mode guarantees reads within a transaction see a single
|
|
33
|
-
// consistent snapshot, preventing torn reads from concurrent writes.
|
|
34
|
-
const adapter = _getAdapter();
|
|
35
|
-
adapter.exec("BEGIN"); // eslint-disable-line -- SQLite exec, not child_process
|
|
36
|
-
try {
|
|
37
|
-
const milestone = getMilestone(params.milestoneId);
|
|
38
|
-
if (!milestone) {
|
|
39
|
-
adapter.exec("COMMIT"); // eslint-disable-line
|
|
40
|
-
return {
|
|
41
|
-
content: [{ type: "text", text: `Milestone ${params.milestoneId} not found in database.` }],
|
|
42
|
-
details: { operation: "milestone_status", milestoneId: params.milestoneId, found: false },
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
const sliceStatuses = getSliceStatusSummary(params.milestoneId);
|
|
46
|
-
const slices = sliceStatuses.map((s) => {
|
|
47
|
-
const counts = getSliceTaskCounts(params.milestoneId, s.id);
|
|
48
|
-
return {
|
|
49
|
-
id: s.id,
|
|
50
|
-
status: s.status,
|
|
51
|
-
taskCounts: counts,
|
|
52
|
-
};
|
|
53
|
-
});
|
|
54
|
-
adapter.exec("COMMIT"); // eslint-disable-line
|
|
55
|
-
const result = {
|
|
56
|
-
milestoneId: milestone.id,
|
|
57
|
-
title: milestone.title,
|
|
58
|
-
status: milestone.status,
|
|
59
|
-
createdAt: milestone.created_at,
|
|
60
|
-
completedAt: milestone.completed_at,
|
|
61
|
-
sliceCount: slices.length,
|
|
62
|
-
slices,
|
|
63
|
-
};
|
|
64
|
-
return {
|
|
65
|
-
content: [{ type: "text", text: JSON.stringify(result, null, 2) }],
|
|
66
|
-
details: { operation: "milestone_status", milestoneId: milestone.id, sliceCount: slices.length },
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
catch (txErr) {
|
|
70
|
-
try {
|
|
71
|
-
adapter.exec("ROLLBACK");
|
|
72
|
-
}
|
|
73
|
-
catch { /* swallow */ } // eslint-disable-line
|
|
74
|
-
throw txErr;
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
catch (err) {
|
|
78
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
79
|
-
logWarning("tool", `gsd_milestone_status tool failed: ${msg}`);
|
|
20
|
+
const dbAvailable = await ensureDbOpen();
|
|
21
|
+
if (!dbAvailable) {
|
|
80
22
|
return {
|
|
81
|
-
content: [{ type: "text", text:
|
|
82
|
-
details: { operation: "milestone_status", error:
|
|
23
|
+
content: [{ type: "text", text: "Error: GSD database is not available. Cannot read milestone status." }],
|
|
24
|
+
details: { operation: "milestone_status", error: "db_unavailable" },
|
|
83
25
|
};
|
|
84
26
|
}
|
|
27
|
+
return executeMilestoneStatus(params);
|
|
85
28
|
},
|
|
86
29
|
});
|
|
87
30
|
}
|
|
@@ -8,6 +8,7 @@ import { readForensicsMarker } from "../forensics.js";
|
|
|
8
8
|
import { resolveAllSkillReferences, renderPreferencesForSystemPrompt, loadEffectiveGSDPreferences } from "../preferences.js";
|
|
9
9
|
import { resolveSkillReference } from "../preferences-skills.js";
|
|
10
10
|
import { resolveGsdRootFile, resolveSliceFile, resolveSlicePath, resolveTaskFile, resolveTaskFiles, resolveTasksDir, relSliceFile, relSlicePath, relTaskFile } from "../paths.js";
|
|
11
|
+
import { ensureCodebaseMapFresh, readCodebaseMap } from "../codebase-generator.js";
|
|
11
12
|
import { hasSkillSnapshot, detectNewSkills, formatSkillsXml } from "../skill-discovery.js";
|
|
12
13
|
import { getActiveAutoWorktreeContext } from "../auto-worktree.js";
|
|
13
14
|
import { getActiveWorktreeName, getWorktreeOriginalCwd } from "../worktree-command.js";
|
|
@@ -103,10 +104,24 @@ export async function buildBeforeAgentStartResult(event, ctx) {
|
|
|
103
104
|
}
|
|
104
105
|
}
|
|
105
106
|
let codebaseBlock = "";
|
|
107
|
+
try {
|
|
108
|
+
const codebaseOptions = loadedPreferences?.preferences?.codebase
|
|
109
|
+
? {
|
|
110
|
+
excludePatterns: loadedPreferences.preferences.codebase.exclude_patterns,
|
|
111
|
+
maxFiles: loadedPreferences.preferences.codebase.max_files,
|
|
112
|
+
collapseThreshold: loadedPreferences.preferences.codebase.collapse_threshold,
|
|
113
|
+
}
|
|
114
|
+
: undefined;
|
|
115
|
+
ensureCodebaseMapFresh(process.cwd(), codebaseOptions);
|
|
116
|
+
}
|
|
117
|
+
catch (e) {
|
|
118
|
+
logWarning("bootstrap", `CODEBASE refresh failed: ${e.message}`);
|
|
119
|
+
}
|
|
106
120
|
const codebasePath = resolveGsdRootFile(process.cwd(), "CODEBASE");
|
|
107
|
-
|
|
121
|
+
const rawCodebase = readCodebaseMap(process.cwd());
|
|
122
|
+
if (existsSync(codebasePath) && rawCodebase) {
|
|
108
123
|
try {
|
|
109
|
-
const rawContent =
|
|
124
|
+
const rawContent = rawCodebase.trim();
|
|
110
125
|
if (rawContent) {
|
|
111
126
|
// Cap injection size to ~2 000 tokens to avoid bloating every request.
|
|
112
127
|
// Full map is always available at .gsd/CODEBASE.md.
|
|
@@ -116,7 +131,7 @@ export async function buildBeforeAgentStartResult(event, ctx) {
|
|
|
116
131
|
const content = rawContent.length > MAX_CODEBASE_CHARS
|
|
117
132
|
? rawContent.slice(0, MAX_CODEBASE_CHARS) + "\n\n*(truncated — see .gsd/CODEBASE.md for full map)*"
|
|
118
133
|
: rawContent;
|
|
119
|
-
codebaseBlock = `\n\n[PROJECT CODEBASE — File structure and descriptions (generated ${generatedAt},
|
|
134
|
+
codebaseBlock = `\n\n[PROJECT CODEBASE — File structure and descriptions (generated ${generatedAt}, auto-refreshed when GSD detects tracked file changes; use /gsd codebase stats for status)]\n\n${content}`;
|
|
120
135
|
}
|
|
121
136
|
}
|
|
122
137
|
catch (e) {
|