gsd-pi 2.78.0 → 2.78.1-dev.84a383f51
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 +59 -23
- package/dist/claude-cli-check.js +91 -32
- package/dist/cli-policy.d.ts +13 -0
- package/dist/cli-policy.js +17 -0
- package/dist/cli.js +95 -55
- package/dist/headless-query.d.ts +22 -0
- package/dist/headless-query.js +24 -4
- package/dist/headless.d.ts +10 -0
- package/dist/headless.js +16 -1
- package/dist/loader.js +7 -10
- package/dist/onboarding.d.ts +10 -0
- package/dist/onboarding.js +2 -2
- package/dist/provider-migrations.d.ts +2 -2
- package/dist/provider-migrations.js +5 -2
- package/dist/resource-loader.d.ts +5 -2
- package/dist/resource-loader.js +28 -5
- package/dist/resources/.managed-resources-content-hash +1 -0
- package/dist/resources/extensions/claude-code-cli/readiness.js +115 -31
- package/dist/resources/extensions/gsd/auto/loop.js +23 -0
- package/dist/resources/extensions/gsd/auto/phases.js +2 -2
- package/dist/resources/extensions/gsd/auto/run-unit.js +3 -1
- package/dist/resources/extensions/gsd/auto/session.js +3 -0
- package/dist/resources/extensions/gsd/auto-recovery.js +43 -4
- package/dist/resources/extensions/gsd/auto-runtime-state.js +31 -0
- package/dist/resources/extensions/gsd/auto-start.js +1 -1
- package/dist/resources/extensions/gsd/auto-tool-tracking.js +2 -2
- package/dist/resources/extensions/gsd/auto-worktree.js +30 -0
- package/dist/resources/extensions/gsd/auto.js +14 -5
- package/dist/resources/extensions/gsd/bootstrap/db-tools.js +14 -2
- package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +7 -5
- package/dist/resources/extensions/gsd/bootstrap/query-tools.js +2 -2
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +5 -4
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +94 -31
- package/dist/resources/extensions/gsd/bootstrap/register-shortcuts.js +11 -6
- package/dist/resources/extensions/gsd/bootstrap/system-context.js +34 -8
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +38 -2
- package/dist/resources/extensions/gsd/commands/catalog.js +69 -5
- package/dist/resources/extensions/gsd/commands/handlers/core.js +22 -1
- package/dist/resources/extensions/gsd/commands-mcp-status.js +3 -1
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +10 -1
- package/dist/resources/extensions/gsd/dashboard-overlay.js +1 -1
- package/dist/resources/extensions/gsd/docs/preferences-reference.md +4 -0
- package/dist/resources/extensions/gsd/doctor-runtime-checks.js +39 -1
- package/dist/resources/extensions/gsd/error-classifier.js +1 -1
- package/dist/resources/extensions/gsd/forensics.js +2 -2
- package/dist/resources/extensions/gsd/git-service.js +12 -5
- package/dist/resources/extensions/gsd/gsd-db.js +11 -2
- package/dist/resources/extensions/gsd/guided-flow.js +23 -23
- package/dist/resources/extensions/gsd/memory-store.js +66 -31
- package/dist/resources/extensions/gsd/milestone-id-reservation.js +36 -0
- package/dist/resources/extensions/gsd/model-router.js +114 -9
- package/dist/resources/extensions/gsd/native-git-bridge.js +7 -1
- package/dist/resources/extensions/gsd/preferences-models.js +91 -15
- package/dist/resources/extensions/gsd/preferences-types.js +2 -0
- package/dist/resources/extensions/gsd/preferences-validation.js +32 -0
- package/dist/resources/extensions/gsd/preferences.js +5 -3
- package/dist/resources/extensions/gsd/prompt-loader.js +23 -12
- package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +9 -3
- package/dist/resources/extensions/gsd/state.js +42 -0
- package/dist/resources/extensions/gsd/templates/PREFERENCES.md +1 -0
- package/dist/resources/extensions/gsd/tools/memory-tools.js +18 -1
- package/dist/resources/extensions/gsd/visualizer-overlay.js +1 -1
- package/dist/resources/extensions/gsd/watch/header-renderer.js +3 -1
- package/dist/resources/extensions/gsd/worktree-command.js +26 -46
- package/dist/resources/extensions/gsd/worktree-session-state.js +33 -0
- package/dist/resources/extensions/mcp-client/index.js +6 -3
- package/dist/resources/extensions/slash-commands/create-extension.js +36 -22
- package/dist/resources/skills/create-gsd-extension/SKILL.md +9 -5
- package/dist/resources/skills/create-gsd-extension/references/custom-commands.md +1 -1
- package/dist/resources/skills/create-gsd-extension/references/custom-rendering.md +5 -5
- package/dist/resources/skills/create-gsd-extension/references/custom-tools.md +4 -4
- package/dist/resources/skills/create-gsd-extension/references/custom-ui.md +6 -6
- package/dist/resources/skills/create-gsd-extension/references/events-reference.md +3 -3
- package/dist/resources/skills/create-gsd-extension/references/packaging-distribution.md +1 -1
- package/dist/resources/skills/create-gsd-extension/references/remote-execution-overrides.md +3 -3
- package/dist/resources/skills/create-gsd-extension/workflows/create-extension.md +32 -12
- package/dist/rtk-shared.d.ts +3 -0
- package/dist/rtk-shared.js +17 -0
- package/dist/rtk.d.ts +2 -5
- package/dist/rtk.js +3 -20
- package/dist/runtime-checks.d.ts +27 -0
- package/dist/runtime-checks.js +38 -0
- package/dist/tsconfig.extensions.tsbuildinfo +1 -1
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +13 -13
- package/dist/web/standalone/.next/build-manifest.json +4 -4
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/react-loadable-manifest.json +44 -4
- package/dist/web/standalone/.next/required-server-files.json +3 -3
- package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
- package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
- package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +3 -3
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
- package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/experimental/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/experimental/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/notifications/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/notifications/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/events/route.js +4 -2
- package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +4 -4
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +4 -4
- package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +4 -4
- package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +3 -3
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/page.js +2 -2
- package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +13 -13
- package/dist/web/standalone/.next/server/chunks/63.js +3 -3
- package/dist/web/standalone/.next/server/chunks/6897.js +1 -1
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
- package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware.js +2 -2
- package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
- package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
- package/dist/web/standalone/.next/server/pages/404.html +1 -1
- package/dist/web/standalone/.next/server/pages/500.html +1 -1
- package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
- package/dist/web/standalone/.next/server/webpack-runtime.js +1 -1
- package/dist/web/standalone/.next/static/chunks/2556.0527fea66e123b7f.js +1 -0
- package/dist/web/standalone/.next/static/chunks/2824.08296bc2f9654698.js +1 -0
- package/dist/web/standalone/.next/static/chunks/3026.3af53b279375f082.js +1 -0
- package/dist/web/standalone/.next/static/chunks/315.6f68ae79b67d25cf.js +1 -0
- package/dist/web/standalone/.next/static/chunks/3497.4bfc60a3b3dea717.js +1 -0
- package/dist/web/standalone/.next/static/chunks/5516.4a07c872b5c3a663.js +1 -0
- package/dist/web/standalone/.next/static/chunks/8336.31b019697882acfb.js +10 -0
- package/dist/web/standalone/.next/static/chunks/8845.c9702695e8c5a9c5.js +2 -0
- package/dist/web/standalone/.next/static/chunks/9058.01ef3a463bda88f1.js +20 -0
- package/dist/web/standalone/.next/static/chunks/9441.1081da1125d1764f.js +1 -0
- package/dist/web/standalone/.next/static/chunks/app/_not-found/{page-2f24283c162b6ab3.js → page-f2a7482d42a5614b.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/app/{layout-9ecfd95f343793f0.js → layout-a16c7a7ecdf0c2cf.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/app/page-9bf2e0c50fb2ca05.js +1 -0
- package/dist/web/standalone/.next/static/chunks/main-app-fdab67f7802d7832.js +1 -0
- package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +1 -0
- package/dist/web/standalone/.next/static/chunks/webpack-f9f0dc45e4f3ac10.js +1 -0
- package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
- package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
- package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
- package/dist/web/standalone/package.json +2 -1
- package/dist/web/standalone/server.js +1 -1
- package/dist/worktree-status-banner.d.ts +1 -0
- package/dist/worktree-status-banner.js +132 -0
- package/package.json +1 -1
- package/packages/daemon/package.json +2 -2
- package/packages/mcp-server/dist/alias-telemetry.d.ts +8 -0
- package/packages/mcp-server/dist/alias-telemetry.d.ts.map +1 -0
- package/packages/mcp-server/dist/alias-telemetry.js +30 -0
- package/packages/mcp-server/dist/alias-telemetry.js.map +1 -0
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +74 -46
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/package.json +2 -2
- package/packages/mcp-server/src/alias-telemetry.test.ts +78 -0
- package/packages/mcp-server/src/alias-telemetry.ts +30 -0
- package/packages/mcp-server/src/workflow-tools.test.ts +26 -0
- package/packages/mcp-server/src/workflow-tools.ts +93 -58
- package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
- package/packages/native/package.json +1 -1
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-ai/dist/providers/anthropic-shared.cache-breakpoint.test.d.ts +2 -0
- package/packages/pi-ai/dist/providers/anthropic-shared.cache-breakpoint.test.d.ts.map +1 -0
- package/packages/pi-ai/dist/providers/anthropic-shared.cache-breakpoint.test.js +231 -0
- package/packages/pi-ai/dist/providers/anthropic-shared.cache-breakpoint.test.js.map +1 -0
- package/packages/pi-ai/dist/providers/anthropic-shared.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic-shared.js +48 -19
- package/packages/pi-ai/dist/providers/anthropic-shared.js.map +1 -1
- package/packages/pi-ai/dist/types.d.ts +13 -0
- package/packages/pi-ai/dist/types.d.ts.map +1 -1
- package/packages/pi-ai/dist/types.js.map +1 -1
- package/packages/pi-ai/dist/utils/repair-tool-json.d.ts.map +1 -1
- package/packages/pi-ai/dist/utils/repair-tool-json.js +24 -3
- package/packages/pi-ai/dist/utils/repair-tool-json.js.map +1 -1
- package/packages/pi-ai/dist/utils/tests/repair-tool-json.test.js +26 -0
- package/packages/pi-ai/dist/utils/tests/repair-tool-json.test.js.map +1 -1
- package/packages/pi-ai/package.json +1 -1
- package/packages/pi-ai/src/providers/anthropic-shared.cache-breakpoint.test.ts +289 -0
- package/packages/pi-ai/src/providers/anthropic-shared.ts +52 -20
- package/packages/pi-ai/src/types.ts +13 -0
- package/packages/pi-ai/src/utils/repair-tool-json.ts +24 -3
- package/packages/pi-ai/src/utils/tests/repair-tool-json.test.ts +32 -0
- package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.js +6 -0
- package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/messages.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/messages.js +4 -0
- package/packages/pi-coding-agent/dist/core/messages.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +19 -2
- package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry.d.ts +10 -0
- package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry.js +18 -0
- package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/system-prompt.d.ts +13 -0
- package/packages/pi-coding-agent/dist/core/system-prompt.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/system-prompt.js +20 -16
- package/packages/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/token-telemetry.d.ts +37 -0
- package/packages/pi-coding-agent/dist/core/token-telemetry.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/token-telemetry.js +49 -0
- package/packages/pi-coding-agent/dist/core/token-telemetry.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.js +133 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.js +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js +14 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/tests/system-prompt-cache-stability.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/tests/system-prompt-cache-stability.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/tests/system-prompt-cache-stability.test.js +78 -0
- package/packages/pi-coding-agent/dist/tests/system-prompt-cache-stability.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/tests/token-telemetry.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/tests/token-telemetry.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/tests/token-telemetry.test.js +181 -0
- package/packages/pi-coding-agent/dist/tests/token-telemetry.test.js.map +1 -0
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/core/agent-session.ts +7 -0
- package/packages/pi-coding-agent/src/core/messages.ts +4 -0
- package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +32 -2
- package/packages/pi-coding-agent/src/core/model-registry.ts +21 -0
- package/packages/pi-coding-agent/src/core/system-prompt.ts +33 -15
- package/packages/pi-coding-agent/src/core/token-telemetry.ts +77 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.ts +212 -0
- package/packages/pi-coding-agent/src/modes/interactive/controllers/input-controller.test.ts +17 -1
- package/packages/pi-coding-agent/src/modes/interactive/controllers/input-controller.ts +1 -1
- package/packages/pi-coding-agent/src/tests/system-prompt-cache-stability.test.ts +102 -0
- package/packages/pi-coding-agent/src/tests/token-telemetry.test.ts +200 -0
- package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-tui/dist/__tests__/autocomplete.test.js +17 -3
- package/packages/pi-tui/dist/__tests__/autocomplete.test.js.map +1 -1
- package/packages/pi-tui/dist/components/__tests__/leak-fixes-runtime.test.d.ts +2 -0
- package/packages/pi-tui/dist/components/__tests__/leak-fixes-runtime.test.d.ts.map +1 -0
- package/packages/pi-tui/dist/components/__tests__/leak-fixes-runtime.test.js +161 -0
- package/packages/pi-tui/dist/components/__tests__/leak-fixes-runtime.test.js.map +1 -0
- package/packages/pi-tui/package.json +1 -1
- package/packages/pi-tui/src/__tests__/autocomplete.test.ts +20 -3
- package/packages/pi-tui/src/components/__tests__/leak-fixes-runtime.test.ts +219 -0
- package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
- package/packages/rpc-client/package.json +1 -1
- package/pkg/package.json +1 -1
- package/src/resources/extensions/claude-code-cli/readiness.ts +116 -29
- package/src/resources/extensions/gsd/auto/loop.ts +24 -2
- package/src/resources/extensions/gsd/auto/phases.ts +3 -3
- package/src/resources/extensions/gsd/auto/run-unit.ts +3 -1
- package/src/resources/extensions/gsd/auto/session.ts +3 -0
- package/src/resources/extensions/gsd/auto/types.ts +1 -0
- package/src/resources/extensions/gsd/auto-recovery.ts +46 -8
- package/src/resources/extensions/gsd/auto-runtime-state.ts +51 -0
- package/src/resources/extensions/gsd/auto-start.ts +1 -1
- package/src/resources/extensions/gsd/auto-tool-tracking.ts +2 -4
- package/src/resources/extensions/gsd/auto-worktree.ts +38 -0
- package/src/resources/extensions/gsd/auto.ts +14 -4
- package/src/resources/extensions/gsd/bootstrap/db-tools.ts +15 -13
- package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +8 -7
- package/src/resources/extensions/gsd/bootstrap/query-tools.ts +2 -2
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +10 -9
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +102 -31
- package/src/resources/extensions/gsd/bootstrap/register-shortcuts.ts +12 -6
- package/src/resources/extensions/gsd/bootstrap/system-context.ts +39 -8
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +39 -11
- package/src/resources/extensions/gsd/commands/catalog.ts +75 -5
- package/src/resources/extensions/gsd/commands/handlers/core.ts +22 -1
- package/src/resources/extensions/gsd/commands-mcp-status.ts +3 -1
- package/src/resources/extensions/gsd/commands-prefs-wizard.ts +15 -1
- package/src/resources/extensions/gsd/dashboard-overlay.ts +1 -1
- package/src/resources/extensions/gsd/docs/preferences-reference.md +4 -0
- package/src/resources/extensions/gsd/doctor-runtime-checks.ts +39 -1
- package/src/resources/extensions/gsd/doctor-types.ts +3 -1
- package/src/resources/extensions/gsd/error-classifier.ts +1 -1
- package/src/resources/extensions/gsd/forensics.ts +2 -2
- package/src/resources/extensions/gsd/git-service.ts +13 -5
- package/src/resources/extensions/gsd/gsd-db.ts +12 -2
- package/src/resources/extensions/gsd/guided-flow.ts +25 -25
- package/src/resources/extensions/gsd/memory-store.ts +81 -28
- package/src/resources/extensions/gsd/milestone-id-reservation.ts +47 -0
- package/src/resources/extensions/gsd/model-router.ts +172 -9
- package/src/resources/extensions/gsd/native-git-bridge.ts +7 -1
- package/src/resources/extensions/gsd/preferences-models.ts +101 -15
- package/src/resources/extensions/gsd/preferences-types.ts +6 -0
- package/src/resources/extensions/gsd/preferences-validation.ts +35 -0
- package/src/resources/extensions/gsd/preferences.ts +16 -2
- package/src/resources/extensions/gsd/prompt-loader.ts +26 -12
- package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +9 -3
- package/src/resources/extensions/gsd/state.ts +42 -0
- package/src/resources/extensions/gsd/templates/PREFERENCES.md +1 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +178 -1
- package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +58 -0
- package/src/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +9 -5
- package/src/resources/extensions/gsd/tests/auto-supervisor.test.mjs +21 -4
- package/src/resources/extensions/gsd/tests/bootstrap-derive-state-db-open.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/budget-prediction.test.ts +138 -211
- package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +142 -59
- package/src/resources/extensions/gsd/tests/complete-slice.test.ts +7 -4
- package/src/resources/extensions/gsd/tests/completed-at-reconcile.test.ts +89 -32
- package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +41 -23
- package/src/resources/extensions/gsd/tests/db-path-worktree-symlink.test.ts +3 -43
- package/src/resources/extensions/gsd/tests/debug-logger.test.ts +5 -3
- package/src/resources/extensions/gsd/tests/deferred-milestone-dir-4996.test.ts +116 -0
- package/src/resources/extensions/gsd/tests/discuss-empty-db-fallback.test.ts +22 -87
- package/src/resources/extensions/gsd/tests/discuss-queued-milestones.test.ts +7 -118
- package/src/resources/extensions/gsd/tests/discuss-tool-scope-leak.test.ts +18 -60
- package/src/resources/extensions/gsd/tests/doctor-orphan-milestone-4996.test.ts +100 -0
- package/src/resources/extensions/gsd/tests/double-merge-guard.test.ts +14 -76
- package/src/resources/extensions/gsd/tests/ensure-preconditions-guard-4996.test.ts +93 -0
- package/src/resources/extensions/gsd/tests/false-degraded-mode-warning.test.ts +22 -83
- package/src/resources/extensions/gsd/tests/finalize-timeout-guard.test.ts +1 -63
- package/src/resources/extensions/gsd/tests/find-missing-summaries-closed-runtime.test.ts +47 -0
- package/src/resources/extensions/gsd/tests/forensics-stuck-loops.test.ts +26 -1
- package/src/resources/extensions/gsd/tests/gitignore-bg-shell-runtime.test.ts +63 -0
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +30 -0
- package/src/resources/extensions/gsd/tests/gsd-no-project-error-runtime.test.ts +81 -0
- package/src/resources/extensions/gsd/tests/headless-answers.test.ts +14 -4
- package/src/resources/extensions/gsd/tests/health-widget.test.ts +22 -12
- package/src/resources/extensions/gsd/tests/help-menu-coverage.test.ts +57 -0
- package/src/resources/extensions/gsd/tests/import-done-milestones-runtime.test.ts +145 -0
- package/src/resources/extensions/gsd/tests/init-prefs-routing.test.ts +64 -1
- package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +22 -0
- package/src/resources/extensions/gsd/tests/integration/token-savings.test.ts +0 -23
- package/src/resources/extensions/gsd/tests/memory-store.test.ts +128 -0
- package/src/resources/extensions/gsd/tests/memory-tools.test.ts +33 -1
- package/src/resources/extensions/gsd/tests/merge-self-branch-guard.test.ts +124 -0
- package/src/resources/extensions/gsd/tests/milestone-id-gap-reuse-4996.test.ts +152 -0
- package/src/resources/extensions/gsd/tests/model-router.test.ts +169 -8
- package/src/resources/extensions/gsd/tests/native-git-infra-errors.test.ts +50 -0
- package/src/resources/extensions/gsd/tests/orphaned-worktree-audit.test.ts +8 -0
- package/src/resources/extensions/gsd/tests/parallel-crash-recovery.test.ts +32 -43
- package/src/resources/extensions/gsd/tests/phases-merge-error-stops-auto.test.ts +4 -10
- package/src/resources/extensions/gsd/tests/preferences.test.ts +127 -0
- package/src/resources/extensions/gsd/tests/prompt-step-ordering.test.ts +16 -0
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +7 -0
- package/src/resources/extensions/gsd/tests/quick-turn-end-cleanup.test.ts +6 -6
- package/src/resources/extensions/gsd/tests/register-hooks-compaction-checkpoint.test.ts +93 -0
- package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +168 -19
- package/src/resources/extensions/gsd/tests/slice-parallel-orchestrator.test.ts +7 -1
- package/src/resources/extensions/gsd/tests/smart-entry-complete.test.ts +23 -1
- package/src/resources/extensions/gsd/tests/system-context-message-routing.test.ts +101 -0
- package/src/resources/extensions/gsd/tests/token-profile.test.ts +51 -4
- package/src/resources/extensions/gsd/tests/turn-epoch.test.ts +7 -16
- package/src/resources/extensions/gsd/tests/unstructured-continue-context-injection.test.ts +5 -7
- package/src/resources/extensions/gsd/tests/uok-gitops-turn-action.test.ts +15 -1
- package/src/resources/extensions/gsd/tests/visualizer-overlay.test.ts +6 -6
- package/src/resources/extensions/gsd/tests/write-gate-planning-unit.test.ts +15 -0
- package/src/resources/extensions/gsd/tools/memory-tools.ts +17 -1
- package/src/resources/extensions/gsd/unit-context-manifest.ts +8 -8
- package/src/resources/extensions/gsd/visualizer-overlay.ts +1 -1
- package/src/resources/extensions/gsd/watch/header-renderer.ts +3 -1
- package/src/resources/extensions/gsd/workflow-logger.ts +1 -0
- package/src/resources/extensions/gsd/worktree-command.ts +31 -44
- package/src/resources/extensions/gsd/worktree-session-state.ts +35 -0
- package/src/resources/extensions/mcp-client/index.ts +6 -3
- package/src/resources/extensions/mcp-client/tests/global-config.test.ts +91 -0
- package/src/resources/extensions/slash-commands/create-extension.ts +38 -24
- package/src/resources/skills/create-gsd-extension/SKILL.md +9 -5
- package/src/resources/skills/create-gsd-extension/references/custom-commands.md +1 -1
- package/src/resources/skills/create-gsd-extension/references/custom-rendering.md +5 -5
- package/src/resources/skills/create-gsd-extension/references/custom-tools.md +4 -4
- package/src/resources/skills/create-gsd-extension/references/custom-ui.md +6 -6
- package/src/resources/skills/create-gsd-extension/references/events-reference.md +3 -3
- package/src/resources/skills/create-gsd-extension/references/packaging-distribution.md +1 -1
- package/src/resources/skills/create-gsd-extension/references/remote-execution-overrides.md +3 -3
- package/src/resources/skills/create-gsd-extension/templates/extension-skeleton.ts +2 -2
- package/src/resources/skills/create-gsd-extension/templates/stateful-tool-skeleton.ts +3 -3
- package/src/resources/skills/create-gsd-extension/templates/templates.test.ts +58 -0
- package/src/resources/skills/create-gsd-extension/workflows/create-extension.md +32 -12
- package/dist/resources/extensions/browser-tools/tests/browser-tools-integration.test.mjs +0 -601
- package/dist/resources/extensions/browser-tools/tests/browser-tools-unit.test.cjs +0 -651
- package/dist/resources/extensions/browser-tools/tests/capture-sharp-optional.test.cjs +0 -91
- package/dist/resources/extensions/gsd/tests/auto-supervisor.test.mjs +0 -53
- package/dist/resources/extensions/gsd/tests/dist-redirect.mjs +0 -112
- package/dist/resources/extensions/gsd/tests/resolve-ts-hooks.mjs +0 -23
- package/dist/resources/extensions/gsd/tests/resolve-ts.mjs +0 -5
- package/dist/resources/skills/github-workflows/references/gh/tests/__init__.py +0 -0
- package/dist/resources/skills/github-workflows/references/gh/tests/test_github_project_setup.py +0 -608
- package/dist/web/standalone/.next/static/chunks/2826.e9f5195e91f9cad2.js +0 -11
- package/dist/web/standalone/.next/static/chunks/3621.fc7480022c972438.js +0 -20
- package/dist/web/standalone/.next/static/chunks/app/page-151349214571e2b6.js +0 -1
- package/dist/web/standalone/.next/static/chunks/main-app-d3d4c336195465f9.js +0 -1
- package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-ab5a8926e07ec673.js +0 -1
- package/dist/web/standalone/.next/static/chunks/webpack-2e68521d7c82f7c2.js +0 -1
- package/src/resources/extensions/gsd/tests/copy-planning-artifacts-samepath.test.ts +0 -22
- package/src/resources/extensions/gsd/tests/discuss-slice-structured-questions.test.ts +0 -47
- package/src/resources/extensions/gsd/tests/empty-content-abort-loop.test.ts +0 -75
- /package/dist/web/standalone/.next/static/{C1zT2kEfoLhDdbWPWKrXd → UF5VF4F1tB0miEtJS7LyX}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{C1zT2kEfoLhDdbWPWKrXd → UF5VF4F1tB0miEtJS7LyX}/_ssgManifest.js +0 -0
|
@@ -58,16 +58,21 @@ export function showHelp(ctx, args = "") {
|
|
|
58
58
|
" /gsd pause Pause auto-mode (preserves state, /gsd auto to resume)",
|
|
59
59
|
" /gsd discuss Start guided milestone/slice discussion",
|
|
60
60
|
" /gsd new-milestone Create milestone from headless context (used by gsd headless)",
|
|
61
|
+
" /gsd quick Execute a quick task without full planning overhead",
|
|
62
|
+
" /gsd dispatch Dispatch a specific phase directly [research|plan|execute|complete|uat|replan]",
|
|
63
|
+
" /gsd parallel Parallel milestone orchestration [start|status|stop|pause|resume|merge|watch]",
|
|
64
|
+
" /gsd workflow Custom workflow lifecycle [new|run|list|validate|pause|resume]",
|
|
61
65
|
"",
|
|
62
66
|
"VISIBILITY",
|
|
63
67
|
` /gsd status Show progress dashboard (${formattedShortcutPair("dashboard")})`,
|
|
64
68
|
` /gsd parallel watch Open parallel worker monitor (${formattedShortcutPair("parallel")})`,
|
|
69
|
+
" /gsd widget Cycle status widget [full|small|min|off]",
|
|
65
70
|
" /gsd visualize Interactive 10-tab TUI (progress, timeline, deps, metrics, health, agent, changes, knowledge, captures, export)",
|
|
66
71
|
" /gsd queue Show queued/dispatched units and execution order",
|
|
67
72
|
" /gsd history View execution history [--cost] [--phase] [--model] [N]",
|
|
68
73
|
" /gsd changelog Show categorized release notes [version]",
|
|
69
74
|
` /gsd notifications View persistent notification history [clear|tail|filter] (${formattedShortcutPair("notifications")})`,
|
|
70
|
-
" /gsd logs Browse activity logs, debug logs, and metrics",
|
|
75
|
+
" /gsd logs Browse activity logs, debug logs, and metrics [debug|tail|clear]",
|
|
71
76
|
" /gsd debug Create/list/continue persistent debug sessions",
|
|
72
77
|
"",
|
|
73
78
|
"COURSE CORRECTION",
|
|
@@ -76,6 +81,9 @@ export function showHelp(ctx, args = "") {
|
|
|
76
81
|
" /gsd triage Classify and route pending captures",
|
|
77
82
|
" /gsd skip <unit> Prevent a unit from auto-mode dispatch",
|
|
78
83
|
" /gsd undo Revert last completed unit [--force]",
|
|
84
|
+
" /gsd undo-task Reset a specific task's completion state [DB + markdown]",
|
|
85
|
+
" /gsd reset-slice Reset a slice and all its tasks [DB + markdown]",
|
|
86
|
+
" /gsd rate Rate last unit's model tier [over|ok|under]",
|
|
79
87
|
" /gsd rethink Conversational project reorganization — reorder, park, discard, add milestones",
|
|
80
88
|
" /gsd park [id] Park a milestone — skip without deleting [reason]",
|
|
81
89
|
" /gsd unpark [id] Reactivate a parked milestone",
|
|
@@ -84,6 +92,15 @@ export function showHelp(ctx, args = "") {
|
|
|
84
92
|
" /gsd knowledge <type> <text> Add rule, pattern, or lesson to KNOWLEDGE.md",
|
|
85
93
|
" /gsd codebase [generate|update|stats] Manage the CODEBASE.md cache used in prompt context",
|
|
86
94
|
"",
|
|
95
|
+
"SHIPPING & BACKLOG",
|
|
96
|
+
" /gsd ship Create a PR from milestone artifacts [--dry-run|--draft|--base|--force]",
|
|
97
|
+
" /gsd do <text> Route freeform text to the right GSD command",
|
|
98
|
+
" /gsd session-report Show session cost, tokens, and work summary [--json|--save]",
|
|
99
|
+
" /gsd backlog Manage backlog items [add|promote|remove|list]",
|
|
100
|
+
" /gsd pr-branch Create a clean PR branch filtering .gsd/ commits [--dry-run|--name]",
|
|
101
|
+
" /gsd add-tests Generate tests for completed slices",
|
|
102
|
+
" /gsd scan Rapid codebase assessment [--focus tech|arch|quality|concerns|tech+arch]",
|
|
103
|
+
"",
|
|
87
104
|
"SETUP & CONFIGURATION",
|
|
88
105
|
" /gsd onboarding Re-run setup wizard [--resume|--reset|--step <name>]",
|
|
89
106
|
" /gsd setup Configuration hub [llm|model|search|remote|keys|prefs|onboarding]",
|
|
@@ -96,18 +113,22 @@ export function showHelp(ctx, args = "") {
|
|
|
96
113
|
" /gsd config (deprecated) Set tool API keys — use /gsd keys instead",
|
|
97
114
|
" /gsd show-config Show effective configuration (models, routing, toggles)",
|
|
98
115
|
" /gsd hooks Show post-unit hook configuration",
|
|
116
|
+
" /gsd run-hook Manually trigger a specific hook",
|
|
117
|
+
" /gsd skill-health Skill lifecycle dashboard",
|
|
99
118
|
" /gsd extensions Manage extensions [list|enable|disable|info]",
|
|
100
119
|
" /gsd fast Toggle OpenAI service tier [on|off|flex|status]",
|
|
101
120
|
" /gsd mcp MCP server status and connectivity [status|check <server>|init [dir]]",
|
|
102
121
|
"",
|
|
103
122
|
"MAINTENANCE",
|
|
104
123
|
" /gsd doctor Diagnose and repair .gsd/ state [audit|fix|heal] [scope]",
|
|
124
|
+
" /gsd forensics Examine execution logs and post-mortem analysis",
|
|
105
125
|
" /gsd export Export milestone/slice results [--json|--markdown|--html] [--all]",
|
|
106
126
|
" /gsd cleanup Remove merged branches or snapshots [branches|snapshots]",
|
|
107
127
|
" /gsd migrate Migrate .planning/ (v1) to .gsd/ (v2) format",
|
|
108
128
|
" /gsd remote Control remote auto-mode [slack|discord|status|disconnect]",
|
|
109
129
|
" /gsd inspect Show SQLite DB diagnostics (schema, row counts, recent entries)",
|
|
110
130
|
" /gsd update Update GSD to the latest version via npm",
|
|
131
|
+
" /gsd language Set or clear the global response language [off|clear|<language>]",
|
|
111
132
|
];
|
|
112
133
|
const full = ["full", "--full", "all"].includes(args.trim().toLowerCase());
|
|
113
134
|
ctx.ui.notify((full ? fullLines : summaryLines).join("\n"), "info");
|
|
@@ -10,6 +10,7 @@
|
|
|
10
10
|
* /gsd mcp init [dir] — Write project-local GSD workflow MCP config
|
|
11
11
|
*/
|
|
12
12
|
import { existsSync, readFileSync } from "node:fs";
|
|
13
|
+
import { homedir } from "node:os";
|
|
13
14
|
import { join, resolve } from "node:path";
|
|
14
15
|
import { ensureProjectWorkflowMcpConfig } from "./mcp-project-config.js";
|
|
15
16
|
export function formatMcpInitResult(status, configPath, targetPath) {
|
|
@@ -33,6 +34,7 @@ function readMcpConfigs() {
|
|
|
33
34
|
const configPaths = [
|
|
34
35
|
join(process.cwd(), ".mcp.json"),
|
|
35
36
|
join(process.cwd(), ".gsd", "mcp.json"),
|
|
37
|
+
join(process.env.GSD_HOME || join(homedir(), ".gsd"), "mcp.json"),
|
|
36
38
|
];
|
|
37
39
|
for (const configPath of configPaths) {
|
|
38
40
|
try {
|
|
@@ -77,7 +79,7 @@ export function formatMcpStatusReport(servers) {
|
|
|
77
79
|
return [
|
|
78
80
|
"No MCP servers configured.",
|
|
79
81
|
"",
|
|
80
|
-
"Add servers to .mcp.json or .gsd/mcp.json to enable MCP integrations.",
|
|
82
|
+
"Add servers to .mcp.json, .gsd/mcp.json, or $GSD_HOME/mcp.json (default: ~/.gsd/mcp.json) to enable MCP integrations.",
|
|
81
83
|
"Tip: run /gsd mcp init . to write the local GSD workflow MCP config.",
|
|
82
84
|
"See: https://modelcontextprotocol.io/quickstart",
|
|
83
85
|
].join("\n");
|
|
@@ -1481,6 +1481,13 @@ async function configureAdvanced(ctx, prefs) {
|
|
|
1481
1481
|
const tokenCost = await promptBoolean(ctx, "Show token cost in footer", prefs.show_token_cost, false);
|
|
1482
1482
|
if (tokenCost !== undefined)
|
|
1483
1483
|
prefs.show_token_cost = tokenCost;
|
|
1484
|
+
const minRequestInterval = await promptInteger(ctx, "Minimum interval between auto-mode LLM requests (ms, 0 to disable)", prefs.min_request_interval_ms, "0");
|
|
1485
|
+
if (minRequestInterval === "clear") {
|
|
1486
|
+
delete prefs.min_request_interval_ms;
|
|
1487
|
+
}
|
|
1488
|
+
else if (minRequestInterval !== undefined) {
|
|
1489
|
+
prefs.min_request_interval_ms = minRequestInterval;
|
|
1490
|
+
}
|
|
1484
1491
|
const widget = await promptEnum(ctx, "Auto-mode widget display", prefs.widget_mode, ["full", "small", "min", "off"], "full");
|
|
1485
1492
|
if (widget !== undefined)
|
|
1486
1493
|
prefs.widget_mode = widget;
|
|
@@ -1668,8 +1675,10 @@ export function serializePreferencesToFrontmatter(prefs) {
|
|
|
1668
1675
|
"budget_ceiling", "budget_enforcement", "context_pause_threshold",
|
|
1669
1676
|
"notifications", "cmux", "remote_questions", "git",
|
|
1670
1677
|
"stale_commit_threshold_minutes",
|
|
1678
|
+
"min_request_interval_ms",
|
|
1671
1679
|
"post_unit_hooks", "pre_dispatch_hooks",
|
|
1672
|
-
"dynamic_routing", "
|
|
1680
|
+
"dynamic_routing", "disabled_model_providers", "uok", "token_profile",
|
|
1681
|
+
"service_tier", "flat_rate_providers",
|
|
1673
1682
|
"phases", "parallel", "slice_parallel",
|
|
1674
1683
|
"reactive_execution", "gate_evaluation",
|
|
1675
1684
|
"auto_visualize", "auto_report",
|
|
@@ -14,7 +14,7 @@ import { resolveMilestoneFile } from "./paths.js";
|
|
|
14
14
|
import { getAutoDashboardData } from "./auto.js";
|
|
15
15
|
import { getLedger, getProjectTotals, aggregateByPhase, aggregateBySlice, aggregateByModel, aggregateCacheHitRate, formatCost, formatTokenCount, formatCostProjection, } from "./metrics.js";
|
|
16
16
|
import { loadEffectiveGSDPreferences } from "./preferences.js";
|
|
17
|
-
import { getActiveWorktreeName } from "./worktree-
|
|
17
|
+
import { getActiveWorktreeName } from "./worktree-session-state.js";
|
|
18
18
|
import { getWorkerBatches, hasActiveWorkers } from "../subagent/worker-registry.js";
|
|
19
19
|
import { formatDuration, padRight, joinColumns, centerLine, fitColumns, STATUS_GLYPH, STATUS_COLOR } from "../shared/mod.js";
|
|
20
20
|
import { estimateTimeRemaining } from "./auto-dashboard.js";
|
|
@@ -126,6 +126,8 @@ Setting `prefer_skills: []` does **not** disable skill discovery — it just mea
|
|
|
126
126
|
- `idle_timeout_minutes`: minutes of inactivity before the supervisor intervenes (default: 10).
|
|
127
127
|
- `hard_timeout_minutes`: minutes before the supervisor forces termination (default: 30).
|
|
128
128
|
|
|
129
|
+
- `min_request_interval_ms`: number — minimum integer milliseconds between auto-mode LLM request dispatches. Non-integer values are rounded down (e.g., `1000.9 → 1000`). Use this to proactively slow auto-mode on rate-limited providers and reduce 429 errors. Set to `0` to disable. Default: `0` (disabled).
|
|
130
|
+
|
|
129
131
|
- `git`: configures GSD's git behavior. All fields are optional — omit any to use defaults. Keys:
|
|
130
132
|
- `auto_push`: boolean — automatically push commits to the remote after committing. Default: `false`.
|
|
131
133
|
- `push_branches`: boolean — push the milestone branch to the remote after commits. Default: `false`.
|
|
@@ -193,6 +195,8 @@ Setting `prefer_skills: []` does **not** disable skill discovery — it just mea
|
|
|
193
195
|
- `hooks`: boolean — enable routing hooks. Default: `true`.
|
|
194
196
|
- `capability_routing`: boolean — enable capability-profile scoring for model selection within a tier. Requires `enabled: true`. Default: `false`.
|
|
195
197
|
|
|
198
|
+
- `disabled_model_providers`: string[] — provider IDs to hide from model selection and routing (for example `["google-gemini-cli"]`). This only affects model availability (`/model`, auto-model selection, routing); it does not disable tool auth flows like `google_search`.
|
|
199
|
+
|
|
196
200
|
- `uok`: Unified Orchestration Kernel controls. Keys:
|
|
197
201
|
- `enabled`: boolean — enable kernel wrappers and contract observers. Default: `true`.
|
|
198
202
|
- `legacy_fallback.enabled`: boolean — emergency release fallback that forces legacy orchestration behavior even when `uok.enabled` is `true`. Default: `false`.
|
|
@@ -2,7 +2,7 @@ import { existsSync, lstatSync, readdirSync, readFileSync, realpathSync, rmSync,
|
|
|
2
2
|
import { basename, dirname, join } from "node:path";
|
|
3
3
|
import { cleanNumberedGsdVariants } from "./repo-identity.js";
|
|
4
4
|
import { milestonesDir, gsdRoot, resolveGsdRootFile } from "./paths.js";
|
|
5
|
-
import { deriveState } from "./state.js";
|
|
5
|
+
import { deriveState, isGhostMilestone, isReusableGhostMilestone } from "./state.js";
|
|
6
6
|
import { saveFile } from "./files.js";
|
|
7
7
|
import { nativeIsRepo, nativeForEachRef, nativeUpdateRef } from "./native-git-bridge.js";
|
|
8
8
|
import { readCrashLock, isLockProcessAlive, clearLock } from "./crash-recovery.js";
|
|
@@ -10,6 +10,7 @@ import { ensureGitignore, isGsdGitignored } from "./gitignore.js";
|
|
|
10
10
|
import { readAllSessionStatuses, isSessionStale, removeSessionStatus } from "./session-status-io.js";
|
|
11
11
|
import { recoverFailedMigration } from "./migrate-external.js";
|
|
12
12
|
import { splitCompletedKey } from "./forensics.js";
|
|
13
|
+
import { findMilestoneIds } from "./milestone-ids.js";
|
|
13
14
|
export async function checkRuntimeHealth(basePath, issues, fixesApplied, shouldFix) {
|
|
14
15
|
const root = gsdRoot(basePath);
|
|
15
16
|
// ── Stale crash lock ──────────────────────────────────────────────────
|
|
@@ -570,6 +571,43 @@ export async function checkRuntimeHealth(basePath, issues, fixesApplied, shouldF
|
|
|
570
571
|
catch {
|
|
571
572
|
// Non-fatal — snapshot ref check failed
|
|
572
573
|
}
|
|
574
|
+
// ── Orphan milestone directories (#4996) ──────────────────────────────
|
|
575
|
+
// Walk every milestone ID on disk. Any dir that has no DB row, no worktree,
|
|
576
|
+
// and no content files is an orphaned stub — it skews nextMilestoneId and
|
|
577
|
+
// was likely created by ensurePreconditions or showHeadlessMilestoneCreation
|
|
578
|
+
// for a phantom forward-reference. Surface as a fixable warning.
|
|
579
|
+
try {
|
|
580
|
+
const milestoneIds = findMilestoneIds(basePath);
|
|
581
|
+
const hasDbFile = existsSync(join(root, "gsd.db"));
|
|
582
|
+
for (const mid of milestoneIds) {
|
|
583
|
+
const isOrphan = isReusableGhostMilestone(basePath, mid)
|
|
584
|
+
|| (!hasDbFile && isGhostMilestone(basePath, mid));
|
|
585
|
+
if (isOrphan) {
|
|
586
|
+
issues.push({
|
|
587
|
+
severity: "warning",
|
|
588
|
+
code: "orphan_milestone_dir",
|
|
589
|
+
scope: "milestone",
|
|
590
|
+
unitId: mid,
|
|
591
|
+
message: `Orphan milestone directory: ${mid} — directory exists on disk with no DB row, no worktree, and no content files. This stub skews milestone ID generation and should be removed.`,
|
|
592
|
+
file: `.gsd/milestones/${mid}`,
|
|
593
|
+
fixable: true,
|
|
594
|
+
});
|
|
595
|
+
if (shouldFix("orphan_milestone_dir")) {
|
|
596
|
+
try {
|
|
597
|
+
const orphanPath = join(milestonesDir(basePath), mid);
|
|
598
|
+
rmSync(orphanPath, { recursive: true, force: true });
|
|
599
|
+
fixesApplied.push(`removed orphan milestone directory: ${mid}`);
|
|
600
|
+
}
|
|
601
|
+
catch {
|
|
602
|
+
// Non-fatal — leave for manual cleanup
|
|
603
|
+
}
|
|
604
|
+
}
|
|
605
|
+
}
|
|
606
|
+
}
|
|
607
|
+
}
|
|
608
|
+
catch {
|
|
609
|
+
// Non-fatal — orphan milestone directory check failed
|
|
610
|
+
}
|
|
573
611
|
}
|
|
574
612
|
/**
|
|
575
613
|
* Build STATE.md markdown content from derived state.
|
|
@@ -34,7 +34,7 @@ const NETWORK_RE = /network|ECONNRESET|ETIMEDOUT|ECONNREFUSED|socket hang up|fet
|
|
|
34
34
|
// Context overflow errors (context window/length exceeded) should be treated as server-class
|
|
35
35
|
// transient errors so auto-mode can retry with reduced budget or fall back to a larger-context model.
|
|
36
36
|
// See: https://github.com/gsd-build/gsd-2/issues/4528
|
|
37
|
-
const SERVER_RE = /internal server error|500|502|503|overloaded|server_error|api_error|service.?unavailable|context (?:window|length) exceed|context window exceed/i;
|
|
37
|
+
const SERVER_RE = /internal(?: server)?[ _-]?error|500|502|503|overloaded|server_error|api_error|service.?unavailable|context (?:window|length) exceed|context window exceed/i;
|
|
38
38
|
// ECONNRESET/ECONNREFUSED are in NETWORK_RE (same-model retry first).
|
|
39
39
|
const CONNECTION_RE = /terminated|connection.?(?:refused|error)|other side closed|EPIPE|network.?(?:is\s+)?unavailable|stream_exhausted(?:_without_result)?/i;
|
|
40
40
|
// Catch-all for V8 JSON.parse errors: all modern variants end with "in JSON at position \d+".
|
|
@@ -649,7 +649,7 @@ function detectMissingArtifacts(completedKeys, basePath, activeMilestone, anomal
|
|
|
649
649
|
* the forensics memory-bloat guard in forensics-journal.test.ts — per-event
|
|
650
650
|
* detail stays in the journal itself where the LLM can query it on demand.
|
|
651
651
|
*/
|
|
652
|
-
function detectWorktreeOrphans(summary, anomalies) {
|
|
652
|
+
export function detectWorktreeOrphans(summary, anomalies) {
|
|
653
653
|
// 1. Orphan aggregate — severity depends on reason. In-progress orphans are
|
|
654
654
|
// the #4761 consumer-side signal (live work sitting on an unmerged branch).
|
|
655
655
|
for (const [reason, count] of Object.entries(summary.orphansByReason)) {
|
|
@@ -663,7 +663,7 @@ function detectWorktreeOrphans(summary, anomalies) {
|
|
|
663
663
|
details: reason === "in-progress-unmerged"
|
|
664
664
|
? "Auto-mode exited without completing a milestone; live work sits on an unmerged milestone branch. Run `/gsd auto` to resume, or merge manually."
|
|
665
665
|
: reason === "complete-unmerged"
|
|
666
|
-
? "A completed milestone's branch was never merged back to main. Run `/gsd
|
|
666
|
+
? "A completed milestone's branch was never merged back to main. Run `/gsd doctor fix` to resolve."
|
|
667
667
|
: `Reason: ${reason}.`,
|
|
668
668
|
});
|
|
669
669
|
}
|
|
@@ -18,6 +18,7 @@ import { SLICE_BRANCH_RE, QUICK_BRANCH_RE, WORKFLOW_BRANCH_RE } from "./branch-p
|
|
|
18
18
|
import { nativeGetCurrentBranch, nativeDetectMainBranch, nativeBranchExists, nativeHasChanges, nativeAddAllWithExclusions, nativeHasStagedChanges, nativeCommit, nativeRmCached, nativeUpdateRef, nativeResetSoft, nativeCommitSubject, _resetHasChangesCache, } from "./native-git-bridge.js";
|
|
19
19
|
import { GSDError, GSD_MERGE_CONFLICT, GSD_GIT_ERROR } from "./errors.js";
|
|
20
20
|
import { getErrorMessage } from "./error-utils.js";
|
|
21
|
+
import { isInfrastructureError } from "./auto/infra-errors.js";
|
|
21
22
|
export const VALID_BRANCH_NAME = /^[a-zA-Z0-9_\-\/.]+$/;
|
|
22
23
|
/**
|
|
23
24
|
* Build a meaningful conventional commit message from task execution context.
|
|
@@ -775,6 +776,16 @@ function buildTurnSnapshotLabel(unitType, unitId) {
|
|
|
775
776
|
.replace(/-{2,}/g, "-")
|
|
776
777
|
.replace(/^[-/]+|[-/]+$/g, "") || "turn";
|
|
777
778
|
}
|
|
779
|
+
export function handleTurnGitActionError(action, err) {
|
|
780
|
+
if (isInfrastructureError(err)) {
|
|
781
|
+
throw err;
|
|
782
|
+
}
|
|
783
|
+
return {
|
|
784
|
+
action,
|
|
785
|
+
status: "failed",
|
|
786
|
+
error: getErrorMessage(err),
|
|
787
|
+
};
|
|
788
|
+
}
|
|
778
789
|
export function runTurnGitAction(args) {
|
|
779
790
|
try {
|
|
780
791
|
// Force fresh working-tree status per turn; nativeHasChanges caches briefly.
|
|
@@ -806,11 +817,7 @@ export function runTurnGitAction(args) {
|
|
|
806
817
|
};
|
|
807
818
|
}
|
|
808
819
|
catch (err) {
|
|
809
|
-
return
|
|
810
|
-
action: args.action,
|
|
811
|
-
status: "failed",
|
|
812
|
-
error: getErrorMessage(err),
|
|
813
|
-
};
|
|
820
|
+
return handleTurnGitActionError(args.action, err);
|
|
814
821
|
}
|
|
815
822
|
}
|
|
816
823
|
// ─── Commit Type Inference ─────────────────────────────────────────────────
|
|
@@ -1321,6 +1321,15 @@ export function checkpointDatabase() {
|
|
|
1321
1321
|
}
|
|
1322
1322
|
}
|
|
1323
1323
|
let _txDepth = 0;
|
|
1324
|
+
/**
|
|
1325
|
+
* Whether the current call is running inside an active SQLite transaction.
|
|
1326
|
+
* Statement-time recovery paths (e.g. VACUUM retry on a malformed memory
|
|
1327
|
+
* store) MUST gate on this — SQLite refuses VACUUM inside a transaction
|
|
1328
|
+
* and would mask the original error with a secondary "cannot VACUUM" throw.
|
|
1329
|
+
*/
|
|
1330
|
+
export function isInTransaction() {
|
|
1331
|
+
return _txDepth > 0;
|
|
1332
|
+
}
|
|
1324
1333
|
export function transaction(fn) {
|
|
1325
1334
|
if (!currentDb)
|
|
1326
1335
|
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
@@ -1335,8 +1344,8 @@ export function transaction(fn) {
|
|
|
1335
1344
|
_txDepth--;
|
|
1336
1345
|
}
|
|
1337
1346
|
}
|
|
1338
|
-
_txDepth++;
|
|
1339
1347
|
currentDb.exec("BEGIN");
|
|
1348
|
+
_txDepth++;
|
|
1340
1349
|
try {
|
|
1341
1350
|
const result = fn();
|
|
1342
1351
|
currentDb.exec("COMMIT");
|
|
@@ -1369,8 +1378,8 @@ export function readTransaction(fn) {
|
|
|
1369
1378
|
_txDepth--;
|
|
1370
1379
|
}
|
|
1371
1380
|
}
|
|
1372
|
-
_txDepth++;
|
|
1373
1381
|
currentDb.exec("BEGIN DEFERRED");
|
|
1382
|
+
_txDepth++;
|
|
1374
1383
|
try {
|
|
1375
1384
|
const result = fn();
|
|
1376
1385
|
currentDb.exec("COMMIT");
|
|
@@ -33,7 +33,9 @@ import { showProjectInit, offerMigration } from "./init-wizard.js";
|
|
|
33
33
|
import { validateDirectory } from "./validate-directory.js";
|
|
34
34
|
import { showConfirm } from "../shared/tui.js";
|
|
35
35
|
import { debugLog } from "./debug-logger.js";
|
|
36
|
-
import { findMilestoneIds,
|
|
36
|
+
import { findMilestoneIds, clearReservedMilestoneIds } from "./milestone-ids.js";
|
|
37
|
+
import { nextMilestoneIdReserved } from "./milestone-id-reservation.js";
|
|
38
|
+
export { nextMilestoneIdReserved } from "./milestone-id-reservation.js";
|
|
37
39
|
import { parkMilestone, discardMilestone } from "./milestone-actions.js";
|
|
38
40
|
import { selectAndApplyModel } from "./auto-model-selection.js";
|
|
39
41
|
import { DISCUSS_TOOLS_ALLOWLIST } from "./constants.js";
|
|
@@ -43,18 +45,6 @@ import { runPreparation, formatCodebaseBrief, formatPriorContextBrief, } from ".
|
|
|
43
45
|
export { MILESTONE_ID_RE, generateMilestoneSuffix, nextMilestoneId, extractMilestoneSeq, parseMilestoneId, milestoneIdSort, maxMilestoneNum, findMilestoneIds, reserveMilestoneId, claimReservedId, getReservedMilestoneIds, clearReservedMilestoneIds, } from "./milestone-ids.js";
|
|
44
46
|
export { showQueue, handleQueueReorder, showQueueAdd, buildExistingMilestonesContext, } from "./guided-flow-queue.js";
|
|
45
47
|
import { logWarning } from "./workflow-logger.js";
|
|
46
|
-
// ─── ID Generation with Reservation ─────────────────────────────────────────
|
|
47
|
-
/**
|
|
48
|
-
* Generate the next milestone ID, accounting for reserved IDs, and reserve it.
|
|
49
|
-
* Ensures any preview ID shown in the UI matches what `gsd_milestone_generate_id`
|
|
50
|
-
* will later return.
|
|
51
|
-
*/
|
|
52
|
-
function nextMilestoneIdReserved(existingIds, uniqueEnabled) {
|
|
53
|
-
const allIds = [...new Set([...existingIds, ...getReservedMilestoneIds()])];
|
|
54
|
-
const id = nextMilestoneId(allIds, uniqueEnabled);
|
|
55
|
-
reserveMilestoneId(id);
|
|
56
|
-
return id;
|
|
57
|
-
}
|
|
58
48
|
function needsPlanV2Gate(state) {
|
|
59
49
|
return state.phase === "executing"
|
|
60
50
|
|| state.phase === "summarizing"
|
|
@@ -675,13 +665,17 @@ export async function showHeadlessMilestoneCreation(ctx, pi, basePath, seedConte
|
|
|
675
665
|
clearReservedMilestoneIds();
|
|
676
666
|
// Ensure .gsd/ is bootstrapped
|
|
677
667
|
bootstrapGsdProject(basePath);
|
|
668
|
+
const { ensureDbOpen } = await import("./bootstrap/dynamic-tools.js");
|
|
669
|
+
await ensureDbOpen(basePath);
|
|
678
670
|
// Generate next milestone ID
|
|
679
671
|
const existingIds = findMilestoneIds(basePath);
|
|
680
672
|
const prefs = loadEffectiveGSDPreferences();
|
|
681
|
-
const nextId = nextMilestoneIdReserved(existingIds, prefs?.preferences?.unique_milestone_ids ?? false);
|
|
682
|
-
//
|
|
683
|
-
|
|
684
|
-
|
|
673
|
+
const nextId = nextMilestoneIdReserved(existingIds, prefs?.preferences?.unique_milestone_ids ?? false, basePath);
|
|
674
|
+
// Fix #4996: Do NOT pre-create the milestone directory here.
|
|
675
|
+
// atomicWriteAsync (used by all artifact writers) calls mkdir lazily before
|
|
676
|
+
// each write, so every path through saveArtifactToDb / saveFile is already
|
|
677
|
+
// lazy-mkdir-safe. Pre-creating the dir before the discuss flow runs leaves
|
|
678
|
+
// an orphan stub if discuss is abandoned — that stub later skews nextMilestoneId.
|
|
685
679
|
// Build and dispatch the headless discuss prompt
|
|
686
680
|
const prompt = buildHeadlessDiscussPrompt(nextId, seedContext, basePath);
|
|
687
681
|
// Set pending auto start (auto-mode triggers on "Milestone X ready." via checkAutoStartAfterDiscuss)
|
|
@@ -865,9 +859,11 @@ export async function showDiscuss(ctx, pi, basePath) {
|
|
|
865
859
|
}), "gsd-discuss", ctx, "discuss-milestone");
|
|
866
860
|
}
|
|
867
861
|
else if (choice === "skip_milestone") {
|
|
862
|
+
const { ensureDbOpen } = await import("./bootstrap/dynamic-tools.js");
|
|
863
|
+
await ensureDbOpen(basePath);
|
|
868
864
|
const milestoneIds = findMilestoneIds(basePath);
|
|
869
865
|
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
870
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
866
|
+
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds, basePath);
|
|
871
867
|
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: false, createdAt: Date.now() });
|
|
872
868
|
await dispatchWorkflow(pi, await prepareAndBuildDiscussPrompt(ctx, pi, nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
873
869
|
}
|
|
@@ -1223,7 +1219,7 @@ async function handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneT
|
|
|
1223
1219
|
if (choice === "skip") {
|
|
1224
1220
|
const milestoneIds = findMilestoneIds(basePath);
|
|
1225
1221
|
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
1226
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
1222
|
+
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds, basePath);
|
|
1227
1223
|
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: stepMode, createdAt: Date.now() });
|
|
1228
1224
|
await dispatchWorkflow(pi, await prepareAndBuildDiscussPrompt(ctx, pi, nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
1229
1225
|
return true;
|
|
@@ -1291,6 +1287,10 @@ export async function showSmartEntry(ctx, pi, basePath, options) {
|
|
|
1291
1287
|
// ── Ensure .gitignore has baseline patterns ──────────────────────────
|
|
1292
1288
|
ensureGitignore(basePath);
|
|
1293
1289
|
untrackRuntimeFiles(basePath);
|
|
1290
|
+
{
|
|
1291
|
+
const { ensureDbOpen } = await import("./bootstrap/dynamic-tools.js");
|
|
1292
|
+
await ensureDbOpen(basePath);
|
|
1293
|
+
}
|
|
1294
1294
|
// ── Self-heal stale runtime records from crashed auto-mode sessions ──
|
|
1295
1295
|
selfHealRuntimeRecords(basePath, ctx);
|
|
1296
1296
|
const interrupted = await assessInterruptedSession(basePath);
|
|
@@ -1388,7 +1388,7 @@ export async function showSmartEntry(ctx, pi, basePath, options) {
|
|
|
1388
1388
|
}
|
|
1389
1389
|
}
|
|
1390
1390
|
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
1391
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
1391
|
+
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds, basePath);
|
|
1392
1392
|
const isFirst = milestoneIds.length === 0;
|
|
1393
1393
|
if (isFirst) {
|
|
1394
1394
|
// First ever — skip wizard, just ask directly
|
|
@@ -1446,7 +1446,7 @@ export async function showSmartEntry(ctx, pi, basePath, options) {
|
|
|
1446
1446
|
if (choice === "new_milestone") {
|
|
1447
1447
|
const milestoneIds = findMilestoneIds(basePath);
|
|
1448
1448
|
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
1449
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
1449
|
+
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds, basePath);
|
|
1450
1450
|
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: stepMode, createdAt: Date.now() });
|
|
1451
1451
|
await dispatchWorkflow(pi, await prepareAndBuildDiscussPrompt(ctx, pi, nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
1452
1452
|
}
|
|
@@ -1510,7 +1510,7 @@ export async function showSmartEntry(ctx, pi, basePath, options) {
|
|
|
1510
1510
|
else if (choice === "skip_milestone") {
|
|
1511
1511
|
const milestoneIds = findMilestoneIds(basePath);
|
|
1512
1512
|
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
1513
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
1513
|
+
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds, basePath);
|
|
1514
1514
|
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: stepMode, createdAt: Date.now() });
|
|
1515
1515
|
await dispatchWorkflow(pi, await prepareAndBuildDiscussPrompt(ctx, pi, nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
1516
1516
|
}
|
|
@@ -1600,7 +1600,7 @@ export async function showSmartEntry(ctx, pi, basePath, options) {
|
|
|
1600
1600
|
else if (choice === "skip_milestone") {
|
|
1601
1601
|
const milestoneIds = findMilestoneIds(basePath);
|
|
1602
1602
|
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
1603
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
1603
|
+
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds, basePath);
|
|
1604
1604
|
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: stepMode, createdAt: Date.now() });
|
|
1605
1605
|
await dispatchWorkflow(pi, await prepareAndBuildDiscussPrompt(ctx, pi, nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
1606
1606
|
}
|
|
@@ -2,8 +2,9 @@
|
|
|
2
2
|
//
|
|
3
3
|
// Storage layer for auto-learned project memories. Follows context-store.ts patterns.
|
|
4
4
|
// All functions degrade gracefully: return empty results when DB unavailable, never throw.
|
|
5
|
-
import { isDbAvailable, _getAdapter, transaction, insertMemoryRow, rewriteMemoryId, updateMemoryContentRow, incrementMemoryHitCount, supersedeMemoryRow, markMemoryUnitProcessed, decayMemoriesBefore, supersedeLowestRankedMemories, deleteMemoryEmbedding, deleteMemoryRelationsFor, } from './gsd-db.js';
|
|
5
|
+
import { isDbAvailable, _getAdapter, transaction, isInTransaction, insertMemoryRow, rewriteMemoryId, updateMemoryContentRow, incrementMemoryHitCount, supersedeMemoryRow, markMemoryUnitProcessed, decayMemoriesBefore, supersedeLowestRankedMemories, deleteMemoryEmbedding, deleteMemoryRelationsFor, } from './gsd-db.js';
|
|
6
6
|
import { createMemoryRelation, isValidRelation } from './memory-relations.js';
|
|
7
|
+
import { logWarning } from './workflow-logger.js';
|
|
7
8
|
// ─── Category Display Order ─────────────────────────────────────────────────
|
|
8
9
|
const CATEGORY_PRIORITY = {
|
|
9
10
|
gotcha: 0,
|
|
@@ -367,7 +368,13 @@ export function nextMemoryId() {
|
|
|
367
368
|
* Insert a new memory with a race-safe auto-assigned ID.
|
|
368
369
|
* Uses AUTOINCREMENT seq to derive the ID after insert, avoiding
|
|
369
370
|
* the read-then-write race in concurrent scenarios (e.g. worktrees).
|
|
370
|
-
* Returns the assigned ID, or null
|
|
371
|
+
* Returns the assigned ID, or null when the DB is unavailable.
|
|
372
|
+
*
|
|
373
|
+
* Throws on genuine SQL errors (corruption, missing tables, constraint
|
|
374
|
+
* violations) so callers can surface the underlying message instead of
|
|
375
|
+
* collapsing the failure to a generic "create_failed". See issue #4967 —
|
|
376
|
+
* the previous bare-catch swallowed "database disk image is malformed"
|
|
377
|
+
* errors, leaving the memory subsystem broken without any signal.
|
|
371
378
|
*/
|
|
372
379
|
export function createMemory(fields) {
|
|
373
380
|
if (!isDbAvailable())
|
|
@@ -376,35 +383,57 @@ export function createMemory(fields) {
|
|
|
376
383
|
if (!adapter)
|
|
377
384
|
return null;
|
|
378
385
|
try {
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
return realId;
|
|
403
|
-
}
|
|
404
|
-
catch {
|
|
405
|
-
return null;
|
|
386
|
+
return transaction(() => doCreateMemory(adapter, fields));
|
|
387
|
+
}
|
|
388
|
+
catch (err) {
|
|
389
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
390
|
+
// Targeted recovery: a malformed memory store can sometimes be rebuilt
|
|
391
|
+
// by VACUUM. Skip when inside a transaction — SQLite refuses VACUUM
|
|
392
|
+
// there and a secondary throw would mask the real fault.
|
|
393
|
+
if (message.toLowerCase().includes('malformed') && !isInTransaction()) {
|
|
394
|
+
try {
|
|
395
|
+
adapter.prepare('VACUUM').run();
|
|
396
|
+
const recoveryMessage = 'recovered malformed memory store via VACUUM';
|
|
397
|
+
process.stderr.write(`memory-store: ${recoveryMessage}\n`);
|
|
398
|
+
logWarning('memory-store', recoveryMessage);
|
|
399
|
+
return transaction(() => doCreateMemory(adapter, fields));
|
|
400
|
+
}
|
|
401
|
+
catch (retryErr) {
|
|
402
|
+
const retryMsg = retryErr instanceof Error ? retryErr.message : String(retryErr);
|
|
403
|
+
logWarning('memory-store', `VACUUM recovery for memory store failed: ${retryMsg}`);
|
|
404
|
+
// Surface the *original* malformed error — it's the actionable signal.
|
|
405
|
+
throw err;
|
|
406
|
+
}
|
|
407
|
+
}
|
|
408
|
+
throw err;
|
|
406
409
|
}
|
|
407
410
|
}
|
|
411
|
+
function doCreateMemory(adapter, fields) {
|
|
412
|
+
const now = new Date().toISOString();
|
|
413
|
+
// Insert with a temporary placeholder ID — seq is auto-assigned
|
|
414
|
+
const placeholder = `_TMP_${Date.now()}_${Math.random().toString(36).slice(2, 8)}`;
|
|
415
|
+
insertMemoryRow({
|
|
416
|
+
id: placeholder,
|
|
417
|
+
category: fields.category,
|
|
418
|
+
content: fields.content,
|
|
419
|
+
confidence: fields.confidence ?? 0.8,
|
|
420
|
+
sourceUnitType: fields.source_unit_type ?? null,
|
|
421
|
+
sourceUnitId: fields.source_unit_id ?? null,
|
|
422
|
+
createdAt: now,
|
|
423
|
+
updatedAt: now,
|
|
424
|
+
scope: fields.scope ?? 'project',
|
|
425
|
+
tags: fields.tags ?? [],
|
|
426
|
+
structuredFields: fields.structuredFields ?? null,
|
|
427
|
+
});
|
|
428
|
+
// Derive the real ID from the assigned seq (SELECT is still fine via adapter)
|
|
429
|
+
const row = adapter.prepare('SELECT seq FROM memories WHERE id = :id').get({ ':id': placeholder });
|
|
430
|
+
if (!row)
|
|
431
|
+
return placeholder; // fallback — should not happen
|
|
432
|
+
const seq = row['seq'];
|
|
433
|
+
const realId = `MEM${String(seq).padStart(3, '0')}`;
|
|
434
|
+
rewriteMemoryId(placeholder, realId);
|
|
435
|
+
return realId;
|
|
436
|
+
}
|
|
408
437
|
/**
|
|
409
438
|
* Update a memory's content and optionally its confidence.
|
|
410
439
|
*/
|
|
@@ -591,8 +620,14 @@ export function applyMemoryActions(actions, unitType, unitId) {
|
|
|
591
620
|
enforceMemoryCap();
|
|
592
621
|
});
|
|
593
622
|
}
|
|
594
|
-
catch {
|
|
595
|
-
//
|
|
623
|
+
catch (err) {
|
|
624
|
+
// Non-fatal — the transaction has rolled back. We log a warning so a
|
|
625
|
+
// degraded memory subsystem (e.g. malformed store, missing tables) is
|
|
626
|
+
// visible to forensics instead of silently dropping every CREATE — see
|
|
627
|
+
// issue #4967, where this swallow combined with createMemory's bare
|
|
628
|
+
// catch hid SQLite corruption from the auto-mode flow entirely.
|
|
629
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
630
|
+
logWarning('memory-store', `applyMemoryActions failed (memory subsystem degraded): ${message}`);
|
|
596
631
|
}
|
|
597
632
|
}
|
|
598
633
|
// ─── LINK action ────────────────────────────────────────────────────────────
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { isDbAvailable, getAllMilestones } from "./gsd-db.js";
|
|
2
|
+
import { getReservedMilestoneIds, milestoneIdSort, nextMilestoneId, reserveMilestoneId, } from "./milestone-ids.js";
|
|
3
|
+
import { isReusableGhostMilestone } from "./state.js";
|
|
4
|
+
function getDatabaseMilestoneIds() {
|
|
5
|
+
if (!isDbAvailable())
|
|
6
|
+
return [];
|
|
7
|
+
return getAllMilestones().map((milestone) => milestone.id);
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Generate the next milestone ID, accounting for DB rows and in-process
|
|
11
|
+
* reservations, and reserve it.
|
|
12
|
+
*/
|
|
13
|
+
export function nextMilestoneIdReserved(existingIds, uniqueEnabled, basePath) {
|
|
14
|
+
const reservedIds = getReservedMilestoneIds();
|
|
15
|
+
const allIds = [
|
|
16
|
+
...new Set([
|
|
17
|
+
...existingIds,
|
|
18
|
+
...reservedIds,
|
|
19
|
+
...getDatabaseMilestoneIds(),
|
|
20
|
+
]),
|
|
21
|
+
];
|
|
22
|
+
if (basePath) {
|
|
23
|
+
const sorted = [...allIds].sort(milestoneIdSort);
|
|
24
|
+
for (const candidate of sorted) {
|
|
25
|
+
if (reservedIds.has(candidate))
|
|
26
|
+
continue;
|
|
27
|
+
if (isReusableGhostMilestone(basePath, candidate)) {
|
|
28
|
+
reserveMilestoneId(candidate);
|
|
29
|
+
return candidate;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
const id = nextMilestoneId(allIds, uniqueEnabled);
|
|
34
|
+
reserveMilestoneId(id);
|
|
35
|
+
return id;
|
|
36
|
+
}
|