gsd-pi 2.81.0 → 2.82.0-dev.2841a1e44
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 +63 -32
- package/dist/resources/.managed-resources-content-hash +1 -1
- package/dist/resources/GSD-WORKFLOW.md +3 -1
- package/dist/resources/extensions/browser-tools/tools/screenshot.js +1 -0
- package/dist/resources/extensions/browser-tools/tools/zoom.js +1 -0
- package/dist/resources/extensions/cmux/index.js +5 -0
- package/dist/resources/extensions/gsd/auto/loop.js +111 -8
- package/dist/resources/extensions/gsd/auto/orchestrator.js +113 -6
- package/dist/resources/extensions/gsd/auto/phases.js +199 -97
- package/dist/resources/extensions/gsd/auto/run-unit.js +66 -3
- package/dist/resources/extensions/gsd/auto/session.js +9 -0
- package/dist/resources/extensions/gsd/auto/verification-retry-policy.js +43 -0
- package/dist/resources/extensions/gsd/auto-dashboard.js +182 -178
- package/dist/resources/extensions/gsd/auto-dispatch.js +14 -11
- package/dist/resources/extensions/gsd/auto-post-unit.js +176 -125
- package/dist/resources/extensions/gsd/auto-prompts.js +13 -5
- package/dist/resources/extensions/gsd/auto-recovery.js +6 -181
- package/dist/resources/extensions/gsd/auto-runtime-state.js +5 -0
- package/dist/resources/extensions/gsd/auto-start.js +20 -23
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +33 -5
- package/dist/resources/extensions/gsd/auto-verification.js +38 -26
- package/dist/resources/extensions/gsd/auto-worktree.js +8 -0
- package/dist/resources/extensions/gsd/auto.js +371 -106
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +13 -6
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +13 -2
- package/dist/resources/extensions/gsd/bootstrap/register-shortcuts.js +4 -8
- package/dist/resources/extensions/gsd/bootstrap/subagent-input.js +16 -7
- package/dist/resources/extensions/gsd/bootstrap/system-context.js +55 -12
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +3 -1
- package/dist/resources/extensions/gsd/clean-root-preflight.js +170 -8
- package/dist/resources/extensions/gsd/commands/catalog.js +4 -1
- package/dist/resources/extensions/gsd/commands/handlers/core.js +22 -1
- package/dist/resources/extensions/gsd/commands/handlers/notifications-handler.js +4 -10
- package/dist/resources/extensions/gsd/commands/handlers/parallel.js +9 -0
- package/dist/resources/extensions/gsd/commands-bootstrap.js +5 -0
- package/dist/resources/extensions/gsd/commands-handlers.js +15 -2
- package/dist/resources/extensions/gsd/context-store.js +112 -0
- package/dist/resources/extensions/gsd/db-writer.js +150 -84
- package/dist/resources/extensions/gsd/docs/preferences-reference.md +1 -1
- package/dist/resources/extensions/gsd/doctor-git-checks.js +41 -6
- package/dist/resources/extensions/gsd/git-service.js +2 -1
- package/dist/resources/extensions/gsd/gsd-db.js +7 -23
- package/dist/resources/extensions/gsd/health-widget-core.js +1 -1
- package/dist/resources/extensions/gsd/health-widget.js +4 -10
- package/dist/resources/extensions/gsd/knowledge-backfill.js +144 -0
- package/dist/resources/extensions/gsd/knowledge-capture.js +136 -0
- package/dist/resources/extensions/gsd/knowledge-parser.js +154 -0
- package/dist/resources/extensions/gsd/knowledge-projection.js +210 -0
- package/dist/resources/extensions/gsd/markdown-renderer.js +6 -96
- package/dist/resources/extensions/gsd/md-importer.js +1 -1
- package/dist/resources/extensions/gsd/memory-backfill.js +73 -17
- package/dist/resources/extensions/gsd/memory-consolidation-scanner.js +222 -0
- package/dist/resources/extensions/gsd/migrate/command.js +5 -0
- package/dist/resources/extensions/gsd/migrate/preview.js +9 -0
- package/dist/resources/extensions/gsd/migrate/transformer.js +51 -4
- package/dist/resources/extensions/gsd/migrate/writer.js +11 -1
- package/dist/resources/extensions/gsd/native-git-bridge.js +14 -14
- package/dist/resources/extensions/gsd/notification-overlay.js +35 -40
- package/dist/resources/extensions/gsd/parallel-merge.js +53 -30
- package/dist/resources/extensions/gsd/parallel-monitor-overlay.js +25 -33
- package/dist/resources/extensions/gsd/prompts/complete-slice.md +14 -12
- package/dist/resources/extensions/gsd/prompts/discuss-headless.md +20 -2
- package/dist/resources/extensions/gsd/prompts/discuss.md +20 -2
- package/dist/resources/extensions/gsd/prompts/system.md +2 -2
- package/dist/resources/extensions/gsd/provider-switch-observer.js +146 -0
- package/dist/resources/extensions/gsd/recovery-classification.js +15 -1
- package/dist/resources/extensions/gsd/session-lock.js +40 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/completion.js +131 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/merge-state.js +247 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/project-md.js +50 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/roadmap.js +87 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/sketch-flag.js +50 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/stale-render.js +124 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/stale-worker.js +32 -0
- package/dist/resources/extensions/gsd/state-reconciliation/errors.js +41 -0
- package/dist/resources/extensions/gsd/state-reconciliation/index.js +99 -0
- package/dist/resources/extensions/gsd/state-reconciliation/registry.js +24 -0
- package/dist/resources/extensions/gsd/state-reconciliation/spawn-gate.js +43 -0
- package/dist/resources/extensions/gsd/state-reconciliation/types.js +3 -0
- package/dist/resources/extensions/gsd/state-reconciliation.js +5 -26
- package/dist/resources/extensions/gsd/templates/knowledge.md +2 -2
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +119 -0
- package/dist/resources/extensions/gsd/tui/render-kit.js +74 -0
- package/dist/resources/extensions/gsd/unit-context-manifest.js +25 -2
- package/dist/resources/extensions/gsd/verification-verdict.js +26 -0
- package/dist/resources/extensions/gsd/watch/header-renderer.js +92 -69
- package/dist/resources/extensions/gsd/watch/splash-palette.js +10 -0
- package/dist/resources/extensions/gsd/workflow-mcp.js +2 -2
- package/dist/resources/extensions/gsd/worktree-lifecycle.js +743 -318
- package/dist/resources/extensions/gsd/worktree-telemetry.js +3 -1
- package/dist/resources/extensions/subagent/index.js +448 -78
- package/dist/resources/extensions/subagent/launch.js +77 -0
- package/dist/resources/extensions/subagent/run-store.js +148 -0
- package/dist/resources/extensions/visual-brief/artifact-policy.js +29 -0
- package/dist/resources/extensions/visual-brief/extension-manifest.json +8 -0
- package/dist/resources/extensions/visual-brief/index.js +5 -0
- package/dist/resources/extensions/visual-brief/page-contract.js +122 -0
- package/dist/resources/extensions/visual-brief/prompts.js +111 -0
- package/dist/tsconfig.extensions.tsbuildinfo +1 -1
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +11 -11
- package/dist/web/standalone/.next/build-manifest.json +4 -4
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/react-loadable-manifest.json +3 -3
- package/dist/web/standalone/.next/required-server-files.json +3 -3
- package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
- package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
- package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +4 -4
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +4 -4
- 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 +4 -4
- 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_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/experimental/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/experimental/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/notifications/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/notifications/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/events/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +5 -5
- 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 +5 -5
- 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 +4 -4
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -2
- package/dist/web/standalone/.next/server/app/page.js +2 -2
- package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +11 -11
- package/dist/web/standalone/.next/server/chunks/63.js +3 -3
- package/dist/web/standalone/.next/server/chunks/6897.js +1 -1
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware.js +2 -2
- package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
- package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
- package/dist/web/standalone/.next/server/pages/404.html +1 -1
- package/dist/web/standalone/.next/server/pages/500.html +1 -1
- package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
- package/dist/web/standalone/.next/static/chunks/2973.33f26573894b6153.js +2 -0
- package/dist/web/standalone/.next/static/chunks/{8359.e059d86b255fce1c.js → 8359.7eb3bb8f8ecf4c01.js} +2 -2
- package/dist/web/standalone/.next/static/chunks/app/_not-found/{page-2f24283c162b6ab3.js → page-f2a7482d42a5614b.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/app/{layout-9ecfd95f343793f0.js → layout-a16c7a7ecdf0c2cf.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/app/page-752f1e2ebdaa3e45.js +1 -0
- package/dist/web/standalone/.next/static/chunks/main-app-fdab67f7802d7832.js +1 -0
- package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +1 -0
- package/dist/web/standalone/.next/static/chunks/{webpack-de742b64187e13fe.js → webpack-6a95bc41e0f7ec89.js} +1 -1
- package/dist/web/standalone/.next/static/css/0262768ec1b89d34.css +1 -0
- package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
- package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
- package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
- package/dist/web/standalone/server.js +1 -1
- package/dist/welcome-screen.d.ts +0 -7
- package/dist/welcome-screen.js +60 -69
- package/package.json +5 -4
- package/packages/contracts/dist/rpc.test.js +7 -0
- package/packages/contracts/dist/rpc.test.js.map +1 -1
- package/packages/contracts/dist/workflow.d.ts +21 -0
- package/packages/contracts/dist/workflow.d.ts.map +1 -1
- package/packages/contracts/dist/workflow.js +24 -0
- package/packages/contracts/dist/workflow.js.map +1 -1
- package/packages/contracts/src/rpc.test.ts +8 -0
- package/packages/contracts/src/workflow.ts +24 -0
- package/packages/daemon/package.json +2 -2
- package/packages/mcp-server/README.md +14 -3
- package/packages/mcp-server/dist/workflow-tools.d.ts +0 -3
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +80 -0
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/package.json +2 -2
- package/packages/mcp-server/src/workflow-tools-parity.test.ts +244 -0
- package/packages/mcp-server/src/workflow-tools.test.ts +22 -0
- package/packages/mcp-server/src/workflow-tools.ts +168 -0
- package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
- package/packages/native/package.json +1 -1
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-ai/dist/index.d.ts +2 -2
- package/packages/pi-ai/dist/index.d.ts.map +1 -1
- package/packages/pi-ai/dist/index.js +1 -1
- package/packages/pi-ai/dist/index.js.map +1 -1
- package/packages/pi-ai/dist/providers/transform-messages.d.ts +11 -0
- package/packages/pi-ai/dist/providers/transform-messages.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/transform-messages.js +20 -0
- package/packages/pi-ai/dist/providers/transform-messages.js.map +1 -1
- package/packages/pi-ai/package.json +1 -1
- package/packages/pi-ai/src/index.ts +7 -2
- package/packages/pi-ai/src/providers/transform-messages.ts +24 -0
- package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-coding-agent/dist/core/system-prompt.js +4 -4
- package/packages/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/assistant-message-design.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/assistant-message-design.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/assistant-message-design.test.js +47 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/assistant-message-design.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +76 -9
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/user-message-design.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/user-message-design.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/user-message-design.test.js +40 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/user-message-design.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.d.ts +0 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.js +30 -29
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.test.js +10 -3
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js +13 -13
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.d.ts +1 -3
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.js +58 -3
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/diff.d.ts +2 -2
- package/packages/pi-coding-agent/dist/modes/interactive/components/diff.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/diff.js +12 -6
- package/packages/pi-coding-agent/dist/modes/interactive/components/diff.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 +14 -41
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts +0 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +86 -82
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/transcript-design.d.ts +35 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/transcript-design.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/transcript-design.js +152 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/transcript-design.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tui-style-kit.d.ts +16 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tui-style-kit.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tui-style-kit.js +73 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tui-style-kit.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js +12 -8
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-highlight.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-highlight.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-highlight.test.js +17 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-highlight.test.js.map +1 -0
- 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 +105 -1
- 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.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js +27 -26
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.test.js +9 -6
- package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/tests/system-prompt-file-safety.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/tests/system-prompt-file-safety.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/tests/system-prompt-file-safety.test.js +17 -0
- package/packages/pi-coding-agent/dist/tests/system-prompt-file-safety.test.js.map +1 -0
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/core/system-prompt.ts +4 -4
- package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/assistant-message-design.test.ts +56 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +113 -9
- package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/user-message-design.test.ts +48 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/adaptive-layout.test.ts +10 -3
- package/packages/pi-coding-agent/src/modes/interactive/components/adaptive-layout.ts +43 -42
- package/packages/pi-coding-agent/src/modes/interactive/components/assistant-message.ts +14 -14
- package/packages/pi-coding-agent/src/modes/interactive/components/bash-execution.ts +64 -3
- package/packages/pi-coding-agent/src/modes/interactive/components/diff.ts +13 -7
- package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +15 -42
- package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +84 -104
- package/packages/pi-coding-agent/src/modes/interactive/components/transcript-design.ts +196 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/tui-style-kit.ts +94 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/user-message.ts +14 -9
- package/packages/pi-coding-agent/src/modes/interactive/theme/theme-highlight.test.ts +23 -0
- package/packages/pi-coding-agent/src/modes/interactive/theme/theme.ts +106 -1
- package/packages/pi-coding-agent/src/modes/interactive/theme/themes.ts +27 -26
- package/packages/pi-coding-agent/src/modes/interactive/tui-mode.test.ts +9 -6
- package/packages/pi-coding-agent/src/tests/system-prompt-file-safety.test.ts +22 -0
- package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-tui/dist/__tests__/overlay-layout.test.js +14 -1
- package/packages/pi-tui/dist/__tests__/overlay-layout.test.js.map +1 -1
- package/packages/pi-tui/dist/overlay-layout.d.ts.map +1 -1
- package/packages/pi-tui/dist/overlay-layout.js +9 -6
- package/packages/pi-tui/dist/overlay-layout.js.map +1 -1
- package/packages/pi-tui/dist/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +5 -0
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/package.json +1 -1
- package/packages/pi-tui/src/__tests__/overlay-layout.test.ts +20 -1
- package/packages/pi-tui/src/overlay-layout.ts +10 -7
- package/packages/pi-tui/src/tui.ts +6 -0
- 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-highlight.test.d.ts +2 -0
- package/pkg/dist/modes/interactive/theme/theme-highlight.test.d.ts.map +1 -0
- package/pkg/dist/modes/interactive/theme/theme-highlight.test.js +17 -0
- package/pkg/dist/modes/interactive/theme/theme-highlight.test.js.map +1 -0
- package/pkg/dist/modes/interactive/theme/theme.d.ts.map +1 -1
- package/pkg/dist/modes/interactive/theme/theme.js +105 -1
- package/pkg/dist/modes/interactive/theme/theme.js.map +1 -1
- package/pkg/dist/modes/interactive/theme/themes.d.ts.map +1 -1
- package/pkg/dist/modes/interactive/theme/themes.js +27 -26
- package/pkg/dist/modes/interactive/theme/themes.js.map +1 -1
- package/pkg/package.json +1 -1
- package/src/resources/GSD-WORKFLOW.md +3 -1
- package/src/resources/extensions/browser-tools/tools/screenshot.ts +1 -0
- package/src/resources/extensions/browser-tools/tools/zoom.ts +1 -0
- package/src/resources/extensions/cmux/index.ts +6 -0
- package/src/resources/extensions/gsd/auto/contracts.ts +46 -11
- package/src/resources/extensions/gsd/auto/loop-deps.ts +9 -5
- package/src/resources/extensions/gsd/auto/loop.ts +113 -9
- package/src/resources/extensions/gsd/auto/orchestrator.ts +118 -6
- package/src/resources/extensions/gsd/auto/phases.ts +158 -19
- package/src/resources/extensions/gsd/auto/run-unit.ts +69 -4
- package/src/resources/extensions/gsd/auto/session.ts +10 -0
- package/src/resources/extensions/gsd/auto/verification-retry-policy.ts +82 -0
- package/src/resources/extensions/gsd/auto-dashboard.ts +230 -183
- package/src/resources/extensions/gsd/auto-dispatch.ts +15 -1
- package/src/resources/extensions/gsd/auto-post-unit.ts +201 -138
- package/src/resources/extensions/gsd/auto-prompts.ts +13 -5
- package/src/resources/extensions/gsd/auto-recovery.ts +7 -209
- package/src/resources/extensions/gsd/auto-runtime-state.ts +5 -0
- package/src/resources/extensions/gsd/auto-start.ts +22 -22
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +51 -0
- package/src/resources/extensions/gsd/auto-verification.ts +46 -38
- package/src/resources/extensions/gsd/auto-worktree.ts +8 -0
- package/src/resources/extensions/gsd/auto.ts +411 -106
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +21 -6
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +12 -2
- package/src/resources/extensions/gsd/bootstrap/register-shortcuts.ts +5 -8
- package/src/resources/extensions/gsd/bootstrap/subagent-input.ts +16 -6
- package/src/resources/extensions/gsd/bootstrap/system-context.ts +58 -15
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +3 -2
- package/src/resources/extensions/gsd/clean-root-preflight.ts +174 -8
- package/src/resources/extensions/gsd/commands/catalog.ts +4 -1
- package/src/resources/extensions/gsd/commands/handlers/core.ts +25 -1
- package/src/resources/extensions/gsd/commands/handlers/notifications-handler.ts +4 -10
- package/src/resources/extensions/gsd/commands/handlers/parallel.ts +12 -0
- package/src/resources/extensions/gsd/commands-bootstrap.ts +10 -0
- package/src/resources/extensions/gsd/commands-handlers.ts +19 -2
- package/src/resources/extensions/gsd/context-store.ts +120 -1
- package/src/resources/extensions/gsd/db-writer.ts +167 -84
- package/src/resources/extensions/gsd/docs/preferences-reference.md +1 -1
- package/src/resources/extensions/gsd/doctor-git-checks.ts +44 -6
- package/src/resources/extensions/gsd/doctor-types.ts +2 -0
- package/src/resources/extensions/gsd/git-service.ts +2 -0
- package/src/resources/extensions/gsd/gsd-db.ts +7 -23
- package/src/resources/extensions/gsd/health-widget-core.ts +1 -1
- package/src/resources/extensions/gsd/health-widget.ts +6 -10
- package/src/resources/extensions/gsd/journal.ts +2 -0
- package/src/resources/extensions/gsd/knowledge-backfill.ts +164 -0
- package/src/resources/extensions/gsd/knowledge-capture.ts +160 -0
- package/src/resources/extensions/gsd/knowledge-parser.ts +174 -0
- package/src/resources/extensions/gsd/knowledge-projection.ts +241 -0
- package/src/resources/extensions/gsd/markdown-renderer.ts +10 -96
- package/src/resources/extensions/gsd/md-importer.ts +1 -1
- package/src/resources/extensions/gsd/memory-backfill.ts +89 -17
- package/src/resources/extensions/gsd/memory-consolidation-scanner.ts +277 -0
- package/src/resources/extensions/gsd/migrate/command.ts +5 -0
- package/src/resources/extensions/gsd/migrate/preview.ts +10 -0
- package/src/resources/extensions/gsd/migrate/transformer.ts +58 -4
- package/src/resources/extensions/gsd/migrate/writer.ts +14 -1
- package/src/resources/extensions/gsd/native-git-bridge.ts +14 -13
- package/src/resources/extensions/gsd/notification-overlay.ts +50 -46
- package/src/resources/extensions/gsd/parallel-merge.ts +61 -34
- package/src/resources/extensions/gsd/parallel-monitor-overlay.ts +33 -35
- package/src/resources/extensions/gsd/prompts/complete-slice.md +14 -12
- package/src/resources/extensions/gsd/prompts/discuss-headless.md +20 -2
- package/src/resources/extensions/gsd/prompts/discuss.md +20 -2
- package/src/resources/extensions/gsd/prompts/system.md +2 -2
- package/src/resources/extensions/gsd/provider-switch-observer.ts +185 -0
- package/src/resources/extensions/gsd/recovery-classification.ts +18 -1
- package/src/resources/extensions/gsd/session-lock.ts +41 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/completion.ts +172 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/merge-state.ts +337 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/project-md.ts +69 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/roadmap.ts +109 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/sketch-flag.ts +68 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/stale-render.ts +185 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/stale-worker.ts +46 -0
- package/src/resources/extensions/gsd/state-reconciliation/errors.ts +67 -0
- package/src/resources/extensions/gsd/state-reconciliation/index.ts +142 -0
- package/src/resources/extensions/gsd/state-reconciliation/registry.ts +27 -0
- package/src/resources/extensions/gsd/state-reconciliation/spawn-gate.ts +60 -0
- package/src/resources/extensions/gsd/state-reconciliation/types.ts +83 -0
- package/src/resources/extensions/gsd/state-reconciliation.ts +21 -53
- package/src/resources/extensions/gsd/templates/knowledge.md +2 -2
- package/src/resources/extensions/gsd/tests/artifact-retry-cap.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +99 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +729 -176
- package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +408 -4
- package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +292 -4
- package/src/resources/extensions/gsd/tests/auto-runtime-state.test.ts +20 -5
- package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +18 -0
- package/src/resources/extensions/gsd/tests/auto-unit-closeout.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/brief-command.test.ts +89 -0
- package/src/resources/extensions/gsd/tests/browser-tools-compatibility-declarations.test.ts +62 -0
- package/src/resources/extensions/gsd/tests/clean-root-preflight.test.ts +107 -2
- package/src/resources/extensions/gsd/tests/closeout-git-deferral.test.ts +16 -0
- package/src/resources/extensions/gsd/tests/context-store-decisions-from-memories.test.ts +312 -0
- package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +28 -1
- package/src/resources/extensions/gsd/tests/db-writer.test.ts +13 -8
- package/src/resources/extensions/gsd/tests/decisions-projection-from-memories.test.ts +453 -0
- package/src/resources/extensions/gsd/tests/decisions-stop-table-writes.test.ts +348 -0
- package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +20 -2
- package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/evidence-cross-ref.test.ts +38 -0
- package/src/resources/extensions/gsd/tests/freeform-decisions.test.ts +8 -4
- package/src/resources/extensions/gsd/tests/gsd-tools.test.ts +11 -7
- package/src/resources/extensions/gsd/tests/header-renderer.test.ts +40 -0
- package/src/resources/extensions/gsd/tests/headless-milestone-parity.test.ts +10 -0
- package/src/resources/extensions/gsd/tests/health-widget.test.ts +14 -4
- package/src/resources/extensions/gsd/tests/integration/doctor-git.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +26 -0
- package/src/resources/extensions/gsd/tests/integration/integration-lifecycle.test.ts +13 -5
- package/src/resources/extensions/gsd/tests/integration/integration-proof.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/integration/migrate-command.test.ts +48 -3
- package/src/resources/extensions/gsd/tests/integration/parallel-merge.test.ts +116 -24
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +0 -1
- package/src/resources/extensions/gsd/tests/knowledge-backfill-projection.test.ts +323 -0
- package/src/resources/extensions/gsd/tests/knowledge-capture.test.ts +242 -0
- package/src/resources/extensions/gsd/tests/knowledge.test.ts +47 -2
- package/src/resources/extensions/gsd/tests/load-knowledge-block-rules-only.test.ts +209 -0
- package/src/resources/extensions/gsd/tests/markdown-renderer.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/memory-consolidation-scanner.test.ts +316 -0
- package/src/resources/extensions/gsd/tests/merge-conflict-stops-loop.test.ts +46 -11
- package/src/resources/extensions/gsd/tests/migrate-transformer.test.ts +5 -1
- package/src/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +6 -1
- package/src/resources/extensions/gsd/tests/notification-overlay.test.ts +78 -41
- package/src/resources/extensions/gsd/tests/notifications-handler.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/originalbase-path-comparison.test.ts +12 -217
- package/src/resources/extensions/gsd/tests/parallel-monitor-overlay.test.ts +38 -6
- package/src/resources/extensions/gsd/tests/plan-milestone-sketch-render.test.ts +157 -0
- package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +81 -3
- package/src/resources/extensions/gsd/tests/progressive-planning.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +32 -1
- package/src/resources/extensions/gsd/tests/provider-switch-observer.test.ts +252 -0
- package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +7 -3
- package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +6 -3
- package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +16 -4
- package/src/resources/extensions/gsd/tests/session-switch-abort-misclassification.test.ts +24 -0
- package/src/resources/extensions/gsd/tests/state-corruption-2945.test.ts +71 -58
- package/src/resources/extensions/gsd/tests/state-reconciliation-drift.test.ts +952 -0
- package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +4 -0
- package/src/resources/extensions/gsd/tests/tui-header-lifecycle.test.ts +121 -1
- package/src/resources/extensions/gsd/tests/tui-render-kit.test.ts +66 -0
- package/src/resources/extensions/gsd/tests/unit-context-manifest.test.ts +21 -0
- package/src/resources/extensions/gsd/tests/verification-retry-policy.test.ts +83 -0
- package/src/resources/extensions/gsd/tests/verification-verdict.test.ts +78 -0
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +6 -0
- package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +158 -58
- package/src/resources/extensions/gsd/tests/worktree-lifecycle.test.ts +597 -118
- package/src/resources/extensions/gsd/tests/worktree-telemetry.test.ts +59 -2
- package/src/resources/extensions/gsd/tests/write-gate-planning-unit.test.ts +34 -0
- package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +135 -0
- package/src/resources/extensions/gsd/tui/render-kit.ts +109 -0
- package/src/resources/extensions/gsd/unit-context-manifest.ts +35 -2
- package/src/resources/extensions/gsd/verification-verdict.ts +47 -0
- package/src/resources/extensions/gsd/watch/header-renderer.ts +121 -79
- package/src/resources/extensions/gsd/watch/splash-palette.ts +11 -0
- package/src/resources/extensions/gsd/workflow-logger.ts +4 -0
- package/src/resources/extensions/gsd/workflow-mcp.ts +2 -2
- package/src/resources/extensions/gsd/worktree-lifecycle.ts +1171 -526
- package/src/resources/extensions/gsd/worktree-telemetry.ts +7 -2
- package/src/resources/extensions/subagent/index.ts +567 -103
- package/src/resources/extensions/subagent/launch.ts +131 -0
- package/src/resources/extensions/subagent/run-store.ts +218 -0
- package/src/resources/extensions/subagent/tests/launch.test.ts +115 -0
- package/src/resources/extensions/subagent/tests/run-store.test.ts +111 -0
- package/src/resources/extensions/visual-brief/artifact-policy.ts +41 -0
- package/src/resources/extensions/visual-brief/extension-manifest.json +8 -0
- package/src/resources/extensions/visual-brief/index.ts +8 -0
- package/src/resources/extensions/visual-brief/page-contract.ts +134 -0
- package/src/resources/extensions/visual-brief/prompts.ts +147 -0
- package/src/resources/extensions/visual-brief/tests/visual-brief.test.ts +172 -0
- package/dist/web/standalone/.next/static/chunks/2556.0527fea66e123b7f.js +0 -1
- package/dist/web/standalone/.next/static/chunks/app/page-200592a7f3baf579.js +0 -1
- package/dist/web/standalone/.next/static/chunks/main-app-d3d4c336195465f9.js +0 -1
- package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-ab5a8926e07ec673.js +0 -1
- package/dist/web/standalone/.next/static/css/54ec2745c1da488b.css +0 -1
- package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +0 -1544
- /package/dist/web/standalone/.next/static/{drLMkgfHQ8lzS229_HWYR → Qgr2B_MRhPxC0z8fwv4vT}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{drLMkgfHQ8lzS229_HWYR → Qgr2B_MRhPxC0z8fwv4vT}/_ssgManifest.js +0 -0
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: ADR-017 roadmap-divergence drift handler. Detects mismatches
|
|
3
|
+
// between ROADMAP.md (parsed slice sequence + depends declarations) and the
|
|
4
|
+
// DB slice rows for that milestone, then reconciles via the markdown
|
|
5
|
+
// importer plus an explicit junction-table sync.
|
|
6
|
+
|
|
7
|
+
import { existsSync, readFileSync } from "node:fs";
|
|
8
|
+
|
|
9
|
+
import {
|
|
10
|
+
getMilestone,
|
|
11
|
+
getMilestoneSlices,
|
|
12
|
+
isDbAvailable,
|
|
13
|
+
syncSliceDependencies,
|
|
14
|
+
} from "../../gsd-db.js";
|
|
15
|
+
import { migrateHierarchyToDb } from "../../md-importer.js";
|
|
16
|
+
import { findMilestoneIds } from "../../milestone-ids.js";
|
|
17
|
+
import { parseRoadmap } from "../../parsers-legacy.js";
|
|
18
|
+
import { resolveMilestoneFile } from "../../paths.js";
|
|
19
|
+
import type { GSDState } from "../../types.js";
|
|
20
|
+
import type { DriftContext, DriftHandler, DriftRecord } from "../types.js";
|
|
21
|
+
|
|
22
|
+
type RoadmapDivergenceDrift = Extract<
|
|
23
|
+
DriftRecord,
|
|
24
|
+
{ kind: "roadmap-divergence" }
|
|
25
|
+
>;
|
|
26
|
+
|
|
27
|
+
function arraysEqual(a: readonly string[], b: readonly string[]): boolean {
|
|
28
|
+
if (a.length !== b.length) return false;
|
|
29
|
+
for (let i = 0; i < a.length; i++) if (a[i] !== b[i]) return false;
|
|
30
|
+
return true;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
function milestoneHasDivergence(
|
|
34
|
+
basePath: string,
|
|
35
|
+
milestoneId: string,
|
|
36
|
+
): boolean {
|
|
37
|
+
const roadmapPath = resolveMilestoneFile(basePath, milestoneId, "ROADMAP");
|
|
38
|
+
if (!roadmapPath || !existsSync(roadmapPath)) return false;
|
|
39
|
+
|
|
40
|
+
let roadmap: ReturnType<typeof parseRoadmap>;
|
|
41
|
+
try {
|
|
42
|
+
roadmap = parseRoadmap(readFileSync(roadmapPath, "utf-8"));
|
|
43
|
+
} catch {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const dbSlices = getMilestoneSlices(milestoneId);
|
|
48
|
+
const dbSliceMap = new Map(dbSlices.map((s) => [s.id, s]));
|
|
49
|
+
|
|
50
|
+
for (let i = 0; i < roadmap.slices.length; i++) {
|
|
51
|
+
const roadmapSlice = roadmap.slices[i]!;
|
|
52
|
+
const expectedSequence = i + 1;
|
|
53
|
+
const dbSlice = dbSliceMap.get(roadmapSlice.id);
|
|
54
|
+
if (!dbSlice) return true; // Roadmap has a slice the DB doesn't.
|
|
55
|
+
if (dbSlice.sequence !== expectedSequence) return true;
|
|
56
|
+
if (!arraysEqual(dbSlice.depends, roadmapSlice.depends)) return true;
|
|
57
|
+
}
|
|
58
|
+
return false;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export function detectRoadmapDivergenceDrift(
|
|
62
|
+
_state: GSDState,
|
|
63
|
+
ctx: DriftContext,
|
|
64
|
+
): RoadmapDivergenceDrift[] {
|
|
65
|
+
if (!isDbAvailable()) return [];
|
|
66
|
+
|
|
67
|
+
const drifts: RoadmapDivergenceDrift[] = [];
|
|
68
|
+
for (const milestoneId of findMilestoneIds(ctx.basePath)) {
|
|
69
|
+
// Skip milestones that don't yet have a DB row — that's the
|
|
70
|
+
// unregistered-milestone drift handler's responsibility.
|
|
71
|
+
if (!getMilestone(milestoneId)) continue;
|
|
72
|
+
if (milestoneHasDivergence(ctx.basePath, milestoneId)) {
|
|
73
|
+
drifts.push({ kind: "roadmap-divergence", milestoneId });
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return drifts;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* Repair a milestone's roadmap divergence:
|
|
81
|
+
* 1. migrateHierarchyToDb upserts slice rows (sequence + depends JSON
|
|
82
|
+
* update via ON CONFLICT DO UPDATE).
|
|
83
|
+
* 2. syncSliceDependencies updates the junction table per slice — the
|
|
84
|
+
* importer only writes the JSON column, not the relational view.
|
|
85
|
+
*/
|
|
86
|
+
export function repairRoadmapDivergence(
|
|
87
|
+
record: RoadmapDivergenceDrift,
|
|
88
|
+
ctx: DriftContext,
|
|
89
|
+
): void {
|
|
90
|
+
migrateHierarchyToDb(ctx.basePath);
|
|
91
|
+
|
|
92
|
+
const roadmapPath = resolveMilestoneFile(ctx.basePath, record.milestoneId, "ROADMAP");
|
|
93
|
+
if (!roadmapPath || !existsSync(roadmapPath)) return;
|
|
94
|
+
|
|
95
|
+
try {
|
|
96
|
+
const roadmap = parseRoadmap(readFileSync(roadmapPath, "utf-8"));
|
|
97
|
+
for (const slice of roadmap.slices) {
|
|
98
|
+
syncSliceDependencies(record.milestoneId, slice.id, slice.depends);
|
|
99
|
+
}
|
|
100
|
+
} catch {
|
|
101
|
+
/* parse failure: detector will fire again next pass */
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
export const roadmapDivergenceHandler: DriftHandler<RoadmapDivergenceDrift> = {
|
|
106
|
+
kind: "roadmap-divergence",
|
|
107
|
+
detect: detectRoadmapDivergenceDrift,
|
|
108
|
+
repair: repairRoadmapDivergence,
|
|
109
|
+
};
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: ADR-017 stale-sketch-flag drift handler. Relocated from
|
|
3
|
+
// gsd-db.ts where autoHealSketchFlags previously lived with zero callers.
|
|
4
|
+
//
|
|
5
|
+
// Recovers from two scenarios (per ADR-011):
|
|
6
|
+
// 1. Crash between gsd_plan_slice's PLAN.md write and the sketch flag flip.
|
|
7
|
+
// 2. Flag-OFF downgrade: when progressive_planning is off, dispatch routes
|
|
8
|
+
// sketch slices to plan-slice, which writes PLAN.md but leaves
|
|
9
|
+
// is_sketch=1 — the next reconciliation pass clears it.
|
|
10
|
+
|
|
11
|
+
import { existsSync } from "node:fs";
|
|
12
|
+
|
|
13
|
+
import {
|
|
14
|
+
getSketchedSliceIds,
|
|
15
|
+
isDbAvailable,
|
|
16
|
+
setSliceSketchFlag,
|
|
17
|
+
} from "../../gsd-db.js";
|
|
18
|
+
import { resolveSliceFile } from "../../paths.js";
|
|
19
|
+
import type { GSDState } from "../../types.js";
|
|
20
|
+
import type { DriftContext, DriftHandler, DriftRecord } from "../types.js";
|
|
21
|
+
|
|
22
|
+
type SketchFlagDrift = Extract<DriftRecord, { kind: "stale-sketch-flag" }>;
|
|
23
|
+
|
|
24
|
+
export function detectStaleSketchFlags(
|
|
25
|
+
state: GSDState,
|
|
26
|
+
ctx: DriftContext,
|
|
27
|
+
): SketchFlagDrift[] {
|
|
28
|
+
if (!isDbAvailable()) return [];
|
|
29
|
+
const mid = state.activeMilestone?.id;
|
|
30
|
+
if (!mid) return [];
|
|
31
|
+
|
|
32
|
+
const sliceIds = getSketchedSliceIds(mid);
|
|
33
|
+
return sliceIds
|
|
34
|
+
.filter((sid) => {
|
|
35
|
+
const planPath = resolveSliceFile(ctx.basePath, mid, sid, "PLAN");
|
|
36
|
+
return planPath !== null && existsSync(planPath);
|
|
37
|
+
})
|
|
38
|
+
.map((sid) => ({ kind: "stale-sketch-flag" as const, mid, sid }));
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export function repairStaleSketchFlag(record: SketchFlagDrift): void {
|
|
42
|
+
setSliceSketchFlag(record.mid, record.sid, false);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export const sketchFlagHandler: DriftHandler<SketchFlagDrift> = {
|
|
46
|
+
kind: "stale-sketch-flag",
|
|
47
|
+
detect: detectStaleSketchFlags,
|
|
48
|
+
repair: (record) => {
|
|
49
|
+
repairStaleSketchFlag(record);
|
|
50
|
+
},
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
/**
|
|
54
|
+
* Legacy entry point preserved for callers that supply a custom hasPlanFile
|
|
55
|
+
* predicate. Prefer the drift handler (sketchFlagHandler) for new code.
|
|
56
|
+
*/
|
|
57
|
+
export function autoHealSketchFlags(
|
|
58
|
+
milestoneId: string,
|
|
59
|
+
hasPlanFile: (sliceId: string) => boolean,
|
|
60
|
+
): void {
|
|
61
|
+
if (!isDbAvailable()) return;
|
|
62
|
+
const sliceIds = getSketchedSliceIds(milestoneId);
|
|
63
|
+
for (const sid of sliceIds) {
|
|
64
|
+
if (hasPlanFile(sid)) {
|
|
65
|
+
setSliceSketchFlag(milestoneId, sid, false);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: ADR-017 stale-render drift handler. Relocated from
|
|
3
|
+
// markdown-renderer.ts as part of issue #5702. detectStaleRenders stays in
|
|
4
|
+
// markdown-renderer.ts (it's a useful diagnostic primitive on its own); only
|
|
5
|
+
// the detect+repair composition moves here. The previous repairStaleRenders
|
|
6
|
+
// had zero callers in production code — wiring it through
|
|
7
|
+
// reconcileBeforeDispatch closes that gap.
|
|
8
|
+
|
|
9
|
+
import {
|
|
10
|
+
detectStaleRenders,
|
|
11
|
+
renderPlanCheckboxes,
|
|
12
|
+
renderRoadmapCheckboxes,
|
|
13
|
+
renderSliceSummary,
|
|
14
|
+
renderTaskSummary,
|
|
15
|
+
} from "../../markdown-renderer.js";
|
|
16
|
+
import type { GSDState } from "../../types.js";
|
|
17
|
+
import { logWarning } from "../../workflow-logger.js";
|
|
18
|
+
import type { DriftContext, DriftHandler, DriftRecord } from "../types.js";
|
|
19
|
+
|
|
20
|
+
type StaleRenderDrift = Extract<DriftRecord, { kind: "stale-render" }>;
|
|
21
|
+
|
|
22
|
+
// ─── Core (basePath-only — usable by both drift API and legacy wrapper) ──────
|
|
23
|
+
|
|
24
|
+
function detectStaleRenderDriftFromBasePath(basePath: string): StaleRenderDrift[] {
|
|
25
|
+
const entries = detectStaleRenders(basePath);
|
|
26
|
+
if (entries.length === 0) return [];
|
|
27
|
+
|
|
28
|
+
// detectStaleRenders may emit multiple entries for the same path (one per
|
|
29
|
+
// mismatched checkbox). Dedupe by path; the repair re-renders the whole
|
|
30
|
+
// file in a single call. Prefer a reason the repair dispatcher can handle.
|
|
31
|
+
const seen = new Map<string, string>();
|
|
32
|
+
for (const entry of entries) {
|
|
33
|
+
const currentReason = seen.get(entry.path);
|
|
34
|
+
if (
|
|
35
|
+
currentReason === undefined ||
|
|
36
|
+
(!isRepairableStaleRenderReason(currentReason) && isRepairableStaleRenderReason(entry.reason))
|
|
37
|
+
) {
|
|
38
|
+
seen.set(entry.path, entry.reason);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
return Array.from(seen.entries()).map(([renderPath, reason]) => ({
|
|
43
|
+
kind: "stale-render" as const,
|
|
44
|
+
renderPath,
|
|
45
|
+
reason,
|
|
46
|
+
}));
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
function isRepairableStaleRenderReason(reason: string): boolean {
|
|
50
|
+
return (
|
|
51
|
+
reason.includes("in roadmap") ||
|
|
52
|
+
reason.includes("in plan") ||
|
|
53
|
+
(reason.includes("SUMMARY.md missing") && /^T\d+/.test(reason)) ||
|
|
54
|
+
(reason.includes("SUMMARY.md missing") && /^S\d+/.test(reason)) ||
|
|
55
|
+
reason.includes("UAT.md missing")
|
|
56
|
+
);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
async function repairStaleRenderFromBasePath(
|
|
60
|
+
record: StaleRenderDrift,
|
|
61
|
+
basePath: string,
|
|
62
|
+
): Promise<void> {
|
|
63
|
+
const normPath = record.renderPath.replace(/\\/g, "/");
|
|
64
|
+
const reason = record.reason;
|
|
65
|
+
|
|
66
|
+
if (reason.includes("in roadmap")) {
|
|
67
|
+
const milestoneMatch = normPath.match(/milestones\/([^/]+)\//);
|
|
68
|
+
if (!milestoneMatch) {
|
|
69
|
+
throw new Error(
|
|
70
|
+
`stale-render drift: roadmap path missing milestone segment: ${record.renderPath}`,
|
|
71
|
+
);
|
|
72
|
+
}
|
|
73
|
+
await renderRoadmapCheckboxes(basePath, milestoneMatch[1]);
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
if (reason.includes("in plan")) {
|
|
78
|
+
const pathMatch = normPath.match(/milestones\/([^/]+)\/slices\/([^/]+)\//);
|
|
79
|
+
if (!pathMatch) {
|
|
80
|
+
throw new Error(
|
|
81
|
+
`stale-render drift: plan path missing milestone/slice segments: ${record.renderPath}`,
|
|
82
|
+
);
|
|
83
|
+
}
|
|
84
|
+
await renderPlanCheckboxes(basePath, pathMatch[1], pathMatch[2]);
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
if (reason.includes("SUMMARY.md missing") && /^T\d+/.test(reason)) {
|
|
89
|
+
const pathMatch = normPath.match(
|
|
90
|
+
/milestones\/([^/]+)\/slices\/([^/]+)\/tasks\//,
|
|
91
|
+
);
|
|
92
|
+
const taskMatch = reason.match(/^(T\d+)/);
|
|
93
|
+
if (!pathMatch || !taskMatch) {
|
|
94
|
+
throw new Error(
|
|
95
|
+
`stale-render drift: task summary path/reason malformed: ${record.renderPath} reason=${reason}`,
|
|
96
|
+
);
|
|
97
|
+
}
|
|
98
|
+
await renderTaskSummary(basePath, pathMatch[1], pathMatch[2], taskMatch[1]);
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
if (reason.includes("SUMMARY.md missing") && /^S\d+/.test(reason)) {
|
|
103
|
+
const pathMatch = normPath.match(/milestones\/([^/]+)\/slices\/([^/]+)\//);
|
|
104
|
+
if (!pathMatch) {
|
|
105
|
+
throw new Error(
|
|
106
|
+
`stale-render drift: slice summary path missing milestone/slice segments: ${record.renderPath}`,
|
|
107
|
+
);
|
|
108
|
+
}
|
|
109
|
+
await renderSliceSummary(basePath, pathMatch[1], pathMatch[2]);
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
if (reason.includes("UAT.md missing")) {
|
|
114
|
+
const pathMatch = normPath.match(/milestones\/([^/]+)\/slices\/([^/]+)\//);
|
|
115
|
+
if (!pathMatch) {
|
|
116
|
+
throw new Error(
|
|
117
|
+
`stale-render drift: UAT path missing milestone/slice segments: ${record.renderPath}`,
|
|
118
|
+
);
|
|
119
|
+
}
|
|
120
|
+
// renderSliceSummary handles both SUMMARY and UAT.
|
|
121
|
+
await renderSliceSummary(basePath, pathMatch[1], pathMatch[2]);
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
throw new Error(
|
|
126
|
+
`stale-render drift: detector emitted unknown reason "${reason}" for ${record.renderPath}`,
|
|
127
|
+
);
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
// ─── Drift Handler API ───────────────────────────────────────────────────────
|
|
131
|
+
|
|
132
|
+
export function detectStaleRenderDrift(
|
|
133
|
+
_state: GSDState,
|
|
134
|
+
ctx: DriftContext,
|
|
135
|
+
): StaleRenderDrift[] {
|
|
136
|
+
return detectStaleRenderDriftFromBasePath(ctx.basePath);
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
export async function repairStaleRender(
|
|
140
|
+
record: StaleRenderDrift,
|
|
141
|
+
ctx: DriftContext,
|
|
142
|
+
): Promise<void> {
|
|
143
|
+
await repairStaleRenderFromBasePath(record, ctx.basePath);
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
export const staleRenderHandler: DriftHandler<StaleRenderDrift> = {
|
|
147
|
+
kind: "stale-render",
|
|
148
|
+
detect: detectStaleRenderDrift,
|
|
149
|
+
repair: repairStaleRender,
|
|
150
|
+
};
|
|
151
|
+
|
|
152
|
+
// ─── Legacy entry point ──────────────────────────────────────────────────────
|
|
153
|
+
|
|
154
|
+
/**
|
|
155
|
+
* Legacy bulk entry preserved for existing tests
|
|
156
|
+
* (tests/markdown-renderer.test.ts, tests/integration/integration-proof.test.ts).
|
|
157
|
+
* New code prefers the drift handler via `reconcileBeforeDispatch`. Matches the
|
|
158
|
+
* pre-ADR-017 behavior: silent per-entry error handling, returns the count of
|
|
159
|
+
* successful repairs.
|
|
160
|
+
*/
|
|
161
|
+
export async function repairStaleRenders(basePath: string): Promise<number> {
|
|
162
|
+
const drifts = detectStaleRenderDriftFromBasePath(basePath);
|
|
163
|
+
if (drifts.length === 0) return 0;
|
|
164
|
+
|
|
165
|
+
let repaired = 0;
|
|
166
|
+
for (const drift of drifts) {
|
|
167
|
+
try {
|
|
168
|
+
await repairStaleRenderFromBasePath(drift, basePath);
|
|
169
|
+
repaired++;
|
|
170
|
+
} catch (err) {
|
|
171
|
+
logWarning(
|
|
172
|
+
"renderer",
|
|
173
|
+
`repair failed for ${drift.renderPath}: ${(err as Error).message}`,
|
|
174
|
+
);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
if (repaired > 0) {
|
|
179
|
+
process.stderr.write(
|
|
180
|
+
`markdown-renderer: repaired ${repaired} stale render(s)\n`,
|
|
181
|
+
);
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
return repaired;
|
|
185
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: ADR-017 stale-worker drift handler. Detects session-lock
|
|
3
|
+
// artifacts whose owning PID is no longer alive (typical after SIGKILL or
|
|
4
|
+
// laptop sleep where the heartbeat wasn't released cleanly), and clears them
|
|
5
|
+
// before the next dispatch attempts to acquire the lock.
|
|
6
|
+
|
|
7
|
+
import {
|
|
8
|
+
effectiveLockFile,
|
|
9
|
+
isSessionLockProcessAlive,
|
|
10
|
+
readSessionLockData,
|
|
11
|
+
removeStaleSessionLock,
|
|
12
|
+
} from "../../session-lock.js";
|
|
13
|
+
import type { GSDState } from "../../types.js";
|
|
14
|
+
import type { DriftContext, DriftHandler, DriftRecord } from "../types.js";
|
|
15
|
+
|
|
16
|
+
type StaleWorkerDrift = Extract<DriftRecord, { kind: "stale-worker" }>;
|
|
17
|
+
|
|
18
|
+
export function detectStaleWorkerDrift(
|
|
19
|
+
_state: GSDState,
|
|
20
|
+
ctx: DriftContext,
|
|
21
|
+
): StaleWorkerDrift[] {
|
|
22
|
+
const data = readSessionLockData(ctx.basePath);
|
|
23
|
+
if (!data) return [];
|
|
24
|
+
if (typeof data.pid !== "number") return [];
|
|
25
|
+
if (isSessionLockProcessAlive(data)) return [];
|
|
26
|
+
|
|
27
|
+
return [
|
|
28
|
+
{
|
|
29
|
+
kind: "stale-worker",
|
|
30
|
+
lockPath: effectiveLockFile(),
|
|
31
|
+
pid: data.pid,
|
|
32
|
+
},
|
|
33
|
+
];
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export function repairStaleWorker(_record: StaleWorkerDrift, ctx: DriftContext): void {
|
|
37
|
+
// removeStaleSessionLock is idempotent: it re-reads lock state and is a
|
|
38
|
+
// no-op when the lock is held by an alive process. Safe under cap=2 retry.
|
|
39
|
+
removeStaleSessionLock(ctx.basePath);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export const staleWorkerHandler: DriftHandler<StaleWorkerDrift> = {
|
|
43
|
+
kind: "stale-worker",
|
|
44
|
+
detect: detectStaleWorkerDrift,
|
|
45
|
+
repair: repairStaleWorker,
|
|
46
|
+
};
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: ADR-017 typed reconciliation failure for Recovery Classification.
|
|
3
|
+
|
|
4
|
+
import type { DriftRecord } from "./types.js";
|
|
5
|
+
|
|
6
|
+
export interface ReconciliationFailureDetail {
|
|
7
|
+
drift: DriftRecord;
|
|
8
|
+
cause: unknown;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export interface ReconciliationDetectionFailureDetail {
|
|
12
|
+
handlerKind: string;
|
|
13
|
+
phase: "detect";
|
|
14
|
+
basePath: string;
|
|
15
|
+
statePhase?: string;
|
|
16
|
+
activeMilestoneId?: string;
|
|
17
|
+
cause: unknown;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export interface ReconciliationFailedErrorOptions {
|
|
21
|
+
failures?: ReadonlyArray<ReconciliationFailureDetail>;
|
|
22
|
+
detectionFailures?: ReadonlyArray<ReconciliationDetectionFailureDetail>;
|
|
23
|
+
persistentDrift?: ReadonlyArray<DriftRecord>;
|
|
24
|
+
pass?: number;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Thrown by reconcileBeforeDispatch when:
|
|
29
|
+
* - one or more repair functions throw within a pass (`failures` populated), or
|
|
30
|
+
* - drift persists after the cap=2 lifecycle (`persistentDrift` populated).
|
|
31
|
+
*
|
|
32
|
+
* Recovery Classification recognizes this error via instanceof and maps it to
|
|
33
|
+
* failureKind "reconciliation-drift" with action "escalate".
|
|
34
|
+
*/
|
|
35
|
+
export class ReconciliationFailedError extends Error {
|
|
36
|
+
readonly failures: ReadonlyArray<ReconciliationFailureDetail>;
|
|
37
|
+
readonly detectionFailures: ReadonlyArray<ReconciliationDetectionFailureDetail>;
|
|
38
|
+
readonly persistentDrift: ReadonlyArray<DriftRecord>;
|
|
39
|
+
readonly pass?: number;
|
|
40
|
+
|
|
41
|
+
constructor(opts: ReconciliationFailedErrorOptions) {
|
|
42
|
+
super(formatMessage(opts));
|
|
43
|
+
this.name = "ReconciliationFailedError";
|
|
44
|
+
this.failures = opts.failures ?? [];
|
|
45
|
+
this.detectionFailures = opts.detectionFailures ?? [];
|
|
46
|
+
this.persistentDrift = opts.persistentDrift ?? [];
|
|
47
|
+
this.pass = opts.pass;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
function formatMessage(opts: ReconciliationFailedErrorOptions): string {
|
|
52
|
+
if (opts.detectionFailures && opts.detectionFailures.length > 0) {
|
|
53
|
+
const kinds = opts.detectionFailures.map((f) => f.handlerKind).join(", ");
|
|
54
|
+
const passSuffix = opts.pass !== undefined ? ` in pass ${opts.pass}` : "";
|
|
55
|
+
return `Reconciliation detect failed${passSuffix} for handlers: ${kinds}`;
|
|
56
|
+
}
|
|
57
|
+
if (opts.failures && opts.failures.length > 0) {
|
|
58
|
+
const kinds = opts.failures.map((f) => f.drift.kind).join(", ");
|
|
59
|
+
const passSuffix = opts.pass !== undefined ? ` in pass ${opts.pass}` : "";
|
|
60
|
+
return `Reconciliation repair failed${passSuffix} for drift kinds: ${kinds}`;
|
|
61
|
+
}
|
|
62
|
+
if (opts.persistentDrift && opts.persistentDrift.length > 0) {
|
|
63
|
+
const kinds = opts.persistentDrift.map((d) => d.kind).join(", ");
|
|
64
|
+
return `Reconciliation drift persisted after cap=2 passes: ${kinds}`;
|
|
65
|
+
}
|
|
66
|
+
return "Reconciliation failed";
|
|
67
|
+
}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: ADR-017 drift-driven State Reconciliation Module entry point.
|
|
3
|
+
// reconcileBeforeDispatch runs before every Dispatch decision and worker spawn.
|
|
4
|
+
|
|
5
|
+
import {
|
|
6
|
+
deriveState as defaultDeriveState,
|
|
7
|
+
invalidateStateCache as defaultInvalidate,
|
|
8
|
+
} from "../state.js";
|
|
9
|
+
import type { GSDState } from "../types.js";
|
|
10
|
+
|
|
11
|
+
import {
|
|
12
|
+
ReconciliationFailedError,
|
|
13
|
+
type ReconciliationFailureDetail,
|
|
14
|
+
} from "./errors.js";
|
|
15
|
+
import { DRIFT_REGISTRY } from "./registry.js";
|
|
16
|
+
import type {
|
|
17
|
+
DriftContext,
|
|
18
|
+
DriftHandler,
|
|
19
|
+
DriftRecord,
|
|
20
|
+
ReconciliationDeps,
|
|
21
|
+
ReconciliationResult,
|
|
22
|
+
} from "./types.js";
|
|
23
|
+
|
|
24
|
+
export type {
|
|
25
|
+
DriftContext,
|
|
26
|
+
DriftHandler,
|
|
27
|
+
DriftRecord,
|
|
28
|
+
ReconciliationDeps,
|
|
29
|
+
ReconciliationResult,
|
|
30
|
+
} from "./types.js";
|
|
31
|
+
export { ReconciliationFailedError } from "./errors.js";
|
|
32
|
+
export type { ReconciliationFailureDetail } from "./errors.js";
|
|
33
|
+
export { DRIFT_REGISTRY } from "./registry.js";
|
|
34
|
+
|
|
35
|
+
const MAX_PASSES = 2;
|
|
36
|
+
|
|
37
|
+
const defaultDeps: ReconciliationDeps = {
|
|
38
|
+
invalidateStateCache: defaultInvalidate,
|
|
39
|
+
deriveState: defaultDeriveState,
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Drift-driven pre-dispatch reconciliation per ADR-017.
|
|
44
|
+
*
|
|
45
|
+
* Lifecycle: derive → detect drift → apply repairs → re-derive. Capped at
|
|
46
|
+
* MAX_PASSES (=2) cycles. The loop runs only when the prior pass fully
|
|
47
|
+
* succeeded but re-derive surfaces NEW drift (cascading repairs — e.g.
|
|
48
|
+
* fixing milestone registration uncovers a downstream completion-timestamp
|
|
49
|
+
* drift).
|
|
50
|
+
*
|
|
51
|
+
* Returns ok=true with `repaired` and terminal `blockers` populated.
|
|
52
|
+
* Throws ReconciliationFailedError when:
|
|
53
|
+
* - any repair function throws within a pass, or
|
|
54
|
+
* - drift persists after the cap.
|
|
55
|
+
*/
|
|
56
|
+
export async function reconcileBeforeDispatch(
|
|
57
|
+
basePath: string,
|
|
58
|
+
deps: ReconciliationDeps = defaultDeps,
|
|
59
|
+
): Promise<ReconciliationResult> {
|
|
60
|
+
const registry = deps.registry ?? DRIFT_REGISTRY;
|
|
61
|
+
const repaired: DriftRecord[] = [];
|
|
62
|
+
|
|
63
|
+
for (let pass = 0; pass < MAX_PASSES; pass++) {
|
|
64
|
+
deps.invalidateStateCache();
|
|
65
|
+
const stateSnapshot = await deps.deriveState(basePath, deps.deriveStateOptions);
|
|
66
|
+
const ctx: DriftContext = { basePath, state: stateSnapshot };
|
|
67
|
+
|
|
68
|
+
const drift = await detectAllDrift(stateSnapshot, ctx, registry, pass);
|
|
69
|
+
if (drift.length === 0) {
|
|
70
|
+
return {
|
|
71
|
+
ok: true,
|
|
72
|
+
stateSnapshot,
|
|
73
|
+
repaired,
|
|
74
|
+
blockers: stateSnapshot.blockers ?? [],
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
const failures: ReconciliationFailureDetail[] = [];
|
|
79
|
+
for (const record of drift) {
|
|
80
|
+
const handler = registry.find((h) => h.kind === record.kind);
|
|
81
|
+
if (!handler) {
|
|
82
|
+
failures.push({
|
|
83
|
+
drift: record,
|
|
84
|
+
cause: new Error(
|
|
85
|
+
`No drift handler registered for kind "${record.kind}"`,
|
|
86
|
+
),
|
|
87
|
+
});
|
|
88
|
+
continue;
|
|
89
|
+
}
|
|
90
|
+
try {
|
|
91
|
+
await handler.repair(record, ctx);
|
|
92
|
+
repaired.push(record);
|
|
93
|
+
} catch (cause) {
|
|
94
|
+
failures.push({ drift: record, cause });
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
if (failures.length > 0) {
|
|
99
|
+
throw new ReconciliationFailedError({ failures, pass });
|
|
100
|
+
}
|
|
101
|
+
// Pass fully succeeded; loop runs again to detect cascading drift.
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
// After MAX_PASSES, one more derive+detect to verify nothing persists.
|
|
105
|
+
deps.invalidateStateCache();
|
|
106
|
+
const finalState = await deps.deriveState(basePath, deps.deriveStateOptions);
|
|
107
|
+
const finalCtx: DriftContext = { basePath, state: finalState };
|
|
108
|
+
const persistent = await detectAllDrift(finalState, finalCtx, registry);
|
|
109
|
+
|
|
110
|
+
if (persistent.length > 0) {
|
|
111
|
+
throw new ReconciliationFailedError({ persistentDrift: persistent });
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
return {
|
|
115
|
+
ok: true,
|
|
116
|
+
stateSnapshot: finalState,
|
|
117
|
+
repaired,
|
|
118
|
+
blockers: finalState.blockers ?? [],
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
async function detectAllDrift(
|
|
123
|
+
state: GSDState,
|
|
124
|
+
ctx: DriftContext,
|
|
125
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
126
|
+
registry: ReadonlyArray<DriftHandler<any>>,
|
|
127
|
+
pass?: number,
|
|
128
|
+
): Promise<DriftRecord[]> {
|
|
129
|
+
const collected: DriftRecord[] = [];
|
|
130
|
+
for (const handler of registry) {
|
|
131
|
+
try {
|
|
132
|
+
const detected = await handler.detect(state, ctx);
|
|
133
|
+
collected.push(...detected);
|
|
134
|
+
} catch (cause) {
|
|
135
|
+
throw new ReconciliationFailedError({
|
|
136
|
+
failures: [{ drift: { kind: handler.kind } as DriftRecord, cause }],
|
|
137
|
+
pass,
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
return collected;
|
|
142
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: ADR-017 drift handler registry. Single source of truth for
|
|
3
|
+
// the catalog. Tests can override per-call via ReconciliationDeps.registry.
|
|
4
|
+
|
|
5
|
+
import { completionTimestampHandler } from "./drift/completion.js";
|
|
6
|
+
import { mergeStateHandler } from "./drift/merge-state.js";
|
|
7
|
+
import { unregisteredMilestoneHandler } from "./drift/project-md.js";
|
|
8
|
+
import { roadmapDivergenceHandler } from "./drift/roadmap.js";
|
|
9
|
+
import { sketchFlagHandler } from "./drift/sketch-flag.js";
|
|
10
|
+
import { staleRenderHandler } from "./drift/stale-render.js";
|
|
11
|
+
import { staleWorkerHandler } from "./drift/stale-worker.js";
|
|
12
|
+
import type { DriftHandler } from "./types.js";
|
|
13
|
+
|
|
14
|
+
// Each handler is parameterized over its specific DriftRecord variant for
|
|
15
|
+
// internal type safety. The registry stores them under DriftHandler<any> so
|
|
16
|
+
// handlers with disjoint repair parameter types coexist; the lifecycle matches
|
|
17
|
+
// by kind before invoking repair, so this is sound at runtime.
|
|
18
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
19
|
+
export const DRIFT_REGISTRY: ReadonlyArray<DriftHandler<any>> = [
|
|
20
|
+
sketchFlagHandler,
|
|
21
|
+
mergeStateHandler,
|
|
22
|
+
staleRenderHandler,
|
|
23
|
+
staleWorkerHandler,
|
|
24
|
+
unregisteredMilestoneHandler,
|
|
25
|
+
roadmapDivergenceHandler,
|
|
26
|
+
completionTimestampHandler,
|
|
27
|
+
];
|