gsd-pi 2.80.0-dev.fbe7c8c6f → 2.81.0-dev.3cddbbba2
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 +47 -59
- package/dist/claude-cli-check.d.ts +30 -0
- package/dist/claude-cli-check.js +18 -7
- package/dist/cli.js +0 -19
- package/dist/headless-query.d.ts +10 -0
- package/dist/headless-query.js +6 -4
- package/dist/loader-entrypoint.d.ts +8 -0
- package/dist/loader-entrypoint.js +27 -0
- package/dist/loader.js +2 -11
- package/dist/mcp-server.d.ts +1 -0
- package/dist/mcp-server.js +6 -3
- package/dist/resources/.managed-resources-content-hash +1 -1
- package/dist/resources/extensions/claude-code-cli/readiness.js +18 -7
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +40 -3
- package/dist/resources/extensions/github-sync/sync.js +4 -1
- package/dist/resources/extensions/gsd/auto/contracts.js +2 -0
- package/dist/resources/extensions/gsd/auto/loop.js +214 -17
- package/dist/resources/extensions/gsd/auto/orchestrator.js +48 -4
- package/dist/resources/extensions/gsd/auto/phases.js +372 -134
- package/dist/resources/extensions/gsd/auto/resolve.js +29 -0
- package/dist/resources/extensions/gsd/auto/run-unit.js +88 -33
- package/dist/resources/extensions/gsd/auto/session.js +18 -1
- package/dist/resources/extensions/gsd/auto/unit-runner-events.js +7 -0
- package/dist/resources/extensions/gsd/auto/verification-retry-policy.js +43 -0
- package/dist/resources/extensions/gsd/auto/workflow-dispatch-claim.js +33 -1
- package/dist/resources/extensions/gsd/auto/workflow-worker-heartbeat.js +9 -1
- package/dist/resources/extensions/gsd/auto-dashboard.js +199 -177
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +5 -32
- package/dist/resources/extensions/gsd/auto-dispatch.js +30 -11
- package/dist/resources/extensions/gsd/auto-post-unit.js +119 -79
- package/dist/resources/extensions/gsd/auto-prompts.js +103 -16
- package/dist/resources/extensions/gsd/auto-recovery.js +43 -1
- package/dist/resources/extensions/gsd/auto-runtime-state.js +5 -0
- package/dist/resources/extensions/gsd/auto-start.js +251 -16
- package/dist/resources/extensions/gsd/auto-supervisor.js +8 -1
- package/dist/resources/extensions/gsd/auto-timeout-recovery.js +2 -2
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +33 -5
- package/dist/resources/extensions/gsd/auto-verification.js +12 -6
- package/dist/resources/extensions/gsd/auto-worktree.js +237 -336
- package/dist/resources/extensions/gsd/auto.js +493 -129
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +133 -12
- package/dist/resources/extensions/gsd/bootstrap/db-tools.js +44 -37
- package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +37 -10
- package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +30 -20
- package/dist/resources/extensions/gsd/bootstrap/journal-tools.js +4 -1
- package/dist/resources/extensions/gsd/bootstrap/memory-tools.js +6 -4
- package/dist/resources/extensions/gsd/bootstrap/query-tools.js +5 -3
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +1 -1
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +337 -55
- package/dist/resources/extensions/gsd/bootstrap/register-shortcuts.js +4 -8
- package/dist/resources/extensions/gsd/bootstrap/sanitize-complete-milestone.js +4 -0
- package/dist/resources/extensions/gsd/bootstrap/system-context.js +82 -23
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +19 -2
- package/dist/resources/extensions/gsd/clean-root-preflight.js +24 -6
- package/dist/resources/extensions/gsd/commands/handlers/notifications-handler.js +4 -10
- package/dist/resources/extensions/gsd/commands/handlers/ops.js +2 -2
- package/dist/resources/extensions/gsd/commands-config.js +1 -1
- package/dist/resources/extensions/gsd/commands-eval-review.js +2 -2
- package/dist/resources/extensions/gsd/commands-handlers.js +23 -9
- package/dist/resources/extensions/gsd/context-budget.js +37 -2
- package/dist/resources/extensions/gsd/crash-recovery.js +56 -10
- package/dist/resources/extensions/gsd/dashboard-overlay.js +1 -1
- package/dist/resources/extensions/gsd/db/unit-dispatches.js +92 -0
- package/dist/resources/extensions/gsd/db-base-schema.js +4 -2
- package/dist/resources/extensions/gsd/db-migration-steps.js +6 -0
- package/dist/resources/extensions/gsd/ecosystem/gsd-extension-api.js +2 -0
- package/dist/resources/extensions/gsd/git-service.js +75 -6
- package/dist/resources/extensions/gsd/gsd-db.js +46 -13
- package/dist/resources/extensions/gsd/guided-flow.js +119 -42
- package/dist/resources/extensions/gsd/health-widget-core.js +1 -1
- package/dist/resources/extensions/gsd/health-widget.js +6 -9
- package/dist/resources/extensions/gsd/init-wizard.js +4 -1
- package/dist/resources/extensions/gsd/memory-store.js +69 -12
- package/dist/resources/extensions/gsd/migrate/command.js +40 -1
- package/dist/resources/extensions/gsd/migration-auto-check.js +87 -0
- package/dist/resources/extensions/gsd/native-git-bridge.js +46 -22
- package/dist/resources/extensions/gsd/notification-overlay.js +35 -40
- package/dist/resources/extensions/gsd/orphan-stash-audit.js +101 -0
- 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/parallel-orchestrator.js +13 -3
- package/dist/resources/extensions/gsd/planning-path-scope.js +26 -0
- package/dist/resources/extensions/gsd/pre-execution-checks.js +22 -0
- package/dist/resources/extensions/gsd/prompt-loader.js +28 -2
- package/dist/resources/extensions/gsd/prompts/complete-milestone.md +22 -17
- 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/execute-task.md +4 -2
- package/dist/resources/extensions/gsd/prompts/parallel-research-slices.md +1 -1
- package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/quick-task.md +1 -5
- package/dist/resources/extensions/gsd/prompts/replan-slice.md +2 -2
- package/dist/resources/extensions/gsd/prompts/validate-milestone.md +2 -2
- package/dist/resources/extensions/gsd/quick.js +34 -2
- package/dist/resources/extensions/gsd/recovery-classification.js +94 -0
- package/dist/resources/extensions/gsd/slice-cadence.js +45 -2
- package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +15 -9
- package/dist/resources/extensions/gsd/state-reconciliation.js +27 -0
- package/dist/resources/extensions/gsd/tool-contract.js +50 -0
- package/dist/resources/extensions/gsd/tools/complete-milestone.js +6 -7
- package/dist/resources/extensions/gsd/tools/complete-task.js +1 -1
- package/dist/resources/extensions/gsd/tools/context-mode-tool-result.js +15 -0
- package/dist/resources/extensions/gsd/tools/exec-search-tool.js +5 -0
- package/dist/resources/extensions/gsd/tools/exec-tool.js +3 -15
- package/dist/resources/extensions/gsd/tools/memory-tools.js +1 -0
- package/dist/resources/extensions/gsd/tools/plan-slice.js +9 -0
- package/dist/resources/extensions/gsd/tools/plan-task.js +9 -0
- package/dist/resources/extensions/gsd/tools/resume-tool.js +5 -0
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +1 -1
- package/dist/resources/extensions/gsd/tui/render-kit.js +74 -0
- package/dist/resources/extensions/gsd/unit-context-composer.js +12 -3
- package/dist/resources/extensions/gsd/unit-runtime.js +22 -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/workflow-protocol.js +131 -0
- package/dist/resources/extensions/gsd/worktree-lifecycle.js +1364 -0
- package/dist/resources/extensions/gsd/worktree-safety.js +119 -0
- package/dist/resources/extensions/gsd/worktree-state-projection.js +317 -0
- package/dist/resources/extensions/gsd/worktree-telemetry.js +3 -1
- package/dist/resources/skills/web-quality-audit/scripts/analyze.sh +0 -0
- package/dist/tsconfig.extensions.tsbuildinfo +1 -1
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +13 -13
- package/dist/web/standalone/.next/build-manifest.json +3 -3
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/react-loadable-manifest.json +2 -2
- package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +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/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +2 -2
- package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +2 -2
- package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +13 -13
- 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 +3 -3
- 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/8359.e059d86b255fce1c.js +10 -0
- package/dist/web/standalone/.next/static/chunks/app/{page-fab3ebb85b006001.js → page-752f1e2ebdaa3e45.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/{webpack-0481f1221120a7c6.js → webpack-de742b64187e13fe.js} +1 -1
- package/dist/welcome-screen.d.ts +2 -7
- package/dist/welcome-screen.js +68 -75
- package/package.json +3 -3
- package/packages/daemon/package.json +2 -2
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +22 -17
- 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.test.ts +75 -2
- package/packages/mcp-server/src/workflow-tools.ts +30 -16
- package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
- package/packages/native/package.json +1 -1
- package/packages/native/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-agent-core/dist/agent-loop.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/agent-loop.js +4 -1
- package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
- package/packages/pi-agent-core/dist/agent.d.ts +9 -2
- package/packages/pi-agent-core/dist/agent.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/agent.js +43 -11
- package/packages/pi-agent-core/dist/agent.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 +2 -0
- package/packages/pi-agent-core/dist/index.js.map +1 -1
- package/packages/pi-agent-core/dist/token-audit.d.ts +47 -0
- package/packages/pi-agent-core/dist/token-audit.d.ts.map +1 -0
- package/packages/pi-agent-core/dist/token-audit.js +221 -0
- package/packages/pi-agent-core/dist/token-audit.js.map +1 -0
- package/packages/pi-agent-core/dist/types.d.ts +31 -0
- package/packages/pi-agent-core/dist/types.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/types.js.map +1 -1
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-agent-core/src/agent-loop.test.ts +128 -0
- package/packages/pi-agent-core/src/agent-loop.ts +4 -1
- package/packages/pi-agent-core/src/agent.ts +52 -11
- package/packages/pi-agent-core/src/index.ts +2 -0
- package/packages/pi-agent-core/src/token-audit.test.ts +189 -0
- package/packages/pi-agent-core/src/token-audit.ts +287 -0
- package/packages/pi-agent-core/src/types.ts +26 -10
- package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-ai/dist/providers/anthropic-auth.test.js +35 -13
- package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.js +21 -11
- package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.d.ts +7 -0
- package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.js +9 -7
- package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
- package/packages/pi-ai/dist/providers/minimax-tool-name.test.js +23 -14
- package/packages/pi-ai/dist/providers/minimax-tool-name.test.js.map +1 -1
- package/packages/pi-ai/dist/types.d.ts +2 -0
- package/packages/pi-ai/dist/types.d.ts.map +1 -1
- package/packages/pi-ai/dist/types.js.map +1 -1
- package/packages/pi-ai/dist/utils/oauth/github-copilot.test.js +48 -21
- package/packages/pi-ai/dist/utils/oauth/github-copilot.test.js.map +1 -1
- package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.js +22 -21
- package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.js.map +1 -1
- package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.js +22 -21
- package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.js.map +1 -1
- package/packages/pi-ai/package.json +1 -1
- package/packages/pi-ai/src/providers/anthropic-auth.test.ts +39 -25
- package/packages/pi-ai/src/providers/anthropic-bearer-auth.test.ts +26 -22
- package/packages/pi-ai/src/providers/anthropic.ts +22 -9
- package/packages/pi-ai/src/providers/minimax-tool-name.test.ts +34 -21
- package/packages/pi-ai/src/types.ts +3 -0
- package/packages/pi-ai/src/utils/oauth/github-copilot.test.ts +56 -22
- package/packages/pi-ai/src/utils/oauth/google-antigravity.test.ts +24 -28
- package/packages/pi-ai/src/utils/oauth/google-gemini-cli.test.ts +24 -28
- package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +36 -1
- package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session-tool-refresh.test.js +30 -1
- package/packages/pi-coding-agent/dist/core/agent-session-tool-refresh.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts +21 -2
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.js +94 -16
- package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js +6 -2
- package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts +11 -0
- package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction/compaction.js +9 -0
- package/packages/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction-threshold.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/compaction-threshold.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/compaction-threshold.test.js +103 -0
- package/packages/pi-coding-agent/dist/core/compaction-threshold.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/db-snapshot.d.ts +15 -0
- package/packages/pi-coding-agent/dist/core/db-snapshot.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/db-snapshot.js +66 -0
- package/packages/pi-coding-agent/dist/core/db-snapshot.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/db-snapshot.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/db-snapshot.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/db-snapshot.test.js +24 -0
- package/packages/pi-coding-agent/dist/core/db-snapshot.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/loader.js +8 -0
- package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +3 -0
- package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.js +6 -6
- package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.test.js +5 -3
- package/packages/pi-coding-agent/dist/core/extensions/runner.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +60 -4
- package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/hooks-runner.test.js +2 -0
- package/packages/pi-coding-agent/dist/core/hooks-runner.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/sdk-tool-filter.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/sdk-tool-filter.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/sdk-tool-filter.test.js +46 -0
- package/packages/pi-coding-agent/dist/core/sdk-tool-filter.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/sdk.d.ts +10 -2
- package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/sdk.js +81 -4
- package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +20 -0
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.js +25 -0
- package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/skill-tool.test.js +22 -0
- package/packages/pi-coding-agent/dist/core/skill-tool.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/system-prompt.d.ts +6 -7
- package/packages/pi-coding-agent/dist/core/system-prompt.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/system-prompt.js +2 -3
- package/packages/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/bash-spawn-windows.test.js +22 -56
- package/packages/pi-coding-agent/dist/core/tools/bash-spawn-windows.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/bash.d.ts +1 -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 +3 -1
- package/packages/pi-coding-agent/dist/core/tools/bash.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/edit.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/tools/edit.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/edit.js +12 -1
- package/packages/pi-coding-agent/dist/core/tools/edit.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/find.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/tools/find.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/find.js +14 -6
- package/packages/pi-coding-agent/dist/core/tools/find.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/grep.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/tools/grep.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/grep.js +12 -3
- package/packages/pi-coding-agent/dist/core/tools/grep.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/hashline-read.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/tools/hashline-read.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/hashline-read.js +3 -1
- package/packages/pi-coding-agent/dist/core/tools/hashline-read.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/index.d.ts +2 -1
- package/packages/pi-coding-agent/dist/core/tools/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/index.js +1 -0
- package/packages/pi-coding-agent/dist/core/tools/index.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/ls.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/tools/ls.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/ls.js +10 -3
- package/packages/pi-coding-agent/dist/core/tools/ls.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/read.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/tools/read.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/read.js +3 -1
- package/packages/pi-coding-agent/dist/core/tools/read.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/spawn-shell-windows.test.js +7 -62
- package/packages/pi-coding-agent/dist/core/tools/spawn-shell-windows.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/tool-target-metadata.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/tools/tool-target-metadata.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/tools/tool-target-metadata.test.js +115 -0
- package/packages/pi-coding-agent/dist/core/tools/tool-target-metadata.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/tools/tool-target.d.ts +19 -0
- package/packages/pi-coding-agent/dist/core/tools/tool-target.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/tools/tool-target.js +20 -0
- package/packages/pi-coding-agent/dist/core/tools/tool-target.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/tools/write.d.ts +4 -0
- package/packages/pi-coding-agent/dist/core/tools/write.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/write.js +9 -1
- package/packages/pi-coding-agent/dist/core/tools/write.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 +161 -7
- 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-card-cleanup-and-success-runtime.test.js +25 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts +6 -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 +225 -73
- 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/controllers/chat-controller.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +31 -6
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.test.js +71 -0
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +25 -3
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.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/modes/rpc/rpc-mode.js +1 -1
- package/packages/pi-coding-agent/dist/modes/rpc/rpc-mode.js.map +1 -1
- package/packages/pi-coding-agent/dist/resources/extensions/memory/storage-safety-guard.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/resources/extensions/memory/storage-safety-guard.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/resources/extensions/memory/storage-safety-guard.test.js +28 -0
- package/packages/pi-coding-agent/dist/resources/extensions/memory/storage-safety-guard.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/resources/extensions/memory/storage.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/resources/extensions/memory/storage.js +3 -2
- package/packages/pi-coding-agent/dist/resources/extensions/memory/storage.js.map +1 -1
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +40 -1
- package/packages/pi-coding-agent/src/core/agent-session-tool-refresh.test.ts +40 -1
- package/packages/pi-coding-agent/src/core/agent-session.ts +102 -16
- package/packages/pi-coding-agent/src/core/chat-controller-ordering.test.ts +6 -2
- package/packages/pi-coding-agent/src/core/compaction/compaction.ts +18 -0
- package/packages/pi-coding-agent/src/core/compaction-threshold.test.ts +121 -0
- package/packages/pi-coding-agent/src/core/db-snapshot.test.ts +32 -0
- package/packages/pi-coding-agent/src/core/db-snapshot.ts +66 -0
- package/packages/pi-coding-agent/src/core/extensions/loader.ts +10 -0
- package/packages/pi-coding-agent/src/core/extensions/runner.test.ts +5 -3
- package/packages/pi-coding-agent/src/core/extensions/runner.ts +8 -5
- package/packages/pi-coding-agent/src/core/extensions/types.ts +63 -2
- package/packages/pi-coding-agent/src/core/hooks-runner.test.ts +2 -0
- package/packages/pi-coding-agent/src/core/sdk-tool-filter.test.ts +60 -0
- package/packages/pi-coding-agent/src/core/sdk.ts +92 -4
- package/packages/pi-coding-agent/src/core/settings-manager.ts +39 -1
- package/packages/pi-coding-agent/src/core/skill-tool.test.ts +28 -0
- package/packages/pi-coding-agent/src/core/system-prompt.ts +8 -10
- package/packages/pi-coding-agent/src/core/tools/bash-spawn-windows.test.ts +22 -66
- package/packages/pi-coding-agent/src/core/tools/bash.ts +4 -1
- package/packages/pi-coding-agent/src/core/tools/edit.ts +13 -1
- package/packages/pi-coding-agent/src/core/tools/find.ts +15 -6
- package/packages/pi-coding-agent/src/core/tools/grep.ts +13 -3
- package/packages/pi-coding-agent/src/core/tools/hashline-read.ts +4 -1
- package/packages/pi-coding-agent/src/core/tools/index.ts +8 -0
- package/packages/pi-coding-agent/src/core/tools/ls.ts +11 -3
- package/packages/pi-coding-agent/src/core/tools/read.ts +4 -1
- package/packages/pi-coding-agent/src/core/tools/spawn-shell-windows.test.ts +11 -72
- package/packages/pi-coding-agent/src/core/tools/tool-target-metadata.test.ts +127 -0
- package/packages/pi-coding-agent/src/core/tools/tool-target.ts +48 -0
- package/packages/pi-coding-agent/src/core/tools/write.ts +14 -2
- 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 +228 -7
- 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-card-cleanup-and-success-runtime.test.ts +31 -1
- package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +247 -94
- 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/controllers/chat-controller.test.ts +75 -0
- package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +39 -8
- package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +27 -3
- 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/modes/rpc/rpc-mode.ts +1 -1
- package/packages/pi-coding-agent/src/resources/extensions/memory/storage-safety-guard.test.ts +31 -0
- package/packages/pi-coding-agent/src/resources/extensions/memory/storage.ts +3 -2
- 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 +18 -8
- 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 +20 -8
- package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
- package/packages/rpc-client/README.md +7 -0
- package/packages/rpc-client/package.json +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/extensions/claude-code-cli/readiness.ts +25 -7
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +42 -3
- package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +67 -0
- package/src/resources/extensions/github-sync/sync.ts +8 -1
- package/src/resources/extensions/github-sync/tests/sync-source.test.ts +6 -18
- package/src/resources/extensions/gsd/auto/contracts.ts +19 -2
- package/src/resources/extensions/gsd/auto/loop-deps.ts +19 -16
- package/src/resources/extensions/gsd/auto/loop.ts +247 -25
- package/src/resources/extensions/gsd/auto/orchestrator.ts +52 -4
- package/src/resources/extensions/gsd/auto/phases.ts +512 -202
- package/src/resources/extensions/gsd/auto/resolve.ts +42 -1
- package/src/resources/extensions/gsd/auto/run-unit.ts +97 -34
- package/src/resources/extensions/gsd/auto/session.ts +19 -1
- package/src/resources/extensions/gsd/auto/types.ts +3 -0
- package/src/resources/extensions/gsd/auto/unit-runner-events.ts +15 -0
- package/src/resources/extensions/gsd/auto/verification-retry-policy.ts +82 -0
- package/src/resources/extensions/gsd/auto/workflow-dispatch-claim.ts +63 -1
- package/src/resources/extensions/gsd/auto/workflow-worker-heartbeat.ts +14 -1
- package/src/resources/extensions/gsd/auto-dashboard.ts +249 -182
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +8 -34
- package/src/resources/extensions/gsd/auto-dispatch.ts +31 -1
- package/src/resources/extensions/gsd/auto-post-unit.ts +131 -81
- package/src/resources/extensions/gsd/auto-prompts.ts +112 -15
- package/src/resources/extensions/gsd/auto-recovery.ts +54 -0
- package/src/resources/extensions/gsd/auto-runtime-state.ts +5 -0
- package/src/resources/extensions/gsd/auto-start.ts +321 -21
- package/src/resources/extensions/gsd/auto-supervisor.ts +7 -0
- package/src/resources/extensions/gsd/auto-timeout-recovery.ts +2 -2
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +51 -0
- package/src/resources/extensions/gsd/auto-verification.ts +12 -6
- package/src/resources/extensions/gsd/auto-worktree.ts +267 -360
- package/src/resources/extensions/gsd/auto.ts +578 -126
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +166 -12
- package/src/resources/extensions/gsd/bootstrap/db-tools.ts +45 -37
- package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +36 -10
- package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +32 -19
- package/src/resources/extensions/gsd/bootstrap/journal-tools.ts +5 -1
- package/src/resources/extensions/gsd/bootstrap/memory-tools.ts +7 -4
- package/src/resources/extensions/gsd/bootstrap/query-tools.ts +6 -3
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +1 -1
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +384 -55
- package/src/resources/extensions/gsd/bootstrap/register-shortcuts.ts +5 -8
- package/src/resources/extensions/gsd/bootstrap/sanitize-complete-milestone.ts +4 -0
- package/src/resources/extensions/gsd/bootstrap/system-context.ts +90 -22
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +19 -2
- package/src/resources/extensions/gsd/clean-root-preflight.ts +32 -7
- package/src/resources/extensions/gsd/commands/handlers/notifications-handler.ts +4 -10
- package/src/resources/extensions/gsd/commands/handlers/ops.ts +4 -2
- package/src/resources/extensions/gsd/commands-config.ts +1 -1
- package/src/resources/extensions/gsd/commands-eval-review.ts +2 -2
- package/src/resources/extensions/gsd/commands-handlers.ts +34 -15
- package/src/resources/extensions/gsd/context-budget.ts +44 -2
- package/src/resources/extensions/gsd/crash-recovery.ts +67 -10
- package/src/resources/extensions/gsd/dashboard-overlay.ts +1 -1
- package/src/resources/extensions/gsd/db/unit-dispatches.ts +107 -0
- package/src/resources/extensions/gsd/db-base-schema.ts +4 -2
- package/src/resources/extensions/gsd/db-migration-steps.ts +8 -0
- package/src/resources/extensions/gsd/ecosystem/gsd-extension-api.ts +3 -0
- package/src/resources/extensions/gsd/git-service.ts +89 -10
- package/src/resources/extensions/gsd/gsd-db.ts +50 -13
- package/src/resources/extensions/gsd/guided-flow.ts +148 -49
- package/src/resources/extensions/gsd/health-widget-core.ts +1 -1
- package/src/resources/extensions/gsd/health-widget.ts +8 -9
- package/src/resources/extensions/gsd/init-wizard.ts +5 -1
- package/src/resources/extensions/gsd/journal.ts +2 -0
- package/src/resources/extensions/gsd/memory-store.ts +77 -12
- package/src/resources/extensions/gsd/migrate/command.ts +47 -1
- package/src/resources/extensions/gsd/migration-auto-check.ts +129 -0
- package/src/resources/extensions/gsd/native-git-bridge.ts +53 -19
- package/src/resources/extensions/gsd/notification-overlay.ts +50 -46
- package/src/resources/extensions/gsd/orphan-stash-audit.ts +117 -0
- 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/parallel-orchestrator.ts +13 -3
- package/src/resources/extensions/gsd/planning-path-scope.ts +35 -0
- package/src/resources/extensions/gsd/pre-execution-checks.ts +23 -0
- package/src/resources/extensions/gsd/preferences-types.ts +1 -1
- package/src/resources/extensions/gsd/prompt-loader.ts +27 -2
- package/src/resources/extensions/gsd/prompts/complete-milestone.md +22 -17
- 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/execute-task.md +4 -2
- package/src/resources/extensions/gsd/prompts/parallel-research-slices.md +1 -1
- package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/quick-task.md +1 -5
- package/src/resources/extensions/gsd/prompts/replan-slice.md +2 -2
- package/src/resources/extensions/gsd/prompts/validate-milestone.md +2 -2
- package/src/resources/extensions/gsd/quick.ts +37 -2
- package/src/resources/extensions/gsd/recovery-classification.ts +122 -0
- package/src/resources/extensions/gsd/slice-cadence.ts +49 -2
- package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +23 -9
- package/src/resources/extensions/gsd/state-reconciliation.ts +57 -0
- package/src/resources/extensions/gsd/tests/agent-end-retry.test.ts +59 -89
- package/src/resources/extensions/gsd/tests/artifact-retry-cap.test.ts +47 -172
- package/src/resources/extensions/gsd/tests/artifacts-table-preserved-on-cache-invalidate.test.ts +0 -35
- package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +134 -9
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +1125 -215
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +80 -59
- package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +119 -2
- package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +3 -47
- package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +363 -18
- package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +175 -11
- package/src/resources/extensions/gsd/tests/auto-pr-bugs.test.ts +54 -95
- package/src/resources/extensions/gsd/tests/auto-project-root-env.test.ts +67 -26
- package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +14 -1
- package/src/resources/extensions/gsd/tests/auto-remediate-slice-status.test.ts +32 -30
- package/src/resources/extensions/gsd/tests/auto-runtime-state.test.ts +16 -1
- package/src/resources/extensions/gsd/tests/auto-start-bootstrap-await-3420.test.ts +32 -128
- package/src/resources/extensions/gsd/tests/auto-start-clean-runtime-db-gated.test.ts +20 -54
- package/src/resources/extensions/gsd/tests/auto-start-cold-db-bootstrap.test.ts +20 -30
- package/src/resources/extensions/gsd/tests/auto-start-index-lock.test.ts +17 -29
- package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +160 -0
- package/src/resources/extensions/gsd/tests/auto-start-time-persistence.test.ts +21 -39
- package/src/resources/extensions/gsd/tests/auto-start-worktree-db-path.test.ts +15 -24
- package/src/resources/extensions/gsd/tests/auto-thinking-restore.test.ts +44 -29
- package/src/resources/extensions/gsd/tests/auto-unit-closeout.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/auto-warning-noise-regression.test.ts +39 -51
- package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +159 -213
- package/src/resources/extensions/gsd/tests/bootstrap-derive-state-db-open.test.ts +15 -32
- package/src/resources/extensions/gsd/tests/browser-teardown.test.ts +0 -41
- package/src/resources/extensions/gsd/tests/clean-root-preflight.test.ts +15 -6
- package/src/resources/extensions/gsd/tests/clear-stale-autostart.test.ts +34 -27
- package/src/resources/extensions/gsd/tests/cmux.test.ts +51 -53
- package/src/resources/extensions/gsd/tests/cold-resume-db-reopen.test.ts +39 -61
- package/src/resources/extensions/gsd/tests/commands-config.test.ts +26 -19
- package/src/resources/extensions/gsd/tests/compaction-snapshot.test.ts +14 -1
- package/src/resources/extensions/gsd/tests/complete-milestone-excerpt.test.ts +31 -0
- package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +140 -0
- package/src/resources/extensions/gsd/tests/complete-slice-composer.test.ts +3 -2
- package/src/resources/extensions/gsd/tests/complete-task-normalize-lists.test.ts +29 -33
- package/src/resources/extensions/gsd/tests/completed-units-metrics-sync.test.ts +45 -108
- package/src/resources/extensions/gsd/tests/context-budget.test.ts +10 -1
- package/src/resources/extensions/gsd/tests/context-store.test.ts +7 -1
- package/src/resources/extensions/gsd/tests/crash-handler-secondary.test.ts +90 -31
- package/src/resources/extensions/gsd/tests/crash-recovery-via-db.test.ts +22 -0
- package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +46 -11
- package/src/resources/extensions/gsd/tests/cwd-fallback-hardening.test.ts +138 -0
- package/src/resources/extensions/gsd/tests/dashboard-custom-engine.test.ts +4 -68
- package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +24 -11
- package/src/resources/extensions/gsd/tests/deferred-milestone-dir-4996.test.ts +14 -65
- package/src/resources/extensions/gsd/tests/discuss-tool-scoping.test.ts +44 -37
- package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +100 -38
- package/src/resources/extensions/gsd/tests/dispatch-guard-closed-status.test.ts +25 -15
- package/src/resources/extensions/gsd/tests/dispatch-rule-coverage.test.ts +313 -0
- package/src/resources/extensions/gsd/tests/dispatcher-stuck-planning.test.ts +35 -17
- package/src/resources/extensions/gsd/tests/error-success-mask.test.ts +16 -21
- package/src/resources/extensions/gsd/tests/est-annotation-timeout.test.ts +15 -82
- package/src/resources/extensions/gsd/tests/exec-history.test.ts +15 -0
- package/src/resources/extensions/gsd/tests/exec-sandbox.test.ts +65 -0
- package/src/resources/extensions/gsd/tests/execute-task-rendering.test.ts +5 -2
- package/src/resources/extensions/gsd/tests/fast-forward-reused-milestone-branch.test.ts +219 -0
- package/src/resources/extensions/gsd/tests/finalize-survivor-branch.test.ts +151 -0
- package/src/resources/extensions/gsd/tests/flat-rate-routing-guard.test.ts +2 -20
- package/src/resources/extensions/gsd/tests/frontmatter-parse-noise.test.ts +18 -26
- 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/init-skip-git.test.ts +9 -12
- package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +40 -0
- package/src/resources/extensions/gsd/tests/integration/commands-eval-review.integration.test.ts +4 -2
- package/src/resources/extensions/gsd/tests/integration/git-locale.test.ts +31 -20
- package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +92 -0
- package/src/resources/extensions/gsd/tests/integration/milestone-transition-worktree.test.ts +0 -47
- package/src/resources/extensions/gsd/tests/integration/parallel-merge.test.ts +116 -24
- package/src/resources/extensions/gsd/tests/interactive-routing-bypass.test.ts +60 -202
- package/src/resources/extensions/gsd/tests/isolation-none-branch-guard.test.ts +13 -56
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +248 -11
- package/src/resources/extensions/gsd/tests/journal-query-tool.test.ts +32 -0
- package/src/resources/extensions/gsd/tests/knowledge.test.ts +47 -0
- package/src/resources/extensions/gsd/tests/lazy-pi-tui-import.test.ts +44 -6
- package/src/resources/extensions/gsd/tests/memory-decay-factor.test.ts +90 -0
- package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +21 -35
- package/src/resources/extensions/gsd/tests/merge-conflict-stops-loop.test.ts +77 -12
- package/src/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +48 -0
- package/src/resources/extensions/gsd/tests/migration-auto-check.test.ts +127 -0
- package/src/resources/extensions/gsd/tests/milestone-merge-stash-restore.test.ts +267 -0
- package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +88 -98
- package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +70 -278
- package/src/resources/extensions/gsd/tests/native-git-bridge-exec-fallback.test.ts +34 -2
- package/src/resources/extensions/gsd/tests/needs-remediation-revalidation.test.ts +37 -30
- package/src/resources/extensions/gsd/tests/note-captures-executed.test.ts +32 -28
- 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 -182
- package/src/resources/extensions/gsd/tests/orphan-merge-bootstrap.test.ts +144 -0
- package/src/resources/extensions/gsd/tests/orphan-stash-audit.test.ts +201 -0
- package/src/resources/extensions/gsd/tests/parallel-monitor-overlay.test.ts +38 -6
- package/src/resources/extensions/gsd/tests/parallel-orchestrator-fast-forward.test.ts +113 -0
- package/src/resources/extensions/gsd/tests/phantom-ghost-detection.test.ts +24 -37
- package/src/resources/extensions/gsd/tests/phantom-milestone-default-queued.test.ts +9 -24
- package/src/resources/extensions/gsd/tests/phases-merge-error-stops-auto.test.ts +95 -75
- package/src/resources/extensions/gsd/tests/plan-slice.test.ts +50 -0
- package/src/resources/extensions/gsd/tests/plan-task.test.ts +21 -0
- package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/post-unit-state-rebuild.test.ts +36 -22
- package/src/resources/extensions/gsd/tests/pre-exec-backtick-strip.test.ts +36 -30
- package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +45 -5
- package/src/resources/extensions/gsd/tests/pre-execution-pause-wiring.test.ts +74 -4
- package/src/resources/extensions/gsd/tests/preferences-worktree-sync.test.ts +20 -22
- package/src/resources/extensions/gsd/tests/prefs-wizard-coverage.test.ts +130 -32
- package/src/resources/extensions/gsd/tests/project-root-cwd-crash.test.ts +18 -36
- package/src/resources/extensions/gsd/tests/projection-no-plan-overwrite.test.ts +35 -73
- package/src/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +76 -138
- package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +24 -1
- package/src/resources/extensions/gsd/tests/prompt-duplication-cuts.test.ts +230 -0
- package/src/resources/extensions/gsd/tests/prompt-path-audit.test.ts +40 -0
- package/src/resources/extensions/gsd/tests/prompt-step-ordering.test.ts +70 -106
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +59 -161
- package/src/resources/extensions/gsd/tests/query-tools-db-open.test.ts +33 -29
- package/src/resources/extensions/gsd/tests/queue-auto-guard.test.ts +22 -196
- package/src/resources/extensions/gsd/tests/quick-auto-guard.test.ts +23 -93
- package/src/resources/extensions/gsd/tests/quick-external-gsd.test.ts +40 -0
- package/src/resources/extensions/gsd/tests/quick-turn-end-cleanup.test.ts +50 -79
- package/src/resources/extensions/gsd/tests/reassess-default-optin.test.ts +27 -13
- package/src/resources/extensions/gsd/tests/remote-questions.test.ts +151 -251
- package/src/resources/extensions/gsd/tests/resource-loader-import-path.test.ts +41 -29
- package/src/resources/extensions/gsd/tests/restore-tools-after-discuss.test.ts +58 -69
- package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +36 -164
- package/src/resources/extensions/gsd/tests/run-uat-replay-cap.test.ts +57 -41
- package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +91 -0
- package/src/resources/extensions/gsd/tests/schema-v27-v28-sequence.test.ts +156 -0
- package/src/resources/extensions/gsd/tests/select-resumable-milestone.test.ts +96 -0
- package/src/resources/extensions/gsd/tests/session-model-override.test.ts +14 -9
- package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +77 -0
- package/src/resources/extensions/gsd/tests/session-switch-abort-misclassification.test.ts +222 -0
- package/src/resources/extensions/gsd/tests/show-config-command.test.ts +44 -42
- package/src/resources/extensions/gsd/tests/signal-handlers.test.ts +27 -0
- package/src/resources/extensions/gsd/tests/skip-slice-state-rebuild.test.ts +56 -24
- package/src/resources/extensions/gsd/tests/skipped-validation-db-atomicity.test.ts +51 -11
- package/src/resources/extensions/gsd/tests/slice-cadence.test.ts +23 -0
- package/src/resources/extensions/gsd/tests/slice-context-injection.test.ts +66 -50
- package/src/resources/extensions/gsd/tests/slice-parallel-orchestrator.test.ts +68 -107
- package/src/resources/extensions/gsd/tests/slice-sequence-insert.test.ts +115 -42
- package/src/resources/extensions/gsd/tests/smart-entry-complete.test.ts +21 -77
- package/src/resources/extensions/gsd/tests/smart-entry-draft.test.ts +25 -116
- package/src/resources/extensions/gsd/tests/sqlite-unavailable-gate.test.ts +21 -57
- package/src/resources/extensions/gsd/tests/stale-dirlistcache-4648.test.ts +29 -76
- package/src/resources/extensions/gsd/tests/stale-lockfile-recovery.test.ts +33 -24
- package/src/resources/extensions/gsd/tests/stale-slice-rows.test.ts +39 -30
- package/src/resources/extensions/gsd/tests/stalled-tool-recovery.test.ts +49 -1
- package/src/resources/extensions/gsd/tests/start-auto-detached.test.ts +55 -0
- package/src/resources/extensions/gsd/tests/state-corruption-2945.test.ts +65 -56
- package/src/resources/extensions/gsd/tests/status-db-open.test.ts +35 -40
- package/src/resources/extensions/gsd/tests/stop-auto-merge-back.test.ts +48 -46
- package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +14 -102
- package/src/resources/extensions/gsd/tests/subagent-model-dispatch.test.ts +78 -232
- package/src/resources/extensions/gsd/tests/sync-worktree-skip-current.test.ts +32 -35
- package/src/resources/extensions/gsd/tests/system-context-memory.test.ts +112 -0
- package/src/resources/extensions/gsd/tests/system-context-message-routing.test.ts +7 -9
- package/src/resources/extensions/gsd/tests/token-profile.test.ts +84 -309
- package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +295 -0
- package/src/resources/extensions/gsd/tests/triage-dispatch.test.ts +134 -341
- package/src/resources/extensions/gsd/tests/tui-header-lifecycle.test.ts +330 -0
- package/src/resources/extensions/gsd/tests/tui-render-kit.test.ts +66 -0
- package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +136 -4
- package/src/resources/extensions/gsd/tests/unit-context-manifest.test.ts +8 -25
- package/src/resources/extensions/gsd/tests/unit-dispatches.test.ts +80 -1
- package/src/resources/extensions/gsd/tests/unit-runtime.test.ts +37 -0
- package/src/resources/extensions/gsd/tests/unstructured-continue-context-injection.test.ts +5 -99
- package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +43 -36
- package/src/resources/extensions/gsd/tests/verification-retry-policy.test.ts +83 -0
- package/src/resources/extensions/gsd/tests/visualizer-data.test.ts +84 -444
- package/src/resources/extensions/gsd/tests/workflow-dispatch-claim.test.ts +142 -0
- package/src/resources/extensions/gsd/tests/workflow-logger-wiring.test.ts +44 -189
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +8 -57
- package/src/resources/extensions/gsd/tests/workflow-protocol-excerpt.test.ts +99 -0
- package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +3 -0
- package/src/resources/extensions/gsd/tests/workflow-worker-heartbeat.test.ts +32 -1
- package/src/resources/extensions/gsd/tests/worktree-db-same-file.test.ts +21 -44
- package/src/resources/extensions/gsd/tests/worktree-expected-warnings.test.ts +27 -26
- package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +14 -13
- package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +197 -78
- package/src/resources/extensions/gsd/tests/worktree-lifecycle.test.ts +888 -0
- package/src/resources/extensions/gsd/tests/worktree-main-branch.test.ts +20 -18
- package/src/resources/extensions/gsd/tests/worktree-path-injection.test.ts +22 -19
- package/src/resources/extensions/gsd/tests/worktree-project-root-degrade.test.ts +66 -0
- package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +327 -0
- package/src/resources/extensions/gsd/tests/worktree-state-projection.test.ts +120 -0
- package/src/resources/extensions/gsd/tests/worktree-telemetry.test.ts +59 -2
- package/src/resources/extensions/gsd/tests/write-gate-planning-unit.test.ts +18 -0
- package/src/resources/extensions/gsd/tests/write-gate.test.ts +40 -1
- package/src/resources/extensions/gsd/tests/zero-slice-roadmap-guided.test.ts +19 -13
- package/src/resources/extensions/gsd/tool-contract.ts +82 -0
- package/src/resources/extensions/gsd/tools/complete-milestone.ts +14 -15
- package/src/resources/extensions/gsd/tools/complete-task.ts +1 -1
- package/src/resources/extensions/gsd/tools/context-mode-tool-result.ts +25 -0
- package/src/resources/extensions/gsd/tools/exec-search-tool.ts +7 -7
- package/src/resources/extensions/gsd/tools/exec-tool.ts +4 -23
- package/src/resources/extensions/gsd/tools/memory-tools.ts +1 -0
- package/src/resources/extensions/gsd/tools/plan-slice.ts +13 -0
- package/src/resources/extensions/gsd/tools/plan-task.ts +10 -0
- package/src/resources/extensions/gsd/tools/resume-tool.ts +7 -7
- package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +1 -1
- package/src/resources/extensions/gsd/tui/render-kit.ts +109 -0
- package/src/resources/extensions/gsd/unit-context-composer.ts +19 -4
- package/src/resources/extensions/gsd/unit-runtime.ts +25 -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-mcp.ts +2 -2
- package/src/resources/extensions/gsd/workflow-protocol.ts +160 -0
- package/src/resources/extensions/gsd/worktree-lifecycle.ts +1882 -0
- package/src/resources/extensions/gsd/worktree-safety.ts +282 -0
- package/src/resources/extensions/gsd/worktree-state-projection.ts +404 -0
- package/src/resources/extensions/gsd/worktree-telemetry.ts +7 -2
- package/src/resources/skills/create-gsd-extension/templates/templates.test.ts +86 -40
- package/src/resources/skills/web-quality-audit/scripts/analyze.sh +0 -0
- package/dist/resources/extensions/gsd/worktree-resolver.js +0 -733
- package/dist/web/standalone/.next/static/chunks/8336.631939fb583761fa.js +0 -10
- package/src/resources/extensions/gsd/tests/sync-layer-scope.test.ts +0 -434
- package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +0 -1247
- package/src/resources/extensions/gsd/worktree-resolver.ts +0 -909
- /package/dist/web/standalone/.next/static/{yTuahMMuJzVnsov5PreWl → F5x9E6H9k_52fjqyql93y}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{yTuahMMuJzVnsov5PreWl → F5x9E6H9k_52fjqyql93y}/_ssgManifest.js +0 -0
|
@@ -7,12 +7,11 @@
|
|
|
7
7
|
* manual `/worktree` which uses `worktree/<name>` branches). This module
|
|
8
8
|
* manages create, enter, detect, and teardown for auto-mode worktrees.
|
|
9
9
|
*/
|
|
10
|
-
import { existsSync, cpSync, readFileSync, readdirSync, mkdirSync, realpathSync, rmSync, unlinkSync,
|
|
10
|
+
import { existsSync, cpSync, readFileSync, readdirSync, mkdirSync, realpathSync, rmSync, unlinkSync, lstatSync as lstatSyncFn, } from "node:fs";
|
|
11
11
|
import { isAbsolute, join, relative, sep as pathSep } from "node:path";
|
|
12
12
|
import { GSDError, GSD_IO_ERROR, GSD_GIT_ERROR } from "./errors.js";
|
|
13
|
-
import { reconcileWorktreeDb, isDbAvailable, getMilestone, getMilestoneSlices, closeDatabase, openDatabase, getDbPath, } from "./gsd-db.js";
|
|
13
|
+
import { reconcileWorktreeDb, isDbAvailable, getMilestone, getMilestoneSlices, getSliceTasks, closeDatabase, openDatabase, getDbPath, } from "./gsd-db.js";
|
|
14
14
|
import { execFileSync } from "node:child_process";
|
|
15
|
-
import { safeCopy, safeCopyRecursive } from "./safe-fs.js";
|
|
16
15
|
import { gsdRoot, resolveGsdPathContract } from "./paths.js";
|
|
17
16
|
import { createWorktree, removeWorktree, resolveGitDir, worktreePath, isInsideWorktreesDir, } from "./worktree-manager.js";
|
|
18
17
|
import { detectWorktreeName, nudgeGitBranchCache, } from "./worktree.js";
|
|
@@ -23,9 +22,10 @@ import { debugLog } from "./debug-logger.js";
|
|
|
23
22
|
import { logWarning, logError } from "./workflow-logger.js";
|
|
24
23
|
import { loadEffectiveGSDPreferences } from "./preferences.js";
|
|
25
24
|
import { MILESTONE_ID_RE } from "./milestone-ids.js";
|
|
26
|
-
import { nativeGetCurrentBranch, nativeDetectMainBranch, nativeWorkingTreeStatus, nativeAddAllWithExclusions, nativeCommit, nativeCheckoutBranch, nativeMergeSquash, nativeConflictFiles, nativeCheckoutTheirs, nativeAddPaths, nativeRmForce, nativeBranchDelete, nativeBranchForceReset, nativeBranchExists, nativeDiffNumstat, nativeUpdateRef, nativeIsAncestor, nativeMergeAbort, } from "./native-git-bridge.js";
|
|
25
|
+
import { nativeGetCurrentBranch, nativeDetectMainBranch, nativeWorkingTreeStatus, nativeAddAllWithExclusions, nativeCommit, nativeCheckoutBranch, nativeMergeSquash, nativeConflictFiles, nativeCheckoutTheirs, nativeAddPaths, nativeRmForce, nativeBranchDelete, nativeBranchForceReset, nativeBranchExists, nativeDiffNumstat, nativeUpdateRef, nativeIsAncestor, nativeMergeAbort, nativeWorktreeList, } from "./native-git-bridge.js";
|
|
27
26
|
import { gsdHome } from "./gsd-home.js";
|
|
28
27
|
import { createWorkspace } from "./workspace.js";
|
|
28
|
+
import { _finalizeProjectionForMergeImpl, _projectRootToWorktreeImpl, _projectWorktreeToRootImpl, } from "./worktree-state-projection.js";
|
|
29
29
|
const PROJECT_PREFERENCES_FILE = "PREFERENCES.md";
|
|
30
30
|
const LEGACY_PROJECT_PREFERENCES_FILE = "preferences.md";
|
|
31
31
|
const LEGACY_DEEP_SETUP_RUNTIME_UNIT_FILES = new Set([
|
|
@@ -55,10 +55,6 @@ const ROOT_STATE_FILES = [
|
|
|
55
55
|
// Back-sync (worktree → main) must NEVER overwrite the project root's copy
|
|
56
56
|
// because the project root is authoritative for preferences (#2684).
|
|
57
57
|
];
|
|
58
|
-
const ROOT_DIAGNOSTIC_FILES = [
|
|
59
|
-
"completed-units.json",
|
|
60
|
-
"metrics.json",
|
|
61
|
-
];
|
|
62
58
|
/**
|
|
63
59
|
* Pop a stash entry by tracking the unique marker embedded in its message so
|
|
64
60
|
* concurrent stash operations against the same project root cannot cause us to
|
|
@@ -135,67 +131,34 @@ function isSamePath(a, b) {
|
|
|
135
131
|
return false;
|
|
136
132
|
}
|
|
137
133
|
}
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
const srcSliceDir = join(slicesDir, sliceEntry.name);
|
|
167
|
-
const dstSliceDir = join(dstMilestoneDir, "slices", sliceEntry.name);
|
|
168
|
-
try {
|
|
169
|
-
for (const fileEntry of readdirSync(srcSliceDir, { withFileTypes: true })) {
|
|
170
|
-
if (!fileEntry.isFile())
|
|
171
|
-
continue;
|
|
172
|
-
if (!fileEntry.name.endsWith("-ASSESSMENT.md"))
|
|
173
|
-
continue;
|
|
174
|
-
const srcFile = join(srcSliceDir, fileEntry.name);
|
|
175
|
-
try {
|
|
176
|
-
const srcContent = readFileSync(srcFile, "utf-8");
|
|
177
|
-
if (!VERDICT_RE.test(srcContent))
|
|
178
|
-
continue; // no verdict in source — skip
|
|
179
|
-
// Source has a verdict — force-copy into worktree
|
|
180
|
-
mkdirSync(dstSliceDir, { recursive: true });
|
|
181
|
-
safeCopy(srcFile, join(dstSliceDir, fileEntry.name), { force: true });
|
|
182
|
-
}
|
|
183
|
-
catch (err) {
|
|
184
|
-
/* non-fatal per file */
|
|
185
|
-
logWarning("worktree", `assessment force-copy failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
catch (err) {
|
|
190
|
-
/* non-fatal per slice */
|
|
191
|
-
logWarning("worktree", `assessment slice scan failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
catch (err) {
|
|
196
|
-
/* non-fatal */
|
|
197
|
-
logWarning("worktree", `assessment sync failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
198
|
-
}
|
|
134
|
+
export function _isSamePath(a, b) {
|
|
135
|
+
return isSamePath(a, b);
|
|
136
|
+
}
|
|
137
|
+
export function _resolveAutoWorktreeStartPoint(integrationBranch, gitMainBranch, branchExists) {
|
|
138
|
+
if (integrationBranch)
|
|
139
|
+
return integrationBranch;
|
|
140
|
+
return gitMainBranch &&
|
|
141
|
+
typeof gitMainBranch === "string" &&
|
|
142
|
+
gitMainBranch.length > 0 &&
|
|
143
|
+
branchExists(gitMainBranch)
|
|
144
|
+
? gitMainBranch
|
|
145
|
+
: undefined;
|
|
146
|
+
}
|
|
147
|
+
export function _shouldReconcileWorktreeDb(worktreeDbPath, mainDbPath, pathExists = existsSync, samePath = isSamePath) {
|
|
148
|
+
return pathExists(worktreeDbPath) && !samePath(worktreeDbPath, mainDbPath);
|
|
149
|
+
}
|
|
150
|
+
export function _isExpectedWorktreeUnlinkError(code) {
|
|
151
|
+
return code === "ENOENT" || code === "EISDIR";
|
|
152
|
+
}
|
|
153
|
+
function stripGsdDisplayPrefix(value, id) {
|
|
154
|
+
const raw = String(value ?? "").trim();
|
|
155
|
+
if (!raw)
|
|
156
|
+
return undefined;
|
|
157
|
+
const lower = raw.toLowerCase();
|
|
158
|
+
const idLower = id.toLowerCase();
|
|
159
|
+
if (lower.startsWith(`${idLower}:`))
|
|
160
|
+
return raw.slice(id.length + 1).trim() || undefined;
|
|
161
|
+
return raw;
|
|
199
162
|
}
|
|
200
163
|
// ─── Module State ──────────────────────────────────────────────────────────
|
|
201
164
|
/** Active workspace registry — replaces the legacy `originalBase` singleton. */
|
|
@@ -288,7 +251,7 @@ function clearProjectRootStateFiles(basePath, milestoneId) {
|
|
|
288
251
|
catch (err) {
|
|
289
252
|
// ENOENT/EISDIR are expected for already-removed or directory entries (#3597)
|
|
290
253
|
const code = err.code;
|
|
291
|
-
if (code
|
|
254
|
+
if (!_isExpectedWorktreeUnlinkError(code)) {
|
|
292
255
|
logWarning("worktree", `untracked file unlink failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
293
256
|
}
|
|
294
257
|
}
|
|
@@ -317,6 +280,44 @@ export const SAFE_AUTO_RESOLVE_PATTERNS = [
|
|
|
317
280
|
* Covers `.gsd/` state files and common build artifacts. */
|
|
318
281
|
export const isSafeToAutoResolve = (filePath) => filePath.startsWith(".gsd/") ||
|
|
319
282
|
SAFE_AUTO_RESOLVE_PATTERNS.some((re) => re.test(filePath));
|
|
283
|
+
function removeMergeStateFiles(basePath, contextLabel) {
|
|
284
|
+
try {
|
|
285
|
+
const gitDir_ = resolveGitDir(basePath);
|
|
286
|
+
for (const f of ["SQUASH_MSG", "MERGE_MSG", "MERGE_HEAD"]) {
|
|
287
|
+
const p = join(gitDir_, f);
|
|
288
|
+
if (existsSync(p))
|
|
289
|
+
unlinkSync(p);
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
catch (err) {
|
|
293
|
+
logError("worktree", `${contextLabel} merge state cleanup failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
function cleanupSquashConflictState(basePath) {
|
|
297
|
+
// `git merge --squash` conflicts can leave unmerged index entries without
|
|
298
|
+
// MERGE_HEAD, so merge-abort alone is not enough. Reset the merge index, then
|
|
299
|
+
// remove merge message files that native/libgit2 paths may have created.
|
|
300
|
+
try {
|
|
301
|
+
nativeMergeAbort(basePath);
|
|
302
|
+
}
|
|
303
|
+
catch (err) {
|
|
304
|
+
// Expected for squash conflicts when MERGE_HEAD was never written.
|
|
305
|
+
debugLog("squash-conflict-cleanup:merge-abort-skipped", {
|
|
306
|
+
error: err instanceof Error ? err.message : String(err),
|
|
307
|
+
});
|
|
308
|
+
}
|
|
309
|
+
try {
|
|
310
|
+
execFileSync("git", ["reset", "--merge"], {
|
|
311
|
+
cwd: basePath,
|
|
312
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
313
|
+
encoding: "utf-8",
|
|
314
|
+
});
|
|
315
|
+
}
|
|
316
|
+
catch (err) {
|
|
317
|
+
logError("worktree", `git reset --merge failed after squash conflict: ${err instanceof Error ? err.message : String(err)}`);
|
|
318
|
+
}
|
|
319
|
+
removeMergeStateFiles(basePath, "squash conflict");
|
|
320
|
+
}
|
|
320
321
|
// ─── Dispatch-Level Sync (project root ↔ worktree) ──────────────────────────
|
|
321
322
|
/**
|
|
322
323
|
* Sync milestone artifacts from project root INTO worktree before deriveState.
|
|
@@ -326,156 +327,21 @@ export const isSafeToAutoResolve = (filePath) => filePath.startsWith(".gsd/") ||
|
|
|
326
327
|
* Non-fatal — sync failure should never block dispatch.
|
|
327
328
|
*/
|
|
328
329
|
/**
|
|
329
|
-
*
|
|
330
|
-
*
|
|
331
|
-
*
|
|
332
|
-
*
|
|
333
|
-
* in argument order. Asserts both scopes belong to the same workspace identity
|
|
334
|
-
* to prevent silent mismatch bugs.
|
|
335
|
-
*/
|
|
336
|
-
export function syncProjectRootToWorktreeByScope(rootScope, worktreeScope) {
|
|
337
|
-
if (rootScope.workspace.identityKey !== worktreeScope.workspace.identityKey) {
|
|
338
|
-
throw new Error(`syncProjectRootToWorktreeByScope: scope identity mismatch — ` +
|
|
339
|
-
`rootScope.identityKey="${rootScope.workspace.identityKey}" ` +
|
|
340
|
-
`worktreeScope.identityKey="${worktreeScope.workspace.identityKey}"`);
|
|
341
|
-
}
|
|
342
|
-
if (rootScope.milestoneId !== worktreeScope.milestoneId) {
|
|
343
|
-
throw new Error(`syncProjectRootToWorktreeByScope: milestoneId mismatch — ` +
|
|
344
|
-
`rootScope.milestoneId="${rootScope.milestoneId}" worktreeScope.milestoneId="${worktreeScope.milestoneId}"`);
|
|
345
|
-
}
|
|
346
|
-
const projectRoot = rootScope.workspace.projectRoot;
|
|
347
|
-
const worktreePath_ = worktreeScope.workspace.worktreeRoot ?? worktreeScope.workspace.projectRoot;
|
|
348
|
-
const milestoneId = rootScope.milestoneId;
|
|
349
|
-
syncProjectRootToWorktree(projectRoot, worktreePath_, milestoneId);
|
|
350
|
-
}
|
|
351
|
-
/**
|
|
352
|
-
* @deprecated Use syncProjectRootToWorktreeByScope instead.
|
|
353
|
-
* TODO(C-future): remove once all callers migrated.
|
|
330
|
+
* Path-string entry point to WorktreeStateProjection.projectRootToWorktree.
|
|
331
|
+
* Production code goes through the Module class; this delegator survives so
|
|
332
|
+
* the projection-invariant tests (#1886, #2184, #2478, #2821) can exercise
|
|
333
|
+
* the bodies with raw paths.
|
|
354
334
|
*/
|
|
355
335
|
export function syncProjectRootToWorktree(projectRoot, worktreePath_, milestoneId) {
|
|
356
|
-
|
|
357
|
-
return;
|
|
358
|
-
if (!milestoneId)
|
|
359
|
-
return;
|
|
360
|
-
const contract = resolveGsdPathContract(worktreePath_, projectRoot);
|
|
361
|
-
const prGsd = contract.projectGsd;
|
|
362
|
-
const wtGsd = contract.worktreeGsd ?? join(worktreePath_, ".gsd");
|
|
363
|
-
// When .gsd is a symlink to the same external directory in both locations,
|
|
364
|
-
// cpSync rejects the copy because source === destination (ERR_FS_CP_EINVAL).
|
|
365
|
-
// Compare realpaths and skip when they resolve to the same physical path (#2184).
|
|
366
|
-
if (isSamePath(prGsd, wtGsd))
|
|
367
|
-
return;
|
|
368
|
-
// Copy milestone directory from project root to worktree — additive only.
|
|
369
|
-
// force:false prevents cpSync from overwriting existing worktree files.
|
|
370
|
-
// Without this, worktree-local files (e.g. VALIDATION.md written
|
|
371
|
-
// by validate-milestone) get clobbered by stale project root copies,
|
|
372
|
-
// causing an infinite re-validation loop (#1886).
|
|
373
|
-
safeCopyRecursive(join(prGsd, "milestones", milestoneId), join(wtGsd, "milestones", milestoneId), { force: false });
|
|
374
|
-
// Force-sync ASSESSMENT files that have a verdict from project root (#2821).
|
|
375
|
-
// The additive-only copy above preserves worktree-local files, but
|
|
376
|
-
// ASSESSMENT files are special: after run-uat writes a verdict and post-unit
|
|
377
|
-
// syncs it to the project root, the worktree may retain a stale copy (e.g.
|
|
378
|
-
// verdict:fail while the project root has verdict:pass from a retry). On
|
|
379
|
-
// session resume the DB is rebuilt from disk, and if the stale ASSESSMENT
|
|
380
|
-
// persists, checkNeedsRunUat finds no passing verdict → re-dispatches
|
|
381
|
-
// run-uat indefinitely (stuck-loop ×9).
|
|
382
|
-
forceOverwriteAssessmentsWithVerdict(join(prGsd, "milestones", milestoneId), join(wtGsd, "milestones", milestoneId));
|
|
383
|
-
// Forward-sync completed-units.json from project root to worktree.
|
|
384
|
-
// Project root is authoritative for completion state after crash recovery;
|
|
385
|
-
// without this, the worktree re-dispatches already-completed units (#1886).
|
|
386
|
-
safeCopy(join(prGsd, "completed-units.json"), join(wtGsd, "completed-units.json"), { force: true });
|
|
387
|
-
// Delete a legacy worktree-local gsd.db ONLY if it is empty (0 bytes).
|
|
388
|
-
// Runtime opens contract.projectDb; this cleanup only removes corrupt
|
|
389
|
-
// pre-upgrade local DB projections.
|
|
390
|
-
try {
|
|
391
|
-
const wtDb = join(wtGsd, "gsd.db");
|
|
392
|
-
let deleteSidecars = false;
|
|
393
|
-
if (existsSync(wtDb)) {
|
|
394
|
-
const size = statSync(wtDb).size;
|
|
395
|
-
if (size === 0) {
|
|
396
|
-
unlinkSync(wtDb);
|
|
397
|
-
deleteSidecars = true;
|
|
398
|
-
}
|
|
399
|
-
}
|
|
400
|
-
else {
|
|
401
|
-
// Main DB already missing — sidecars are orphaned from a previous
|
|
402
|
-
// partial cleanup and must still be removed.
|
|
403
|
-
deleteSidecars = true;
|
|
404
|
-
}
|
|
405
|
-
// Always clean up WAL/SHM sidecar files when the main DB was deleted
|
|
406
|
-
// or is already missing. Orphaned WAL/SHM files cause SQLite WAL
|
|
407
|
-
// recovery on next open, which triggers a CPU spin on Node 24's
|
|
408
|
-
// node:sqlite DatabaseSync implementation (#2478).
|
|
409
|
-
if (deleteSidecars) {
|
|
410
|
-
for (const suffix of ["-wal", "-shm"]) {
|
|
411
|
-
const f = wtDb + suffix;
|
|
412
|
-
if (existsSync(f)) {
|
|
413
|
-
unlinkSync(f);
|
|
414
|
-
}
|
|
415
|
-
}
|
|
416
|
-
}
|
|
417
|
-
}
|
|
418
|
-
catch (err) {
|
|
419
|
-
/* non-fatal */
|
|
420
|
-
logWarning("worktree", `worktree DB cleanup failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
421
|
-
}
|
|
422
|
-
}
|
|
423
|
-
/**
|
|
424
|
-
* Scope-typed variant of syncStateToProjectRoot.
|
|
425
|
-
*
|
|
426
|
-
* Takes an explicit (worktreeScope, rootScope) pair. Direction is encoded in
|
|
427
|
-
* argument order (worktree → root). Asserts both scopes belong to the same
|
|
428
|
-
* workspace identity to prevent silent mismatch bugs.
|
|
429
|
-
*/
|
|
430
|
-
export function syncStateToProjectRootByScope(worktreeScope, rootScope) {
|
|
431
|
-
if (worktreeScope.workspace.identityKey !== rootScope.workspace.identityKey) {
|
|
432
|
-
throw new Error(`syncStateToProjectRootByScope: scope identity mismatch — ` +
|
|
433
|
-
`worktreeScope.identityKey="${worktreeScope.workspace.identityKey}" ` +
|
|
434
|
-
`rootScope.identityKey="${rootScope.workspace.identityKey}"`);
|
|
435
|
-
}
|
|
436
|
-
if (worktreeScope.milestoneId !== rootScope.milestoneId) {
|
|
437
|
-
throw new Error(`syncStateToProjectRootByScope: milestoneId mismatch — ` +
|
|
438
|
-
`worktreeScope.milestoneId="${worktreeScope.milestoneId}" rootScope.milestoneId="${rootScope.milestoneId}"`);
|
|
439
|
-
}
|
|
440
|
-
const worktreePath_ = worktreeScope.workspace.worktreeRoot ?? worktreeScope.workspace.projectRoot;
|
|
441
|
-
const projectRoot = rootScope.workspace.projectRoot;
|
|
442
|
-
const milestoneId = worktreeScope.milestoneId;
|
|
443
|
-
syncStateToProjectRoot(worktreePath_, projectRoot, milestoneId);
|
|
336
|
+
_projectRootToWorktreeImpl(projectRoot, worktreePath_, milestoneId);
|
|
444
337
|
}
|
|
445
338
|
/**
|
|
446
|
-
*
|
|
447
|
-
*
|
|
448
|
-
*
|
|
449
|
-
* copied from the worktree back to the project root.
|
|
450
|
-
* Non-fatal — sync failure should never block dispatch.
|
|
451
|
-
* @deprecated Use syncStateToProjectRootByScope instead.
|
|
452
|
-
* TODO(C-future): remove once all callers migrated.
|
|
339
|
+
* Path-string entry point to WorktreeStateProjection.projectWorktreeToRoot.
|
|
340
|
+
* Production code goes through the Module class; this delegator survives so
|
|
341
|
+
* the projection-invariant tests can exercise the body with raw paths.
|
|
453
342
|
*/
|
|
454
343
|
export function syncStateToProjectRoot(worktreePath_, projectRoot, milestoneId) {
|
|
455
|
-
|
|
456
|
-
return;
|
|
457
|
-
if (!milestoneId)
|
|
458
|
-
return;
|
|
459
|
-
const contract = resolveGsdPathContract(worktreePath_, projectRoot);
|
|
460
|
-
const wtGsd = contract.worktreeGsd ?? join(worktreePath_, ".gsd");
|
|
461
|
-
const prGsd = contract.projectGsd;
|
|
462
|
-
// When .gsd is a symlink to the same external directory in both locations,
|
|
463
|
-
// cpSync rejects the copy because source === destination (ERR_FS_CP_EINVAL).
|
|
464
|
-
// Compare realpaths and skip when they resolve to the same physical path (#2184).
|
|
465
|
-
if (isSamePath(wtGsd, prGsd))
|
|
466
|
-
return;
|
|
467
|
-
// metrics.json — session cost/token tracking (#2313).
|
|
468
|
-
// Without this, metrics accumulated in the worktree are invisible from the
|
|
469
|
-
// project root and never appear in the dashboard or skill-health reports.
|
|
470
|
-
safeCopy(join(wtGsd, "metrics.json"), join(prGsd, "metrics.json"), { force: true });
|
|
471
|
-
// completed-units.json — runtime completion diagnostics used to avoid
|
|
472
|
-
// re-dispatching work already completed in an isolated worktree.
|
|
473
|
-
safeCopy(join(wtGsd, "completed-units.json"), join(prGsd, "completed-units.json"), { force: true });
|
|
474
|
-
// Runtime records — unit dispatch diagnostics used by selfHealRuntimeRecords().
|
|
475
|
-
// Without this, a crash during a unit leaves the runtime record only in the
|
|
476
|
-
// worktree. If the next session resolves basePath before worktree re-entry,
|
|
477
|
-
// selfHeal can't find or clear the stale record (#769).
|
|
478
|
-
safeCopyRecursive(join(wtGsd, "runtime", "units"), join(prGsd, "runtime", "units"), { force: true });
|
|
344
|
+
_projectWorktreeToRootImpl(worktreePath_, projectRoot, milestoneId);
|
|
479
345
|
}
|
|
480
346
|
// ─── Resource Staleness ───────────────────────────────────────────────────
|
|
481
347
|
/**
|
|
@@ -816,50 +682,7 @@ export function syncGsdStateToWorktree(mainBasePath, worktreePath_) {
|
|
|
816
682
|
* the shared project DB or the pre-upgrade DB reconciliation path above.
|
|
817
683
|
*/
|
|
818
684
|
export function syncWorktreeStateBack(mainBasePath, worktreePath, milestoneId) {
|
|
819
|
-
|
|
820
|
-
const mainGsd = contract.projectGsd;
|
|
821
|
-
const wtGsd = contract.worktreeGsd ?? join(worktreePath, ".gsd");
|
|
822
|
-
const synced = [];
|
|
823
|
-
// If both resolve to the same directory (symlink), no sync needed
|
|
824
|
-
if (isSamePath(mainGsd, wtGsd))
|
|
825
|
-
return { synced };
|
|
826
|
-
if (!existsSync(wtGsd) || !existsSync(mainGsd))
|
|
827
|
-
return { synced };
|
|
828
|
-
// ── 0. Pre-upgrade worktree DB reconciliation ────────────────────────
|
|
829
|
-
// If the worktree has its own gsd.db (copied before the WAL transition),
|
|
830
|
-
// reconcile its hierarchy data into the project root DB before syncing
|
|
831
|
-
// files. This handles in-flight worktrees that were created before the
|
|
832
|
-
// upgrade to shared WAL mode.
|
|
833
|
-
const wtLocalDb = join(wtGsd, "gsd.db");
|
|
834
|
-
const mainDb = contract.projectDb;
|
|
835
|
-
if (existsSync(wtLocalDb) && existsSync(mainDb)) {
|
|
836
|
-
try {
|
|
837
|
-
reconcileWorktreeDb(mainDb, wtLocalDb);
|
|
838
|
-
synced.push("gsd.db (pre-upgrade reconcile)");
|
|
839
|
-
}
|
|
840
|
-
catch (err) {
|
|
841
|
-
// Non-fatal — file sync below is the fallback
|
|
842
|
-
logError("worktree", `DB reconciliation failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
843
|
-
}
|
|
844
|
-
}
|
|
845
|
-
// ── 1. Sync root-level diagnostic files back ─────────────────────────
|
|
846
|
-
// Markdown/JSON state projections remain project-root/DB authoritative.
|
|
847
|
-
// These diagnostic files are copied for observability only.
|
|
848
|
-
for (const f of ROOT_DIAGNOSTIC_FILES) {
|
|
849
|
-
const src = join(wtGsd, f);
|
|
850
|
-
const dst = join(mainGsd, f);
|
|
851
|
-
if (existsSync(src)) {
|
|
852
|
-
try {
|
|
853
|
-
cpSync(src, dst, { force: true });
|
|
854
|
-
synced.push(f);
|
|
855
|
-
}
|
|
856
|
-
catch (err) {
|
|
857
|
-
/* non-fatal */
|
|
858
|
-
logWarning("worktree", `state file copy-back failed (${f}): ${err instanceof Error ? err.message : String(err)}`);
|
|
859
|
-
}
|
|
860
|
-
}
|
|
861
|
-
}
|
|
862
|
-
return { synced };
|
|
685
|
+
return _finalizeProjectionForMergeImpl(mainBasePath, worktreePath, milestoneId);
|
|
863
686
|
}
|
|
864
687
|
// ─── Worktree Post-Create Hook (#597) ────────────────────────────────────────
|
|
865
688
|
/**
|
|
@@ -945,17 +768,7 @@ export function enterBranchModeForMilestone(basePath, milestoneId) {
|
|
|
945
768
|
// Create the milestone branch from the integration branch start-point.
|
|
946
769
|
const integrationBranch = readIntegrationBranch(basePath, milestoneId) ?? undefined;
|
|
947
770
|
const gitPrefs = loadEffectiveGSDPreferences()?.preferences?.git;
|
|
948
|
-
|
|
949
|
-
// a stale preference (e.g. "master" when repo uses "main") would cause
|
|
950
|
-
// nativeBranchForceReset to fail with a bad start-point reference.
|
|
951
|
-
const validatedPrefBranch = gitPrefs?.main_branch &&
|
|
952
|
-
typeof gitPrefs.main_branch === "string" &&
|
|
953
|
-
gitPrefs.main_branch.length > 0 &&
|
|
954
|
-
nativeBranchExists(basePath, gitPrefs.main_branch)
|
|
955
|
-
? gitPrefs.main_branch
|
|
956
|
-
: undefined;
|
|
957
|
-
const startPoint = integrationBranch ??
|
|
958
|
-
validatedPrefBranch ??
|
|
771
|
+
const startPoint = _resolveAutoWorktreeStartPoint(integrationBranch, gitPrefs?.main_branch, (branchName) => nativeBranchExists(basePath, branchName)) ??
|
|
959
772
|
nativeDetectMainBranch(basePath);
|
|
960
773
|
// TOCTOU ancestry guard (Issue #4980 HIGH-3).
|
|
961
774
|
//
|
|
@@ -1018,6 +831,111 @@ export function enterBranchModeForMilestone(basePath, milestoneId) {
|
|
|
1018
831
|
* for both reads and writes. copyPlanningArtifacts and reconcilePlanCheckboxes
|
|
1019
832
|
* (both formerly here) became dead.
|
|
1020
833
|
*/
|
|
834
|
+
/**
|
|
835
|
+
* True when `branch` is checked out in any worktree listed by
|
|
836
|
+
* `git worktree list --porcelain`. Used to gate ref updates that would
|
|
837
|
+
* otherwise leave a concurrent worktree's HEAD inconsistent with its
|
|
838
|
+
* index/working tree (Codex peer-review of #5538-followup).
|
|
839
|
+
*
|
|
840
|
+
* Best-effort: a `nativeWorktreeList` failure returns true so we err on
|
|
841
|
+
* the side of NOT moving the ref. Better to skip a fast-forward than to
|
|
842
|
+
* silently corrupt another worktree.
|
|
843
|
+
*/
|
|
844
|
+
export function _isBranchCheckedOutElsewhere(basePath, branch) {
|
|
845
|
+
try {
|
|
846
|
+
const entries = nativeWorktreeList(basePath);
|
|
847
|
+
return entries.some((entry) => entry.branch === branch);
|
|
848
|
+
}
|
|
849
|
+
catch {
|
|
850
|
+
return true;
|
|
851
|
+
}
|
|
852
|
+
}
|
|
853
|
+
/**
|
|
854
|
+
* Resolve the integration branch using the same 3-tier fallback as the
|
|
855
|
+
* fresh-create path: META.json → git.main_branch preference → detected
|
|
856
|
+
* main branch. Returns null when no usable target exists.
|
|
857
|
+
*/
|
|
858
|
+
function _resolveIntegrationBranchForReuse(basePath, milestoneId) {
|
|
859
|
+
const fromMeta = readIntegrationBranch(basePath, milestoneId);
|
|
860
|
+
if (fromMeta)
|
|
861
|
+
return fromMeta;
|
|
862
|
+
const gitPrefs = loadEffectiveGSDPreferences()?.preferences?.git;
|
|
863
|
+
const fromPref = gitPrefs?.main_branch &&
|
|
864
|
+
typeof gitPrefs.main_branch === "string" &&
|
|
865
|
+
gitPrefs.main_branch.length > 0 &&
|
|
866
|
+
nativeBranchExists(basePath, gitPrefs.main_branch)
|
|
867
|
+
? gitPrefs.main_branch
|
|
868
|
+
: null;
|
|
869
|
+
if (fromPref)
|
|
870
|
+
return fromPref;
|
|
871
|
+
try {
|
|
872
|
+
return nativeDetectMainBranch(basePath);
|
|
873
|
+
}
|
|
874
|
+
catch {
|
|
875
|
+
return null;
|
|
876
|
+
}
|
|
877
|
+
}
|
|
878
|
+
/**
|
|
879
|
+
* When reusing an existing milestone branch, fast-forward it onto the
|
|
880
|
+
* integration branch when that's safe (branch is a strict ancestor of
|
|
881
|
+
* integration — no commits would be lost). Skips when the branch has its
|
|
882
|
+
* own commits ahead of integration, when the integration branch can't be
|
|
883
|
+
* resolved, or when any git operation fails — the merge gate at milestone
|
|
884
|
+
* completion will surface real divergence as a conflict.
|
|
885
|
+
*
|
|
886
|
+
* The previous behavior re-attached the worktree to whatever stale tip
|
|
887
|
+
* the branch held, which caused new milestone work to fork from a base
|
|
888
|
+
* missing prior milestones' merges (#5538-followup).
|
|
889
|
+
*/
|
|
890
|
+
export function fastForwardReusedMilestoneBranchIfSafe(basePath, milestoneId, branch) {
|
|
891
|
+
try {
|
|
892
|
+
const integrationBranch = _resolveIntegrationBranchForReuse(basePath, milestoneId);
|
|
893
|
+
if (!integrationBranch || integrationBranch === branch)
|
|
894
|
+
return;
|
|
895
|
+
if (!nativeBranchExists(basePath, integrationBranch))
|
|
896
|
+
return;
|
|
897
|
+
// Pure fast-forward only: branch must be a strict ancestor of integration.
|
|
898
|
+
// If the branch has its own commits ahead, leave it alone.
|
|
899
|
+
if (!nativeIsAncestor(basePath, branch, integrationBranch)) {
|
|
900
|
+
debugLog("createAutoWorktree", {
|
|
901
|
+
phase: "skip-ff-branch-not-ancestor",
|
|
902
|
+
milestoneId,
|
|
903
|
+
branch,
|
|
904
|
+
integration: integrationBranch,
|
|
905
|
+
});
|
|
906
|
+
return;
|
|
907
|
+
}
|
|
908
|
+
// Codex peer-review: `nativeUpdateRef` succeeds even when the branch is
|
|
909
|
+
// currently checked out in another worktree, leaving that worktree's HEAD
|
|
910
|
+
// inconsistent with its index/work tree. Skip the fast-forward if any
|
|
911
|
+
// listed worktree has this branch checked out — the merge gate at
|
|
912
|
+
// milestone-completion will surface stale-base divergence as a conflict
|
|
913
|
+
// instead of silently corrupting the other worktree's state.
|
|
914
|
+
if (_isBranchCheckedOutElsewhere(basePath, branch)) {
|
|
915
|
+
debugLog("createAutoWorktree", {
|
|
916
|
+
phase: "skip-ff-branch-checked-out-elsewhere",
|
|
917
|
+
milestoneId,
|
|
918
|
+
branch,
|
|
919
|
+
});
|
|
920
|
+
return;
|
|
921
|
+
}
|
|
922
|
+
nativeUpdateRef(basePath, `refs/heads/${branch}`, integrationBranch);
|
|
923
|
+
debugLog("createAutoWorktree", {
|
|
924
|
+
phase: "fast-forward-reused-branch",
|
|
925
|
+
milestoneId,
|
|
926
|
+
branch,
|
|
927
|
+
integration: integrationBranch,
|
|
928
|
+
});
|
|
929
|
+
}
|
|
930
|
+
catch (err) {
|
|
931
|
+
debugLog("createAutoWorktree", {
|
|
932
|
+
phase: "fast-forward-reused-branch-failed",
|
|
933
|
+
milestoneId,
|
|
934
|
+
branch,
|
|
935
|
+
error: err instanceof Error ? err.message : String(err),
|
|
936
|
+
});
|
|
937
|
+
}
|
|
938
|
+
}
|
|
1021
939
|
export function createAutoWorktree(basePath, milestoneId) {
|
|
1022
940
|
basePath = resolveWorktreeProjectRoot(basePath);
|
|
1023
941
|
// Check if repo has commits — git worktree requires a valid HEAD
|
|
@@ -1035,6 +953,11 @@ export function createAutoWorktree(basePath, milestoneId) {
|
|
|
1035
953
|
const branchExists = nativeBranchExists(basePath, branch);
|
|
1036
954
|
let info;
|
|
1037
955
|
if (branchExists) {
|
|
956
|
+
// #5538-followup: fast-forward the reused branch onto the integration
|
|
957
|
+
// branch when safe so the next milestone forks from up-to-date code.
|
|
958
|
+
// Without this, a milestone that was created before another milestone
|
|
959
|
+
// merged into main would carry a stale base into its worktree.
|
|
960
|
+
fastForwardReusedMilestoneBranchIfSafe(basePath, milestoneId, branch);
|
|
1038
961
|
// Re-attach worktree to the existing milestone branch (preserving commits)
|
|
1039
962
|
info = createWorktree(basePath, milestoneId, {
|
|
1040
963
|
branch,
|
|
@@ -1051,13 +974,7 @@ export function createAutoWorktree(basePath, milestoneId) {
|
|
|
1051
974
|
// would fork worktrees from the wrong (stale) branch.
|
|
1052
975
|
const integrationBranch = readIntegrationBranch(basePath, milestoneId) ?? undefined;
|
|
1053
976
|
const gitPrefs = loadEffectiveGSDPreferences()?.preferences?.git;
|
|
1054
|
-
const
|
|
1055
|
-
typeof gitPrefs.main_branch === "string" &&
|
|
1056
|
-
gitPrefs.main_branch.length > 0 &&
|
|
1057
|
-
nativeBranchExists(basePath, gitPrefs.main_branch)
|
|
1058
|
-
? gitPrefs.main_branch
|
|
1059
|
-
: undefined;
|
|
1060
|
-
const startPoint = integrationBranch ?? validatedPrefBranch ?? undefined;
|
|
977
|
+
const startPoint = _resolveAutoWorktreeStartPoint(integrationBranch, gitPrefs?.main_branch, (branchName) => nativeBranchExists(basePath, branchName));
|
|
1061
978
|
info = createWorktree(basePath, milestoneId, {
|
|
1062
979
|
branch,
|
|
1063
980
|
startPoint,
|
|
@@ -1134,7 +1051,7 @@ export function teardownAutoWorktree(originalBasePath, milestoneId, opts = {}) {
|
|
|
1134
1051
|
const contract = resolveGsdPathContract(previousCwd, originalBasePath);
|
|
1135
1052
|
const worktreeDbPath = join(contract.worktreeGsd ?? join(previousCwd, ".gsd"), "gsd.db");
|
|
1136
1053
|
const mainDbPath = contract.projectDb;
|
|
1137
|
-
if (
|
|
1054
|
+
if (_shouldReconcileWorktreeDb(worktreeDbPath, mainDbPath)) {
|
|
1138
1055
|
reconcileWorktreeDb(mainDbPath, worktreeDbPath);
|
|
1139
1056
|
}
|
|
1140
1057
|
}
|
|
@@ -1280,6 +1197,15 @@ export function enterAutoWorktree(basePath, milestoneId) {
|
|
|
1280
1197
|
export function getAutoWorktreeOriginalBase() {
|
|
1281
1198
|
return getActiveWorkspace()?.projectRoot ?? null;
|
|
1282
1199
|
}
|
|
1200
|
+
/**
|
|
1201
|
+
* Test-only — resets the module-level `activeWorkspace` registry between
|
|
1202
|
+
* runs. Production code never clears the registry directly; tests call this
|
|
1203
|
+
* in `beforeEach`/`afterEach` to isolate registry-mutating cases. Renaming
|
|
1204
|
+
* the underscore-prefixed `_*ForTest` exports it joins (slice 7 / step G of
|
|
1205
|
+
* ADR-016) was deliberate: those wrapped real production helpers and lost
|
|
1206
|
+
* the suffix; this one stays as the only legitimate test-scaffolding export
|
|
1207
|
+
* because it has no production caller.
|
|
1208
|
+
*/
|
|
1283
1209
|
export function _resetAutoWorktreeOriginalBaseForTests() {
|
|
1284
1210
|
setActiveWorkspace(null);
|
|
1285
1211
|
}
|
|
@@ -1345,6 +1271,14 @@ function autoCommitDirtyState(cwd) {
|
|
|
1345
1271
|
* On merge conflict: throws MergeConflictError.
|
|
1346
1272
|
* On "nothing to commit" after squash: safe only if milestone work is already
|
|
1347
1273
|
* on the integration branch. Throws if unanchored code changes would be lost.
|
|
1274
|
+
*
|
|
1275
|
+
* @internal **Do not call directly.** This is the inner squash-merge primitive
|
|
1276
|
+
* for the Worktree Lifecycle Module (ADR-016 phase 2 / A3, issue #5619).
|
|
1277
|
+
* Production callers must go through `WorktreeLifecycle.mergeMilestoneStandalone`
|
|
1278
|
+
* or `WorktreeLifecycle.exitMilestone({ merge: true })`. The export keyword
|
|
1279
|
+
* is preserved only so `auto.ts:buildWorktreeLifecycleDeps()` can wire this
|
|
1280
|
+
* function through the Module's deps seam — that is the construction of the
|
|
1281
|
+
* seam, not a bypass.
|
|
1348
1282
|
*/
|
|
1349
1283
|
export function mergeMilestoneToMain(originalBasePath_, milestoneId, roadmapContent) {
|
|
1350
1284
|
const worktreeCwd = process.cwd();
|
|
@@ -1384,7 +1318,7 @@ export function mergeMilestoneToMain(originalBasePath_, milestoneId, roadmapCont
|
|
|
1384
1318
|
const contract = resolveGsdPathContract(worktreeCwd, originalBasePath_);
|
|
1385
1319
|
const worktreeDbPath = join(contract.worktreeGsd ?? join(worktreeCwd, ".gsd"), "gsd.db");
|
|
1386
1320
|
const mainDbPath = contract.projectDb;
|
|
1387
|
-
if (
|
|
1321
|
+
if (_shouldReconcileWorktreeDb(worktreeDbPath, mainDbPath)) {
|
|
1388
1322
|
reconcileWorktreeDb(mainDbPath, worktreeDbPath);
|
|
1389
1323
|
}
|
|
1390
1324
|
}
|
|
@@ -1398,14 +1332,23 @@ export function mergeMilestoneToMain(originalBasePath_, milestoneId, roadmapCont
|
|
|
1398
1332
|
if (isDbAvailable()) {
|
|
1399
1333
|
completedSlices = getMilestoneSlices(milestoneId)
|
|
1400
1334
|
.filter(s => s.status === "complete")
|
|
1401
|
-
.map(s => ({
|
|
1335
|
+
.map(s => ({
|
|
1336
|
+
id: s.id,
|
|
1337
|
+
title: stripGsdDisplayPrefix(s.title, s.id) ?? s.id,
|
|
1338
|
+
tasks: getSliceTasks(milestoneId, s.id)
|
|
1339
|
+
.filter((task) => task.status === "complete")
|
|
1340
|
+
.map((task) => ({
|
|
1341
|
+
id: task.id,
|
|
1342
|
+
title: stripGsdDisplayPrefix(task.title, task.id) ?? task.id,
|
|
1343
|
+
})),
|
|
1344
|
+
}));
|
|
1402
1345
|
}
|
|
1403
1346
|
// Fallback: parse roadmap content when DB is unavailable
|
|
1404
1347
|
if (completedSlices.length === 0 && roadmapContent) {
|
|
1405
1348
|
const sliceRe = /- \[x\] \*\*(\w+):\s*(.+?)\*\*/gi;
|
|
1406
1349
|
let m;
|
|
1407
1350
|
while ((m = sliceRe.exec(roadmapContent)) !== null) {
|
|
1408
|
-
completedSlices.push({ id: m[1], title: m[2] });
|
|
1351
|
+
completedSlices.push({ id: m[1], title: m[2], tasks: [] });
|
|
1409
1352
|
}
|
|
1410
1353
|
}
|
|
1411
1354
|
// 3. chdir to original base
|
|
@@ -1462,7 +1405,7 @@ export function mergeMilestoneToMain(originalBasePath_, milestoneId, roadmapCont
|
|
|
1462
1405
|
}
|
|
1463
1406
|
// 6. Build rich commit message
|
|
1464
1407
|
const dbMilestone = getMilestone(milestoneId);
|
|
1465
|
-
let milestoneTitle = (dbMilestone?.title ?? ""
|
|
1408
|
+
let milestoneTitle = stripGsdDisplayPrefix(dbMilestone?.title, milestoneId) ?? "";
|
|
1466
1409
|
// Fallback: parse title from roadmap content header (e.g. "# M020: Backend foundation")
|
|
1467
1410
|
if (!milestoneTitle && roadmapContent) {
|
|
1468
1411
|
const titleMatch = roadmapContent.match(new RegExp(`^#\\s+${milestoneId}:\\s*(.+)`, "m"));
|
|
@@ -1471,15 +1414,22 @@ export function mergeMilestoneToMain(originalBasePath_, milestoneId, roadmapCont
|
|
|
1471
1414
|
}
|
|
1472
1415
|
milestoneTitle = milestoneTitle || milestoneId;
|
|
1473
1416
|
const subject = `feat: ${milestoneTitle}`;
|
|
1417
|
+
const milestoneContext = milestoneTitle === milestoneId
|
|
1418
|
+
? `Milestone: ${milestoneId}`
|
|
1419
|
+
: `Milestone: ${milestoneId} - ${milestoneTitle}`;
|
|
1474
1420
|
let body = "";
|
|
1475
1421
|
if (completedSlices.length > 0) {
|
|
1476
1422
|
const sliceLines = completedSlices
|
|
1477
1423
|
.map((s) => `- ${s.id}: ${s.title}`)
|
|
1478
1424
|
.join("\n");
|
|
1479
|
-
|
|
1425
|
+
const taskLines = completedSlices
|
|
1426
|
+
.flatMap((s) => s.tasks.map((task) => `- ${s.id}/${task.id}: ${task.title}`))
|
|
1427
|
+
.join("\n");
|
|
1428
|
+
const taskBlock = taskLines ? `\n\nCompleted tasks:\n${taskLines}` : "";
|
|
1429
|
+
body = `\n\nCompleted slices:\n${sliceLines}${taskBlock}\n\n${milestoneContext}\nGSD-Milestone: ${milestoneId}\nBranch: ${milestoneBranch}`;
|
|
1480
1430
|
}
|
|
1481
1431
|
else {
|
|
1482
|
-
body = `\n\nGSD-Milestone: ${milestoneId}\nBranch: ${milestoneBranch}`;
|
|
1432
|
+
body = `\n\n${milestoneContext}\nGSD-Milestone: ${milestoneId}\nBranch: ${milestoneBranch}`;
|
|
1483
1433
|
}
|
|
1484
1434
|
const commitMessage = subject + body;
|
|
1485
1435
|
// 6b. Reconcile worktree HEAD with milestone branch ref (#1846).
|
|
@@ -1680,17 +1630,7 @@ export function mergeMilestoneToMain(originalBasePath_, milestoneId, roadmapCont
|
|
|
1680
1630
|
// or interrupted operation) causes `git merge --squash` to refuse with
|
|
1681
1631
|
// "fatal: You have not concluded your merge (MERGE_HEAD exists)".
|
|
1682
1632
|
// Defensively remove merge artifacts before starting.
|
|
1683
|
-
|
|
1684
|
-
const gitDir_ = resolveGitDir(originalBasePath_);
|
|
1685
|
-
for (const f of ["SQUASH_MSG", "MERGE_MSG", "MERGE_HEAD"]) {
|
|
1686
|
-
const p = join(gitDir_, f);
|
|
1687
|
-
if (existsSync(p))
|
|
1688
|
-
unlinkSync(p);
|
|
1689
|
-
}
|
|
1690
|
-
}
|
|
1691
|
-
catch (err) { /* best-effort */
|
|
1692
|
-
logError("worktree", `merge state cleanup failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
1693
|
-
}
|
|
1633
|
+
removeMergeStateFiles(originalBasePath_, "pre-merge");
|
|
1694
1634
|
// 8. Squash merge — auto-resolve .gsd/ state file conflicts (#530)
|
|
1695
1635
|
const mergeResult = nativeMergeSquash(originalBasePath_, milestoneBranch);
|
|
1696
1636
|
if (!mergeResult.success) {
|
|
@@ -1700,17 +1640,7 @@ export function mergeMilestoneToMain(originalBasePath_, milestoneId, roadmapCont
|
|
|
1700
1640
|
if (mergeResult.conflicts.includes("__dirty_working_tree__")) {
|
|
1701
1641
|
// Defensively clean merge state — the native path may leave MERGE_HEAD
|
|
1702
1642
|
// even when the merge is rejected (#2912).
|
|
1703
|
-
|
|
1704
|
-
const gitDir_ = resolveGitDir(originalBasePath_);
|
|
1705
|
-
for (const f of ["SQUASH_MSG", "MERGE_MSG", "MERGE_HEAD"]) {
|
|
1706
|
-
const p = join(gitDir_, f);
|
|
1707
|
-
if (existsSync(p))
|
|
1708
|
-
unlinkSync(p);
|
|
1709
|
-
}
|
|
1710
|
-
}
|
|
1711
|
-
catch (err) { /* best-effort */
|
|
1712
|
-
logError("worktree", `merge state cleanup failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
1713
|
-
}
|
|
1643
|
+
removeMergeStateFiles(originalBasePath_, "dirty-tree rejection");
|
|
1714
1644
|
// Pop stash before throwing so local work is not lost.
|
|
1715
1645
|
if (stashed) {
|
|
1716
1646
|
try {
|
|
@@ -1759,26 +1689,7 @@ export function mergeMilestoneToMain(originalBasePath_, milestoneId, roadmapCont
|
|
|
1759
1689
|
}
|
|
1760
1690
|
// If there are still real code conflicts, escalate
|
|
1761
1691
|
if (codeConflicts.length > 0) {
|
|
1762
|
-
|
|
1763
|
-
// libgit2's merge creates MERGE_HEAD even for squash merges; if left
|
|
1764
|
-
// dangling, subsequent merges fail and doctor reports corrupt state.
|
|
1765
|
-
try {
|
|
1766
|
-
nativeMergeAbort(originalBasePath_);
|
|
1767
|
-
}
|
|
1768
|
-
catch (err) { /* best-effort */
|
|
1769
|
-
logError("worktree", `git merge-abort failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
1770
|
-
}
|
|
1771
|
-
try {
|
|
1772
|
-
const gitDir_ = resolveGitDir(originalBasePath_);
|
|
1773
|
-
for (const f of ["SQUASH_MSG", "MERGE_MSG", "MERGE_HEAD"]) {
|
|
1774
|
-
const p = join(gitDir_, f);
|
|
1775
|
-
if (existsSync(p))
|
|
1776
|
-
unlinkSync(p);
|
|
1777
|
-
}
|
|
1778
|
-
}
|
|
1779
|
-
catch (err) { /* best-effort */
|
|
1780
|
-
logError("worktree", `merge state file cleanup failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
1781
|
-
}
|
|
1692
|
+
cleanupSquashConflictState(originalBasePath_);
|
|
1782
1693
|
// Pop stash before throwing so local work is not lost (#2151).
|
|
1783
1694
|
if (stashed) {
|
|
1784
1695
|
try {
|
|
@@ -1809,17 +1720,7 @@ export function mergeMilestoneToMain(originalBasePath_, milestoneId, roadmapCont
|
|
|
1809
1720
|
// of which trigger git's SQUASH_MSG cleanup. MERGE_HEAD is created by
|
|
1810
1721
|
// libgit2's merge even in squash mode and is not removed by nativeCommit.
|
|
1811
1722
|
// If left on disk, doctor reports `corrupt_merge_state` on every subsequent run.
|
|
1812
|
-
|
|
1813
|
-
const gitDir_ = resolveGitDir(originalBasePath_);
|
|
1814
|
-
for (const f of ["SQUASH_MSG", "MERGE_MSG", "MERGE_HEAD"]) {
|
|
1815
|
-
const p = join(gitDir_, f);
|
|
1816
|
-
if (existsSync(p))
|
|
1817
|
-
unlinkSync(p);
|
|
1818
|
-
}
|
|
1819
|
-
}
|
|
1820
|
-
catch (err) { /* best-effort */
|
|
1821
|
-
logError("worktree", `post-commit merge state cleanup failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
1822
|
-
}
|
|
1723
|
+
removeMergeStateFiles(originalBasePath_, "post-commit");
|
|
1823
1724
|
// 9a-ii. Restore stashed files now that the merge+commit is complete (#2151).
|
|
1824
1725
|
// Pop after commit so stashed changes do not interfere with the squash merge
|
|
1825
1726
|
// or the commit content. Conflict on pop is non-fatal — the stash entry is
|