gsd-pi 2.75.0 → 2.76.0
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 +186 -149
- package/dist/claude-cli-check.d.ts +10 -0
- package/dist/claude-cli-check.js +13 -3
- package/dist/headless-events.d.ts +1 -1
- package/dist/headless-events.js +5 -2
- package/dist/headless.js +5 -6
- package/dist/onboarding.d.ts +20 -1
- package/dist/onboarding.js +99 -39
- package/dist/resources/extensions/ask-user-questions.js +17 -5
- package/dist/resources/extensions/claude-code-cli/models.js +9 -0
- package/dist/resources/extensions/claude-code-cli/readiness.js +12 -2
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +76 -4
- package/dist/resources/extensions/gsd/auto/detect-stuck.js +9 -0
- package/dist/resources/extensions/gsd/auto/loop.js +67 -4
- package/dist/resources/extensions/gsd/auto/phases.js +72 -47
- package/dist/resources/extensions/gsd/auto/resolve.js +1 -1
- package/dist/resources/extensions/gsd/auto/run-unit.js +10 -1
- package/dist/resources/extensions/gsd/auto/session.js +5 -0
- package/dist/resources/extensions/gsd/auto-artifact-paths.js +20 -0
- package/dist/resources/extensions/gsd/auto-dashboard.js +37 -8
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +8 -2
- package/dist/resources/extensions/gsd/auto-dispatch.js +120 -14
- package/dist/resources/extensions/gsd/auto-loop.js +1 -1
- package/dist/resources/extensions/gsd/auto-model-selection.js +14 -4
- package/dist/resources/extensions/gsd/auto-post-unit.js +10 -8
- package/dist/resources/extensions/gsd/auto-prompts.js +190 -46
- package/dist/resources/extensions/gsd/auto-recovery.js +57 -0
- package/dist/resources/extensions/gsd/auto-start.js +5 -3
- package/dist/resources/extensions/gsd/auto-verification.js +3 -3
- package/dist/resources/extensions/gsd/auto-worktree.js +71 -2
- package/dist/resources/extensions/gsd/auto.js +57 -25
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +8 -21
- package/dist/resources/extensions/gsd/bootstrap/db-tools.js +45 -23
- package/dist/resources/extensions/gsd/bootstrap/memory-tools.js +128 -0
- package/dist/resources/extensions/gsd/bootstrap/query-tools.js +29 -0
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +2 -0
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +22 -0
- package/dist/resources/extensions/gsd/bootstrap/system-context.js +17 -4
- package/dist/resources/extensions/gsd/commands/catalog.js +81 -9
- package/dist/resources/extensions/gsd/commands/handlers/core.js +64 -24
- package/dist/resources/extensions/gsd/commands/handlers/escalate.js +171 -0
- package/dist/resources/extensions/gsd/commands/handlers/onboarding.js +159 -0
- package/dist/resources/extensions/gsd/commands/handlers/ops.js +21 -0
- package/dist/resources/extensions/gsd/commands/handlers/workflow.js +228 -29
- package/dist/resources/extensions/gsd/commands-cmux.js +5 -2
- package/dist/resources/extensions/gsd/commands-config.js +5 -0
- package/dist/resources/extensions/gsd/commands-debug.js +388 -0
- package/dist/resources/extensions/gsd/commands-do.js +1 -0
- package/dist/resources/extensions/gsd/commands-extract-learnings.js +233 -75
- package/dist/resources/extensions/gsd/commands-handlers.js +21 -2
- package/dist/resources/extensions/gsd/commands-memory.js +462 -0
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +40 -12
- package/dist/resources/extensions/gsd/commands-scan.js +94 -0
- package/dist/resources/extensions/gsd/commands-workflow-templates.js +101 -2
- package/dist/resources/extensions/gsd/custom-workflow-engine.js +74 -54
- package/dist/resources/extensions/gsd/db-writer.js +1 -0
- package/dist/resources/extensions/gsd/debug-session-store.js +238 -0
- package/dist/resources/extensions/gsd/definition-loader.js +7 -0
- package/dist/resources/extensions/gsd/docs/preferences-reference.md +9 -9
- package/dist/resources/extensions/gsd/doctor-environment.js +2 -1
- package/dist/resources/extensions/gsd/doctor-git-checks.js +27 -3
- package/dist/resources/extensions/gsd/doctor-proactive.js +4 -1
- package/dist/resources/extensions/gsd/doctor-providers.js +48 -20
- package/dist/resources/extensions/gsd/doctor-runtime-checks.js +22 -4
- package/dist/resources/extensions/gsd/doctor.js +7 -1
- package/dist/resources/extensions/gsd/error-classifier.js +6 -3
- package/dist/resources/extensions/gsd/escalation.js +321 -0
- package/dist/resources/extensions/gsd/forensics.js +26 -29
- package/dist/resources/extensions/gsd/git-service.js +0 -1
- package/dist/resources/extensions/gsd/graph.js +26 -2
- package/dist/resources/extensions/gsd/gsd-db.js +490 -32
- package/dist/resources/extensions/gsd/health-widget-core.js +42 -14
- package/dist/resources/extensions/gsd/health-widget.js +7 -4
- package/dist/resources/extensions/gsd/init-wizard.js +86 -45
- package/dist/resources/extensions/gsd/markdown-renderer.js +5 -5
- package/dist/resources/extensions/gsd/memory-embeddings.js +219 -0
- package/dist/resources/extensions/gsd/memory-extractor.js +78 -27
- package/dist/resources/extensions/gsd/memory-ingest.js +218 -0
- package/dist/resources/extensions/gsd/memory-relations.js +189 -0
- package/dist/resources/extensions/gsd/memory-source-store.js +113 -0
- package/dist/resources/extensions/gsd/memory-store.js +299 -6
- package/dist/resources/extensions/gsd/metrics.js +1 -0
- package/dist/resources/extensions/gsd/model-cost-table.js +3 -1
- package/dist/resources/extensions/gsd/model-router.js +16 -6
- package/dist/resources/extensions/gsd/native-git-bridge.js +137 -5
- package/dist/resources/extensions/gsd/notification-overlay.js +7 -22
- package/dist/resources/extensions/gsd/notification-widget.js +24 -39
- package/dist/resources/extensions/gsd/notifications.js +4 -0
- package/dist/resources/extensions/gsd/onboarding-state.js +133 -0
- package/dist/resources/extensions/gsd/post-execution-checks.js +27 -11
- package/dist/resources/extensions/gsd/pre-execution-checks.js +105 -8
- package/dist/resources/extensions/gsd/preferences-models.js +1 -0
- package/dist/resources/extensions/gsd/preferences-types.js +2 -1
- package/dist/resources/extensions/gsd/preferences-validation.js +42 -8
- package/dist/resources/extensions/gsd/preferences.js +10 -10
- package/dist/resources/extensions/gsd/prompts/add-tests.md +1 -0
- package/dist/resources/extensions/gsd/prompts/complete-milestone.md +4 -1
- package/dist/resources/extensions/gsd/prompts/debug-diagnose.md +25 -0
- package/dist/resources/extensions/gsd/prompts/debug-session-manager.md +80 -0
- package/dist/resources/extensions/gsd/prompts/execute-task.md +13 -1
- package/dist/resources/extensions/gsd/prompts/plan-milestone.md +12 -0
- package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -0
- package/dist/resources/extensions/gsd/prompts/refine-slice.md +69 -0
- package/dist/resources/extensions/gsd/prompts/scan.md +79 -0
- package/dist/resources/extensions/gsd/prompts/workflow-oneshot.md +26 -0
- package/dist/resources/extensions/gsd/python-resolver.js +70 -0
- package/dist/resources/extensions/gsd/run-manager.js +37 -17
- package/dist/resources/extensions/gsd/setup-catalog.js +75 -0
- package/dist/resources/extensions/gsd/state.js +47 -3
- package/dist/resources/extensions/gsd/templates/PREFERENCES.md +7 -7
- package/dist/resources/extensions/gsd/tools/complete-task.js +80 -0
- package/dist/resources/extensions/gsd/tools/memory-tools.js +306 -0
- package/dist/resources/extensions/gsd/tools/plan-milestone.js +37 -12
- package/dist/resources/extensions/gsd/tools/plan-slice.js +5 -2
- package/dist/resources/extensions/gsd/tools/skip-slice.js +78 -0
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +14 -0
- package/dist/resources/extensions/gsd/uok/flags.js +7 -7
- package/dist/resources/extensions/gsd/uok/kernel.js +8 -3
- package/dist/resources/extensions/gsd/verification-gate.js +2 -1
- package/dist/resources/extensions/gsd/workflow-dispatch.js +64 -0
- package/dist/resources/extensions/gsd/workflow-install.js +327 -0
- package/dist/resources/extensions/gsd/workflow-manifest.js +8 -0
- package/dist/resources/extensions/gsd/workflow-mcp.js +1 -6
- package/dist/resources/extensions/gsd/workflow-plugins.js +346 -0
- package/dist/resources/extensions/gsd/workflow-projections.js +17 -15
- package/dist/resources/extensions/gsd/workflow-templates/accessibility-audit.md +88 -0
- package/dist/resources/extensions/gsd/workflow-templates/api-breaking-change.md +117 -0
- package/dist/resources/extensions/gsd/workflow-templates/bugfix.md +1 -0
- package/dist/resources/extensions/gsd/workflow-templates/changelog-gen.md +82 -0
- package/dist/resources/extensions/gsd/workflow-templates/ci-bootstrap.md +144 -0
- package/dist/resources/extensions/gsd/workflow-templates/dead-code.md +81 -0
- package/dist/resources/extensions/gsd/workflow-templates/dep-upgrade.md +1 -0
- package/dist/resources/extensions/gsd/workflow-templates/docs-sync.yaml +76 -0
- package/dist/resources/extensions/gsd/workflow-templates/env-audit.yaml +88 -0
- package/dist/resources/extensions/gsd/workflow-templates/full-project.md +1 -0
- package/dist/resources/extensions/gsd/workflow-templates/hotfix.md +1 -0
- package/dist/resources/extensions/gsd/workflow-templates/issue-triage.md +84 -0
- package/dist/resources/extensions/gsd/workflow-templates/observability-setup.md +133 -0
- package/dist/resources/extensions/gsd/workflow-templates/onboarding-check.md +74 -0
- package/dist/resources/extensions/gsd/workflow-templates/performance-audit.md +125 -0
- package/dist/resources/extensions/gsd/workflow-templates/pr-review.md +67 -0
- package/dist/resources/extensions/gsd/workflow-templates/pr-triage.md +83 -0
- package/dist/resources/extensions/gsd/workflow-templates/refactor.md +1 -0
- package/dist/resources/extensions/gsd/workflow-templates/registry.json +184 -0
- package/dist/resources/extensions/gsd/workflow-templates/release.md +118 -0
- package/dist/resources/extensions/gsd/workflow-templates/rename-symbol.yaml +99 -0
- package/dist/resources/extensions/gsd/workflow-templates/security-audit.md +1 -0
- package/dist/resources/extensions/gsd/workflow-templates/small-feature.md +1 -0
- package/dist/resources/extensions/gsd/workflow-templates/spike.md +1 -0
- package/dist/resources/extensions/gsd/workflow-templates/test-backfill.yaml +73 -0
- package/dist/resources/extensions/gsd/worktree-resolver.js +42 -1
- package/dist/resources/extensions/remote-questions/commands.js +380 -0
- package/dist/resources/extensions/remote-questions/manager.js +39 -5
- package/dist/resources/extensions/remote-questions/telegram-adapter.js +79 -4
- package/dist/resources/extensions/search-the-web/command-search-provider.js +4 -1
- package/dist/resources/extensions/search-the-web/native-search.js +13 -2
- package/dist/resources/extensions/shared/interview-ui.js +189 -1
- package/dist/resources/extensions/shared/layout-utils.js +17 -0
- package/dist/resources/extensions/shared/rtk-shared.js +47 -0
- package/dist/resources/extensions/shared/rtk.js +3 -46
- package/dist/resources/skills/create-workflow/SKILL.md +33 -6
- package/dist/rtk-shared.d.ts +10 -0
- package/dist/rtk-shared.js +47 -0
- package/dist/rtk.d.ts +2 -6
- package/dist/rtk.js +3 -48
- package/dist/shared/workspace-types.d.ts +52 -0
- package/dist/shared/workspace-types.js +1 -0
- package/dist/tsconfig.extensions.tsbuildinfo +1 -1
- package/dist/update-check.d.ts +10 -0
- package/dist/update-check.js +24 -3
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +13 -13
- package/dist/web/standalone/.next/build-manifest.json +3 -3
- package/dist/web/standalone/.next/react-loadable-manifest.json +2 -2
- package/dist/web/standalone/.next/required-server-files.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 -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_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 +2 -2
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
- 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 +2 -2
- 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 +2 -2
- 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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/stream/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +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/update/route.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/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +3 -3
- 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 +3 -3
- 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 +2 -2
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +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/6897.js +2 -2
- package/dist/web/standalone/.next/server/chunks/7461.js +1 -0
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware-manifest.json +1 -1
- package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +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/static/chunks/2826.e59e8578e2e28639.js +9 -0
- package/dist/web/standalone/.next/static/chunks/{2008.71ee9230ad78df21.js → 3621.fc7480022c972438.js} +2 -2
- package/dist/web/standalone/.next/static/chunks/app/{page-7115e62689b5fd84.js → page-151349214571e2b6.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/{webpack-b868033a5834586d.js → webpack-5fc74f13a25fa1bb.js} +1 -1
- package/dist/web/standalone/.next/static/css/632cd626b1731d88.css +1 -0
- package/dist/web/standalone/server.js +1 -1
- package/dist/welcome-screen.js +48 -24
- package/dist/wizard.js +2 -2
- package/dist/worktree-cli.d.ts +6 -5
- package/dist/worktree-cli.js +23 -7
- package/package.json +3 -3
- package/packages/daemon/package.json +2 -2
- package/packages/mcp-server/dist/server.d.ts.map +1 -1
- package/packages/mcp-server/dist/server.js +12 -10
- package/packages/mcp-server/dist/server.js.map +1 -1
- package/packages/mcp-server/dist/session-manager.d.ts.map +1 -1
- package/packages/mcp-server/dist/session-manager.js +8 -1
- package/packages/mcp-server/dist/session-manager.js.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.d.ts +1 -0
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +207 -71
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/package.json +2 -2
- package/packages/mcp-server/src/mcp-server.test.ts +40 -4
- package/packages/mcp-server/src/server.ts +12 -10
- package/packages/mcp-server/src/session-manager.ts +10 -3
- package/packages/mcp-server/src/workflow-tools.test.ts +346 -1
- package/packages/mcp-server/src/workflow-tools.ts +228 -75
- package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
- package/packages/native/package.json +1 -1
- package/packages/native/tsconfig.tsbuildinfo +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/index.d.ts +1 -0
- package/packages/pi-ai/dist/index.d.ts.map +1 -1
- package/packages/pi-ai/dist/index.js +1 -0
- package/packages/pi-ai/dist/index.js.map +1 -1
- package/packages/pi-ai/dist/models/capability-patches.d.ts.map +1 -1
- package/packages/pi-ai/dist/models/capability-patches.js +3 -2
- package/packages/pi-ai/dist/models/capability-patches.js.map +1 -1
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts +68 -0
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts.map +1 -1
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.js +68 -0
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.js.map +1 -1
- package/packages/pi-ai/dist/models/generated/anthropic.d.ts +17 -0
- package/packages/pi-ai/dist/models/generated/anthropic.d.ts.map +1 -1
- package/packages/pi-ai/dist/models/generated/anthropic.js +17 -0
- package/packages/pi-ai/dist/models/generated/anthropic.js.map +1 -1
- package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts +17 -0
- package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts.map +1 -1
- package/packages/pi-ai/dist/models/generated/google-antigravity.js +17 -0
- package/packages/pi-ai/dist/models/generated/google-antigravity.js.map +1 -1
- package/packages/pi-ai/dist/models/generated/groq.d.ts +0 -153
- package/packages/pi-ai/dist/models/generated/groq.d.ts.map +1 -1
- package/packages/pi-ai/dist/models/generated/groq.js +0 -153
- package/packages/pi-ai/dist/models/generated/groq.js.map +1 -1
- package/packages/pi-ai/dist/models/generated/index.d.ts +136 -153
- package/packages/pi-ai/dist/models/generated/index.d.ts.map +1 -1
- package/packages/pi-ai/dist/models/generated/openai-codex.d.ts +17 -0
- package/packages/pi-ai/dist/models/generated/openai-codex.d.ts.map +1 -1
- package/packages/pi-ai/dist/models/generated/openai-codex.js +17 -0
- package/packages/pi-ai/dist/models/generated/openai-codex.js.map +1 -1
- package/packages/pi-ai/dist/models/generated/openrouter.d.ts +17 -0
- package/packages/pi-ai/dist/models/generated/openrouter.d.ts.map +1 -1
- package/packages/pi-ai/dist/models/generated/openrouter.js +17 -0
- package/packages/pi-ai/dist/models/generated/openrouter.js.map +1 -1
- package/packages/pi-ai/dist/models.generated.test.js +17 -0
- package/packages/pi-ai/dist/models.generated.test.js.map +1 -1
- package/packages/pi-ai/dist/providers/amazon-bedrock.d.ts +22 -1
- package/packages/pi-ai/dist/providers/amazon-bedrock.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/amazon-bedrock.js +40 -6
- package/packages/pi-ai/dist/providers/amazon-bedrock.js.map +1 -1
- package/packages/pi-ai/dist/providers/amazon-bedrock.test.d.ts +2 -0
- package/packages/pi-ai/dist/providers/amazon-bedrock.test.d.ts.map +1 -0
- package/packages/pi-ai/dist/providers/amazon-bedrock.test.js +106 -0
- package/packages/pi-ai/dist/providers/amazon-bedrock.test.js.map +1 -0
- package/packages/pi-ai/dist/providers/anthropic-auth.test.js +42 -1
- package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic-shared.d.ts +20 -1
- package/packages/pi-ai/dist/providers/anthropic-shared.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic-shared.js +32 -2
- package/packages/pi-ai/dist/providers/anthropic-shared.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic-shared.test.js +12 -1
- package/packages/pi-ai/dist/providers/anthropic-shared.test.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.d.ts +11 -0
- package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.js +18 -1
- package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
- package/packages/pi-ai/dist/providers/api-family.d.ts +27 -0
- package/packages/pi-ai/dist/providers/api-family.d.ts.map +1 -0
- package/packages/pi-ai/dist/providers/api-family.js +47 -0
- package/packages/pi-ai/dist/providers/api-family.js.map +1 -0
- package/packages/pi-ai/dist/providers/api-family.test.d.ts +2 -0
- package/packages/pi-ai/dist/providers/api-family.test.d.ts.map +1 -0
- package/packages/pi-ai/dist/providers/api-family.test.js +101 -0
- package/packages/pi-ai/dist/providers/api-family.test.js.map +1 -0
- package/packages/pi-ai/dist/utils/oauth/openai-codex.d.ts.map +1 -1
- package/packages/pi-ai/dist/utils/oauth/openai-codex.js +12 -0
- package/packages/pi-ai/dist/utils/oauth/openai-codex.js.map +1 -1
- package/packages/pi-ai/package.json +2 -2
- package/packages/pi-ai/scripts/generate-models.ts +50 -0
- package/packages/pi-ai/src/index.ts +1 -0
- package/packages/pi-ai/src/models/capability-patches.ts +5 -2
- package/packages/pi-ai/src/models/generated/amazon-bedrock.ts +68 -0
- package/packages/pi-ai/src/models/generated/anthropic.ts +17 -0
- package/packages/pi-ai/src/models/generated/google-antigravity.ts +17 -0
- package/packages/pi-ai/src/models/generated/groq.ts +0 -153
- package/packages/pi-ai/src/models/generated/openai-codex.ts +17 -0
- package/packages/pi-ai/src/models/generated/openrouter.ts +17 -0
- package/packages/pi-ai/src/models.generated.test.ts +17 -0
- package/packages/pi-ai/src/providers/amazon-bedrock.test.ts +164 -0
- package/packages/pi-ai/src/providers/amazon-bedrock.ts +41 -7
- package/packages/pi-ai/src/providers/anthropic-auth.test.ts +47 -1
- package/packages/pi-ai/src/providers/anthropic-shared.test.ts +15 -1
- package/packages/pi-ai/src/providers/anthropic-shared.ts +36 -3
- package/packages/pi-ai/src/providers/anthropic.ts +19 -1
- package/packages/pi-ai/src/providers/api-family.test.ts +129 -0
- package/packages/pi-ai/src/providers/api-family.ts +57 -0
- package/packages/pi-ai/src/utils/oauth/openai-codex.ts +15 -0
- package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-coding-agent/dist/cli/args.d.ts +6 -0
- package/packages/pi-coding-agent/dist/cli/args.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/cli/args.js +14 -4
- package/packages/pi-coding-agent/dist/cli/args.js.map +1 -1
- package/packages/pi-coding-agent/dist/cli/args.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/cli/args.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/cli/args.test.js +38 -0
- package/packages/pi-coding-agent/dist/cli/args.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +38 -0
- package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts +14 -0
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/auth-storage.js +34 -0
- package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/auth-storage.test.js +74 -0
- package/packages/pi-coding-agent/dist/core/auth-storage.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js +4 -1
- package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +1 -0
- package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +2 -1
- package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +32 -0
- package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/retry-handler.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/retry-handler.js +4 -1
- package/packages/pi-coding-agent/dist/core/retry-handler.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/sdk.d.ts +10 -0
- package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/sdk.js +39 -1
- package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/skill-tool.test.js +2 -2
- package/packages/pi-coding-agent/dist/core/skill-tool.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/main.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/main.js +3 -0
- package/packages/pi-coding-agent/dist/main.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js +17 -7
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +48 -34
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts +4 -0
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +83 -33
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.d.ts +70 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.js +77 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts +1 -66
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js +1 -75
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.d.ts +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js +192 -24
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js.map +1 -1
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/cli/args.test.ts +44 -0
- package/packages/pi-coding-agent/src/cli/args.ts +21 -6
- package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +56 -0
- package/packages/pi-coding-agent/src/core/auth-storage.test.ts +83 -0
- package/packages/pi-coding-agent/src/core/auth-storage.ts +35 -0
- package/packages/pi-coding-agent/src/core/chat-controller-ordering.test.ts +4 -1
- package/packages/pi-coding-agent/src/core/extensions/runner.ts +4 -1
- package/packages/pi-coding-agent/src/core/extensions/types.ts +2 -2
- package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +37 -1
- package/packages/pi-coding-agent/src/core/retry-handler.ts +4 -1
- package/packages/pi-coding-agent/src/core/sdk.ts +58 -1
- package/packages/pi-coding-agent/src/core/skill-tool.test.ts +2 -2
- package/packages/pi-coding-agent/src/main.ts +4 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/chat-frame.ts +19 -7
- package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +53 -31
- package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +88 -36
- package/packages/pi-coding-agent/src/modes/interactive/theme/theme-schema.ts +83 -0
- package/packages/pi-coding-agent/src/modes/interactive/theme/theme.ts +2 -83
- package/packages/pi-coding-agent/src/modes/interactive/theme/themes.ts +208 -27
- package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-tui/package.json +1 -1
- package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
- package/packages/rpc-client/package.json +1 -1
- package/packages/rpc-client/tsconfig.tsbuildinfo +1 -1
- package/pkg/dist/modes/interactive/theme/theme-schema.d.ts +70 -0
- package/pkg/dist/modes/interactive/theme/theme-schema.d.ts.map +1 -0
- package/pkg/dist/modes/interactive/theme/theme-schema.js +77 -0
- package/pkg/dist/modes/interactive/theme/theme-schema.js.map +1 -0
- package/pkg/dist/modes/interactive/theme/theme.d.ts +1 -66
- package/pkg/dist/modes/interactive/theme/theme.d.ts.map +1 -1
- package/pkg/dist/modes/interactive/theme/theme.js +1 -75
- package/pkg/dist/modes/interactive/theme/theme.js.map +1 -1
- package/pkg/dist/modes/interactive/theme/themes.d.ts +1 -1
- package/pkg/dist/modes/interactive/theme/themes.d.ts.map +1 -1
- package/pkg/dist/modes/interactive/theme/themes.js +192 -24
- package/pkg/dist/modes/interactive/theme/themes.js.map +1 -1
- package/pkg/package.json +1 -1
- package/src/resources/extensions/ask-user-questions.ts +24 -6
- package/src/resources/extensions/claude-code-cli/models.ts +9 -0
- package/src/resources/extensions/claude-code-cli/readiness.ts +13 -2
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +94 -4
- package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +84 -0
- package/src/resources/extensions/gsd/auto/detect-stuck.ts +10 -0
- package/src/resources/extensions/gsd/auto/loop-deps.ts +2 -9
- package/src/resources/extensions/gsd/auto/loop.ts +109 -3
- package/src/resources/extensions/gsd/auto/phases.ts +97 -60
- package/src/resources/extensions/gsd/auto/resolve.ts +1 -1
- package/src/resources/extensions/gsd/auto/run-unit.ts +11 -1
- package/src/resources/extensions/gsd/auto/session.ts +7 -0
- package/src/resources/extensions/gsd/auto-artifact-paths.ts +20 -0
- package/src/resources/extensions/gsd/auto-dashboard.ts +46 -5
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +15 -2
- package/src/resources/extensions/gsd/auto-dispatch.ts +141 -9
- package/src/resources/extensions/gsd/auto-loop.ts +1 -1
- package/src/resources/extensions/gsd/auto-model-selection.ts +17 -4
- package/src/resources/extensions/gsd/auto-post-unit.ts +10 -8
- package/src/resources/extensions/gsd/auto-prompts.ts +232 -47
- package/src/resources/extensions/gsd/auto-recovery.ts +63 -1
- package/src/resources/extensions/gsd/auto-start.ts +8 -6
- package/src/resources/extensions/gsd/auto-verification.ts +3 -3
- package/src/resources/extensions/gsd/auto-worktree.ts +81 -1
- package/src/resources/extensions/gsd/auto.ts +61 -28
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +8 -21
- package/src/resources/extensions/gsd/bootstrap/db-tools.ts +46 -24
- package/src/resources/extensions/gsd/bootstrap/memory-tools.ts +158 -0
- package/src/resources/extensions/gsd/bootstrap/query-tools.ts +31 -0
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +2 -0
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +22 -0
- package/src/resources/extensions/gsd/bootstrap/system-context.ts +20 -4
- package/src/resources/extensions/gsd/commands/catalog.ts +74 -9
- package/src/resources/extensions/gsd/commands/handlers/core.ts +69 -27
- package/src/resources/extensions/gsd/commands/handlers/escalate.ts +216 -0
- package/src/resources/extensions/gsd/commands/handlers/onboarding.ts +196 -0
- package/src/resources/extensions/gsd/commands/handlers/ops.ts +21 -0
- package/src/resources/extensions/gsd/commands/handlers/workflow.ts +279 -29
- package/src/resources/extensions/gsd/commands-cmux.ts +6 -2
- package/src/resources/extensions/gsd/commands-config.ts +10 -0
- package/src/resources/extensions/gsd/commands-debug.ts +484 -0
- package/src/resources/extensions/gsd/commands-do.ts +1 -0
- package/src/resources/extensions/gsd/commands-extract-learnings.ts +295 -76
- package/src/resources/extensions/gsd/commands-handlers.ts +19 -2
- package/src/resources/extensions/gsd/commands-memory.ts +551 -0
- package/src/resources/extensions/gsd/commands-prefs-wizard.ts +49 -12
- package/src/resources/extensions/gsd/commands-scan.ts +125 -0
- package/src/resources/extensions/gsd/commands-workflow-templates.ts +129 -2
- package/src/resources/extensions/gsd/custom-workflow-engine.ts +85 -60
- package/src/resources/extensions/gsd/db-writer.ts +3 -0
- package/src/resources/extensions/gsd/debug-session-store.ts +377 -0
- package/src/resources/extensions/gsd/definition-loader.ts +7 -0
- package/src/resources/extensions/gsd/docs/preferences-reference.md +9 -9
- package/src/resources/extensions/gsd/doctor-environment.ts +2 -1
- package/src/resources/extensions/gsd/doctor-git-checks.ts +28 -3
- package/src/resources/extensions/gsd/doctor-proactive.ts +4 -1
- package/src/resources/extensions/gsd/doctor-providers.ts +52 -22
- package/src/resources/extensions/gsd/doctor-runtime-checks.ts +23 -4
- package/src/resources/extensions/gsd/doctor-types.ts +1 -0
- package/src/resources/extensions/gsd/doctor.ts +7 -1
- package/src/resources/extensions/gsd/error-classifier.ts +6 -3
- package/src/resources/extensions/gsd/escalation.ts +367 -0
- package/src/resources/extensions/gsd/forensics.ts +25 -29
- package/src/resources/extensions/gsd/git-service.ts +0 -1
- package/src/resources/extensions/gsd/graph.ts +33 -3
- package/src/resources/extensions/gsd/gsd-db.ts +578 -32
- package/src/resources/extensions/gsd/health-widget-core.ts +43 -14
- package/src/resources/extensions/gsd/health-widget.ts +7 -3
- package/src/resources/extensions/gsd/init-wizard.ts +87 -54
- package/src/resources/extensions/gsd/markdown-renderer.ts +5 -5
- package/src/resources/extensions/gsd/memory-embeddings.ts +235 -0
- package/src/resources/extensions/gsd/memory-extractor.ts +100 -34
- package/src/resources/extensions/gsd/memory-ingest.ts +286 -0
- package/src/resources/extensions/gsd/memory-relations.ts +240 -0
- package/src/resources/extensions/gsd/memory-source-store.ts +138 -0
- package/src/resources/extensions/gsd/memory-store.ts +351 -7
- package/src/resources/extensions/gsd/metrics.ts +1 -0
- package/src/resources/extensions/gsd/model-cost-table.ts +3 -1
- package/src/resources/extensions/gsd/model-router.ts +25 -6
- package/src/resources/extensions/gsd/native-git-bridge.ts +134 -6
- package/src/resources/extensions/gsd/notification-overlay.ts +9 -19
- package/src/resources/extensions/gsd/notification-widget.ts +25 -43
- package/src/resources/extensions/gsd/notifications.ts +6 -0
- package/src/resources/extensions/gsd/onboarding-state.ts +146 -0
- package/src/resources/extensions/gsd/post-execution-checks.ts +37 -14
- package/src/resources/extensions/gsd/pre-execution-checks.ts +106 -12
- package/src/resources/extensions/gsd/preferences-models.ts +1 -0
- package/src/resources/extensions/gsd/preferences-types.ts +10 -2
- package/src/resources/extensions/gsd/preferences-validation.ts +33 -7
- package/src/resources/extensions/gsd/preferences.ts +10 -10
- package/src/resources/extensions/gsd/prompts/add-tests.md +1 -0
- package/src/resources/extensions/gsd/prompts/complete-milestone.md +4 -1
- package/src/resources/extensions/gsd/prompts/debug-diagnose.md +25 -0
- package/src/resources/extensions/gsd/prompts/debug-session-manager.md +80 -0
- package/src/resources/extensions/gsd/prompts/execute-task.md +13 -1
- package/src/resources/extensions/gsd/prompts/plan-milestone.md +12 -0
- package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -0
- package/src/resources/extensions/gsd/prompts/refine-slice.md +69 -0
- package/src/resources/extensions/gsd/prompts/scan.md +79 -0
- package/src/resources/extensions/gsd/prompts/workflow-oneshot.md +26 -0
- package/src/resources/extensions/gsd/python-resolver.ts +76 -0
- package/src/resources/extensions/gsd/run-manager.ts +53 -19
- package/src/resources/extensions/gsd/setup-catalog.ts +105 -0
- package/src/resources/extensions/gsd/state.ts +50 -2
- package/src/resources/extensions/gsd/templates/PREFERENCES.md +7 -7
- package/src/resources/extensions/gsd/tests/agent-end-retry.test.ts +1 -34
- package/src/resources/extensions/gsd/tests/artifact-corruption-2630.test.ts +7 -0
- package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +49 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +45 -31
- package/src/resources/extensions/gsd/tests/auto-migrating-recovery.test.ts +63 -0
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +12 -0
- package/src/resources/extensions/gsd/tests/auto-prompts-fallback.test.ts +35 -0
- package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +123 -1
- package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +39 -0
- package/src/resources/extensions/gsd/tests/autocomplete-regressions-1675.test.ts +39 -0
- package/src/resources/extensions/gsd/tests/commands-do.test.ts +48 -0
- package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +333 -21
- package/src/resources/extensions/gsd/tests/commands-scan.test.ts +351 -0
- package/src/resources/extensions/gsd/tests/commands-workflow-custom.test.ts +8 -6
- package/src/resources/extensions/gsd/tests/complete-slice.test.ts +6 -8
- package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/custom-workflow-engine.test.ts +63 -0
- package/src/resources/extensions/gsd/tests/debug-command-handler.test.ts +905 -0
- package/src/resources/extensions/gsd/tests/debug-command-lifecycle.integration.test.ts +1229 -0
- package/src/resources/extensions/gsd/tests/debug-session-store.test.ts +565 -0
- package/src/resources/extensions/gsd/tests/discuss-milestone-structured-questions.test.ts +64 -0
- package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +67 -0
- package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +62 -18
- package/src/resources/extensions/gsd/tests/enhanced-verification-integration.test.ts +5 -0
- package/src/resources/extensions/gsd/tests/escalation.test.ts +818 -0
- package/src/resources/extensions/gsd/tests/finalize-timeout-guard.test.ts +29 -12
- package/src/resources/extensions/gsd/tests/flat-rate-routing-guard.test.ts +106 -0
- package/src/resources/extensions/gsd/tests/forensics-hook-key-parse.test.ts +74 -0
- package/src/resources/extensions/gsd/tests/graph-operations.test.ts +0 -4
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +44 -1
- package/src/resources/extensions/gsd/tests/health-widget.test.ts +8 -2
- package/src/resources/extensions/gsd/tests/init-prefs-routing.test.ts +190 -0
- package/src/resources/extensions/gsd/tests/integration/doctor-git-symlink-cwd.test.ts +79 -0
- package/src/resources/extensions/gsd/tests/integration/doctor-git.test.ts +39 -0
- package/src/resources/extensions/gsd/tests/integration/doctor-proactive.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/integration/doctor-runtime.test.ts +68 -1
- package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +109 -11
- package/src/resources/extensions/gsd/tests/integration/idle-recovery.test.ts +51 -0
- package/src/resources/extensions/gsd/tests/integration/integration-proof.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/integration/test-isolation.ts +53 -0
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +171 -1
- package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/memory-embeddings.test.ts +213 -0
- package/src/resources/extensions/gsd/tests/memory-ingest.test.ts +153 -0
- package/src/resources/extensions/gsd/tests/memory-maintenance.test.ts +107 -0
- package/src/resources/extensions/gsd/tests/memory-relations.test.ts +175 -0
- package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/memory-tools.test.ts +295 -0
- package/src/resources/extensions/gsd/tests/milestone-status-tool.test.ts +3 -2
- package/src/resources/extensions/gsd/tests/model-cost-table.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/model-router.test.ts +51 -1
- package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +59 -0
- package/src/resources/extensions/gsd/tests/notification-overlay.test.ts +56 -37
- package/src/resources/extensions/gsd/tests/notification-widget.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/onboarding-state.test.ts +105 -0
- package/src/resources/extensions/gsd/tests/plan-milestone-boundary-map-preservation.test.ts +114 -0
- package/src/resources/extensions/gsd/tests/plan-milestone.test.ts +4 -5
- package/src/resources/extensions/gsd/tests/plan-slice.test.ts +17 -0
- package/src/resources/extensions/gsd/tests/post-execution-checks.test.ts +105 -1
- package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +341 -6
- package/src/resources/extensions/gsd/tests/preferences.test.ts +69 -1
- package/src/resources/extensions/gsd/tests/progressive-planning.test.ts +539 -0
- package/src/resources/extensions/gsd/tests/projection-no-plan-overwrite.test.ts +11 -2
- package/src/resources/extensions/gsd/tests/projection-regression.test.ts +7 -0
- package/src/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +159 -8
- package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +24 -0
- package/src/resources/extensions/gsd/tests/prompt-db.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/prompts-no-gitignored-test-refs.test.ts +56 -0
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +33 -0
- package/src/resources/extensions/gsd/tests/python-resolver.test.ts +131 -0
- package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +67 -0
- package/src/resources/extensions/gsd/tests/remote-notification-from-desktop.test.ts +107 -0
- package/src/resources/extensions/gsd/tests/requirements.test.ts +9 -0
- package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +153 -0
- package/src/resources/extensions/gsd/tests/skip-slice-cascades-tasks.test.ts +125 -0
- package/src/resources/extensions/gsd/tests/slice-context-injection.test.ts +16 -4
- package/src/resources/extensions/gsd/tests/stash-queued-context-files.test.ts +54 -0
- package/src/resources/extensions/gsd/tests/state-corruption-2945.test.ts +3 -0
- package/src/resources/extensions/gsd/tests/stuck-detection-coverage.test.ts +15 -0
- package/src/resources/extensions/gsd/tests/summary-render-parity.test.ts +5 -0
- package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/uok-flags.test.ts +31 -1
- package/src/resources/extensions/gsd/tests/uok-kernel-path.test.ts +166 -0
- package/src/resources/extensions/gsd/tests/verification-gate.test.ts +35 -0
- package/src/resources/extensions/gsd/tests/workflow-install.test.ts +113 -0
- package/src/resources/extensions/gsd/tests/workflow-logger-wiring.test.ts +15 -6
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/workflow-plugins.test.ts +310 -0
- package/src/resources/extensions/gsd/tests/workflow-projections.test.ts +7 -0
- package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +8 -2
- package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +97 -0
- package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +77 -2
- package/src/resources/extensions/gsd/tools/complete-task.ts +87 -0
- package/src/resources/extensions/gsd/tools/memory-tools.ts +380 -0
- package/src/resources/extensions/gsd/tools/plan-milestone.ts +42 -8
- package/src/resources/extensions/gsd/tools/plan-slice.ts +6 -1
- package/src/resources/extensions/gsd/tools/skip-slice.ts +133 -0
- package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +14 -0
- package/src/resources/extensions/gsd/types.ts +62 -0
- package/src/resources/extensions/gsd/unit-runtime.ts +1 -0
- package/src/resources/extensions/gsd/uok/contracts.ts +2 -1
- package/src/resources/extensions/gsd/uok/flags.ts +7 -7
- package/src/resources/extensions/gsd/uok/kernel.ts +16 -4
- package/src/resources/extensions/gsd/verification-gate.ts +2 -1
- package/src/resources/extensions/gsd/workflow-dispatch.ts +106 -0
- package/src/resources/extensions/gsd/workflow-install.ts +423 -0
- package/src/resources/extensions/gsd/workflow-logger.ts +3 -1
- package/src/resources/extensions/gsd/workflow-manifest.ts +8 -0
- package/src/resources/extensions/gsd/workflow-mcp.ts +1 -6
- package/src/resources/extensions/gsd/workflow-plugins.ts +403 -0
- package/src/resources/extensions/gsd/workflow-projections.ts +18 -16
- package/src/resources/extensions/gsd/workflow-templates/accessibility-audit.md +88 -0
- package/src/resources/extensions/gsd/workflow-templates/api-breaking-change.md +117 -0
- package/src/resources/extensions/gsd/workflow-templates/bugfix.md +1 -0
- package/src/resources/extensions/gsd/workflow-templates/changelog-gen.md +82 -0
- package/src/resources/extensions/gsd/workflow-templates/ci-bootstrap.md +144 -0
- package/src/resources/extensions/gsd/workflow-templates/dead-code.md +81 -0
- package/src/resources/extensions/gsd/workflow-templates/dep-upgrade.md +1 -0
- package/src/resources/extensions/gsd/workflow-templates/docs-sync.yaml +76 -0
- package/src/resources/extensions/gsd/workflow-templates/env-audit.yaml +88 -0
- package/src/resources/extensions/gsd/workflow-templates/full-project.md +1 -0
- package/src/resources/extensions/gsd/workflow-templates/hotfix.md +1 -0
- package/src/resources/extensions/gsd/workflow-templates/issue-triage.md +84 -0
- package/src/resources/extensions/gsd/workflow-templates/observability-setup.md +133 -0
- package/src/resources/extensions/gsd/workflow-templates/onboarding-check.md +74 -0
- package/src/resources/extensions/gsd/workflow-templates/performance-audit.md +125 -0
- package/src/resources/extensions/gsd/workflow-templates/pr-review.md +67 -0
- package/src/resources/extensions/gsd/workflow-templates/pr-triage.md +83 -0
- package/src/resources/extensions/gsd/workflow-templates/refactor.md +1 -0
- package/src/resources/extensions/gsd/workflow-templates/registry.json +184 -0
- package/src/resources/extensions/gsd/workflow-templates/release.md +118 -0
- package/src/resources/extensions/gsd/workflow-templates/rename-symbol.yaml +99 -0
- package/src/resources/extensions/gsd/workflow-templates/security-audit.md +1 -0
- package/src/resources/extensions/gsd/workflow-templates/small-feature.md +1 -0
- package/src/resources/extensions/gsd/workflow-templates/spike.md +1 -0
- package/src/resources/extensions/gsd/workflow-templates/test-backfill.yaml +73 -0
- package/src/resources/extensions/gsd/workflow-templates.ts +7 -0
- package/src/resources/extensions/gsd/workspace-index.ts +9 -4
- package/src/resources/extensions/gsd/worktree-resolver.ts +47 -1
- package/src/resources/extensions/remote-questions/commands.ts +480 -0
- package/src/resources/extensions/remote-questions/manager.ts +49 -4
- package/src/resources/extensions/remote-questions/telegram-adapter.ts +86 -4
- package/src/resources/extensions/remote-questions/tests/command-polling.test.ts +246 -0
- package/src/resources/extensions/remote-questions/tests/remote-answer-normalization.test.ts +92 -0
- package/src/resources/extensions/remote-questions/tests/telegram-commands.test.ts +267 -0
- package/src/resources/extensions/search-the-web/command-search-provider.ts +4 -1
- package/src/resources/extensions/search-the-web/native-search.ts +13 -3
- package/src/resources/extensions/shared/interview-ui.ts +195 -1
- package/src/resources/extensions/shared/layout-utils.ts +26 -0
- package/src/resources/extensions/shared/rtk-shared.ts +58 -0
- package/src/resources/extensions/shared/rtk.ts +12 -52
- package/src/resources/extensions/shared/tests/interview-preview.test.ts +177 -0
- package/src/resources/extensions/shared/tests/preview-layout.test.ts +120 -0
- package/src/resources/skills/create-workflow/SKILL.md +33 -6
- package/dist/web/standalone/.next/static/chunks/2826.dd3dc8bbd3025fa5.js +0 -9
- package/dist/web/standalone/.next/static/css/f6e8833d46e738d8.css +0 -1
- package/packages/native/dist/ps/types.d.ts +0 -5
- package/packages/native/dist/ps/types.js +0 -2
- package/packages/native/src/ps/types.ts +0 -5
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/LICENSE +0 -201
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/README.md +0 -9
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-cjs/index.js +0 -762
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/build-abort-error.js +0 -19
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/constants.js +0 -1
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/get-transformed-headers.js +0 -9
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/index.js +0 -3
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/node-http-handler.js +0 -230
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/node-http2-connection-manager.js +0 -87
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/node-http2-connection-pool.js +0 -32
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/node-http2-handler.js +0 -169
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/readable.mock.js +0 -21
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/server.mock.js +0 -88
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/set-connection-timeout.js +0 -36
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/set-request-timeout.js +0 -21
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/set-socket-keep-alive.js +0 -22
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/set-socket-timeout.js +0 -23
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/stream-collector/collector.js +0 -8
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/stream-collector/index.js +0 -41
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/stream-collector/readable.mock.js +0 -21
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/timing.js +0 -4
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/write-request-body.js +0 -63
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/build-abort-error.d.ts +0 -10
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/constants.d.ts +0 -5
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/get-transformed-headers.d.ts +0 -4
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/index.d.ts +0 -3
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/node-http-handler.d.ts +0 -46
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/node-http2-connection-manager.d.ts +0 -24
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/node-http2-connection-pool.d.ts +0 -12
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/node-http2-handler.d.ts +0 -63
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/readable.mock.d.ts +0 -13
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/server.mock.d.ts +0 -12
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/set-connection-timeout.d.ts +0 -2
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/set-request-timeout.d.ts +0 -6
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/set-socket-keep-alive.d.ts +0 -6
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/set-socket-timeout.d.ts +0 -2
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/stream-collector/collector.d.ts +0 -5
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/stream-collector/index.d.ts +0 -6
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/stream-collector/readable.mock.d.ts +0 -13
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/timing.d.ts +0 -8
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/build-abort-error.d.ts +0 -10
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/constants.d.ts +0 -5
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/get-transformed-headers.d.ts +0 -4
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/index.d.ts +0 -3
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/node-http-handler.d.ts +0 -46
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/node-http2-connection-manager.d.ts +0 -24
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/node-http2-connection-pool.d.ts +0 -12
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/node-http2-handler.d.ts +0 -63
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/readable.mock.d.ts +0 -13
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/server.mock.d.ts +0 -12
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/set-connection-timeout.d.ts +0 -2
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/set-request-timeout.d.ts +0 -6
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/set-socket-keep-alive.d.ts +0 -6
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/set-socket-timeout.d.ts +0 -2
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/stream-collector/collector.d.ts +0 -5
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/stream-collector/index.d.ts +0 -6
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/stream-collector/readable.mock.d.ts +0 -13
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/timing.d.ts +0 -8
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/write-request-body.d.ts +0 -12
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/write-request-body.d.ts +0 -12
- package/packages/pi-ai/node_modules/@smithy/node-http-handler/package.json +0 -68
- package/packages/pi-ai/oauth.d.ts +0 -1
- package/packages/pi-ai/oauth.js +0 -1
- /package/dist/web/standalone/.next/static/{prkokVQFxWtUVIku57_0z → ssX7BLv3Dw9Fb4CtrCGeR}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{prkokVQFxWtUVIku57_0z → ssX7BLv3Dw9Fb4CtrCGeR}/_ssgManifest.js +0 -0
|
@@ -135,7 +135,7 @@ function openRawDb(path) {
|
|
|
135
135
|
const Database = providerModule;
|
|
136
136
|
return new Database(path);
|
|
137
137
|
}
|
|
138
|
-
const SCHEMA_VERSION =
|
|
138
|
+
const SCHEMA_VERSION = 20;
|
|
139
139
|
function indexExists(db, name) {
|
|
140
140
|
return !!db.prepare("SELECT 1 as present FROM sqlite_master WHERE type = 'index' AND name = ?").get(name);
|
|
141
141
|
}
|
|
@@ -189,6 +189,7 @@ function initSchema(db, fileBacked) {
|
|
|
189
189
|
rationale TEXT NOT NULL DEFAULT '',
|
|
190
190
|
revisable TEXT NOT NULL DEFAULT '',
|
|
191
191
|
made_by TEXT NOT NULL DEFAULT 'agent',
|
|
192
|
+
source TEXT NOT NULL DEFAULT 'discussion', -- ADR-011 P2: 'discussion' | 'planning' | 'escalation'
|
|
192
193
|
superseded_by TEXT DEFAULT NULL
|
|
193
194
|
)
|
|
194
195
|
`);
|
|
@@ -231,7 +232,9 @@ function initSchema(db, fileBacked) {
|
|
|
231
232
|
created_at TEXT NOT NULL,
|
|
232
233
|
updated_at TEXT NOT NULL,
|
|
233
234
|
superseded_by TEXT DEFAULT NULL,
|
|
234
|
-
hit_count INTEGER NOT NULL DEFAULT 0
|
|
235
|
+
hit_count INTEGER NOT NULL DEFAULT 0,
|
|
236
|
+
scope TEXT NOT NULL DEFAULT 'project',
|
|
237
|
+
tags TEXT NOT NULL DEFAULT '[]'
|
|
235
238
|
)
|
|
236
239
|
`);
|
|
237
240
|
db.exec(`
|
|
@@ -242,6 +245,41 @@ function initSchema(db, fileBacked) {
|
|
|
242
245
|
)
|
|
243
246
|
`);
|
|
244
247
|
db.exec(`
|
|
248
|
+
CREATE TABLE IF NOT EXISTS memory_sources (
|
|
249
|
+
id TEXT PRIMARY KEY,
|
|
250
|
+
kind TEXT NOT NULL,
|
|
251
|
+
uri TEXT,
|
|
252
|
+
title TEXT,
|
|
253
|
+
content TEXT NOT NULL,
|
|
254
|
+
content_hash TEXT NOT NULL UNIQUE,
|
|
255
|
+
imported_at TEXT NOT NULL,
|
|
256
|
+
scope TEXT NOT NULL DEFAULT 'project',
|
|
257
|
+
tags TEXT NOT NULL DEFAULT '[]'
|
|
258
|
+
)
|
|
259
|
+
`);
|
|
260
|
+
db.exec(`
|
|
261
|
+
CREATE TABLE IF NOT EXISTS memory_embeddings (
|
|
262
|
+
memory_id TEXT PRIMARY KEY,
|
|
263
|
+
model TEXT NOT NULL,
|
|
264
|
+
dim INTEGER NOT NULL,
|
|
265
|
+
vector BLOB NOT NULL,
|
|
266
|
+
updated_at TEXT NOT NULL
|
|
267
|
+
)
|
|
268
|
+
`);
|
|
269
|
+
db.exec(`
|
|
270
|
+
CREATE TABLE IF NOT EXISTS memory_relations (
|
|
271
|
+
from_id TEXT NOT NULL,
|
|
272
|
+
to_id TEXT NOT NULL,
|
|
273
|
+
rel TEXT NOT NULL,
|
|
274
|
+
confidence REAL NOT NULL DEFAULT 0.8,
|
|
275
|
+
created_at TEXT NOT NULL,
|
|
276
|
+
PRIMARY KEY (from_id, to_id, rel)
|
|
277
|
+
)
|
|
278
|
+
`);
|
|
279
|
+
// FTS5 virtual table mirroring memories.content for fast keyword search.
|
|
280
|
+
// Optional — if the SQLite build lacks FTS5, we fall back to LIKE scans.
|
|
281
|
+
tryCreateMemoriesFts(db);
|
|
282
|
+
db.exec(`
|
|
245
283
|
CREATE TABLE IF NOT EXISTS milestones (
|
|
246
284
|
id TEXT PRIMARY KEY,
|
|
247
285
|
title TEXT NOT NULL DEFAULT '',
|
|
@@ -282,6 +320,8 @@ function initSchema(db, fileBacked) {
|
|
|
282
320
|
observability_impact TEXT NOT NULL DEFAULT '',
|
|
283
321
|
sequence INTEGER DEFAULT 0, -- Ordering hint: tools may set this to control execution order
|
|
284
322
|
replan_triggered_at TEXT DEFAULT NULL,
|
|
323
|
+
is_sketch INTEGER NOT NULL DEFAULT 0, -- ADR-011: 1 = slice is a sketch awaiting refinement
|
|
324
|
+
sketch_scope TEXT NOT NULL DEFAULT '', -- ADR-011: 2-3 sentence rough scope from plan-milestone
|
|
285
325
|
PRIMARY KEY (milestone_id, id),
|
|
286
326
|
FOREIGN KEY (milestone_id) REFERENCES milestones(id)
|
|
287
327
|
)
|
|
@@ -299,6 +339,11 @@ function initSchema(db, fileBacked) {
|
|
|
299
339
|
duration TEXT NOT NULL DEFAULT '',
|
|
300
340
|
completed_at TEXT DEFAULT NULL,
|
|
301
341
|
blocker_discovered INTEGER DEFAULT 0,
|
|
342
|
+
blocker_source TEXT NOT NULL DEFAULT '', -- ADR-011 P2: provenance for blocker_discovered (e.g. 'reject-escalation')
|
|
343
|
+
escalation_pending INTEGER NOT NULL DEFAULT 0, -- ADR-011 P2: pause-on-escalation flag
|
|
344
|
+
escalation_awaiting_review INTEGER NOT NULL DEFAULT 0, -- ADR-011 P2: artifact exists but continueWithDefault=true (no pause)
|
|
345
|
+
escalation_artifact_path TEXT DEFAULT NULL, -- ADR-011 P2: path to T##-ESCALATION.json
|
|
346
|
+
escalation_override_applied_at TEXT DEFAULT NULL, -- ADR-011 P2: DB claim lock for idempotent override injection
|
|
302
347
|
deviations TEXT NOT NULL DEFAULT '',
|
|
303
348
|
known_issues TEXT NOT NULL DEFAULT '',
|
|
304
349
|
key_files TEXT NOT NULL DEFAULT '[]',
|
|
@@ -445,6 +490,11 @@ function initSchema(db, fileBacked) {
|
|
|
445
490
|
)
|
|
446
491
|
`);
|
|
447
492
|
db.exec("CREATE INDEX IF NOT EXISTS idx_memories_active ON memories(superseded_by)");
|
|
493
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_memories_scope ON memories(scope)");
|
|
494
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_memory_sources_kind ON memory_sources(kind)");
|
|
495
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_memory_sources_scope ON memory_sources(scope)");
|
|
496
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_memory_relations_from ON memory_relations(from_id)");
|
|
497
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_memory_relations_to ON memory_relations(to_id)");
|
|
448
498
|
db.exec("CREATE INDEX IF NOT EXISTS idx_replan_history_milestone ON replan_history(milestone_id, created_at)");
|
|
449
499
|
// v13 indexes — hot-path dispatch queries
|
|
450
500
|
db.exec("CREATE INDEX IF NOT EXISTS idx_tasks_active ON tasks(milestone_id, slice_id, status)");
|
|
@@ -460,6 +510,9 @@ function initSchema(db, fileBacked) {
|
|
|
460
510
|
db.exec("CREATE INDEX IF NOT EXISTS idx_turn_git_tx_turn ON turn_git_transactions(trace_id, turn_id)");
|
|
461
511
|
db.exec("CREATE INDEX IF NOT EXISTS idx_audit_events_trace ON audit_events(trace_id, ts)");
|
|
462
512
|
db.exec("CREATE INDEX IF NOT EXISTS idx_audit_events_turn ON audit_events(trace_id, turn_id, ts)");
|
|
513
|
+
// ADR-011 Phase 2 — also created by the v17 migration; fresh installs
|
|
514
|
+
// skip migrations so the index must be created here too.
|
|
515
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_tasks_escalation_pending ON tasks(milestone_id, slice_id, escalation_pending)");
|
|
463
516
|
db.exec(`CREATE VIEW IF NOT EXISTS active_decisions AS SELECT * FROM decisions WHERE superseded_by IS NULL`);
|
|
464
517
|
db.exec(`CREATE VIEW IF NOT EXISTS active_requirements AS SELECT * FROM requirements WHERE superseded_by IS NULL`);
|
|
465
518
|
db.exec(`CREATE VIEW IF NOT EXISTS active_memories AS SELECT * FROM memories WHERE superseded_by IS NULL`);
|
|
@@ -482,6 +535,56 @@ function columnExists(db, table, column) {
|
|
|
482
535
|
const rows = db.prepare(`PRAGMA table_info(${table})`).all();
|
|
483
536
|
return rows.some((row) => row["name"] === column);
|
|
484
537
|
}
|
|
538
|
+
/**
|
|
539
|
+
* Create the FTS5 virtual table for memories plus the triggers that keep it
|
|
540
|
+
* in sync with the base table. FTS5 may be unavailable on stripped-down
|
|
541
|
+
* SQLite builds — callers should treat failure as non-fatal and fall back
|
|
542
|
+
* to LIKE-based scans in `memory-store.queryMemoriesRanked`.
|
|
543
|
+
*/
|
|
544
|
+
export function tryCreateMemoriesFts(db) {
|
|
545
|
+
try {
|
|
546
|
+
db.exec(`
|
|
547
|
+
CREATE VIRTUAL TABLE IF NOT EXISTS memories_fts
|
|
548
|
+
USING fts5(content, content='memories', content_rowid='seq', tokenize='porter unicode61')
|
|
549
|
+
`);
|
|
550
|
+
// Triggers mirror inserts / updates / deletes on the base memories table.
|
|
551
|
+
db.exec(`
|
|
552
|
+
CREATE TRIGGER IF NOT EXISTS memories_ai
|
|
553
|
+
AFTER INSERT ON memories BEGIN
|
|
554
|
+
INSERT INTO memories_fts(rowid, content) VALUES (new.seq, new.content);
|
|
555
|
+
END
|
|
556
|
+
`);
|
|
557
|
+
db.exec(`
|
|
558
|
+
CREATE TRIGGER IF NOT EXISTS memories_ad
|
|
559
|
+
AFTER DELETE ON memories BEGIN
|
|
560
|
+
INSERT INTO memories_fts(memories_fts, rowid, content) VALUES ('delete', old.seq, old.content);
|
|
561
|
+
END
|
|
562
|
+
`);
|
|
563
|
+
db.exec(`
|
|
564
|
+
CREATE TRIGGER IF NOT EXISTS memories_au
|
|
565
|
+
AFTER UPDATE OF content ON memories BEGIN
|
|
566
|
+
INSERT INTO memories_fts(memories_fts, rowid, content) VALUES ('delete', old.seq, old.content);
|
|
567
|
+
INSERT INTO memories_fts(rowid, content) VALUES (new.seq, new.content);
|
|
568
|
+
END
|
|
569
|
+
`);
|
|
570
|
+
return true;
|
|
571
|
+
}
|
|
572
|
+
catch (err) {
|
|
573
|
+
logWarning("db", `FTS5 unavailable — memory queries will use LIKE fallback: ${err.message}`);
|
|
574
|
+
return false;
|
|
575
|
+
}
|
|
576
|
+
}
|
|
577
|
+
export function isMemoriesFtsAvailable(db) {
|
|
578
|
+
try {
|
|
579
|
+
const row = db
|
|
580
|
+
.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name='memories_fts'")
|
|
581
|
+
.get();
|
|
582
|
+
return !!row;
|
|
583
|
+
}
|
|
584
|
+
catch {
|
|
585
|
+
return false;
|
|
586
|
+
}
|
|
587
|
+
}
|
|
485
588
|
function ensureColumn(db, table, column, ddl) {
|
|
486
589
|
if (!columnExists(db, table, column))
|
|
487
590
|
db.exec(ddl);
|
|
@@ -861,6 +964,101 @@ function migrateSchema(db) {
|
|
|
861
964
|
":applied_at": new Date().toISOString(),
|
|
862
965
|
});
|
|
863
966
|
}
|
|
967
|
+
if (currentVersion < 16) {
|
|
968
|
+
// ADR-011 Phase 1: sketch-then-refine progressive planning — sketch columns on slices.
|
|
969
|
+
ensureColumn(db, "slices", "is_sketch", `ALTER TABLE slices ADD COLUMN is_sketch INTEGER NOT NULL DEFAULT 0`);
|
|
970
|
+
ensureColumn(db, "slices", "sketch_scope", `ALTER TABLE slices ADD COLUMN sketch_scope TEXT NOT NULL DEFAULT ''`);
|
|
971
|
+
// ADR-011 Phase 2: decisions can now be sourced from escalation resolutions.
|
|
972
|
+
ensureColumn(db, "decisions", "source", `ALTER TABLE decisions ADD COLUMN source TEXT NOT NULL DEFAULT 'discussion'`);
|
|
973
|
+
db.prepare("INSERT INTO schema_version (version, applied_at) VALUES (:version, :applied_at)").run({
|
|
974
|
+
":version": 16,
|
|
975
|
+
":applied_at": new Date().toISOString(),
|
|
976
|
+
});
|
|
977
|
+
}
|
|
978
|
+
if (currentVersion < 17) {
|
|
979
|
+
// ADR-011 Phase 2: mid-execution escalation — columns on the tasks table.
|
|
980
|
+
ensureColumn(db, "tasks", "blocker_source", `ALTER TABLE tasks ADD COLUMN blocker_source TEXT NOT NULL DEFAULT ''`);
|
|
981
|
+
ensureColumn(db, "tasks", "escalation_pending", `ALTER TABLE tasks ADD COLUMN escalation_pending INTEGER NOT NULL DEFAULT 0`);
|
|
982
|
+
ensureColumn(db, "tasks", "escalation_awaiting_review", `ALTER TABLE tasks ADD COLUMN escalation_awaiting_review INTEGER NOT NULL DEFAULT 0`);
|
|
983
|
+
ensureColumn(db, "tasks", "escalation_artifact_path", `ALTER TABLE tasks ADD COLUMN escalation_artifact_path TEXT DEFAULT NULL`);
|
|
984
|
+
ensureColumn(db, "tasks", "escalation_override_applied_at", `ALTER TABLE tasks ADD COLUMN escalation_override_applied_at TEXT DEFAULT NULL`);
|
|
985
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_tasks_escalation_pending ON tasks(milestone_id, slice_id, escalation_pending)");
|
|
986
|
+
db.prepare("INSERT INTO schema_version (version, applied_at) VALUES (:version, :applied_at)").run({
|
|
987
|
+
":version": 17,
|
|
988
|
+
":applied_at": new Date().toISOString(),
|
|
989
|
+
});
|
|
990
|
+
}
|
|
991
|
+
if (currentVersion < 18) {
|
|
992
|
+
// Memory system Phase 2: scope + tags on memories, plus memory_sources
|
|
993
|
+
// table for raw ingested content (notes, files, URLs, artifacts).
|
|
994
|
+
ensureColumn(db, "memories", "scope", `ALTER TABLE memories ADD COLUMN scope TEXT NOT NULL DEFAULT 'project'`);
|
|
995
|
+
ensureColumn(db, "memories", "tags", `ALTER TABLE memories ADD COLUMN tags TEXT NOT NULL DEFAULT '[]'`);
|
|
996
|
+
db.exec(`
|
|
997
|
+
CREATE TABLE IF NOT EXISTS memory_sources (
|
|
998
|
+
id TEXT PRIMARY KEY,
|
|
999
|
+
kind TEXT NOT NULL,
|
|
1000
|
+
uri TEXT,
|
|
1001
|
+
title TEXT,
|
|
1002
|
+
content TEXT NOT NULL,
|
|
1003
|
+
content_hash TEXT NOT NULL UNIQUE,
|
|
1004
|
+
imported_at TEXT NOT NULL,
|
|
1005
|
+
scope TEXT NOT NULL DEFAULT 'project',
|
|
1006
|
+
tags TEXT NOT NULL DEFAULT '[]'
|
|
1007
|
+
)
|
|
1008
|
+
`);
|
|
1009
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_memories_scope ON memories(scope)");
|
|
1010
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_memory_sources_kind ON memory_sources(kind)");
|
|
1011
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_memory_sources_scope ON memory_sources(scope)");
|
|
1012
|
+
db.prepare("INSERT INTO schema_version (version, applied_at) VALUES (:version, :applied_at)").run({
|
|
1013
|
+
":version": 18,
|
|
1014
|
+
":applied_at": new Date().toISOString(),
|
|
1015
|
+
});
|
|
1016
|
+
}
|
|
1017
|
+
if (currentVersion < 19) {
|
|
1018
|
+
// Memory system Phase 3: embeddings + FTS5 for hybrid retrieval.
|
|
1019
|
+
db.exec(`
|
|
1020
|
+
CREATE TABLE IF NOT EXISTS memory_embeddings (
|
|
1021
|
+
memory_id TEXT PRIMARY KEY,
|
|
1022
|
+
model TEXT NOT NULL,
|
|
1023
|
+
dim INTEGER NOT NULL,
|
|
1024
|
+
vector BLOB NOT NULL,
|
|
1025
|
+
updated_at TEXT NOT NULL
|
|
1026
|
+
)
|
|
1027
|
+
`);
|
|
1028
|
+
tryCreateMemoriesFts(db);
|
|
1029
|
+
// Backfill FTS5 with any existing memories (triggers only cover future writes).
|
|
1030
|
+
if (isMemoriesFtsAvailable(db)) {
|
|
1031
|
+
try {
|
|
1032
|
+
db.exec(`INSERT INTO memories_fts(rowid, content) SELECT seq, content FROM memories`);
|
|
1033
|
+
}
|
|
1034
|
+
catch (err) {
|
|
1035
|
+
logWarning("db", `FTS5 backfill failed: ${err.message}`);
|
|
1036
|
+
}
|
|
1037
|
+
}
|
|
1038
|
+
db.prepare("INSERT INTO schema_version (version, applied_at) VALUES (:version, :applied_at)").run({
|
|
1039
|
+
":version": 19,
|
|
1040
|
+
":applied_at": new Date().toISOString(),
|
|
1041
|
+
});
|
|
1042
|
+
}
|
|
1043
|
+
if (currentVersion < 20) {
|
|
1044
|
+
// Memory system Phase 4: knowledge-graph relations between memories.
|
|
1045
|
+
db.exec(`
|
|
1046
|
+
CREATE TABLE IF NOT EXISTS memory_relations (
|
|
1047
|
+
from_id TEXT NOT NULL,
|
|
1048
|
+
to_id TEXT NOT NULL,
|
|
1049
|
+
rel TEXT NOT NULL,
|
|
1050
|
+
confidence REAL NOT NULL DEFAULT 0.8,
|
|
1051
|
+
created_at TEXT NOT NULL,
|
|
1052
|
+
PRIMARY KEY (from_id, to_id, rel)
|
|
1053
|
+
)
|
|
1054
|
+
`);
|
|
1055
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_memory_relations_from ON memory_relations(from_id)");
|
|
1056
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_memory_relations_to ON memory_relations(to_id)");
|
|
1057
|
+
db.prepare("INSERT INTO schema_version (version, applied_at) VALUES (:version, :applied_at)").run({
|
|
1058
|
+
":version": 20,
|
|
1059
|
+
":applied_at": new Date().toISOString(),
|
|
1060
|
+
});
|
|
1061
|
+
}
|
|
864
1062
|
db.exec("COMMIT");
|
|
865
1063
|
}
|
|
866
1064
|
catch (err) {
|
|
@@ -984,6 +1182,17 @@ export function vacuumDatabase() {
|
|
|
984
1182
|
logWarning("db", `VACUUM failed: ${e.message}`);
|
|
985
1183
|
}
|
|
986
1184
|
}
|
|
1185
|
+
/** Flush WAL into gsd.db so `git add .gsd/gsd.db` stages current state — safe while DB is open. */
|
|
1186
|
+
export function checkpointDatabase() {
|
|
1187
|
+
if (!currentDb)
|
|
1188
|
+
return;
|
|
1189
|
+
try {
|
|
1190
|
+
currentDb.exec('PRAGMA wal_checkpoint(TRUNCATE)');
|
|
1191
|
+
}
|
|
1192
|
+
catch (e) {
|
|
1193
|
+
logWarning("db", `WAL checkpoint failed: ${e.message}`);
|
|
1194
|
+
}
|
|
1195
|
+
}
|
|
987
1196
|
let _txDepth = 0;
|
|
988
1197
|
export function transaction(fn) {
|
|
989
1198
|
if (!currentDb)
|
|
@@ -1061,8 +1270,8 @@ export function readTransaction(fn) {
|
|
|
1061
1270
|
export function insertDecision(d) {
|
|
1062
1271
|
if (!currentDb)
|
|
1063
1272
|
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
1064
|
-
currentDb.prepare(`INSERT INTO decisions (id, when_context, scope, decision, choice, rationale, revisable, made_by, superseded_by)
|
|
1065
|
-
VALUES (:id, :when_context, :scope, :decision, :choice, :rationale, :revisable, :made_by, :superseded_by)`).run({
|
|
1273
|
+
currentDb.prepare(`INSERT INTO decisions (id, when_context, scope, decision, choice, rationale, revisable, made_by, source, superseded_by)
|
|
1274
|
+
VALUES (:id, :when_context, :scope, :decision, :choice, :rationale, :revisable, :made_by, :source, :superseded_by)`).run({
|
|
1066
1275
|
":id": d.id,
|
|
1067
1276
|
":when_context": d.when_context,
|
|
1068
1277
|
":scope": d.scope,
|
|
@@ -1071,6 +1280,7 @@ export function insertDecision(d) {
|
|
|
1071
1280
|
":rationale": d.rationale,
|
|
1072
1281
|
":revisable": d.revisable,
|
|
1073
1282
|
":made_by": d.made_by ?? "agent",
|
|
1283
|
+
":source": d.source ?? "discussion",
|
|
1074
1284
|
":superseded_by": d.superseded_by,
|
|
1075
1285
|
});
|
|
1076
1286
|
}
|
|
@@ -1090,6 +1300,7 @@ export function getDecisionById(id) {
|
|
|
1090
1300
|
rationale: row["rationale"],
|
|
1091
1301
|
revisable: row["revisable"],
|
|
1092
1302
|
made_by: row["made_by"] ?? "agent",
|
|
1303
|
+
source: row["source"] ?? "discussion",
|
|
1093
1304
|
superseded_by: row["superseded_by"] ?? null,
|
|
1094
1305
|
};
|
|
1095
1306
|
}
|
|
@@ -1107,6 +1318,7 @@ export function getActiveDecisions() {
|
|
|
1107
1318
|
rationale: row["rationale"],
|
|
1108
1319
|
revisable: row["revisable"],
|
|
1109
1320
|
made_by: row["made_by"] ?? "agent",
|
|
1321
|
+
source: row["source"] ?? "discussion",
|
|
1110
1322
|
superseded_by: null,
|
|
1111
1323
|
}));
|
|
1112
1324
|
}
|
|
@@ -1189,8 +1401,8 @@ export function upsertDecision(d) {
|
|
|
1189
1401
|
// Use ON CONFLICT DO UPDATE instead of INSERT OR REPLACE to preserve the
|
|
1190
1402
|
// seq column. INSERT OR REPLACE deletes then reinserts, resetting seq and
|
|
1191
1403
|
// corrupting decision ordering in DECISIONS.md after reconcile replay.
|
|
1192
|
-
currentDb.prepare(`INSERT INTO decisions (id, when_context, scope, decision, choice, rationale, revisable, made_by, superseded_by)
|
|
1193
|
-
VALUES (:id, :when_context, :scope, :decision, :choice, :rationale, :revisable, :made_by, :superseded_by)
|
|
1404
|
+
currentDb.prepare(`INSERT INTO decisions (id, when_context, scope, decision, choice, rationale, revisable, made_by, source, superseded_by)
|
|
1405
|
+
VALUES (:id, :when_context, :scope, :decision, :choice, :rationale, :revisable, :made_by, :source, :superseded_by)
|
|
1194
1406
|
ON CONFLICT(id) DO UPDATE SET
|
|
1195
1407
|
when_context = excluded.when_context,
|
|
1196
1408
|
scope = excluded.scope,
|
|
@@ -1199,6 +1411,7 @@ export function upsertDecision(d) {
|
|
|
1199
1411
|
rationale = excluded.rationale,
|
|
1200
1412
|
revisable = excluded.revisable,
|
|
1201
1413
|
made_by = excluded.made_by,
|
|
1414
|
+
source = excluded.source,
|
|
1202
1415
|
superseded_by = excluded.superseded_by`).run({
|
|
1203
1416
|
":id": d.id,
|
|
1204
1417
|
":when_context": d.when_context,
|
|
@@ -1208,6 +1421,7 @@ export function upsertDecision(d) {
|
|
|
1208
1421
|
":rationale": d.rationale,
|
|
1209
1422
|
":revisable": d.revisable,
|
|
1210
1423
|
":made_by": d.made_by ?? "agent",
|
|
1424
|
+
":source": d.source ?? "discussion",
|
|
1211
1425
|
":superseded_by": d.superseded_by ?? null,
|
|
1212
1426
|
});
|
|
1213
1427
|
}
|
|
@@ -1327,10 +1541,12 @@ export function insertSlice(s) {
|
|
|
1327
1541
|
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
1328
1542
|
currentDb.prepare(`INSERT INTO slices (
|
|
1329
1543
|
milestone_id, id, title, status, risk, depends, demo, created_at,
|
|
1330
|
-
goal, success_criteria, proof_level, integration_closure, observability_impact, sequence
|
|
1544
|
+
goal, success_criteria, proof_level, integration_closure, observability_impact, sequence,
|
|
1545
|
+
is_sketch, sketch_scope
|
|
1331
1546
|
) VALUES (
|
|
1332
1547
|
:milestone_id, :id, :title, :status, :risk, :depends, :demo, :created_at,
|
|
1333
|
-
:goal, :success_criteria, :proof_level, :integration_closure, :observability_impact, :sequence
|
|
1548
|
+
:goal, :success_criteria, :proof_level, :integration_closure, :observability_impact, :sequence,
|
|
1549
|
+
:is_sketch, :sketch_scope
|
|
1334
1550
|
)
|
|
1335
1551
|
ON CONFLICT (milestone_id, id) DO UPDATE SET
|
|
1336
1552
|
title = CASE WHEN :raw_title IS NOT NULL THEN excluded.title ELSE slices.title END,
|
|
@@ -1343,7 +1559,9 @@ export function insertSlice(s) {
|
|
|
1343
1559
|
proof_level = CASE WHEN :raw_proof_level IS NOT NULL THEN excluded.proof_level ELSE slices.proof_level END,
|
|
1344
1560
|
integration_closure = CASE WHEN :raw_integration_closure IS NOT NULL THEN excluded.integration_closure ELSE slices.integration_closure END,
|
|
1345
1561
|
observability_impact = CASE WHEN :raw_observability_impact IS NOT NULL THEN excluded.observability_impact ELSE slices.observability_impact END,
|
|
1346
|
-
sequence = CASE WHEN :raw_sequence IS NOT NULL THEN excluded.sequence ELSE slices.sequence END
|
|
1562
|
+
sequence = CASE WHEN :raw_sequence IS NOT NULL THEN excluded.sequence ELSE slices.sequence END,
|
|
1563
|
+
is_sketch = CASE WHEN :raw_is_sketch IS NOT NULL THEN excluded.is_sketch ELSE slices.is_sketch END,
|
|
1564
|
+
sketch_scope = CASE WHEN :raw_sketch_scope IS NOT NULL THEN excluded.sketch_scope ELSE slices.sketch_scope END`).run({
|
|
1347
1565
|
":milestone_id": s.milestoneId,
|
|
1348
1566
|
":id": s.id,
|
|
1349
1567
|
":title": s.title ?? "",
|
|
@@ -1358,6 +1576,8 @@ export function insertSlice(s) {
|
|
|
1358
1576
|
":integration_closure": s.planning?.integrationClosure ?? "",
|
|
1359
1577
|
":observability_impact": s.planning?.observabilityImpact ?? "",
|
|
1360
1578
|
":sequence": s.sequence ?? 0,
|
|
1579
|
+
":is_sketch": s.isSketch ? 1 : 0,
|
|
1580
|
+
":sketch_scope": s.sketchScope ?? "",
|
|
1361
1581
|
// Raw sentinel params: NULL when caller omitted the field, used in ON CONFLICT guards
|
|
1362
1582
|
":raw_title": s.title ?? null,
|
|
1363
1583
|
":raw_risk": s.risk ?? null,
|
|
@@ -1368,8 +1588,47 @@ export function insertSlice(s) {
|
|
|
1368
1588
|
":raw_integration_closure": s.planning?.integrationClosure ?? null,
|
|
1369
1589
|
":raw_observability_impact": s.planning?.observabilityImpact ?? null,
|
|
1370
1590
|
":raw_sequence": s.sequence ?? null,
|
|
1591
|
+
":raw_is_sketch": s.isSketch === undefined ? null : (s.isSketch ? 1 : 0),
|
|
1592
|
+
// NOTE: use !== undefined (not ??) so an explicit empty string "" is treated
|
|
1593
|
+
// as a present value and correctly clears the existing sketch_scope on
|
|
1594
|
+
// CONFLICT. ?? would incorrectly preserve the stale value.
|
|
1595
|
+
":raw_sketch_scope": s.sketchScope !== undefined ? s.sketchScope : null,
|
|
1371
1596
|
});
|
|
1372
1597
|
}
|
|
1598
|
+
// ADR-011: sketch-then-refine helpers
|
|
1599
|
+
export function setSliceSketchFlag(milestoneId, sliceId, isSketch) {
|
|
1600
|
+
if (!currentDb)
|
|
1601
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
1602
|
+
currentDb.prepare(`UPDATE slices SET is_sketch = :is_sketch WHERE milestone_id = :mid AND id = :sid`).run({ ":is_sketch": isSketch ? 1 : 0, ":mid": milestoneId, ":sid": sliceId });
|
|
1603
|
+
}
|
|
1604
|
+
/**
|
|
1605
|
+
* ADR-011 auto-heal: reconcile stale is_sketch=1 rows whose PLAN already exists.
|
|
1606
|
+
*
|
|
1607
|
+
* Callers pass a predicate that resolves whether a plan file exists for a slice.
|
|
1608
|
+
* The predicate MUST use the canonical path resolver (`resolveSliceFile`, etc.)
|
|
1609
|
+
* to keep path logic in one place — do not hand-roll the path inside the callback.
|
|
1610
|
+
*
|
|
1611
|
+
* Recovers from two scenarios:
|
|
1612
|
+
* 1. Crash between `gsd_plan_slice` write and the sketch flag flip.
|
|
1613
|
+
* 2. Flag-OFF downgrade path: when `progressive_planning` is off, the dispatch
|
|
1614
|
+
* rule routes sketch slices to plan-slice, which writes PLAN.md but leaves
|
|
1615
|
+
* `is_sketch=1` — the next state derivation auto-heals it to 0 here.
|
|
1616
|
+
*
|
|
1617
|
+
* Not aggressive in practice: PLAN.md is only written via the DB-backed
|
|
1618
|
+
* `gsd_plan_slice` tool (which also inserts tasks), so a "stale PLAN.md with
|
|
1619
|
+
* is_sketch=1" is extremely unlikely to indicate anything other than the two
|
|
1620
|
+
* recovery scenarios above.
|
|
1621
|
+
*/
|
|
1622
|
+
export function autoHealSketchFlags(milestoneId, hasPlanFile) {
|
|
1623
|
+
if (!currentDb)
|
|
1624
|
+
return;
|
|
1625
|
+
const rows = currentDb.prepare(`SELECT id FROM slices WHERE milestone_id = :mid AND is_sketch = 1`).all({ ":mid": milestoneId });
|
|
1626
|
+
for (const row of rows) {
|
|
1627
|
+
if (hasPlanFile(row.id)) {
|
|
1628
|
+
setSliceSketchFlag(milestoneId, row.id, false);
|
|
1629
|
+
}
|
|
1630
|
+
}
|
|
1631
|
+
}
|
|
1373
1632
|
export function upsertSlicePlanning(milestoneId, sliceId, planning) {
|
|
1374
1633
|
if (!currentDb)
|
|
1375
1634
|
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
@@ -1516,6 +1775,8 @@ function rowToSlice(row) {
|
|
|
1516
1775
|
observability_impact: row["observability_impact"] ?? "",
|
|
1517
1776
|
sequence: row["sequence"] ?? 0,
|
|
1518
1777
|
replan_triggered_at: row["replan_triggered_at"] ?? null,
|
|
1778
|
+
is_sketch: row["is_sketch"] ?? 0,
|
|
1779
|
+
sketch_scope: row["sketch_scope"] ?? "",
|
|
1519
1780
|
};
|
|
1520
1781
|
}
|
|
1521
1782
|
export function getSlice(milestoneId, sliceId) {
|
|
@@ -1616,6 +1877,11 @@ function rowToTask(row) {
|
|
|
1616
1877
|
observability_impact: row["observability_impact"] ?? "",
|
|
1617
1878
|
full_plan_md: row["full_plan_md"] ?? "",
|
|
1618
1879
|
sequence: row["sequence"] ?? 0,
|
|
1880
|
+
blocker_source: row["blocker_source"] ?? "",
|
|
1881
|
+
escalation_pending: row["escalation_pending"] ?? 0,
|
|
1882
|
+
escalation_awaiting_review: row["escalation_awaiting_review"] ?? 0,
|
|
1883
|
+
escalation_artifact_path: row["escalation_artifact_path"] ?? null,
|
|
1884
|
+
escalation_override_applied_at: row["escalation_override_applied_at"] ?? null,
|
|
1619
1885
|
};
|
|
1620
1886
|
}
|
|
1621
1887
|
export function getTask(milestoneId, sliceId, taskId) {
|
|
@@ -1632,6 +1898,95 @@ export function getSliceTasks(milestoneId, sliceId) {
|
|
|
1632
1898
|
const rows = currentDb.prepare("SELECT * FROM tasks WHERE milestone_id = :mid AND slice_id = :sid ORDER BY sequence, id").all({ ":mid": milestoneId, ":sid": sliceId });
|
|
1633
1899
|
return rows.map(rowToTask);
|
|
1634
1900
|
}
|
|
1901
|
+
// ─── ADR-011 Phase 2 escalation helpers ──────────────────────────────────
|
|
1902
|
+
/** Set pause-on-escalation state on a completed task. Mutually exclusive with awaiting_review. */
|
|
1903
|
+
export function setTaskEscalationPending(milestoneId, sliceId, taskId, artifactPath) {
|
|
1904
|
+
if (!currentDb)
|
|
1905
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
1906
|
+
currentDb.prepare(`UPDATE tasks
|
|
1907
|
+
SET escalation_pending = 1,
|
|
1908
|
+
escalation_awaiting_review = 0,
|
|
1909
|
+
escalation_artifact_path = :path
|
|
1910
|
+
WHERE milestone_id = :mid AND slice_id = :sid AND id = :tid`).run({ ":path": artifactPath, ":mid": milestoneId, ":sid": sliceId, ":tid": taskId });
|
|
1911
|
+
}
|
|
1912
|
+
/** Set awaiting-review state (artifact exists but continueWithDefault=true, no pause). Mutually exclusive with pending. */
|
|
1913
|
+
export function setTaskEscalationAwaitingReview(milestoneId, sliceId, taskId, artifactPath) {
|
|
1914
|
+
if (!currentDb)
|
|
1915
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
1916
|
+
currentDb.prepare(`UPDATE tasks
|
|
1917
|
+
SET escalation_awaiting_review = 1,
|
|
1918
|
+
escalation_pending = 0,
|
|
1919
|
+
escalation_artifact_path = :path
|
|
1920
|
+
WHERE milestone_id = :mid AND slice_id = :sid AND id = :tid`).run({ ":path": artifactPath, ":mid": milestoneId, ":sid": sliceId, ":tid": taskId });
|
|
1921
|
+
}
|
|
1922
|
+
/** Clear escalation-pending and awaiting-review flags once the user has resolved it. */
|
|
1923
|
+
export function clearTaskEscalationFlags(milestoneId, sliceId, taskId) {
|
|
1924
|
+
if (!currentDb)
|
|
1925
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
1926
|
+
currentDb.prepare(`UPDATE tasks
|
|
1927
|
+
SET escalation_pending = 0,
|
|
1928
|
+
escalation_awaiting_review = 0
|
|
1929
|
+
WHERE milestone_id = :mid AND slice_id = :sid AND id = :tid`).run({ ":mid": milestoneId, ":sid": sliceId, ":tid": taskId });
|
|
1930
|
+
}
|
|
1931
|
+
/**
|
|
1932
|
+
* Atomically claim a resolved escalation override for injection into a downstream
|
|
1933
|
+
* task's prompt. Returns true if this caller claimed it (must inject), false if
|
|
1934
|
+
* another caller already claimed it (must skip).
|
|
1935
|
+
*/
|
|
1936
|
+
export function claimEscalationOverride(milestoneId, sliceId, sourceTaskId) {
|
|
1937
|
+
if (!currentDb)
|
|
1938
|
+
return false;
|
|
1939
|
+
const now = new Date().toISOString();
|
|
1940
|
+
const result = currentDb.prepare(`UPDATE tasks
|
|
1941
|
+
SET escalation_override_applied_at = :now
|
|
1942
|
+
WHERE milestone_id = :mid AND slice_id = :sid AND id = :tid
|
|
1943
|
+
AND escalation_override_applied_at IS NULL
|
|
1944
|
+
AND escalation_artifact_path IS NOT NULL`).run({ ":now": now, ":mid": milestoneId, ":sid": sliceId, ":tid": sourceTaskId });
|
|
1945
|
+
// node:sqlite + better-sqlite3 both surface `changes` on the run result.
|
|
1946
|
+
const changes = result.changes ?? 0;
|
|
1947
|
+
return changes > 0;
|
|
1948
|
+
}
|
|
1949
|
+
/** Find the most recent resolved-but-unapplied escalation override in a slice. */
|
|
1950
|
+
export function findUnappliedEscalationOverride(milestoneId, sliceId) {
|
|
1951
|
+
if (!currentDb)
|
|
1952
|
+
return null;
|
|
1953
|
+
// Filter BOTH flags: escalation_pending=0 AND escalation_awaiting_review=0
|
|
1954
|
+
// ensures we only claim overrides the user has explicitly resolved.
|
|
1955
|
+
// Without the awaiting_review filter, continueWithDefault=true artifacts
|
|
1956
|
+
// (not yet responded to) would be prematurely claimed, causing the override
|
|
1957
|
+
// to be lost when the user later resolves (#ADR-011 Phase 2 peer-review Bug 2).
|
|
1958
|
+
const row = currentDb.prepare(`SELECT id, escalation_artifact_path AS path
|
|
1959
|
+
FROM tasks
|
|
1960
|
+
WHERE milestone_id = :mid AND slice_id = :sid
|
|
1961
|
+
AND escalation_artifact_path IS NOT NULL
|
|
1962
|
+
AND escalation_override_applied_at IS NULL
|
|
1963
|
+
AND escalation_pending = 0
|
|
1964
|
+
AND escalation_awaiting_review = 0
|
|
1965
|
+
ORDER BY sequence DESC, id DESC
|
|
1966
|
+
LIMIT 1`).get({ ":mid": milestoneId, ":sid": sliceId });
|
|
1967
|
+
if (!row || !row.path)
|
|
1968
|
+
return null;
|
|
1969
|
+
return { taskId: row.id, artifactPath: row.path };
|
|
1970
|
+
}
|
|
1971
|
+
/** Set the blocker_source provenance field (used when rejecting an escalation). */
|
|
1972
|
+
export function setTaskBlockerSource(milestoneId, sliceId, taskId, source) {
|
|
1973
|
+
if (!currentDb)
|
|
1974
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
1975
|
+
currentDb.prepare(`UPDATE tasks
|
|
1976
|
+
SET blocker_discovered = 1,
|
|
1977
|
+
blocker_source = :src
|
|
1978
|
+
WHERE milestone_id = :mid AND slice_id = :sid AND id = :tid`).run({ ":src": source, ":mid": milestoneId, ":sid": sliceId, ":tid": taskId });
|
|
1979
|
+
}
|
|
1980
|
+
/** List tasks with active escalation artifacts across a milestone (for /gsd escalate list). */
|
|
1981
|
+
export function listEscalationArtifacts(milestoneId, includeResolved = false) {
|
|
1982
|
+
if (!currentDb)
|
|
1983
|
+
return [];
|
|
1984
|
+
const filter = includeResolved
|
|
1985
|
+
? "escalation_artifact_path IS NOT NULL"
|
|
1986
|
+
: "(escalation_pending = 1 OR escalation_awaiting_review = 1) AND escalation_artifact_path IS NOT NULL";
|
|
1987
|
+
const rows = currentDb.prepare(`SELECT * FROM tasks WHERE milestone_id = :mid AND ${filter} ORDER BY slice_id, sequence, id`).all({ ":mid": milestoneId });
|
|
1988
|
+
return rows.map(rowToTask);
|
|
1989
|
+
}
|
|
1635
1990
|
export function insertVerificationEvidence(e) {
|
|
1636
1991
|
if (!currentDb)
|
|
1637
1992
|
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
@@ -1862,6 +2217,19 @@ export function reconcileWorktreeDb(mainDbPath, worktreeDbPath) {
|
|
|
1862
2217
|
try {
|
|
1863
2218
|
const wtInfo = adapter.prepare("PRAGMA wt.table_info('decisions')").all();
|
|
1864
2219
|
const hasMadeBy = wtInfo.some((col) => col["name"] === "made_by");
|
|
2220
|
+
// ADR-011: worktree may predate schema v16/v17. For missing columns we
|
|
2221
|
+
// fall through to the main DB's existing value (not a literal default)
|
|
2222
|
+
// so reconcile never silently clears state the main tree has recorded.
|
|
2223
|
+
const hasDecisionSource = wtInfo.some((col) => col["name"] === "source");
|
|
2224
|
+
const wtSliceInfo = adapter.prepare("PRAGMA wt.table_info('slices')").all();
|
|
2225
|
+
const hasIsSketch = wtSliceInfo.some((col) => col["name"] === "is_sketch");
|
|
2226
|
+
const hasSketchScope = wtSliceInfo.some((col) => col["name"] === "sketch_scope");
|
|
2227
|
+
const wtTaskInfo = adapter.prepare("PRAGMA wt.table_info('tasks')").all();
|
|
2228
|
+
const hasBlockerSource = wtTaskInfo.some((col) => col["name"] === "blocker_source");
|
|
2229
|
+
const hasEscalationPending = wtTaskInfo.some((col) => col["name"] === "escalation_pending");
|
|
2230
|
+
const hasEscalationAwaiting = wtTaskInfo.some((col) => col["name"] === "escalation_awaiting_review");
|
|
2231
|
+
const hasEscalationArtifact = wtTaskInfo.some((col) => col["name"] === "escalation_artifact_path");
|
|
2232
|
+
const hasEscalationOverride = wtTaskInfo.some((col) => col["name"] === "escalation_override_applied_at");
|
|
1865
2233
|
const decConf = adapter.prepare(`SELECT m.id FROM decisions m INNER JOIN wt.decisions w ON m.id = w.id WHERE m.decision != w.decision OR m.choice != w.choice OR m.rationale != w.rationale OR ${hasMadeBy ? "m.made_by != w.made_by" : "'agent' != 'agent'"} OR m.superseded_by IS NOT w.superseded_by`).all();
|
|
1866
2234
|
for (const row of decConf)
|
|
1867
2235
|
conflicts.push(`decision ${row["id"]}: modified in both`);
|
|
@@ -1874,11 +2242,16 @@ export function reconcileWorktreeDb(mainDbPath, worktreeDbPath) {
|
|
|
1874
2242
|
}
|
|
1875
2243
|
adapter.exec("BEGIN");
|
|
1876
2244
|
try {
|
|
2245
|
+
// Join the target decisions so we can prefer an existing main.source
|
|
2246
|
+
// when the worktree predates v16 — otherwise a write-through reconcile
|
|
2247
|
+
// would clobber 'escalation'-sourced decisions with the literal default.
|
|
1877
2248
|
merged.decisions = countChanges(adapter.prepare(`
|
|
1878
2249
|
INSERT OR REPLACE INTO decisions (
|
|
1879
|
-
id, when_context, scope, decision, choice, rationale, revisable, made_by, superseded_by
|
|
2250
|
+
id, when_context, scope, decision, choice, rationale, revisable, made_by, source, superseded_by
|
|
1880
2251
|
)
|
|
1881
|
-
SELECT id, when_context, scope, decision, choice, rationale, revisable, ${hasMadeBy ? "made_by" : "'agent'"},
|
|
2252
|
+
SELECT w.id, w.when_context, w.scope, w.decision, w.choice, w.rationale, w.revisable, ${hasMadeBy ? "w.made_by" : "COALESCE(m.made_by, 'agent')"}, ${hasDecisionSource ? "w.source" : "COALESCE(m.source, 'discussion')"}, w.superseded_by
|
|
2253
|
+
FROM wt.decisions w
|
|
2254
|
+
LEFT JOIN decisions m ON m.id = w.id
|
|
1882
2255
|
`).run());
|
|
1883
2256
|
merged.requirements = countChanges(adapter.prepare(`
|
|
1884
2257
|
INSERT OR REPLACE INTO requirements (
|
|
@@ -1911,13 +2284,15 @@ export function reconcileWorktreeDb(mainDbPath, worktreeDbPath) {
|
|
|
1911
2284
|
FROM wt.milestones
|
|
1912
2285
|
`).run());
|
|
1913
2286
|
// Merge slices — preserve worktree progress but never downgrade completed status (#2558).
|
|
1914
|
-
//
|
|
1915
|
-
//
|
|
2287
|
+
// ADR-011 Phase 1: carry is_sketch + sketch_scope so reconcile doesn't
|
|
2288
|
+
// silently clear sketch metadata. When the worktree predates v16,
|
|
2289
|
+
// fall back to the main DB's existing value rather than a literal 0/''.
|
|
1916
2290
|
merged.slices = countChanges(adapter.prepare(`
|
|
1917
2291
|
INSERT OR REPLACE INTO slices (
|
|
1918
2292
|
milestone_id, id, title, status, risk, depends, demo, created_at, completed_at,
|
|
1919
2293
|
full_summary_md, full_uat_md, goal, success_criteria, proof_level,
|
|
1920
|
-
integration_closure, observability_impact, sequence, replan_triggered_at
|
|
2294
|
+
integration_closure, observability_impact, sequence, replan_triggered_at,
|
|
2295
|
+
is_sketch, sketch_scope
|
|
1921
2296
|
)
|
|
1922
2297
|
SELECT w.milestone_id, w.id, w.title,
|
|
1923
2298
|
CASE
|
|
@@ -1930,18 +2305,24 @@ export function reconcileWorktreeDb(mainDbPath, worktreeDbPath) {
|
|
|
1930
2305
|
THEN m.completed_at ELSE w.completed_at
|
|
1931
2306
|
END,
|
|
1932
2307
|
w.full_summary_md, w.full_uat_md, w.goal, w.success_criteria, w.proof_level,
|
|
1933
|
-
w.integration_closure, w.observability_impact, w.sequence, w.replan_triggered_at
|
|
2308
|
+
w.integration_closure, w.observability_impact, w.sequence, w.replan_triggered_at,
|
|
2309
|
+
${hasIsSketch ? "w.is_sketch" : "COALESCE(m.is_sketch, 0)"},
|
|
2310
|
+
${hasSketchScope ? "w.sketch_scope" : "COALESCE(m.sketch_scope, '')"}
|
|
1934
2311
|
FROM wt.slices w
|
|
1935
2312
|
LEFT JOIN slices m ON m.milestone_id = w.milestone_id AND m.id = w.id
|
|
1936
2313
|
`).run());
|
|
1937
|
-
// Merge tasks — preserve execution results, never downgrade completed status (#2558)
|
|
2314
|
+
// Merge tasks — preserve execution results, never downgrade completed status (#2558).
|
|
2315
|
+
// ADR-011 P2: carry blocker_source + escalation_* columns so worktree reconcile
|
|
2316
|
+
// doesn't silently clear escalation state back to defaults.
|
|
1938
2317
|
merged.tasks = countChanges(adapter.prepare(`
|
|
1939
2318
|
INSERT OR REPLACE INTO tasks (
|
|
1940
2319
|
milestone_id, slice_id, id, title, status, one_liner, narrative,
|
|
1941
2320
|
verification_result, duration, completed_at, blocker_discovered,
|
|
1942
2321
|
deviations, known_issues, key_files, key_decisions, full_summary_md,
|
|
1943
2322
|
description, estimate, files, verify, inputs, expected_output,
|
|
1944
|
-
observability_impact, full_plan_md, sequence
|
|
2323
|
+
observability_impact, full_plan_md, sequence,
|
|
2324
|
+
blocker_source, escalation_pending, escalation_awaiting_review,
|
|
2325
|
+
escalation_artifact_path, escalation_override_applied_at
|
|
1945
2326
|
)
|
|
1946
2327
|
SELECT w.milestone_id, w.slice_id, w.id, w.title,
|
|
1947
2328
|
CASE
|
|
@@ -1957,7 +2338,12 @@ export function reconcileWorktreeDb(mainDbPath, worktreeDbPath) {
|
|
|
1957
2338
|
w.blocker_discovered,
|
|
1958
2339
|
w.deviations, w.known_issues, w.key_files, w.key_decisions, w.full_summary_md,
|
|
1959
2340
|
w.description, w.estimate, w.files, w.verify, w.inputs, w.expected_output,
|
|
1960
|
-
w.observability_impact, w.full_plan_md, w.sequence
|
|
2341
|
+
w.observability_impact, w.full_plan_md, w.sequence,
|
|
2342
|
+
${hasBlockerSource ? "w.blocker_source" : "COALESCE(m.blocker_source, '')"},
|
|
2343
|
+
${hasEscalationPending ? "w.escalation_pending" : "COALESCE(m.escalation_pending, 0)"},
|
|
2344
|
+
${hasEscalationAwaiting ? "w.escalation_awaiting_review" : "COALESCE(m.escalation_awaiting_review, 0)"},
|
|
2345
|
+
${hasEscalationArtifact ? "w.escalation_artifact_path" : "m.escalation_artifact_path"},
|
|
2346
|
+
${hasEscalationOverride ? "w.escalation_override_applied_at" : "m.escalation_override_applied_at"}
|
|
1961
2347
|
FROM wt.tasks w
|
|
1962
2348
|
LEFT JOIN tasks m ON m.milestone_id = w.milestone_id AND m.slice_id = w.slice_id AND m.id = w.id
|
|
1963
2349
|
`).run());
|
|
@@ -2489,30 +2875,32 @@ export function restoreManifest(manifest) {
|
|
|
2489
2875
|
for (const m of manifest.milestones) {
|
|
2490
2876
|
msStmt.run(m.id, m.title, m.status, JSON.stringify(m.depends_on), m.created_at, m.completed_at, m.vision, JSON.stringify(m.success_criteria), JSON.stringify(m.key_risks), JSON.stringify(m.proof_strategy), m.verification_contract, m.verification_integration, m.verification_operational, m.verification_uat, JSON.stringify(m.definition_of_done), m.requirement_coverage, m.boundary_map_markdown);
|
|
2491
2877
|
}
|
|
2492
|
-
// Restore slices
|
|
2878
|
+
// Restore slices (ADR-011 Phase 1: includes is_sketch + sketch_scope)
|
|
2493
2879
|
const slStmt = db.prepare(`INSERT INTO slices (milestone_id, id, title, status, risk, depends, demo,
|
|
2494
2880
|
created_at, completed_at, full_summary_md, full_uat_md,
|
|
2495
2881
|
goal, success_criteria, proof_level, integration_closure, observability_impact,
|
|
2496
|
-
sequence, replan_triggered_at)
|
|
2497
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
2882
|
+
sequence, replan_triggered_at, is_sketch, sketch_scope)
|
|
2883
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
2498
2884
|
for (const s of manifest.slices) {
|
|
2499
|
-
slStmt.run(s.milestone_id, s.id, s.title, s.status, s.risk, JSON.stringify(s.depends), s.demo, s.created_at, s.completed_at, s.full_summary_md, s.full_uat_md, s.goal, s.success_criteria, s.proof_level, s.integration_closure, s.observability_impact, s.sequence, s.replan_triggered_at);
|
|
2885
|
+
slStmt.run(s.milestone_id, s.id, s.title, s.status, s.risk, JSON.stringify(s.depends), s.demo, s.created_at, s.completed_at, s.full_summary_md, s.full_uat_md, s.goal, s.success_criteria, s.proof_level, s.integration_closure, s.observability_impact, s.sequence, s.replan_triggered_at, s.is_sketch ?? 0, s.sketch_scope ?? "");
|
|
2500
2886
|
}
|
|
2501
|
-
// Restore tasks
|
|
2887
|
+
// Restore tasks (ADR-011 P2: includes blocker_source + escalation_* columns)
|
|
2502
2888
|
const tkStmt = db.prepare(`INSERT INTO tasks (milestone_id, slice_id, id, title, status,
|
|
2503
2889
|
one_liner, narrative, verification_result, duration, completed_at,
|
|
2504
2890
|
blocker_discovered, deviations, known_issues, key_files, key_decisions,
|
|
2505
2891
|
full_summary_md, description, estimate, files, verify,
|
|
2506
|
-
inputs, expected_output, observability_impact, sequence
|
|
2507
|
-
|
|
2892
|
+
inputs, expected_output, observability_impact, sequence,
|
|
2893
|
+
blocker_source, escalation_pending, escalation_awaiting_review,
|
|
2894
|
+
escalation_artifact_path, escalation_override_applied_at)
|
|
2895
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
2508
2896
|
for (const t of manifest.tasks) {
|
|
2509
|
-
tkStmt.run(t.milestone_id, t.slice_id, t.id, t.title, t.status, t.one_liner, t.narrative, t.verification_result, t.duration, t.completed_at, t.blocker_discovered ? 1 : 0, t.deviations, t.known_issues, JSON.stringify(t.key_files), JSON.stringify(t.key_decisions), t.full_summary_md, t.description, t.estimate, JSON.stringify(t.files), t.verify, JSON.stringify(t.inputs), JSON.stringify(t.expected_output), t.observability_impact, t.sequence);
|
|
2897
|
+
tkStmt.run(t.milestone_id, t.slice_id, t.id, t.title, t.status, t.one_liner, t.narrative, t.verification_result, t.duration, t.completed_at, t.blocker_discovered ? 1 : 0, t.deviations, t.known_issues, JSON.stringify(t.key_files), JSON.stringify(t.key_decisions), t.full_summary_md, t.description, t.estimate, JSON.stringify(t.files), t.verify, JSON.stringify(t.inputs), JSON.stringify(t.expected_output), t.observability_impact, t.sequence, t.blocker_source ?? "", t.escalation_pending ?? 0, t.escalation_awaiting_review ?? 0, t.escalation_artifact_path ?? null, t.escalation_override_applied_at ?? null);
|
|
2510
2898
|
}
|
|
2511
|
-
// Restore decisions
|
|
2512
|
-
const dcStmt = db.prepare(`INSERT INTO decisions (seq, id, when_context, scope, decision, choice, rationale, revisable, made_by, superseded_by)
|
|
2513
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
2899
|
+
// Restore decisions (ADR-011 P2: include source so escalation decisions survive)
|
|
2900
|
+
const dcStmt = db.prepare(`INSERT INTO decisions (seq, id, when_context, scope, decision, choice, rationale, revisable, made_by, source, superseded_by)
|
|
2901
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
2514
2902
|
for (const d of manifest.decisions) {
|
|
2515
|
-
dcStmt.run(d.seq, d.id, d.when_context, d.scope, d.decision, d.choice, d.rationale, d.revisable, d.made_by, d.superseded_by);
|
|
2903
|
+
dcStmt.run(d.seq, d.id, d.when_context, d.scope, d.decision, d.choice, d.rationale, d.revisable, d.made_by, d.source ?? "discussion", d.superseded_by);
|
|
2516
2904
|
}
|
|
2517
2905
|
// Restore verification evidence
|
|
2518
2906
|
const evStmt = db.prepare(`INSERT INTO verification_evidence (task_id, slice_id, milestone_id, command, exit_code, verdict, duration_ms, created_at)
|
|
@@ -2560,8 +2948,8 @@ export function bulkInsertLegacyHierarchy(payload) {
|
|
|
2560
2948
|
export function insertMemoryRow(args) {
|
|
2561
2949
|
if (!currentDb)
|
|
2562
2950
|
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2563
|
-
currentDb.prepare(`INSERT INTO memories (id, category, content, confidence, source_unit_type, source_unit_id, created_at, updated_at)
|
|
2564
|
-
VALUES (:id, :category, :content, :confidence, :source_unit_type, :source_unit_id, :created_at, :updated_at)`).run({
|
|
2951
|
+
currentDb.prepare(`INSERT INTO memories (id, category, content, confidence, source_unit_type, source_unit_id, created_at, updated_at, scope, tags)
|
|
2952
|
+
VALUES (:id, :category, :content, :confidence, :source_unit_type, :source_unit_id, :created_at, :updated_at, :scope, :tags)`).run({
|
|
2565
2953
|
":id": args.id,
|
|
2566
2954
|
":category": args.category,
|
|
2567
2955
|
":content": args.content,
|
|
@@ -2570,8 +2958,78 @@ export function insertMemoryRow(args) {
|
|
|
2570
2958
|
":source_unit_id": args.sourceUnitId,
|
|
2571
2959
|
":created_at": args.createdAt,
|
|
2572
2960
|
":updated_at": args.updatedAt,
|
|
2961
|
+
":scope": args.scope ?? "project",
|
|
2962
|
+
":tags": JSON.stringify(args.tags ?? []),
|
|
2963
|
+
});
|
|
2964
|
+
}
|
|
2965
|
+
export function insertMemorySourceRow(args) {
|
|
2966
|
+
if (!currentDb)
|
|
2967
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2968
|
+
currentDb.prepare(`INSERT OR IGNORE INTO memory_sources (id, kind, uri, title, content, content_hash, imported_at, scope, tags)
|
|
2969
|
+
VALUES (:id, :kind, :uri, :title, :content, :content_hash, :imported_at, :scope, :tags)`).run({
|
|
2970
|
+
":id": args.id,
|
|
2971
|
+
":kind": args.kind,
|
|
2972
|
+
":uri": args.uri,
|
|
2973
|
+
":title": args.title,
|
|
2974
|
+
":content": args.content,
|
|
2975
|
+
":content_hash": args.contentHash,
|
|
2976
|
+
":imported_at": args.importedAt,
|
|
2977
|
+
":scope": args.scope ?? "project",
|
|
2978
|
+
":tags": JSON.stringify(args.tags ?? []),
|
|
2979
|
+
});
|
|
2980
|
+
}
|
|
2981
|
+
export function deleteMemorySourceRow(id) {
|
|
2982
|
+
if (!currentDb)
|
|
2983
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2984
|
+
const res = currentDb
|
|
2985
|
+
.prepare("DELETE FROM memory_sources WHERE id = :id")
|
|
2986
|
+
.run({ ":id": id });
|
|
2987
|
+
return (res?.changes ?? 0) > 0;
|
|
2988
|
+
}
|
|
2989
|
+
export function upsertMemoryEmbedding(args) {
|
|
2990
|
+
if (!currentDb)
|
|
2991
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2992
|
+
currentDb.prepare(`INSERT INTO memory_embeddings (memory_id, model, dim, vector, updated_at)
|
|
2993
|
+
VALUES (:memory_id, :model, :dim, :vector, :updated_at)
|
|
2994
|
+
ON CONFLICT(memory_id) DO UPDATE SET
|
|
2995
|
+
model = excluded.model,
|
|
2996
|
+
dim = excluded.dim,
|
|
2997
|
+
vector = excluded.vector,
|
|
2998
|
+
updated_at = excluded.updated_at`).run({
|
|
2999
|
+
":memory_id": args.memoryId,
|
|
3000
|
+
":model": args.model,
|
|
3001
|
+
":dim": args.dim,
|
|
3002
|
+
":vector": args.vector,
|
|
3003
|
+
":updated_at": args.updatedAt,
|
|
3004
|
+
});
|
|
3005
|
+
}
|
|
3006
|
+
export function deleteMemoryEmbedding(memoryId) {
|
|
3007
|
+
if (!currentDb)
|
|
3008
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
3009
|
+
const res = currentDb
|
|
3010
|
+
.prepare("DELETE FROM memory_embeddings WHERE memory_id = :id")
|
|
3011
|
+
.run({ ":id": memoryId });
|
|
3012
|
+
return (res?.changes ?? 0) > 0;
|
|
3013
|
+
}
|
|
3014
|
+
export function insertMemoryRelationRow(args) {
|
|
3015
|
+
if (!currentDb)
|
|
3016
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
3017
|
+
currentDb.prepare(`INSERT OR REPLACE INTO memory_relations (from_id, to_id, rel, confidence, created_at)
|
|
3018
|
+
VALUES (:from_id, :to_id, :rel, :confidence, :created_at)`).run({
|
|
3019
|
+
":from_id": args.fromId,
|
|
3020
|
+
":to_id": args.toId,
|
|
3021
|
+
":rel": args.rel,
|
|
3022
|
+
":confidence": args.confidence,
|
|
3023
|
+
":created_at": args.createdAt,
|
|
2573
3024
|
});
|
|
2574
3025
|
}
|
|
3026
|
+
export function deleteMemoryRelationsFor(memoryId) {
|
|
3027
|
+
if (!currentDb)
|
|
3028
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
3029
|
+
currentDb
|
|
3030
|
+
.prepare("DELETE FROM memory_relations WHERE from_id = :id OR to_id = :id")
|
|
3031
|
+
.run({ ":id": memoryId });
|
|
3032
|
+
}
|
|
2575
3033
|
export function rewriteMemoryId(placeholderId, realId) {
|
|
2576
3034
|
if (!currentDb)
|
|
2577
3035
|
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|