@opengsd/gsd-pi 1.2.0-dev.b1abb545 → 1.2.0-dev.d6c5343c
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/dist/cli-style.d.ts +17 -0
- package/dist/cli-style.js +28 -0
- package/dist/cli.js +1 -1
- package/dist/headless-events.d.ts +4 -2
- package/dist/headless-events.js +14 -34
- package/dist/models-resolver.d.ts +3 -13
- package/dist/models-resolver.js +3 -22
- package/dist/resource-loader.js +2 -14
- package/dist/resources/.managed-resources-content-hash +1 -1
- package/dist/resources/GSD-WORKFLOW.md +5 -4
- package/dist/resources/extensions/async-jobs/async-bash-tool.js +30 -64
- package/dist/resources/extensions/async-jobs/await-tool.js +80 -12
- package/dist/resources/extensions/async-jobs/index.js +65 -0
- package/dist/resources/extensions/async-jobs/job-manager.js +12 -1
- package/dist/resources/extensions/bg-shell/bg-shell-command.js +6 -6
- package/dist/resources/extensions/bg-shell/bg-shell-tool.js +10 -7
- package/dist/resources/extensions/bg-shell/overlay.js +9 -6
- package/dist/resources/extensions/bg-shell/process-manager.js +54 -25
- package/dist/resources/extensions/bg-shell/readiness-detector.js +11 -0
- package/dist/resources/extensions/bg-shell/utilities.js +5 -2
- package/dist/resources/extensions/browser-tools/engine/managed-gsd-browser.js +209 -88
- package/dist/resources/extensions/browser-tools/engine/selection.js +73 -5
- package/dist/resources/extensions/browser-tools/index.js +69 -12
- package/dist/resources/extensions/claude-code-cli/models.js +9 -0
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +38 -6
- package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +17 -2
- package/dist/resources/extensions/gsd/auto/detect-stuck.js +33 -13
- package/dist/resources/extensions/gsd/auto/dispatch-history.js +105 -0
- package/dist/resources/extensions/gsd/auto/dispatch-key.js +37 -0
- package/dist/resources/extensions/gsd/auto/loop.js +4 -1
- package/dist/resources/extensions/gsd/auto/orchestrator.js +94 -48
- package/dist/resources/extensions/gsd/auto/phases.js +8 -3
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +8 -32
- package/dist/resources/extensions/gsd/auto-dispatch.js +40 -57
- package/dist/resources/extensions/gsd/auto-model-selection.js +25 -6
- package/dist/resources/extensions/gsd/auto-post-unit.js +31 -14
- package/dist/resources/extensions/gsd/auto-prompts.js +81 -19
- package/dist/resources/extensions/gsd/auto-start.js +24 -26
- package/dist/resources/extensions/gsd/auto-tool-tracking.js +18 -0
- package/dist/resources/extensions/gsd/auto-unit-tool-scope.js +12 -20
- package/dist/resources/extensions/gsd/auto-verification.js +9 -28
- package/dist/resources/extensions/gsd/auto-worktree-repair.js +10 -2
- package/dist/resources/extensions/gsd/auto-worktree.js +35 -352
- package/dist/resources/extensions/gsd/auto.js +8 -20
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +3 -2
- package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +32 -12
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +19 -0
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +229 -36
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +319 -71
- package/dist/resources/extensions/gsd/branch-patterns.js +2 -0
- package/dist/resources/extensions/gsd/browser-daemon-auto-prep.js +83 -0
- package/dist/resources/extensions/gsd/browser-evidence.js +8 -2
- package/dist/resources/extensions/gsd/captures.js +5 -15
- package/dist/resources/extensions/gsd/closeout-recovery.js +3 -2
- package/dist/resources/extensions/gsd/commands/catalog.js +6 -62
- package/dist/resources/extensions/gsd/consent-question.js +337 -0
- package/dist/resources/extensions/gsd/consent-verdict.js +63 -0
- package/dist/resources/extensions/gsd/constants.js +0 -2
- package/dist/resources/extensions/gsd/crash-recovery.js +4 -12
- package/dist/resources/extensions/gsd/db/engine.js +755 -0
- package/dist/resources/extensions/gsd/db/queries.js +398 -0
- package/dist/resources/extensions/gsd/db/sql-constants.js +11 -0
- package/dist/resources/extensions/gsd/db/writers/cascades.js +194 -0
- package/dist/resources/extensions/gsd/db/writers/import-restore.js +182 -0
- package/dist/resources/extensions/gsd/db/writers/memory.js +149 -0
- package/dist/resources/extensions/gsd/db/writers/reconcile.js +458 -0
- package/dist/resources/extensions/gsd/db/writers/status.js +70 -0
- package/dist/resources/extensions/gsd/dispatch-guard.js +10 -35
- package/dist/resources/extensions/gsd/doctor-environment.js +5 -11
- package/dist/resources/extensions/gsd/doctor-format.js +9 -6
- package/dist/resources/extensions/gsd/doctor-git-checks.js +4 -3
- package/dist/resources/extensions/gsd/doctor-runtime-checks.js +21 -16
- package/dist/resources/extensions/gsd/engine-hook-contract.js +70 -0
- package/dist/resources/extensions/gsd/error-classifier.js +9 -0
- package/dist/resources/extensions/gsd/exec-sandbox.js +30 -10
- package/dist/resources/extensions/gsd/files.js +33 -19
- package/dist/resources/extensions/gsd/git-service.js +1 -0
- package/dist/resources/extensions/gsd/gitignore.js +3 -0
- package/dist/resources/extensions/gsd/gsd-db.js +171 -2048
- package/dist/resources/extensions/gsd/guidance.js +158 -0
- package/dist/resources/extensions/gsd/guided-flow.js +51 -5
- package/dist/resources/extensions/gsd/markdown-renderer.js +10 -0
- package/dist/resources/extensions/gsd/mcp-filter.js +2 -19
- package/dist/resources/extensions/gsd/mcp-tool-name.js +5 -13
- package/dist/resources/extensions/gsd/memory-consolidation-scanner.js +1 -1
- package/dist/resources/extensions/gsd/migrate/safety.js +20 -9
- package/dist/resources/extensions/gsd/migration-auto-check.js +24 -3
- package/dist/resources/extensions/gsd/milestone-closeout.js +13 -23
- package/dist/resources/extensions/gsd/model-cost-table.js +1 -0
- package/dist/resources/extensions/gsd/model-router.js +3 -0
- package/dist/resources/extensions/gsd/notification-store.js +11 -4
- package/dist/resources/extensions/gsd/parallel-merge.js +14 -11
- package/dist/resources/extensions/gsd/parallel-monitor-overlay.js +11 -7
- package/dist/resources/extensions/gsd/parsers-legacy.js +16 -4
- package/dist/resources/extensions/gsd/paths.js +37 -24
- package/dist/resources/extensions/gsd/pre-execution-checks.js +91 -3
- package/dist/resources/extensions/gsd/preferences-models.js +14 -48
- package/dist/resources/extensions/gsd/preferences.js +14 -0
- package/dist/resources/extensions/gsd/prompts/complete-slice.md +2 -2
- package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/refine-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/replan-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/run-uat.md +6 -4
- package/dist/resources/extensions/gsd/prompts/system.md +5 -2
- package/dist/resources/extensions/gsd/provider-error-guidance.js +1 -5
- package/dist/resources/extensions/gsd/provider-switch-observer.js +1 -1
- package/dist/resources/extensions/gsd/publication.js +87 -0
- package/dist/resources/extensions/gsd/reactive-graph.js +8 -1
- package/dist/resources/extensions/gsd/recovery-classification.js +41 -87
- package/dist/resources/extensions/gsd/safety/destructive-confirmation.js +108 -0
- package/dist/resources/extensions/gsd/safety/evidence-collector.js +37 -4
- package/dist/resources/extensions/gsd/safety/evidence-cross-ref.js +7 -2
- package/dist/resources/extensions/gsd/safety/file-change-validator.js +10 -0
- package/dist/resources/extensions/gsd/state-transition-matrix.js +38 -0
- package/dist/resources/extensions/gsd/state.js +6 -20
- package/dist/resources/extensions/gsd/status-guards.js +56 -8
- package/dist/resources/extensions/gsd/stop-notice.js +57 -0
- package/dist/resources/extensions/gsd/tool-presentation-plan.js +4 -4
- package/dist/resources/extensions/gsd/tool-surface-readiness.js +56 -0
- package/dist/resources/extensions/gsd/tools/complete-slice.js +44 -53
- package/dist/resources/extensions/gsd/tools/exec-tool.js +10 -8
- package/dist/resources/extensions/gsd/tools/plan-slice.js +12 -6
- package/dist/resources/extensions/gsd/tools/reopen-milestone.js +11 -29
- package/dist/resources/extensions/gsd/tools/reopen-slice.js +14 -33
- package/dist/resources/extensions/gsd/tools/skip-slice.js +18 -36
- package/dist/resources/extensions/gsd/uat-policy.js +42 -16
- package/dist/resources/extensions/gsd/undo.js +8 -7
- package/dist/resources/extensions/gsd/unit-closeout.js +138 -0
- package/dist/resources/extensions/gsd/unit-context-composer.js +74 -1
- package/dist/resources/extensions/gsd/unit-context-manifest.js +4 -27
- package/dist/resources/extensions/gsd/unit-registry.js +337 -0
- package/dist/resources/extensions/gsd/unit-tool-contracts.js +9 -182
- package/dist/resources/extensions/gsd/verdict-parser.js +1 -1
- package/dist/resources/extensions/gsd/web-app-uat.js +45 -8
- package/dist/resources/extensions/gsd/workflow-tool-surface.js +1 -1
- package/dist/resources/extensions/gsd/worktree-git-recovery.js +293 -0
- package/dist/resources/extensions/gsd/worktree-lifecycle.js +12 -3
- package/dist/resources/extensions/gsd/worktree-manager.js +45 -28
- package/dist/resources/extensions/gsd/worktree-placement.js +59 -0
- package/dist/resources/extensions/gsd/worktree-reentry.js +12 -8
- package/dist/resources/extensions/gsd/worktree-root.js +28 -6
- package/dist/resources/extensions/gsd/worktree-safety.js +8 -5
- package/dist/resources/extensions/gsd/worktree-session-state.js +12 -11
- package/dist/resources/extensions/search-the-web/native-search.js +5 -3
- package/dist/resources/extensions/shared/browser-contract.js +59 -0
- package/dist/resources/extensions/shared/gsd-browser-cli.js +96 -5
- package/dist/resources/shared/package.json +3 -0
- package/dist/resources/skills/create-skill/references/executable-code.md +1 -1
- package/dist/resources/skills/create-skill/workflows/add-reference.md +8 -3
- package/dist/resources/skills/create-skill/workflows/add-script.md +4 -2
- package/dist/resources/skills/create-skill/workflows/add-template.md +3 -1
- package/dist/resources/skills/create-skill/workflows/add-workflow.md +8 -3
- package/dist/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
- package/dist/resources/skills/create-skill/workflows/verify-skill.md +9 -4
- package/dist/resources/skills/gsd-browser/SKILL.md +1 -1
- package/dist/resources/skills/spike-wrap-up/SKILL.md +9 -9
- 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 +8 -8
- package/dist/web/standalone/.next/build-manifest.json +3 -3
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/react-loadable-manifest.json +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.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +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.nft.json +1 -1
- 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.nft.json +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.nft.json +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.nft.json +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.nft.json +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.nft.json +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.nft.json +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/mcp-connections/route.js.nft.json +1 -1
- 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.nft.json +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.nft.json +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.nft.json +1 -1
- 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.nft.json +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/shutdown/route.js.nft.json +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.nft.json +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.nft.json +1 -1
- 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.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/update/route.js.nft.json +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 +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +8 -8
- package/dist/web/standalone/.next/server/chunks/5124.js +1 -1
- package/dist/web/standalone/.next/server/chunks/{5047.js → 5942.js} +2 -2
- package/dist/web/standalone/.next/server/chunks/8357.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/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/{796.cf859a427a2cb2ac.js → 796.e0bdc932325d7e03.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/{webpack-fbea77b5f9953368.js → webpack-f0285ce91d4ec9ef.js} +1 -1
- package/dist/web/standalone/package.json +1 -1
- package/dist/worktree-cli.js +3 -6
- package/dist/worktree-status-banner.js +7 -11
- package/package.json +1 -1
- package/packages/cloud-mcp-gateway/package.json +2 -2
- package/packages/contracts/dist/rpc.d.ts +1 -0
- package/packages/contracts/dist/rpc.d.ts.map +1 -1
- package/packages/contracts/dist/rpc.js.map +1 -1
- package/packages/contracts/dist/workflow.d.ts +4 -0
- package/packages/contracts/dist/workflow.d.ts.map +1 -1
- package/packages/contracts/dist/workflow.js.map +1 -1
- package/packages/contracts/package.json +1 -1
- package/packages/daemon/package.json +4 -4
- package/packages/gsd-agent-core/package.json +5 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +5 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js +8 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js +7 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js +8 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js +11 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js +4 -4
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js +3 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js.map +1 -1
- package/packages/gsd-agent-modes/package.json +7 -7
- package/packages/mcp-server/dist/cli.js +6 -3
- package/packages/mcp-server/dist/cli.js.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.d.ts +8 -0
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +46 -21
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/package.json +3 -3
- package/packages/native/package.json +1 -1
- package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts +1 -0
- package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/harness/env/nodejs.js +34 -3
- package/packages/pi-agent-core/dist/harness/env/nodejs.js.map +1 -1
- package/packages/pi-agent-core/dist/index.d.ts +1 -0
- package/packages/pi-agent-core/dist/index.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/index.js +3 -0
- package/packages/pi-agent-core/dist/index.js.map +1 -1
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-ai/README.md +1 -0
- package/packages/pi-ai/dist/models.generated.d.ts +192 -0
- package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
- package/packages/pi-ai/dist/models.generated.js +166 -0
- package/packages/pi-ai/dist/models.generated.js.map +1 -1
- package/packages/pi-ai/package.json +3 -2
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts +2 -2
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/auth-storage.js +19 -13
- package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/capability-patches.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/capability-patches.js +3 -1
- package/packages/pi-coding-agent/dist/core/capability-patches.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/provider-readiness.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/provider-readiness.js +13 -6
- package/packages/pi-coding-agent/dist/core/provider-readiness.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/bash.d.ts +11 -0
- package/packages/pi-coding-agent/dist/core/tools/bash.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/bash.js +53 -11
- package/packages/pi-coding-agent/dist/core/tools/bash.js.map +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/index.js +1 -1
- package/packages/pi-coding-agent/dist/index.js.map +1 -1
- package/packages/pi-coding-agent/dist/utils/shell.d.ts +28 -2
- package/packages/pi-coding-agent/dist/utils/shell.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/utils/shell.js +56 -10
- package/packages/pi-coding-agent/dist/utils/shell.js.map +1 -1
- package/packages/pi-coding-agent/package.json +7 -7
- package/packages/pi-tui/dist/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +9 -0
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/package.json +2 -2
- package/packages/rpc-client/package.json +2 -2
- package/pkg/package.json +1 -1
- package/src/resources/GSD-WORKFLOW.md +5 -4
- package/src/resources/extensions/async-jobs/async-bash-cancel.test.ts +360 -0
- package/src/resources/extensions/async-jobs/async-bash-tool.ts +33 -56
- package/src/resources/extensions/async-jobs/await-tool.test.ts +139 -0
- package/src/resources/extensions/async-jobs/await-tool.ts +82 -12
- package/src/resources/extensions/async-jobs/index.ts +79 -0
- package/src/resources/extensions/async-jobs/job-manager.ts +21 -1
- package/src/resources/extensions/bg-shell/bg-shell-command.ts +6 -6
- package/src/resources/extensions/bg-shell/bg-shell-tool.ts +10 -6
- package/src/resources/extensions/bg-shell/overlay.ts +9 -5
- package/src/resources/extensions/bg-shell/process-manager.ts +50 -25
- package/src/resources/extensions/bg-shell/readiness-detector.ts +12 -0
- package/src/resources/extensions/bg-shell/tests/lifecycle-and-utilities.test.ts +48 -1
- package/src/resources/extensions/bg-shell/utilities.ts +5 -2
- package/src/resources/extensions/browser-tools/engine/managed-gsd-browser.ts +265 -98
- package/src/resources/extensions/browser-tools/engine/selection.ts +90 -4
- package/src/resources/extensions/browser-tools/index.ts +71 -13
- package/src/resources/extensions/browser-tools/tests/browser-engine-selection.test.mjs +83 -13
- package/src/resources/extensions/browser-tools/tests/gsd-browser-launch-config.test.mjs +29 -1
- package/src/resources/extensions/browser-tools/tests/managed-gsd-browser-tools.test.mjs +136 -0
- package/src/resources/extensions/claude-code-cli/models.ts +9 -0
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +40 -4
- package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +28 -0
- package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +21 -3
- package/src/resources/extensions/gsd/auto/detect-stuck.ts +32 -9
- package/src/resources/extensions/gsd/auto/dispatch-history.ts +152 -0
- package/src/resources/extensions/gsd/auto/dispatch-key.ts +39 -0
- package/src/resources/extensions/gsd/auto/loop-deps.ts +1 -1
- package/src/resources/extensions/gsd/auto/loop.ts +4 -1
- package/src/resources/extensions/gsd/auto/orchestrator.ts +109 -51
- package/src/resources/extensions/gsd/auto/phases.ts +12 -3
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +8 -32
- package/src/resources/extensions/gsd/auto-dispatch.ts +38 -52
- package/src/resources/extensions/gsd/auto-model-selection.ts +25 -5
- package/src/resources/extensions/gsd/auto-post-unit.ts +37 -13
- package/src/resources/extensions/gsd/auto-prompts.ts +118 -35
- package/src/resources/extensions/gsd/auto-start.ts +24 -29
- package/src/resources/extensions/gsd/auto-tool-tracking.ts +19 -0
- package/src/resources/extensions/gsd/auto-unit-tool-scope.ts +14 -21
- package/src/resources/extensions/gsd/auto-verification.ts +8 -26
- package/src/resources/extensions/gsd/auto-worktree-repair.ts +13 -2
- package/src/resources/extensions/gsd/auto-worktree.ts +41 -364
- package/src/resources/extensions/gsd/auto.ts +20 -24
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +3 -5
- package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +33 -12
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +24 -0
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +270 -37
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +368 -78
- package/src/resources/extensions/gsd/branch-patterns.ts +3 -0
- package/src/resources/extensions/gsd/browser-daemon-auto-prep.ts +108 -0
- package/src/resources/extensions/gsd/browser-evidence.ts +18 -2
- package/src/resources/extensions/gsd/captures.ts +5 -16
- package/src/resources/extensions/gsd/closeout-recovery.ts +2 -1
- package/src/resources/extensions/gsd/commands/catalog.ts +6 -68
- package/src/resources/extensions/gsd/consent-question.ts +416 -0
- package/src/resources/extensions/gsd/consent-verdict.ts +86 -0
- package/src/resources/extensions/gsd/constants.ts +0 -3
- package/src/resources/extensions/gsd/crash-recovery.ts +3 -9
- package/src/resources/extensions/gsd/db/engine.ts +809 -0
- package/src/resources/extensions/gsd/db/queries.ts +490 -0
- package/src/resources/extensions/gsd/db/sql-constants.ts +12 -0
- package/src/resources/extensions/gsd/db/writers/cascades.ts +237 -0
- package/src/resources/extensions/gsd/db/writers/import-restore.ts +310 -0
- package/src/resources/extensions/gsd/db/writers/memory.ts +220 -0
- package/src/resources/extensions/gsd/db/writers/reconcile.ts +500 -0
- package/src/resources/extensions/gsd/db/writers/status.ts +88 -0
- package/src/resources/extensions/gsd/dispatch-guard.ts +8 -31
- package/src/resources/extensions/gsd/doctor-environment.ts +5 -13
- package/src/resources/extensions/gsd/doctor-format.ts +12 -7
- package/src/resources/extensions/gsd/doctor-git-checks.ts +3 -3
- package/src/resources/extensions/gsd/doctor-runtime-checks.ts +22 -17
- package/src/resources/extensions/gsd/engine-hook-contract.ts +79 -0
- package/src/resources/extensions/gsd/error-classifier.ts +11 -0
- package/src/resources/extensions/gsd/exec-sandbox.ts +49 -9
- package/src/resources/extensions/gsd/files.ts +33 -12
- package/src/resources/extensions/gsd/git-service.ts +1 -0
- package/src/resources/extensions/gsd/gitignore.ts +3 -0
- package/src/resources/extensions/gsd/gsd-db.ts +173 -2373
- package/src/resources/extensions/gsd/guidance.ts +217 -0
- package/src/resources/extensions/gsd/guided-flow.ts +50 -5
- package/src/resources/extensions/gsd/markdown-renderer.ts +11 -0
- package/src/resources/extensions/gsd/mcp-filter.ts +2 -23
- package/src/resources/extensions/gsd/mcp-tool-name.ts +6 -11
- package/src/resources/extensions/gsd/memory-consolidation-scanner.ts +1 -1
- package/src/resources/extensions/gsd/migrate/safety.ts +18 -7
- package/src/resources/extensions/gsd/migration-auto-check.ts +28 -3
- package/src/resources/extensions/gsd/milestone-closeout.ts +13 -23
- package/src/resources/extensions/gsd/model-cost-table.ts +1 -0
- package/src/resources/extensions/gsd/model-router.ts +3 -0
- package/src/resources/extensions/gsd/notification-store.ts +26 -3
- package/src/resources/extensions/gsd/parallel-merge.ts +12 -9
- package/src/resources/extensions/gsd/parallel-monitor-overlay.ts +10 -7
- package/src/resources/extensions/gsd/parsers-legacy.ts +16 -4
- package/src/resources/extensions/gsd/paths.ts +42 -22
- package/src/resources/extensions/gsd/pre-execution-checks.ts +109 -3
- package/src/resources/extensions/gsd/preferences-models.ts +12 -47
- package/src/resources/extensions/gsd/preferences.ts +18 -0
- package/src/resources/extensions/gsd/prompts/complete-slice.md +2 -2
- package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/refine-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/replan-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/run-uat.md +6 -4
- package/src/resources/extensions/gsd/prompts/system.md +5 -2
- package/src/resources/extensions/gsd/provider-error-guidance.ts +4 -9
- package/src/resources/extensions/gsd/provider-switch-observer.ts +1 -1
- package/src/resources/extensions/gsd/publication.ts +122 -0
- package/src/resources/extensions/gsd/reactive-graph.ts +11 -1
- package/src/resources/extensions/gsd/recovery-classification.ts +47 -88
- package/src/resources/extensions/gsd/safety/destructive-confirmation.ts +134 -0
- package/src/resources/extensions/gsd/safety/evidence-collector.ts +36 -4
- package/src/resources/extensions/gsd/safety/evidence-cross-ref.ts +7 -2
- package/src/resources/extensions/gsd/safety/file-change-validator.ts +14 -0
- package/src/resources/extensions/gsd/state-transition-matrix.ts +42 -0
- package/src/resources/extensions/gsd/state.ts +9 -21
- package/src/resources/extensions/gsd/status-guards.ts +59 -8
- package/src/resources/extensions/gsd/stop-notice.ts +75 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +123 -0
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +22 -0
- package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +101 -26
- package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +3 -1
- package/src/resources/extensions/gsd/tests/auto-post-unit-evidence-crossref-4909.test.ts +46 -0
- package/src/resources/extensions/gsd/tests/auto-worktree-registry.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/auto-worktree-repair.test.ts +4 -2
- package/src/resources/extensions/gsd/tests/browser-automation-contract-fixture.ts +39 -0
- package/src/resources/extensions/gsd/tests/browser-contract.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/browser-daemon-auto-prep.test.ts +144 -0
- package/src/resources/extensions/gsd/tests/checkout-branch-stash-guard.test.ts +66 -1
- package/src/resources/extensions/gsd/tests/clear-stale-autostart.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/commands-verdict.test.ts +8 -7
- package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +42 -0
- package/src/resources/extensions/gsd/tests/consent-question.test.ts +336 -0
- package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +67 -0
- package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +10 -10
- package/src/resources/extensions/gsd/tests/destructive-confirmation.test.ts +303 -0
- package/src/resources/extensions/gsd/tests/dispatch-history.test.ts +273 -0
- package/src/resources/extensions/gsd/tests/dispatch-run-uat-browser-tools.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/dynamic-bash-no-cap.test.ts +132 -0
- package/src/resources/extensions/gsd/tests/engine-hook-contract.test.ts +148 -0
- package/src/resources/extensions/gsd/tests/evidence-xref-gsd-exec.test.ts +157 -0
- package/src/resources/extensions/gsd/tests/exec-graceful-kill.test.ts +193 -0
- package/src/resources/extensions/gsd/tests/exec-tool.test.ts +29 -1
- package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +35 -1
- package/src/resources/extensions/gsd/tests/file-change-validator.test.ts +33 -1
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +27 -0
- package/src/resources/extensions/gsd/tests/guidance.test.ts +148 -0
- package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +58 -15
- package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +74 -59
- package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +3 -2
- package/src/resources/extensions/gsd/tests/integration/gsd-integration-fixture.ts +80 -0
- package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +199 -0
- package/src/resources/extensions/gsd/tests/mcp-project-config.test.ts +3 -1
- package/src/resources/extensions/gsd/tests/migration-auto-check.test.ts +85 -1
- package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +32 -1
- package/src/resources/extensions/gsd/tests/notification-store.test.ts +32 -0
- package/src/resources/extensions/gsd/tests/oauth-api-model-routing.test.ts +167 -0
- package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +18 -0
- package/src/resources/extensions/gsd/tests/parsers-legacy-importers.test.ts +139 -0
- package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +193 -1
- package/src/resources/extensions/gsd/tests/prompt-db.test.ts +124 -6
- package/src/resources/extensions/gsd/tests/provider-error-guidance.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/publication.test.ts +120 -0
- package/src/resources/extensions/gsd/tests/recovery-classification-illegal-transition.test.ts +30 -0
- package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +248 -1
- package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +1 -0
- package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +38 -0
- package/src/resources/extensions/gsd/tests/session-switch-clears-pending-autostart.test.ts +108 -0
- package/src/resources/extensions/gsd/tests/single-writer-invariant.test.ts +43 -6
- package/src/resources/extensions/gsd/tests/state-transition-matrix.test.ts +36 -0
- package/src/resources/extensions/gsd/tests/status-guards.test.ts +38 -0
- package/src/resources/extensions/gsd/tests/stop-notice.test.ts +70 -0
- package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +76 -0
- package/src/resources/extensions/gsd/tests/tool-invocation-error-loop-break.test.ts +8 -0
- package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +155 -0
- package/src/resources/extensions/gsd/tests/uat-policy.test.ts +112 -29
- package/src/resources/extensions/gsd/tests/unit-closeout.test.ts +209 -0
- package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +67 -2
- package/src/resources/extensions/gsd/tests/unit-registry.test.ts +163 -0
- package/src/resources/extensions/gsd/tests/web-app-uat.test.ts +44 -1
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/worktree-lifecycle.test.ts +41 -4
- package/src/resources/extensions/gsd/tests/worktree-manager.test.ts +22 -1
- package/src/resources/extensions/gsd/tests/worktree-placement.test.ts +113 -0
- package/src/resources/extensions/gsd/tests/worktree-reentry.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +3 -1
- package/src/resources/extensions/gsd/tests/worktree-symlink-removal.test.ts +12 -6
- package/src/resources/extensions/gsd/tests/worktree-teardown-safety.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/write-gate-seam.test.ts +358 -0
- package/src/resources/extensions/gsd/tests/write-gate.test.ts +109 -1
- package/src/resources/extensions/gsd/tool-presentation-plan.ts +4 -4
- package/src/resources/extensions/gsd/tool-surface-readiness.ts +76 -0
- package/src/resources/extensions/gsd/tools/complete-slice.ts +43 -68
- package/src/resources/extensions/gsd/tools/exec-tool.ts +9 -8
- package/src/resources/extensions/gsd/tools/plan-slice.ts +12 -6
- package/src/resources/extensions/gsd/tools/reopen-milestone.ts +11 -38
- package/src/resources/extensions/gsd/tools/reopen-slice.ts +14 -42
- package/src/resources/extensions/gsd/tools/skip-slice.ts +18 -44
- package/src/resources/extensions/gsd/uat-policy.ts +62 -16
- package/src/resources/extensions/gsd/undo.ts +9 -8
- package/src/resources/extensions/gsd/unit-closeout.ts +201 -0
- package/src/resources/extensions/gsd/unit-context-composer.ts +111 -1
- package/src/resources/extensions/gsd/unit-context-manifest.ts +4 -28
- package/src/resources/extensions/gsd/unit-registry.ts +412 -0
- package/src/resources/extensions/gsd/unit-tool-contracts.ts +27 -192
- package/src/resources/extensions/gsd/verdict-parser.ts +1 -1
- package/src/resources/extensions/gsd/web-app-uat.ts +51 -8
- package/src/resources/extensions/gsd/workflow-tool-surface.ts +4 -1
- package/src/resources/extensions/gsd/worktree-git-recovery.ts +314 -0
- package/src/resources/extensions/gsd/worktree-lifecycle.ts +13 -9
- package/src/resources/extensions/gsd/worktree-manager.ts +47 -28
- package/src/resources/extensions/gsd/worktree-placement.ts +63 -0
- package/src/resources/extensions/gsd/worktree-reentry.ts +10 -7
- package/src/resources/extensions/gsd/worktree-root.ts +29 -6
- package/src/resources/extensions/gsd/worktree-safety.ts +8 -5
- package/src/resources/extensions/gsd/worktree-session-state.ts +11 -11
- package/src/resources/extensions/search-the-web/native-search.ts +5 -3
- package/src/resources/extensions/shared/browser-contract.ts +66 -0
- package/src/resources/extensions/shared/gsd-browser-cli.ts +119 -5
- package/src/resources/shared/package.json +3 -0
- package/src/resources/skills/create-skill/references/executable-code.md +1 -1
- package/src/resources/skills/create-skill/workflows/add-reference.md +8 -3
- package/src/resources/skills/create-skill/workflows/add-script.md +4 -2
- package/src/resources/skills/create-skill/workflows/add-template.md +3 -1
- package/src/resources/skills/create-skill/workflows/add-workflow.md +8 -3
- package/src/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
- package/src/resources/skills/create-skill/workflows/verify-skill.md +9 -4
- package/src/resources/skills/gsd-browser/SKILL.md +1 -1
- package/src/resources/skills/spike-wrap-up/SKILL.md +9 -9
- package/dist/resources/extensions/gsd/user-input-boundary.js +0 -218
- package/src/resources/extensions/gsd/tests/user-input-boundary.test.ts +0 -173
- package/src/resources/extensions/gsd/user-input-boundary.ts +0 -216
- /package/dist/web/standalone/.next/static/{3PtrU9qGPEXwNLWkIyiqk → jmTLg6xZmAuq_LIqKOxrH}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{3PtrU9qGPEXwNLWkIyiqk → jmTLg6xZmAuq_LIqKOxrH}/_ssgManifest.js +0 -0
|
@@ -12,6 +12,17 @@ import { randomUUID } from "node:crypto";
|
|
|
12
12
|
export type NotifySeverity = "info" | "success" | "warning" | "error";
|
|
13
13
|
export type NotificationSource = "notify" | "workflow-logger";
|
|
14
14
|
|
|
15
|
+
/**
|
|
16
|
+
* Optional structured identity for a notification. When present, `kind`
|
|
17
|
+
* (a stable machine name like "auto-stop" or "provider-error-pause") plus
|
|
18
|
+
* `scope` (e.g. a milestone/slice id) — not the prose — key deduplication,
|
|
19
|
+
* and consumers can filter without parsing message text.
|
|
20
|
+
*/
|
|
21
|
+
export interface NotificationMeta {
|
|
22
|
+
kind?: string;
|
|
23
|
+
scope?: string;
|
|
24
|
+
}
|
|
25
|
+
|
|
15
26
|
export interface NotificationEntry {
|
|
16
27
|
id: string;
|
|
17
28
|
ts: string;
|
|
@@ -19,6 +30,8 @@ export interface NotificationEntry {
|
|
|
19
30
|
message: string;
|
|
20
31
|
source: NotificationSource;
|
|
21
32
|
read: boolean;
|
|
33
|
+
kind?: string;
|
|
34
|
+
scope?: string;
|
|
22
35
|
}
|
|
23
36
|
|
|
24
37
|
// ─── Constants ──────────────────────────────────────────────────────────
|
|
@@ -60,11 +73,15 @@ export function appendNotification(
|
|
|
60
73
|
message: string,
|
|
61
74
|
severity: NotifySeverity,
|
|
62
75
|
source: NotificationSource = "notify",
|
|
76
|
+
meta?: NotificationMeta,
|
|
63
77
|
): void {
|
|
64
78
|
if (!_basePath) return;
|
|
65
79
|
if (_suppressCount > 0) return;
|
|
66
80
|
const persistedMessage = message.length > 500 ? message.slice(0, 500) + "…" : message;
|
|
67
|
-
|
|
81
|
+
// Structured identity (kind + scope) keys dedup when present, so a rephrased
|
|
82
|
+
// message of the same event still dedups; otherwise fall back to the prose.
|
|
83
|
+
const identity = meta?.kind ? `${meta.kind}:${meta.scope ?? ""}` : persistedMessage;
|
|
84
|
+
const dedupKey = `${_basePath}:${severity}:${source}:${identity}`;
|
|
68
85
|
const now = Date.now();
|
|
69
86
|
const lastSeen = _recentMessageTimestamps.get(dedupKey);
|
|
70
87
|
if (lastSeen !== undefined && now - lastSeen < DEDUP_WINDOW_MS) return;
|
|
@@ -82,6 +99,8 @@ export function appendNotification(
|
|
|
82
99
|
message: persistedMessage,
|
|
83
100
|
source,
|
|
84
101
|
read: false,
|
|
102
|
+
...(meta?.kind ? { kind: meta.kind } : {}),
|
|
103
|
+
...(meta?.scope ? { scope: meta.scope } : {}),
|
|
85
104
|
};
|
|
86
105
|
|
|
87
106
|
try {
|
|
@@ -102,11 +121,15 @@ export function appendNotification(
|
|
|
102
121
|
|
|
103
122
|
/**
|
|
104
123
|
* Read all notification entries from disk. Returns newest-first.
|
|
124
|
+
* An optional filter narrows by structured identity (kind and/or scope).
|
|
105
125
|
*/
|
|
106
|
-
export function readNotifications(basePath?: string): NotificationEntry[] {
|
|
126
|
+
export function readNotifications(basePath?: string, filter?: NotificationMeta): NotificationEntry[] {
|
|
107
127
|
const bp = basePath ?? _basePath;
|
|
108
128
|
if (!bp) return [];
|
|
109
|
-
|
|
129
|
+
const entries = _readEntriesFromDisk(bp).filter(
|
|
130
|
+
(e) => (!filter?.kind || e.kind === filter.kind) && (!filter?.scope || e.scope === filter.scope),
|
|
131
|
+
);
|
|
132
|
+
return entries.reverse();
|
|
110
133
|
}
|
|
111
134
|
|
|
112
135
|
/**
|
|
@@ -9,6 +9,7 @@ import { existsSync, readdirSync } from "node:fs";
|
|
|
9
9
|
import { join } from "node:path";
|
|
10
10
|
import { spawnSync } from "node:child_process";
|
|
11
11
|
import { resolveGsdPathContract } from "./paths.js";
|
|
12
|
+
import { worktreePathFor, worktreesDirs } from "./worktree-placement.js";
|
|
12
13
|
import { getAutoWorktreePath } from "./auto-worktree.js";
|
|
13
14
|
import { buildWorktreeLifecycleDeps } from "./auto.js";
|
|
14
15
|
import {
|
|
@@ -42,7 +43,7 @@ export type MergeOrder = "sequential" | "by-completion";
|
|
|
42
43
|
* Returns true when milestones.status = 'complete' in project gsd.db.
|
|
43
44
|
*/
|
|
44
45
|
export function isMilestoneCompleteInProjectDb(basePath: string, mid: string): boolean {
|
|
45
|
-
const workRoot =
|
|
46
|
+
const workRoot = worktreePathFor(basePath, mid);
|
|
46
47
|
const dbPath = resolveGsdPathContract(workRoot, basePath).projectDb;
|
|
47
48
|
if (!existsSync(dbPath)) return false;
|
|
48
49
|
|
|
@@ -65,15 +66,17 @@ export function isMilestoneCompleteInProjectDb(basePath: string, mid: string): b
|
|
|
65
66
|
*/
|
|
66
67
|
function discoverDbCompletedMilestones(basePath: string): Set<string> {
|
|
67
68
|
const completed = new Set<string>();
|
|
68
|
-
const worktreeDir
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
69
|
+
for (const worktreeDir of worktreesDirs(basePath)) {
|
|
70
|
+
if (!existsSync(worktreeDir)) continue;
|
|
71
|
+
try {
|
|
72
|
+
for (const entry of readdirSync(worktreeDir)) {
|
|
73
|
+
if (entry.startsWith("M") && isMilestoneCompleteInProjectDb(basePath, entry)) {
|
|
74
|
+
completed.add(entry);
|
|
75
|
+
}
|
|
73
76
|
}
|
|
77
|
+
} catch (e) {
|
|
78
|
+
logWarning("parallel", `readdirSync for completed set failed: ${(e as Error).message}`);
|
|
74
79
|
}
|
|
75
|
-
} catch (e) {
|
|
76
|
-
logWarning("parallel", `readdirSync for completed set failed: ${(e as Error).message}`);
|
|
77
80
|
}
|
|
78
81
|
return completed;
|
|
79
82
|
}
|
|
@@ -120,7 +123,7 @@ export function determineMergeOrder(
|
|
|
120
123
|
title: mid,
|
|
121
124
|
pid: 0,
|
|
122
125
|
process: null,
|
|
123
|
-
worktreePath: basePath ?
|
|
126
|
+
worktreePath: basePath ? worktreePathFor(basePath, mid) : "",
|
|
124
127
|
startedAt: 0,
|
|
125
128
|
state: "stopped",
|
|
126
129
|
cost: 0,
|
|
@@ -11,6 +11,7 @@ import { matchesKey, Key } from "@gsd/pi-tui";
|
|
|
11
11
|
import { formatDuration } from "../shared/mod.js";
|
|
12
12
|
import { formattedShortcutPair } from "./shortcut-defs.js";
|
|
13
13
|
import { resolveGsdPathContract } from "./paths.js";
|
|
14
|
+
import { worktreePathFor, worktreesDirs } from "./worktree-placement.js";
|
|
14
15
|
import {
|
|
15
16
|
renderBar,
|
|
16
17
|
renderDialogFrame,
|
|
@@ -101,7 +102,6 @@ function tailRead(filePath: string, maxBytes: number): string {
|
|
|
101
102
|
|
|
102
103
|
function discoverWorkers(basePath: string): string[] {
|
|
103
104
|
const parallelDir = join(basePath, ".gsd", "parallel");
|
|
104
|
-
const worktreeDir = join(basePath, ".gsd", "worktrees");
|
|
105
105
|
const mids = new Set<string>();
|
|
106
106
|
|
|
107
107
|
if (existsSync(parallelDir)) {
|
|
@@ -114,7 +114,8 @@ function discoverWorkers(basePath: string): string[] {
|
|
|
114
114
|
} catch { /* skip */ }
|
|
115
115
|
}
|
|
116
116
|
|
|
117
|
-
|
|
117
|
+
for (const worktreeDir of worktreesDirs(basePath)) {
|
|
118
|
+
if (!existsSync(worktreeDir)) continue;
|
|
118
119
|
try {
|
|
119
120
|
for (const d of readdirSync(worktreeDir)) {
|
|
120
121
|
if (d.startsWith("M") && existsSync(join(worktreeDir, d, ".gsd", "auto.lock"))) {
|
|
@@ -127,8 +128,7 @@ function discoverWorkers(basePath: string): string[] {
|
|
|
127
128
|
return [...mids].sort();
|
|
128
129
|
}
|
|
129
130
|
|
|
130
|
-
function querySliceProgress(basePath: string, mid: string): SliceProgress[] {
|
|
131
|
-
const workRoot = join(basePath, ".gsd", "worktrees", mid);
|
|
131
|
+
function querySliceProgress(basePath: string, mid: string, workRoot: string = worktreePathFor(basePath, mid)): SliceProgress[] {
|
|
132
132
|
const dbPath = resolveGsdPathContract(workRoot, basePath).projectDb;
|
|
133
133
|
if (!existsSync(dbPath)) return [];
|
|
134
134
|
|
|
@@ -169,7 +169,7 @@ function extractCostFromNdjson(basePath: string, mid: string): number {
|
|
|
169
169
|
}
|
|
170
170
|
|
|
171
171
|
function queryRecentCompletions(basePath: string, mid: string): string[] {
|
|
172
|
-
const workRoot =
|
|
172
|
+
const workRoot = worktreePathFor(basePath, mid);
|
|
173
173
|
const dbPath = resolveGsdPathContract(workRoot, basePath).projectDb;
|
|
174
174
|
if (!existsSync(dbPath)) return [];
|
|
175
175
|
try {
|
|
@@ -192,9 +192,12 @@ function collectWorkerData(basePath: string): WorkerView[] {
|
|
|
192
192
|
const workers: WorkerView[] = [];
|
|
193
193
|
|
|
194
194
|
for (const mid of mids) {
|
|
195
|
+
// Resolve the worktree path once per worker per tick — this runs on a
|
|
196
|
+
// 5-second refresh interval and worktreePathFor probes the filesystem.
|
|
197
|
+
const workRoot = worktreePathFor(basePath, mid);
|
|
195
198
|
const status = readJsonSafe<StatusJson>(join(parallelDir, `${mid}.status.json`));
|
|
196
|
-
const lock = readJsonSafe<AutoLock>(join(
|
|
197
|
-
const slices = querySliceProgress(basePath, mid);
|
|
199
|
+
const lock = readJsonSafe<AutoLock>(join(workRoot, ".gsd", "auto.lock"));
|
|
200
|
+
const slices = querySliceProgress(basePath, mid, workRoot);
|
|
198
201
|
|
|
199
202
|
const pid = lock?.pid || status?.pid || 0;
|
|
200
203
|
const alive = pid ? isPidAlive(pid) : false;
|
|
@@ -1,10 +1,22 @@
|
|
|
1
1
|
// GSD Extension - Legacy Parsers
|
|
2
2
|
// parseRoadmap() and parsePlan() extracted from files.ts.
|
|
3
|
-
// Used only by: md-importer.ts (migration), state.ts (pre-migration fallback),
|
|
4
|
-
// markdown-renderer.ts (detectStaleRenders disk-vs-DB comparison),
|
|
5
|
-
// commands-maintenance.ts (cold-path branch cleanup), and tests.
|
|
6
3
|
//
|
|
7
|
-
//
|
|
4
|
+
// ADR-017: the DB is the single source of truth; `.gsd/*.md` files are
|
|
5
|
+
// projections. These parsers may be imported ONLY for:
|
|
6
|
+
// - migration/import (md-importer, workflow-migration, migration-auto-check)
|
|
7
|
+
// - drift detection that compares both sources by design
|
|
8
|
+
// (state-reconciliation/drift, markdown-renderer stale-render detection)
|
|
9
|
+
// - explicit pre-migration / DB-unavailable fallbacks (state.ts,
|
|
10
|
+
// reactive-graph.ts, auto-recovery.ts)
|
|
11
|
+
// - diagnostics and display/telemetry-only surfaces (doctor,
|
|
12
|
+
// doctor-git-checks, workspace-index, visualizer-data, auto-prompts
|
|
13
|
+
// context text, commands-maintenance, milestone-closeout, github-sync)
|
|
14
|
+
// - tests
|
|
15
|
+
//
|
|
16
|
+
// Dispatch/gate/completion DECISION paths must NOT import this module — they
|
|
17
|
+
// read the DB via gsd-db queries (e.g. getMilestoneSliceSummaries). Enforced
|
|
18
|
+
// by tests/parsers-legacy-importers.test.ts; new importers must be added to
|
|
19
|
+
// its allowlist with a one-line justification.
|
|
8
20
|
|
|
9
21
|
import { extractSection, parseBullets, extractBoldField, extractAllSections, registerCacheClearCallback } from './files.js';
|
|
10
22
|
import { splitFrontmatter } from '../shared/frontmatter.js';
|
|
@@ -17,7 +17,7 @@ import { spawnSync } from "node:child_process";
|
|
|
17
17
|
import { nativeScanGsdTree, type GsdTreeEntry } from "./native-parser-bridge.js";
|
|
18
18
|
import { DIR_CACHE_MAX } from "./constants.js";
|
|
19
19
|
import { gsdHome } from "./gsd-home.js";
|
|
20
|
-
import { isGsdWorktreePath, resolveExternalStateProjectGsdFromWorktreePath, resolveWorktreeProjectRoot } from "./worktree-root.js";
|
|
20
|
+
import { findWorktreeSegment, isGsdWorktreePath, resolveExternalStateProjectGsdFromWorktreePath, resolveWorktreeProjectRoot } from "./worktree-root.js";
|
|
21
21
|
|
|
22
22
|
// ─── Directory Listing Cache ──────────────────────────────────────────────────
|
|
23
23
|
|
|
@@ -148,6 +148,39 @@ export function clearPathCache(): void {
|
|
|
148
148
|
|
|
149
149
|
// ─── Name Builders ─────────────────────────────────────────────────────────
|
|
150
150
|
|
|
151
|
+
/** Directories owned by the GSD framework — metadata, never project source. */
|
|
152
|
+
export const FRAMEWORK_METADATA_DIRS: readonly string[] = [".gsd", ".planning", ".audits"];
|
|
153
|
+
|
|
154
|
+
/**
|
|
155
|
+
* Every artifact suffix used with the name builders below — the single source
|
|
156
|
+
* for the `<ID>-<SUFFIX>.md` naming vocabulary. Extend this list when a new
|
|
157
|
+
* artifact type is introduced; consumers (md-importer walking, pre-execution
|
|
158
|
+
* artifact detection) pick it up from here.
|
|
159
|
+
*/
|
|
160
|
+
export const PLANNING_ARTIFACT_SUFFIXES: readonly string[] = [
|
|
161
|
+
"CONTEXT",
|
|
162
|
+
"CONTEXT-DRAFT",
|
|
163
|
+
"ROADMAP",
|
|
164
|
+
"PLAN",
|
|
165
|
+
"REPLAN",
|
|
166
|
+
"SUMMARY",
|
|
167
|
+
"RESEARCH",
|
|
168
|
+
"VALIDATION",
|
|
169
|
+
"ASSESSMENT",
|
|
170
|
+
"UAT",
|
|
171
|
+
"DISCUSSION",
|
|
172
|
+
"EVAL-REVIEW",
|
|
173
|
+
"PARKED",
|
|
174
|
+
"VERIFICATION-FAILED",
|
|
175
|
+
"CONTINUE",
|
|
176
|
+
];
|
|
177
|
+
|
|
178
|
+
/** Matches a bare planning-artifact file name, e.g. "M001-CONTEXT.md", "S01-PLAN.md". */
|
|
179
|
+
export const PLANNING_ARTIFACT_NAME_RE = new RegExp(
|
|
180
|
+
`^[MST]\\d+-(${PLANNING_ARTIFACT_SUFFIXES.join("|")})\\.md$`,
|
|
181
|
+
"i",
|
|
182
|
+
);
|
|
183
|
+
|
|
151
184
|
/**
|
|
152
185
|
* Build a milestone-level file name.
|
|
153
186
|
* ("M001", "CONTEXT") → "M001-CONTEXT.md"
|
|
@@ -458,29 +491,16 @@ function assertNotGlobalGsdHome(basePath: string, result: string): void {
|
|
|
458
491
|
* When gsdRoot() is called with such a path, we must NOT walk up to the
|
|
459
492
|
* project root's .gsd — each worktree manages its own .gsd state (#2594).
|
|
460
493
|
*
|
|
461
|
-
*
|
|
462
|
-
*
|
|
494
|
+
* Layout matching is owned by worktree-root's findWorktreeSegment; this
|
|
495
|
+
* only adds the requirement that a non-empty worktree name follows the
|
|
496
|
+
* marker (the worktrees container dir itself is not a worktree).
|
|
463
497
|
*/
|
|
464
498
|
function isInsideGsdWorktree(p: string): boolean {
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
const
|
|
469
|
-
|
|
470
|
-
`${sepFwd}.gsd${sepFwd}worktrees${sepFwd}`,
|
|
471
|
-
`${sepNative}.gsd${sepNative}worktrees${sepNative}`,
|
|
472
|
-
];
|
|
473
|
-
for (const marker of markers) {
|
|
474
|
-
const idx = p.indexOf(marker);
|
|
475
|
-
if (idx === -1) continue;
|
|
476
|
-
// Verify there's a non-empty worktree name after the marker
|
|
477
|
-
const afterMarker = p.slice(idx + marker.length);
|
|
478
|
-
// The name is everything up to the next separator (or end of string)
|
|
479
|
-
const nameEnd = afterMarker.search(/[/\\]/);
|
|
480
|
-
const name = nameEnd === -1 ? afterMarker : afterMarker.slice(0, nameEnd);
|
|
481
|
-
if (name.length > 0) return true;
|
|
482
|
-
}
|
|
483
|
-
return false;
|
|
499
|
+
const normalized = p.replaceAll("\\", "/");
|
|
500
|
+
const segment = findWorktreeSegment(normalized);
|
|
501
|
+
if (!segment) return false;
|
|
502
|
+
const name = normalized.slice(segment.afterWorktrees).split("/")[0];
|
|
503
|
+
return name.length > 0;
|
|
484
504
|
}
|
|
485
505
|
|
|
486
506
|
function probeGsdRoot(rawBasePath: string): string {
|
|
@@ -24,6 +24,7 @@ import { isAbsolute, relative, resolve } from "node:path";
|
|
|
24
24
|
import type { TaskRow } from "./db-task-slice-rows.js";
|
|
25
25
|
import type { PreExecutionCheckJSON } from "./verification-evidence.ts";
|
|
26
26
|
import { validateVerificationCommand } from "./verification-gate.js";
|
|
27
|
+
import { FRAMEWORK_METADATA_DIRS, PLANNING_ARTIFACT_NAME_RE } from "./paths.js";
|
|
27
28
|
|
|
28
29
|
const NPM_COMMAND = process.platform === "win32" ? "npm.cmd" : "npm";
|
|
29
30
|
|
|
@@ -586,6 +587,9 @@ export function checkFilePathConsistency(
|
|
|
586
587
|
// Skip empty strings
|
|
587
588
|
if (!file.trim()) continue;
|
|
588
589
|
if (!shouldValidateInputAsPath(file)) continue;
|
|
590
|
+
// Planning-artifact references are owned by checkPlanningArtifactReferences,
|
|
591
|
+
// which reports a precise removal message instead of "doesn't exist".
|
|
592
|
+
if (isPlanningArtifactReference(file, basePath, context)) continue;
|
|
589
593
|
|
|
590
594
|
// Normalize path for consistent comparison
|
|
591
595
|
const normalizedFile = toComparisonPath(file, basePath);
|
|
@@ -628,6 +632,85 @@ export function checkFilePathConsistency(
|
|
|
628
632
|
return results;
|
|
629
633
|
}
|
|
630
634
|
|
|
635
|
+
// ─── Planning Artifact Reference Check ───────────────────────────────────────
|
|
636
|
+
|
|
637
|
+
function isFrameworkMetadataPath(normalizedFile: string): boolean {
|
|
638
|
+
return normalizedFile.split("/").some((segment) => FRAMEWORK_METADATA_DIRS.includes(segment.toLowerCase()));
|
|
639
|
+
}
|
|
640
|
+
|
|
641
|
+
/**
|
|
642
|
+
* True when a task IO entry references a GSD planning artifact.
|
|
643
|
+
*
|
|
644
|
+
* Task inputs are source files only — planning artifacts are projections of DB
|
|
645
|
+
* state that the framework preloads as composed context (see CONTEXT.md "Task
|
|
646
|
+
* Input"). Two triggers, deliberately different in strictness:
|
|
647
|
+
*
|
|
648
|
+
* - Any path entering framework-owned metadata (.gsd/, .planning/, .audits/)
|
|
649
|
+
* is always a violation, even when the file exists.
|
|
650
|
+
* - A bare artifact-style basename (M001-CONTEXT.md, S01-PLAN.md, …) is a
|
|
651
|
+
* violation only when it does NOT resolve to a real file. When such a file
|
|
652
|
+
* genuinely exists in the source tree (e.g. a fixture), it is a source file
|
|
653
|
+
* and stays legal; a path with directory components is likewise left to the
|
|
654
|
+
* ordinary existence checks.
|
|
655
|
+
*/
|
|
656
|
+
function isPlanningArtifactReference(
|
|
657
|
+
rawEntry: string,
|
|
658
|
+
basePath: string,
|
|
659
|
+
context?: PreExecutionCheckContext,
|
|
660
|
+
): boolean {
|
|
661
|
+
if (!shouldValidateInputAsPath(rawEntry)) return false;
|
|
662
|
+
const normalized = toComparisonPath(rawEntry, basePath);
|
|
663
|
+
if (isFrameworkMetadataPath(normalized)) return true;
|
|
664
|
+
return (
|
|
665
|
+
!normalized.includes("/") &&
|
|
666
|
+
PLANNING_ARTIFACT_NAME_RE.test(normalized) &&
|
|
667
|
+
!inputExistsOnDisk(normalized, basePath, context)
|
|
668
|
+
);
|
|
669
|
+
}
|
|
670
|
+
|
|
671
|
+
/**
|
|
672
|
+
* Block GSD planning artifacts in task IO fields (inputs, files, expectedOutput).
|
|
673
|
+
*
|
|
674
|
+
* For inputs/files the violation smuggles a projection into the executor's
|
|
675
|
+
* preloaded source context; for expectedOutput it promises a write the runtime
|
|
676
|
+
* write-gate would reject mid-execution. Both get a precise message so the
|
|
677
|
+
* planning retry steers toward *removing* the reference, not creating the file.
|
|
678
|
+
* checkFilePathConsistency and checkTaskOrdering skip entries this check owns.
|
|
679
|
+
*/
|
|
680
|
+
export function checkPlanningArtifactReferences(
|
|
681
|
+
tasks: TaskRow[],
|
|
682
|
+
basePath: string,
|
|
683
|
+
context?: PreExecutionCheckContext,
|
|
684
|
+
): PreExecutionCheckJSON[] {
|
|
685
|
+
const results: PreExecutionCheckJSON[] = [];
|
|
686
|
+
|
|
687
|
+
for (const task of tasks) {
|
|
688
|
+
const fields = [
|
|
689
|
+
{ label: "inputs", entries: task.inputs },
|
|
690
|
+
{ label: "files", entries: task.files },
|
|
691
|
+
{ label: "expectedOutput", entries: task.expected_output },
|
|
692
|
+
];
|
|
693
|
+
for (const { label, entries } of fields) {
|
|
694
|
+
for (const file of entries) {
|
|
695
|
+
if (!isPlanningArtifactReference(file, basePath, context)) continue;
|
|
696
|
+
const message =
|
|
697
|
+
label === "expectedOutput"
|
|
698
|
+
? `Task ${task.id} lists '${file}' in expectedOutput — GSD planning artifacts are written by workflow tools (e.g. gsd_summary_save), never by tasks; remove it`
|
|
699
|
+
: `Task ${task.id} lists '${file}' in ${label} — GSD planning artifacts are projections preloaded as context, never task ${label}; remove it`;
|
|
700
|
+
results.push({
|
|
701
|
+
category: "file",
|
|
702
|
+
target: file,
|
|
703
|
+
passed: false,
|
|
704
|
+
message,
|
|
705
|
+
blocking: true,
|
|
706
|
+
});
|
|
707
|
+
}
|
|
708
|
+
}
|
|
709
|
+
}
|
|
710
|
+
|
|
711
|
+
return results;
|
|
712
|
+
}
|
|
713
|
+
|
|
631
714
|
// ─── Task Ordering Check ─────────────────────────────────────────────────────
|
|
632
715
|
|
|
633
716
|
/**
|
|
@@ -671,6 +754,9 @@ export function checkTaskOrdering(
|
|
|
671
754
|
for (const file of filesToCheck) {
|
|
672
755
|
if (isRuntimeOnlyInput(file)) continue;
|
|
673
756
|
if (!shouldValidateInputAsPath(file)) continue;
|
|
757
|
+
// Owned by checkPlanningArtifactReferences — avoid a duplicate sequence
|
|
758
|
+
// finding on top of the removal message.
|
|
759
|
+
if (isPlanningArtifactReference(file, basePath, context)) continue;
|
|
674
760
|
|
|
675
761
|
const normalizedFile = toComparisonPath(file, basePath);
|
|
676
762
|
if (containsGlobPattern(normalizedFile)) continue;
|
|
@@ -700,6 +786,27 @@ export function checkTaskOrdering(
|
|
|
700
786
|
return results;
|
|
701
787
|
}
|
|
702
788
|
|
|
789
|
+
// ─── Shared Path-Check Composition ───────────────────────────────────────────
|
|
790
|
+
|
|
791
|
+
/**
|
|
792
|
+
* The synchronous path-shaped checks, in order. One list shared by the
|
|
793
|
+
* plan-persist gate (gsd_plan_slice) and the dispatch gate
|
|
794
|
+
* (runPreExecutionChecks) so the two cannot drift — the checks coordinate
|
|
795
|
+
* ownership of planning-artifact entries via isPlanningArtifactReference
|
|
796
|
+
* skips, which only works when they run as a set.
|
|
797
|
+
*/
|
|
798
|
+
export function runTaskPathChecks(
|
|
799
|
+
tasks: TaskRow[],
|
|
800
|
+
basePath: string,
|
|
801
|
+
context?: PreExecutionCheckContext,
|
|
802
|
+
): PreExecutionCheckJSON[] {
|
|
803
|
+
return [
|
|
804
|
+
...checkPlanningArtifactReferences(tasks, basePath, context),
|
|
805
|
+
...checkFilePathConsistency(tasks, basePath, context),
|
|
806
|
+
...checkTaskOrdering(tasks, basePath, context),
|
|
807
|
+
];
|
|
808
|
+
}
|
|
809
|
+
|
|
703
810
|
// ─── Interface Contract Check ────────────────────────────────────────────────
|
|
704
811
|
|
|
705
812
|
interface FunctionSignature {
|
|
@@ -866,12 +973,11 @@ export async function runPreExecutionChecks(
|
|
|
866
973
|
const allChecks: PreExecutionCheckJSON[] = [];
|
|
867
974
|
|
|
868
975
|
// Run sync checks first
|
|
869
|
-
const
|
|
870
|
-
const orderingChecks = checkTaskOrdering(tasks, basePath, context);
|
|
976
|
+
const pathChecks = runTaskPathChecks(tasks, basePath, context);
|
|
871
977
|
const contractChecks = checkInterfaceContracts(tasks, basePath);
|
|
872
978
|
const verificationChecks = checkVerificationCommands(tasks);
|
|
873
979
|
|
|
874
|
-
allChecks.push(...
|
|
980
|
+
allChecks.push(...pathChecks, ...contractChecks, ...verificationChecks);
|
|
875
981
|
|
|
876
982
|
// Run async package checks
|
|
877
983
|
const packageChecks = await checkPackageExistence(tasks, basePath);
|
|
@@ -26,6 +26,7 @@ import type {
|
|
|
26
26
|
AutoSupervisorConfig,
|
|
27
27
|
} from "./preferences-types.js";
|
|
28
28
|
import { loadEffectiveGSDPreferences, getGlobalGSDPreferencesPath } from "./preferences.js";
|
|
29
|
+
import { getUnitPhaseChain } from "./unit-registry.js";
|
|
29
30
|
|
|
30
31
|
// Re-export types so existing consumers of ./preferences-models.js keep working
|
|
31
32
|
export type { GSDPhaseModelConfig, GSDModelConfig, GSDModelConfigV2, ResolvedModelConfig } from "./preferences-types.js";
|
|
@@ -49,53 +50,16 @@ export function resolveModelForUnit(unitType: string): string | undefined {
|
|
|
49
50
|
* (`resolveThinkingLevelForUnit`) so the two never drift (ADR-026).
|
|
50
51
|
*/
|
|
51
52
|
export function phaseChainForUnit(unitType: string): GSDModelPhaseKey[] | undefined {
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
case "plan-slice":
|
|
61
|
-
case "refine-slice":
|
|
62
|
-
case "replan-slice":
|
|
63
|
-
return ["planning"];
|
|
64
|
-
// Deep-mode project-level discussion units route to the same model bucket
|
|
65
|
-
// as milestone-level discussion (interactive interview style). Workflow
|
|
66
|
-
// preferences and research-decision are tiny ask_user_questions style units
|
|
67
|
-
// that share the discuss bucket because they are conversational. All fall
|
|
68
|
-
// back to planning when no `discuss` bucket is set.
|
|
69
|
-
case "discuss-milestone":
|
|
70
|
-
case "discuss-slice":
|
|
71
|
-
case "discuss-project":
|
|
72
|
-
case "discuss-requirements":
|
|
73
|
-
case "workflow-preferences":
|
|
74
|
-
case "research-decision":
|
|
75
|
-
return ["discuss", "planning"];
|
|
76
|
-
case "execute-task":
|
|
77
|
-
case "reactive-execute":
|
|
78
|
-
return ["execution"];
|
|
79
|
-
case "execute-task-simple":
|
|
80
|
-
return ["execution_simple", "execution"];
|
|
81
|
-
case "complete-slice":
|
|
82
|
-
case "complete-milestone":
|
|
83
|
-
case "worktree-merge":
|
|
84
|
-
return ["completion"];
|
|
85
|
-
case "run-uat":
|
|
86
|
-
return ["uat", "completion"];
|
|
87
|
-
case "reassess-roadmap":
|
|
88
|
-
case "rewrite-docs":
|
|
89
|
-
case "gate-evaluate":
|
|
90
|
-
case "validate-milestone":
|
|
91
|
-
return ["validation", "planning"];
|
|
92
|
-
default:
|
|
93
|
-
// Subagent unit types (e.g., "subagent", "subagent/scout")
|
|
94
|
-
if (unitType === "subagent" || unitType.startsWith("subagent/")) {
|
|
95
|
-
return ["subagent"];
|
|
96
|
-
}
|
|
97
|
-
return undefined;
|
|
53
|
+
// Unit types declare their chain on their Unit Descriptor (ADR-033).
|
|
54
|
+
const declared = getUnitPhaseChain(unitType);
|
|
55
|
+
if (declared) return [...declared];
|
|
56
|
+
// Dispatch types without a Unit Descriptor.
|
|
57
|
+
if (unitType === "worktree-merge") return ["completion"];
|
|
58
|
+
// Subagent unit types (e.g., "subagent", "subagent/scout")
|
|
59
|
+
if (unitType === "subagent" || unitType.startsWith("subagent/")) {
|
|
60
|
+
return ["subagent"];
|
|
98
61
|
}
|
|
62
|
+
return undefined;
|
|
99
63
|
}
|
|
100
64
|
|
|
101
65
|
/**
|
|
@@ -221,8 +185,9 @@ export function resolveThinkingLevelForUnit(unitType: string): GSDThinkingLevel
|
|
|
221
185
|
*/
|
|
222
186
|
export function resolveDefaultSessionModel(
|
|
223
187
|
sessionProvider?: string,
|
|
188
|
+
basePath?: string,
|
|
224
189
|
): { provider: string; id: string } | undefined {
|
|
225
|
-
const prefs = loadEffectiveGSDPreferences(
|
|
190
|
+
const prefs = loadEffectiveGSDPreferences(basePath, { availableModelIds: [] });
|
|
226
191
|
const models = prefs?.preferences?.models;
|
|
227
192
|
if (!models) return undefined;
|
|
228
193
|
|
|
@@ -867,6 +867,24 @@ export function getIsolationMode(basePath?: string): "none" | "worktree" | "bran
|
|
|
867
867
|
return "none"; // default — no isolation, work on current branch
|
|
868
868
|
}
|
|
869
869
|
|
|
870
|
+
/**
|
|
871
|
+
* Resolve the isolation mode a unit actually runs under. A session whose
|
|
872
|
+
* worktree isolation has degraded (worktree creation failed) falls back to
|
|
873
|
+
* the milestone branch in the project root, so configured "worktree" becomes
|
|
874
|
+
* effective "branch". A stranded-work recovery session likewise runs under
|
|
875
|
+
* the adopted mode (`strandedRecoveryIsolationMode`) rather than the
|
|
876
|
+
* configured one until the recovered milestone merges — adopting the
|
|
877
|
+
* milestone branch in the project root is intentional, not degraded.
|
|
878
|
+
*/
|
|
879
|
+
export function resolveEffectiveUnitIsolationMode(
|
|
880
|
+
configuredMode: ReturnType<typeof getIsolationMode>,
|
|
881
|
+
isolationDegraded: boolean,
|
|
882
|
+
strandedRecoveryIsolationMode: "worktree" | "branch" | null = null,
|
|
883
|
+
): ReturnType<typeof getIsolationMode> {
|
|
884
|
+
if (configuredMode === "worktree" && isolationDegraded) return "branch";
|
|
885
|
+
return strandedRecoveryIsolationMode ?? configuredMode;
|
|
886
|
+
}
|
|
887
|
+
|
|
870
888
|
export function resolveParallelConfig(prefs: GSDPreferences | undefined): import("./types.js").ParallelConfig {
|
|
871
889
|
return {
|
|
872
890
|
enabled: prefs?.parallel?.enabled ?? false,
|
|
@@ -24,7 +24,7 @@ Use `subagent` only when useful: reviewer, security, or tester. Apply findings b
|
|
|
24
24
|
|
|
25
25
|
1. Use the inlined Slice Summary and UAT templates.
|
|
26
26
|
2. {{skillActivation}}
|
|
27
|
-
3. Run all slice-level verification through `gsd_exec` / Context Mode evidence; refresh current state if needed. Do not use direct `bash` for verification commands.
|
|
27
|
+
3. Run all slice-level verification through `gsd_exec` / Context Mode evidence; refresh current state if needed. Do not use direct `bash` for verification commands. See the prepended **Tool Surface** block for unavailable tools.
|
|
28
28
|
4. Complete only when every required check passes. If verification fails or source changes are needed, do **not** edit source files in this unit and do **not** call `gsd_slice_complete`.
|
|
29
29
|
5. If verification fails:
|
|
30
30
|
- Task-specific regressions: if the failure is in files the task touched and pre-task verification evidence shows it was absent before that task ran, call `gsd_task_reopen` with that task and reason.
|
|
@@ -36,7 +36,7 @@ Use `subagent` only when useful: reviewer, security, or tester. Apply findings b
|
|
|
36
36
|
8. Address every Gate to Close. Q8 = **Operational Readiness**: health signal, failure signal, recovery, monitoring gaps. Omit empty sections.
|
|
37
37
|
9. If requirement status changed, call `gsd_requirement_update`; do not write `.gsd/REQUIREMENTS.md` directly.
|
|
38
38
|
10. Prepare `gsd_slice_complete` content with camelCase fields `milestoneId`, `sliceId`, `sliceTitle`, `oneLiner`, `narrative`, `verification`, and `uatContent`.
|
|
39
|
-
11. Draft concrete UAT with preconditions, steps, expected outcomes, edge cases, and UAT Type.
|
|
39
|
+
11. Draft concrete UAT with preconditions, steps, expected outcomes, edge cases, and UAT Type. Declare the type as a bullet under a `## UAT Type` heading, exactly like `- UAT mode: browser-executable`.
|
|
40
40
|
**Web apps:** when inlined Web App UAT guidance is present, declare `browser-executable` or `runtime-executable` (not `artifact-driven`) for localhost/browser/screenshot steps; include dev-server preconditions and name Playwright specs when they exist.
|
|
41
41
|
12. Review the inlined task-summary excerpts for DECISIONS.md/KNOWLEDGE.md-worthy decisions and gotchas. Read full `*-SUMMARY.md` only if needed. Capture with `capture_thought`; do not append knowledge files.
|
|
42
42
|
13. When verification passes, call `gsd_slice_complete`. The DB-backed tool is the canonical write path. Do **not** manually write `{{sliceSummaryPath}}`. Do **not** manually write `{{sliceUatPath}}`. Do not edit roadmap checkboxes.
|
|
@@ -45,7 +45,7 @@ If slice research is inlined, trust its architectural findings, but verify every
|
|
|
45
45
|
6. Include Threat Surface (Q3), Requirement Impact (Q4), proof level, observability, integration closure, Failure Modes (Q5), Load Profile (Q6), and Negative Tests (Q7) only where applicable.
|
|
46
46
|
7. Right-size tasks. Simple slices can be one task; split only when context, ownership, or verification boundaries justify it.
|
|
47
47
|
8. Task `verify` commands must be safe, simple commands. Do not use shell pipes, redirects, semicolons, backticks, command substitution, output trimming, or grep regex alternation with `|`. If multiple checks are needed, create a small test file and run it with `node --test` or a package test script, or use separate simple commands joined only with `&&`. For absence checks, verify a pattern does not exist with `! grep -q 'pattern' file` or `! rg -q 'pattern' file`; do not use `grep -c` or `rg -c` to assert zero matches because count commands exit 1 when they find zero matches, and the verification gate treats that as failure.
|
|
48
|
-
9. Each task needs the exact `gsd_plan_slice.tasks[]` shape: `taskId`, `title`, `description`, `estimate`, `files`, `verify`, `inputs`, `expectedOutput`, and optional `observabilityImpact`. `description` should contain the Why / Do / Done-when narrative. `files`, `inputs`, and `expectedOutput` must be JSON arrays of strings, even when there is only one path (for example, `"inputs": ["src/index.ts"]`, never `"inputs": "src/index.ts"`). Use paths relative to `{{workingDirectory}}`; do not put absolute paths to the original checkout or any directory outside `{{workingDirectory}}` in `files`, `inputs`, `expectedOutput`, or verification commands. **`expectedOutput` must only list files the task actually creates or overwrites on disk.** Do NOT include files the task merely reads, verifies, tests, or describes — those belong in `inputs`, `verify`, `description`, or slice success criteria. If a task is a pure verification or test task that produces no new files, `expectedOutput` must be `[]`; if it writes a test-result log or assertion output file, list only that concrete file path. A file that does not yet exist on disk and is needed as an `input` must be produced by an earlier task's `expectedOutput` — if no prior task creates it, add a task before this one that does.
|
|
48
|
+
9. Each task needs the exact `gsd_plan_slice.tasks[]` shape: `taskId`, `title`, `description`, `estimate`, `files`, `verify`, `inputs`, `expectedOutput`, and optional `observabilityImpact`. `description` should contain the Why / Do / Done-when narrative. `files`, `inputs`, and `expectedOutput` must be JSON arrays of strings, even when there is only one path (for example, `"inputs": ["src/index.ts"]`, never `"inputs": "src/index.ts"`). Use paths relative to `{{workingDirectory}}`; do not put absolute paths to the original checkout or any directory outside `{{workingDirectory}}` in `files`, `inputs`, `expectedOutput`, or verification commands. **`expectedOutput` must only list files the task actually creates or overwrites on disk.** Do NOT include files the task merely reads, verifies, tests, or describes — those belong in `inputs`, `verify`, `description`, or slice success criteria. If a task is a pure verification or test task that produces no new files, `expectedOutput` must be `[]`; if it writes a test-result log or assertion output file, list only that concrete file path. A file that does not yet exist on disk and is needed as an `input` must be produced by an earlier task's `expectedOutput` — if no prior task creates it, add a task before this one that does. Never list GSD planning artifacts — anything under `.gsd/`, `.planning/`, or `.audits/`, or artifact names like `M001-CONTEXT.md` / `S01-PLAN.md` — in `inputs`, `files`, or `expectedOutput`: their content is preloaded as context, and they are written by workflow tools, not by tasks.
|
|
49
49
|
10. Persist with `gsd_plan_slice` using `milestoneId`, `sliceId`, `goal`, optional `successCriteria`/`proofLevel`/`integrationClosure`/`observabilityImpact`, and `tasks`. `gsd_plan_slice` handles task persistence transactionally and renders `{{outputPath}}` plus task plans; do not call `gsd_plan_task`. The DB-backed tool is the canonical write path. Do **not** rely on direct `PLAN.md` writes as the source of truth.
|
|
50
50
|
11. Self-audit before finishing: goal/demo closure, requirement coverage, deliverable coverage audit (cross-check every file listed in CONTEXT.md `## Scope` / `### In Scope` against task `files` or `expectedOutput`), locked decisions, concrete paths, dependency order, wiring, scope size, proof truthfulness, feature completeness, and quality gates. Quality gates: non-trivial slices/tasks include specific Q3-Q7 coverage where applicable.
|
|
51
51
|
12. If planning creates structural decisions, call `gsd_decision_save` for each; the tool persists the decision and regenerates `.gsd/DECISIONS.md`.
|
|
@@ -65,7 +65,7 @@ Then:
|
|
|
65
65
|
3. Define slice-level verification: the objective stopping condition. Plan real test files with real assertions; for simple slices, executable commands are fine.
|
|
66
66
|
**Web apps:** when inlined Web App UAT guidance is present, follow it for Playwright scaffolding and browser-capable verification commands.
|
|
67
67
|
4. For non-trivial slices, plan observability / proof level / integration closure, threat surface, and requirement impact. Omit entirely for simple slices.
|
|
68
|
-
5. Decompose the slice into tasks that fit one context window each. Every task passed to `gsd_plan_slice` must use the exact keys `taskId`, `title`, `description`, `estimate`, `files`, `verify`, `inputs`, `expectedOutput`, and optional `observabilityImpact`. Put Why / Do / Done-when detail in `description`. `files`, `inputs`, and `expectedOutput` must be JSON arrays of strings, even for one path (for example, `"expectedOutput": ["src/index.ts"]`, never `"expectedOutput": "src/index.ts"`). `expectedOutput` is path-only: list only files the task creates or overwrites, and use `[]` for pure verification tasks.
|
|
68
|
+
5. Decompose the slice into tasks that fit one context window each. Every task passed to `gsd_plan_slice` must use the exact keys `taskId`, `title`, `description`, `estimate`, `files`, `verify`, `inputs`, `expectedOutput`, and optional `observabilityImpact`. Put Why / Do / Done-when detail in `description`. `files`, `inputs`, and `expectedOutput` must be JSON arrays of strings, even for one path (for example, `"expectedOutput": ["src/index.ts"]`, never `"expectedOutput": "src/index.ts"`). `expectedOutput` is path-only: list only files the task creates or overwrites, and use `[]` for pure verification tasks. Never list GSD planning artifacts — anything under `.gsd/`, `.planning/`, or `.audits/`, or artifact names like `M001-CONTEXT.md` / `S01-PLAN.md` — in `inputs`, `files`, or `expectedOutput`: their content is preloaded as context, and they are written by workflow tools, not by tasks.
|
|
69
69
|
6. **Persist planning state through `gsd_plan_slice`.** Call it with the full payload. The tool writes to the DB and renders `{{outputPath}}` and `{{slicePath}}/tasks/T##-PLAN.md` automatically. Do NOT rely on direct `PLAN.md` writes.
|
|
70
70
|
7. **Self-audit the plan.** If every task were completed exactly as written, the slice goal/demo should be true. Every must-have maps to a task. Inputs and Expected Output are backtick-wrapped file paths.
|
|
71
71
|
8. If refinement produced structural decisions that diverge from the sketch, call `gsd_decision_save` for each; the tool persists the decision and regenerates `.gsd/DECISIONS.md`.
|
|
@@ -34,7 +34,7 @@ Consider these captures when rewriting the remaining tasks — they represent th
|
|
|
34
34
|
|
|
35
35
|
1. Use the inlined blocker summary excerpt first. Read the full blocker task summary only if the excerpt is absent, marked truncated, or lacks the specific blocker evidence needed to replan.
|
|
36
36
|
2. Analyze the remaining `[ ]` tasks in the slice plan. Determine which are still valid, which need modification, and which should be replaced.
|
|
37
|
-
3. **Persist replan state through `gsd_replan_slice`.** Call it with: `milestoneId`, `sliceId`, `blockerTaskId`, `blockerDescription`, `whatChanged`, `updatedTasks` (array of task objects with taskId, title, description, estimate, files, verify, inputs, expectedOutput), `removedTaskIds` (array of task ID strings). The tool structurally enforces preservation of completed tasks, writes replan history to the DB, re-renders `{{planPath}}`, and renders `{{replanPath}}`. Preserve or update the Threat Surface and Requirement Impact sections if the replan changes the slice's security posture or requirement coverage.
|
|
37
|
+
3. **Persist replan state through `gsd_replan_slice`.** Call it with: `milestoneId`, `sliceId`, `blockerTaskId`, `blockerDescription`, `whatChanged`, `updatedTasks` (array of task objects with taskId, title, description, estimate, files, verify, inputs, expectedOutput), `removedTaskIds` (array of task ID strings). Never list GSD planning artifacts — anything under `.gsd/`, `.planning/`, or `.audits/`, or artifact names like `M001-CONTEXT.md` / `S01-PLAN.md` — in `inputs`, `files`, or `expectedOutput`: their content is preloaded as context, and they are written by workflow tools, not by tasks. The tool structurally enforces preservation of completed tasks, writes replan history to the DB, re-renders `{{planPath}}`, and renders `{{replanPath}}`. Preserve or update the Threat Surface and Requirement Impact sections if the replan changes the slice's security posture or requirement coverage.
|
|
38
38
|
4. If any incomplete task had a `T0x-PLAN.md`, remove or rewrite it to match the new task description.
|
|
39
39
|
5. Do not commit manually — the system auto-commits your changes after this unit completes.
|
|
40
40
|
|