gsd-pi 2.33.1 → 2.34.0-dev.6769913
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bundled-resource-path.d.ts +8 -0
- package/dist/bundled-resource-path.js +14 -0
- package/dist/cli.js +16 -0
- package/dist/headless-query.js +6 -6
- package/dist/resource-loader.d.ts +2 -0
- package/dist/resource-loader.js +39 -4
- 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 +182 -0
- package/dist/resources/extensions/gsd/auto-budget.js +30 -0
- package/dist/resources/extensions/gsd/auto-dashboard.js +429 -0
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +185 -0
- package/dist/resources/extensions/gsd/auto-dispatch.js +353 -0
- package/dist/resources/extensions/gsd/auto-loop.js +956 -0
- package/dist/resources/extensions/gsd/auto-model-selection.js +133 -0
- package/dist/resources/extensions/gsd/auto-observability.js +56 -0
- package/dist/resources/extensions/gsd/auto-post-unit.js +385 -0
- package/dist/resources/extensions/gsd/auto-prompts.js +1153 -0
- package/dist/resources/extensions/gsd/auto-recovery.js +512 -0
- package/dist/resources/extensions/gsd/auto-start.js +414 -0
- package/dist/resources/extensions/gsd/auto-supervisor.js +47 -0
- package/dist/resources/extensions/gsd/auto-timeout-recovery.js +183 -0
- package/dist/resources/extensions/gsd/auto-timers.js +180 -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 +171 -0
- package/dist/resources/extensions/gsd/auto-worktree-sync.js +167 -0
- package/dist/resources/extensions/gsd/auto-worktree.js +830 -0
- package/dist/resources/extensions/gsd/auto.js +765 -0
- package/dist/resources/extensions/gsd/{cache.ts → cache.js} +5 -7
- package/dist/resources/extensions/gsd/captures.js +354 -0
- package/dist/resources/extensions/gsd/changelog.js +162 -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 +224 -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 +1031 -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 +75 -0
- package/dist/resources/extensions/gsd/docs/preferences-reference.md +25 -18
- package/dist/resources/extensions/gsd/doctor-checks.js +562 -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 +735 -0
- package/dist/resources/extensions/gsd/guided-flow-queue.js +366 -0
- package/dist/resources/extensions/gsd/guided-flow.js +1158 -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 +1114 -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/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 +102 -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 +206 -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 +397 -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/templates/preferences.md +1 -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 +205 -0
- package/dist/resources/extensions/gsd/unit-id.js +7 -0
- package/dist/resources/extensions/gsd/unit-runtime.js +131 -0
- package/dist/resources/extensions/gsd/validate-directory.js +143 -0
- package/dist/resources/extensions/gsd/verification-evidence.js +122 -0
- package/dist/resources/extensions/gsd/verification-gate.js +514 -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 +682 -0
- package/dist/resources/extensions/gsd/worktree-manager.js +358 -0
- package/dist/resources/extensions/gsd/worktree-resolver.js +344 -0
- package/dist/resources/extensions/gsd/worktree.js +199 -0
- package/dist/resources/extensions/mac-tools/index.js +768 -0
- package/dist/resources/extensions/mcp-client/index.js +364 -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/dist/tool-bootstrap.js +59 -11
- package/dist/worktree-cli.js +7 -7
- package/package.json +1 -1
- package/packages/native/dist/native.d.ts +0 -2
- package/packages/native/dist/native.js +0 -2
- package/packages/native/src/native.ts +0 -3
- package/packages/pi-agent-core/dist/agent-loop.d.ts +14 -0
- package/packages/pi-agent-core/dist/agent-loop.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/agent-loop.js +24 -27
- package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
- package/packages/pi-agent-core/dist/agent.d.ts +1 -0
- package/packages/pi-agent-core/dist/agent.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/agent.js +11 -22
- package/packages/pi-agent-core/dist/agent.js.map +1 -1
- package/packages/pi-agent-core/dist/proxy.d.ts +1 -25
- package/packages/pi-agent-core/dist/proxy.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/proxy.js +1 -1
- package/packages/pi-agent-core/dist/proxy.js.map +1 -1
- package/packages/pi-agent-core/src/agent-loop.ts +30 -27
- package/packages/pi-agent-core/src/agent.ts +12 -23
- package/packages/pi-agent-core/src/proxy.ts +1 -1
- package/packages/pi-ai/dist/api-registry.d.ts +0 -2
- package/packages/pi-ai/dist/api-registry.d.ts.map +1 -1
- package/packages/pi-ai/dist/api-registry.js +0 -10
- package/packages/pi-ai/dist/api-registry.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.d.ts +0 -8
- package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.js +1 -1
- package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
- package/packages/pi-ai/dist/providers/github-copilot-headers.d.ts +0 -1
- package/packages/pi-ai/dist/providers/github-copilot-headers.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/github-copilot-headers.js +1 -1
- package/packages/pi-ai/dist/providers/github-copilot-headers.js.map +1 -1
- package/packages/pi-ai/dist/providers/google-gemini-cli.d.ts +1 -43
- package/packages/pi-ai/dist/providers/google-gemini-cli.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/google-gemini-cli.js +2 -2
- package/packages/pi-ai/dist/providers/google-gemini-cli.js.map +1 -1
- package/packages/pi-ai/dist/providers/google-shared.d.ts +0 -4
- package/packages/pi-ai/dist/providers/google-shared.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/google-shared.js +1 -1
- package/packages/pi-ai/dist/providers/google-shared.js.map +1 -1
- package/packages/pi-ai/dist/providers/register-builtins.d.ts +0 -1
- package/packages/pi-ai/dist/providers/register-builtins.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/register-builtins.js +1 -1
- package/packages/pi-ai/dist/providers/register-builtins.js.map +1 -1
- package/packages/pi-ai/dist/utils/event-stream.d.ts +0 -2
- package/packages/pi-ai/dist/utils/event-stream.d.ts.map +1 -1
- package/packages/pi-ai/dist/utils/event-stream.js +0 -4
- package/packages/pi-ai/dist/utils/event-stream.js.map +1 -1
- package/packages/pi-ai/dist/utils/overflow.d.ts +0 -4
- package/packages/pi-ai/dist/utils/overflow.d.ts.map +1 -1
- package/packages/pi-ai/dist/utils/overflow.js +0 -6
- package/packages/pi-ai/dist/utils/overflow.js.map +1 -1
- package/packages/pi-ai/dist/utils/validation.d.ts +0 -8
- package/packages/pi-ai/dist/utils/validation.d.ts.map +1 -1
- package/packages/pi-ai/dist/utils/validation.js +0 -14
- package/packages/pi-ai/dist/utils/validation.js.map +1 -1
- package/packages/pi-ai/src/api-registry.ts +0 -12
- package/packages/pi-ai/src/providers/anthropic.ts +1 -1
- package/packages/pi-ai/src/providers/github-copilot-headers.ts +1 -1
- package/packages/pi-ai/src/providers/google-gemini-cli.ts +2 -2
- package/packages/pi-ai/src/providers/google-shared.ts +1 -1
- package/packages/pi-ai/src/providers/register-builtins.ts +1 -1
- package/packages/pi-ai/src/utils/event-stream.ts +0 -5
- package/packages/pi-ai/src/utils/overflow.ts +1 -8
- package/packages/pi-ai/src/utils/validation.ts +0 -15
- package/packages/pi-coding-agent/dist/config.d.ts +0 -9
- package/packages/pi-coding-agent/dist/config.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/config.js +4 -8
- package/packages/pi-coding-agent/dist/config.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts +4 -0
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.js +24 -5
- package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/export-html/ansi-to-html.d.ts +0 -4
- package/packages/pi-coding-agent/dist/core/export-html/ansi-to-html.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/export-html/ansi-to-html.js +1 -1
- package/packages/pi-coding-agent/dist/core/export-html/ansi-to-html.js.map +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/core/extensions/runner.d.ts +0 -5
- package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.js +0 -13
- package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/keybindings.d.ts +0 -8
- package/packages/pi-coding-agent/dist/core/keybindings.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/keybindings.js +2 -2
- package/packages/pi-coding-agent/dist/core/keybindings.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/client.d.ts +0 -17
- package/packages/pi-coding-agent/dist/core/lsp/client.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/client.js +3 -62
- package/packages/pi-coding-agent/dist/core/lsp/client.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/config.d.ts +0 -2
- package/packages/pi-coding-agent/dist/core/lsp/config.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/config.js +0 -7
- package/packages/pi-coding-agent/dist/core/lsp/config.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/edits.d.ts +0 -5
- package/packages/pi-coding-agent/dist/core/lsp/edits.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/edits.js +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/edits.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/lspmux.d.ts +0 -1
- package/packages/pi-coding-agent/dist/core/lsp/lspmux.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/lspmux.js +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/lspmux.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/utils.d.ts +1 -6
- package/packages/pi-coding-agent/dist/core/lsp/utils.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/utils.js +1 -28
- package/packages/pi-coding-agent/dist/core/lsp/utils.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/messages.d.ts +0 -8
- package/packages/pi-coding-agent/dist/core/messages.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/messages.js +5 -5
- package/packages/pi-coding-agent/dist/core/messages.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry.d.ts +0 -3
- package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry.js +1 -3
- package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-resolver.d.ts +1 -26
- package/packages/pi-coding-agent/dist/core/model-resolver.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-resolver.js +3 -59
- package/packages/pi-coding-agent/dist/core/model-resolver.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/prompt-templates.d.ts +0 -17
- package/packages/pi-coding-agent/dist/core/prompt-templates.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/prompt-templates.js +2 -2
- package/packages/pi-coding-agent/dist/core/prompt-templates.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/session-manager.d.ts +0 -4
- package/packages/pi-coding-agent/dist/core/session-manager.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/session-manager.js +2 -4
- package/packages/pi-coding-agent/dist/core/session-manager.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +8 -12
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.js +78 -168
- package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/index.js +1 -1
- package/packages/pi-coding-agent/dist/index.js.map +1 -1
- package/packages/pi-coding-agent/dist/migrations.d.ts +0 -16
- package/packages/pi-coding-agent/dist/migrations.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/migrations.js +2 -2
- package/packages/pi-coding-agent/dist/migrations.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/session-selector-search.d.ts +0 -2
- package/packages/pi-coding-agent/dist/modes/interactive/components/session-selector-search.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/session-selector-search.js +2 -2
- package/packages/pi-coding-agent/dist/modes/interactive/components/session-selector-search.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +1 -24
- 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 +50 -512
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.d.ts +71 -0
- package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.js +514 -0
- package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts +65 -4
- 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 +6 -23
- 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 +12 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js +175 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js.map +1 -0
- package/packages/pi-coding-agent/dist/utils/changelog.d.ts +0 -4
- package/packages/pi-coding-agent/dist/utils/changelog.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/utils/changelog.js +1 -1
- package/packages/pi-coding-agent/dist/utils/changelog.js.map +1 -1
- package/packages/pi-coding-agent/dist/utils/clipboard-image.d.ts +0 -1
- package/packages/pi-coding-agent/dist/utils/clipboard-image.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/utils/clipboard-image.js +1 -1
- package/packages/pi-coding-agent/dist/utils/clipboard-image.js.map +1 -1
- package/packages/pi-coding-agent/dist/utils/photon.d.ts +0 -19
- package/packages/pi-coding-agent/dist/utils/photon.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/utils/photon.js +1 -120
- package/packages/pi-coding-agent/dist/utils/photon.js.map +1 -1
- package/packages/pi-coding-agent/dist/utils/tools-manager.d.ts +0 -1
- package/packages/pi-coding-agent/dist/utils/tools-manager.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/utils/tools-manager.js +1 -1
- package/packages/pi-coding-agent/dist/utils/tools-manager.js.map +1 -1
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/config.ts +5 -10
- package/packages/pi-coding-agent/src/core/agent-session.ts +26 -5
- package/packages/pi-coding-agent/src/core/export-html/ansi-to-html.ts +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/core/extensions/runner.ts +0 -13
- package/packages/pi-coding-agent/src/core/keybindings.ts +2 -2
- package/packages/pi-coding-agent/src/core/lsp/client.ts +3 -73
- package/packages/pi-coding-agent/src/core/lsp/config.ts +0 -11
- package/packages/pi-coding-agent/src/core/lsp/edits.ts +1 -1
- package/packages/pi-coding-agent/src/core/lsp/lspmux.ts +1 -1
- package/packages/pi-coding-agent/src/core/lsp/utils.ts +1 -33
- package/packages/pi-coding-agent/src/core/messages.ts +5 -5
- package/packages/pi-coding-agent/src/core/model-registry.ts +0 -2
- package/packages/pi-coding-agent/src/core/model-resolver.ts +3 -77
- package/packages/pi-coding-agent/src/core/prompt-templates.ts +2 -2
- package/packages/pi-coding-agent/src/core/session-manager.ts +2 -4
- package/packages/pi-coding-agent/src/core/settings-manager.ts +87 -166
- package/packages/pi-coding-agent/src/index.ts +1 -0
- package/packages/pi-coding-agent/src/migrations.ts +2 -2
- package/packages/pi-coding-agent/src/modes/interactive/components/session-selector-search.ts +2 -2
- package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +50 -561
- package/packages/pi-coding-agent/src/modes/interactive/slash-command-handlers.ts +653 -0
- package/packages/pi-coding-agent/src/modes/interactive/theme/theme.ts +7 -26
- package/packages/pi-coding-agent/src/modes/interactive/theme/themes.ts +196 -0
- package/packages/pi-coding-agent/src/utils/changelog.ts +1 -1
- package/packages/pi-coding-agent/src/utils/clipboard-image.ts +1 -1
- package/packages/pi-coding-agent/src/utils/photon.ts +0 -137
- package/packages/pi-coding-agent/src/utils/tools-manager.ts +1 -1
- package/packages/pi-tui/dist/components/editor.d.ts +0 -10
- package/packages/pi-tui/dist/components/editor.d.ts.map +1 -1
- package/packages/pi-tui/dist/components/editor.js +1 -1
- package/packages/pi-tui/dist/components/editor.js.map +1 -1
- package/packages/pi-tui/dist/overlay-layout.d.ts +55 -0
- package/packages/pi-tui/dist/overlay-layout.d.ts.map +1 -0
- package/packages/pi-tui/dist/overlay-layout.js +288 -0
- package/packages/pi-tui/dist/overlay-layout.js.map +1 -0
- package/packages/pi-tui/dist/tui.d.ts +0 -22
- package/packages/pi-tui/dist/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +6 -272
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/dist/utils.d.ts +0 -7
- package/packages/pi-tui/dist/utils.d.ts.map +1 -1
- package/packages/pi-tui/dist/utils.js +0 -44
- package/packages/pi-tui/dist/utils.js.map +1 -1
- package/packages/pi-tui/src/components/editor.ts +1 -1
- package/packages/pi-tui/src/overlay-layout.ts +372 -0
- package/packages/pi-tui/src/tui.ts +11 -312
- package/packages/pi-tui/src/utils.ts +0 -43
- package/pkg/dist/core/export-html/ansi-to-html.d.ts +0 -4
- package/pkg/dist/core/export-html/ansi-to-html.d.ts.map +1 -1
- package/pkg/dist/core/export-html/ansi-to-html.js +1 -1
- package/pkg/dist/core/export-html/ansi-to-html.js.map +1 -1
- package/pkg/dist/modes/interactive/theme/theme.d.ts +65 -4
- package/pkg/dist/modes/interactive/theme/theme.d.ts.map +1 -1
- package/pkg/dist/modes/interactive/theme/theme.js +6 -23
- package/pkg/dist/modes/interactive/theme/theme.js.map +1 -1
- package/pkg/dist/modes/interactive/theme/themes.d.ts +12 -0
- package/pkg/dist/modes/interactive/theme/themes.d.ts.map +1 -0
- package/pkg/dist/modes/interactive/theme/themes.js +175 -0
- package/pkg/dist/modes/interactive/theme/themes.js.map +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/session.ts +47 -30
- package/src/resources/extensions/gsd/auto-dashboard.ts +28 -131
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +6 -1
- package/src/resources/extensions/gsd/auto-dispatch.ts +135 -91
- package/src/resources/extensions/gsd/auto-loop.ts +1665 -0
- package/src/resources/extensions/gsd/auto-observability.ts +4 -2
- package/src/resources/extensions/gsd/auto-post-unit.ts +85 -228
- package/src/resources/extensions/gsd/auto-prompts.ts +138 -109
- package/src/resources/extensions/gsd/auto-recovery.ts +124 -118
- package/src/resources/extensions/gsd/auto-start.ts +440 -354
- package/src/resources/extensions/gsd/auto-supervisor.ts +5 -12
- package/src/resources/extensions/gsd/auto-timeout-recovery.ts +8 -8
- package/src/resources/extensions/gsd/auto-timers.ts +3 -4
- package/src/resources/extensions/gsd/auto-verification.ts +76 -72
- package/src/resources/extensions/gsd/auto-worktree-sync.ts +204 -0
- package/src/resources/extensions/gsd/auto-worktree.ts +453 -133
- package/src/resources/extensions/gsd/auto.ts +516 -1189
- package/src/resources/extensions/gsd/captures.ts +10 -4
- package/src/resources/extensions/gsd/changelog.ts +213 -0
- package/src/resources/extensions/gsd/commands-bootstrap.ts +253 -0
- package/src/resources/extensions/gsd/commands.ts +48 -32
- package/src/resources/extensions/gsd/dispatch-guard.ts +13 -9
- package/src/resources/extensions/gsd/docs/preferences-reference.md +25 -18
- package/src/resources/extensions/gsd/doctor-checks.ts +3 -4
- package/src/resources/extensions/gsd/git-service.ts +32 -12
- package/src/resources/extensions/gsd/gitignore.ts +4 -2
- package/src/resources/extensions/gsd/gsd-db.ts +375 -180
- package/src/resources/extensions/gsd/guided-flow.ts +22 -11
- package/src/resources/extensions/gsd/index.ts +76 -163
- package/src/resources/extensions/gsd/post-unit-hooks.ts +13 -13
- package/src/resources/extensions/gsd/progress-score.ts +65 -200
- package/src/resources/extensions/gsd/quick.ts +121 -76
- package/src/resources/extensions/gsd/repo-identity.ts +56 -22
- package/src/resources/extensions/gsd/session-lock.ts +17 -0
- package/src/resources/extensions/gsd/templates/preferences.md +1 -0
- package/src/resources/extensions/gsd/tests/agent-end-retry.test.ts +32 -59
- package/src/resources/extensions/gsd/tests/all-milestones-complete-merge.test.ts +75 -27
- package/src/resources/extensions/gsd/tests/auto-budget-alerts.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-lock-creation.test.ts +37 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +1458 -0
- package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +8 -162
- package/src/resources/extensions/gsd/tests/auto-secrets-gate.test.ts +2 -108
- package/src/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +1 -3
- package/src/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +0 -3
- package/src/resources/extensions/gsd/tests/auto-worktree.test.ts +58 -0
- package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +0 -55
- package/src/resources/extensions/gsd/tests/git-service.test.ts +16 -7
- package/src/resources/extensions/gsd/tests/headless-query.test.ts +22 -0
- package/src/resources/extensions/gsd/tests/milestone-transition-worktree.test.ts +8 -11
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +4 -6
- 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/run-uat.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/session-lock-regression.test.ts +64 -0
- package/src/resources/extensions/gsd/tests/sidecar-queue.test.ts +181 -0
- package/src/resources/extensions/gsd/tests/stale-worktree-cwd.test.ts +0 -3
- package/src/resources/extensions/gsd/tests/token-profile.test.ts +6 -6
- package/src/resources/extensions/gsd/tests/triage-dispatch.test.ts +6 -6
- package/src/resources/extensions/gsd/tests/undo.test.ts +6 -0
- package/src/resources/extensions/gsd/tests/verification-evidence.test.ts +24 -26
- package/src/resources/extensions/gsd/tests/verification-gate.test.ts +7 -136
- package/src/resources/extensions/gsd/tests/worktree-db-integration.test.ts +205 -0
- package/src/resources/extensions/gsd/tests/worktree-db.test.ts +442 -0
- package/src/resources/extensions/gsd/tests/worktree-e2e.test.ts +0 -3
- package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +705 -0
- package/src/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +57 -106
- package/src/resources/extensions/gsd/tests/worktree.test.ts +5 -1
- package/src/resources/extensions/gsd/tests/write-gate.test.ts +43 -132
- package/src/resources/extensions/gsd/types.ts +90 -77
- package/src/resources/extensions/gsd/undo.ts +42 -46
- package/src/resources/extensions/gsd/unit-runtime.ts +14 -18
- package/src/resources/extensions/gsd/verification-evidence.ts +0 -2
- package/src/resources/extensions/gsd/verification-gate.ts +4 -16
- package/src/resources/extensions/gsd/worktree-command-bootstrap.ts +46 -0
- package/src/resources/extensions/gsd/worktree-command.ts +29 -11
- package/src/resources/extensions/gsd/worktree-manager.ts +2 -3
- package/src/resources/extensions/gsd/worktree-resolver.ts +485 -0
- package/src/resources/extensions/gsd/worktree.ts +7 -44
- package/src/resources/extensions/mcp-client/index.ts +2 -1
- 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-constants.ts +0 -6
- 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-supervisor.ts +0 -61
- 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 -658
- 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 -1149
- 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 -426
- 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-dispatch-loop.test.ts +0 -691
- 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/cache-staleness-regression.test.ts +0 -317
- 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 -877
- 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-parse-regression.test.ts +0 -358
- 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-regression.test.ts +0 -216
- package/dist/resources/extensions/gsd/tests/session-lock.test.ts +0 -434
- 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-sync-milestones.test.ts +0 -206
- 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/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/packages/pi-coding-agent/dist/modes/interactive/theme/dark.json +0 -85
- package/packages/pi-coding-agent/dist/modes/interactive/theme/light.json +0 -84
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.json +0 -335
- package/packages/pi-coding-agent/src/modes/interactive/theme/dark.json +0 -85
- package/packages/pi-coding-agent/src/modes/interactive/theme/light.json +0 -84
- package/packages/pi-coding-agent/src/modes/interactive/theme/theme-schema.json +0 -335
- package/pkg/dist/modes/interactive/theme/dark.json +0 -85
- package/pkg/dist/modes/interactive/theme/light.json +0 -84
- package/pkg/dist/modes/interactive/theme/theme-schema.json +0 -335
- package/src/resources/extensions/gsd/auto-constants.ts +0 -6
- package/src/resources/extensions/gsd/auto-idempotency.ts +0 -151
- package/src/resources/extensions/gsd/auto-stuck-detection.ts +0 -221
- package/src/resources/extensions/gsd/mechanical-completion.ts +0 -430
- package/src/resources/extensions/gsd/tests/auto-dispatch-loop.test.ts +0 -691
- package/src/resources/extensions/gsd/tests/auto-reentrancy-guard.test.ts +0 -127
- package/src/resources/extensions/gsd/tests/auto-skip-loop.test.ts +0 -123
- package/src/resources/extensions/gsd/tests/dispatch-stall-guard.test.ts +0 -126
- package/src/resources/extensions/gsd/tests/loop-regression.test.ts +0 -877
- package/src/resources/extensions/gsd/tests/mechanical-completion.test.ts +0 -356
- package/src/resources/extensions/gsd/tests/progress-score.test.ts +0 -206
- package/src/resources/extensions/gsd/tests/session-lock.test.ts +0 -434
|
@@ -0,0 +1,1158 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GSD Guided Flow — Smart Entry Wizard
|
|
3
|
+
*
|
|
4
|
+
* One function: showSmartEntry(). Reads state from disk, shows a contextual
|
|
5
|
+
* wizard via showNextAction(), and dispatches through GSD-WORKFLOW.md.
|
|
6
|
+
* No execution state, no hooks, no tools — the LLM does the rest.
|
|
7
|
+
*/
|
|
8
|
+
import { showNextAction } from "../shared/mod.js";
|
|
9
|
+
import { loadFile, parseRoadmap } from "./files.js";
|
|
10
|
+
import { loadPrompt, inlineTemplate } from "./prompt-loader.js";
|
|
11
|
+
import { deriveState } from "./state.js";
|
|
12
|
+
import { invalidateAllCaches } from "./cache.js";
|
|
13
|
+
import { startAuto } from "./auto.js";
|
|
14
|
+
import { readCrashLock, clearLock, formatCrashInfo } from "./crash-recovery.js";
|
|
15
|
+
import { listUnitRuntimeRecords, clearUnitRuntimeRecord } from "./unit-runtime.js";
|
|
16
|
+
import { resolveExpectedArtifactPath } from "./auto.js";
|
|
17
|
+
import { gsdRoot, milestonesDir, resolveMilestoneFile, resolveSliceFile, resolveSlicePath, resolveGsdRootFile, relGsdRootFile, relMilestoneFile, relSliceFile, } from "./paths.js";
|
|
18
|
+
import { join } from "node:path";
|
|
19
|
+
import { readFileSync, existsSync, mkdirSync, readdirSync, unlinkSync } from "node:fs";
|
|
20
|
+
import { nativeIsRepo, nativeInit } from "./native-git-bridge.js";
|
|
21
|
+
import { ensureGitignore, ensurePreferences, untrackRuntimeFiles } from "./gitignore.js";
|
|
22
|
+
import { loadEffectiveGSDPreferences } from "./preferences.js";
|
|
23
|
+
import { detectProjectState } from "./detection.js";
|
|
24
|
+
import { showProjectInit, offerMigration } from "./init-wizard.js";
|
|
25
|
+
import { validateDirectory } from "./validate-directory.js";
|
|
26
|
+
import { showConfirm } from "../shared/mod.js";
|
|
27
|
+
import { debugLog } from "./debug-logger.js";
|
|
28
|
+
import { findMilestoneIds, nextMilestoneId } from "./milestone-ids.js";
|
|
29
|
+
import { parkMilestone, discardMilestone } from "./milestone-actions.js";
|
|
30
|
+
// ─── Re-exports (preserve public API for existing importers) ────────────────
|
|
31
|
+
export { MILESTONE_ID_RE, generateMilestoneSuffix, nextMilestoneId, extractMilestoneSeq, parseMilestoneId, milestoneIdSort, maxMilestoneNum, findMilestoneIds, } from "./milestone-ids.js";
|
|
32
|
+
export { showQueue, handleQueueReorder, showQueueAdd, buildExistingMilestonesContext, } from "./guided-flow-queue.js";
|
|
33
|
+
import { getErrorMessage } from "./error-utils.js";
|
|
34
|
+
// ─── Commit Instruction Helpers ──────────────────────────────────────────────
|
|
35
|
+
/** Build commit instruction for planning prompts. .gsd/ is managed externally and always gitignored. */
|
|
36
|
+
function buildDocsCommitInstruction(_message) {
|
|
37
|
+
return "Do not commit planning artifacts — .gsd/ is managed externally.";
|
|
38
|
+
}
|
|
39
|
+
// ─── Auto-start after discuss ─────────────────────────────────────────────────
|
|
40
|
+
/** Stashed context + flag for auto-starting after discuss phase completes */
|
|
41
|
+
let pendingAutoStart = null;
|
|
42
|
+
/** Returns the milestoneId being discussed, or null if no discussion is active */
|
|
43
|
+
export function getDiscussionMilestoneId() {
|
|
44
|
+
return pendingAutoStart?.milestoneId ?? null;
|
|
45
|
+
}
|
|
46
|
+
/** Called from agent_end to check if auto-mode should start after discuss */
|
|
47
|
+
export function checkAutoStartAfterDiscuss() {
|
|
48
|
+
if (!pendingAutoStart)
|
|
49
|
+
return false;
|
|
50
|
+
const { ctx, pi, basePath, milestoneId, step } = pendingAutoStart;
|
|
51
|
+
// Gate 1: Primary milestone must have CONTEXT.md or ROADMAP.md
|
|
52
|
+
// The "discuss" path creates CONTEXT.md; the "plan" path creates ROADMAP.md.
|
|
53
|
+
const contextFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT");
|
|
54
|
+
const roadmapFile = resolveMilestoneFile(basePath, milestoneId, "ROADMAP");
|
|
55
|
+
if (!contextFile && !roadmapFile)
|
|
56
|
+
return false; // neither artifact yet — keep waiting
|
|
57
|
+
// Gate 2: STATE.md must exist — written as the last step in the discuss
|
|
58
|
+
// output phase. This prevents auto-start from firing during Phase 3
|
|
59
|
+
// (sequential readiness gates for remaining milestones) in multi-milestone
|
|
60
|
+
// discussions, where M001-CONTEXT.md exists but M002/M003 haven't been
|
|
61
|
+
// processed yet.
|
|
62
|
+
const stateFile = resolveGsdRootFile(basePath, "STATE");
|
|
63
|
+
if (!stateFile)
|
|
64
|
+
return false; // discussion not finalized yet
|
|
65
|
+
// Gate 3: Multi-milestone completeness warning
|
|
66
|
+
// Parse PROJECT.md for milestone sequence, warn if any are missing context.
|
|
67
|
+
// Don't block — milestones can be intentionally queued without context.
|
|
68
|
+
const projectFile = resolveGsdRootFile(basePath, "PROJECT");
|
|
69
|
+
if (projectFile) {
|
|
70
|
+
try {
|
|
71
|
+
const projectContent = readFileSync(projectFile, "utf-8");
|
|
72
|
+
const milestoneIds = parseMilestoneSequenceFromProject(projectContent);
|
|
73
|
+
if (milestoneIds.length > 1) {
|
|
74
|
+
const missing = milestoneIds.filter(id => {
|
|
75
|
+
const hasContext = !!resolveMilestoneFile(basePath, id, "CONTEXT");
|
|
76
|
+
const hasDraft = !!resolveMilestoneFile(basePath, id, "CONTEXT-DRAFT");
|
|
77
|
+
const hasDir = existsSync(join(gsdRoot(basePath), "milestones", id));
|
|
78
|
+
return !hasContext && !hasDraft && !hasDir;
|
|
79
|
+
});
|
|
80
|
+
if (missing.length > 0) {
|
|
81
|
+
ctx.ui.notify(`Multi-milestone validation: ${missing.join(", ")} not found in filesystem. ` +
|
|
82
|
+
`Discussion may not have completed all readiness gates.`, "warning");
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
catch { /* non-fatal — PROJECT.md parsing failure shouldn't block auto-start */ }
|
|
87
|
+
}
|
|
88
|
+
// Gate 4: Discussion manifest process verification (multi-milestone only)
|
|
89
|
+
// The LLM writes DISCUSSION-MANIFEST.json after each Phase 3 gate decision.
|
|
90
|
+
// If the manifest exists but gates_completed < total, the LLM hasn't finished
|
|
91
|
+
// presenting all readiness gates to the user — block auto-start.
|
|
92
|
+
const manifestPath = join(gsdRoot(basePath), "DISCUSSION-MANIFEST.json");
|
|
93
|
+
if (existsSync(manifestPath)) {
|
|
94
|
+
try {
|
|
95
|
+
const manifest = JSON.parse(readFileSync(manifestPath, "utf-8"));
|
|
96
|
+
const total = typeof manifest.total === "number" ? manifest.total : 0;
|
|
97
|
+
const completed = typeof manifest.gates_completed === "number" ? manifest.gates_completed : 0;
|
|
98
|
+
if (total > 1 && completed < total) {
|
|
99
|
+
// Discussion not complete — block auto-start until all gates are done
|
|
100
|
+
return false;
|
|
101
|
+
}
|
|
102
|
+
// Cross-check manifest milestones against PROJECT.md if available
|
|
103
|
+
if (projectFile) {
|
|
104
|
+
const projectContent = readFileSync(projectFile, "utf-8");
|
|
105
|
+
const projectIds = parseMilestoneSequenceFromProject(projectContent);
|
|
106
|
+
const manifestIds = Object.keys(manifest.milestones ?? {});
|
|
107
|
+
const untracked = projectIds.filter(id => !manifestIds.includes(id));
|
|
108
|
+
if (untracked.length > 0) {
|
|
109
|
+
ctx.ui.notify(`Discussion manifest missing gates for: ${untracked.join(", ")}`, "warning");
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
catch { /* malformed manifest — warn but don't block */ }
|
|
114
|
+
}
|
|
115
|
+
// Draft promotion cleanup: if a CONTEXT-DRAFT.md exists alongside the new
|
|
116
|
+
// CONTEXT.md, delete the draft — it's been consumed by the discussion.
|
|
117
|
+
try {
|
|
118
|
+
const draftFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT-DRAFT");
|
|
119
|
+
if (draftFile)
|
|
120
|
+
unlinkSync(draftFile);
|
|
121
|
+
}
|
|
122
|
+
catch { /* non-fatal — stale draft doesn't break anything, CONTEXT.md wins */ }
|
|
123
|
+
// Cleanup: remove discussion manifest after auto-start (only needed during discussion)
|
|
124
|
+
try {
|
|
125
|
+
unlinkSync(manifestPath);
|
|
126
|
+
}
|
|
127
|
+
catch { /* may not exist for single-milestone */ }
|
|
128
|
+
pendingAutoStart = null;
|
|
129
|
+
startAuto(ctx, pi, basePath, false, { step }).catch((err) => {
|
|
130
|
+
ctx.ui.notify(`Auto-start failed: ${getErrorMessage(err)}`, "error");
|
|
131
|
+
if (process.env.GSD_DEBUG)
|
|
132
|
+
console.error('[gsd] auto start error:', err);
|
|
133
|
+
debugLog("auto-start-failed", { error: getErrorMessage(err) });
|
|
134
|
+
});
|
|
135
|
+
return true;
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Extract milestone IDs from PROJECT.md milestone sequence table.
|
|
139
|
+
* Looks for rows like "| M001 | Name | Status |" and extracts the ID column.
|
|
140
|
+
*/
|
|
141
|
+
function parseMilestoneSequenceFromProject(content) {
|
|
142
|
+
const ids = [];
|
|
143
|
+
const lines = content.split(/\r?\n/);
|
|
144
|
+
for (const line of lines) {
|
|
145
|
+
const match = line.match(/^\|\s*(M\d{3}[A-Z0-9-]*)\s*\|/);
|
|
146
|
+
if (match)
|
|
147
|
+
ids.push(match[1]);
|
|
148
|
+
}
|
|
149
|
+
return ids;
|
|
150
|
+
}
|
|
151
|
+
// ─── Helpers ──────────────────────────────────────────────────────────────────
|
|
152
|
+
/**
|
|
153
|
+
* Read GSD-WORKFLOW.md and dispatch it to the LLM with a contextual note.
|
|
154
|
+
* This is the only way the wizard triggers work — everything else is the LLM's job.
|
|
155
|
+
*/
|
|
156
|
+
function dispatchWorkflow(pi, note, customType = "gsd-run") {
|
|
157
|
+
const workflowPath = process.env.GSD_WORKFLOW_PATH ?? join(process.env.HOME ?? "~", ".pi", "GSD-WORKFLOW.md");
|
|
158
|
+
const workflow = readFileSync(workflowPath, "utf-8");
|
|
159
|
+
pi.sendMessage({
|
|
160
|
+
customType,
|
|
161
|
+
content: `Read the following GSD workflow protocol and execute exactly.\n\n${workflow}\n\n## Your Task\n\n${note}`,
|
|
162
|
+
display: false,
|
|
163
|
+
}, { triggerTurn: true });
|
|
164
|
+
}
|
|
165
|
+
/**
|
|
166
|
+
* Build the discuss-and-plan prompt for a new milestone.
|
|
167
|
+
* Used by all three "new milestone" paths (first ever, no active, all complete).
|
|
168
|
+
*/
|
|
169
|
+
function buildDiscussPrompt(nextId, preamble, _basePath) {
|
|
170
|
+
const milestoneRel = `.gsd/milestones/${nextId}`;
|
|
171
|
+
const inlinedTemplates = [
|
|
172
|
+
inlineTemplate("project", "Project"),
|
|
173
|
+
inlineTemplate("requirements", "Requirements"),
|
|
174
|
+
inlineTemplate("context", "Context"),
|
|
175
|
+
inlineTemplate("roadmap", "Roadmap"),
|
|
176
|
+
inlineTemplate("decisions", "Decisions"),
|
|
177
|
+
].join("\n\n---\n\n");
|
|
178
|
+
return loadPrompt("discuss", {
|
|
179
|
+
milestoneId: nextId,
|
|
180
|
+
preamble,
|
|
181
|
+
contextPath: `${milestoneRel}/${nextId}-CONTEXT.md`,
|
|
182
|
+
roadmapPath: `${milestoneRel}/${nextId}-ROADMAP.md`,
|
|
183
|
+
inlinedTemplates,
|
|
184
|
+
commitInstruction: buildDocsCommitInstruction(`docs(${nextId}): context, requirements, and roadmap`),
|
|
185
|
+
multiMilestoneCommitInstruction: buildDocsCommitInstruction("docs: project plan — N milestones"),
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* Build the discuss prompt for headless milestone creation.
|
|
190
|
+
* Uses the discuss-headless prompt template with seed context injected.
|
|
191
|
+
*/
|
|
192
|
+
function buildHeadlessDiscussPrompt(nextId, seedContext, _basePath) {
|
|
193
|
+
const milestoneRel = `.gsd/milestones/${nextId}`;
|
|
194
|
+
const inlinedTemplates = [
|
|
195
|
+
inlineTemplate("project", "Project"),
|
|
196
|
+
inlineTemplate("requirements", "Requirements"),
|
|
197
|
+
inlineTemplate("context", "Context"),
|
|
198
|
+
inlineTemplate("roadmap", "Roadmap"),
|
|
199
|
+
inlineTemplate("decisions", "Decisions"),
|
|
200
|
+
].join("\n\n---\n\n");
|
|
201
|
+
return loadPrompt("discuss-headless", {
|
|
202
|
+
milestoneId: nextId,
|
|
203
|
+
seedContext,
|
|
204
|
+
contextPath: `${milestoneRel}/${nextId}-CONTEXT.md`,
|
|
205
|
+
roadmapPath: `${milestoneRel}/${nextId}-ROADMAP.md`,
|
|
206
|
+
inlinedTemplates,
|
|
207
|
+
commitInstruction: buildDocsCommitInstruction(`docs(${nextId}): context, requirements, and roadmap`),
|
|
208
|
+
multiMilestoneCommitInstruction: buildDocsCommitInstruction("docs: project plan — N milestones"),
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* Bootstrap a .gsd/ project from scratch for headless use.
|
|
213
|
+
* Ensures git repo, .gsd/ structure, gitignore, and preferences all exist.
|
|
214
|
+
*/
|
|
215
|
+
function bootstrapGsdProject(basePath) {
|
|
216
|
+
if (!nativeIsRepo(basePath)) {
|
|
217
|
+
const mainBranch = loadEffectiveGSDPreferences()?.preferences?.git?.main_branch || "main";
|
|
218
|
+
nativeInit(basePath, mainBranch);
|
|
219
|
+
}
|
|
220
|
+
const root = gsdRoot(basePath);
|
|
221
|
+
mkdirSync(join(root, "milestones"), { recursive: true });
|
|
222
|
+
mkdirSync(join(root, "runtime"), { recursive: true });
|
|
223
|
+
ensureGitignore(basePath);
|
|
224
|
+
ensurePreferences(basePath);
|
|
225
|
+
untrackRuntimeFiles(basePath);
|
|
226
|
+
}
|
|
227
|
+
/**
|
|
228
|
+
* Headless milestone creation from a seed specification document.
|
|
229
|
+
* Bootstraps the project if needed, generates the next milestone ID,
|
|
230
|
+
* and dispatches the headless discuss prompt (no Q&A rounds).
|
|
231
|
+
*/
|
|
232
|
+
export async function showHeadlessMilestoneCreation(ctx, pi, basePath, seedContext) {
|
|
233
|
+
// Ensure .gsd/ is bootstrapped
|
|
234
|
+
bootstrapGsdProject(basePath);
|
|
235
|
+
// Generate next milestone ID
|
|
236
|
+
const existingIds = findMilestoneIds(basePath);
|
|
237
|
+
const prefs = loadEffectiveGSDPreferences();
|
|
238
|
+
const nextId = nextMilestoneId(existingIds, prefs?.preferences?.unique_milestone_ids ?? false);
|
|
239
|
+
// Create milestone directory
|
|
240
|
+
const milestoneDir = join(gsdRoot(basePath), "milestones", nextId, "slices");
|
|
241
|
+
mkdirSync(milestoneDir, { recursive: true });
|
|
242
|
+
// Build and dispatch the headless discuss prompt
|
|
243
|
+
const prompt = buildHeadlessDiscussPrompt(nextId, seedContext, basePath);
|
|
244
|
+
// Set pending auto start (auto-mode triggers on "Milestone X ready." via checkAutoStartAfterDiscuss)
|
|
245
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId };
|
|
246
|
+
// Dispatch
|
|
247
|
+
dispatchWorkflow(pi, prompt);
|
|
248
|
+
}
|
|
249
|
+
// ─── Discuss Flow ─────────────────────────────────────────────────────────────
|
|
250
|
+
/**
|
|
251
|
+
* Build a rich inlined-context prompt for discussing a specific slice.
|
|
252
|
+
* Preloads roadmap, milestone context, research, decisions, and completed
|
|
253
|
+
* slice summaries so the agent can ask grounded UX/behaviour questions
|
|
254
|
+
* without wasting a turn reading files.
|
|
255
|
+
*/
|
|
256
|
+
async function buildDiscussSlicePrompt(mid, sid, sTitle, base, options) {
|
|
257
|
+
const inlined = [];
|
|
258
|
+
// Roadmap — always included so the agent sees surrounding slices
|
|
259
|
+
const roadmapPath = resolveMilestoneFile(base, mid, "ROADMAP");
|
|
260
|
+
const roadmapRel = relMilestoneFile(base, mid, "ROADMAP");
|
|
261
|
+
const roadmapContent = roadmapPath ? await loadFile(roadmapPath) : null;
|
|
262
|
+
if (roadmapContent) {
|
|
263
|
+
inlined.push(`### Milestone Roadmap\nSource: \`${roadmapRel}\`\n\n${roadmapContent.trim()}`);
|
|
264
|
+
}
|
|
265
|
+
// Milestone context — understanding the full milestone intent
|
|
266
|
+
const contextPath = resolveMilestoneFile(base, mid, "CONTEXT");
|
|
267
|
+
const contextRel = relMilestoneFile(base, mid, "CONTEXT");
|
|
268
|
+
const contextContent = contextPath ? await loadFile(contextPath) : null;
|
|
269
|
+
if (contextContent) {
|
|
270
|
+
inlined.push(`### Milestone Context\nSource: \`${contextRel}\`\n\n${contextContent.trim()}`);
|
|
271
|
+
}
|
|
272
|
+
// Milestone research — technical grounding
|
|
273
|
+
const researchPath = resolveMilestoneFile(base, mid, "RESEARCH");
|
|
274
|
+
const researchRel = relMilestoneFile(base, mid, "RESEARCH");
|
|
275
|
+
const researchContent = researchPath ? await loadFile(researchPath) : null;
|
|
276
|
+
if (researchContent) {
|
|
277
|
+
inlined.push(`### Milestone Research\nSource: \`${researchRel}\`\n\n${researchContent.trim()}`);
|
|
278
|
+
}
|
|
279
|
+
// Decisions — architectural context that constrains this slice
|
|
280
|
+
const decisionsPath = resolveGsdRootFile(base, "DECISIONS");
|
|
281
|
+
if (existsSync(decisionsPath)) {
|
|
282
|
+
const decisionsContent = await loadFile(decisionsPath);
|
|
283
|
+
if (decisionsContent) {
|
|
284
|
+
inlined.push(`### Decisions Register\nSource: \`${relGsdRootFile("DECISIONS")}\`\n\n${decisionsContent.trim()}`);
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
// Completed slice summaries — what was already built that this slice builds on
|
|
288
|
+
if (roadmapContent) {
|
|
289
|
+
const roadmap = parseRoadmap(roadmapContent);
|
|
290
|
+
for (const s of roadmap.slices) {
|
|
291
|
+
if (!s.done || s.id === sid)
|
|
292
|
+
continue;
|
|
293
|
+
const summaryPath = resolveSliceFile(base, mid, s.id, "SUMMARY");
|
|
294
|
+
const summaryRel = relSliceFile(base, mid, s.id, "SUMMARY");
|
|
295
|
+
const summaryContent = summaryPath ? await loadFile(summaryPath) : null;
|
|
296
|
+
if (summaryContent) {
|
|
297
|
+
inlined.push(`### ${s.id} Summary (completed)\nSource: \`${summaryRel}\`\n\n${summaryContent.trim()}`);
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
const inlinedContext = inlined.length > 0
|
|
302
|
+
? `## Inlined Context (preloaded — do not re-read these files)\n\n${inlined.join("\n\n---\n\n")}`
|
|
303
|
+
: `## Inlined Context\n\n_(no context files found yet — go in blind and ask broad questions)_`;
|
|
304
|
+
const sliceDirPath = `.gsd/milestones/${mid}/slices/${sid}`;
|
|
305
|
+
const sliceContextPath = `${sliceDirPath}/${sid}-CONTEXT.md`;
|
|
306
|
+
// When re-discussing, inject a preamble so the agent treats this as an update interview
|
|
307
|
+
const rediscussPreamble = options?.rediscuss
|
|
308
|
+
? `\n\n## Re-discuss Mode\n\nThis slice already has an existing context file (\`${sliceContextPath}\`) from a prior discussion. The user has chosen to re-discuss it. Read the existing context file, interview for any updates, changes, or new decisions, and rewrite the file with merged findings. Do NOT skip the interview — the user explicitly asked to revisit this slice.\n`
|
|
309
|
+
: "";
|
|
310
|
+
const inlinedTemplates = inlineTemplate("slice-context", "Slice Context");
|
|
311
|
+
return loadPrompt("guided-discuss-slice", {
|
|
312
|
+
milestoneId: mid,
|
|
313
|
+
sliceId: sid,
|
|
314
|
+
sliceTitle: sTitle,
|
|
315
|
+
inlinedContext: inlinedContext + rediscussPreamble,
|
|
316
|
+
sliceDirPath,
|
|
317
|
+
contextPath: sliceContextPath,
|
|
318
|
+
projectRoot: base,
|
|
319
|
+
inlinedTemplates,
|
|
320
|
+
commitInstruction: buildDocsCommitInstruction(`docs(${mid}/${sid}): slice context from discuss`),
|
|
321
|
+
});
|
|
322
|
+
}
|
|
323
|
+
/**
|
|
324
|
+
* /gsd discuss — show a picker of non-done slices and run a slice interview.
|
|
325
|
+
* Loops back to the picker after each discussion so the user can chain
|
|
326
|
+
* multiple slice interviews in one session.
|
|
327
|
+
*/
|
|
328
|
+
export async function showDiscuss(ctx, pi, basePath) {
|
|
329
|
+
// Guard: no .gsd/ project
|
|
330
|
+
if (!existsSync(gsdRoot(basePath))) {
|
|
331
|
+
ctx.ui.notify("No GSD project found. Run /gsd to start one first.", "warning");
|
|
332
|
+
return;
|
|
333
|
+
}
|
|
334
|
+
// Invalidate caches to pick up artifacts written by a just-completed discuss/plan
|
|
335
|
+
invalidateAllCaches();
|
|
336
|
+
const state = await deriveState(basePath);
|
|
337
|
+
// Guard: no active milestone
|
|
338
|
+
if (!state.activeMilestone) {
|
|
339
|
+
ctx.ui.notify("No active milestone. Run /gsd to create one first.", "warning");
|
|
340
|
+
return;
|
|
341
|
+
}
|
|
342
|
+
const mid = state.activeMilestone.id;
|
|
343
|
+
const milestoneTitle = state.activeMilestone.title;
|
|
344
|
+
// Special case: milestone is in needs-discussion phase (has CONTEXT-DRAFT.md but no roadmap yet).
|
|
345
|
+
// Route to the draft discussion flow instead of erroring — the discussion IS how the roadmap gets created.
|
|
346
|
+
if (state.phase === "needs-discussion") {
|
|
347
|
+
const draftFile = resolveMilestoneFile(basePath, mid, "CONTEXT-DRAFT");
|
|
348
|
+
const draftContent = draftFile ? await loadFile(draftFile) : null;
|
|
349
|
+
const choice = await showNextAction(ctx, {
|
|
350
|
+
title: `GSD — ${mid}: ${milestoneTitle}`,
|
|
351
|
+
summary: ["This milestone has a draft context from a prior discussion.", "It needs a dedicated discussion before auto-planning can begin."],
|
|
352
|
+
actions: [
|
|
353
|
+
{
|
|
354
|
+
id: "discuss_draft",
|
|
355
|
+
label: "Discuss from draft",
|
|
356
|
+
description: "Continue where the prior discussion left off — seed material is loaded automatically.",
|
|
357
|
+
recommended: true,
|
|
358
|
+
},
|
|
359
|
+
{
|
|
360
|
+
id: "discuss_fresh",
|
|
361
|
+
label: "Start fresh discussion",
|
|
362
|
+
description: "Discard the draft and start a new discussion from scratch.",
|
|
363
|
+
},
|
|
364
|
+
{
|
|
365
|
+
id: "skip_milestone",
|
|
366
|
+
label: "Skip — create new milestone",
|
|
367
|
+
description: "Leave this milestone as-is and start something new.",
|
|
368
|
+
},
|
|
369
|
+
],
|
|
370
|
+
notYetMessage: "Run /gsd discuss when ready to discuss this milestone.",
|
|
371
|
+
});
|
|
372
|
+
if (choice === "discuss_draft") {
|
|
373
|
+
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
374
|
+
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
375
|
+
const basePrompt = loadPrompt("guided-discuss-milestone", {
|
|
376
|
+
milestoneId: mid, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
|
|
377
|
+
commitInstruction: buildDocsCommitInstruction(`docs(${mid}): milestone context from discuss`),
|
|
378
|
+
});
|
|
379
|
+
const seed = draftContent
|
|
380
|
+
? `${basePrompt}\n\n## Prior Discussion (Draft Seed)\n\n${draftContent}`
|
|
381
|
+
: basePrompt;
|
|
382
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId: mid, step: false };
|
|
383
|
+
dispatchWorkflow(pi, seed, "gsd-discuss");
|
|
384
|
+
}
|
|
385
|
+
else if (choice === "discuss_fresh") {
|
|
386
|
+
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
387
|
+
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
388
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId: mid, step: false };
|
|
389
|
+
dispatchWorkflow(pi, loadPrompt("guided-discuss-milestone", {
|
|
390
|
+
milestoneId: mid, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
|
|
391
|
+
commitInstruction: buildDocsCommitInstruction(`docs(${mid}): milestone context from discuss`),
|
|
392
|
+
}), "gsd-discuss");
|
|
393
|
+
}
|
|
394
|
+
else if (choice === "skip_milestone") {
|
|
395
|
+
const milestoneIds = findMilestoneIds(basePath);
|
|
396
|
+
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
397
|
+
const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
|
|
398
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: false };
|
|
399
|
+
dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
|
|
400
|
+
}
|
|
401
|
+
return;
|
|
402
|
+
}
|
|
403
|
+
// Guard: no roadmap yet
|
|
404
|
+
const roadmapFile = resolveMilestoneFile(basePath, mid, "ROADMAP");
|
|
405
|
+
const roadmapContent = roadmapFile ? await loadFile(roadmapFile) : null;
|
|
406
|
+
if (!roadmapContent) {
|
|
407
|
+
ctx.ui.notify("No roadmap yet for this milestone. Run /gsd to plan first.", "warning");
|
|
408
|
+
return;
|
|
409
|
+
}
|
|
410
|
+
const roadmap = parseRoadmap(roadmapContent);
|
|
411
|
+
const pendingSlices = roadmap.slices.filter(s => !s.done);
|
|
412
|
+
if (pendingSlices.length === 0) {
|
|
413
|
+
ctx.ui.notify("All slices are complete — nothing to discuss.", "info");
|
|
414
|
+
return;
|
|
415
|
+
}
|
|
416
|
+
// Loop: show picker, dispatch discuss, repeat until "not_yet"
|
|
417
|
+
while (true) {
|
|
418
|
+
// Invalidate caches so we pick up CONTEXT files written by the just-completed discussion
|
|
419
|
+
invalidateAllCaches();
|
|
420
|
+
// Build discussion-state map: which slices have CONTEXT files already?
|
|
421
|
+
const discussedMap = new Map();
|
|
422
|
+
for (const s of pendingSlices) {
|
|
423
|
+
const contextFile = resolveSliceFile(basePath, mid, s.id, "CONTEXT");
|
|
424
|
+
discussedMap.set(s.id, !!contextFile);
|
|
425
|
+
}
|
|
426
|
+
// If all pending slices are discussed, notify and exit instead of looping
|
|
427
|
+
const allDiscussed = pendingSlices.every(s => discussedMap.get(s.id));
|
|
428
|
+
if (allDiscussed) {
|
|
429
|
+
ctx.ui.notify(`All ${pendingSlices.length} slices discussed. Run /gsd to start planning.`, "info");
|
|
430
|
+
return;
|
|
431
|
+
}
|
|
432
|
+
// Find the first undiscussed slice to recommend
|
|
433
|
+
const firstUndiscussedId = pendingSlices.find(s => !discussedMap.get(s.id))?.id;
|
|
434
|
+
const actions = pendingSlices.map((s) => {
|
|
435
|
+
const discussed = discussedMap.get(s.id) ?? false;
|
|
436
|
+
const statusParts = [];
|
|
437
|
+
if (state.activeSlice?.id === s.id)
|
|
438
|
+
statusParts.push("active");
|
|
439
|
+
else
|
|
440
|
+
statusParts.push("upcoming");
|
|
441
|
+
statusParts.push(discussed ? "discussed ✓" : "not discussed");
|
|
442
|
+
return {
|
|
443
|
+
id: s.id,
|
|
444
|
+
label: `${s.id}: ${s.title}`,
|
|
445
|
+
description: statusParts.join(" · "),
|
|
446
|
+
recommended: s.id === firstUndiscussedId,
|
|
447
|
+
};
|
|
448
|
+
});
|
|
449
|
+
const choice = await showNextAction(ctx, {
|
|
450
|
+
title: "GSD — Discuss a slice",
|
|
451
|
+
summary: [
|
|
452
|
+
`${mid}: ${milestoneTitle}`,
|
|
453
|
+
"Pick a slice to interview. Context file will be written when done.",
|
|
454
|
+
],
|
|
455
|
+
actions,
|
|
456
|
+
notYetMessage: "Run /gsd discuss when ready.",
|
|
457
|
+
});
|
|
458
|
+
if (choice === "not_yet")
|
|
459
|
+
return;
|
|
460
|
+
const chosen = pendingSlices.find(s => s.id === choice);
|
|
461
|
+
if (!chosen)
|
|
462
|
+
return;
|
|
463
|
+
// If the slice already has a CONTEXT file, confirm re-discuss intent
|
|
464
|
+
const isRediscuss = discussedMap.get(chosen.id) ?? false;
|
|
465
|
+
if (isRediscuss) {
|
|
466
|
+
const confirm = await showNextAction(ctx, {
|
|
467
|
+
title: `Re-discuss ${chosen.id}?`,
|
|
468
|
+
summary: [
|
|
469
|
+
`${chosen.id} already has a context file from a prior discussion.`,
|
|
470
|
+
"Re-discussing will interview for updates and rewrite the context file.",
|
|
471
|
+
],
|
|
472
|
+
actions: [
|
|
473
|
+
{ id: "rediscuss", label: "Re-discuss to update context", description: "Interview for changes and rewrite", recommended: true },
|
|
474
|
+
{ id: "cancel", label: "Cancel", description: "Go back to slice picker" },
|
|
475
|
+
],
|
|
476
|
+
});
|
|
477
|
+
if (confirm !== "rediscuss")
|
|
478
|
+
continue;
|
|
479
|
+
}
|
|
480
|
+
const prompt = await buildDiscussSlicePrompt(mid, chosen.id, chosen.title, basePath, { rediscuss: isRediscuss });
|
|
481
|
+
dispatchWorkflow(pi, prompt, "gsd-discuss");
|
|
482
|
+
// Wait for the discuss session to finish, then loop back to the picker
|
|
483
|
+
await ctx.waitForIdle();
|
|
484
|
+
invalidateAllCaches();
|
|
485
|
+
}
|
|
486
|
+
}
|
|
487
|
+
// ─── Smart Entry Point ────────────────────────────────────────────────────────
|
|
488
|
+
/**
|
|
489
|
+
* The one wizard. Reads state, shows contextual options, dispatches into the workflow doc.
|
|
490
|
+
*/
|
|
491
|
+
/**
|
|
492
|
+
* Self-heal: scan runtime records and clear stale ones left behind when
|
|
493
|
+
* auto-mode crashed mid-unit. auto.ts has its own selfHealRuntimeRecords()
|
|
494
|
+
* but guided-flow (manual /gsd mode) never called it — meaning stale records
|
|
495
|
+
* persisted until the next /gsd auto run. This ensures the wizard always
|
|
496
|
+
* starts from a clean state regardless of how the previous session ended.
|
|
497
|
+
*/
|
|
498
|
+
function selfHealRuntimeRecords(basePath, ctx) {
|
|
499
|
+
try {
|
|
500
|
+
const records = listUnitRuntimeRecords(basePath);
|
|
501
|
+
let cleared = 0;
|
|
502
|
+
for (const record of records) {
|
|
503
|
+
const { unitType, unitId, phase } = record;
|
|
504
|
+
// Clear records whose expected artifact already exists (completed but not cleaned up)
|
|
505
|
+
const artifactPath = resolveExpectedArtifactPath(unitType, unitId, basePath);
|
|
506
|
+
if (artifactPath && existsSync(artifactPath)) {
|
|
507
|
+
clearUnitRuntimeRecord(basePath, unitType, unitId);
|
|
508
|
+
cleared++;
|
|
509
|
+
continue;
|
|
510
|
+
}
|
|
511
|
+
// Clear records stuck in dispatched or timeout phase (process died mid-unit)
|
|
512
|
+
if (phase === "dispatched" || phase === "timeout") {
|
|
513
|
+
clearUnitRuntimeRecord(basePath, unitType, unitId);
|
|
514
|
+
cleared++;
|
|
515
|
+
}
|
|
516
|
+
}
|
|
517
|
+
if (cleared > 0) {
|
|
518
|
+
ctx.ui.notify(`Self-heal: cleared ${cleared} stale runtime record(s) from a previous session.`, "info");
|
|
519
|
+
}
|
|
520
|
+
return { cleared };
|
|
521
|
+
}
|
|
522
|
+
catch {
|
|
523
|
+
// Non-fatal — self-heal should never block the wizard
|
|
524
|
+
return { cleared: 0 };
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
// ─── Milestone Actions Submenu ──────────────────────────────────────────────
|
|
528
|
+
/**
|
|
529
|
+
* Shows a submenu with Park / Discard / Skip / Back options for the active milestone.
|
|
530
|
+
* Returns true if an action was taken (caller should re-enter showSmartEntry or
|
|
531
|
+
* dispatch a new workflow). Returns false if the user chose "Back".
|
|
532
|
+
*/
|
|
533
|
+
async function handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options) {
|
|
534
|
+
const stepMode = options?.step;
|
|
535
|
+
const choice = await showNextAction(ctx, {
|
|
536
|
+
title: `Milestone Actions — ${milestoneId}`,
|
|
537
|
+
summary: [`${milestoneId}: ${milestoneTitle}`],
|
|
538
|
+
actions: [
|
|
539
|
+
{
|
|
540
|
+
id: "park",
|
|
541
|
+
label: "Park milestone",
|
|
542
|
+
description: "Pause this milestone — it stays on disk but is skipped.",
|
|
543
|
+
},
|
|
544
|
+
{
|
|
545
|
+
id: "discard",
|
|
546
|
+
label: "Discard milestone",
|
|
547
|
+
description: "Permanently delete this milestone and all its contents.",
|
|
548
|
+
},
|
|
549
|
+
{
|
|
550
|
+
id: "skip",
|
|
551
|
+
label: "Skip — create new milestone",
|
|
552
|
+
description: "Leave this milestone and start a fresh one.",
|
|
553
|
+
},
|
|
554
|
+
{
|
|
555
|
+
id: "back",
|
|
556
|
+
label: "Back",
|
|
557
|
+
description: "Return to the previous menu.",
|
|
558
|
+
},
|
|
559
|
+
],
|
|
560
|
+
notYetMessage: "Run /gsd when ready.",
|
|
561
|
+
});
|
|
562
|
+
if (choice === "park") {
|
|
563
|
+
const reason = await showNextAction(ctx, {
|
|
564
|
+
title: `Park ${milestoneId}`,
|
|
565
|
+
summary: ["Why is this milestone being parked?"],
|
|
566
|
+
actions: [
|
|
567
|
+
{ id: "priority_shift", label: "Priority shift", description: "Other work is more important right now." },
|
|
568
|
+
{ id: "blocked_external", label: "Blocked externally", description: "Waiting on an external dependency or decision." },
|
|
569
|
+
{ id: "needs_rethink", label: "Needs rethinking", description: "The approach needs to be reconsidered." },
|
|
570
|
+
],
|
|
571
|
+
notYetMessage: "Run /gsd when ready.",
|
|
572
|
+
});
|
|
573
|
+
// User pressed "Not yet" / Escape — cancel the park operation
|
|
574
|
+
if (!reason || reason === "not_yet")
|
|
575
|
+
return false;
|
|
576
|
+
const reasonText = reason === "priority_shift" ? "Priority shift — other work is more important"
|
|
577
|
+
: reason === "blocked_external" ? "Blocked externally — waiting on external dependency"
|
|
578
|
+
: reason === "needs_rethink" ? "Needs rethinking — approach needs reconsideration"
|
|
579
|
+
: "Parked by user";
|
|
580
|
+
const success = parkMilestone(basePath, milestoneId, reasonText);
|
|
581
|
+
if (success) {
|
|
582
|
+
ctx.ui.notify(`Parked ${milestoneId}. Run /gsd unpark ${milestoneId} to reactivate.`, "info");
|
|
583
|
+
}
|
|
584
|
+
else {
|
|
585
|
+
ctx.ui.notify(`Could not park ${milestoneId} — milestone not found or already parked.`, "warning");
|
|
586
|
+
}
|
|
587
|
+
return true;
|
|
588
|
+
}
|
|
589
|
+
if (choice === "discard") {
|
|
590
|
+
const confirmed = await showConfirm(ctx, {
|
|
591
|
+
title: "Discard milestone?",
|
|
592
|
+
message: `This will permanently delete ${milestoneId} and all its contents (roadmap, plans, task summaries).`,
|
|
593
|
+
confirmLabel: "Discard",
|
|
594
|
+
declineLabel: "Cancel",
|
|
595
|
+
});
|
|
596
|
+
if (confirmed) {
|
|
597
|
+
discardMilestone(basePath, milestoneId);
|
|
598
|
+
ctx.ui.notify(`Discarded ${milestoneId}.`, "info");
|
|
599
|
+
return true;
|
|
600
|
+
}
|
|
601
|
+
return false;
|
|
602
|
+
}
|
|
603
|
+
if (choice === "skip") {
|
|
604
|
+
const milestoneIds = findMilestoneIds(basePath);
|
|
605
|
+
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
606
|
+
const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
|
|
607
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
|
|
608
|
+
dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
|
|
609
|
+
return true;
|
|
610
|
+
}
|
|
611
|
+
// "back" or null
|
|
612
|
+
return false;
|
|
613
|
+
}
|
|
614
|
+
export async function showSmartEntry(ctx, pi, basePath, options) {
|
|
615
|
+
const stepMode = options?.step;
|
|
616
|
+
// ── Directory safety check — refuse to operate in system/home dirs ───
|
|
617
|
+
const dirCheck = validateDirectory(basePath);
|
|
618
|
+
if (dirCheck.severity === "blocked") {
|
|
619
|
+
ctx.ui.notify(dirCheck.reason, "error");
|
|
620
|
+
return;
|
|
621
|
+
}
|
|
622
|
+
if (dirCheck.severity === "warning") {
|
|
623
|
+
const proceed = await showConfirm(ctx, {
|
|
624
|
+
title: "GSD — Unusual Directory",
|
|
625
|
+
message: dirCheck.reason,
|
|
626
|
+
confirmLabel: "Continue anyway",
|
|
627
|
+
declineLabel: "Cancel",
|
|
628
|
+
});
|
|
629
|
+
if (!proceed)
|
|
630
|
+
return;
|
|
631
|
+
}
|
|
632
|
+
// ── Detection preamble — run before any bootstrap ────────────────────
|
|
633
|
+
if (!existsSync(gsdRoot(basePath))) {
|
|
634
|
+
const detection = detectProjectState(basePath);
|
|
635
|
+
// v1 .planning/ detected — offer migration before anything else
|
|
636
|
+
if (detection.state === "v1-planning" && detection.v1) {
|
|
637
|
+
const migrationChoice = await offerMigration(ctx, detection.v1);
|
|
638
|
+
if (migrationChoice === "cancel")
|
|
639
|
+
return;
|
|
640
|
+
if (migrationChoice === "migrate") {
|
|
641
|
+
const { handleMigrate } = await import("./migrate/command.js");
|
|
642
|
+
await handleMigrate("", ctx, pi);
|
|
643
|
+
return;
|
|
644
|
+
}
|
|
645
|
+
// "fresh" — fall through to init wizard
|
|
646
|
+
}
|
|
647
|
+
// No .gsd/ — run the project init wizard
|
|
648
|
+
const result = await showProjectInit(ctx, pi, basePath, detection);
|
|
649
|
+
if (!result.completed)
|
|
650
|
+
return; // User cancelled
|
|
651
|
+
// Init wizard bootstrapped .gsd/ — fall through to the normal flow below
|
|
652
|
+
// which will detect "no milestones" and start the discuss prompt
|
|
653
|
+
}
|
|
654
|
+
// ── Ensure git repo exists — GSD needs it for worktree isolation ──────
|
|
655
|
+
if (!nativeIsRepo(basePath)) {
|
|
656
|
+
const mainBranch = loadEffectiveGSDPreferences()?.preferences?.git?.main_branch || "main";
|
|
657
|
+
nativeInit(basePath, mainBranch);
|
|
658
|
+
}
|
|
659
|
+
// ── Ensure .gitignore has baseline patterns ──────────────────────────
|
|
660
|
+
ensureGitignore(basePath);
|
|
661
|
+
untrackRuntimeFiles(basePath);
|
|
662
|
+
// ── Self-heal stale runtime records from crashed auto-mode sessions ──
|
|
663
|
+
selfHealRuntimeRecords(basePath, ctx);
|
|
664
|
+
// Check for crash from previous auto-mode session
|
|
665
|
+
const crashLock = readCrashLock(basePath);
|
|
666
|
+
if (crashLock) {
|
|
667
|
+
clearLock(basePath);
|
|
668
|
+
// Bootstrap crash with zero completed units = no work was lost.
|
|
669
|
+
// Auto-discard instead of prompting the user — this commonly happens
|
|
670
|
+
// when the user exits during init wizard or discuss phase before any
|
|
671
|
+
// real auto-mode work begins.
|
|
672
|
+
const isBootstrapCrash = crashLock.unitType === "starting"
|
|
673
|
+
&& crashLock.unitId === "bootstrap"
|
|
674
|
+
&& crashLock.completedUnits === 0;
|
|
675
|
+
if (!isBootstrapCrash) {
|
|
676
|
+
const resume = await showNextAction(ctx, {
|
|
677
|
+
title: "GSD — Interrupted Session Detected",
|
|
678
|
+
summary: [formatCrashInfo(crashLock)],
|
|
679
|
+
actions: [
|
|
680
|
+
{ id: "resume", label: "Resume with /gsd auto", description: "Pick up where it left off", recommended: true },
|
|
681
|
+
{ id: "continue", label: "Continue manually", description: "Open the wizard as normal" },
|
|
682
|
+
],
|
|
683
|
+
});
|
|
684
|
+
if (resume === "resume") {
|
|
685
|
+
await startAuto(ctx, pi, basePath, false);
|
|
686
|
+
return;
|
|
687
|
+
}
|
|
688
|
+
}
|
|
689
|
+
}
|
|
690
|
+
const state = await deriveState(basePath);
|
|
691
|
+
if (!state.activeMilestone) {
|
|
692
|
+
// Guard: if a discuss session is already in flight, don't re-inject the prompt.
|
|
693
|
+
// Both /gsd and /gsd auto reach this branch when no milestone exists yet.
|
|
694
|
+
// Without this guard, every subsequent /gsd call overwrites pendingAutoStart
|
|
695
|
+
// and fires another dispatchWorkflow, resetting the conversation mid-interview.
|
|
696
|
+
if (pendingAutoStart) {
|
|
697
|
+
ctx.ui.notify("Discussion already in progress — answer the question above to continue.", "info");
|
|
698
|
+
return;
|
|
699
|
+
}
|
|
700
|
+
const milestoneIds = findMilestoneIds(basePath);
|
|
701
|
+
// Sanity check (#456): if findMilestoneIds returns [] but the milestones
|
|
702
|
+
// directory has contents, something went wrong (permissions, stale worktree
|
|
703
|
+
// cwd, etc). Warn instead of silently starting a new-project flow.
|
|
704
|
+
if (milestoneIds.length === 0) {
|
|
705
|
+
const mDir = milestonesDir(basePath);
|
|
706
|
+
if (existsSync(mDir)) {
|
|
707
|
+
try {
|
|
708
|
+
const entries = readdirSync(mDir);
|
|
709
|
+
if (entries.length > 0) {
|
|
710
|
+
ctx.ui.notify(`Milestone directory has ${entries.length} entries but none were recognized as milestones. ` +
|
|
711
|
+
`This may indicate a corrupted state or wrong working directory. Run \`/gsd doctor\` to diagnose.`, "warning");
|
|
712
|
+
return;
|
|
713
|
+
}
|
|
714
|
+
}
|
|
715
|
+
catch { /* directory exists but unreadable — fall through to normal flow */ }
|
|
716
|
+
}
|
|
717
|
+
}
|
|
718
|
+
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
719
|
+
const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
|
|
720
|
+
const isFirst = milestoneIds.length === 0;
|
|
721
|
+
if (isFirst) {
|
|
722
|
+
// First ever — skip wizard, just ask directly
|
|
723
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
|
|
724
|
+
dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New project, milestone ${nextId}. Do NOT read or explore .gsd/ — it's empty scaffolding.`, basePath));
|
|
725
|
+
}
|
|
726
|
+
else {
|
|
727
|
+
const choice = await showNextAction(ctx, {
|
|
728
|
+
title: "GSD — Get Shit Done",
|
|
729
|
+
summary: ["No active milestone."],
|
|
730
|
+
actions: [
|
|
731
|
+
{
|
|
732
|
+
id: "new_milestone",
|
|
733
|
+
label: "Create next milestone",
|
|
734
|
+
description: "Define what to build next.",
|
|
735
|
+
recommended: true,
|
|
736
|
+
},
|
|
737
|
+
],
|
|
738
|
+
notYetMessage: "Run /gsd when ready.",
|
|
739
|
+
});
|
|
740
|
+
if (choice === "new_milestone") {
|
|
741
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
|
|
742
|
+
dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
|
|
743
|
+
}
|
|
744
|
+
}
|
|
745
|
+
return;
|
|
746
|
+
}
|
|
747
|
+
const milestoneId = state.activeMilestone.id;
|
|
748
|
+
const milestoneTitle = state.activeMilestone.title;
|
|
749
|
+
// ── All milestones complete → New milestone ──────────────────────────
|
|
750
|
+
if (state.phase === "complete") {
|
|
751
|
+
const choice = await showNextAction(ctx, {
|
|
752
|
+
title: `GSD — ${milestoneId}: ${milestoneTitle}`,
|
|
753
|
+
summary: ["All milestones complete."],
|
|
754
|
+
actions: [
|
|
755
|
+
{
|
|
756
|
+
id: "new_milestone",
|
|
757
|
+
label: "Start new milestone",
|
|
758
|
+
description: "Define and plan the next milestone.",
|
|
759
|
+
recommended: true,
|
|
760
|
+
},
|
|
761
|
+
{
|
|
762
|
+
id: "status",
|
|
763
|
+
label: "View status",
|
|
764
|
+
description: "Review what was built.",
|
|
765
|
+
},
|
|
766
|
+
],
|
|
767
|
+
notYetMessage: "Run /gsd when ready.",
|
|
768
|
+
});
|
|
769
|
+
if (choice === "new_milestone") {
|
|
770
|
+
const milestoneIds = findMilestoneIds(basePath);
|
|
771
|
+
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
772
|
+
const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
|
|
773
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
|
|
774
|
+
dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
|
|
775
|
+
}
|
|
776
|
+
else if (choice === "status") {
|
|
777
|
+
const { fireStatusViaCommand } = await import("./commands.js");
|
|
778
|
+
await fireStatusViaCommand(ctx);
|
|
779
|
+
}
|
|
780
|
+
return;
|
|
781
|
+
}
|
|
782
|
+
// ── Draft milestone — needs discussion before planning ────────────────
|
|
783
|
+
if (state.phase === "needs-discussion") {
|
|
784
|
+
const draftFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT-DRAFT");
|
|
785
|
+
const draftContent = draftFile ? await loadFile(draftFile) : null;
|
|
786
|
+
const choice = await showNextAction(ctx, {
|
|
787
|
+
title: `GSD — ${milestoneId}: ${milestoneTitle}`,
|
|
788
|
+
summary: ["This milestone has a draft context from a prior discussion.", "It needs a dedicated discussion before auto-planning can begin."],
|
|
789
|
+
actions: [
|
|
790
|
+
{
|
|
791
|
+
id: "discuss_draft",
|
|
792
|
+
label: "Discuss from draft",
|
|
793
|
+
description: "Continue where the prior discussion left off — seed material is loaded automatically.",
|
|
794
|
+
recommended: true,
|
|
795
|
+
},
|
|
796
|
+
{
|
|
797
|
+
id: "discuss_fresh",
|
|
798
|
+
label: "Start fresh discussion",
|
|
799
|
+
description: "Discard the draft and start a new discussion from scratch.",
|
|
800
|
+
},
|
|
801
|
+
{
|
|
802
|
+
id: "skip_milestone",
|
|
803
|
+
label: "Skip — create new milestone",
|
|
804
|
+
description: "Leave this milestone as-is and start something new.",
|
|
805
|
+
},
|
|
806
|
+
],
|
|
807
|
+
notYetMessage: "Run /gsd when ready to discuss this milestone.",
|
|
808
|
+
});
|
|
809
|
+
if (choice === "discuss_draft") {
|
|
810
|
+
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
811
|
+
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
812
|
+
const basePrompt = loadPrompt("guided-discuss-milestone", {
|
|
813
|
+
milestoneId, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
|
|
814
|
+
commitInstruction: buildDocsCommitInstruction(`docs(${milestoneId}): milestone context from discuss`),
|
|
815
|
+
});
|
|
816
|
+
const seed = draftContent
|
|
817
|
+
? `${basePrompt}\n\n## Prior Discussion (Draft Seed)\n\n${draftContent}`
|
|
818
|
+
: basePrompt;
|
|
819
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId, step: stepMode };
|
|
820
|
+
dispatchWorkflow(pi, seed, "gsd-discuss");
|
|
821
|
+
}
|
|
822
|
+
else if (choice === "discuss_fresh") {
|
|
823
|
+
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
824
|
+
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
825
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId, step: stepMode };
|
|
826
|
+
dispatchWorkflow(pi, loadPrompt("guided-discuss-milestone", {
|
|
827
|
+
milestoneId, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
|
|
828
|
+
commitInstruction: buildDocsCommitInstruction(`docs(${milestoneId}): milestone context from discuss`),
|
|
829
|
+
}), "gsd-discuss");
|
|
830
|
+
}
|
|
831
|
+
else if (choice === "skip_milestone") {
|
|
832
|
+
const milestoneIds = findMilestoneIds(basePath);
|
|
833
|
+
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
834
|
+
const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
|
|
835
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
|
|
836
|
+
dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
|
|
837
|
+
}
|
|
838
|
+
return;
|
|
839
|
+
}
|
|
840
|
+
// ── No active slice ──────────────────────────────────────────────────
|
|
841
|
+
if (!state.activeSlice) {
|
|
842
|
+
const roadmapFile = resolveMilestoneFile(basePath, milestoneId, "ROADMAP");
|
|
843
|
+
const hasRoadmap = !!(roadmapFile && await loadFile(roadmapFile));
|
|
844
|
+
if (!hasRoadmap) {
|
|
845
|
+
// No roadmap → discuss or plan
|
|
846
|
+
const contextFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT");
|
|
847
|
+
const hasContext = !!(contextFile && await loadFile(contextFile));
|
|
848
|
+
const actions = [
|
|
849
|
+
{
|
|
850
|
+
id: "plan",
|
|
851
|
+
label: "Create roadmap",
|
|
852
|
+
description: hasContext
|
|
853
|
+
? "Context captured. Decompose into slices with a boundary map."
|
|
854
|
+
: "Decompose the milestone into slices with a boundary map.",
|
|
855
|
+
recommended: true,
|
|
856
|
+
},
|
|
857
|
+
...(!hasContext ? [{
|
|
858
|
+
id: "discuss",
|
|
859
|
+
label: "Discuss first",
|
|
860
|
+
description: "Capture decisions on gray areas before planning.",
|
|
861
|
+
}] : []),
|
|
862
|
+
{
|
|
863
|
+
id: "skip_milestone",
|
|
864
|
+
label: "Skip — create new milestone",
|
|
865
|
+
description: "Leave this milestone on disk and start a fresh one.",
|
|
866
|
+
},
|
|
867
|
+
{
|
|
868
|
+
id: "discard_milestone",
|
|
869
|
+
label: "Discard this milestone",
|
|
870
|
+
description: "Delete the milestone directory and start over.",
|
|
871
|
+
},
|
|
872
|
+
];
|
|
873
|
+
const choice = await showNextAction(ctx, {
|
|
874
|
+
title: `GSD — ${milestoneId}: ${milestoneTitle}`,
|
|
875
|
+
summary: [hasContext ? "Context captured. Ready to create roadmap." : "New milestone — no roadmap yet."],
|
|
876
|
+
actions,
|
|
877
|
+
notYetMessage: "Run /gsd when ready.",
|
|
878
|
+
});
|
|
879
|
+
if (choice === "plan") {
|
|
880
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId, step: stepMode };
|
|
881
|
+
const planMilestoneTemplates = [
|
|
882
|
+
inlineTemplate("roadmap", "Roadmap"),
|
|
883
|
+
inlineTemplate("plan", "Slice Plan"),
|
|
884
|
+
inlineTemplate("task-plan", "Task Plan"),
|
|
885
|
+
inlineTemplate("secrets-manifest", "Secrets Manifest"),
|
|
886
|
+
].join("\n\n---\n\n");
|
|
887
|
+
const secretsOutputPath = relMilestoneFile(basePath, milestoneId, "SECRETS");
|
|
888
|
+
dispatchWorkflow(pi, loadPrompt("guided-plan-milestone", {
|
|
889
|
+
milestoneId, milestoneTitle, secretsOutputPath, inlinedTemplates: planMilestoneTemplates,
|
|
890
|
+
}));
|
|
891
|
+
}
|
|
892
|
+
else if (choice === "discuss") {
|
|
893
|
+
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
894
|
+
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
895
|
+
dispatchWorkflow(pi, loadPrompt("guided-discuss-milestone", {
|
|
896
|
+
milestoneId, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
|
|
897
|
+
commitInstruction: buildDocsCommitInstruction(`docs(${milestoneId}): milestone context from discuss`),
|
|
898
|
+
}));
|
|
899
|
+
}
|
|
900
|
+
else if (choice === "skip_milestone") {
|
|
901
|
+
const milestoneIds = findMilestoneIds(basePath);
|
|
902
|
+
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
903
|
+
const nextId = nextMilestoneId(milestoneIds, uniqueMilestoneIds);
|
|
904
|
+
pendingAutoStart = { ctx, pi, basePath, milestoneId: nextId, step: stepMode };
|
|
905
|
+
dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath));
|
|
906
|
+
}
|
|
907
|
+
else if (choice === "discard_milestone") {
|
|
908
|
+
const confirmed = await showConfirm(ctx, {
|
|
909
|
+
title: "Discard milestone?",
|
|
910
|
+
message: `This will permanently delete ${milestoneId} and all its contents.`,
|
|
911
|
+
confirmLabel: "Discard",
|
|
912
|
+
declineLabel: "Cancel",
|
|
913
|
+
});
|
|
914
|
+
if (confirmed) {
|
|
915
|
+
discardMilestone(basePath, milestoneId);
|
|
916
|
+
return showSmartEntry(ctx, pi, basePath, options);
|
|
917
|
+
}
|
|
918
|
+
}
|
|
919
|
+
}
|
|
920
|
+
else {
|
|
921
|
+
// Roadmap exists — either blocked or ready for auto
|
|
922
|
+
const actions = [
|
|
923
|
+
{
|
|
924
|
+
id: "auto",
|
|
925
|
+
label: "Go auto",
|
|
926
|
+
description: "Execute everything automatically until milestone complete.",
|
|
927
|
+
recommended: true,
|
|
928
|
+
},
|
|
929
|
+
{
|
|
930
|
+
id: "status",
|
|
931
|
+
label: "View status",
|
|
932
|
+
description: "See milestone progress and blockers.",
|
|
933
|
+
},
|
|
934
|
+
{
|
|
935
|
+
id: "milestone_actions",
|
|
936
|
+
label: "Milestone actions",
|
|
937
|
+
description: "Park, discard, or skip this milestone.",
|
|
938
|
+
},
|
|
939
|
+
];
|
|
940
|
+
const choice = await showNextAction(ctx, {
|
|
941
|
+
title: `GSD — ${milestoneId}: ${milestoneTitle}`,
|
|
942
|
+
summary: ["Roadmap exists. Ready to execute."],
|
|
943
|
+
actions,
|
|
944
|
+
notYetMessage: "Run /gsd status for details.",
|
|
945
|
+
});
|
|
946
|
+
if (choice === "auto") {
|
|
947
|
+
await startAuto(ctx, pi, basePath, false);
|
|
948
|
+
}
|
|
949
|
+
else if (choice === "status") {
|
|
950
|
+
const { fireStatusViaCommand } = await import("./commands.js");
|
|
951
|
+
await fireStatusViaCommand(ctx);
|
|
952
|
+
}
|
|
953
|
+
else if (choice === "milestone_actions") {
|
|
954
|
+
const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
|
|
955
|
+
if (acted)
|
|
956
|
+
return showSmartEntry(ctx, pi, basePath, options);
|
|
957
|
+
}
|
|
958
|
+
}
|
|
959
|
+
return;
|
|
960
|
+
}
|
|
961
|
+
const sliceId = state.activeSlice.id;
|
|
962
|
+
const sliceTitle = state.activeSlice.title;
|
|
963
|
+
// ── Slice needs planning ─────────────────────────────────────────────
|
|
964
|
+
if (state.phase === "planning") {
|
|
965
|
+
const contextFile = resolveSliceFile(basePath, milestoneId, sliceId, "CONTEXT");
|
|
966
|
+
const researchFile = resolveSliceFile(basePath, milestoneId, sliceId, "RESEARCH");
|
|
967
|
+
const hasContext = !!(contextFile && await loadFile(contextFile));
|
|
968
|
+
const hasResearch = !!(researchFile && await loadFile(researchFile));
|
|
969
|
+
const actions = [
|
|
970
|
+
{
|
|
971
|
+
id: "plan",
|
|
972
|
+
label: `Plan ${sliceId}`,
|
|
973
|
+
description: `Decompose "${sliceTitle}" into tasks with must-haves.`,
|
|
974
|
+
recommended: true,
|
|
975
|
+
},
|
|
976
|
+
...(!hasContext ? [{
|
|
977
|
+
id: "discuss",
|
|
978
|
+
label: `Discuss ${sliceId} first`,
|
|
979
|
+
description: "Capture context and decisions for this slice.",
|
|
980
|
+
}] : []),
|
|
981
|
+
...(!hasResearch ? [{
|
|
982
|
+
id: "research",
|
|
983
|
+
label: `Research ${sliceId} first`,
|
|
984
|
+
description: "Scout codebase and relevant docs.",
|
|
985
|
+
}] : []),
|
|
986
|
+
{
|
|
987
|
+
id: "status",
|
|
988
|
+
label: "View status",
|
|
989
|
+
description: "See milestone progress.",
|
|
990
|
+
},
|
|
991
|
+
{
|
|
992
|
+
id: "milestone_actions",
|
|
993
|
+
label: "Milestone actions",
|
|
994
|
+
description: "Park, discard, or skip this milestone.",
|
|
995
|
+
},
|
|
996
|
+
];
|
|
997
|
+
const summaryParts = [];
|
|
998
|
+
if (hasContext)
|
|
999
|
+
summaryParts.push("context ✓");
|
|
1000
|
+
if (hasResearch)
|
|
1001
|
+
summaryParts.push("research ✓");
|
|
1002
|
+
const summaryLine = summaryParts.length > 0
|
|
1003
|
+
? `${sliceId}: ${sliceTitle} (${summaryParts.join(", ")})`
|
|
1004
|
+
: `${sliceId}: ${sliceTitle} — ready for planning.`;
|
|
1005
|
+
const choice = await showNextAction(ctx, {
|
|
1006
|
+
title: `GSD — ${milestoneId} / ${sliceId}: ${sliceTitle}`,
|
|
1007
|
+
summary: [summaryLine],
|
|
1008
|
+
actions,
|
|
1009
|
+
notYetMessage: "Run /gsd when ready.",
|
|
1010
|
+
});
|
|
1011
|
+
if (choice === "plan") {
|
|
1012
|
+
const planSliceTemplates = [
|
|
1013
|
+
inlineTemplate("plan", "Slice Plan"),
|
|
1014
|
+
inlineTemplate("task-plan", "Task Plan"),
|
|
1015
|
+
].join("\n\n---\n\n");
|
|
1016
|
+
dispatchWorkflow(pi, loadPrompt("guided-plan-slice", {
|
|
1017
|
+
milestoneId, sliceId, sliceTitle, inlinedTemplates: planSliceTemplates,
|
|
1018
|
+
}));
|
|
1019
|
+
}
|
|
1020
|
+
else if (choice === "discuss") {
|
|
1021
|
+
dispatchWorkflow(pi, await buildDiscussSlicePrompt(milestoneId, sliceId, sliceTitle, basePath, { rediscuss: hasContext }));
|
|
1022
|
+
}
|
|
1023
|
+
else if (choice === "research") {
|
|
1024
|
+
const researchTemplates = inlineTemplate("research", "Research");
|
|
1025
|
+
dispatchWorkflow(pi, loadPrompt("guided-research-slice", {
|
|
1026
|
+
milestoneId, sliceId, sliceTitle, inlinedTemplates: researchTemplates,
|
|
1027
|
+
}));
|
|
1028
|
+
}
|
|
1029
|
+
else if (choice === "status") {
|
|
1030
|
+
const { fireStatusViaCommand } = await import("./commands.js");
|
|
1031
|
+
await fireStatusViaCommand(ctx);
|
|
1032
|
+
}
|
|
1033
|
+
else if (choice === "milestone_actions") {
|
|
1034
|
+
const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
|
|
1035
|
+
if (acted)
|
|
1036
|
+
return showSmartEntry(ctx, pi, basePath, options);
|
|
1037
|
+
}
|
|
1038
|
+
return;
|
|
1039
|
+
}
|
|
1040
|
+
// ── All tasks done → Complete slice ──────────────────────────────────
|
|
1041
|
+
if (state.phase === "summarizing") {
|
|
1042
|
+
const choice = await showNextAction(ctx, {
|
|
1043
|
+
title: `GSD — ${milestoneId} / ${sliceId}: ${sliceTitle}`,
|
|
1044
|
+
summary: ["All tasks complete. Ready for slice summary."],
|
|
1045
|
+
actions: [
|
|
1046
|
+
{
|
|
1047
|
+
id: "complete",
|
|
1048
|
+
label: `Complete ${sliceId}`,
|
|
1049
|
+
description: "Write slice summary, UAT, mark done, and squash-merge to main.",
|
|
1050
|
+
recommended: true,
|
|
1051
|
+
},
|
|
1052
|
+
{
|
|
1053
|
+
id: "status",
|
|
1054
|
+
label: "View status",
|
|
1055
|
+
description: "Review tasks before completing.",
|
|
1056
|
+
},
|
|
1057
|
+
{
|
|
1058
|
+
id: "milestone_actions",
|
|
1059
|
+
label: "Milestone actions",
|
|
1060
|
+
description: "Park, discard, or skip this milestone.",
|
|
1061
|
+
},
|
|
1062
|
+
],
|
|
1063
|
+
notYetMessage: "Run /gsd when ready.",
|
|
1064
|
+
});
|
|
1065
|
+
if (choice === "complete") {
|
|
1066
|
+
const completeSliceTemplates = [
|
|
1067
|
+
inlineTemplate("slice-summary", "Slice Summary"),
|
|
1068
|
+
inlineTemplate("uat", "UAT"),
|
|
1069
|
+
].join("\n\n---\n\n");
|
|
1070
|
+
dispatchWorkflow(pi, loadPrompt("guided-complete-slice", {
|
|
1071
|
+
workingDirectory: basePath, milestoneId, sliceId, sliceTitle, inlinedTemplates: completeSliceTemplates,
|
|
1072
|
+
}));
|
|
1073
|
+
}
|
|
1074
|
+
else if (choice === "status") {
|
|
1075
|
+
const { fireStatusViaCommand } = await import("./commands.js");
|
|
1076
|
+
await fireStatusViaCommand(ctx);
|
|
1077
|
+
}
|
|
1078
|
+
else if (choice === "milestone_actions") {
|
|
1079
|
+
const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
|
|
1080
|
+
if (acted)
|
|
1081
|
+
return showSmartEntry(ctx, pi, basePath, options);
|
|
1082
|
+
}
|
|
1083
|
+
return;
|
|
1084
|
+
}
|
|
1085
|
+
// ── Active task → Execute ────────────────────────────────────────────
|
|
1086
|
+
if (state.activeTask) {
|
|
1087
|
+
const taskId = state.activeTask.id;
|
|
1088
|
+
const taskTitle = state.activeTask.title;
|
|
1089
|
+
const continueFile = resolveSliceFile(basePath, milestoneId, sliceId, "CONTINUE");
|
|
1090
|
+
const sDir = resolveSlicePath(basePath, milestoneId, sliceId);
|
|
1091
|
+
const hasInterrupted = !!(continueFile && await loadFile(continueFile)) ||
|
|
1092
|
+
!!(sDir && await loadFile(join(sDir, "continue.md")));
|
|
1093
|
+
const choice = await showNextAction(ctx, {
|
|
1094
|
+
title: `GSD — ${milestoneId} / ${sliceId}: ${sliceTitle}`,
|
|
1095
|
+
summary: [
|
|
1096
|
+
hasInterrupted
|
|
1097
|
+
? `Resuming: ${taskId} — ${taskTitle}`
|
|
1098
|
+
: `Next: ${taskId} — ${taskTitle}`,
|
|
1099
|
+
],
|
|
1100
|
+
actions: [
|
|
1101
|
+
{
|
|
1102
|
+
id: "execute",
|
|
1103
|
+
label: hasInterrupted ? `Resume ${taskId}` : `Execute ${taskId}`,
|
|
1104
|
+
description: hasInterrupted
|
|
1105
|
+
? "Continue from where you left off."
|
|
1106
|
+
: `Start working on "${taskTitle}".`,
|
|
1107
|
+
recommended: true,
|
|
1108
|
+
},
|
|
1109
|
+
{
|
|
1110
|
+
id: "auto",
|
|
1111
|
+
label: "Go auto",
|
|
1112
|
+
description: "Execute this and all remaining tasks automatically.",
|
|
1113
|
+
},
|
|
1114
|
+
{
|
|
1115
|
+
id: "status",
|
|
1116
|
+
label: "View status",
|
|
1117
|
+
description: "See slice progress before starting.",
|
|
1118
|
+
},
|
|
1119
|
+
{
|
|
1120
|
+
id: "milestone_actions",
|
|
1121
|
+
label: "Milestone actions",
|
|
1122
|
+
description: "Park, discard, or skip this milestone.",
|
|
1123
|
+
},
|
|
1124
|
+
],
|
|
1125
|
+
notYetMessage: "Run /gsd when ready.",
|
|
1126
|
+
});
|
|
1127
|
+
if (choice === "auto") {
|
|
1128
|
+
await startAuto(ctx, pi, basePath, false);
|
|
1129
|
+
return;
|
|
1130
|
+
}
|
|
1131
|
+
if (choice === "execute") {
|
|
1132
|
+
if (hasInterrupted) {
|
|
1133
|
+
dispatchWorkflow(pi, loadPrompt("guided-resume-task", {
|
|
1134
|
+
milestoneId, sliceId,
|
|
1135
|
+
}));
|
|
1136
|
+
}
|
|
1137
|
+
else {
|
|
1138
|
+
const executeTaskTemplates = inlineTemplate("task-summary", "Task Summary");
|
|
1139
|
+
dispatchWorkflow(pi, loadPrompt("guided-execute-task", {
|
|
1140
|
+
milestoneId, sliceId, taskId, taskTitle, inlinedTemplates: executeTaskTemplates,
|
|
1141
|
+
}));
|
|
1142
|
+
}
|
|
1143
|
+
}
|
|
1144
|
+
else if (choice === "status") {
|
|
1145
|
+
const { fireStatusViaCommand } = await import("./commands.js");
|
|
1146
|
+
await fireStatusViaCommand(ctx);
|
|
1147
|
+
}
|
|
1148
|
+
else if (choice === "milestone_actions") {
|
|
1149
|
+
const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
|
|
1150
|
+
if (acted)
|
|
1151
|
+
return showSmartEntry(ctx, pi, basePath, options);
|
|
1152
|
+
}
|
|
1153
|
+
return;
|
|
1154
|
+
}
|
|
1155
|
+
// ── Fallback: show status ────────────────────────────────────────────
|
|
1156
|
+
const { fireStatusViaCommand } = await import("./commands.js");
|
|
1157
|
+
await fireStatusViaCommand(ctx);
|
|
1158
|
+
}
|