gsd-pi 2.33.0-dev.bafba33 → 2.33.1-dev.235d83a
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 +13 -18
- package/dist/cli.js +16 -0
- package/dist/resource-loader.d.ts +2 -0
- package/dist/resource-loader.js +36 -3
- package/dist/resources/extensions/ask-user-questions.js +217 -0
- package/dist/resources/extensions/async-jobs/async-bash-tool.js +180 -0
- package/dist/resources/extensions/async-jobs/await-tool.js +90 -0
- package/dist/resources/extensions/async-jobs/cancel-job-tool.js +28 -0
- package/dist/resources/extensions/async-jobs/index.js +119 -0
- package/dist/resources/extensions/async-jobs/job-manager.js +159 -0
- package/dist/resources/extensions/aws-auth/index.js +138 -0
- package/dist/resources/extensions/bg-shell/bg-shell-command.js +182 -0
- package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.js +343 -0
- package/dist/resources/extensions/bg-shell/bg-shell-tool.js +831 -0
- package/dist/resources/extensions/bg-shell/index.js +41 -0
- package/dist/resources/extensions/bg-shell/interaction.js +160 -0
- package/dist/resources/extensions/bg-shell/output-formatter.js +245 -0
- package/dist/resources/extensions/bg-shell/overlay.js +378 -0
- package/dist/resources/extensions/bg-shell/process-manager.js +413 -0
- package/dist/resources/extensions/bg-shell/readiness-detector.js +109 -0
- package/dist/resources/extensions/bg-shell/types.js +96 -0
- package/dist/resources/extensions/bg-shell/utilities.js +50 -0
- package/dist/resources/extensions/browser-tools/capture.js +179 -0
- package/dist/resources/extensions/browser-tools/core.js +899 -0
- package/dist/resources/extensions/browser-tools/{evaluate-helpers.ts → evaluate-helpers.js} +0 -1
- package/dist/resources/extensions/browser-tools/index.js +123 -0
- package/dist/resources/extensions/browser-tools/lifecycle.js +222 -0
- package/dist/resources/extensions/browser-tools/refs.js +254 -0
- package/dist/resources/extensions/browser-tools/settle.js +173 -0
- package/dist/resources/extensions/browser-tools/state.js +126 -0
- package/dist/resources/extensions/browser-tools/tools/action-cache.js +179 -0
- package/dist/resources/extensions/browser-tools/tools/assertions.js +320 -0
- package/dist/resources/extensions/browser-tools/tools/codegen.js +242 -0
- package/dist/resources/extensions/browser-tools/tools/device.js +162 -0
- package/dist/resources/extensions/browser-tools/tools/extract.js +191 -0
- package/dist/resources/extensions/browser-tools/tools/forms.js +710 -0
- package/dist/resources/extensions/browser-tools/tools/injection-detect.js +178 -0
- package/dist/resources/extensions/browser-tools/tools/inspection.js +426 -0
- package/dist/resources/extensions/browser-tools/tools/intent.js +556 -0
- package/dist/resources/extensions/browser-tools/tools/interaction.js +776 -0
- package/dist/resources/extensions/browser-tools/tools/navigation.js +208 -0
- package/dist/resources/extensions/browser-tools/tools/network-mock.js +194 -0
- package/dist/resources/extensions/browser-tools/tools/pages.js +280 -0
- package/dist/resources/extensions/browser-tools/tools/pdf.js +74 -0
- package/dist/resources/extensions/browser-tools/tools/refs.js +485 -0
- package/dist/resources/extensions/browser-tools/tools/screenshot.js +87 -0
- package/dist/resources/extensions/browser-tools/tools/session.js +375 -0
- package/dist/resources/extensions/browser-tools/tools/state-persistence.js +180 -0
- package/dist/resources/extensions/browser-tools/tools/visual-diff.js +174 -0
- package/dist/resources/extensions/browser-tools/tools/wait.js +201 -0
- package/dist/resources/extensions/browser-tools/tools/zoom.js +90 -0
- package/dist/resources/extensions/browser-tools/utils.js +490 -0
- package/dist/resources/extensions/context7/index.js +337 -0
- package/dist/resources/extensions/get-secrets-from-user.js +492 -0
- package/dist/resources/extensions/google-search/index.js +373 -0
- package/dist/resources/extensions/gsd/activity-log.js +146 -0
- package/dist/resources/extensions/gsd/atomic-write.js +38 -0
- package/dist/resources/extensions/gsd/auto/session.js +187 -0
- package/dist/resources/extensions/gsd/auto-budget.js +30 -0
- package/dist/resources/extensions/gsd/{auto-constants.ts → auto-constants.js} +0 -1
- package/dist/resources/extensions/gsd/auto-dashboard.js +509 -0
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +180 -0
- package/dist/resources/extensions/gsd/auto-dispatch.js +382 -0
- package/dist/resources/extensions/gsd/auto-idempotency.js +106 -0
- package/dist/resources/extensions/gsd/auto-model-selection.js +133 -0
- package/dist/resources/extensions/gsd/auto-observability.js +54 -0
- package/dist/resources/extensions/gsd/auto-post-unit.js +495 -0
- package/dist/resources/extensions/gsd/auto-prompts.js +1121 -0
- package/dist/resources/extensions/gsd/auto-recovery.js +550 -0
- package/dist/resources/extensions/gsd/auto-start.js +393 -0
- package/dist/resources/extensions/gsd/auto-stuck-detection.js +165 -0
- package/dist/resources/extensions/gsd/{auto-supervisor.ts → auto-supervisor.js} +29 -32
- package/dist/resources/extensions/gsd/auto-timeout-recovery.js +183 -0
- package/dist/resources/extensions/gsd/auto-timers.js +181 -0
- package/dist/resources/extensions/gsd/auto-tool-tracking.js +50 -0
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +30 -0
- package/dist/resources/extensions/gsd/auto-verification.js +209 -0
- package/dist/resources/extensions/gsd/auto-worktree.js +594 -0
- package/dist/resources/extensions/gsd/auto.js +1485 -0
- package/dist/resources/extensions/gsd/{cache.ts → cache.js} +5 -7
- package/dist/resources/extensions/gsd/captures.js +348 -0
- package/dist/resources/extensions/gsd/claude-import.js +540 -0
- package/dist/resources/extensions/gsd/collision-diagnostics.js +226 -0
- package/dist/resources/extensions/gsd/commands-bootstrap.js +223 -0
- package/dist/resources/extensions/gsd/commands-config.js +89 -0
- package/dist/resources/extensions/gsd/commands-extensions.js +259 -0
- package/dist/resources/extensions/gsd/commands-handlers.js +310 -0
- package/dist/resources/extensions/gsd/commands-inspect.js +70 -0
- package/dist/resources/extensions/gsd/commands-logs.js +468 -0
- package/dist/resources/extensions/gsd/commands-maintenance.js +185 -0
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +660 -0
- package/dist/resources/extensions/gsd/commands-workflow-templates.js +408 -0
- package/dist/resources/extensions/gsd/commands.js +1024 -0
- package/dist/resources/extensions/gsd/complexity-classifier.js +257 -0
- package/dist/resources/extensions/gsd/{constants.ts → constants.js} +0 -6
- package/dist/resources/extensions/gsd/context-budget.js +187 -0
- package/dist/resources/extensions/gsd/context-store.js +165 -0
- package/dist/resources/extensions/gsd/crash-recovery.js +110 -0
- package/dist/resources/extensions/gsd/dashboard-overlay.js +562 -0
- package/dist/resources/extensions/gsd/db-writer.js +298 -0
- package/dist/resources/extensions/gsd/debug-logger.js +161 -0
- package/dist/resources/extensions/gsd/detection.js +373 -0
- package/dist/resources/extensions/gsd/diff-context.js +168 -0
- package/dist/resources/extensions/gsd/dispatch-guard.js +76 -0
- package/dist/resources/extensions/gsd/doctor-checks.js +563 -0
- package/dist/resources/extensions/gsd/doctor-environment.js +429 -0
- package/dist/resources/extensions/gsd/doctor-format.js +71 -0
- package/dist/resources/extensions/gsd/doctor-proactive.js +239 -0
- package/dist/resources/extensions/gsd/doctor-providers.js +292 -0
- package/dist/resources/extensions/gsd/doctor-types.js +12 -0
- package/dist/resources/extensions/gsd/doctor.js +672 -0
- package/dist/resources/extensions/gsd/error-utils.js +6 -0
- package/dist/resources/extensions/gsd/{errors.ts → errors.js} +6 -11
- package/dist/resources/extensions/gsd/exit-command.js +11 -0
- package/dist/resources/extensions/gsd/{export-html.ts → export-html.js} +482 -614
- package/dist/resources/extensions/gsd/export.js +268 -0
- package/dist/resources/extensions/gsd/file-watcher.js +76 -0
- package/dist/resources/extensions/gsd/files.js +937 -0
- package/dist/resources/extensions/gsd/forensics.js +511 -0
- package/dist/resources/extensions/gsd/{git-constants.ts → git-constants.js} +4 -5
- package/dist/resources/extensions/gsd/git-self-heal.js +113 -0
- package/dist/resources/extensions/gsd/git-service.js +460 -0
- package/dist/resources/extensions/gsd/{gitignore.ts → gitignore.js} +98 -125
- package/dist/resources/extensions/gsd/gsd-db.js +590 -0
- package/dist/resources/extensions/gsd/guided-flow-queue.js +366 -0
- package/dist/resources/extensions/gsd/guided-flow.js +1149 -0
- package/dist/resources/extensions/gsd/health-widget.js +141 -0
- package/dist/resources/extensions/gsd/history.js +118 -0
- package/dist/resources/extensions/gsd/index.js +1250 -0
- package/dist/resources/extensions/gsd/init-wizard.js +479 -0
- package/dist/resources/extensions/gsd/json-persistence.js +62 -0
- package/dist/resources/extensions/gsd/{jsonl-utils.ts → jsonl-utils.js} +10 -7
- package/dist/resources/extensions/gsd/key-manager.js +829 -0
- package/dist/resources/extensions/gsd/marketplace-discovery.js +356 -0
- package/dist/resources/extensions/gsd/md-importer.js +440 -0
- package/dist/resources/extensions/gsd/mechanical-completion.js +351 -0
- package/dist/resources/extensions/gsd/memory-extractor.js +295 -0
- package/dist/resources/extensions/gsd/memory-store.js +351 -0
- package/dist/resources/extensions/gsd/metrics.js +377 -0
- package/dist/resources/extensions/gsd/migrate/command.js +157 -0
- package/dist/resources/extensions/gsd/migrate/index.js +7 -0
- package/dist/resources/extensions/gsd/migrate/parser.js +268 -0
- package/dist/resources/extensions/gsd/migrate/parsers.js +477 -0
- package/dist/resources/extensions/gsd/migrate/preview.js +47 -0
- package/dist/resources/extensions/gsd/migrate/transformer.js +278 -0
- package/dist/resources/extensions/gsd/migrate/types.js +4 -0
- package/dist/resources/extensions/gsd/migrate/validator.js +41 -0
- package/dist/resources/extensions/gsd/migrate/writer.js +477 -0
- package/dist/resources/extensions/gsd/migrate-external.js +130 -0
- package/dist/resources/extensions/gsd/milestone-actions.js +111 -0
- package/dist/resources/extensions/gsd/{milestone-ids.ts → milestone-ids.js} +50 -63
- package/dist/resources/extensions/gsd/model-cost-table.js +48 -0
- package/dist/resources/extensions/gsd/model-router.js +187 -0
- package/dist/resources/extensions/gsd/namespaced-registry.js +322 -0
- package/dist/resources/extensions/gsd/namespaced-resolver.js +176 -0
- package/dist/resources/extensions/gsd/native-git-bridge.js +842 -0
- package/dist/resources/extensions/gsd/native-parser-bridge.js +156 -0
- package/dist/resources/extensions/gsd/notifications.js +58 -0
- package/dist/resources/extensions/gsd/observability-validator.js +398 -0
- package/dist/resources/extensions/gsd/parallel-eligibility.js +182 -0
- package/dist/resources/extensions/gsd/parallel-merge.js +121 -0
- package/dist/resources/extensions/gsd/parallel-orchestrator.js +687 -0
- package/dist/resources/extensions/gsd/paths.js +414 -0
- package/dist/resources/extensions/gsd/plugin-importer.js +254 -0
- package/dist/resources/extensions/gsd/post-unit-hooks.js +433 -0
- package/dist/resources/extensions/gsd/preferences-models.js +294 -0
- package/dist/resources/extensions/gsd/preferences-skills.js +154 -0
- package/dist/resources/extensions/gsd/preferences-types.js +73 -0
- package/dist/resources/extensions/gsd/preferences-validation.js +607 -0
- package/dist/resources/extensions/gsd/preferences.js +325 -0
- package/dist/resources/extensions/gsd/progress-score.js +197 -0
- package/dist/resources/extensions/gsd/prompt-cache-optimizer.js +150 -0
- package/dist/resources/extensions/gsd/prompt-compressor.js +393 -0
- package/dist/resources/extensions/gsd/prompt-loader.js +119 -0
- package/dist/resources/extensions/gsd/prompt-ordering.js +170 -0
- package/dist/resources/extensions/gsd/provider-error-pause.js +60 -0
- package/dist/resources/extensions/gsd/queue-order.js +178 -0
- package/dist/resources/extensions/gsd/queue-reorder-ui.js +234 -0
- package/dist/resources/extensions/gsd/quick.js +230 -0
- package/dist/resources/extensions/gsd/repo-identity.js +187 -0
- package/dist/resources/extensions/gsd/{reports.ts → reports.js} +146 -241
- package/dist/resources/extensions/gsd/{resource-version.ts → resource-version.js} +50 -53
- package/dist/resources/extensions/gsd/roadmap-slices.js +130 -0
- package/dist/resources/extensions/gsd/routing-history.js +210 -0
- package/dist/resources/extensions/gsd/safe-fs.js +52 -0
- package/dist/resources/extensions/gsd/semantic-chunker.js +254 -0
- package/dist/resources/extensions/gsd/session-forensics.js +427 -0
- package/dist/resources/extensions/gsd/session-lock.js +376 -0
- package/dist/resources/extensions/gsd/session-status-io.js +134 -0
- package/dist/resources/extensions/gsd/skill-discovery.js +121 -0
- package/dist/resources/extensions/gsd/skill-health.js +324 -0
- package/dist/resources/extensions/gsd/{skill-telemetry.ts → skill-telemetry.js} +58 -74
- package/dist/resources/extensions/gsd/state.js +653 -0
- package/dist/resources/extensions/gsd/structured-data-formatter.js +97 -0
- package/dist/resources/extensions/gsd/summary-distiller.js +212 -0
- package/dist/resources/extensions/gsd/token-counter.js +54 -0
- package/dist/resources/extensions/gsd/triage-resolution.js +217 -0
- package/dist/resources/extensions/gsd/triage-ui.js +125 -0
- package/dist/resources/extensions/gsd/types.js +4 -0
- package/dist/resources/extensions/gsd/undo.js +210 -0
- package/dist/resources/extensions/gsd/unit-id.js +7 -0
- package/dist/resources/extensions/gsd/unit-runtime.js +130 -0
- package/dist/resources/extensions/gsd/validate-directory.js +143 -0
- package/dist/resources/extensions/gsd/verification-evidence.js +123 -0
- package/dist/resources/extensions/gsd/verification-gate.js +543 -0
- package/dist/resources/extensions/gsd/visualizer-data.js +612 -0
- package/dist/resources/extensions/gsd/visualizer-overlay.js +501 -0
- package/dist/resources/extensions/gsd/visualizer-views.js +893 -0
- package/dist/resources/extensions/gsd/workflow-templates.js +188 -0
- package/dist/resources/extensions/gsd/workspace-index.js +139 -0
- package/dist/resources/extensions/gsd/worktree-command-bootstrap.js +40 -0
- package/dist/resources/extensions/gsd/worktree-command.js +676 -0
- package/dist/resources/extensions/gsd/worktree-manager.js +359 -0
- package/dist/resources/extensions/gsd/worktree.js +236 -0
- package/dist/resources/extensions/mac-tools/index.js +768 -0
- package/dist/resources/extensions/mcp-client/index.js +363 -0
- package/dist/resources/extensions/package.json +3 -0
- package/dist/resources/extensions/remote-questions/config.js +70 -0
- package/dist/resources/extensions/remote-questions/discord-adapter.js +134 -0
- package/dist/resources/extensions/remote-questions/format.js +234 -0
- package/dist/resources/extensions/remote-questions/http-client.js +43 -0
- package/dist/resources/extensions/remote-questions/manager.js +156 -0
- package/dist/resources/extensions/remote-questions/{mod.ts → mod.js} +1 -10
- package/dist/resources/extensions/remote-questions/notify.js +89 -0
- package/dist/resources/extensions/remote-questions/remote-command.js +453 -0
- package/dist/resources/extensions/remote-questions/slack-adapter.js +123 -0
- package/dist/resources/extensions/remote-questions/status.js +25 -0
- package/dist/resources/extensions/remote-questions/store.js +70 -0
- package/dist/resources/extensions/remote-questions/telegram-adapter.js +123 -0
- package/dist/resources/extensions/remote-questions/types.js +5 -0
- package/dist/resources/extensions/search-the-web/cache.js +74 -0
- package/dist/resources/extensions/search-the-web/command-search-provider.js +79 -0
- package/dist/resources/extensions/search-the-web/format.js +161 -0
- package/dist/resources/extensions/search-the-web/http.js +178 -0
- package/dist/resources/extensions/search-the-web/index.js +41 -0
- package/dist/resources/extensions/search-the-web/native-search.js +166 -0
- package/dist/resources/extensions/search-the-web/provider.js +143 -0
- package/dist/resources/extensions/search-the-web/tavily.js +82 -0
- package/dist/resources/extensions/search-the-web/tool-fetch-page.js +452 -0
- package/dist/resources/extensions/search-the-web/tool-llm-context.js +455 -0
- package/dist/resources/extensions/search-the-web/tool-search.js +482 -0
- package/dist/resources/extensions/search-the-web/url-utils.js +121 -0
- package/dist/resources/extensions/shared/confirm-ui.js +96 -0
- package/dist/resources/extensions/shared/{format-utils.ts → format-utils.js} +85 -91
- package/dist/resources/extensions/shared/frontmatter.js +109 -0
- package/dist/resources/extensions/shared/interview-ui.js +569 -0
- package/dist/resources/extensions/shared/{mod.ts → mod.js} +2 -24
- package/dist/resources/extensions/shared/next-action-ui.js +168 -0
- package/dist/resources/extensions/shared/{path-display.ts → path-display.js} +2 -3
- package/dist/resources/extensions/shared/sanitize.js +17 -0
- package/dist/resources/extensions/shared/terminal.js +21 -0
- package/dist/resources/extensions/shared/ui.js +245 -0
- package/dist/resources/extensions/shared/wizard-ui.js +478 -0
- package/dist/resources/extensions/slash-commands/audit.js +72 -0
- package/dist/resources/extensions/slash-commands/clear.js +8 -0
- package/dist/resources/extensions/slash-commands/create-extension.js +264 -0
- package/dist/resources/extensions/slash-commands/create-slash-command.js +208 -0
- package/dist/resources/extensions/slash-commands/index.js +10 -0
- package/dist/resources/extensions/subagent/agents.js +103 -0
- package/dist/resources/extensions/subagent/index.js +905 -0
- package/dist/resources/extensions/subagent/isolation.js +384 -0
- package/dist/resources/extensions/subagent/worker-registry.js +73 -0
- package/dist/resources/extensions/ttsr/index.js +144 -0
- package/dist/resources/extensions/ttsr/rule-loader.js +70 -0
- package/dist/resources/extensions/ttsr/ttsr-manager.js +380 -0
- package/dist/resources/extensions/universal-config/discovery.js +94 -0
- package/dist/resources/extensions/universal-config/format.js +178 -0
- package/dist/resources/extensions/universal-config/index.js +99 -0
- package/dist/resources/extensions/universal-config/scanners.js +574 -0
- package/dist/resources/extensions/universal-config/tools.js +57 -0
- package/dist/resources/extensions/universal-config/types.js +8 -0
- package/dist/resources/extensions/voice/index.js +247 -0
- package/dist/startup-timings.d.ts +2 -0
- package/dist/startup-timings.js +22 -0
- package/package.json +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.js +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +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 +31 -4
- package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/index.js +1 -1
- package/packages/pi-coding-agent/dist/index.js.map +1 -1
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/core/extensions/index.ts +1 -0
- package/packages/pi-coding-agent/src/core/extensions/loader.ts +35 -4
- package/packages/pi-coding-agent/src/index.ts +1 -0
- package/pkg/package.json +1 -1
- package/src/resources/extensions/bg-shell/index.ts +41 -46
- package/src/resources/extensions/browser-tools/index.ts +156 -67
- package/src/resources/extensions/gsd/auto-supervisor.ts +10 -5
- package/src/resources/extensions/gsd/auto-verification.ts +20 -2
- package/src/resources/extensions/gsd/auto-worktree.ts +136 -1
- package/src/resources/extensions/gsd/commands-bootstrap.ts +252 -0
- package/src/resources/extensions/gsd/commands.ts +53 -33
- package/src/resources/extensions/gsd/git-service.ts +24 -11
- package/src/resources/extensions/gsd/index.ts +106 -34
- package/src/resources/extensions/gsd/quick.ts +52 -3
- package/src/resources/extensions/gsd/repo-identity.ts +56 -22
- package/src/resources/extensions/gsd/session-lock.ts +80 -16
- package/src/resources/extensions/gsd/tests/auto-dispatch-loop.test.ts +691 -0
- package/src/resources/extensions/gsd/tests/cache-staleness-regression.test.ts +317 -0
- package/src/resources/extensions/gsd/tests/git-service.test.ts +16 -7
- package/src/resources/extensions/gsd/tests/loop-regression.test.ts +40 -5
- package/src/resources/extensions/gsd/tests/quick-branch-lifecycle.test.ts +281 -0
- package/src/resources/extensions/gsd/tests/repo-identity-worktree.test.ts +71 -0
- package/src/resources/extensions/gsd/tests/roadmap-parse-regression.test.ts +358 -0
- package/src/resources/extensions/gsd/tests/session-lock-regression.test.ts +216 -0
- package/src/resources/extensions/gsd/tests/session-lock.test.ts +119 -0
- package/src/resources/extensions/gsd/tests/verification-gate.test.ts +65 -0
- package/src/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +206 -0
- package/src/resources/extensions/gsd/types.ts +4 -0
- package/src/resources/extensions/gsd/verification-evidence.ts +1 -1
- package/src/resources/extensions/gsd/verification-gate.ts +23 -2
- package/src/resources/extensions/gsd/worktree-command-bootstrap.ts +46 -0
- package/src/resources/extensions/gsd/worktree-command.ts +17 -11
- package/src/resources/extensions/package.json +3 -0
- package/src/resources/extensions/search-the-web/command-search-provider.ts +1 -1
- package/src/resources/extensions/search-the-web/index.ts +35 -52
- package/src/resources/extensions/search-the-web/tavily.ts +1 -1
- package/dist/resources/extensions/ask-user-questions.ts +0 -290
- package/dist/resources/extensions/async-jobs/async-bash-tool.ts +0 -212
- package/dist/resources/extensions/async-jobs/await-tool.ts +0 -103
- package/dist/resources/extensions/async-jobs/cancel-job-tool.ts +0 -35
- package/dist/resources/extensions/async-jobs/index.ts +0 -141
- package/dist/resources/extensions/async-jobs/job-manager.ts +0 -211
- package/dist/resources/extensions/aws-auth/index.ts +0 -144
- package/dist/resources/extensions/bg-shell/bg-shell-command.ts +0 -219
- package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.ts +0 -400
- package/dist/resources/extensions/bg-shell/bg-shell-tool.ts +0 -985
- package/dist/resources/extensions/bg-shell/index.ts +0 -59
- package/dist/resources/extensions/bg-shell/interaction.ts +0 -198
- package/dist/resources/extensions/bg-shell/output-formatter.ts +0 -279
- package/dist/resources/extensions/bg-shell/overlay.ts +0 -437
- package/dist/resources/extensions/bg-shell/process-manager.ts +0 -464
- package/dist/resources/extensions/bg-shell/readiness-detector.ts +0 -126
- package/dist/resources/extensions/bg-shell/types.ts +0 -303
- package/dist/resources/extensions/bg-shell/utilities.ts +0 -57
- package/dist/resources/extensions/browser-tools/capture.ts +0 -199
- package/dist/resources/extensions/browser-tools/core.ts +0 -1196
- package/dist/resources/extensions/browser-tools/index.ts +0 -71
- package/dist/resources/extensions/browser-tools/lifecycle.ts +0 -270
- package/dist/resources/extensions/browser-tools/refs.ts +0 -264
- package/dist/resources/extensions/browser-tools/settle.ts +0 -197
- package/dist/resources/extensions/browser-tools/state.ts +0 -408
- package/dist/resources/extensions/browser-tools/tools/action-cache.ts +0 -216
- package/dist/resources/extensions/browser-tools/tools/assertions.ts +0 -342
- package/dist/resources/extensions/browser-tools/tools/codegen.ts +0 -274
- package/dist/resources/extensions/browser-tools/tools/device.ts +0 -183
- package/dist/resources/extensions/browser-tools/tools/extract.ts +0 -229
- package/dist/resources/extensions/browser-tools/tools/forms.ts +0 -801
- package/dist/resources/extensions/browser-tools/tools/injection-detect.ts +0 -221
- package/dist/resources/extensions/browser-tools/tools/inspection.ts +0 -492
- package/dist/resources/extensions/browser-tools/tools/intent.ts +0 -614
- package/dist/resources/extensions/browser-tools/tools/interaction.ts +0 -865
- package/dist/resources/extensions/browser-tools/tools/navigation.ts +0 -232
- package/dist/resources/extensions/browser-tools/tools/network-mock.ts +0 -244
- package/dist/resources/extensions/browser-tools/tools/pages.ts +0 -303
- package/dist/resources/extensions/browser-tools/tools/pdf.ts +0 -92
- package/dist/resources/extensions/browser-tools/tools/refs.ts +0 -541
- package/dist/resources/extensions/browser-tools/tools/screenshot.ts +0 -101
- package/dist/resources/extensions/browser-tools/tools/session.ts +0 -400
- package/dist/resources/extensions/browser-tools/tools/state-persistence.ts +0 -202
- package/dist/resources/extensions/browser-tools/tools/visual-diff.ts +0 -209
- package/dist/resources/extensions/browser-tools/tools/wait.ts +0 -247
- package/dist/resources/extensions/browser-tools/tools/zoom.ts +0 -104
- package/dist/resources/extensions/browser-tools/utils.ts +0 -660
- package/dist/resources/extensions/context7/index.ts +0 -428
- package/dist/resources/extensions/get-secrets-from-user.ts +0 -607
- package/dist/resources/extensions/google-search/index.ts +0 -466
- package/dist/resources/extensions/gsd/activity-log.ts +0 -162
- package/dist/resources/extensions/gsd/atomic-write.ts +0 -35
- package/dist/resources/extensions/gsd/auto/session.ts +0 -236
- package/dist/resources/extensions/gsd/auto-budget.ts +0 -32
- package/dist/resources/extensions/gsd/auto-dashboard.ts +0 -626
- package/dist/resources/extensions/gsd/auto-direct-dispatch.ts +0 -224
- package/dist/resources/extensions/gsd/auto-dispatch.ts +0 -409
- package/dist/resources/extensions/gsd/auto-idempotency.ts +0 -151
- package/dist/resources/extensions/gsd/auto-model-selection.ts +0 -179
- package/dist/resources/extensions/gsd/auto-observability.ts +0 -72
- package/dist/resources/extensions/gsd/auto-post-unit.ts +0 -618
- package/dist/resources/extensions/gsd/auto-prompts.ts +0 -1273
- package/dist/resources/extensions/gsd/auto-recovery.ts +0 -578
- package/dist/resources/extensions/gsd/auto-start.ts +0 -483
- package/dist/resources/extensions/gsd/auto-stuck-detection.ts +0 -221
- package/dist/resources/extensions/gsd/auto-timeout-recovery.ts +0 -263
- package/dist/resources/extensions/gsd/auto-timers.ts +0 -224
- package/dist/resources/extensions/gsd/auto-tool-tracking.ts +0 -54
- package/dist/resources/extensions/gsd/auto-unit-closeout.ts +0 -48
- package/dist/resources/extensions/gsd/auto-verification.ts +0 -229
- package/dist/resources/extensions/gsd/auto-worktree.ts +0 -524
- package/dist/resources/extensions/gsd/auto.ts +0 -1834
- package/dist/resources/extensions/gsd/captures.ts +0 -427
- package/dist/resources/extensions/gsd/claude-import.ts +0 -656
- package/dist/resources/extensions/gsd/collision-diagnostics.ts +0 -332
- package/dist/resources/extensions/gsd/commands-config.ts +0 -102
- package/dist/resources/extensions/gsd/commands-extensions.ts +0 -328
- package/dist/resources/extensions/gsd/commands-handlers.ts +0 -395
- package/dist/resources/extensions/gsd/commands-inspect.ts +0 -91
- package/dist/resources/extensions/gsd/commands-logs.ts +0 -536
- package/dist/resources/extensions/gsd/commands-maintenance.ts +0 -206
- package/dist/resources/extensions/gsd/commands-prefs-wizard.ts +0 -780
- package/dist/resources/extensions/gsd/commands-workflow-templates.ts +0 -543
- package/dist/resources/extensions/gsd/commands.ts +0 -1137
- package/dist/resources/extensions/gsd/complexity-classifier.ts +0 -320
- package/dist/resources/extensions/gsd/context-budget.ts +0 -266
- package/dist/resources/extensions/gsd/context-store.ts +0 -195
- package/dist/resources/extensions/gsd/crash-recovery.ts +0 -121
- package/dist/resources/extensions/gsd/dashboard-overlay.ts +0 -681
- package/dist/resources/extensions/gsd/db-writer.ts +0 -360
- package/dist/resources/extensions/gsd/debug-logger.ts +0 -178
- package/dist/resources/extensions/gsd/detection.ts +0 -470
- package/dist/resources/extensions/gsd/diff-context.ts +0 -214
- package/dist/resources/extensions/gsd/dispatch-guard.ts +0 -81
- package/dist/resources/extensions/gsd/doctor-checks.ts +0 -612
- package/dist/resources/extensions/gsd/doctor-environment.ts +0 -497
- package/dist/resources/extensions/gsd/doctor-format.ts +0 -78
- package/dist/resources/extensions/gsd/doctor-proactive.ts +0 -292
- package/dist/resources/extensions/gsd/doctor-providers.ts +0 -343
- package/dist/resources/extensions/gsd/doctor-types.ts +0 -87
- package/dist/resources/extensions/gsd/doctor.ts +0 -722
- package/dist/resources/extensions/gsd/error-utils.ts +0 -6
- package/dist/resources/extensions/gsd/exit-command.ts +0 -18
- package/dist/resources/extensions/gsd/export.ts +0 -317
- package/dist/resources/extensions/gsd/file-watcher.ts +0 -97
- package/dist/resources/extensions/gsd/files.ts +0 -1058
- package/dist/resources/extensions/gsd/forensics.ts +0 -629
- package/dist/resources/extensions/gsd/git-self-heal.ts +0 -127
- package/dist/resources/extensions/gsd/git-service.ts +0 -580
- package/dist/resources/extensions/gsd/gsd-db.ts +0 -685
- package/dist/resources/extensions/gsd/guided-flow-queue.ts +0 -440
- package/dist/resources/extensions/gsd/guided-flow.ts +0 -1303
- package/dist/resources/extensions/gsd/health-widget.ts +0 -167
- package/dist/resources/extensions/gsd/history.ts +0 -143
- package/dist/resources/extensions/gsd/index.ts +0 -1390
- package/dist/resources/extensions/gsd/init-wizard.ts +0 -587
- package/dist/resources/extensions/gsd/json-persistence.ts +0 -67
- package/dist/resources/extensions/gsd/key-manager.ts +0 -996
- package/dist/resources/extensions/gsd/marketplace-discovery.ts +0 -508
- package/dist/resources/extensions/gsd/md-importer.ts +0 -527
- package/dist/resources/extensions/gsd/mechanical-completion.ts +0 -430
- package/dist/resources/extensions/gsd/memory-extractor.ts +0 -352
- package/dist/resources/extensions/gsd/memory-store.ts +0 -441
- package/dist/resources/extensions/gsd/metrics.ts +0 -532
- package/dist/resources/extensions/gsd/migrate/command.ts +0 -219
- package/dist/resources/extensions/gsd/migrate/index.ts +0 -42
- package/dist/resources/extensions/gsd/migrate/parser.ts +0 -323
- package/dist/resources/extensions/gsd/migrate/parsers.ts +0 -539
- package/dist/resources/extensions/gsd/migrate/preview.ts +0 -48
- package/dist/resources/extensions/gsd/migrate/transformer.ts +0 -346
- package/dist/resources/extensions/gsd/migrate/types.ts +0 -370
- package/dist/resources/extensions/gsd/migrate/validator.ts +0 -55
- package/dist/resources/extensions/gsd/migrate/writer.ts +0 -579
- package/dist/resources/extensions/gsd/migrate-external.ts +0 -140
- package/dist/resources/extensions/gsd/milestone-actions.ts +0 -126
- package/dist/resources/extensions/gsd/model-cost-table.ts +0 -65
- package/dist/resources/extensions/gsd/model-router.ts +0 -256
- package/dist/resources/extensions/gsd/namespaced-registry.ts +0 -467
- package/dist/resources/extensions/gsd/namespaced-resolver.ts +0 -307
- package/dist/resources/extensions/gsd/native-git-bridge.ts +0 -1041
- package/dist/resources/extensions/gsd/native-parser-bridge.ts +0 -267
- package/dist/resources/extensions/gsd/notifications.ts +0 -87
- package/dist/resources/extensions/gsd/observability-validator.ts +0 -429
- package/dist/resources/extensions/gsd/parallel-eligibility.ts +0 -233
- package/dist/resources/extensions/gsd/parallel-merge.ts +0 -157
- package/dist/resources/extensions/gsd/parallel-orchestrator.ts +0 -826
- package/dist/resources/extensions/gsd/paths.ts +0 -449
- package/dist/resources/extensions/gsd/plugin-importer.ts +0 -411
- package/dist/resources/extensions/gsd/post-unit-hooks.ts +0 -520
- package/dist/resources/extensions/gsd/preferences-models.ts +0 -329
- package/dist/resources/extensions/gsd/preferences-skills.ts +0 -169
- package/dist/resources/extensions/gsd/preferences-types.ts +0 -229
- package/dist/resources/extensions/gsd/preferences-validation.ts +0 -590
- package/dist/resources/extensions/gsd/preferences.ts +0 -416
- package/dist/resources/extensions/gsd/progress-score.ts +0 -273
- package/dist/resources/extensions/gsd/prompt-cache-optimizer.ts +0 -213
- package/dist/resources/extensions/gsd/prompt-compressor.ts +0 -508
- package/dist/resources/extensions/gsd/prompt-loader.ts +0 -130
- package/dist/resources/extensions/gsd/prompt-ordering.ts +0 -200
- package/dist/resources/extensions/gsd/provider-error-pause.ts +0 -88
- package/dist/resources/extensions/gsd/queue-order.ts +0 -230
- package/dist/resources/extensions/gsd/queue-reorder-ui.ts +0 -276
- package/dist/resources/extensions/gsd/quick.ts +0 -212
- package/dist/resources/extensions/gsd/repo-identity.ts +0 -169
- package/dist/resources/extensions/gsd/roadmap-slices.ts +0 -149
- package/dist/resources/extensions/gsd/routing-history.ts +0 -286
- package/dist/resources/extensions/gsd/safe-fs.ts +0 -47
- package/dist/resources/extensions/gsd/semantic-chunker.ts +0 -336
- package/dist/resources/extensions/gsd/session-forensics.ts +0 -537
- package/dist/resources/extensions/gsd/session-lock.ts +0 -362
- package/dist/resources/extensions/gsd/session-status-io.ts +0 -179
- package/dist/resources/extensions/gsd/skill-discovery.ts +0 -139
- package/dist/resources/extensions/gsd/skill-health.ts +0 -417
- package/dist/resources/extensions/gsd/state.ts +0 -727
- package/dist/resources/extensions/gsd/structured-data-formatter.ts +0 -144
- package/dist/resources/extensions/gsd/summary-distiller.ts +0 -258
- package/dist/resources/extensions/gsd/tests/activity-log.test.ts +0 -213
- package/dist/resources/extensions/gsd/tests/agent-end-retry.test.ts +0 -107
- package/dist/resources/extensions/gsd/tests/all-milestones-complete-merge.test.ts +0 -200
- package/dist/resources/extensions/gsd/tests/auto-budget-alerts.test.ts +0 -50
- package/dist/resources/extensions/gsd/tests/auto-dashboard.test.ts +0 -166
- package/dist/resources/extensions/gsd/tests/auto-lock-creation.test.ts +0 -186
- package/dist/resources/extensions/gsd/tests/auto-preflight.test.ts +0 -40
- package/dist/resources/extensions/gsd/tests/auto-recovery.test.ts +0 -640
- package/dist/resources/extensions/gsd/tests/auto-reentrancy-guard.test.ts +0 -127
- package/dist/resources/extensions/gsd/tests/auto-secrets-gate.test.ts +0 -302
- package/dist/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +0 -257
- package/dist/resources/extensions/gsd/tests/auto-skip-loop.test.ts +0 -123
- package/dist/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +0 -340
- package/dist/resources/extensions/gsd/tests/auto-worktree.test.ts +0 -167
- package/dist/resources/extensions/gsd/tests/budget-prediction.test.ts +0 -220
- package/dist/resources/extensions/gsd/tests/captures.test.ts +0 -438
- package/dist/resources/extensions/gsd/tests/claude-import-tui.test.ts +0 -351
- package/dist/resources/extensions/gsd/tests/collect-from-manifest.test.ts +0 -469
- package/dist/resources/extensions/gsd/tests/collision-diagnostics.test.ts +0 -705
- package/dist/resources/extensions/gsd/tests/commands-logs.test.ts +0 -241
- package/dist/resources/extensions/gsd/tests/complete-milestone.test.ts +0 -209
- package/dist/resources/extensions/gsd/tests/complexity-classifier.test.ts +0 -181
- package/dist/resources/extensions/gsd/tests/context-budget.test.ts +0 -352
- package/dist/resources/extensions/gsd/tests/context-compression.test.ts +0 -193
- package/dist/resources/extensions/gsd/tests/context-store.test.ts +0 -462
- package/dist/resources/extensions/gsd/tests/continue-here.test.ts +0 -285
- package/dist/resources/extensions/gsd/tests/cost-projection.test.ts +0 -134
- package/dist/resources/extensions/gsd/tests/crash-recovery.test.ts +0 -134
- package/dist/resources/extensions/gsd/tests/dashboard-budget.test.ts +0 -346
- package/dist/resources/extensions/gsd/tests/db-writer.test.ts +0 -602
- package/dist/resources/extensions/gsd/tests/debug-logger.test.ts +0 -185
- package/dist/resources/extensions/gsd/tests/derive-state-db.test.ts +0 -405
- package/dist/resources/extensions/gsd/tests/derive-state-deps.test.ts +0 -421
- package/dist/resources/extensions/gsd/tests/derive-state-draft.test.ts +0 -308
- package/dist/resources/extensions/gsd/tests/derive-state.test.ts +0 -788
- package/dist/resources/extensions/gsd/tests/detection.test.ts +0 -398
- package/dist/resources/extensions/gsd/tests/diff-context.test.ts +0 -136
- package/dist/resources/extensions/gsd/tests/discuss-prompt.test.ts +0 -15
- package/dist/resources/extensions/gsd/tests/dispatch-guard.test.ts +0 -128
- package/dist/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +0 -132
- package/dist/resources/extensions/gsd/tests/dispatch-stall-guard.test.ts +0 -126
- package/dist/resources/extensions/gsd/tests/doctor-environment.test.ts +0 -314
- package/dist/resources/extensions/gsd/tests/doctor-fixlevel.test.ts +0 -245
- package/dist/resources/extensions/gsd/tests/doctor-git.test.ts +0 -344
- package/dist/resources/extensions/gsd/tests/doctor-proactive.test.ts +0 -278
- package/dist/resources/extensions/gsd/tests/doctor-providers.test.ts +0 -298
- package/dist/resources/extensions/gsd/tests/doctor-runtime.test.ts +0 -302
- package/dist/resources/extensions/gsd/tests/doctor.test.ts +0 -652
- package/dist/resources/extensions/gsd/tests/draft-promotion.test.ts +0 -169
- package/dist/resources/extensions/gsd/tests/exit-command.test.ts +0 -50
- package/dist/resources/extensions/gsd/tests/export-html-all.test.ts +0 -105
- package/dist/resources/extensions/gsd/tests/export-html-enhancements.test.ts +0 -378
- package/dist/resources/extensions/gsd/tests/extension-selector-separator.test.ts +0 -144
- package/dist/resources/extensions/gsd/tests/feature-branch-lifecycle-integration.test.ts +0 -424
- package/dist/resources/extensions/gsd/tests/git-self-heal.test.ts +0 -131
- package/dist/resources/extensions/gsd/tests/git-service.test.ts +0 -1172
- package/dist/resources/extensions/gsd/tests/gsd-db.test.ts +0 -353
- package/dist/resources/extensions/gsd/tests/gsd-inspect.test.ts +0 -125
- package/dist/resources/extensions/gsd/tests/gsd-tools.test.ts +0 -326
- package/dist/resources/extensions/gsd/tests/headless-answers.test.ts +0 -340
- package/dist/resources/extensions/gsd/tests/headless-query.test.ts +0 -162
- package/dist/resources/extensions/gsd/tests/idle-recovery.test.ts +0 -485
- package/dist/resources/extensions/gsd/tests/in-flight-tool-tracking.test.ts +0 -32
- package/dist/resources/extensions/gsd/tests/init-wizard.test.ts +0 -197
- package/dist/resources/extensions/gsd/tests/integration/headless-command.ts +0 -534
- package/dist/resources/extensions/gsd/tests/integration-edge.test.ts +0 -228
- package/dist/resources/extensions/gsd/tests/integration-lifecycle.test.ts +0 -277
- package/dist/resources/extensions/gsd/tests/integration-mixed-milestones.test.ts +0 -523
- package/dist/resources/extensions/gsd/tests/key-manager.test.ts +0 -414
- package/dist/resources/extensions/gsd/tests/knowledge.test.ts +0 -161
- package/dist/resources/extensions/gsd/tests/loop-regression.test.ts +0 -839
- package/dist/resources/extensions/gsd/tests/manifest-status.test.ts +0 -283
- package/dist/resources/extensions/gsd/tests/marketplace-test-fixtures.ts +0 -91
- package/dist/resources/extensions/gsd/tests/md-importer.test.ts +0 -410
- package/dist/resources/extensions/gsd/tests/mechanical-completion.test.ts +0 -356
- package/dist/resources/extensions/gsd/tests/memory-extractor.test.ts +0 -180
- package/dist/resources/extensions/gsd/tests/memory-leak-guards.test.ts +0 -91
- package/dist/resources/extensions/gsd/tests/memory-store.test.ts +0 -345
- package/dist/resources/extensions/gsd/tests/metrics.test.ts +0 -253
- package/dist/resources/extensions/gsd/tests/migrate-command.test.ts +0 -369
- package/dist/resources/extensions/gsd/tests/migrate-parser.test.ts +0 -757
- package/dist/resources/extensions/gsd/tests/migrate-transformer.test.ts +0 -635
- package/dist/resources/extensions/gsd/tests/migrate-validator-parsers.test.ts +0 -414
- package/dist/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +0 -303
- package/dist/resources/extensions/gsd/tests/migrate-writer.test.ts +0 -398
- package/dist/resources/extensions/gsd/tests/milestone-transition-worktree.test.ts +0 -147
- package/dist/resources/extensions/gsd/tests/model-cost-table.test.ts +0 -69
- package/dist/resources/extensions/gsd/tests/model-isolation.test.ts +0 -157
- package/dist/resources/extensions/gsd/tests/model-router.test.ts +0 -167
- package/dist/resources/extensions/gsd/tests/must-have-parser.test.ts +0 -291
- package/dist/resources/extensions/gsd/tests/namespaced-registry.test.ts +0 -1027
- package/dist/resources/extensions/gsd/tests/namespaced-resolver.test.ts +0 -671
- package/dist/resources/extensions/gsd/tests/native-has-changes-cache.test.ts +0 -61
- package/dist/resources/extensions/gsd/tests/next-milestone-id.test.ts +0 -23
- package/dist/resources/extensions/gsd/tests/none-mode-gates.test.ts +0 -114
- package/dist/resources/extensions/gsd/tests/notifications.test.ts +0 -67
- package/dist/resources/extensions/gsd/tests/overrides.test.ts +0 -131
- package/dist/resources/extensions/gsd/tests/parallel-budget-atomicity.test.ts +0 -331
- package/dist/resources/extensions/gsd/tests/parallel-crash-recovery.test.ts +0 -298
- package/dist/resources/extensions/gsd/tests/parallel-merge.test.ts +0 -468
- package/dist/resources/extensions/gsd/tests/parallel-orchestration.test.ts +0 -685
- package/dist/resources/extensions/gsd/tests/parallel-worker-monitoring.test.ts +0 -171
- package/dist/resources/extensions/gsd/tests/parallel-workers-multi-milestone-e2e.test.ts +0 -354
- package/dist/resources/extensions/gsd/tests/park-edge-cases.test.ts +0 -276
- package/dist/resources/extensions/gsd/tests/park-milestone.test.ts +0 -401
- package/dist/resources/extensions/gsd/tests/parsers.test.ts +0 -1704
- package/dist/resources/extensions/gsd/tests/plan-milestone.test.ts +0 -133
- package/dist/resources/extensions/gsd/tests/plan-quality-validator.test.ts +0 -363
- package/dist/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +0 -42
- package/dist/resources/extensions/gsd/tests/plugin-importer-live.test.ts +0 -481
- package/dist/resources/extensions/gsd/tests/plugin-importer.test.ts +0 -1383
- package/dist/resources/extensions/gsd/tests/post-unit-hooks.test.ts +0 -337
- package/dist/resources/extensions/gsd/tests/preferences.test.ts +0 -276
- package/dist/resources/extensions/gsd/tests/progress-score.test.ts +0 -206
- package/dist/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +0 -464
- package/dist/resources/extensions/gsd/tests/prompt-cache-optimizer.test.ts +0 -314
- package/dist/resources/extensions/gsd/tests/prompt-compressor.test.ts +0 -529
- package/dist/resources/extensions/gsd/tests/prompt-db.test.ts +0 -385
- package/dist/resources/extensions/gsd/tests/prompt-ordering.test.ts +0 -296
- package/dist/resources/extensions/gsd/tests/provider-errors.test.ts +0 -338
- package/dist/resources/extensions/gsd/tests/queue-draft-detection.test.ts +0 -126
- package/dist/resources/extensions/gsd/tests/queue-order.test.ts +0 -204
- package/dist/resources/extensions/gsd/tests/queue-reorder-e2e.test.ts +0 -282
- package/dist/resources/extensions/gsd/tests/reassess-detection.test.ts +0 -154
- package/dist/resources/extensions/gsd/tests/reassess-prompt.test.ts +0 -145
- package/dist/resources/extensions/gsd/tests/regex-hardening.test.ts +0 -281
- package/dist/resources/extensions/gsd/tests/remote-questions.test.ts +0 -642
- package/dist/resources/extensions/gsd/tests/remote-status.test.ts +0 -99
- package/dist/resources/extensions/gsd/tests/replan-slice.test.ts +0 -538
- package/dist/resources/extensions/gsd/tests/requirements.test.ts +0 -106
- package/dist/resources/extensions/gsd/tests/roadmap-slices.test.ts +0 -66
- package/dist/resources/extensions/gsd/tests/routing-history.test.ts +0 -240
- package/dist/resources/extensions/gsd/tests/run-uat.test.ts +0 -416
- package/dist/resources/extensions/gsd/tests/secure-env-collect.test.ts +0 -185
- package/dist/resources/extensions/gsd/tests/semantic-chunker.test.ts +0 -426
- package/dist/resources/extensions/gsd/tests/session-lock.test.ts +0 -315
- package/dist/resources/extensions/gsd/tests/skill-lifecycle.test.ts +0 -126
- package/dist/resources/extensions/gsd/tests/smart-entry-draft.test.ts +0 -123
- package/dist/resources/extensions/gsd/tests/stale-worktree-cwd.test.ts +0 -142
- package/dist/resources/extensions/gsd/tests/stop-auto-remote.test.ts +0 -156
- package/dist/resources/extensions/gsd/tests/structured-data-formatter.test.ts +0 -365
- package/dist/resources/extensions/gsd/tests/summary-distiller.test.ts +0 -323
- package/dist/resources/extensions/gsd/tests/test-helpers.ts +0 -61
- package/dist/resources/extensions/gsd/tests/token-counter.test.ts +0 -129
- package/dist/resources/extensions/gsd/tests/token-optimization-benchmark.test.ts +0 -1272
- package/dist/resources/extensions/gsd/tests/token-optimization-prefs.test.ts +0 -164
- package/dist/resources/extensions/gsd/tests/token-profile.test.ts +0 -268
- package/dist/resources/extensions/gsd/tests/token-savings.test.ts +0 -366
- package/dist/resources/extensions/gsd/tests/triage-dispatch.test.ts +0 -340
- package/dist/resources/extensions/gsd/tests/triage-resolution.test.ts +0 -416
- package/dist/resources/extensions/gsd/tests/undo.test.ts +0 -136
- package/dist/resources/extensions/gsd/tests/unique-milestone-ids.test.ts +0 -219
- package/dist/resources/extensions/gsd/tests/unit-runtime.test.ts +0 -258
- package/dist/resources/extensions/gsd/tests/update-command.test.ts +0 -67
- package/dist/resources/extensions/gsd/tests/validate-directory.test.ts +0 -222
- package/dist/resources/extensions/gsd/tests/validate-milestone.test.ts +0 -375
- package/dist/resources/extensions/gsd/tests/verification-evidence.test.ts +0 -745
- package/dist/resources/extensions/gsd/tests/verification-gate.test.ts +0 -1208
- package/dist/resources/extensions/gsd/tests/visualizer-critical-path.test.ts +0 -145
- package/dist/resources/extensions/gsd/tests/visualizer-data.test.ts +0 -446
- package/dist/resources/extensions/gsd/tests/visualizer-overlay.test.ts +0 -237
- package/dist/resources/extensions/gsd/tests/visualizer-views.test.ts +0 -718
- package/dist/resources/extensions/gsd/tests/worker-registry.test.ts +0 -148
- package/dist/resources/extensions/gsd/tests/workflow-templates.test.ts +0 -173
- package/dist/resources/extensions/gsd/tests/workspace-index.test.ts +0 -38
- package/dist/resources/extensions/gsd/tests/worktree-bugfix.test.ts +0 -120
- package/dist/resources/extensions/gsd/tests/worktree-e2e.test.ts +0 -244
- package/dist/resources/extensions/gsd/tests/worktree-integration.test.ts +0 -207
- package/dist/resources/extensions/gsd/tests/worktree-manager.test.ts +0 -141
- package/dist/resources/extensions/gsd/tests/worktree-post-create-hook.test.ts +0 -165
- package/dist/resources/extensions/gsd/tests/worktree.test.ts +0 -171
- package/dist/resources/extensions/gsd/tests/write-gate.test.ts +0 -211
- package/dist/resources/extensions/gsd/token-counter.ts +0 -65
- package/dist/resources/extensions/gsd/triage-resolution.ts +0 -284
- package/dist/resources/extensions/gsd/triage-ui.ts +0 -175
- package/dist/resources/extensions/gsd/types.ts +0 -425
- package/dist/resources/extensions/gsd/undo.ts +0 -223
- package/dist/resources/extensions/gsd/unit-id.ts +0 -14
- package/dist/resources/extensions/gsd/unit-runtime.ts +0 -192
- package/dist/resources/extensions/gsd/validate-directory.ts +0 -164
- package/dist/resources/extensions/gsd/verification-evidence.ts +0 -188
- package/dist/resources/extensions/gsd/verification-gate.ts +0 -643
- package/dist/resources/extensions/gsd/visualizer-data.ts +0 -866
- package/dist/resources/extensions/gsd/visualizer-overlay.ts +0 -566
- package/dist/resources/extensions/gsd/visualizer-views.ts +0 -1171
- package/dist/resources/extensions/gsd/workflow-templates.ts +0 -241
- package/dist/resources/extensions/gsd/workspace-index.ts +0 -217
- package/dist/resources/extensions/gsd/worktree-command.ts +0 -807
- package/dist/resources/extensions/gsd/worktree-manager.ts +0 -449
- package/dist/resources/extensions/gsd/worktree.ts +0 -257
- package/dist/resources/extensions/mac-tools/index.ts +0 -852
- package/dist/resources/extensions/mcp-client/index.ts +0 -459
- package/dist/resources/extensions/mcporter/extension-manifest.json +0 -12
- package/dist/resources/extensions/remote-questions/config.ts +0 -83
- package/dist/resources/extensions/remote-questions/discord-adapter.ts +0 -148
- package/dist/resources/extensions/remote-questions/format.ts +0 -315
- package/dist/resources/extensions/remote-questions/http-client.ts +0 -76
- package/dist/resources/extensions/remote-questions/manager.ts +0 -184
- package/dist/resources/extensions/remote-questions/notify.ts +0 -90
- package/dist/resources/extensions/remote-questions/remote-command.ts +0 -457
- package/dist/resources/extensions/remote-questions/slack-adapter.ts +0 -141
- package/dist/resources/extensions/remote-questions/status.ts +0 -31
- package/dist/resources/extensions/remote-questions/store.ts +0 -81
- package/dist/resources/extensions/remote-questions/telegram-adapter.ts +0 -149
- package/dist/resources/extensions/remote-questions/types.ts +0 -102
- package/dist/resources/extensions/search-the-web/cache.ts +0 -78
- package/dist/resources/extensions/search-the-web/command-search-provider.ts +0 -101
- package/dist/resources/extensions/search-the-web/format.ts +0 -258
- package/dist/resources/extensions/search-the-web/http.ts +0 -238
- package/dist/resources/extensions/search-the-web/index.ts +0 -65
- package/dist/resources/extensions/search-the-web/native-search.ts +0 -193
- package/dist/resources/extensions/search-the-web/provider.ts +0 -148
- package/dist/resources/extensions/search-the-web/tavily.ts +0 -116
- package/dist/resources/extensions/search-the-web/tool-fetch-page.ts +0 -589
- package/dist/resources/extensions/search-the-web/tool-llm-context.ts +0 -608
- package/dist/resources/extensions/search-the-web/tool-search.ts +0 -649
- package/dist/resources/extensions/search-the-web/url-utils.ts +0 -125
- package/dist/resources/extensions/shared/confirm-ui.ts +0 -126
- package/dist/resources/extensions/shared/frontmatter.ts +0 -117
- package/dist/resources/extensions/shared/interview-ui.ts +0 -613
- package/dist/resources/extensions/shared/next-action-ui.ts +0 -212
- package/dist/resources/extensions/shared/sanitize.ts +0 -19
- package/dist/resources/extensions/shared/terminal.ts +0 -23
- package/dist/resources/extensions/shared/tests/format-utils.test.ts +0 -153
- package/dist/resources/extensions/shared/ui.ts +0 -400
- package/dist/resources/extensions/shared/wizard-ui.ts +0 -551
- package/dist/resources/extensions/slash-commands/audit.ts +0 -88
- package/dist/resources/extensions/slash-commands/clear.ts +0 -10
- package/dist/resources/extensions/slash-commands/create-extension.ts +0 -297
- package/dist/resources/extensions/slash-commands/create-slash-command.ts +0 -234
- package/dist/resources/extensions/slash-commands/index.ts +0 -12
- package/dist/resources/extensions/subagent/agents.ts +0 -126
- package/dist/resources/extensions/subagent/index.ts +0 -1121
- package/dist/resources/extensions/subagent/isolation.ts +0 -501
- package/dist/resources/extensions/subagent/worker-registry.ts +0 -99
- package/dist/resources/extensions/ttsr/index.ts +0 -168
- package/dist/resources/extensions/ttsr/rule-loader.ts +0 -74
- package/dist/resources/extensions/ttsr/ttsr-manager.ts +0 -456
- package/dist/resources/extensions/universal-config/discovery.ts +0 -104
- package/dist/resources/extensions/universal-config/format.ts +0 -191
- package/dist/resources/extensions/universal-config/index.ts +0 -120
- package/dist/resources/extensions/universal-config/scanners.ts +0 -642
- package/dist/resources/extensions/universal-config/tests/discovery.test.ts +0 -119
- package/dist/resources/extensions/universal-config/tests/format.test.ts +0 -127
- package/dist/resources/extensions/universal-config/tests/scanners.test.ts +0 -456
- package/dist/resources/extensions/universal-config/tools.ts +0 -60
- package/dist/resources/extensions/universal-config/types.ts +0 -135
- package/dist/resources/extensions/voice/index.ts +0 -272
- package/dist/resources/skills/create-gsd-extension/templates/extension-skeleton.ts +0 -51
- package/dist/resources/skills/create-gsd-extension/templates/stateful-tool-skeleton.ts +0 -143
- package/src/resources/extensions/mcporter/extension-manifest.json +0 -12
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Timeout recovery logic for auto-mode units.
|
|
3
|
+
* Handles idle and hard timeout recovery with escalation, steering messages,
|
|
4
|
+
* and blocker placeholder generation.
|
|
5
|
+
*/
|
|
6
|
+
import { readUnitRuntimeRecord, writeUnitRuntimeRecord, formatExecuteTaskRecoveryStatus, inspectExecuteTaskDurability, } from "./unit-runtime.js";
|
|
7
|
+
import { resolveExpectedArtifactPath, diagnoseExpectedArtifact, skipExecuteTask, writeBlockerPlaceholder, } from "./auto-recovery.js";
|
|
8
|
+
import { existsSync } from "node:fs";
|
|
9
|
+
import { parseUnitId } from "./unit-id.js";
|
|
10
|
+
export async function recoverTimedOutUnit(ctx, pi, unitType, unitId, reason, rctx) {
|
|
11
|
+
const { basePath, verbose, currentUnitStartedAt, unitRecoveryCount, dispatchNextUnit } = rctx;
|
|
12
|
+
const runtime = readUnitRuntimeRecord(basePath, unitType, unitId);
|
|
13
|
+
const recoveryAttempts = runtime?.recoveryAttempts ?? 0;
|
|
14
|
+
const maxRecoveryAttempts = reason === "idle" ? 2 : 1;
|
|
15
|
+
const recoveryKey = `${unitType}/${unitId}`;
|
|
16
|
+
const attemptNumber = (unitRecoveryCount.get(recoveryKey) ?? 0) + 1;
|
|
17
|
+
unitRecoveryCount.set(recoveryKey, attemptNumber);
|
|
18
|
+
if (attemptNumber > 1) {
|
|
19
|
+
// Exponential backoff: 2^(n-1) seconds, capped at 30s
|
|
20
|
+
const backoffMs = Math.min(1000 * Math.pow(2, attemptNumber - 2), 30000);
|
|
21
|
+
ctx.ui.notify(`Recovery attempt ${attemptNumber} for ${unitType} ${unitId}. Waiting ${backoffMs / 1000}s before retry.`, "info");
|
|
22
|
+
await new Promise(r => setTimeout(r, backoffMs));
|
|
23
|
+
}
|
|
24
|
+
if (unitType === "execute-task") {
|
|
25
|
+
const status = await inspectExecuteTaskDurability(basePath, unitId);
|
|
26
|
+
if (!status)
|
|
27
|
+
return "paused";
|
|
28
|
+
writeUnitRuntimeRecord(basePath, unitType, unitId, currentUnitStartedAt, {
|
|
29
|
+
recovery: status,
|
|
30
|
+
});
|
|
31
|
+
const durableComplete = status.summaryExists && status.taskChecked && status.nextActionAdvanced;
|
|
32
|
+
if (durableComplete) {
|
|
33
|
+
writeUnitRuntimeRecord(basePath, unitType, unitId, currentUnitStartedAt, {
|
|
34
|
+
phase: "finalized",
|
|
35
|
+
recovery: status,
|
|
36
|
+
});
|
|
37
|
+
ctx.ui.notify(`${reason === "idle" ? "Idle" : "Timeout"} recovery: ${unitType} ${unitId} already completed on disk. Continuing auto-mode. (attempt ${attemptNumber})`, "info");
|
|
38
|
+
unitRecoveryCount.delete(recoveryKey);
|
|
39
|
+
await dispatchNextUnit(ctx, pi);
|
|
40
|
+
return "recovered";
|
|
41
|
+
}
|
|
42
|
+
if (recoveryAttempts < maxRecoveryAttempts) {
|
|
43
|
+
const isEscalation = recoveryAttempts > 0;
|
|
44
|
+
writeUnitRuntimeRecord(basePath, unitType, unitId, currentUnitStartedAt, {
|
|
45
|
+
phase: "recovered",
|
|
46
|
+
recovery: status,
|
|
47
|
+
recoveryAttempts: recoveryAttempts + 1,
|
|
48
|
+
lastRecoveryReason: reason,
|
|
49
|
+
lastProgressAt: Date.now(),
|
|
50
|
+
progressCount: (runtime?.progressCount ?? 0) + 1,
|
|
51
|
+
lastProgressKind: reason === "idle" ? "idle-recovery-retry" : "hard-recovery-retry",
|
|
52
|
+
});
|
|
53
|
+
const steeringLines = isEscalation
|
|
54
|
+
? [
|
|
55
|
+
`**FINAL ${reason === "idle" ? "IDLE" : "HARD TIMEOUT"} RECOVERY — last chance before this task is skipped.**`,
|
|
56
|
+
`You are still executing ${unitType} ${unitId}.`,
|
|
57
|
+
`Recovery attempt ${recoveryAttempts + 1} of ${maxRecoveryAttempts}.`,
|
|
58
|
+
`Current durability status: ${formatExecuteTaskRecoveryStatus(status)}.`,
|
|
59
|
+
"You MUST finish the durable output NOW, even if incomplete.",
|
|
60
|
+
"Write the task summary with whatever you have accomplished so far.",
|
|
61
|
+
"Mark the task [x] in the plan. Commit your work.",
|
|
62
|
+
"A partial summary is infinitely better than no summary.",
|
|
63
|
+
]
|
|
64
|
+
: [
|
|
65
|
+
`**${reason === "idle" ? "IDLE" : "HARD TIMEOUT"} RECOVERY — do not stop.**`,
|
|
66
|
+
`You are still executing ${unitType} ${unitId}.`,
|
|
67
|
+
`Recovery attempt ${recoveryAttempts + 1} of ${maxRecoveryAttempts}.`,
|
|
68
|
+
`Current durability status: ${formatExecuteTaskRecoveryStatus(status)}.`,
|
|
69
|
+
"Do not keep exploring.",
|
|
70
|
+
"Immediately finish the required durable output for this unit.",
|
|
71
|
+
"If full completion is impossible, write the partial artifact/state needed for recovery and make the blocker explicit.",
|
|
72
|
+
];
|
|
73
|
+
pi.sendMessage({
|
|
74
|
+
customType: "gsd-auto-timeout-recovery",
|
|
75
|
+
display: verbose,
|
|
76
|
+
content: steeringLines.join("\n"),
|
|
77
|
+
}, { triggerTurn: true, deliverAs: "steer" });
|
|
78
|
+
ctx.ui.notify(`${reason === "idle" ? "Idle" : "Timeout"} recovery: steering ${unitType} ${unitId} to finish durable output (attempt ${attemptNumber}, session ${recoveryAttempts + 1}/${maxRecoveryAttempts}).`, "warning");
|
|
79
|
+
return "recovered";
|
|
80
|
+
}
|
|
81
|
+
// Retries exhausted — write missing durable artifacts and advance.
|
|
82
|
+
const diagnostic = formatExecuteTaskRecoveryStatus(status);
|
|
83
|
+
const { milestone: mid, slice: sid, task: tid } = parseUnitId(unitId);
|
|
84
|
+
const skipped = mid && sid && tid
|
|
85
|
+
? skipExecuteTask(basePath, mid, sid, tid, status, reason, maxRecoveryAttempts)
|
|
86
|
+
: false;
|
|
87
|
+
if (skipped) {
|
|
88
|
+
writeUnitRuntimeRecord(basePath, unitType, unitId, currentUnitStartedAt, {
|
|
89
|
+
phase: "skipped",
|
|
90
|
+
recovery: status,
|
|
91
|
+
recoveryAttempts: recoveryAttempts + 1,
|
|
92
|
+
lastRecoveryReason: reason,
|
|
93
|
+
});
|
|
94
|
+
ctx.ui.notify(`${unitType} ${unitId} skipped after ${maxRecoveryAttempts} recovery attempts (${diagnostic}). Blocker artifacts written. Advancing pipeline. (attempt ${attemptNumber})`, "warning");
|
|
95
|
+
unitRecoveryCount.delete(recoveryKey);
|
|
96
|
+
await dispatchNextUnit(ctx, pi);
|
|
97
|
+
return "recovered";
|
|
98
|
+
}
|
|
99
|
+
// Fallback: couldn't write skip artifacts — pause as before.
|
|
100
|
+
writeUnitRuntimeRecord(basePath, unitType, unitId, currentUnitStartedAt, {
|
|
101
|
+
phase: "paused",
|
|
102
|
+
recovery: status,
|
|
103
|
+
recoveryAttempts: recoveryAttempts + 1,
|
|
104
|
+
lastRecoveryReason: reason,
|
|
105
|
+
});
|
|
106
|
+
ctx.ui.notify(`${reason === "idle" ? "Idle" : "Timeout"} recovery check for ${unitType} ${unitId}: ${diagnostic}`, "warning");
|
|
107
|
+
return "paused";
|
|
108
|
+
}
|
|
109
|
+
const expected = diagnoseExpectedArtifact(unitType, unitId, basePath) ?? "required durable artifact";
|
|
110
|
+
// Check if the artifact already exists on disk — agent may have written it
|
|
111
|
+
// without signaling completion.
|
|
112
|
+
const artifactPath = resolveExpectedArtifactPath(unitType, unitId, basePath);
|
|
113
|
+
if (artifactPath && existsSync(artifactPath)) {
|
|
114
|
+
writeUnitRuntimeRecord(basePath, unitType, unitId, currentUnitStartedAt, {
|
|
115
|
+
phase: "finalized",
|
|
116
|
+
recoveryAttempts: recoveryAttempts + 1,
|
|
117
|
+
lastRecoveryReason: reason,
|
|
118
|
+
});
|
|
119
|
+
ctx.ui.notify(`${reason === "idle" ? "Idle" : "Timeout"} recovery: ${unitType} ${unitId} artifact already exists on disk. Advancing. (attempt ${attemptNumber})`, "info");
|
|
120
|
+
unitRecoveryCount.delete(recoveryKey);
|
|
121
|
+
await dispatchNextUnit(ctx, pi);
|
|
122
|
+
return "recovered";
|
|
123
|
+
}
|
|
124
|
+
if (recoveryAttempts < maxRecoveryAttempts) {
|
|
125
|
+
const isEscalation = recoveryAttempts > 0;
|
|
126
|
+
writeUnitRuntimeRecord(basePath, unitType, unitId, currentUnitStartedAt, {
|
|
127
|
+
phase: "recovered",
|
|
128
|
+
recoveryAttempts: recoveryAttempts + 1,
|
|
129
|
+
lastRecoveryReason: reason,
|
|
130
|
+
lastProgressAt: Date.now(),
|
|
131
|
+
progressCount: (runtime?.progressCount ?? 0) + 1,
|
|
132
|
+
lastProgressKind: reason === "idle" ? "idle-recovery-retry" : "hard-recovery-retry",
|
|
133
|
+
});
|
|
134
|
+
const steeringLines = isEscalation
|
|
135
|
+
? [
|
|
136
|
+
`**FINAL ${reason === "idle" ? "IDLE" : "HARD TIMEOUT"} RECOVERY — last chance before skip.**`,
|
|
137
|
+
`You are still executing ${unitType} ${unitId}.`,
|
|
138
|
+
`Recovery attempt ${recoveryAttempts + 1} of ${maxRecoveryAttempts} — next failure skips this unit.`,
|
|
139
|
+
`Expected durable output: ${expected}.`,
|
|
140
|
+
"You MUST write the artifact file NOW, even if incomplete.",
|
|
141
|
+
"Write whatever you have — partial research, preliminary findings, best-effort analysis.",
|
|
142
|
+
"A partial artifact is infinitely better than no artifact.",
|
|
143
|
+
"If you are truly blocked, write the file with a BLOCKER section explaining why.",
|
|
144
|
+
]
|
|
145
|
+
: [
|
|
146
|
+
`**${reason === "idle" ? "IDLE" : "HARD TIMEOUT"} RECOVERY — stay in auto-mode.**`,
|
|
147
|
+
`You are still executing ${unitType} ${unitId}.`,
|
|
148
|
+
`Recovery attempt ${recoveryAttempts + 1} of ${maxRecoveryAttempts}.`,
|
|
149
|
+
`Expected durable output: ${expected}.`,
|
|
150
|
+
"Stop broad exploration.",
|
|
151
|
+
"Write the required artifact now.",
|
|
152
|
+
"If blocked, write the partial artifact and explicitly record the blocker instead of going silent.",
|
|
153
|
+
];
|
|
154
|
+
pi.sendMessage({
|
|
155
|
+
customType: "gsd-auto-timeout-recovery",
|
|
156
|
+
display: verbose,
|
|
157
|
+
content: steeringLines.join("\n"),
|
|
158
|
+
}, { triggerTurn: true, deliverAs: "steer" });
|
|
159
|
+
ctx.ui.notify(`${reason === "idle" ? "Idle" : "Timeout"} recovery: steering ${unitType} ${unitId} to produce ${expected} (attempt ${attemptNumber}, session ${recoveryAttempts + 1}/${maxRecoveryAttempts}).`, "warning");
|
|
160
|
+
return "recovered";
|
|
161
|
+
}
|
|
162
|
+
// Retries exhausted — write a blocker placeholder and advance the pipeline
|
|
163
|
+
// instead of silently stalling.
|
|
164
|
+
const placeholder = writeBlockerPlaceholder(unitType, unitId, basePath, `${reason} recovery exhausted ${maxRecoveryAttempts} attempts without producing the artifact.`);
|
|
165
|
+
if (placeholder) {
|
|
166
|
+
writeUnitRuntimeRecord(basePath, unitType, unitId, currentUnitStartedAt, {
|
|
167
|
+
phase: "skipped",
|
|
168
|
+
recoveryAttempts: recoveryAttempts + 1,
|
|
169
|
+
lastRecoveryReason: reason,
|
|
170
|
+
});
|
|
171
|
+
ctx.ui.notify(`${unitType} ${unitId} skipped after ${maxRecoveryAttempts} recovery attempts. Blocker placeholder written to ${placeholder}. Advancing pipeline. (attempt ${attemptNumber})`, "warning");
|
|
172
|
+
unitRecoveryCount.delete(recoveryKey);
|
|
173
|
+
await dispatchNextUnit(ctx, pi);
|
|
174
|
+
return "recovered";
|
|
175
|
+
}
|
|
176
|
+
// Fallback: couldn't resolve artifact path — pause as before.
|
|
177
|
+
writeUnitRuntimeRecord(basePath, unitType, unitId, currentUnitStartedAt, {
|
|
178
|
+
phase: "paused",
|
|
179
|
+
recoveryAttempts: recoveryAttempts + 1,
|
|
180
|
+
lastRecoveryReason: reason,
|
|
181
|
+
});
|
|
182
|
+
return "paused";
|
|
183
|
+
}
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unit supervision timers — soft timeout warning, idle watchdog,
|
|
3
|
+
* hard timeout, and context-pressure monitor.
|
|
4
|
+
*
|
|
5
|
+
* Extracted from dispatchNextUnit() in auto.ts. All timers are set up
|
|
6
|
+
* via startUnitSupervision() and torn down by the caller via clearUnitTimeout().
|
|
7
|
+
*/
|
|
8
|
+
import { readUnitRuntimeRecord, writeUnitRuntimeRecord } from "./unit-runtime.js";
|
|
9
|
+
import { resolveAutoSupervisorConfig } from "./preferences.js";
|
|
10
|
+
import { computeBudgets, resolveExecutorContextWindow } from "./context-budget.js";
|
|
11
|
+
import { getInFlightToolCount, getOldestInFlightToolStart, } from "./auto-tool-tracking.js";
|
|
12
|
+
import { detectWorkingTreeActivity } from "./auto-supervisor.js";
|
|
13
|
+
import { closeoutUnit } from "./auto-unit-closeout.js";
|
|
14
|
+
import { saveActivityLog } from "./activity-log.js";
|
|
15
|
+
import { recoverTimedOutUnit } from "./auto-timeout-recovery.js";
|
|
16
|
+
import { getErrorMessage } from "./error-utils.js";
|
|
17
|
+
/**
|
|
18
|
+
* Set up all four supervision timers for the current unit:
|
|
19
|
+
* 1. Soft timeout warning (wrapup)
|
|
20
|
+
* 2. Idle watchdog (progress polling, stuck tool detection)
|
|
21
|
+
* 3. Hard timeout (pause + recovery)
|
|
22
|
+
* 4. Context-pressure monitor (continue-here)
|
|
23
|
+
*/
|
|
24
|
+
export function startUnitSupervision(sctx) {
|
|
25
|
+
const { s, ctx, pi, unitType, unitId, prefs, buildSnapshotOpts, buildRecoveryContext, pauseAuto } = sctx;
|
|
26
|
+
const supervisor = resolveAutoSupervisorConfig();
|
|
27
|
+
const softTimeoutMs = (supervisor.soft_timeout_minutes ?? 0) * 60 * 1000;
|
|
28
|
+
const idleTimeoutMs = (supervisor.idle_timeout_minutes ?? 0) * 60 * 1000;
|
|
29
|
+
const hardTimeoutMs = (supervisor.hard_timeout_minutes ?? 0) * 60 * 1000;
|
|
30
|
+
// ── 1. Soft timeout warning ──
|
|
31
|
+
s.wrapupWarningHandle = setTimeout(() => {
|
|
32
|
+
s.wrapupWarningHandle = null;
|
|
33
|
+
if (!s.active || !s.currentUnit)
|
|
34
|
+
return;
|
|
35
|
+
writeUnitRuntimeRecord(s.basePath, unitType, unitId, s.currentUnit.startedAt, {
|
|
36
|
+
phase: "wrapup-warning-sent",
|
|
37
|
+
wrapupWarningSent: true,
|
|
38
|
+
});
|
|
39
|
+
pi.sendMessage({
|
|
40
|
+
customType: "gsd-auto-wrapup",
|
|
41
|
+
display: s.verbose,
|
|
42
|
+
content: [
|
|
43
|
+
"**TIME BUDGET WARNING — keep going only if progress is real.**",
|
|
44
|
+
"This unit crossed the soft time budget.",
|
|
45
|
+
"If you are making progress, continue. If not, switch to wrap-up mode now:",
|
|
46
|
+
"1. rerun the minimal required verification",
|
|
47
|
+
"2. write or update the required durable artifacts",
|
|
48
|
+
"3. mark task or slice state on disk correctly",
|
|
49
|
+
"4. leave precise resume notes if anything remains unfinished",
|
|
50
|
+
].join("\n"),
|
|
51
|
+
}, { triggerTurn: true });
|
|
52
|
+
}, softTimeoutMs);
|
|
53
|
+
// ── 2. Idle watchdog ──
|
|
54
|
+
s.idleWatchdogHandle = setInterval(async () => {
|
|
55
|
+
try {
|
|
56
|
+
if (!s.active || !s.currentUnit)
|
|
57
|
+
return;
|
|
58
|
+
const runtime = readUnitRuntimeRecord(s.basePath, unitType, unitId);
|
|
59
|
+
if (!runtime)
|
|
60
|
+
return;
|
|
61
|
+
if (Date.now() - runtime.lastProgressAt < idleTimeoutMs)
|
|
62
|
+
return;
|
|
63
|
+
// Agent has tool calls currently executing — not idle, just waiting.
|
|
64
|
+
// But only suppress recovery if the tool started recently.
|
|
65
|
+
if (getInFlightToolCount() > 0) {
|
|
66
|
+
const oldestStart = getOldestInFlightToolStart();
|
|
67
|
+
const toolAgeMs = Date.now() - oldestStart;
|
|
68
|
+
if (toolAgeMs < idleTimeoutMs) {
|
|
69
|
+
writeUnitRuntimeRecord(s.basePath, unitType, unitId, s.currentUnit.startedAt, {
|
|
70
|
+
lastProgressAt: Date.now(),
|
|
71
|
+
lastProgressKind: "tool-in-flight",
|
|
72
|
+
});
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
ctx.ui.notify(`Stalled tool detected: a tool has been in-flight for ${Math.round(toolAgeMs / 60000)}min. Treating as hung — attempting idle recovery.`, "warning");
|
|
76
|
+
}
|
|
77
|
+
// Check if the agent is producing work on disk.
|
|
78
|
+
if (detectWorkingTreeActivity(s.basePath)) {
|
|
79
|
+
writeUnitRuntimeRecord(s.basePath, unitType, unitId, s.currentUnit.startedAt, {
|
|
80
|
+
lastProgressAt: Date.now(),
|
|
81
|
+
lastProgressKind: "filesystem-activity",
|
|
82
|
+
});
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
if (s.currentUnit) {
|
|
86
|
+
await closeoutUnit(ctx, s.basePath, s.currentUnit.type, s.currentUnit.id, s.currentUnit.startedAt, buildSnapshotOpts());
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
saveActivityLog(ctx, s.basePath, unitType, unitId);
|
|
90
|
+
}
|
|
91
|
+
const recovery = await recoverTimedOutUnit(ctx, pi, unitType, unitId, "idle", buildRecoveryContext());
|
|
92
|
+
if (recovery === "recovered")
|
|
93
|
+
return;
|
|
94
|
+
writeUnitRuntimeRecord(s.basePath, unitType, unitId, s.currentUnit.startedAt, {
|
|
95
|
+
phase: "paused",
|
|
96
|
+
});
|
|
97
|
+
ctx.ui.notify(`Unit ${unitType} ${unitId} made no meaningful progress for ${supervisor.idle_timeout_minutes}min. Pausing auto-mode.`, "warning");
|
|
98
|
+
await pauseAuto(ctx, pi);
|
|
99
|
+
}
|
|
100
|
+
catch (err) {
|
|
101
|
+
const message = getErrorMessage(err);
|
|
102
|
+
console.error(`[idle-watchdog] Unhandled error: ${message}`);
|
|
103
|
+
try {
|
|
104
|
+
ctx.ui.notify(`Idle watchdog error: ${message}`, "warning");
|
|
105
|
+
}
|
|
106
|
+
catch { /* best effort */ }
|
|
107
|
+
}
|
|
108
|
+
}, 15000);
|
|
109
|
+
// ── 3. Hard timeout ──
|
|
110
|
+
s.unitTimeoutHandle = setTimeout(async () => {
|
|
111
|
+
try {
|
|
112
|
+
s.unitTimeoutHandle = null;
|
|
113
|
+
if (!s.active)
|
|
114
|
+
return;
|
|
115
|
+
if (s.currentUnit) {
|
|
116
|
+
writeUnitRuntimeRecord(s.basePath, unitType, unitId, s.currentUnit.startedAt, {
|
|
117
|
+
phase: "timeout",
|
|
118
|
+
timeoutAt: Date.now(),
|
|
119
|
+
});
|
|
120
|
+
await closeoutUnit(ctx, s.basePath, s.currentUnit.type, s.currentUnit.id, s.currentUnit.startedAt, buildSnapshotOpts());
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
saveActivityLog(ctx, s.basePath, unitType, unitId);
|
|
124
|
+
}
|
|
125
|
+
const recovery = await recoverTimedOutUnit(ctx, pi, unitType, unitId, "hard", buildRecoveryContext());
|
|
126
|
+
if (recovery === "recovered")
|
|
127
|
+
return;
|
|
128
|
+
ctx.ui.notify(`Unit ${unitType} ${unitId} exceeded ${supervisor.hard_timeout_minutes}min hard timeout. Pausing auto-mode.`, "warning");
|
|
129
|
+
await pauseAuto(ctx, pi);
|
|
130
|
+
}
|
|
131
|
+
catch (err) {
|
|
132
|
+
const message = getErrorMessage(err);
|
|
133
|
+
console.error(`[hard-timeout] Unhandled error: ${message}`);
|
|
134
|
+
try {
|
|
135
|
+
ctx.ui.notify(`Hard timeout error: ${message}`, "warning");
|
|
136
|
+
}
|
|
137
|
+
catch { /* best effort */ }
|
|
138
|
+
}
|
|
139
|
+
}, hardTimeoutMs);
|
|
140
|
+
// ── 4. Context-pressure continue-here monitor ──
|
|
141
|
+
if (s.continueHereHandle) {
|
|
142
|
+
clearInterval(s.continueHereHandle);
|
|
143
|
+
s.continueHereHandle = null;
|
|
144
|
+
}
|
|
145
|
+
const executorContextWindow = resolveExecutorContextWindow(ctx.modelRegistry, prefs, ctx.model?.contextWindow);
|
|
146
|
+
const continueHereThreshold = computeBudgets(executorContextWindow).continueThresholdPercent;
|
|
147
|
+
s.continueHereHandle = setInterval(() => {
|
|
148
|
+
if (!s.active || !s.currentUnit || !s.cmdCtx)
|
|
149
|
+
return;
|
|
150
|
+
const runtime = readUnitRuntimeRecord(s.basePath, unitType, unitId);
|
|
151
|
+
if (runtime?.continueHereFired)
|
|
152
|
+
return;
|
|
153
|
+
const contextUsage = s.cmdCtx.getContextUsage();
|
|
154
|
+
if (!contextUsage || contextUsage.percent == null || contextUsage.percent < continueHereThreshold)
|
|
155
|
+
return;
|
|
156
|
+
writeUnitRuntimeRecord(s.basePath, unitType, unitId, s.currentUnit.startedAt, {
|
|
157
|
+
continueHereFired: true,
|
|
158
|
+
});
|
|
159
|
+
if (s.verbose) {
|
|
160
|
+
ctx.ui.notify(`Context at ${contextUsage.percent}% (threshold: ${continueHereThreshold}%) — sending wrap-up signal.`, "info");
|
|
161
|
+
}
|
|
162
|
+
pi.sendMessage({
|
|
163
|
+
customType: "gsd-auto-wrapup",
|
|
164
|
+
display: s.verbose,
|
|
165
|
+
content: [
|
|
166
|
+
"**CONTEXT BUDGET WARNING — wrap up this unit now.**",
|
|
167
|
+
`Context window is at ${contextUsage.percent}% (threshold: ${continueHereThreshold}%).`,
|
|
168
|
+
"The next unit needs a fresh context to work effectively. Wrap up now:",
|
|
169
|
+
"1. Finish any in-progress file writes",
|
|
170
|
+
"2. Write or update the required durable artifacts (summary, checkboxes)",
|
|
171
|
+
"3. Mark task state on disk correctly",
|
|
172
|
+
"4. Leave precise resume notes if anything remains unfinished",
|
|
173
|
+
"Do NOT start new sub-tasks or investigations.",
|
|
174
|
+
].join("\n"),
|
|
175
|
+
}, { triggerTurn: true });
|
|
176
|
+
if (s.continueHereHandle) {
|
|
177
|
+
clearInterval(s.continueHereHandle);
|
|
178
|
+
s.continueHereHandle = null;
|
|
179
|
+
}
|
|
180
|
+
}, 15_000);
|
|
181
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* In-flight tool call tracking for auto-mode idle detection.
|
|
3
|
+
* Tracks which tool calls are currently executing so the idle watchdog
|
|
4
|
+
* can distinguish "waiting for tool completion" from "truly idle".
|
|
5
|
+
*/
|
|
6
|
+
const inFlightTools = new Map();
|
|
7
|
+
/**
|
|
8
|
+
* Mark a tool execution as in-flight.
|
|
9
|
+
* Records start time so the idle watchdog can detect tools hung longer than the idle timeout.
|
|
10
|
+
*/
|
|
11
|
+
export function markToolStart(toolCallId, isActive) {
|
|
12
|
+
if (!isActive)
|
|
13
|
+
return;
|
|
14
|
+
inFlightTools.set(toolCallId, Date.now());
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Mark a tool execution as completed.
|
|
18
|
+
*/
|
|
19
|
+
export function markToolEnd(toolCallId) {
|
|
20
|
+
inFlightTools.delete(toolCallId);
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Returns the age (ms) of the oldest currently in-flight tool, or 0 if none.
|
|
24
|
+
*/
|
|
25
|
+
export function getOldestInFlightToolAgeMs() {
|
|
26
|
+
if (inFlightTools.size === 0)
|
|
27
|
+
return 0;
|
|
28
|
+
const oldestStart = Math.min(...inFlightTools.values());
|
|
29
|
+
return Date.now() - oldestStart;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Returns the number of currently in-flight tools.
|
|
33
|
+
*/
|
|
34
|
+
export function getInFlightToolCount() {
|
|
35
|
+
return inFlightTools.size;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Returns the start timestamp of the oldest in-flight tool, or undefined if none.
|
|
39
|
+
*/
|
|
40
|
+
export function getOldestInFlightToolStart() {
|
|
41
|
+
if (inFlightTools.size === 0)
|
|
42
|
+
return undefined;
|
|
43
|
+
return Math.min(...inFlightTools.values());
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Clear all in-flight tool tracking state.
|
|
47
|
+
*/
|
|
48
|
+
export function clearInFlightTools() {
|
|
49
|
+
inFlightTools.clear();
|
|
50
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unit closeout helper — consolidates the repeated pattern of
|
|
3
|
+
* snapshotting metrics + saving activity log + extracting memories
|
|
4
|
+
* that appears 6+ times in auto.ts.
|
|
5
|
+
*/
|
|
6
|
+
import { snapshotUnitMetrics } from "./metrics.js";
|
|
7
|
+
import { saveActivityLog } from "./activity-log.js";
|
|
8
|
+
/**
|
|
9
|
+
* Snapshot metrics, save activity log, and fire-and-forget memory extraction
|
|
10
|
+
* for a completed unit. Returns the activity log file path (if any).
|
|
11
|
+
*/
|
|
12
|
+
export async function closeoutUnit(ctx, basePath, unitType, unitId, startedAt, opts) {
|
|
13
|
+
const modelId = ctx.model?.id ?? "unknown";
|
|
14
|
+
snapshotUnitMetrics(ctx, unitType, unitId, startedAt, modelId, opts);
|
|
15
|
+
const activityFile = saveActivityLog(ctx, basePath, unitType, unitId);
|
|
16
|
+
if (activityFile) {
|
|
17
|
+
try {
|
|
18
|
+
const { buildMemoryLLMCall, extractMemoriesFromUnit } = await import('./memory-extractor.js');
|
|
19
|
+
const llmCallFn = buildMemoryLLMCall(ctx);
|
|
20
|
+
if (llmCallFn) {
|
|
21
|
+
extractMemoriesFromUnit(activityFile, unitType, unitId, llmCallFn).catch((err) => {
|
|
22
|
+
if (process.env.GSD_DEBUG)
|
|
23
|
+
console.error(`[gsd] memory extraction failed for ${unitType}/${unitId}:`, err);
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
catch { /* non-fatal */ }
|
|
28
|
+
}
|
|
29
|
+
return activityFile ?? undefined;
|
|
30
|
+
}
|
|
@@ -0,0 +1,209 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Post-unit verification gate for auto-mode.
|
|
3
|
+
*
|
|
4
|
+
* Runs typecheck/lint/test checks, captures runtime errors, performs
|
|
5
|
+
* dependency audits, handles auto-fix retry logic, and writes
|
|
6
|
+
* verification evidence JSON.
|
|
7
|
+
*
|
|
8
|
+
* Extracted from handleAgentEnd() in auto.ts. Returns a sentinel
|
|
9
|
+
* value instead of calling return/pauseAuto directly — the caller
|
|
10
|
+
* checks the result and handles control flow.
|
|
11
|
+
*/
|
|
12
|
+
import { loadFile, parsePlan } from "./files.js";
|
|
13
|
+
import { resolveSliceFile, resolveSlicePath } from "./paths.js";
|
|
14
|
+
import { loadEffectiveGSDPreferences } from "./preferences.js";
|
|
15
|
+
import { runVerificationGate, formatFailureContext, captureRuntimeErrors, runDependencyAudit, } from "./verification-gate.js";
|
|
16
|
+
import { writeVerificationJSON } from "./verification-evidence.js";
|
|
17
|
+
import { removePersistedKey } from "./auto-recovery.js";
|
|
18
|
+
import { join } from "node:path";
|
|
19
|
+
import { getErrorMessage } from "./error-utils.js";
|
|
20
|
+
import { parseUnitId } from "./unit-id.js";
|
|
21
|
+
/**
|
|
22
|
+
* Run the verification gate for the current execute-task unit.
|
|
23
|
+
* Returns:
|
|
24
|
+
* - "continue" — gate passed (or no checks configured), proceed normally
|
|
25
|
+
* - "retry" — gate failed with retries remaining, dispatchNextUnit already called
|
|
26
|
+
* - "pause" — gate failed with retries exhausted, pauseAuto already called
|
|
27
|
+
*/
|
|
28
|
+
export async function runPostUnitVerification(vctx, dispatchNextUnit, startDispatchGapWatchdog, pauseAuto) {
|
|
29
|
+
const { s, ctx, pi } = vctx;
|
|
30
|
+
if (!s.currentUnit || s.currentUnit.type !== "execute-task") {
|
|
31
|
+
return "continue";
|
|
32
|
+
}
|
|
33
|
+
try {
|
|
34
|
+
const effectivePrefs = loadEffectiveGSDPreferences();
|
|
35
|
+
const prefs = effectivePrefs?.preferences;
|
|
36
|
+
// Read task plan verify field
|
|
37
|
+
const { milestone: mid, slice: sid, task: tid } = parseUnitId(s.currentUnit.id);
|
|
38
|
+
let taskPlanVerify;
|
|
39
|
+
if (mid && sid && tid) {
|
|
40
|
+
const planFile = resolveSliceFile(s.basePath, mid, sid, "PLAN");
|
|
41
|
+
if (planFile) {
|
|
42
|
+
const planContent = await loadFile(planFile);
|
|
43
|
+
if (planContent) {
|
|
44
|
+
const slicePlan = parsePlan(planContent);
|
|
45
|
+
const taskEntry = slicePlan?.tasks?.find(t => t.id === tid);
|
|
46
|
+
taskPlanVerify = taskEntry?.verify;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
const result = runVerificationGate({
|
|
51
|
+
basePath: s.basePath,
|
|
52
|
+
unitId: s.currentUnit.id,
|
|
53
|
+
cwd: s.basePath,
|
|
54
|
+
preferenceCommands: prefs?.verification_commands,
|
|
55
|
+
taskPlanVerify,
|
|
56
|
+
});
|
|
57
|
+
// Capture runtime errors
|
|
58
|
+
const runtimeErrors = await captureRuntimeErrors();
|
|
59
|
+
if (runtimeErrors.length > 0) {
|
|
60
|
+
result.runtimeErrors = runtimeErrors;
|
|
61
|
+
if (runtimeErrors.some(e => e.blocking)) {
|
|
62
|
+
result.passed = false;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
// Dependency audit
|
|
66
|
+
const auditWarnings = runDependencyAudit(s.basePath);
|
|
67
|
+
if (auditWarnings.length > 0) {
|
|
68
|
+
result.auditWarnings = auditWarnings;
|
|
69
|
+
process.stderr.write(`verification-gate: ${auditWarnings.length} audit warning(s)\n`);
|
|
70
|
+
for (const w of auditWarnings) {
|
|
71
|
+
process.stderr.write(` [${w.severity}] ${w.name}: ${w.title}\n`);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
// Auto-fix retry preferences
|
|
75
|
+
const autoFixEnabled = prefs?.verification_auto_fix !== false;
|
|
76
|
+
const maxRetries = typeof prefs?.verification_max_retries === "number" ? prefs.verification_max_retries : 2;
|
|
77
|
+
const completionKey = `${s.currentUnit.type}/${s.currentUnit.id}`;
|
|
78
|
+
if (result.checks.length > 0) {
|
|
79
|
+
const blockingChecks = result.checks.filter(c => c.blocking);
|
|
80
|
+
const advisoryChecks = result.checks.filter(c => !c.blocking);
|
|
81
|
+
const blockingPassCount = blockingChecks.filter(c => c.exitCode === 0).length;
|
|
82
|
+
const advisoryFailCount = advisoryChecks.filter(c => c.exitCode !== 0).length;
|
|
83
|
+
if (result.passed) {
|
|
84
|
+
let msg = blockingChecks.length > 0
|
|
85
|
+
? `Verification gate: ${blockingPassCount}/${blockingChecks.length} blocking checks passed`
|
|
86
|
+
: `Verification gate: passed (no blocking checks)`;
|
|
87
|
+
if (advisoryFailCount > 0) {
|
|
88
|
+
msg += ` (${advisoryFailCount} advisory warning${advisoryFailCount > 1 ? "s" : ""})`;
|
|
89
|
+
}
|
|
90
|
+
ctx.ui.notify(msg);
|
|
91
|
+
// Log advisory warnings to stderr for visibility
|
|
92
|
+
if (advisoryFailCount > 0) {
|
|
93
|
+
const advisoryFailures = advisoryChecks.filter(c => c.exitCode !== 0);
|
|
94
|
+
process.stderr.write(`verification-gate: ${advisoryFailCount} advisory (non-blocking) failure(s)\n`);
|
|
95
|
+
for (const f of advisoryFailures) {
|
|
96
|
+
process.stderr.write(` [advisory] ${f.command} exited ${f.exitCode}\n`);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
const blockingFailures = blockingChecks.filter(c => c.exitCode !== 0);
|
|
102
|
+
const failNames = blockingFailures.map(f => f.command).join(", ");
|
|
103
|
+
ctx.ui.notify(`Verification gate: FAILED — ${failNames}`);
|
|
104
|
+
process.stderr.write(`verification-gate: ${blockingFailures.length}/${blockingChecks.length} blocking checks failed\n`);
|
|
105
|
+
for (const f of blockingFailures) {
|
|
106
|
+
process.stderr.write(` ${f.command} exited ${f.exitCode}\n`);
|
|
107
|
+
if (f.stderr)
|
|
108
|
+
process.stderr.write(` stderr: ${f.stderr.slice(0, 500)}\n`);
|
|
109
|
+
}
|
|
110
|
+
if (advisoryFailCount > 0) {
|
|
111
|
+
process.stderr.write(`verification-gate: ${advisoryFailCount} additional advisory (non-blocking) failure(s)\n`);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
// Log blocking runtime errors
|
|
116
|
+
if (result.runtimeErrors?.some(e => e.blocking)) {
|
|
117
|
+
const blockingErrors = result.runtimeErrors.filter(e => e.blocking);
|
|
118
|
+
process.stderr.write(`verification-gate: ${blockingErrors.length} blocking runtime error(s) detected\n`);
|
|
119
|
+
for (const err of blockingErrors) {
|
|
120
|
+
process.stderr.write(` [${err.source}] ${err.severity}: ${err.message.slice(0, 200)}\n`);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
// Write verification evidence JSON
|
|
124
|
+
const attempt = s.verificationRetryCount.get(s.currentUnit.id) ?? 0;
|
|
125
|
+
if (mid && sid && tid) {
|
|
126
|
+
try {
|
|
127
|
+
const sDir = resolveSlicePath(s.basePath, mid, sid);
|
|
128
|
+
if (sDir) {
|
|
129
|
+
const tasksDir = join(sDir, "tasks");
|
|
130
|
+
if (result.passed) {
|
|
131
|
+
writeVerificationJSON(result, tasksDir, tid, s.currentUnit.id);
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
const nextAttempt = attempt + 1;
|
|
135
|
+
writeVerificationJSON(result, tasksDir, tid, s.currentUnit.id, nextAttempt, maxRetries);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
catch (evidenceErr) {
|
|
140
|
+
process.stderr.write(`verification-evidence: write error — ${evidenceErr.message}\n`);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
// ── Auto-fix retry logic ──
|
|
144
|
+
if (result.passed) {
|
|
145
|
+
s.verificationRetryCount.delete(s.currentUnit.id);
|
|
146
|
+
s.pendingVerificationRetry = null;
|
|
147
|
+
return "continue";
|
|
148
|
+
}
|
|
149
|
+
// Check if all failures are infra errors (ETIMEDOUT, ENOENT, etc.).
|
|
150
|
+
// Infra errors are transient OS-level problems the agent cannot fix —
|
|
151
|
+
// retrying the entire task is wasteful and creates phantom failures.
|
|
152
|
+
const failedChecks = result.checks.filter(c => c.exitCode !== 0);
|
|
153
|
+
const allInfraErrors = failedChecks.length > 0 && failedChecks.every(c => c.infraError === true);
|
|
154
|
+
if (allInfraErrors) {
|
|
155
|
+
const infraNames = failedChecks.map(f => f.command).join(", ");
|
|
156
|
+
ctx.ui.notify(`Verification gate: infra error (${infraNames}) — skipping retry, not a code issue`, "warning");
|
|
157
|
+
process.stderr.write(`verification-gate: all ${failedChecks.length} failure(s) are infra errors — treating as transient, no retry\n`);
|
|
158
|
+
s.verificationRetryCount.delete(s.currentUnit.id);
|
|
159
|
+
s.pendingVerificationRetry = null;
|
|
160
|
+
return "continue";
|
|
161
|
+
}
|
|
162
|
+
if (result.discoverySource === "package-json") {
|
|
163
|
+
// Auto-discovered checks from package.json may fail on pre-existing errors
|
|
164
|
+
// that the current task didn't introduce. Don't trigger the retry loop —
|
|
165
|
+
// log a warning and let the task proceed (#1186).
|
|
166
|
+
process.stderr.write(`verification-gate: auto-discovered checks failed (source: package-json) — treating as advisory, not blocking\n`);
|
|
167
|
+
ctx.ui.notify(`Verification: auto-discovered checks failed (pre-existing errors likely). Continuing without retry.`, "warning");
|
|
168
|
+
s.verificationRetryCount.delete(s.currentUnit.id);
|
|
169
|
+
s.pendingVerificationRetry = null;
|
|
170
|
+
return "continue";
|
|
171
|
+
}
|
|
172
|
+
if (autoFixEnabled && attempt + 1 <= maxRetries) {
|
|
173
|
+
const nextAttempt = attempt + 1;
|
|
174
|
+
s.verificationRetryCount.set(s.currentUnit.id, nextAttempt);
|
|
175
|
+
s.pendingVerificationRetry = {
|
|
176
|
+
unitId: s.currentUnit.id,
|
|
177
|
+
failureContext: formatFailureContext(result),
|
|
178
|
+
attempt: nextAttempt,
|
|
179
|
+
};
|
|
180
|
+
ctx.ui.notify(`Verification failed — auto-fix attempt ${nextAttempt}/${maxRetries}`, "warning");
|
|
181
|
+
s.completedKeySet.delete(completionKey);
|
|
182
|
+
removePersistedKey(s.basePath, completionKey);
|
|
183
|
+
// Dispatch retry immediately
|
|
184
|
+
try {
|
|
185
|
+
await dispatchNextUnit(ctx, pi);
|
|
186
|
+
}
|
|
187
|
+
catch (retryDispatchErr) {
|
|
188
|
+
const msg = getErrorMessage(retryDispatchErr);
|
|
189
|
+
ctx.ui.notify(`Verification retry dispatch error: ${msg}`, "error");
|
|
190
|
+
startDispatchGapWatchdog(ctx, pi);
|
|
191
|
+
}
|
|
192
|
+
return "retry";
|
|
193
|
+
}
|
|
194
|
+
else {
|
|
195
|
+
// Gate failed, retries exhausted
|
|
196
|
+
const exhaustedAttempt = attempt + 1;
|
|
197
|
+
s.verificationRetryCount.delete(s.currentUnit.id);
|
|
198
|
+
s.pendingVerificationRetry = null;
|
|
199
|
+
ctx.ui.notify(`Verification gate FAILED after ${exhaustedAttempt > maxRetries ? exhaustedAttempt - 1 : exhaustedAttempt} retries — pausing for human review`, "error");
|
|
200
|
+
await pauseAuto(ctx, pi);
|
|
201
|
+
return "pause";
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
catch (err) {
|
|
205
|
+
// Gate errors are non-fatal
|
|
206
|
+
process.stderr.write(`verification-gate: error — ${err.message}\n`);
|
|
207
|
+
return "continue";
|
|
208
|
+
}
|
|
209
|
+
}
|