lsd-pi 1.0.0 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +283 -648
- package/dist/cli-theme.d.ts +1 -1
- package/dist/cli-theme.js +4 -4
- package/dist/cli.js +2 -2
- package/dist/headless.js +4 -6
- package/dist/help-text.js +1 -3
- package/dist/loader.js +8 -7
- package/dist/logo.d.ts +9 -0
- package/dist/logo.js +18 -8
- package/dist/lsd-brand.d.ts +14 -0
- package/dist/lsd-brand.js +42 -0
- package/dist/onboarding.js +51 -0
- package/dist/resource-loader.d.ts +2 -3
- package/dist/resource-loader.js +18 -20
- package/dist/resources/agents/generic.md +29 -0
- package/dist/resources/agents/scout.md +1 -0
- package/dist/resources/extensions/ask-user-questions.js +0 -4
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +6 -0
- package/dist/resources/extensions/get-secrets-from-user.js +2 -3
- package/dist/resources/extensions/remote-questions/config.js +3 -3
- package/dist/resources/extensions/remote-questions/remote-command.js +4 -27
- package/dist/resources/extensions/search-the-web/native-search.js +1 -1
- package/dist/resources/extensions/search-the-web/provider.js +4 -12
- package/dist/resources/extensions/shared/debug-logger.js +103 -0
- package/dist/resources/extensions/shared/env-utils.js +17 -0
- package/dist/resources/extensions/shared/paths.js +17 -0
- package/dist/resources/extensions/shared/preferences.js +90 -0
- package/dist/resources/extensions/shared/remote-questions-config.js +27 -0
- package/dist/resources/extensions/shared/rtk-session-stats.js +2 -2
- package/dist/resources/extensions/shared/secrets-manifest.js +115 -0
- package/dist/resources/extensions/slash-commands/extension-manifest.json +2 -1
- package/dist/resources/extensions/slash-commands/index.js +2 -0
- package/dist/resources/extensions/slash-commands/plan.js +284 -0
- package/dist/resources/extensions/subagent/agents.js +1 -1
- package/dist/resources/extensions/subagent/approval-proxy.js +34 -0
- package/dist/resources/extensions/subagent/configured-model.js +9 -0
- package/dist/resources/extensions/subagent/index.js +95 -144
- package/dist/resources/extensions/subagent/model-resolution.js +12 -0
- package/dist/resources/extensions/ttsr/ttsr-manager.js +1 -1
- package/dist/resources/skills/create-skill/SKILL.md +2 -2
- package/dist/resources/skills/create-skill/references/gsd-skill-ecosystem.md +8 -7
- package/dist/resources/skills/create-skill/workflows/audit-skill.md +4 -4
- package/dist/resources/skills/create-skill/workflows/create-new-skill.md +6 -5
- package/dist/shared-paths.d.ts +1 -0
- package/dist/shared-paths.js +17 -0
- package/dist/shared-preferences.d.ts +37 -0
- package/dist/shared-preferences.js +102 -0
- package/dist/welcome-screen.js +24 -18
- package/dist/worktree-cli.d.ts +4 -49
- package/dist/worktree-cli.js +197 -113
- package/package.json +6 -6
- package/packages/pi-coding-agent/dist/cli/args.d.ts +1 -1
- package/packages/pi-coding-agent/dist/cli/args.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/cli/args.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts +2 -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 +13 -1
- package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/auth-storage.js +35 -0
- package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/auth-storage.test.js +24 -0
- package/packages/pi-coding-agent/dist/core/auth-storage.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts +3 -0
- package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction/compaction.js +8 -0
- package/packages/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts +12 -0
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js +77 -15
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js +76 -0
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js.map +1 -0
- 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/package-manager.js +8 -8
- package/packages/pi-coding-agent/dist/core/package-manager.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/resource-loader-lsd-md.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/resource-loader-lsd-md.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/resource-loader-lsd-md.test.js +59 -0
- package/packages/pi-coding-agent/dist/core/resource-loader-lsd-md.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/resource-loader.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/resource-loader.js +32 -14
- package/packages/pi-coding-agent/dist/core/resource-loader.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +13 -3
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.js +25 -0
- package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/skills.d.ts +4 -6
- package/packages/pi-coding-agent/dist/core/skills.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/skills.js +18 -13
- package/packages/pi-coding-agent/dist/core/skills.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/slash-commands.js +1 -1
- package/packages/pi-coding-agent/dist/core/slash-commands.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tool-approval.d.ts +1 -1
- package/packages/pi-coding-agent/dist/core/tool-approval.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tool-approval.js +2 -0
- package/packages/pi-coding-agent/dist/core/tool-approval.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/main.js +1 -1
- package/packages/pi-coding-agent/dist/main.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.d.ts +5 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.js +11 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +11 -4
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.d.ts +7 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.js +33 -3
- package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts +6 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +129 -57
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +12 -3
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
- 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 +46 -6
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js +28 -20
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js.map +1 -1
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/cli/args.ts +1 -1
- package/packages/pi-coding-agent/src/core/agent-session.ts +14 -1
- package/packages/pi-coding-agent/src/core/auth-storage.test.ts +30 -0
- package/packages/pi-coding-agent/src/core/auth-storage.ts +36 -0
- package/packages/pi-coding-agent/src/core/compaction/compaction.ts +9 -0
- package/packages/pi-coding-agent/src/core/compaction-orchestrator.test.ts +87 -0
- package/packages/pi-coding-agent/src/core/compaction-orchestrator.ts +84 -16
- package/packages/pi-coding-agent/src/core/keybindings.ts +2 -2
- package/packages/pi-coding-agent/src/core/package-manager.ts +8 -8
- package/packages/pi-coding-agent/src/core/resource-loader-lsd-md.test.ts +67 -0
- package/packages/pi-coding-agent/src/core/resource-loader.ts +32 -13
- package/packages/pi-coding-agent/src/core/settings-manager.ts +39 -5
- package/packages/pi-coding-agent/src/core/skills.ts +20 -14
- package/packages/pi-coding-agent/src/core/slash-commands.ts +1 -1
- package/packages/pi-coding-agent/src/core/tool-approval.js +111 -0
- package/packages/pi-coding-agent/src/core/tool-approval.ts +2 -1
- package/packages/pi-coding-agent/src/index.ts +2 -0
- package/packages/pi-coding-agent/src/main.ts +1 -1
- package/packages/pi-coding-agent/src/modes/interactive/components/bash-execution.ts +14 -1
- package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +11 -5
- package/packages/pi-coding-agent/src/modes/interactive/components/settings-selector.ts +40 -3
- package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +135 -66
- package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +12 -3
- package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +70 -6
- package/packages/pi-coding-agent/src/modes/interactive/theme/themes.ts +28 -20
- package/pkg/dist/modes/interactive/theme/themes.d.ts.map +1 -1
- package/pkg/dist/modes/interactive/theme/themes.js +28 -20
- package/pkg/dist/modes/interactive/theme/themes.js.map +1 -1
- package/pkg/package.json +1 -1
- package/src/resources/agents/generic.md +29 -0
- package/src/resources/agents/scout.md +1 -0
- package/src/resources/extensions/ask-user-questions.ts +0 -3
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +6 -0
- package/src/resources/extensions/cmux/index.ts +29 -10
- package/src/resources/extensions/get-secrets-from-user.ts +2 -4
- package/src/resources/extensions/gsd/tests/test-helpers.ts +44 -44
- package/src/resources/extensions/remote-questions/config.ts +3 -3
- package/src/resources/extensions/remote-questions/remote-command.ts +4 -30
- package/src/resources/extensions/search-the-web/native-search.ts +2 -1
- package/src/resources/extensions/search-the-web/provider.ts +3 -10
- package/src/resources/extensions/shared/debug-logger.ts +102 -0
- package/src/resources/extensions/shared/env-utils.ts +18 -0
- package/src/resources/extensions/shared/paths.ts +15 -0
- package/src/resources/extensions/shared/preferences.ts +122 -0
- package/src/resources/extensions/shared/remote-questions-config.ts +30 -0
- package/src/resources/extensions/shared/rtk-session-stats.ts +2 -2
- package/src/resources/extensions/shared/secrets-manifest.ts +130 -0
- package/src/resources/extensions/slash-commands/extension-manifest.json +2 -1
- package/src/resources/extensions/slash-commands/index.ts +2 -0
- package/src/resources/extensions/slash-commands/plan.ts +328 -0
- package/src/resources/extensions/subagent/agents.ts +1 -1
- package/src/resources/extensions/subagent/approval-proxy.ts +70 -0
- package/src/resources/extensions/subagent/configured-model.ts +15 -0
- package/src/resources/extensions/subagent/index.ts +126 -185
- package/src/resources/extensions/subagent/model-resolution.ts +26 -0
- package/src/resources/extensions/ttsr/ttsr-manager.ts +1 -1
- package/src/resources/skills/create-skill/SKILL.md +2 -2
- package/src/resources/skills/create-skill/references/gsd-skill-ecosystem.md +8 -7
- package/src/resources/skills/create-skill/workflows/audit-skill.md +4 -4
- package/src/resources/skills/create-skill/workflows/create-new-skill.md +6 -5
- package/dist/resources/extensions/github-sync/cli.js +0 -284
- package/dist/resources/extensions/github-sync/index.js +0 -73
- package/dist/resources/extensions/github-sync/mapping.js +0 -67
- package/dist/resources/extensions/github-sync/sync.js +0 -425
- package/dist/resources/extensions/github-sync/templates.js +0 -118
- package/dist/resources/extensions/github-sync/types.js +0 -7
- package/dist/resources/extensions/gsd/activity-log.js +0 -153
- package/dist/resources/extensions/gsd/atomic-write.js +0 -134
- package/dist/resources/extensions/gsd/auto/detect-stuck.js +0 -49
- package/dist/resources/extensions/gsd/auto/infra-errors.js +0 -49
- package/dist/resources/extensions/gsd/auto/loop-deps.js +0 -6
- package/dist/resources/extensions/gsd/auto/loop.js +0 -256
- package/dist/resources/extensions/gsd/auto/phases.js +0 -942
- package/dist/resources/extensions/gsd/auto/resolve.js +0 -90
- package/dist/resources/extensions/gsd/auto/run-unit.js +0 -106
- package/dist/resources/extensions/gsd/auto/session.js +0 -171
- package/dist/resources/extensions/gsd/auto/types.js +0 -23
- package/dist/resources/extensions/gsd/auto-artifact-paths.js +0 -116
- package/dist/resources/extensions/gsd/auto-budget.js +0 -30
- package/dist/resources/extensions/gsd/auto-dashboard.js +0 -751
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +0 -212
- package/dist/resources/extensions/gsd/auto-dispatch.js +0 -627
- package/dist/resources/extensions/gsd/auto-loop.js +0 -13
- package/dist/resources/extensions/gsd/auto-model-selection.js +0 -192
- package/dist/resources/extensions/gsd/auto-observability.js +0 -54
- package/dist/resources/extensions/gsd/auto-post-unit.js +0 -548
- package/dist/resources/extensions/gsd/auto-prompts.js +0 -1686
- package/dist/resources/extensions/gsd/auto-recovery.js +0 -533
- package/dist/resources/extensions/gsd/auto-start.js +0 -544
- package/dist/resources/extensions/gsd/auto-supervisor.js +0 -73
- package/dist/resources/extensions/gsd/auto-timeout-recovery.js +0 -180
- package/dist/resources/extensions/gsd/auto-timers.js +0 -261
- package/dist/resources/extensions/gsd/auto-tool-tracking.js +0 -77
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +0 -30
- package/dist/resources/extensions/gsd/auto-utils.js +0 -20
- package/dist/resources/extensions/gsd/auto-verification.js +0 -163
- package/dist/resources/extensions/gsd/auto-worktree.js +0 -1645
- package/dist/resources/extensions/gsd/auto.js +0 -1087
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +0 -191
- package/dist/resources/extensions/gsd/bootstrap/db-tools.js +0 -1207
- package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +0 -149
- package/dist/resources/extensions/gsd/bootstrap/journal-tools.js +0 -62
- package/dist/resources/extensions/gsd/bootstrap/provider-error-resume.js +0 -18
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +0 -53
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +0 -267
- package/dist/resources/extensions/gsd/bootstrap/register-shortcuts.js +0 -45
- package/dist/resources/extensions/gsd/bootstrap/system-context.js +0 -367
- package/dist/resources/extensions/gsd/bootstrap/tool-call-loop-guard.js +0 -75
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +0 -105
- package/dist/resources/extensions/gsd/branch-patterns.js +0 -13
- package/dist/resources/extensions/gsd/cache.js +0 -27
- package/dist/resources/extensions/gsd/captures.js +0 -414
- package/dist/resources/extensions/gsd/changelog.js +0 -162
- package/dist/resources/extensions/gsd/claude-import.js +0 -591
- package/dist/resources/extensions/gsd/collision-diagnostics.js +0 -226
- package/dist/resources/extensions/gsd/commands/catalog.js +0 -336
- package/dist/resources/extensions/gsd/commands/context.js +0 -87
- package/dist/resources/extensions/gsd/commands/dispatcher.js +0 -21
- package/dist/resources/extensions/gsd/commands/handlers/auto.js +0 -175
- package/dist/resources/extensions/gsd/commands/handlers/core.js +0 -249
- package/dist/resources/extensions/gsd/commands/handlers/ops.js +0 -207
- package/dist/resources/extensions/gsd/commands/handlers/parallel.js +0 -106
- package/dist/resources/extensions/gsd/commands/handlers/workflow.js +0 -253
- package/dist/resources/extensions/gsd/commands/index.js +0 -11
- package/dist/resources/extensions/gsd/commands-bootstrap.js +0 -224
- package/dist/resources/extensions/gsd/commands-cmux.js +0 -120
- package/dist/resources/extensions/gsd/commands-config.js +0 -94
- package/dist/resources/extensions/gsd/commands-extensions.js +0 -260
- package/dist/resources/extensions/gsd/commands-handlers.js +0 -318
- package/dist/resources/extensions/gsd/commands-inspect.js +0 -77
- package/dist/resources/extensions/gsd/commands-logs.js +0 -468
- package/dist/resources/extensions/gsd/commands-maintenance.js +0 -485
- package/dist/resources/extensions/gsd/commands-mcp-status.js +0 -187
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +0 -664
- package/dist/resources/extensions/gsd/commands-rate.js +0 -31
- package/dist/resources/extensions/gsd/commands-workflow-templates.js +0 -408
- package/dist/resources/extensions/gsd/commands.js +0 -9
- package/dist/resources/extensions/gsd/complexity-classifier.js +0 -259
- package/dist/resources/extensions/gsd/constants.js +0 -15
- package/dist/resources/extensions/gsd/context-budget.js +0 -179
- package/dist/resources/extensions/gsd/context-injector.js +0 -74
- package/dist/resources/extensions/gsd/context-store.js +0 -166
- package/dist/resources/extensions/gsd/crash-recovery.js +0 -112
- package/dist/resources/extensions/gsd/custom-execution-policy.js +0 -48
- package/dist/resources/extensions/gsd/custom-verification.js +0 -147
- package/dist/resources/extensions/gsd/custom-workflow-engine.js +0 -165
- package/dist/resources/extensions/gsd/dashboard-overlay.js +0 -539
- package/dist/resources/extensions/gsd/db-writer.js +0 -518
- package/dist/resources/extensions/gsd/debug-logger.js +0 -161
- package/dist/resources/extensions/gsd/definition-loader.js +0 -352
- package/dist/resources/extensions/gsd/detection.js +0 -977
- package/dist/resources/extensions/gsd/dev-execution-policy.js +0 -24
- package/dist/resources/extensions/gsd/dev-workflow-engine.js +0 -82
- package/dist/resources/extensions/gsd/diff-context.js +0 -168
- package/dist/resources/extensions/gsd/dispatch-guard.js +0 -114
- package/dist/resources/extensions/gsd/docs/claude-marketplace-import.md +0 -214
- package/dist/resources/extensions/gsd/docs/preferences-reference.md +0 -671
- package/dist/resources/extensions/gsd/doctor-checks.js +0 -5
- package/dist/resources/extensions/gsd/doctor-engine-checks.js +0 -168
- package/dist/resources/extensions/gsd/doctor-environment.js +0 -565
- package/dist/resources/extensions/gsd/doctor-format.js +0 -86
- package/dist/resources/extensions/gsd/doctor-git-checks.js +0 -433
- package/dist/resources/extensions/gsd/doctor-global-checks.js +0 -74
- package/dist/resources/extensions/gsd/doctor-proactive.js +0 -349
- package/dist/resources/extensions/gsd/doctor-providers.js +0 -356
- package/dist/resources/extensions/gsd/doctor-runtime-checks.js +0 -601
- package/dist/resources/extensions/gsd/doctor-types.js +0 -15
- package/dist/resources/extensions/gsd/doctor.js +0 -765
- package/dist/resources/extensions/gsd/engine-resolver.js +0 -40
- package/dist/resources/extensions/gsd/engine-types.js +0 -8
- package/dist/resources/extensions/gsd/env-utils.js +0 -29
- package/dist/resources/extensions/gsd/error-classifier.js +0 -108
- package/dist/resources/extensions/gsd/error-utils.js +0 -6
- package/dist/resources/extensions/gsd/errors.js +0 -24
- package/dist/resources/extensions/gsd/execution-policy.js +0 -8
- package/dist/resources/extensions/gsd/exit-command.js +0 -22
- package/dist/resources/extensions/gsd/export-html.js +0 -1271
- package/dist/resources/extensions/gsd/export.js +0 -264
- package/dist/resources/extensions/gsd/extension-manifest.json +0 -33
- package/dist/resources/extensions/gsd/file-watcher.js +0 -80
- package/dist/resources/extensions/gsd/files.js +0 -863
- package/dist/resources/extensions/gsd/forensics.js +0 -996
- package/dist/resources/extensions/gsd/git-constants.js +0 -11
- package/dist/resources/extensions/gsd/git-self-heal.js +0 -113
- package/dist/resources/extensions/gsd/git-service.js +0 -586
- package/dist/resources/extensions/gsd/gitignore.js +0 -285
- package/dist/resources/extensions/gsd/graph.js +0 -225
- package/dist/resources/extensions/gsd/gsd-db.js +0 -1808
- package/dist/resources/extensions/gsd/guided-flow-queue.js +0 -365
- package/dist/resources/extensions/gsd/guided-flow.js +0 -1456
- package/dist/resources/extensions/gsd/health-widget-core.js +0 -89
- package/dist/resources/extensions/gsd/health-widget.js +0 -126
- package/dist/resources/extensions/gsd/history.js +0 -119
- package/dist/resources/extensions/gsd/index.js +0 -5
- package/dist/resources/extensions/gsd/init-wizard.js +0 -487
- package/dist/resources/extensions/gsd/journal.js +0 -85
- package/dist/resources/extensions/gsd/json-persistence.js +0 -70
- package/dist/resources/extensions/gsd/jsonl-utils.js +0 -24
- package/dist/resources/extensions/gsd/key-manager.js +0 -820
- package/dist/resources/extensions/gsd/markdown-renderer.js +0 -891
- package/dist/resources/extensions/gsd/marketplace-discovery.js +0 -356
- package/dist/resources/extensions/gsd/md-importer.js +0 -623
- package/dist/resources/extensions/gsd/memory-extractor.js +0 -302
- package/dist/resources/extensions/gsd/memory-store.js +0 -366
- package/dist/resources/extensions/gsd/metrics.js +0 -419
- package/dist/resources/extensions/gsd/migrate/command.js +0 -157
- package/dist/resources/extensions/gsd/migrate/index.js +0 -7
- package/dist/resources/extensions/gsd/migrate/parser.js +0 -268
- package/dist/resources/extensions/gsd/migrate/parsers.js +0 -477
- package/dist/resources/extensions/gsd/migrate/preview.js +0 -47
- package/dist/resources/extensions/gsd/migrate/transformer.js +0 -278
- package/dist/resources/extensions/gsd/migrate/types.js +0 -4
- package/dist/resources/extensions/gsd/migrate/validator.js +0 -41
- package/dist/resources/extensions/gsd/migrate/writer.js +0 -477
- package/dist/resources/extensions/gsd/migrate-external.js +0 -207
- package/dist/resources/extensions/gsd/milestone-actions.js +0 -130
- package/dist/resources/extensions/gsd/milestone-id-utils.js +0 -28
- package/dist/resources/extensions/gsd/milestone-ids.js +0 -116
- package/dist/resources/extensions/gsd/milestone-validation-gates.js +0 -45
- package/dist/resources/extensions/gsd/model-cost-table.js +0 -66
- package/dist/resources/extensions/gsd/model-router.js +0 -246
- package/dist/resources/extensions/gsd/namespaced-registry.js +0 -322
- package/dist/resources/extensions/gsd/namespaced-resolver.js +0 -176
- package/dist/resources/extensions/gsd/native-git-bridge.js +0 -992
- package/dist/resources/extensions/gsd/native-parser-bridge.js +0 -156
- package/dist/resources/extensions/gsd/notifications.js +0 -105
- package/dist/resources/extensions/gsd/observability-validator.js +0 -422
- package/dist/resources/extensions/gsd/package.json +0 -11
- package/dist/resources/extensions/gsd/parallel-eligibility.js +0 -188
- package/dist/resources/extensions/gsd/parallel-merge.js +0 -194
- package/dist/resources/extensions/gsd/parallel-monitor-overlay.js +0 -413
- package/dist/resources/extensions/gsd/parallel-orchestrator.js +0 -850
- package/dist/resources/extensions/gsd/parsers-legacy.js +0 -256
- package/dist/resources/extensions/gsd/paths.js +0 -527
- package/dist/resources/extensions/gsd/plugin-importer.js +0 -254
- package/dist/resources/extensions/gsd/post-unit-hooks.js +0 -48
- package/dist/resources/extensions/gsd/preferences-models.js +0 -295
- package/dist/resources/extensions/gsd/preferences-skills.js +0 -160
- package/dist/resources/extensions/gsd/preferences-types.js +0 -82
- package/dist/resources/extensions/gsd/preferences-validation.js +0 -852
- package/dist/resources/extensions/gsd/preferences.js +0 -432
- package/dist/resources/extensions/gsd/progress-score.js +0 -121
- package/dist/resources/extensions/gsd/prompt-cache-optimizer.js +0 -150
- package/dist/resources/extensions/gsd/prompt-loader.js +0 -156
- package/dist/resources/extensions/gsd/prompt-ordering.js +0 -170
- package/dist/resources/extensions/gsd/prompts/complete-milestone.md +0 -66
- package/dist/resources/extensions/gsd/prompts/complete-slice.md +0 -40
- package/dist/resources/extensions/gsd/prompts/discuss-headless.md +0 -253
- package/dist/resources/extensions/gsd/prompts/discuss.md +0 -290
- package/dist/resources/extensions/gsd/prompts/doctor-heal.md +0 -29
- package/dist/resources/extensions/gsd/prompts/execute-task.md +0 -80
- package/dist/resources/extensions/gsd/prompts/forensics.md +0 -196
- package/dist/resources/extensions/gsd/prompts/gate-evaluate.md +0 -32
- package/dist/resources/extensions/gsd/prompts/guided-complete-slice.md +0 -3
- package/dist/resources/extensions/gsd/prompts/guided-discuss-milestone.md +0 -110
- package/dist/resources/extensions/gsd/prompts/guided-discuss-slice.md +0 -62
- package/dist/resources/extensions/gsd/prompts/guided-execute-task.md +0 -3
- package/dist/resources/extensions/gsd/prompts/guided-plan-milestone.md +0 -30
- package/dist/resources/extensions/gsd/prompts/guided-plan-slice.md +0 -3
- package/dist/resources/extensions/gsd/prompts/guided-research-slice.md +0 -15
- package/dist/resources/extensions/gsd/prompts/guided-resume-task.md +0 -1
- package/dist/resources/extensions/gsd/prompts/heal-skill.md +0 -45
- package/dist/resources/extensions/gsd/prompts/plan-milestone.md +0 -108
- package/dist/resources/extensions/gsd/prompts/plan-slice.md +0 -89
- package/dist/resources/extensions/gsd/prompts/queue.md +0 -132
- package/dist/resources/extensions/gsd/prompts/quick-task.md +0 -44
- package/dist/resources/extensions/gsd/prompts/reactive-execute.md +0 -44
- package/dist/resources/extensions/gsd/prompts/reassess-roadmap.md +0 -66
- package/dist/resources/extensions/gsd/prompts/replan-slice.md +0 -39
- package/dist/resources/extensions/gsd/prompts/research-milestone.md +0 -47
- package/dist/resources/extensions/gsd/prompts/research-slice.md +0 -57
- package/dist/resources/extensions/gsd/prompts/rethink.md +0 -83
- package/dist/resources/extensions/gsd/prompts/review-migration.md +0 -66
- package/dist/resources/extensions/gsd/prompts/rewrite-docs.md +0 -31
- package/dist/resources/extensions/gsd/prompts/run-uat.md +0 -89
- package/dist/resources/extensions/gsd/prompts/system.md +0 -220
- package/dist/resources/extensions/gsd/prompts/triage-captures.md +0 -63
- package/dist/resources/extensions/gsd/prompts/validate-milestone.md +0 -47
- package/dist/resources/extensions/gsd/prompts/workflow-start.md +0 -28
- package/dist/resources/extensions/gsd/prompts/worktree-merge.md +0 -123
- package/dist/resources/extensions/gsd/provider-error-pause.js +0 -31
- package/dist/resources/extensions/gsd/queue-order.js +0 -178
- package/dist/resources/extensions/gsd/queue-reorder-ui.js +0 -235
- package/dist/resources/extensions/gsd/quick.js +0 -206
- package/dist/resources/extensions/gsd/reactive-graph.js +0 -257
- package/dist/resources/extensions/gsd/repo-identity.js +0 -641
- package/dist/resources/extensions/gsd/reports.js +0 -409
- package/dist/resources/extensions/gsd/rethink.js +0 -120
- package/dist/resources/extensions/gsd/roadmap-mutations.js +0 -110
- package/dist/resources/extensions/gsd/roadmap-slices.js +0 -255
- package/dist/resources/extensions/gsd/routing-history.js +0 -210
- package/dist/resources/extensions/gsd/rtk-status.js +0 -43
- package/dist/resources/extensions/gsd/rule-registry.js +0 -488
- package/dist/resources/extensions/gsd/rule-types.js +0 -6
- package/dist/resources/extensions/gsd/run-manager.js +0 -134
- package/dist/resources/extensions/gsd/safe-fs.js +0 -52
- package/dist/resources/extensions/gsd/service-tier.js +0 -158
- package/dist/resources/extensions/gsd/session-forensics.js +0 -435
- package/dist/resources/extensions/gsd/session-lock.js +0 -554
- package/dist/resources/extensions/gsd/session-status-io.js +0 -134
- package/dist/resources/extensions/gsd/skill-catalog.js +0 -1026
- package/dist/resources/extensions/gsd/skill-discovery.js +0 -122
- package/dist/resources/extensions/gsd/skill-health.js +0 -326
- package/dist/resources/extensions/gsd/skill-telemetry.js +0 -121
- package/dist/resources/extensions/gsd/skills/gsd-headless/SKILL.md +0 -242
- package/dist/resources/extensions/gsd/skills/gsd-headless/references/answer-injection.md +0 -83
- package/dist/resources/extensions/gsd/skills/gsd-headless/references/commands.md +0 -64
- package/dist/resources/extensions/gsd/skills/gsd-headless/references/multi-session.md +0 -176
- package/dist/resources/extensions/gsd/state.js +0 -1407
- package/dist/resources/extensions/gsd/status-guards.js +0 -12
- package/dist/resources/extensions/gsd/structured-data-formatter.js +0 -98
- package/dist/resources/extensions/gsd/sync-lock.js +0 -89
- package/dist/resources/extensions/gsd/templates/PREFERENCES.md +0 -80
- package/dist/resources/extensions/gsd/templates/context.md +0 -76
- package/dist/resources/extensions/gsd/templates/decisions.md +0 -8
- package/dist/resources/extensions/gsd/templates/knowledge.md +0 -19
- package/dist/resources/extensions/gsd/templates/milestone-summary.md +0 -81
- package/dist/resources/extensions/gsd/templates/milestone-validation.md +0 -74
- package/dist/resources/extensions/gsd/templates/plan.md +0 -148
- package/dist/resources/extensions/gsd/templates/project.md +0 -31
- package/dist/resources/extensions/gsd/templates/reassessment.md +0 -29
- package/dist/resources/extensions/gsd/templates/requirements.md +0 -81
- package/dist/resources/extensions/gsd/templates/research.md +0 -79
- package/dist/resources/extensions/gsd/templates/roadmap.md +0 -131
- package/dist/resources/extensions/gsd/templates/runtime.md +0 -21
- package/dist/resources/extensions/gsd/templates/secrets-manifest.md +0 -22
- package/dist/resources/extensions/gsd/templates/slice-context.md +0 -58
- package/dist/resources/extensions/gsd/templates/slice-summary.md +0 -108
- package/dist/resources/extensions/gsd/templates/state.md +0 -17
- package/dist/resources/extensions/gsd/templates/task-plan.md +0 -87
- package/dist/resources/extensions/gsd/templates/task-summary.md +0 -66
- package/dist/resources/extensions/gsd/templates/uat.md +0 -54
- package/dist/resources/extensions/gsd/tests/auto-supervisor.test.mjs +0 -53
- package/dist/resources/extensions/gsd/tests/dist-redirect.mjs +0 -112
- package/dist/resources/extensions/gsd/tests/resolve-ts-hooks.mjs +0 -23
- package/dist/resources/extensions/gsd/tests/resolve-ts.mjs +0 -5
- package/dist/resources/extensions/gsd/token-counter.js +0 -54
- package/dist/resources/extensions/gsd/tools/complete-milestone.js +0 -172
- package/dist/resources/extensions/gsd/tools/complete-slice.js +0 -276
- package/dist/resources/extensions/gsd/tools/complete-task.js +0 -205
- package/dist/resources/extensions/gsd/tools/plan-milestone.js +0 -250
- package/dist/resources/extensions/gsd/tools/plan-slice.js +0 -199
- package/dist/resources/extensions/gsd/tools/plan-task.js +0 -121
- package/dist/resources/extensions/gsd/tools/reassess-roadmap.js +0 -219
- package/dist/resources/extensions/gsd/tools/reopen-slice.js +0 -87
- package/dist/resources/extensions/gsd/tools/reopen-task.js +0 -91
- package/dist/resources/extensions/gsd/tools/replan-slice.js +0 -188
- package/dist/resources/extensions/gsd/tools/validate-milestone.js +0 -110
- package/dist/resources/extensions/gsd/triage-resolution.js +0 -322
- package/dist/resources/extensions/gsd/triage-ui.js +0 -135
- package/dist/resources/extensions/gsd/types.js +0 -4
- package/dist/resources/extensions/gsd/undo.js +0 -400
- package/dist/resources/extensions/gsd/unit-id.js +0 -7
- package/dist/resources/extensions/gsd/unit-ownership.js +0 -216
- package/dist/resources/extensions/gsd/unit-runtime.js +0 -132
- package/dist/resources/extensions/gsd/validate-directory.js +0 -143
- package/dist/resources/extensions/gsd/validation.js +0 -21
- package/dist/resources/extensions/gsd/verdict-parser.js +0 -96
- package/dist/resources/extensions/gsd/verification-evidence.js +0 -122
- package/dist/resources/extensions/gsd/verification-gate.js +0 -519
- package/dist/resources/extensions/gsd/visualizer-data.js +0 -674
- package/dist/resources/extensions/gsd/visualizer-overlay.js +0 -501
- package/dist/resources/extensions/gsd/visualizer-views.js +0 -945
- package/dist/resources/extensions/gsd/workflow-engine.js +0 -7
- package/dist/resources/extensions/gsd/workflow-events.js +0 -102
- package/dist/resources/extensions/gsd/workflow-logger.js +0 -192
- package/dist/resources/extensions/gsd/workflow-manifest.js +0 -263
- package/dist/resources/extensions/gsd/workflow-migration.js +0 -280
- package/dist/resources/extensions/gsd/workflow-projections.js +0 -405
- package/dist/resources/extensions/gsd/workflow-reconcile.js +0 -441
- package/dist/resources/extensions/gsd/workflow-templates/bugfix.md +0 -87
- package/dist/resources/extensions/gsd/workflow-templates/dep-upgrade.md +0 -74
- package/dist/resources/extensions/gsd/workflow-templates/full-project.md +0 -40
- package/dist/resources/extensions/gsd/workflow-templates/hotfix.md +0 -45
- package/dist/resources/extensions/gsd/workflow-templates/refactor.md +0 -83
- package/dist/resources/extensions/gsd/workflow-templates/registry.json +0 -85
- package/dist/resources/extensions/gsd/workflow-templates/security-audit.md +0 -73
- package/dist/resources/extensions/gsd/workflow-templates/small-feature.md +0 -81
- package/dist/resources/extensions/gsd/workflow-templates/spike.md +0 -69
- package/dist/resources/extensions/gsd/workflow-templates.js +0 -200
- package/dist/resources/extensions/gsd/workspace-index.js +0 -190
- package/dist/resources/extensions/gsd/worktree-command-bootstrap.js +0 -40
- package/dist/resources/extensions/gsd/worktree-command.js +0 -702
- package/dist/resources/extensions/gsd/worktree-health.js +0 -126
- package/dist/resources/extensions/gsd/worktree-manager.js +0 -518
- package/dist/resources/extensions/gsd/worktree-resolver.js +0 -480
- package/dist/resources/extensions/gsd/worktree.js +0 -310
- package/dist/resources/extensions/gsd/write-intercept.js +0 -84
- package/src/resources/extensions/github-sync/cli.ts +0 -364
- package/src/resources/extensions/github-sync/index.ts +0 -93
- package/src/resources/extensions/github-sync/mapping.ts +0 -81
- package/src/resources/extensions/github-sync/sync.ts +0 -557
- package/src/resources/extensions/github-sync/templates.ts +0 -183
- package/src/resources/extensions/github-sync/tests/cli.test.ts +0 -20
- package/src/resources/extensions/github-sync/tests/commit-linking.test.ts +0 -43
- package/src/resources/extensions/github-sync/tests/mapping.test.ts +0 -104
- package/src/resources/extensions/github-sync/tests/templates.test.ts +0 -110
- package/src/resources/extensions/github-sync/types.ts +0 -47
- package/src/resources/extensions/gsd/activity-log.ts +0 -163
- package/src/resources/extensions/gsd/atomic-write.ts +0 -185
- package/src/resources/extensions/gsd/auto/detect-stuck.ts +0 -60
- package/src/resources/extensions/gsd/auto/infra-errors.ts +0 -48
- package/src/resources/extensions/gsd/auto/loop-deps.ts +0 -268
- package/src/resources/extensions/gsd/auto/loop.ts +0 -318
- package/src/resources/extensions/gsd/auto/phases.ts +0 -1327
- package/src/resources/extensions/gsd/auto/resolve.ts +0 -106
- package/src/resources/extensions/gsd/auto/run-unit.ts +0 -136
- package/src/resources/extensions/gsd/auto/session.ts +0 -237
- package/src/resources/extensions/gsd/auto/types.ts +0 -117
- package/src/resources/extensions/gsd/auto-artifact-paths.ts +0 -135
- package/src/resources/extensions/gsd/auto-budget.ts +0 -32
- package/src/resources/extensions/gsd/auto-dashboard.ts +0 -880
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +0 -256
- package/src/resources/extensions/gsd/auto-dispatch.ts +0 -781
- package/src/resources/extensions/gsd/auto-loop.ts +0 -16
- package/src/resources/extensions/gsd/auto-model-selection.ts +0 -251
- package/src/resources/extensions/gsd/auto-observability.ts +0 -72
- package/src/resources/extensions/gsd/auto-post-unit.ts +0 -687
- package/src/resources/extensions/gsd/auto-prompts.ts +0 -1896
- package/src/resources/extensions/gsd/auto-recovery.ts +0 -594
- package/src/resources/extensions/gsd/auto-start.ts +0 -737
- package/src/resources/extensions/gsd/auto-supervisor.ts +0 -79
- package/src/resources/extensions/gsd/auto-timeout-recovery.ts +0 -262
- package/src/resources/extensions/gsd/auto-timers.ts +0 -313
- package/src/resources/extensions/gsd/auto-tool-tracking.ts +0 -85
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +0 -48
- package/src/resources/extensions/gsd/auto-utils.ts +0 -25
- package/src/resources/extensions/gsd/auto-verification.ts +0 -225
- package/src/resources/extensions/gsd/auto-worktree.ts +0 -1897
- package/src/resources/extensions/gsd/auto.ts +0 -1477
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +0 -219
- package/src/resources/extensions/gsd/bootstrap/db-tools.ts +0 -1286
- package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +0 -194
- package/src/resources/extensions/gsd/bootstrap/journal-tools.ts +0 -62
- package/src/resources/extensions/gsd/bootstrap/provider-error-resume.ts +0 -53
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +0 -61
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +0 -282
- package/src/resources/extensions/gsd/bootstrap/register-shortcuts.ts +0 -56
- package/src/resources/extensions/gsd/bootstrap/system-context.ts +0 -416
- package/src/resources/extensions/gsd/bootstrap/tool-call-loop-guard.ts +0 -91
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +0 -126
- package/src/resources/extensions/gsd/branch-patterns.ts +0 -16
- package/src/resources/extensions/gsd/cache.ts +0 -29
- package/src/resources/extensions/gsd/captures.ts +0 -502
- package/src/resources/extensions/gsd/changelog.ts +0 -213
- package/src/resources/extensions/gsd/claude-import.ts +0 -705
- package/src/resources/extensions/gsd/collision-diagnostics.ts +0 -332
- package/src/resources/extensions/gsd/commands/catalog.ts +0 -359
- package/src/resources/extensions/gsd/commands/context.ts +0 -108
- package/src/resources/extensions/gsd/commands/dispatcher.ts +0 -32
- package/src/resources/extensions/gsd/commands/handlers/auto.ts +0 -184
- package/src/resources/extensions/gsd/commands/handlers/core.ts +0 -277
- package/src/resources/extensions/gsd/commands/handlers/ops.ts +0 -210
- package/src/resources/extensions/gsd/commands/handlers/parallel.ts +0 -135
- package/src/resources/extensions/gsd/commands/handlers/workflow.ts +0 -281
- package/src/resources/extensions/gsd/commands/index.ts +0 -14
- package/src/resources/extensions/gsd/commands-bootstrap.ts +0 -253
- package/src/resources/extensions/gsd/commands-cmux.ts +0 -143
- package/src/resources/extensions/gsd/commands-config.ts +0 -108
- package/src/resources/extensions/gsd/commands-extensions.ts +0 -330
- package/src/resources/extensions/gsd/commands-handlers.ts +0 -404
- package/src/resources/extensions/gsd/commands-inspect.ts +0 -98
- package/src/resources/extensions/gsd/commands-logs.ts +0 -536
- package/src/resources/extensions/gsd/commands-maintenance.ts +0 -535
- package/src/resources/extensions/gsd/commands-mcp-status.ts +0 -247
- package/src/resources/extensions/gsd/commands-prefs-wizard.ts +0 -784
- package/src/resources/extensions/gsd/commands-rate.ts +0 -55
- package/src/resources/extensions/gsd/commands-workflow-templates.ts +0 -543
- package/src/resources/extensions/gsd/commands.ts +0 -17
- package/src/resources/extensions/gsd/complexity-classifier.ts +0 -322
- package/src/resources/extensions/gsd/constants.ts +0 -21
- package/src/resources/extensions/gsd/context-budget.ts +0 -256
- package/src/resources/extensions/gsd/context-injector.ts +0 -100
- package/src/resources/extensions/gsd/context-store.ts +0 -196
- package/src/resources/extensions/gsd/crash-recovery.ts +0 -120
- package/src/resources/extensions/gsd/custom-execution-policy.ts +0 -74
- package/src/resources/extensions/gsd/custom-verification.ts +0 -182
- package/src/resources/extensions/gsd/custom-workflow-engine.ts +0 -217
- package/src/resources/extensions/gsd/dashboard-overlay.ts +0 -659
- package/src/resources/extensions/gsd/db-writer.ts +0 -612
- package/src/resources/extensions/gsd/debug-logger.ts +0 -178
- package/src/resources/extensions/gsd/definition-loader.ts +0 -462
- package/src/resources/extensions/gsd/detection.ts +0 -1148
- package/src/resources/extensions/gsd/dev-execution-policy.ts +0 -51
- package/src/resources/extensions/gsd/dev-workflow-engine.ts +0 -110
- package/src/resources/extensions/gsd/diff-context.ts +0 -214
- package/src/resources/extensions/gsd/dispatch-guard.ts +0 -120
- package/src/resources/extensions/gsd/docs/claude-marketplace-import.md +0 -214
- package/src/resources/extensions/gsd/docs/preferences-reference.md +0 -671
- package/src/resources/extensions/gsd/doctor-checks.ts +0 -5
- package/src/resources/extensions/gsd/doctor-engine-checks.ts +0 -182
- package/src/resources/extensions/gsd/doctor-environment.ts +0 -642
- package/src/resources/extensions/gsd/doctor-format.ts +0 -98
- package/src/resources/extensions/gsd/doctor-git-checks.ts +0 -441
- package/src/resources/extensions/gsd/doctor-global-checks.ts +0 -84
- package/src/resources/extensions/gsd/doctor-proactive.ts +0 -431
- package/src/resources/extensions/gsd/doctor-providers.ts +0 -415
- package/src/resources/extensions/gsd/doctor-runtime-checks.ts +0 -627
- package/src/resources/extensions/gsd/doctor-types.ts +0 -123
- package/src/resources/extensions/gsd/doctor.ts +0 -808
- package/src/resources/extensions/gsd/engine-resolver.ts +0 -57
- package/src/resources/extensions/gsd/engine-types.ts +0 -71
- package/src/resources/extensions/gsd/env-utils.ts +0 -31
- package/src/resources/extensions/gsd/error-classifier.ts +0 -142
- package/src/resources/extensions/gsd/error-utils.ts +0 -6
- package/src/resources/extensions/gsd/errors.ts +0 -29
- package/src/resources/extensions/gsd/execution-policy.ts +0 -43
- package/src/resources/extensions/gsd/exit-command.ts +0 -30
- package/src/resources/extensions/gsd/export-html.ts +0 -1408
- package/src/resources/extensions/gsd/export.ts +0 -310
- package/src/resources/extensions/gsd/extension-manifest.json +0 -33
- package/src/resources/extensions/gsd/file-watcher.ts +0 -100
- package/src/resources/extensions/gsd/files.ts +0 -971
- package/src/resources/extensions/gsd/forensics.ts +0 -1178
- package/src/resources/extensions/gsd/git-constants.ts +0 -12
- package/src/resources/extensions/gsd/git-self-heal.ts +0 -127
- package/src/resources/extensions/gsd/git-service.ts +0 -755
- package/src/resources/extensions/gsd/gitignore.ts +0 -315
- package/src/resources/extensions/gsd/graph.ts +0 -312
- package/src/resources/extensions/gsd/gsd-db.ts +0 -2205
- package/src/resources/extensions/gsd/guided-flow-queue.ts +0 -439
- package/src/resources/extensions/gsd/guided-flow.ts +0 -1666
- package/src/resources/extensions/gsd/health-widget-core.ts +0 -111
- package/src/resources/extensions/gsd/health-widget.ts +0 -143
- package/src/resources/extensions/gsd/history.ts +0 -144
- package/src/resources/extensions/gsd/index.ts +0 -14
- package/src/resources/extensions/gsd/init-wizard.ts +0 -595
- package/src/resources/extensions/gsd/journal.ts +0 -139
- package/src/resources/extensions/gsd/json-persistence.ts +0 -75
- package/src/resources/extensions/gsd/jsonl-utils.ts +0 -21
- package/src/resources/extensions/gsd/key-manager.ts +0 -987
- package/src/resources/extensions/gsd/markdown-renderer.ts +0 -1132
- package/src/resources/extensions/gsd/marketplace-discovery.ts +0 -508
- package/src/resources/extensions/gsd/md-importer.ts +0 -742
- package/src/resources/extensions/gsd/memory-extractor.ts +0 -360
- package/src/resources/extensions/gsd/memory-store.ts +0 -452
- package/src/resources/extensions/gsd/metrics.ts +0 -575
- package/src/resources/extensions/gsd/migrate/command.ts +0 -219
- package/src/resources/extensions/gsd/migrate/index.ts +0 -42
- package/src/resources/extensions/gsd/migrate/parser.ts +0 -323
- package/src/resources/extensions/gsd/migrate/parsers.ts +0 -539
- package/src/resources/extensions/gsd/migrate/preview.ts +0 -48
- package/src/resources/extensions/gsd/migrate/transformer.ts +0 -346
- package/src/resources/extensions/gsd/migrate/types.ts +0 -370
- package/src/resources/extensions/gsd/migrate/validator.ts +0 -55
- package/src/resources/extensions/gsd/migrate/writer.ts +0 -579
- package/src/resources/extensions/gsd/migrate-external.ts +0 -210
- package/src/resources/extensions/gsd/milestone-actions.ts +0 -143
- package/src/resources/extensions/gsd/milestone-id-utils.ts +0 -32
- package/src/resources/extensions/gsd/milestone-ids.ts +0 -135
- package/src/resources/extensions/gsd/milestone-validation-gates.ts +0 -56
- package/src/resources/extensions/gsd/model-cost-table.ts +0 -84
- package/src/resources/extensions/gsd/model-router.ts +0 -315
- package/src/resources/extensions/gsd/namespaced-registry.ts +0 -467
- package/src/resources/extensions/gsd/namespaced-resolver.ts +0 -307
- package/src/resources/extensions/gsd/native-git-bridge.ts +0 -1197
- package/src/resources/extensions/gsd/native-parser-bridge.ts +0 -267
- package/src/resources/extensions/gsd/notifications.ts +0 -135
- package/src/resources/extensions/gsd/observability-validator.ts +0 -456
- package/src/resources/extensions/gsd/package.json +0 -11
- package/src/resources/extensions/gsd/parallel-eligibility.ts +0 -242
- package/src/resources/extensions/gsd/parallel-merge.ts +0 -240
- package/src/resources/extensions/gsd/parallel-monitor-overlay.ts +0 -497
- package/src/resources/extensions/gsd/parallel-orchestrator.ts +0 -1013
- package/src/resources/extensions/gsd/parsers-legacy.ts +0 -290
- package/src/resources/extensions/gsd/paths.ts +0 -561
- package/src/resources/extensions/gsd/plugin-importer.ts +0 -411
- package/src/resources/extensions/gsd/post-unit-hooks.ts +0 -86
- package/src/resources/extensions/gsd/preferences-models.ts +0 -330
- package/src/resources/extensions/gsd/preferences-skills.ts +0 -175
- package/src/resources/extensions/gsd/preferences-types.ts +0 -285
- package/src/resources/extensions/gsd/preferences-validation.ts +0 -823
- package/src/resources/extensions/gsd/preferences.ts +0 -539
- package/src/resources/extensions/gsd/progress-score.ts +0 -161
- package/src/resources/extensions/gsd/prompt-cache-optimizer.ts +0 -213
- package/src/resources/extensions/gsd/prompt-loader.ts +0 -169
- package/src/resources/extensions/gsd/prompt-ordering.ts +0 -200
- package/src/resources/extensions/gsd/prompts/complete-milestone.md +0 -66
- package/src/resources/extensions/gsd/prompts/complete-slice.md +0 -40
- package/src/resources/extensions/gsd/prompts/discuss-headless.md +0 -253
- package/src/resources/extensions/gsd/prompts/discuss.md +0 -290
- package/src/resources/extensions/gsd/prompts/doctor-heal.md +0 -29
- package/src/resources/extensions/gsd/prompts/execute-task.md +0 -80
- package/src/resources/extensions/gsd/prompts/forensics.md +0 -196
- package/src/resources/extensions/gsd/prompts/gate-evaluate.md +0 -32
- package/src/resources/extensions/gsd/prompts/guided-complete-slice.md +0 -3
- package/src/resources/extensions/gsd/prompts/guided-discuss-milestone.md +0 -110
- package/src/resources/extensions/gsd/prompts/guided-discuss-slice.md +0 -62
- package/src/resources/extensions/gsd/prompts/guided-execute-task.md +0 -3
- package/src/resources/extensions/gsd/prompts/guided-plan-milestone.md +0 -30
- package/src/resources/extensions/gsd/prompts/guided-plan-slice.md +0 -3
- package/src/resources/extensions/gsd/prompts/guided-research-slice.md +0 -15
- package/src/resources/extensions/gsd/prompts/guided-resume-task.md +0 -1
- package/src/resources/extensions/gsd/prompts/heal-skill.md +0 -45
- package/src/resources/extensions/gsd/prompts/plan-milestone.md +0 -108
- package/src/resources/extensions/gsd/prompts/plan-slice.md +0 -89
- package/src/resources/extensions/gsd/prompts/queue.md +0 -132
- package/src/resources/extensions/gsd/prompts/quick-task.md +0 -44
- package/src/resources/extensions/gsd/prompts/reactive-execute.md +0 -44
- package/src/resources/extensions/gsd/prompts/reassess-roadmap.md +0 -66
- package/src/resources/extensions/gsd/prompts/replan-slice.md +0 -39
- package/src/resources/extensions/gsd/prompts/research-milestone.md +0 -47
- package/src/resources/extensions/gsd/prompts/research-slice.md +0 -57
- package/src/resources/extensions/gsd/prompts/rethink.md +0 -83
- package/src/resources/extensions/gsd/prompts/review-migration.md +0 -66
- package/src/resources/extensions/gsd/prompts/rewrite-docs.md +0 -31
- package/src/resources/extensions/gsd/prompts/run-uat.md +0 -89
- package/src/resources/extensions/gsd/prompts/system.md +0 -220
- package/src/resources/extensions/gsd/prompts/triage-captures.md +0 -63
- package/src/resources/extensions/gsd/prompts/validate-milestone.md +0 -47
- package/src/resources/extensions/gsd/prompts/workflow-start.md +0 -28
- package/src/resources/extensions/gsd/prompts/worktree-merge.md +0 -123
- package/src/resources/extensions/gsd/provider-error-pause.ts +0 -49
- package/src/resources/extensions/gsd/queue-order.ts +0 -230
- package/src/resources/extensions/gsd/queue-reorder-ui.ts +0 -277
- package/src/resources/extensions/gsd/quick.ts +0 -257
- package/src/resources/extensions/gsd/reactive-graph.ts +0 -319
- package/src/resources/extensions/gsd/repo-identity.ts +0 -657
- package/src/resources/extensions/gsd/reports.ts +0 -504
- package/src/resources/extensions/gsd/rethink.ts +0 -160
- package/src/resources/extensions/gsd/roadmap-mutations.ts +0 -134
- package/src/resources/extensions/gsd/roadmap-slices.ts +0 -273
- package/src/resources/extensions/gsd/routing-history.ts +0 -286
- package/src/resources/extensions/gsd/rtk-status.ts +0 -53
- package/src/resources/extensions/gsd/rule-registry.ts +0 -598
- package/src/resources/extensions/gsd/rule-types.ts +0 -68
- package/src/resources/extensions/gsd/run-manager.ts +0 -180
- package/src/resources/extensions/gsd/safe-fs.ts +0 -47
- package/src/resources/extensions/gsd/service-tier.ts +0 -196
- package/src/resources/extensions/gsd/session-forensics.ts +0 -546
- package/src/resources/extensions/gsd/session-lock.ts +0 -640
- package/src/resources/extensions/gsd/session-status-io.ts +0 -179
- package/src/resources/extensions/gsd/skill-catalog.ts +0 -1085
- package/src/resources/extensions/gsd/skill-discovery.ts +0 -140
- package/src/resources/extensions/gsd/skill-health.ts +0 -418
- package/src/resources/extensions/gsd/skill-telemetry.ts +0 -137
- package/src/resources/extensions/gsd/skills/gsd-headless/SKILL.md +0 -242
- package/src/resources/extensions/gsd/skills/gsd-headless/references/answer-injection.md +0 -83
- package/src/resources/extensions/gsd/skills/gsd-headless/references/commands.md +0 -64
- package/src/resources/extensions/gsd/skills/gsd-headless/references/multi-session.md +0 -176
- package/src/resources/extensions/gsd/state.ts +0 -1554
- package/src/resources/extensions/gsd/status-guards.ts +0 -13
- package/src/resources/extensions/gsd/structured-data-formatter.ts +0 -146
- package/src/resources/extensions/gsd/sync-lock.ts +0 -94
- package/src/resources/extensions/gsd/templates/PREFERENCES.md +0 -80
- package/src/resources/extensions/gsd/templates/context.md +0 -76
- package/src/resources/extensions/gsd/templates/decisions.md +0 -8
- package/src/resources/extensions/gsd/templates/knowledge.md +0 -19
- package/src/resources/extensions/gsd/templates/milestone-summary.md +0 -81
- package/src/resources/extensions/gsd/templates/milestone-validation.md +0 -74
- package/src/resources/extensions/gsd/templates/plan.md +0 -148
- package/src/resources/extensions/gsd/templates/project.md +0 -31
- package/src/resources/extensions/gsd/templates/reassessment.md +0 -29
- package/src/resources/extensions/gsd/templates/requirements.md +0 -81
- package/src/resources/extensions/gsd/templates/research.md +0 -79
- package/src/resources/extensions/gsd/templates/roadmap.md +0 -131
- package/src/resources/extensions/gsd/templates/runtime.md +0 -21
- package/src/resources/extensions/gsd/templates/secrets-manifest.md +0 -22
- package/src/resources/extensions/gsd/templates/slice-context.md +0 -58
- package/src/resources/extensions/gsd/templates/slice-summary.md +0 -108
- package/src/resources/extensions/gsd/templates/state.md +0 -17
- package/src/resources/extensions/gsd/templates/task-plan.md +0 -87
- package/src/resources/extensions/gsd/templates/task-summary.md +0 -66
- package/src/resources/extensions/gsd/templates/uat.md +0 -54
- package/src/resources/extensions/gsd/tests/active-milestone-id-guard.test.ts +0 -91
- package/src/resources/extensions/gsd/tests/activity-log.test.ts +0 -175
- package/src/resources/extensions/gsd/tests/agent-end-retry.test.ts +0 -143
- package/src/resources/extensions/gsd/tests/atomic-write.test.ts +0 -144
- package/src/resources/extensions/gsd/tests/auto-budget-alerts.test.ts +0 -50
- package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +0 -211
- package/src/resources/extensions/gsd/tests/auto-lock-creation.test.ts +0 -213
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +0 -2307
- package/src/resources/extensions/gsd/tests/auto-milestone-target.test.ts +0 -61
- package/src/resources/extensions/gsd/tests/auto-mode-interactive-guard.test.ts +0 -71
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +0 -209
- package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +0 -129
- package/src/resources/extensions/gsd/tests/auto-pr-bugs.test.ts +0 -88
- package/src/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +0 -255
- package/src/resources/extensions/gsd/tests/auto-stale-lock-self-kill.test.ts +0 -87
- package/src/resources/extensions/gsd/tests/auto-start-cold-db-bootstrap.test.ts +0 -37
- package/src/resources/extensions/gsd/tests/auto-start-model-capture.test.ts +0 -28
- package/src/resources/extensions/gsd/tests/auto-start-needs-discussion.test.ts +0 -218
- package/src/resources/extensions/gsd/tests/auto-supervisor.test.mjs +0 -53
- package/src/resources/extensions/gsd/tests/auto-worktree-auto-resolve.test.ts +0 -80
- package/src/resources/extensions/gsd/tests/autocomplete-regressions-1675.test.ts +0 -83
- package/src/resources/extensions/gsd/tests/browser-teardown.test.ts +0 -133
- package/src/resources/extensions/gsd/tests/budget-prediction.test.ts +0 -220
- package/src/resources/extensions/gsd/tests/bundled-workflow-defs.test.ts +0 -180
- package/src/resources/extensions/gsd/tests/cache-staleness-regression.test.ts +0 -294
- package/src/resources/extensions/gsd/tests/captures.test.ts +0 -524
- package/src/resources/extensions/gsd/tests/claude-import-marketplace-discovery.test.ts +0 -191
- package/src/resources/extensions/gsd/tests/claude-import-tui.test.ts +0 -350
- package/src/resources/extensions/gsd/tests/cli-provider-rate-limit.test.ts +0 -47
- package/src/resources/extensions/gsd/tests/cmux.test.ts +0 -215
- package/src/resources/extensions/gsd/tests/collect-from-manifest.test.ts +0 -506
- package/src/resources/extensions/gsd/tests/collision-diagnostics.test.ts +0 -705
- package/src/resources/extensions/gsd/tests/commands-config.test.ts +0 -24
- package/src/resources/extensions/gsd/tests/commands-inspect-open-db.test.ts +0 -46
- package/src/resources/extensions/gsd/tests/commands-logs.test.ts +0 -241
- package/src/resources/extensions/gsd/tests/commands-workflow-custom.test.ts +0 -283
- package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +0 -311
- package/src/resources/extensions/gsd/tests/complete-slice.test.ts +0 -432
- package/src/resources/extensions/gsd/tests/complete-task-rollback-evidence.test.ts +0 -106
- package/src/resources/extensions/gsd/tests/complete-task.test.ts +0 -454
- package/src/resources/extensions/gsd/tests/completed-units-metrics-sync.test.ts +0 -111
- package/src/resources/extensions/gsd/tests/completion-hierarchy-guards.test.ts +0 -192
- package/src/resources/extensions/gsd/tests/complexity-classifier.test.ts +0 -181
- package/src/resources/extensions/gsd/tests/context-budget.test.ts +0 -352
- package/src/resources/extensions/gsd/tests/context-injector.test.ts +0 -313
- package/src/resources/extensions/gsd/tests/context-store.test.ts +0 -454
- package/src/resources/extensions/gsd/tests/cost-projection.test.ts +0 -120
- package/src/resources/extensions/gsd/tests/crash-recovery.test.ts +0 -122
- package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +0 -535
- package/src/resources/extensions/gsd/tests/custom-verification.test.ts +0 -415
- package/src/resources/extensions/gsd/tests/custom-workflow-engine.test.ts +0 -339
- package/src/resources/extensions/gsd/tests/dashboard-budget.test.ts +0 -329
- package/src/resources/extensions/gsd/tests/dashboard-custom-engine.test.ts +0 -87
- package/src/resources/extensions/gsd/tests/db-path-worktree-symlink.test.ts +0 -131
- package/src/resources/extensions/gsd/tests/db-writer.test.ts +0 -656
- package/src/resources/extensions/gsd/tests/debug-logger.test.ts +0 -185
- package/src/resources/extensions/gsd/tests/definition-loader.test.ts +0 -762
- package/src/resources/extensions/gsd/tests/derive-state-crossval.test.ts +0 -512
- package/src/resources/extensions/gsd/tests/derive-state-db-disk-reconcile.test.ts +0 -121
- package/src/resources/extensions/gsd/tests/derive-state-db.test.ts +0 -1127
- package/src/resources/extensions/gsd/tests/derive-state-deps.test.ts +0 -641
- package/src/resources/extensions/gsd/tests/derive-state-draft.test.ts +0 -310
- package/src/resources/extensions/gsd/tests/derive-state.test.ts +0 -982
- package/src/resources/extensions/gsd/tests/detection.test.ts +0 -1190
- package/src/resources/extensions/gsd/tests/dev-engine-wrapper.test.ts +0 -314
- package/src/resources/extensions/gsd/tests/diff-context.test.ts +0 -136
- package/src/resources/extensions/gsd/tests/discord-invite-links.test.ts +0 -47
- package/src/resources/extensions/gsd/tests/discuss-empty-db-fallback.test.ts +0 -127
- package/src/resources/extensions/gsd/tests/discuss-prompt.test.ts +0 -15
- package/src/resources/extensions/gsd/tests/discuss-queued-milestones.test.ts +0 -281
- package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +0 -265
- package/src/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +0 -126
- package/src/resources/extensions/gsd/tests/dispatch-uat-last-completed.test.ts +0 -172
- package/src/resources/extensions/gsd/tests/dist-redirect.mjs +0 -112
- package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +0 -603
- package/src/resources/extensions/gsd/tests/double-merge-guard.test.ts +0 -97
- package/src/resources/extensions/gsd/tests/draft-promotion.test.ts +0 -169
- package/src/resources/extensions/gsd/tests/dynamic-routing-default.test.ts +0 -20
- package/src/resources/extensions/gsd/tests/empty-content-abort-loop.test.ts +0 -74
- package/src/resources/extensions/gsd/tests/engine-interfaces-contract.test.ts +0 -271
- package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +0 -164
- package/src/resources/extensions/gsd/tests/est-annotation-timeout.test.ts +0 -120
- package/src/resources/extensions/gsd/tests/event-replay-idempotency.test.ts +0 -140
- package/src/resources/extensions/gsd/tests/exit-command.test.ts +0 -101
- package/src/resources/extensions/gsd/tests/export-html-all.test.ts +0 -105
- package/src/resources/extensions/gsd/tests/export-html-enhancements.test.ts +0 -379
- package/src/resources/extensions/gsd/tests/extension-selector-separator.test.ts +0 -144
- package/src/resources/extensions/gsd/tests/files-loadfile-eisdir.test.ts +0 -18
- package/src/resources/extensions/gsd/tests/flag-file-db.test.ts +0 -278
- package/src/resources/extensions/gsd/tests/forensics-context-persist.test.ts +0 -129
- package/src/resources/extensions/gsd/tests/forensics-db-completion.test.ts +0 -96
- package/src/resources/extensions/gsd/tests/forensics-dedup.test.ts +0 -79
- package/src/resources/extensions/gsd/tests/forensics-error-filter.test.ts +0 -121
- package/src/resources/extensions/gsd/tests/forensics-issue-routing.test.ts +0 -43
- package/src/resources/extensions/gsd/tests/forensics-journal.test.ts +0 -162
- package/src/resources/extensions/gsd/tests/freeform-decisions.test.ts +0 -232
- package/src/resources/extensions/gsd/tests/gate-dispatch.test.ts +0 -189
- package/src/resources/extensions/gsd/tests/gate-storage.test.ts +0 -156
- package/src/resources/extensions/gsd/tests/graph-operations.test.ts +0 -593
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +0 -351
- package/src/resources/extensions/gsd/tests/gsd-inspect.test.ts +0 -114
- package/src/resources/extensions/gsd/tests/gsd-recover.test.ts +0 -440
- package/src/resources/extensions/gsd/tests/gsd-tools.test.ts +0 -406
- package/src/resources/extensions/gsd/tests/gsdroot-worktree-detection.test.ts +0 -164
- package/src/resources/extensions/gsd/tests/guided-flow-dynamic-routing.test.ts +0 -135
- package/src/resources/extensions/gsd/tests/guided-flow-session-isolation.test.ts +0 -97
- package/src/resources/extensions/gsd/tests/headless-answers.test.ts +0 -340
- package/src/resources/extensions/gsd/tests/headless-query.test.ts +0 -184
- package/src/resources/extensions/gsd/tests/health-widget.test.ts +0 -179
- package/src/resources/extensions/gsd/tests/hook-key-parsing.test.ts +0 -107
- package/src/resources/extensions/gsd/tests/hook-model-resolution.test.ts +0 -98
- package/src/resources/extensions/gsd/tests/idle-watchdog-stall-override.test.ts +0 -125
- package/src/resources/extensions/gsd/tests/in-flight-tool-tracking.test.ts +0 -32
- package/src/resources/extensions/gsd/tests/infra-error.test.ts +0 -129
- package/src/resources/extensions/gsd/tests/init-wizard.test.ts +0 -195
- package/src/resources/extensions/gsd/tests/integration/all-milestones-complete-merge.test.ts +0 -248
- package/src/resources/extensions/gsd/tests/integration/atomic-task-closeout.test.ts +0 -72
- package/src/resources/extensions/gsd/tests/integration/auto-preflight.test.ts +0 -38
- package/src/resources/extensions/gsd/tests/integration/auto-recovery.test.ts +0 -825
- package/src/resources/extensions/gsd/tests/integration/auto-secrets-gate.test.ts +0 -194
- package/src/resources/extensions/gsd/tests/integration/auto-stash-merge.test.ts +0 -121
- package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +0 -759
- package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +0 -348
- package/src/resources/extensions/gsd/tests/integration/continue-here.test.ts +0 -281
- package/src/resources/extensions/gsd/tests/integration/doctor-completion-deferral.test.ts +0 -88
- package/src/resources/extensions/gsd/tests/integration/doctor-delimiter-fix.test.ts +0 -83
- package/src/resources/extensions/gsd/tests/integration/doctor-enhancements.test.ts +0 -243
- package/src/resources/extensions/gsd/tests/integration/doctor-environment-worktree.test.ts +0 -164
- package/src/resources/extensions/gsd/tests/integration/doctor-environment.test.ts +0 -403
- package/src/resources/extensions/gsd/tests/integration/doctor-false-positives.test.ts +0 -243
- package/src/resources/extensions/gsd/tests/integration/doctor-fixlevel.test.ts +0 -212
- package/src/resources/extensions/gsd/tests/integration/doctor-git.test.ts +0 -653
- package/src/resources/extensions/gsd/tests/integration/doctor-proactive.test.ts +0 -325
- package/src/resources/extensions/gsd/tests/integration/doctor-roadmap-summary-atomicity.test.ts +0 -123
- package/src/resources/extensions/gsd/tests/integration/doctor-runtime.test.ts +0 -377
- package/src/resources/extensions/gsd/tests/integration/doctor.test.ts +0 -612
- package/src/resources/extensions/gsd/tests/integration/e2e-workflow-pipeline-integration.test.ts +0 -476
- package/src/resources/extensions/gsd/tests/integration/feature-branch-lifecycle-integration.test.ts +0 -415
- package/src/resources/extensions/gsd/tests/integration/git-locale.test.ts +0 -119
- package/src/resources/extensions/gsd/tests/integration/git-self-heal.test.ts +0 -131
- package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +0 -1458
- package/src/resources/extensions/gsd/tests/integration/gitignore-staging-2570.test.ts +0 -150
- package/src/resources/extensions/gsd/tests/integration/gitignore-tracked-gsd.test.ts +0 -256
- package/src/resources/extensions/gsd/tests/integration/headless-command.ts +0 -534
- package/src/resources/extensions/gsd/tests/integration/idle-recovery.test.ts +0 -359
- package/src/resources/extensions/gsd/tests/integration/inherited-repo-home-dir.test.ts +0 -191
- package/src/resources/extensions/gsd/tests/integration/integration-lifecycle.test.ts +0 -266
- package/src/resources/extensions/gsd/tests/integration/integration-mixed-milestones.test.ts +0 -539
- package/src/resources/extensions/gsd/tests/integration/integration-proof.test.ts +0 -634
- package/src/resources/extensions/gsd/tests/integration/migrate-command.test.ts +0 -360
- package/src/resources/extensions/gsd/tests/integration/milestone-transition-worktree.test.ts +0 -166
- package/src/resources/extensions/gsd/tests/integration/parallel-merge.test.ts +0 -577
- package/src/resources/extensions/gsd/tests/integration/parallel-workers-multi-milestone-e2e.test.ts +0 -337
- package/src/resources/extensions/gsd/tests/integration/paths.test.ts +0 -98
- package/src/resources/extensions/gsd/tests/integration/plugin-importer-live.test.ts +0 -481
- package/src/resources/extensions/gsd/tests/integration/queue-completed-milestone-perf.test.ts +0 -155
- package/src/resources/extensions/gsd/tests/integration/queue-reorder-e2e.test.ts +0 -335
- package/src/resources/extensions/gsd/tests/integration/quick-branch-lifecycle.test.ts +0 -253
- package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +0 -609
- package/src/resources/extensions/gsd/tests/integration/state-machine-live-validation.test.ts +0 -959
- package/src/resources/extensions/gsd/tests/integration/token-savings.test.ts +0 -364
- package/src/resources/extensions/gsd/tests/integration/worktree-e2e.test.ts +0 -237
- package/src/resources/extensions/gsd/tests/integration-edge.test.ts +0 -223
- package/src/resources/extensions/gsd/tests/interactive-tool-idle-exemption.test.ts +0 -119
- package/src/resources/extensions/gsd/tests/iterate-engine-integration.test.ts +0 -429
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +0 -601
- package/src/resources/extensions/gsd/tests/journal-query-tool.test.ts +0 -147
- package/src/resources/extensions/gsd/tests/journal.test.ts +0 -341
- package/src/resources/extensions/gsd/tests/json-persistence-atomic.test.ts +0 -183
- package/src/resources/extensions/gsd/tests/key-manager.test.ts +0 -429
- package/src/resources/extensions/gsd/tests/knowledge.test.ts +0 -250
- package/src/resources/extensions/gsd/tests/lazy-pi-tui-import.test.ts +0 -15
- package/src/resources/extensions/gsd/tests/manifest-status.test.ts +0 -274
- package/src/resources/extensions/gsd/tests/markdown-renderer.test.ts +0 -1161
- package/src/resources/extensions/gsd/tests/marketplace-test-fixtures.ts +0 -91
- package/src/resources/extensions/gsd/tests/mcp-status.test.ts +0 -103
- package/src/resources/extensions/gsd/tests/md-importer.test.ts +0 -416
- package/src/resources/extensions/gsd/tests/memory-extractor.test.ts +0 -254
- package/src/resources/extensions/gsd/tests/memory-leak-guards.test.ts +0 -91
- package/src/resources/extensions/gsd/tests/memory-store.test.ts +0 -332
- package/src/resources/extensions/gsd/tests/merge-conflict-stops-loop.test.ts +0 -66
- package/src/resources/extensions/gsd/tests/metrics.test.ts +0 -384
- package/src/resources/extensions/gsd/tests/migrate-external-worktree.test.ts +0 -105
- package/src/resources/extensions/gsd/tests/migrate-hierarchy.test.ts +0 -429
- package/src/resources/extensions/gsd/tests/migrate-parser.test.ts +0 -748
- package/src/resources/extensions/gsd/tests/migrate-transformer.test.ts +0 -619
- package/src/resources/extensions/gsd/tests/migrate-validator-parsers.test.ts +0 -390
- package/src/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +0 -295
- package/src/resources/extensions/gsd/tests/migrate-writer.test.ts +0 -361
- package/src/resources/extensions/gsd/tests/milestone-id-reservation.test.ts +0 -73
- package/src/resources/extensions/gsd/tests/milestone-report-path.test.ts +0 -51
- package/src/resources/extensions/gsd/tests/milestone-status-authoritative.test.ts +0 -140
- package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +0 -130
- package/src/resources/extensions/gsd/tests/model-cost-table.test.ts +0 -103
- package/src/resources/extensions/gsd/tests/model-isolation.test.ts +0 -157
- package/src/resources/extensions/gsd/tests/model-router.test.ts +0 -272
- package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +0 -220
- package/src/resources/extensions/gsd/tests/must-have-parser.test.ts +0 -278
- package/src/resources/extensions/gsd/tests/namespaced-registry.test.ts +0 -1027
- package/src/resources/extensions/gsd/tests/namespaced-resolver.test.ts +0 -671
- package/src/resources/extensions/gsd/tests/native-has-changes-cache.test.ts +0 -61
- package/src/resources/extensions/gsd/tests/next-milestone-id.test.ts +0 -23
- package/src/resources/extensions/gsd/tests/none-mode-gates.test.ts +0 -152
- package/src/resources/extensions/gsd/tests/notifications.test.ts +0 -134
- package/src/resources/extensions/gsd/tests/overrides.test.ts +0 -124
- package/src/resources/extensions/gsd/tests/parallel-budget-atomicity.test.ts +0 -330
- package/src/resources/extensions/gsd/tests/parallel-commit-scope.test.ts +0 -159
- package/src/resources/extensions/gsd/tests/parallel-crash-recovery.test.ts +0 -284
- package/src/resources/extensions/gsd/tests/parallel-eligibility-ghost.test.ts +0 -150
- package/src/resources/extensions/gsd/tests/parallel-monitor-overlay.test.ts +0 -60
- package/src/resources/extensions/gsd/tests/parallel-orchestration.test.ts +0 -736
- package/src/resources/extensions/gsd/tests/parallel-orchestrator-zombie-cleanup.test.ts +0 -277
- package/src/resources/extensions/gsd/tests/parallel-worker-lock-contention.test.ts +0 -226
- package/src/resources/extensions/gsd/tests/parallel-worker-monitoring.test.ts +0 -199
- package/src/resources/extensions/gsd/tests/park-db-sync.test.ts +0 -85
- package/src/resources/extensions/gsd/tests/park-edge-cases.test.ts +0 -253
- package/src/resources/extensions/gsd/tests/park-milestone.test.ts +0 -354
- package/src/resources/extensions/gsd/tests/parsers.test.ts +0 -1867
- package/src/resources/extensions/gsd/tests/phases-merge-error-stops-auto.test.ts +0 -103
- package/src/resources/extensions/gsd/tests/plan-milestone-queue-context.test.ts +0 -48
- package/src/resources/extensions/gsd/tests/plan-milestone-title.test.ts +0 -70
- package/src/resources/extensions/gsd/tests/plan-milestone.test.ts +0 -231
- package/src/resources/extensions/gsd/tests/plan-quality-validator.test.ts +0 -474
- package/src/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +0 -298
- package/src/resources/extensions/gsd/tests/plan-slice.test.ts +0 -179
- package/src/resources/extensions/gsd/tests/plan-task.test.ts +0 -145
- package/src/resources/extensions/gsd/tests/planning-crossval.test.ts +0 -305
- package/src/resources/extensions/gsd/tests/plugin-importer.test.ts +0 -1383
- package/src/resources/extensions/gsd/tests/post-mutation-hook.test.ts +0 -171
- package/src/resources/extensions/gsd/tests/post-unit-hooks.test.ts +0 -300
- package/src/resources/extensions/gsd/tests/preferences-worktree-sync.test.ts +0 -133
- package/src/resources/extensions/gsd/tests/preferences.test.ts +0 -463
- package/src/resources/extensions/gsd/tests/preflight-context-draft-filter.test.ts +0 -115
- package/src/resources/extensions/gsd/tests/project-relocation-recovery.test.ts +0 -297
- package/src/resources/extensions/gsd/tests/projection-regression.test.ts +0 -174
- package/src/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +0 -464
- package/src/resources/extensions/gsd/tests/prompt-cache-optimizer.test.ts +0 -314
- package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +0 -239
- package/src/resources/extensions/gsd/tests/prompt-db.test.ts +0 -387
- package/src/resources/extensions/gsd/tests/prompt-loader-replacement.test.ts +0 -178
- package/src/resources/extensions/gsd/tests/prompt-ordering.test.ts +0 -296
- package/src/resources/extensions/gsd/tests/prompt-tool-names.test.ts +0 -69
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +0 -479
- package/src/resources/extensions/gsd/tests/quality-gates.test.ts +0 -347
- package/src/resources/extensions/gsd/tests/queue-draft-detection.test.ts +0 -100
- package/src/resources/extensions/gsd/tests/queue-execution-guard.test.ts +0 -157
- package/src/resources/extensions/gsd/tests/queue-order.test.ts +0 -192
- package/src/resources/extensions/gsd/tests/quick-auto-guard.test.ts +0 -100
- package/src/resources/extensions/gsd/tests/quick-turn-end-cleanup.test.ts +0 -90
- package/src/resources/extensions/gsd/tests/rate-limit-model-fallback.test.ts +0 -90
- package/src/resources/extensions/gsd/tests/reactive-executor.test.ts +0 -511
- package/src/resources/extensions/gsd/tests/reactive-graph.test.ts +0 -299
- package/src/resources/extensions/gsd/tests/reassess-detection.test.ts +0 -154
- package/src/resources/extensions/gsd/tests/reassess-handler.test.ts +0 -442
- package/src/resources/extensions/gsd/tests/reassess-prompt.test.ts +0 -135
- package/src/resources/extensions/gsd/tests/reconciliation-edge-cases.test.ts +0 -162
- package/src/resources/extensions/gsd/tests/recovery-attempts-reset.test.ts +0 -176
- package/src/resources/extensions/gsd/tests/regex-hardening.test.ts +0 -281
- package/src/resources/extensions/gsd/tests/register-extension-guard.test.ts +0 -59
- package/src/resources/extensions/gsd/tests/remediation-completion-guard.test.ts +0 -110
- package/src/resources/extensions/gsd/tests/remote-questions.test.ts +0 -755
- package/src/resources/extensions/gsd/tests/remote-status.test.ts +0 -99
- package/src/resources/extensions/gsd/tests/reopen-slice.test.ts +0 -155
- package/src/resources/extensions/gsd/tests/reopen-task.test.ts +0 -165
- package/src/resources/extensions/gsd/tests/replan-handler.test.ts +0 -410
- package/src/resources/extensions/gsd/tests/replan-slice.test.ts +0 -606
- package/src/resources/extensions/gsd/tests/repo-identity-worktree.test.ts +0 -231
- package/src/resources/extensions/gsd/tests/requirements.test.ts +0 -101
- package/src/resources/extensions/gsd/tests/resolve-ts-hooks.mjs +0 -23
- package/src/resources/extensions/gsd/tests/resolve-ts.mjs +0 -5
- package/src/resources/extensions/gsd/tests/retry-diagnostic-reasoning.test.ts +0 -161
- package/src/resources/extensions/gsd/tests/retry-state-reset.test.ts +0 -305
- package/src/resources/extensions/gsd/tests/rewrite-count-persist.test.ts +0 -82
- package/src/resources/extensions/gsd/tests/roadmap-parse-regression.test.ts +0 -399
- package/src/resources/extensions/gsd/tests/roadmap-slices.test.ts +0 -395
- package/src/resources/extensions/gsd/tests/rogue-file-detection.test.ts +0 -296
- package/src/resources/extensions/gsd/tests/routing-history.test.ts +0 -229
- package/src/resources/extensions/gsd/tests/rule-registry.test.ts +0 -411
- package/src/resources/extensions/gsd/tests/run-manager.test.ts +0 -229
- package/src/resources/extensions/gsd/tests/schema-v9-sequence.test.ts +0 -176
- package/src/resources/extensions/gsd/tests/secure-env-collect.test.ts +0 -319
- package/src/resources/extensions/gsd/tests/service-tier.test.ts +0 -127
- package/src/resources/extensions/gsd/tests/session-lock-multipath.test.ts +0 -166
- package/src/resources/extensions/gsd/tests/session-lock-regression.test.ts +0 -315
- package/src/resources/extensions/gsd/tests/session-lock-transient-read.test.ts +0 -224
- package/src/resources/extensions/gsd/tests/shared-wal.test.ts +0 -209
- package/src/resources/extensions/gsd/tests/sidecar-queue.test.ts +0 -181
- package/src/resources/extensions/gsd/tests/signal-handlers.test.ts +0 -103
- package/src/resources/extensions/gsd/tests/skill-activation.test.ts +0 -233
- package/src/resources/extensions/gsd/tests/skill-catalog.test.ts +0 -193
- package/src/resources/extensions/gsd/tests/skill-lifecycle.test.ts +0 -126
- package/src/resources/extensions/gsd/tests/slice-disk-reconcile.test.ts +0 -233
- package/src/resources/extensions/gsd/tests/smart-entry-complete.test.ts +0 -53
- package/src/resources/extensions/gsd/tests/smart-entry-draft.test.ts +0 -123
- package/src/resources/extensions/gsd/tests/sqlite-unavailable-gate.test.ts +0 -65
- package/src/resources/extensions/gsd/tests/stale-milestone-id-reservation.test.ts +0 -79
- package/src/resources/extensions/gsd/tests/stale-worktree-cwd.test.ts +0 -139
- package/src/resources/extensions/gsd/tests/stalled-tool-recovery.test.ts +0 -100
- package/src/resources/extensions/gsd/tests/stash-pop-gsd-conflict.test.ts +0 -125
- package/src/resources/extensions/gsd/tests/stash-queued-context-files.test.ts +0 -305
- package/src/resources/extensions/gsd/tests/state-corruption-2945.test.ts +0 -405
- package/src/resources/extensions/gsd/tests/state-derivation-parity.test.ts +0 -257
- package/src/resources/extensions/gsd/tests/state-machine-full-walkthrough.test.ts +0 -1628
- package/src/resources/extensions/gsd/tests/status-guards.test.ts +0 -30
- package/src/resources/extensions/gsd/tests/stop-auto-merge-back.test.ts +0 -67
- package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +0 -106
- package/src/resources/extensions/gsd/tests/stop-auto-remote.test.ts +0 -158
- package/src/resources/extensions/gsd/tests/structured-data-formatter.test.ts +0 -366
- package/src/resources/extensions/gsd/tests/stuck-detection-coverage.test.ts +0 -174
- package/src/resources/extensions/gsd/tests/subagent-agent-discovery.test.ts +0 -44
- package/src/resources/extensions/gsd/tests/summary-render-parity.test.ts +0 -221
- package/src/resources/extensions/gsd/tests/survivor-branch-complete.test.ts +0 -108
- package/src/resources/extensions/gsd/tests/symlink-numbered-variants.test.ts +0 -145
- package/src/resources/extensions/gsd/tests/sync-lock.test.ts +0 -122
- package/src/resources/extensions/gsd/tests/terminated-transient.test.ts +0 -84
- package/src/resources/extensions/gsd/tests/test-utils.ts +0 -165
- package/src/resources/extensions/gsd/tests/token-cost-display.test.ts +0 -118
- package/src/resources/extensions/gsd/tests/token-counter.test.ts +0 -129
- package/src/resources/extensions/gsd/tests/token-profile.test.ts +0 -268
- package/src/resources/extensions/gsd/tests/tool-call-loop-guard.test.ts +0 -166
- package/src/resources/extensions/gsd/tests/tool-naming.test.ts +0 -125
- package/src/resources/extensions/gsd/tests/triage-dispatch.test.ts +0 -345
- package/src/resources/extensions/gsd/tests/triage-resolution.test.ts +0 -563
- package/src/resources/extensions/gsd/tests/uat-stuck-loop-orphaned-worktree.test.ts +0 -289
- package/src/resources/extensions/gsd/tests/unborn-branch.test.ts +0 -85
- package/src/resources/extensions/gsd/tests/undo.test.ts +0 -462
- package/src/resources/extensions/gsd/tests/unique-milestone-ids.test.ts +0 -203
- package/src/resources/extensions/gsd/tests/unit-ownership.test.ts +0 -258
- package/src/resources/extensions/gsd/tests/unit-runtime.test.ts +0 -257
- package/src/resources/extensions/gsd/tests/update-command.test.ts +0 -67
- package/src/resources/extensions/gsd/tests/vacuous-truth-slices.test.ts +0 -115
- package/src/resources/extensions/gsd/tests/vacuum-recovery.test.ts +0 -154
- package/src/resources/extensions/gsd/tests/validate-directory.test.ts +0 -237
- package/src/resources/extensions/gsd/tests/validate-milestone-write-order.test.ts +0 -115
- package/src/resources/extensions/gsd/tests/validate-milestone.test.ts +0 -393
- package/src/resources/extensions/gsd/tests/validation-gate-patterns.test.ts +0 -166
- package/src/resources/extensions/gsd/tests/validation.test.ts +0 -72
- package/src/resources/extensions/gsd/tests/verdict-parser.test.ts +0 -156
- package/src/resources/extensions/gsd/tests/verification-evidence.test.ts +0 -601
- package/src/resources/extensions/gsd/tests/verification-gate.test.ts +0 -999
- package/src/resources/extensions/gsd/tests/verification-operational-gate.test.ts +0 -82
- package/src/resources/extensions/gsd/tests/visualizer-critical-path.test.ts +0 -143
- package/src/resources/extensions/gsd/tests/visualizer-data.test.ts +0 -444
- package/src/resources/extensions/gsd/tests/visualizer-overlay.test.ts +0 -235
- package/src/resources/extensions/gsd/tests/visualizer-views.test.ts +0 -716
- package/src/resources/extensions/gsd/tests/windows-path-normalization.test.ts +0 -97
- package/src/resources/extensions/gsd/tests/worker-registry.test.ts +0 -146
- package/src/resources/extensions/gsd/tests/workflow-events.test.ts +0 -205
- package/src/resources/extensions/gsd/tests/workflow-logger.test.ts +0 -403
- package/src/resources/extensions/gsd/tests/workflow-manifest.test.ts +0 -278
- package/src/resources/extensions/gsd/tests/workflow-projections.test.ts +0 -173
- package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +0 -171
- package/src/resources/extensions/gsd/tests/workspace-index.test.ts +0 -38
- package/src/resources/extensions/gsd/tests/worktree-bugfix.test.ts +0 -117
- package/src/resources/extensions/gsd/tests/worktree-db-integration.test.ts +0 -202
- package/src/resources/extensions/gsd/tests/worktree-db-respawn-truncation.test.ts +0 -140
- package/src/resources/extensions/gsd/tests/worktree-db-same-file.test.ts +0 -175
- package/src/resources/extensions/gsd/tests/worktree-db.test.ts +0 -445
- package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +0 -142
- package/src/resources/extensions/gsd/tests/worktree-health.test.ts +0 -181
- package/src/resources/extensions/gsd/tests/worktree-integration.test.ts +0 -200
- package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +0 -220
- package/src/resources/extensions/gsd/tests/worktree-manager.test.ts +0 -238
- package/src/resources/extensions/gsd/tests/worktree-nested-git-safety.test.ts +0 -101
- package/src/resources/extensions/gsd/tests/worktree-post-create-hook.test.ts +0 -165
- package/src/resources/extensions/gsd/tests/worktree-preferences-sync.test.ts +0 -155
- package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +0 -962
- package/src/resources/extensions/gsd/tests/worktree-submodule-safety.test.ts +0 -65
- package/src/resources/extensions/gsd/tests/worktree-symlink-removal.test.ts +0 -133
- package/src/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +0 -617
- package/src/resources/extensions/gsd/tests/worktree-sync-overwrite-loop.test.ts +0 -204
- package/src/resources/extensions/gsd/tests/worktree-sync-tasks.test.ts +0 -206
- package/src/resources/extensions/gsd/tests/worktree.test.ts +0 -279
- package/src/resources/extensions/gsd/tests/write-gate.test.ts +0 -193
- package/src/resources/extensions/gsd/tests/write-intercept.test.ts +0 -76
- package/src/resources/extensions/gsd/tests/zombie-gsd-state.test.ts +0 -95
- package/src/resources/extensions/gsd/token-counter.ts +0 -65
- package/src/resources/extensions/gsd/tools/complete-milestone.ts +0 -229
- package/src/resources/extensions/gsd/tools/complete-slice.ts +0 -340
- package/src/resources/extensions/gsd/tools/complete-task.ts +0 -257
- package/src/resources/extensions/gsd/tools/plan-milestone.ts +0 -304
- package/src/resources/extensions/gsd/tools/plan-slice.ts +0 -250
- package/src/resources/extensions/gsd/tools/plan-task.ts +0 -152
- package/src/resources/extensions/gsd/tools/reassess-roadmap.ts +0 -288
- package/src/resources/extensions/gsd/tools/reopen-slice.ts +0 -126
- package/src/resources/extensions/gsd/tools/reopen-task.ts +0 -130
- package/src/resources/extensions/gsd/tools/replan-slice.ts +0 -243
- package/src/resources/extensions/gsd/tools/validate-milestone.ts +0 -156
- package/src/resources/extensions/gsd/triage-resolution.ts +0 -413
- package/src/resources/extensions/gsd/triage-ui.ts +0 -187
- package/src/resources/extensions/gsd/types.ts +0 -593
- package/src/resources/extensions/gsd/undo.ts +0 -464
- package/src/resources/extensions/gsd/unit-id.ts +0 -14
- package/src/resources/extensions/gsd/unit-ownership.ts +0 -275
- package/src/resources/extensions/gsd/unit-runtime.ts +0 -189
- package/src/resources/extensions/gsd/validate-directory.ts +0 -164
- package/src/resources/extensions/gsd/validation.ts +0 -23
- package/src/resources/extensions/gsd/verdict-parser.ts +0 -110
- package/src/resources/extensions/gsd/verification-evidence.ts +0 -202
- package/src/resources/extensions/gsd/verification-gate.ts +0 -634
- package/src/resources/extensions/gsd/visualizer-data.ts +0 -953
- package/src/resources/extensions/gsd/visualizer-overlay.ts +0 -566
- package/src/resources/extensions/gsd/visualizer-views.ts +0 -1229
- package/src/resources/extensions/gsd/workflow-engine.ts +0 -38
- package/src/resources/extensions/gsd/workflow-events.ts +0 -154
- package/src/resources/extensions/gsd/workflow-logger.ts +0 -244
- package/src/resources/extensions/gsd/workflow-manifest.ts +0 -351
- package/src/resources/extensions/gsd/workflow-migration.ts +0 -345
- package/src/resources/extensions/gsd/workflow-projections.ts +0 -458
- package/src/resources/extensions/gsd/workflow-reconcile.ts +0 -532
- package/src/resources/extensions/gsd/workflow-templates/bugfix.md +0 -87
- package/src/resources/extensions/gsd/workflow-templates/dep-upgrade.md +0 -74
- package/src/resources/extensions/gsd/workflow-templates/full-project.md +0 -40
- package/src/resources/extensions/gsd/workflow-templates/hotfix.md +0 -45
- package/src/resources/extensions/gsd/workflow-templates/refactor.md +0 -83
- package/src/resources/extensions/gsd/workflow-templates/registry.json +0 -85
- package/src/resources/extensions/gsd/workflow-templates/security-audit.md +0 -73
- package/src/resources/extensions/gsd/workflow-templates/small-feature.md +0 -81
- package/src/resources/extensions/gsd/workflow-templates/spike.md +0 -69
- package/src/resources/extensions/gsd/workflow-templates.ts +0 -252
- package/src/resources/extensions/gsd/workspace-index.ts +0 -272
- package/src/resources/extensions/gsd/worktree-command-bootstrap.ts +0 -46
- package/src/resources/extensions/gsd/worktree-command.ts +0 -846
- package/src/resources/extensions/gsd/worktree-health.ts +0 -178
- package/src/resources/extensions/gsd/worktree-manager.ts +0 -630
- package/src/resources/extensions/gsd/worktree-resolver.ts +0 -640
- package/src/resources/extensions/gsd/worktree.ts +0 -336
- package/src/resources/extensions/gsd/write-intercept.ts +0 -90
|
@@ -1,1456 +0,0 @@
|
|
|
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 code-owned prompt text.
|
|
6
|
-
* No execution state, no hooks, no tools — the LLM does the rest.
|
|
7
|
-
*/
|
|
8
|
-
import { showNextAction } from "../shared/tui.js";
|
|
9
|
-
import { loadFile } from "./files.js";
|
|
10
|
-
import { isDbAvailable, getMilestoneSlices } from "./gsd-db.js";
|
|
11
|
-
import { parseRoadmapSlices } from "./roadmap-slices.js";
|
|
12
|
-
import { loadPrompt, inlineTemplate } from "./prompt-loader.js";
|
|
13
|
-
import { buildSkillActivationBlock } from "./auto-prompts.js";
|
|
14
|
-
import { deriveState } from "./state.js";
|
|
15
|
-
import { invalidateAllCaches } from "./cache.js";
|
|
16
|
-
import { startAuto } from "./auto.js";
|
|
17
|
-
import { readCrashLock, clearLock, formatCrashInfo } from "./crash-recovery.js";
|
|
18
|
-
import { listUnitRuntimeRecords, clearUnitRuntimeRecord } from "./unit-runtime.js";
|
|
19
|
-
import { resolveExpectedArtifactPath } from "./auto.js";
|
|
20
|
-
import { gsdRoot, milestonesDir, resolveMilestoneFile, resolveSliceFile, resolveSlicePath, resolveGsdRootFile, relGsdRootFile, relMilestoneFile, relSliceFile, } from "./paths.js";
|
|
21
|
-
import { join } from "node:path";
|
|
22
|
-
import { readFileSync, existsSync, mkdirSync, readdirSync, unlinkSync } from "node:fs";
|
|
23
|
-
import { readSessionLockData, isSessionLockProcessAlive } from "./session-lock.js";
|
|
24
|
-
import { nativeIsRepo, nativeInit } from "./native-git-bridge.js";
|
|
25
|
-
import { isInheritedRepo } from "./repo-identity.js";
|
|
26
|
-
import { ensureGitignore, ensurePreferences, untrackRuntimeFiles } from "./gitignore.js";
|
|
27
|
-
import { loadEffectiveGSDPreferences } from "./preferences.js";
|
|
28
|
-
import { detectProjectState } from "./detection.js";
|
|
29
|
-
import { showProjectInit, offerMigration } from "./init-wizard.js";
|
|
30
|
-
import { validateDirectory } from "./validate-directory.js";
|
|
31
|
-
import { showConfirm } from "../shared/tui.js";
|
|
32
|
-
import { debugLog } from "./debug-logger.js";
|
|
33
|
-
import { findMilestoneIds, nextMilestoneId, reserveMilestoneId, getReservedMilestoneIds, clearReservedMilestoneIds } from "./milestone-ids.js";
|
|
34
|
-
import { parkMilestone, discardMilestone } from "./milestone-actions.js";
|
|
35
|
-
import { selectAndApplyModel } from "./auto-model-selection.js";
|
|
36
|
-
// ─── Re-exports (preserve public API for existing importers) ────────────────
|
|
37
|
-
export { MILESTONE_ID_RE, generateMilestoneSuffix, nextMilestoneId, extractMilestoneSeq, parseMilestoneId, milestoneIdSort, maxMilestoneNum, findMilestoneIds, reserveMilestoneId, claimReservedId, getReservedMilestoneIds, clearReservedMilestoneIds, } from "./milestone-ids.js";
|
|
38
|
-
export { showQueue, handleQueueReorder, showQueueAdd, buildExistingMilestonesContext, } from "./guided-flow-queue.js";
|
|
39
|
-
import { getErrorMessage } from "./error-utils.js";
|
|
40
|
-
// ─── ID Generation with Reservation ─────────────────────────────────────────
|
|
41
|
-
/**
|
|
42
|
-
* Generate the next milestone ID, accounting for reserved IDs, and reserve it.
|
|
43
|
-
* Ensures any preview ID shown in the UI matches what `gsd_milestone_generate_id`
|
|
44
|
-
* will later return.
|
|
45
|
-
*/
|
|
46
|
-
function nextMilestoneIdReserved(existingIds, uniqueEnabled) {
|
|
47
|
-
const allIds = [...new Set([...existingIds, ...getReservedMilestoneIds()])];
|
|
48
|
-
const id = nextMilestoneId(allIds, uniqueEnabled);
|
|
49
|
-
reserveMilestoneId(id);
|
|
50
|
-
return id;
|
|
51
|
-
}
|
|
52
|
-
// ─── Commit Instruction Helpers ──────────────────────────────────────────────
|
|
53
|
-
/** Build commit instruction for planning prompts. .gsd/ is managed externally and always gitignored. */
|
|
54
|
-
function buildDocsCommitInstruction(_message) {
|
|
55
|
-
return "Do not commit planning artifacts — .gsd/ is managed externally.";
|
|
56
|
-
}
|
|
57
|
-
const pendingAutoStartMap = new Map();
|
|
58
|
-
/**
|
|
59
|
-
* Backward-compat bridge: returns a mutable reference to the entry matching
|
|
60
|
-
* basePath, or the sole entry when only one session exists.
|
|
61
|
-
* Internal use only — external code should use the Map directly.
|
|
62
|
-
*/
|
|
63
|
-
function _getPendingAutoStart(basePath) {
|
|
64
|
-
if (basePath)
|
|
65
|
-
return pendingAutoStartMap.get(basePath) ?? null;
|
|
66
|
-
if (pendingAutoStartMap.size === 1)
|
|
67
|
-
return pendingAutoStartMap.values().next().value;
|
|
68
|
-
return null;
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Store pending auto-start state for a project.
|
|
72
|
-
* Exported for testing (#2985).
|
|
73
|
-
*/
|
|
74
|
-
export function setPendingAutoStart(basePath, entry) {
|
|
75
|
-
pendingAutoStartMap.set(basePath, entry);
|
|
76
|
-
}
|
|
77
|
-
/**
|
|
78
|
-
* Clear pending auto-start state.
|
|
79
|
-
* If basePath is given, clears only that project. Otherwise clears all.
|
|
80
|
-
* Exported for testing (#2985).
|
|
81
|
-
*/
|
|
82
|
-
export function clearPendingAutoStart(basePath) {
|
|
83
|
-
if (basePath) {
|
|
84
|
-
pendingAutoStartMap.delete(basePath);
|
|
85
|
-
}
|
|
86
|
-
else {
|
|
87
|
-
pendingAutoStartMap.clear();
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* Returns the milestoneId being discussed for the given project.
|
|
92
|
-
* When basePath is omitted and only one session is active, returns that
|
|
93
|
-
* session's milestoneId for backward compatibility. Returns null when
|
|
94
|
-
* multiple sessions exist and basePath is not specified (#2985 Bug 4).
|
|
95
|
-
*/
|
|
96
|
-
export function getDiscussionMilestoneId(basePath) {
|
|
97
|
-
if (basePath) {
|
|
98
|
-
return pendingAutoStartMap.get(basePath)?.milestoneId ?? null;
|
|
99
|
-
}
|
|
100
|
-
// Backward compat: return the sole entry's milestoneId, or null if ambiguous
|
|
101
|
-
if (pendingAutoStartMap.size === 1) {
|
|
102
|
-
return pendingAutoStartMap.values().next().value.milestoneId;
|
|
103
|
-
}
|
|
104
|
-
return null;
|
|
105
|
-
}
|
|
106
|
-
/** Called from agent_end to check if auto-mode should start after discuss */
|
|
107
|
-
export function checkAutoStartAfterDiscuss() {
|
|
108
|
-
const entry = _getPendingAutoStart();
|
|
109
|
-
if (!entry)
|
|
110
|
-
return false;
|
|
111
|
-
const { ctx, pi, basePath, milestoneId, step } = entry;
|
|
112
|
-
// Gate 1: Primary milestone must have CONTEXT.md or ROADMAP.md
|
|
113
|
-
// The "discuss" path creates CONTEXT.md; the "plan" path creates ROADMAP.md.
|
|
114
|
-
const contextFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT");
|
|
115
|
-
const roadmapFile = resolveMilestoneFile(basePath, milestoneId, "ROADMAP");
|
|
116
|
-
if (!contextFile && !roadmapFile)
|
|
117
|
-
return false; // neither artifact yet — keep waiting
|
|
118
|
-
// Gate 2: STATE.md must exist — written as the last step in the discuss
|
|
119
|
-
// output phase. This prevents auto-start from firing during Phase 3
|
|
120
|
-
// (sequential readiness gates for remaining milestones) in multi-milestone
|
|
121
|
-
// discussions, where M001-CONTEXT.md exists but M002/M003 haven't been
|
|
122
|
-
// processed yet.
|
|
123
|
-
const stateFile = resolveGsdRootFile(basePath, "STATE");
|
|
124
|
-
if (!stateFile)
|
|
125
|
-
return false; // discussion not finalized yet
|
|
126
|
-
// Gate 3: Multi-milestone completeness warning
|
|
127
|
-
// Parse PROJECT.md for milestone sequence, warn if any are missing context.
|
|
128
|
-
// Don't block — milestones can be intentionally queued without context.
|
|
129
|
-
const projectFile = resolveGsdRootFile(basePath, "PROJECT");
|
|
130
|
-
if (projectFile) {
|
|
131
|
-
try {
|
|
132
|
-
const projectContent = readFileSync(projectFile, "utf-8");
|
|
133
|
-
const milestoneIds = parseMilestoneSequenceFromProject(projectContent);
|
|
134
|
-
if (milestoneIds.length > 1) {
|
|
135
|
-
const missing = milestoneIds.filter(id => {
|
|
136
|
-
const hasContext = !!resolveMilestoneFile(basePath, id, "CONTEXT");
|
|
137
|
-
const hasDraft = !!resolveMilestoneFile(basePath, id, "CONTEXT-DRAFT");
|
|
138
|
-
const hasDir = existsSync(join(gsdRoot(basePath), "milestones", id));
|
|
139
|
-
return !hasContext && !hasDraft && !hasDir;
|
|
140
|
-
});
|
|
141
|
-
if (missing.length > 0) {
|
|
142
|
-
ctx.ui.notify(`Multi-milestone validation: ${missing.join(", ")} not found in filesystem. ` +
|
|
143
|
-
`Discussion may not have completed all readiness gates.`, "warning");
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
catch { /* non-fatal — PROJECT.md parsing failure shouldn't block auto-start */ }
|
|
148
|
-
}
|
|
149
|
-
// Gate 4: Discussion manifest process verification (multi-milestone only)
|
|
150
|
-
// The LLM writes DISCUSSION-MANIFEST.json after each Phase 3 gate decision.
|
|
151
|
-
// If the manifest exists but gates_completed < total, the LLM hasn't finished
|
|
152
|
-
// presenting all readiness gates to the user — block auto-start.
|
|
153
|
-
const manifestPath = join(gsdRoot(basePath), "DISCUSSION-MANIFEST.json");
|
|
154
|
-
if (existsSync(manifestPath)) {
|
|
155
|
-
try {
|
|
156
|
-
const manifest = JSON.parse(readFileSync(manifestPath, "utf-8"));
|
|
157
|
-
const total = typeof manifest.total === "number" ? manifest.total : 0;
|
|
158
|
-
const completed = typeof manifest.gates_completed === "number" ? manifest.gates_completed : 0;
|
|
159
|
-
if (total > 1 && completed < total) {
|
|
160
|
-
// Discussion not complete — block auto-start until all gates are done
|
|
161
|
-
return false;
|
|
162
|
-
}
|
|
163
|
-
// Cross-check manifest milestones against PROJECT.md if available
|
|
164
|
-
if (projectFile) {
|
|
165
|
-
const projectContent = readFileSync(projectFile, "utf-8");
|
|
166
|
-
const projectIds = parseMilestoneSequenceFromProject(projectContent);
|
|
167
|
-
const manifestIds = Object.keys(manifest.milestones ?? {});
|
|
168
|
-
const untracked = projectIds.filter(id => !manifestIds.includes(id));
|
|
169
|
-
if (untracked.length > 0) {
|
|
170
|
-
ctx.ui.notify(`Discussion manifest missing gates for: ${untracked.join(", ")}`, "warning");
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
catch { /* malformed manifest — warn but don't block */ }
|
|
175
|
-
}
|
|
176
|
-
// Draft promotion cleanup: if a CONTEXT-DRAFT.md exists alongside the new
|
|
177
|
-
// CONTEXT.md, delete the draft — it's been consumed by the discussion.
|
|
178
|
-
try {
|
|
179
|
-
const draftFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT-DRAFT");
|
|
180
|
-
if (draftFile)
|
|
181
|
-
unlinkSync(draftFile);
|
|
182
|
-
}
|
|
183
|
-
catch { /* non-fatal — stale draft doesn't break anything, CONTEXT.md wins */ }
|
|
184
|
-
// Cleanup: remove discussion manifest after auto-start (only needed during discussion)
|
|
185
|
-
try {
|
|
186
|
-
unlinkSync(manifestPath);
|
|
187
|
-
}
|
|
188
|
-
catch { /* may not exist for single-milestone */ }
|
|
189
|
-
pendingAutoStartMap.delete(basePath);
|
|
190
|
-
ctx.ui.notify(`Milestone ${milestoneId} ready.`, "info");
|
|
191
|
-
startAuto(ctx, pi, basePath, false, { step }).catch((err) => {
|
|
192
|
-
ctx.ui.notify(`Auto-start failed: ${getErrorMessage(err)}`, "error");
|
|
193
|
-
if (process.env.GSD_DEBUG)
|
|
194
|
-
console.error('[gsd] auto start error:', err);
|
|
195
|
-
debugLog("auto-start-failed", { error: getErrorMessage(err) });
|
|
196
|
-
});
|
|
197
|
-
return true;
|
|
198
|
-
}
|
|
199
|
-
/**
|
|
200
|
-
* Extract milestone IDs from PROJECT.md milestone sequence table.
|
|
201
|
-
* Looks for rows like "| M001 | Name | Status |" and extracts the ID column.
|
|
202
|
-
*/
|
|
203
|
-
function parseMilestoneSequenceFromProject(content) {
|
|
204
|
-
const ids = [];
|
|
205
|
-
const lines = content.split(/\r?\n/);
|
|
206
|
-
for (const line of lines) {
|
|
207
|
-
const match = line.match(/^\|\s*(M\d{3}[A-Z0-9-]*)\s*\|/);
|
|
208
|
-
if (match)
|
|
209
|
-
ids.push(match[1]);
|
|
210
|
-
}
|
|
211
|
-
return ids;
|
|
212
|
-
}
|
|
213
|
-
// ─── Helpers ──────────────────────────────────────────────────────────────────
|
|
214
|
-
/**
|
|
215
|
-
* Dispatch guided-flow work to the LLM with a contextual note.
|
|
216
|
-
* This is the only way the wizard triggers work — everything else is the LLM's job.
|
|
217
|
-
*
|
|
218
|
-
* When a unitType is provided, resolves the user's model preference for that
|
|
219
|
-
* phase (e.g., models.planning → "plan-milestone", models.discuss → "discuss-milestone") and applies it before
|
|
220
|
-
* dispatching. This ensures guided-flow dispatches respect the same
|
|
221
|
-
* per-phase model preferences that auto-mode uses.
|
|
222
|
-
*/
|
|
223
|
-
async function dispatchWorkflow(pi, note, customType = "gsd-run", ctx, unitType) {
|
|
224
|
-
// Route through the dynamic routing pipeline (complexity classification,
|
|
225
|
-
// tier downgrade, fallback chains) — same path as auto-mode dispatches (#2958).
|
|
226
|
-
if (ctx && unitType) {
|
|
227
|
-
const prefs = loadEffectiveGSDPreferences()?.preferences;
|
|
228
|
-
const result = await selectAndApplyModel(ctx, pi, unitType, /* unitId */ "", /* basePath */ process.cwd(), prefs, /* verbose */ false, /* autoModeStartModel */ null);
|
|
229
|
-
if (result.appliedModel) {
|
|
230
|
-
debugLog("guided-flow-model-applied", {
|
|
231
|
-
unitType,
|
|
232
|
-
model: `${result.appliedModel.provider}/${result.appliedModel.id}`,
|
|
233
|
-
routing: result.routing,
|
|
234
|
-
});
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
pi.sendMessage({
|
|
238
|
-
customType,
|
|
239
|
-
content: `Execute the following GSD task exactly.\n\n${note}`,
|
|
240
|
-
display: false,
|
|
241
|
-
}, { triggerTurn: true });
|
|
242
|
-
}
|
|
243
|
-
/**
|
|
244
|
-
* Resolve a model ID string to a model object from available models.
|
|
245
|
-
* Handles "provider/model" and bare ID formats.
|
|
246
|
-
*/
|
|
247
|
-
function resolveAvailableModel(modelId, availableModels, currentProvider) {
|
|
248
|
-
const slashIdx = modelId.indexOf("/");
|
|
249
|
-
if (slashIdx !== -1) {
|
|
250
|
-
const maybeProvider = modelId.substring(0, slashIdx);
|
|
251
|
-
const id = modelId.substring(slashIdx + 1);
|
|
252
|
-
const knownProviders = new Set(availableModels.map(m => m.provider.toLowerCase()));
|
|
253
|
-
if (knownProviders.has(maybeProvider.toLowerCase())) {
|
|
254
|
-
const match = availableModels.find(m => m.provider.toLowerCase() === maybeProvider.toLowerCase()
|
|
255
|
-
&& m.id.toLowerCase() === id.toLowerCase());
|
|
256
|
-
if (match)
|
|
257
|
-
return match;
|
|
258
|
-
}
|
|
259
|
-
// Try matching the full string as a model ID (OpenRouter-style)
|
|
260
|
-
const lower = modelId.toLowerCase();
|
|
261
|
-
return availableModels.find(m => m.id.toLowerCase() === lower
|
|
262
|
-
|| `${m.provider}/${m.id}`.toLowerCase() === lower);
|
|
263
|
-
}
|
|
264
|
-
// Bare ID — prefer current provider, then first available
|
|
265
|
-
const exactProviderMatch = availableModels.find(m => m.id === modelId && m.provider === currentProvider);
|
|
266
|
-
return exactProviderMatch ?? availableModels.find(m => m.id === modelId);
|
|
267
|
-
}
|
|
268
|
-
/**
|
|
269
|
-
* Build the discuss-and-plan prompt for a new milestone.
|
|
270
|
-
* Used by all three "new milestone" paths (first ever, no active, all complete).
|
|
271
|
-
*/
|
|
272
|
-
function buildDiscussPrompt(nextId, preamble, _basePath) {
|
|
273
|
-
const milestoneRel = `.gsd/milestones/${nextId}`;
|
|
274
|
-
const inlinedTemplates = [
|
|
275
|
-
inlineTemplate("project", "Project"),
|
|
276
|
-
inlineTemplate("requirements", "Requirements"),
|
|
277
|
-
inlineTemplate("context", "Context"),
|
|
278
|
-
inlineTemplate("roadmap", "Roadmap"),
|
|
279
|
-
inlineTemplate("decisions", "Decisions"),
|
|
280
|
-
].join("\n\n---\n\n");
|
|
281
|
-
return loadPrompt("discuss", {
|
|
282
|
-
milestoneId: nextId,
|
|
283
|
-
preamble,
|
|
284
|
-
contextPath: `${milestoneRel}/${nextId}-CONTEXT.md`,
|
|
285
|
-
roadmapPath: `${milestoneRel}/${nextId}-ROADMAP.md`,
|
|
286
|
-
inlinedTemplates,
|
|
287
|
-
commitInstruction: buildDocsCommitInstruction(`docs(${nextId}): context, requirements, and roadmap`),
|
|
288
|
-
multiMilestoneCommitInstruction: buildDocsCommitInstruction("docs: project plan — N milestones"),
|
|
289
|
-
});
|
|
290
|
-
}
|
|
291
|
-
/**
|
|
292
|
-
* Build the discuss prompt for headless milestone creation.
|
|
293
|
-
* Uses the discuss-headless prompt template with seed context injected.
|
|
294
|
-
*/
|
|
295
|
-
function buildHeadlessDiscussPrompt(nextId, seedContext, _basePath) {
|
|
296
|
-
const milestoneRel = `.gsd/milestones/${nextId}`;
|
|
297
|
-
const inlinedTemplates = [
|
|
298
|
-
inlineTemplate("project", "Project"),
|
|
299
|
-
inlineTemplate("requirements", "Requirements"),
|
|
300
|
-
inlineTemplate("context", "Context"),
|
|
301
|
-
inlineTemplate("roadmap", "Roadmap"),
|
|
302
|
-
inlineTemplate("decisions", "Decisions"),
|
|
303
|
-
].join("\n\n---\n\n");
|
|
304
|
-
return loadPrompt("discuss-headless", {
|
|
305
|
-
milestoneId: nextId,
|
|
306
|
-
seedContext,
|
|
307
|
-
contextPath: `${milestoneRel}/${nextId}-CONTEXT.md`,
|
|
308
|
-
roadmapPath: `${milestoneRel}/${nextId}-ROADMAP.md`,
|
|
309
|
-
inlinedTemplates,
|
|
310
|
-
commitInstruction: buildDocsCommitInstruction(`docs(${nextId}): context, requirements, and roadmap`),
|
|
311
|
-
multiMilestoneCommitInstruction: buildDocsCommitInstruction("docs: project plan — N milestones"),
|
|
312
|
-
});
|
|
313
|
-
}
|
|
314
|
-
/**
|
|
315
|
-
* Bootstrap a .gsd/ project from scratch for headless use.
|
|
316
|
-
* Ensures git repo, .gsd/ structure, gitignore, and preferences all exist.
|
|
317
|
-
*/
|
|
318
|
-
function bootstrapGsdProject(basePath) {
|
|
319
|
-
if (!nativeIsRepo(basePath) || isInheritedRepo(basePath)) {
|
|
320
|
-
const mainBranch = loadEffectiveGSDPreferences()?.preferences?.git?.main_branch || "main";
|
|
321
|
-
nativeInit(basePath, mainBranch);
|
|
322
|
-
}
|
|
323
|
-
const root = gsdRoot(basePath);
|
|
324
|
-
mkdirSync(join(root, "milestones"), { recursive: true });
|
|
325
|
-
mkdirSync(join(root, "runtime"), { recursive: true });
|
|
326
|
-
ensureGitignore(basePath);
|
|
327
|
-
ensurePreferences(basePath);
|
|
328
|
-
untrackRuntimeFiles(basePath);
|
|
329
|
-
}
|
|
330
|
-
/**
|
|
331
|
-
* Headless milestone creation from a seed specification document.
|
|
332
|
-
* Bootstraps the project if needed, generates the next milestone ID,
|
|
333
|
-
* and dispatches the headless discuss prompt (no Q&A rounds).
|
|
334
|
-
*/
|
|
335
|
-
export async function showHeadlessMilestoneCreation(ctx, pi, basePath, seedContext) {
|
|
336
|
-
// Clear stale reservations from previous cancelled sessions (#2488)
|
|
337
|
-
clearReservedMilestoneIds();
|
|
338
|
-
// Ensure .gsd/ is bootstrapped
|
|
339
|
-
bootstrapGsdProject(basePath);
|
|
340
|
-
// Generate next milestone ID
|
|
341
|
-
const existingIds = findMilestoneIds(basePath);
|
|
342
|
-
const prefs = loadEffectiveGSDPreferences();
|
|
343
|
-
const nextId = nextMilestoneIdReserved(existingIds, prefs?.preferences?.unique_milestone_ids ?? false);
|
|
344
|
-
// Create milestone directory
|
|
345
|
-
const milestoneDir = join(gsdRoot(basePath), "milestones", nextId, "slices");
|
|
346
|
-
mkdirSync(milestoneDir, { recursive: true });
|
|
347
|
-
// Build and dispatch the headless discuss prompt
|
|
348
|
-
const prompt = buildHeadlessDiscussPrompt(nextId, seedContext, basePath);
|
|
349
|
-
// Set pending auto start (auto-mode triggers on "Milestone X ready." via checkAutoStartAfterDiscuss)
|
|
350
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId });
|
|
351
|
-
// Dispatch — headless milestone creation is a planning activity
|
|
352
|
-
await dispatchWorkflow(pi, prompt, "gsd-run", ctx, "plan-milestone");
|
|
353
|
-
}
|
|
354
|
-
// ─── Discuss Flow ─────────────────────────────────────────────────────────────
|
|
355
|
-
/**
|
|
356
|
-
* Build a rich inlined-context prompt for discussing a specific slice.
|
|
357
|
-
* Preloads roadmap, milestone context, research, decisions, and completed
|
|
358
|
-
* slice summaries so the agent can ask grounded UX/behaviour questions
|
|
359
|
-
* without wasting a turn reading files.
|
|
360
|
-
*/
|
|
361
|
-
async function buildDiscussSlicePrompt(mid, sid, sTitle, base, options) {
|
|
362
|
-
const inlined = [];
|
|
363
|
-
// Roadmap — always included so the agent sees surrounding slices
|
|
364
|
-
const roadmapPath = resolveMilestoneFile(base, mid, "ROADMAP");
|
|
365
|
-
const roadmapRel = relMilestoneFile(base, mid, "ROADMAP");
|
|
366
|
-
const roadmapContent = roadmapPath ? await loadFile(roadmapPath) : null;
|
|
367
|
-
if (roadmapContent) {
|
|
368
|
-
inlined.push(`### Milestone Roadmap\nSource: \`${roadmapRel}\`\n\n${roadmapContent.trim()}`);
|
|
369
|
-
}
|
|
370
|
-
// Milestone context — understanding the full milestone intent
|
|
371
|
-
const contextPath = resolveMilestoneFile(base, mid, "CONTEXT");
|
|
372
|
-
const contextRel = relMilestoneFile(base, mid, "CONTEXT");
|
|
373
|
-
const contextContent = contextPath ? await loadFile(contextPath) : null;
|
|
374
|
-
if (contextContent) {
|
|
375
|
-
inlined.push(`### Milestone Context\nSource: \`${contextRel}\`\n\n${contextContent.trim()}`);
|
|
376
|
-
}
|
|
377
|
-
// Milestone research — technical grounding
|
|
378
|
-
const researchPath = resolveMilestoneFile(base, mid, "RESEARCH");
|
|
379
|
-
const researchRel = relMilestoneFile(base, mid, "RESEARCH");
|
|
380
|
-
const researchContent = researchPath ? await loadFile(researchPath) : null;
|
|
381
|
-
if (researchContent) {
|
|
382
|
-
inlined.push(`### Milestone Research\nSource: \`${researchRel}\`\n\n${researchContent.trim()}`);
|
|
383
|
-
}
|
|
384
|
-
// Decisions — architectural context that constrains this slice
|
|
385
|
-
const decisionsPath = resolveGsdRootFile(base, "DECISIONS");
|
|
386
|
-
if (existsSync(decisionsPath)) {
|
|
387
|
-
const decisionsContent = await loadFile(decisionsPath);
|
|
388
|
-
if (decisionsContent) {
|
|
389
|
-
inlined.push(`### Decisions Register\nSource: \`${relGsdRootFile("DECISIONS")}\`\n\n${decisionsContent.trim()}`);
|
|
390
|
-
}
|
|
391
|
-
}
|
|
392
|
-
// Completed slice summaries — what was already built that this slice builds on
|
|
393
|
-
// Ensure DB is open so getMilestoneSlices returns real data (#2560).
|
|
394
|
-
{
|
|
395
|
-
const { ensureDbOpen } = await import("./bootstrap/dynamic-tools.js");
|
|
396
|
-
await ensureDbOpen();
|
|
397
|
-
let normSlices = [];
|
|
398
|
-
if (isDbAvailable()) {
|
|
399
|
-
normSlices = getMilestoneSlices(mid).map(s => ({ id: s.id, done: s.status === "complete" }));
|
|
400
|
-
}
|
|
401
|
-
for (const s of normSlices) {
|
|
402
|
-
if (!s.done || s.id === sid)
|
|
403
|
-
continue;
|
|
404
|
-
const summaryPath = resolveSliceFile(base, mid, s.id, "SUMMARY");
|
|
405
|
-
const summaryRel = relSliceFile(base, mid, s.id, "SUMMARY");
|
|
406
|
-
const summaryContent = summaryPath ? await loadFile(summaryPath) : null;
|
|
407
|
-
if (summaryContent) {
|
|
408
|
-
inlined.push(`### ${s.id} Summary (completed)\nSource: \`${summaryRel}\`\n\n${summaryContent.trim()}`);
|
|
409
|
-
}
|
|
410
|
-
}
|
|
411
|
-
}
|
|
412
|
-
const inlinedContext = inlined.length > 0
|
|
413
|
-
? `## Inlined Context (preloaded — do not re-read these files)\n\n${inlined.join("\n\n---\n\n")}`
|
|
414
|
-
: `## Inlined Context\n\n_(no context files found yet — go in blind and ask broad questions)_`;
|
|
415
|
-
const sliceDirPath = `.gsd/milestones/${mid}/slices/${sid}`;
|
|
416
|
-
const sliceContextPath = `${sliceDirPath}/${sid}-CONTEXT.md`;
|
|
417
|
-
// When re-discussing, inject a preamble so the agent treats this as an update interview
|
|
418
|
-
const rediscussPreamble = options?.rediscuss
|
|
419
|
-
? `\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`
|
|
420
|
-
: "";
|
|
421
|
-
const inlinedTemplates = inlineTemplate("slice-context", "Slice Context");
|
|
422
|
-
return loadPrompt("guided-discuss-slice", {
|
|
423
|
-
milestoneId: mid,
|
|
424
|
-
sliceId: sid,
|
|
425
|
-
sliceTitle: sTitle,
|
|
426
|
-
inlinedContext: inlinedContext + rediscussPreamble,
|
|
427
|
-
sliceDirPath,
|
|
428
|
-
contextPath: sliceContextPath,
|
|
429
|
-
projectRoot: base,
|
|
430
|
-
inlinedTemplates,
|
|
431
|
-
commitInstruction: buildDocsCommitInstruction(`docs(${mid}/${sid}): slice context from discuss`),
|
|
432
|
-
});
|
|
433
|
-
}
|
|
434
|
-
/**
|
|
435
|
-
* /gsd discuss — show a picker of non-done slices and run a slice interview.
|
|
436
|
-
* Loops back to the picker after each discussion so the user can chain
|
|
437
|
-
* multiple slice interviews in one session.
|
|
438
|
-
*/
|
|
439
|
-
export async function showDiscuss(ctx, pi, basePath) {
|
|
440
|
-
// Guard: no .gsd/ project
|
|
441
|
-
if (!existsSync(gsdRoot(basePath))) {
|
|
442
|
-
ctx.ui.notify("No GSD project found. Run /gsd to start one first.", "warning");
|
|
443
|
-
return;
|
|
444
|
-
}
|
|
445
|
-
// Invalidate caches to pick up artifacts written by a just-completed discuss/plan
|
|
446
|
-
invalidateAllCaches();
|
|
447
|
-
const state = await deriveState(basePath);
|
|
448
|
-
// No active milestone (or corrupted milestone with undefined id) —
|
|
449
|
-
// check for pending milestones to discuss instead
|
|
450
|
-
if (!state.activeMilestone?.id) {
|
|
451
|
-
const pendingMilestones = state.registry.filter(m => m.status === "pending");
|
|
452
|
-
if (pendingMilestones.length === 0) {
|
|
453
|
-
ctx.ui.notify("No active milestone. Run /gsd to create one first.", "warning");
|
|
454
|
-
return;
|
|
455
|
-
}
|
|
456
|
-
await showDiscussQueuedMilestone(ctx, pi, basePath, pendingMilestones);
|
|
457
|
-
return;
|
|
458
|
-
}
|
|
459
|
-
const mid = state.activeMilestone.id;
|
|
460
|
-
const milestoneTitle = state.activeMilestone.title;
|
|
461
|
-
// Special case: milestone is in needs-discussion phase (has CONTEXT-DRAFT.md but no roadmap yet).
|
|
462
|
-
// Route to the draft discussion flow instead of erroring — the discussion IS how the roadmap gets created.
|
|
463
|
-
if (state.phase === "needs-discussion") {
|
|
464
|
-
const draftFile = resolveMilestoneFile(basePath, mid, "CONTEXT-DRAFT");
|
|
465
|
-
const draftContent = draftFile ? await loadFile(draftFile) : null;
|
|
466
|
-
const choice = await showNextAction(ctx, {
|
|
467
|
-
title: `GSD — ${mid}: ${milestoneTitle}`,
|
|
468
|
-
summary: ["This milestone has a draft context from a prior discussion.", "It needs a dedicated discussion before auto-planning can begin."],
|
|
469
|
-
actions: [
|
|
470
|
-
{
|
|
471
|
-
id: "discuss_draft",
|
|
472
|
-
label: "Discuss from draft",
|
|
473
|
-
description: "Continue where the prior discussion left off — seed material is loaded automatically.",
|
|
474
|
-
recommended: true,
|
|
475
|
-
},
|
|
476
|
-
{
|
|
477
|
-
id: "discuss_fresh",
|
|
478
|
-
label: "Start fresh discussion",
|
|
479
|
-
description: "Discard the draft and start a new discussion from scratch.",
|
|
480
|
-
},
|
|
481
|
-
{
|
|
482
|
-
id: "skip_milestone",
|
|
483
|
-
label: "Skip — create new milestone",
|
|
484
|
-
description: "Leave this milestone as-is and start something new.",
|
|
485
|
-
},
|
|
486
|
-
],
|
|
487
|
-
notYetMessage: "Run /gsd discuss when ready to discuss this milestone.",
|
|
488
|
-
});
|
|
489
|
-
if (choice === "discuss_draft") {
|
|
490
|
-
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
491
|
-
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
492
|
-
const basePrompt = loadPrompt("guided-discuss-milestone", {
|
|
493
|
-
milestoneId: mid, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
|
|
494
|
-
commitInstruction: buildDocsCommitInstruction(`docs(${mid}): milestone context from discuss`),
|
|
495
|
-
});
|
|
496
|
-
const seed = draftContent
|
|
497
|
-
? `${basePrompt}\n\n## Prior Discussion (Draft Seed)\n\n${draftContent}`
|
|
498
|
-
: basePrompt;
|
|
499
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: mid, step: false });
|
|
500
|
-
await dispatchWorkflow(pi, seed, "gsd-discuss", ctx, "discuss-milestone");
|
|
501
|
-
}
|
|
502
|
-
else if (choice === "discuss_fresh") {
|
|
503
|
-
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
504
|
-
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
505
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: mid, step: false });
|
|
506
|
-
await dispatchWorkflow(pi, loadPrompt("guided-discuss-milestone", {
|
|
507
|
-
milestoneId: mid, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
|
|
508
|
-
commitInstruction: buildDocsCommitInstruction(`docs(${mid}): milestone context from discuss`),
|
|
509
|
-
}), "gsd-discuss", ctx, "discuss-milestone");
|
|
510
|
-
}
|
|
511
|
-
else if (choice === "skip_milestone") {
|
|
512
|
-
const milestoneIds = findMilestoneIds(basePath);
|
|
513
|
-
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
514
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
515
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: false });
|
|
516
|
-
await dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
517
|
-
}
|
|
518
|
-
return;
|
|
519
|
-
}
|
|
520
|
-
// Ensure DB is open before querying slices (#2560).
|
|
521
|
-
// showDiscuss() is a command handler — unlike tool handlers, it has no
|
|
522
|
-
// automatic ensureDbOpen() call. Without this, isDbAvailable() returns
|
|
523
|
-
// false on cold-start sessions and normSlices falls to [] → false
|
|
524
|
-
// "All slices complete" exit.
|
|
525
|
-
const { ensureDbOpen } = await import("./bootstrap/dynamic-tools.js");
|
|
526
|
-
await ensureDbOpen();
|
|
527
|
-
// Guard: no roadmap yet (unless DB has slices)
|
|
528
|
-
const roadmapFile = resolveMilestoneFile(basePath, mid, "ROADMAP");
|
|
529
|
-
const roadmapContent = roadmapFile ? await loadFile(roadmapFile) : null;
|
|
530
|
-
if (!roadmapContent && !isDbAvailable()) {
|
|
531
|
-
ctx.ui.notify("No roadmap yet for this milestone. Run /gsd to plan first.", "warning");
|
|
532
|
-
return;
|
|
533
|
-
}
|
|
534
|
-
let normSlices;
|
|
535
|
-
if (isDbAvailable()) {
|
|
536
|
-
normSlices = getMilestoneSlices(mid).map(s => ({ id: s.id, done: s.status === "complete", title: s.title }));
|
|
537
|
-
}
|
|
538
|
-
else {
|
|
539
|
-
normSlices = [];
|
|
540
|
-
}
|
|
541
|
-
// DB is open but returned zero slices despite a roadmap existing —
|
|
542
|
-
// the DB may be empty due to WAL loss or truncation (see #2815, #2892).
|
|
543
|
-
// Fall back to roadmap parsing to prevent false "all complete" exit.
|
|
544
|
-
if (normSlices.length === 0 && roadmapContent) {
|
|
545
|
-
normSlices = parseRoadmapSlices(roadmapContent).map(s => ({ id: s.id, done: s.done, title: s.title }));
|
|
546
|
-
}
|
|
547
|
-
const pendingSlices = normSlices.filter(s => !s.done);
|
|
548
|
-
if (pendingSlices.length === 0) {
|
|
549
|
-
// All slices complete — but queued milestones may still need discussion (#3150)
|
|
550
|
-
const pendingMilestones = state.registry.filter(m => m.status === "pending");
|
|
551
|
-
if (pendingMilestones.length > 0) {
|
|
552
|
-
await showDiscussQueuedMilestone(ctx, pi, basePath, pendingMilestones);
|
|
553
|
-
return;
|
|
554
|
-
}
|
|
555
|
-
ctx.ui.notify("All slices are complete — nothing to discuss.", "info");
|
|
556
|
-
return;
|
|
557
|
-
}
|
|
558
|
-
// Loop: show picker, dispatch discuss, repeat until "not_yet"
|
|
559
|
-
while (true) {
|
|
560
|
-
// Invalidate caches so we pick up CONTEXT files written by the just-completed discussion
|
|
561
|
-
invalidateAllCaches();
|
|
562
|
-
// Build discussion-state map: which slices have CONTEXT files already?
|
|
563
|
-
const discussedMap = new Map();
|
|
564
|
-
for (const s of pendingSlices) {
|
|
565
|
-
const contextFile = resolveSliceFile(basePath, mid, s.id, "CONTEXT");
|
|
566
|
-
discussedMap.set(s.id, !!contextFile);
|
|
567
|
-
}
|
|
568
|
-
// If all pending slices are discussed, check for queued milestones before exiting (#3150)
|
|
569
|
-
const allDiscussed = pendingSlices.every(s => discussedMap.get(s.id));
|
|
570
|
-
if (allDiscussed) {
|
|
571
|
-
const pendingMilestones = state.registry.filter(m => m.status === "pending");
|
|
572
|
-
if (pendingMilestones.length > 0) {
|
|
573
|
-
await showDiscussQueuedMilestone(ctx, pi, basePath, pendingMilestones);
|
|
574
|
-
return;
|
|
575
|
-
}
|
|
576
|
-
const lockData = readSessionLockData(basePath);
|
|
577
|
-
const remoteAutoRunning = lockData && lockData.pid !== process.pid && isSessionLockProcessAlive(lockData);
|
|
578
|
-
const nextStep = remoteAutoRunning
|
|
579
|
-
? "Auto-mode is already running — use /gsd status to check progress."
|
|
580
|
-
: "Run /gsd to start planning.";
|
|
581
|
-
ctx.ui.notify(`All ${pendingSlices.length} slices discussed. ${nextStep}`, "info");
|
|
582
|
-
return;
|
|
583
|
-
}
|
|
584
|
-
// Find the first undiscussed slice to recommend
|
|
585
|
-
const firstUndiscussedId = pendingSlices.find(s => !discussedMap.get(s.id))?.id;
|
|
586
|
-
const actions = pendingSlices.map((s) => {
|
|
587
|
-
const discussed = discussedMap.get(s.id) ?? false;
|
|
588
|
-
const statusParts = [];
|
|
589
|
-
if (state.activeSlice?.id === s.id)
|
|
590
|
-
statusParts.push("active");
|
|
591
|
-
else
|
|
592
|
-
statusParts.push("upcoming");
|
|
593
|
-
statusParts.push(discussed ? "discussed ✓" : "not discussed");
|
|
594
|
-
return {
|
|
595
|
-
id: s.id,
|
|
596
|
-
label: `${s.id}: ${s.title}`,
|
|
597
|
-
description: statusParts.join(" · "),
|
|
598
|
-
recommended: s.id === firstUndiscussedId,
|
|
599
|
-
};
|
|
600
|
-
});
|
|
601
|
-
// Offer access to queued milestones when any exist
|
|
602
|
-
const pendingMilestones = state.registry.filter(m => m.status === "pending");
|
|
603
|
-
if (pendingMilestones.length > 0) {
|
|
604
|
-
actions.push({
|
|
605
|
-
id: "discuss_queued_milestone",
|
|
606
|
-
label: "Discuss a queued milestone",
|
|
607
|
-
description: `Refine context for ${pendingMilestones.length} queued milestone(s). Does not affect current execution.`,
|
|
608
|
-
recommended: false,
|
|
609
|
-
});
|
|
610
|
-
}
|
|
611
|
-
const choice = await showNextAction(ctx, {
|
|
612
|
-
title: "GSD — Discuss a slice",
|
|
613
|
-
summary: [
|
|
614
|
-
`${mid}: ${milestoneTitle}`,
|
|
615
|
-
"Pick a slice to interview. Context file will be written when done.",
|
|
616
|
-
],
|
|
617
|
-
actions,
|
|
618
|
-
notYetMessage: "Run /gsd discuss when ready.",
|
|
619
|
-
});
|
|
620
|
-
if (choice === "not_yet")
|
|
621
|
-
return;
|
|
622
|
-
if (choice === "discuss_queued_milestone") {
|
|
623
|
-
await showDiscussQueuedMilestone(ctx, pi, basePath, pendingMilestones);
|
|
624
|
-
return;
|
|
625
|
-
}
|
|
626
|
-
const chosen = pendingSlices.find(s => s.id === choice);
|
|
627
|
-
if (!chosen)
|
|
628
|
-
return;
|
|
629
|
-
// If the slice already has a CONTEXT file, confirm re-discuss intent
|
|
630
|
-
const isRediscuss = discussedMap.get(chosen.id) ?? false;
|
|
631
|
-
if (isRediscuss) {
|
|
632
|
-
const confirm = await showNextAction(ctx, {
|
|
633
|
-
title: `Re-discuss ${chosen.id}?`,
|
|
634
|
-
summary: [
|
|
635
|
-
`${chosen.id} already has a context file from a prior discussion.`,
|
|
636
|
-
"Re-discussing will interview for updates and rewrite the context file.",
|
|
637
|
-
],
|
|
638
|
-
actions: [
|
|
639
|
-
{ id: "rediscuss", label: "Re-discuss to update context", description: "Interview for changes and rewrite", recommended: true },
|
|
640
|
-
{ id: "cancel", label: "Cancel", description: "Go back to slice picker" },
|
|
641
|
-
],
|
|
642
|
-
});
|
|
643
|
-
if (confirm !== "rediscuss")
|
|
644
|
-
continue;
|
|
645
|
-
}
|
|
646
|
-
const prompt = await buildDiscussSlicePrompt(mid, chosen.id, chosen.title, basePath, { rediscuss: isRediscuss });
|
|
647
|
-
await dispatchWorkflow(pi, prompt, "gsd-discuss", ctx, "discuss-slice");
|
|
648
|
-
// Wait for the discuss session to finish, then loop back to the picker
|
|
649
|
-
await ctx.waitForIdle();
|
|
650
|
-
invalidateAllCaches();
|
|
651
|
-
}
|
|
652
|
-
}
|
|
653
|
-
// ─── Queued Milestone Discussion ─────────────────────────────────────────────
|
|
654
|
-
/**
|
|
655
|
-
* Show a picker of queued (pending) milestones and dispatch a discuss flow for
|
|
656
|
-
* the chosen one. Discussing a queued milestone does NOT activate it — it only
|
|
657
|
-
* refines the CONTEXT.md artifact so it is better prepared when auto-mode
|
|
658
|
-
* eventually reaches it.
|
|
659
|
-
*/
|
|
660
|
-
async function showDiscussQueuedMilestone(ctx, pi, basePath, pendingMilestones) {
|
|
661
|
-
const actions = pendingMilestones.map((m, i) => {
|
|
662
|
-
const hasContext = !!resolveMilestoneFile(basePath, m.id, "CONTEXT");
|
|
663
|
-
const hasDraft = !hasContext && !!resolveMilestoneFile(basePath, m.id, "CONTEXT-DRAFT");
|
|
664
|
-
const contextStatus = hasContext ? "context ✓" : hasDraft ? "draft context" : "no context yet";
|
|
665
|
-
return {
|
|
666
|
-
id: m.id,
|
|
667
|
-
label: `${m.id}: ${m.title}`,
|
|
668
|
-
description: `[queued] · ${contextStatus}`,
|
|
669
|
-
recommended: i === 0,
|
|
670
|
-
};
|
|
671
|
-
});
|
|
672
|
-
const choice = await showNextAction(ctx, {
|
|
673
|
-
title: "GSD — Discuss a queued milestone",
|
|
674
|
-
summary: [
|
|
675
|
-
"Select a queued milestone to discuss.",
|
|
676
|
-
"Discussing will update its context file. It will not be activated.",
|
|
677
|
-
],
|
|
678
|
-
actions,
|
|
679
|
-
notYetMessage: "Run /gsd discuss when ready.",
|
|
680
|
-
});
|
|
681
|
-
if (choice === "not_yet")
|
|
682
|
-
return;
|
|
683
|
-
const chosen = pendingMilestones.find(m => m.id === choice);
|
|
684
|
-
if (!chosen)
|
|
685
|
-
return;
|
|
686
|
-
await dispatchDiscussForMilestone(ctx, pi, basePath, chosen.id, chosen.title);
|
|
687
|
-
}
|
|
688
|
-
/**
|
|
689
|
-
* Dispatch the guided-discuss-milestone prompt for a milestone without
|
|
690
|
-
* setting pendingAutoStart — so discussing a queued milestone does not
|
|
691
|
-
* implicitly activate it when the session ends.
|
|
692
|
-
*/
|
|
693
|
-
async function dispatchDiscussForMilestone(ctx, pi, basePath, mid, milestoneTitle) {
|
|
694
|
-
const draftFile = resolveMilestoneFile(basePath, mid, "CONTEXT-DRAFT");
|
|
695
|
-
const draftContent = draftFile ? await loadFile(draftFile) : null;
|
|
696
|
-
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
697
|
-
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
698
|
-
const basePrompt = loadPrompt("guided-discuss-milestone", {
|
|
699
|
-
milestoneId: mid,
|
|
700
|
-
milestoneTitle,
|
|
701
|
-
inlinedTemplates: discussMilestoneTemplates,
|
|
702
|
-
structuredQuestionsAvailable,
|
|
703
|
-
commitInstruction: buildDocsCommitInstruction(`docs(${mid}): milestone context from discuss`),
|
|
704
|
-
});
|
|
705
|
-
const prompt = draftContent
|
|
706
|
-
? `${basePrompt}\n\n## Prior Discussion (Draft Seed)\n\n${draftContent}`
|
|
707
|
-
: basePrompt;
|
|
708
|
-
await dispatchWorkflow(pi, prompt, "gsd-discuss", ctx, "discuss-milestone");
|
|
709
|
-
}
|
|
710
|
-
// ─── Smart Entry Point ────────────────────────────────────────────────────────
|
|
711
|
-
/**
|
|
712
|
-
* The one wizard. Reads state, shows contextual options, dispatches into the workflow doc.
|
|
713
|
-
*/
|
|
714
|
-
/**
|
|
715
|
-
* Self-heal: scan runtime records and clear stale ones left behind when
|
|
716
|
-
* auto-mode crashed mid-unit. auto.ts has its own selfHealRuntimeRecords()
|
|
717
|
-
* but guided-flow (manual /gsd mode) never called it — meaning stale records
|
|
718
|
-
* persisted until the next /gsd auto run. This ensures the wizard always
|
|
719
|
-
* starts from a clean state regardless of how the previous session ended.
|
|
720
|
-
*/
|
|
721
|
-
function selfHealRuntimeRecords(basePath, ctx) {
|
|
722
|
-
try {
|
|
723
|
-
const records = listUnitRuntimeRecords(basePath);
|
|
724
|
-
let cleared = 0;
|
|
725
|
-
for (const record of records) {
|
|
726
|
-
const { unitType, unitId, phase } = record;
|
|
727
|
-
// Clear records whose expected artifact already exists (completed but not cleaned up)
|
|
728
|
-
const artifactPath = resolveExpectedArtifactPath(unitType, unitId, basePath);
|
|
729
|
-
if (artifactPath && existsSync(artifactPath)) {
|
|
730
|
-
clearUnitRuntimeRecord(basePath, unitType, unitId);
|
|
731
|
-
cleared++;
|
|
732
|
-
continue;
|
|
733
|
-
}
|
|
734
|
-
// Clear records stuck in dispatched or timeout phase (process died mid-unit)
|
|
735
|
-
if (phase === "dispatched" || phase === "timeout") {
|
|
736
|
-
clearUnitRuntimeRecord(basePath, unitType, unitId);
|
|
737
|
-
cleared++;
|
|
738
|
-
}
|
|
739
|
-
}
|
|
740
|
-
if (cleared > 0) {
|
|
741
|
-
ctx.ui.notify(`Self-heal: cleared ${cleared} stale runtime record(s) from a previous session.`, "info");
|
|
742
|
-
}
|
|
743
|
-
return { cleared };
|
|
744
|
-
}
|
|
745
|
-
catch {
|
|
746
|
-
// Non-fatal — self-heal should never block the wizard
|
|
747
|
-
return { cleared: 0 };
|
|
748
|
-
}
|
|
749
|
-
}
|
|
750
|
-
// ─── Milestone Actions Submenu ──────────────────────────────────────────────
|
|
751
|
-
/**
|
|
752
|
-
* Shows a submenu with Park / Discard / Skip / Back options for the active milestone.
|
|
753
|
-
* Returns true if an action was taken (caller should re-enter showSmartEntry or
|
|
754
|
-
* dispatch a new workflow). Returns false if the user chose "Back".
|
|
755
|
-
*/
|
|
756
|
-
async function handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options) {
|
|
757
|
-
const stepMode = options?.step;
|
|
758
|
-
const choice = await showNextAction(ctx, {
|
|
759
|
-
title: `Milestone Actions — ${milestoneId}`,
|
|
760
|
-
summary: [`${milestoneId}: ${milestoneTitle}`],
|
|
761
|
-
actions: [
|
|
762
|
-
{
|
|
763
|
-
id: "park",
|
|
764
|
-
label: "Park milestone",
|
|
765
|
-
description: "Pause this milestone — it stays on disk but is skipped.",
|
|
766
|
-
},
|
|
767
|
-
{
|
|
768
|
-
id: "discard",
|
|
769
|
-
label: "Discard milestone",
|
|
770
|
-
description: "Permanently delete this milestone and all its contents.",
|
|
771
|
-
},
|
|
772
|
-
{
|
|
773
|
-
id: "skip",
|
|
774
|
-
label: "Skip — create new milestone",
|
|
775
|
-
description: "Leave this milestone and start a fresh one.",
|
|
776
|
-
},
|
|
777
|
-
{
|
|
778
|
-
id: "back",
|
|
779
|
-
label: "Back",
|
|
780
|
-
description: "Return to the previous menu.",
|
|
781
|
-
},
|
|
782
|
-
],
|
|
783
|
-
notYetMessage: "Run /gsd when ready.",
|
|
784
|
-
});
|
|
785
|
-
if (choice === "park") {
|
|
786
|
-
const reason = await showNextAction(ctx, {
|
|
787
|
-
title: `Park ${milestoneId}`,
|
|
788
|
-
summary: ["Why is this milestone being parked?"],
|
|
789
|
-
actions: [
|
|
790
|
-
{ id: "priority_shift", label: "Priority shift", description: "Other work is more important right now." },
|
|
791
|
-
{ id: "blocked_external", label: "Blocked externally", description: "Waiting on an external dependency or decision." },
|
|
792
|
-
{ id: "needs_rethink", label: "Needs rethinking", description: "The approach needs to be reconsidered." },
|
|
793
|
-
],
|
|
794
|
-
notYetMessage: "Run /gsd when ready.",
|
|
795
|
-
});
|
|
796
|
-
// User pressed "Not yet" / Escape — cancel the park operation
|
|
797
|
-
if (!reason || reason === "not_yet")
|
|
798
|
-
return false;
|
|
799
|
-
const reasonText = reason === "priority_shift" ? "Priority shift — other work is more important"
|
|
800
|
-
: reason === "blocked_external" ? "Blocked externally — waiting on external dependency"
|
|
801
|
-
: reason === "needs_rethink" ? "Needs rethinking — approach needs reconsideration"
|
|
802
|
-
: "Parked by user";
|
|
803
|
-
const success = parkMilestone(basePath, milestoneId, reasonText);
|
|
804
|
-
if (success) {
|
|
805
|
-
ctx.ui.notify(`Parked ${milestoneId}. Run /gsd unpark ${milestoneId} to reactivate.`, "info");
|
|
806
|
-
}
|
|
807
|
-
else {
|
|
808
|
-
ctx.ui.notify(`Could not park ${milestoneId} — milestone not found or already parked.`, "warning");
|
|
809
|
-
}
|
|
810
|
-
return true;
|
|
811
|
-
}
|
|
812
|
-
if (choice === "discard") {
|
|
813
|
-
const confirmed = await showConfirm(ctx, {
|
|
814
|
-
title: "Discard milestone?",
|
|
815
|
-
message: `This will permanently delete ${milestoneId} and all its contents (roadmap, plans, task summaries).`,
|
|
816
|
-
confirmLabel: "Discard",
|
|
817
|
-
declineLabel: "Cancel",
|
|
818
|
-
});
|
|
819
|
-
if (confirmed) {
|
|
820
|
-
discardMilestone(basePath, milestoneId);
|
|
821
|
-
ctx.ui.notify(`Discarded ${milestoneId}.`, "info");
|
|
822
|
-
return true;
|
|
823
|
-
}
|
|
824
|
-
return false;
|
|
825
|
-
}
|
|
826
|
-
if (choice === "skip") {
|
|
827
|
-
const milestoneIds = findMilestoneIds(basePath);
|
|
828
|
-
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
829
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
830
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: stepMode });
|
|
831
|
-
await dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
832
|
-
return true;
|
|
833
|
-
}
|
|
834
|
-
// "back" or null
|
|
835
|
-
return false;
|
|
836
|
-
}
|
|
837
|
-
export async function showSmartEntry(ctx, pi, basePath, options) {
|
|
838
|
-
const stepMode = options?.step;
|
|
839
|
-
// ── Clear stale milestone ID reservations from previous cancelled sessions ──
|
|
840
|
-
// Reservations only need to survive within a single /gsd interaction.
|
|
841
|
-
// Without this, each cancelled session permanently bumps the next ID. (#2488)
|
|
842
|
-
clearReservedMilestoneIds();
|
|
843
|
-
// ── Directory safety check — refuse to operate in system/home dirs ───
|
|
844
|
-
const dirCheck = validateDirectory(basePath);
|
|
845
|
-
if (dirCheck.severity === "blocked") {
|
|
846
|
-
ctx.ui.notify(dirCheck.reason, "error");
|
|
847
|
-
return;
|
|
848
|
-
}
|
|
849
|
-
if (dirCheck.severity === "warning") {
|
|
850
|
-
const proceed = await showConfirm(ctx, {
|
|
851
|
-
title: "GSD — Unusual Directory",
|
|
852
|
-
message: dirCheck.reason,
|
|
853
|
-
confirmLabel: "Continue anyway",
|
|
854
|
-
declineLabel: "Cancel",
|
|
855
|
-
});
|
|
856
|
-
if (!proceed)
|
|
857
|
-
return;
|
|
858
|
-
}
|
|
859
|
-
// ── Detection preamble — run before any bootstrap ────────────────────
|
|
860
|
-
// Check bootstrap completeness, not just .gsd/ directory existence.
|
|
861
|
-
// A zombie .gsd/ state (symlink exists but missing PREFERENCES.md and
|
|
862
|
-
// milestones/) must trigger the init wizard, not skip it (#2942).
|
|
863
|
-
const gsdPath = gsdRoot(basePath);
|
|
864
|
-
const hasBootstrapArtifacts = existsSync(gsdPath)
|
|
865
|
-
&& (existsSync(join(gsdPath, "PREFERENCES.md"))
|
|
866
|
-
|| existsSync(join(gsdPath, "milestones")));
|
|
867
|
-
if (!hasBootstrapArtifacts) {
|
|
868
|
-
const detection = detectProjectState(basePath);
|
|
869
|
-
// v1 .planning/ detected — offer migration before anything else
|
|
870
|
-
if (detection.state === "v1-planning" && detection.v1) {
|
|
871
|
-
const migrationChoice = await offerMigration(ctx, detection.v1);
|
|
872
|
-
if (migrationChoice === "cancel")
|
|
873
|
-
return;
|
|
874
|
-
if (migrationChoice === "migrate") {
|
|
875
|
-
const { handleMigrate } = await import("./migrate/command.js");
|
|
876
|
-
await handleMigrate("", ctx, pi);
|
|
877
|
-
return;
|
|
878
|
-
}
|
|
879
|
-
// "fresh" — fall through to init wizard
|
|
880
|
-
}
|
|
881
|
-
// No .gsd/ or zombie .gsd/ — run the project init wizard
|
|
882
|
-
const result = await showProjectInit(ctx, pi, basePath, detection);
|
|
883
|
-
if (!result.completed)
|
|
884
|
-
return; // User cancelled
|
|
885
|
-
// Init wizard bootstrapped .gsd/ — fall through to the normal flow below
|
|
886
|
-
// which will detect "no milestones" and start the discuss prompt
|
|
887
|
-
}
|
|
888
|
-
// ── Ensure git repo exists — GSD needs it for worktree isolation ──────
|
|
889
|
-
// Also handle inherited repos: if basePath is a subdirectory of another
|
|
890
|
-
// git repo that has no .gsd, create a fresh repo to prevent cross-project
|
|
891
|
-
// state leaks (#1639).
|
|
892
|
-
if (!nativeIsRepo(basePath) || isInheritedRepo(basePath)) {
|
|
893
|
-
const mainBranch = loadEffectiveGSDPreferences()?.preferences?.git?.main_branch || "main";
|
|
894
|
-
nativeInit(basePath, mainBranch);
|
|
895
|
-
}
|
|
896
|
-
// ── Ensure .gitignore has baseline patterns ──────────────────────────
|
|
897
|
-
ensureGitignore(basePath);
|
|
898
|
-
untrackRuntimeFiles(basePath);
|
|
899
|
-
// ── Self-heal stale runtime records from crashed auto-mode sessions ──
|
|
900
|
-
selfHealRuntimeRecords(basePath, ctx);
|
|
901
|
-
// Check for crash from previous auto-mode session.
|
|
902
|
-
// Skip if the lock was written by the current process — acquireSessionLock()
|
|
903
|
-
// writes to the same file, so we'd always false-positive (#1398).
|
|
904
|
-
const crashLock = readCrashLock(basePath);
|
|
905
|
-
if (crashLock && crashLock.pid !== process.pid) {
|
|
906
|
-
clearLock(basePath);
|
|
907
|
-
// Bootstrap crash with zero completed units = no work was lost.
|
|
908
|
-
// Auto-discard instead of prompting the user — this commonly happens
|
|
909
|
-
// when the user exits during init wizard or discuss phase before any
|
|
910
|
-
// real auto-mode work begins.
|
|
911
|
-
const isBootstrapCrash = crashLock.unitType === "starting"
|
|
912
|
-
&& crashLock.unitId === "bootstrap";
|
|
913
|
-
if (!isBootstrapCrash) {
|
|
914
|
-
const resume = await showNextAction(ctx, {
|
|
915
|
-
title: "GSD — Interrupted Session Detected",
|
|
916
|
-
summary: [formatCrashInfo(crashLock)],
|
|
917
|
-
actions: [
|
|
918
|
-
{ id: "resume", label: "Resume with /gsd auto", description: "Pick up where it left off", recommended: true },
|
|
919
|
-
{ id: "continue", label: "Continue manually", description: "Open the wizard as normal" },
|
|
920
|
-
],
|
|
921
|
-
});
|
|
922
|
-
if (resume === "resume") {
|
|
923
|
-
await startAuto(ctx, pi, basePath, false);
|
|
924
|
-
return;
|
|
925
|
-
}
|
|
926
|
-
}
|
|
927
|
-
}
|
|
928
|
-
const state = await deriveState(basePath);
|
|
929
|
-
if (!state.activeMilestone?.id) {
|
|
930
|
-
// Guard: if a discuss session is already in flight, don't re-inject the prompt.
|
|
931
|
-
// Both /gsd and /gsd auto reach this branch when no milestone exists yet.
|
|
932
|
-
// Without this guard, every subsequent /gsd call overwrites the pending auto-start
|
|
933
|
-
// and fires another dispatchWorkflow, resetting the conversation mid-interview.
|
|
934
|
-
if (pendingAutoStartMap.has(basePath)) {
|
|
935
|
-
ctx.ui.notify("Discussion already in progress — answer the question above to continue.", "info");
|
|
936
|
-
return;
|
|
937
|
-
}
|
|
938
|
-
const milestoneIds = findMilestoneIds(basePath);
|
|
939
|
-
// Sanity check (#456): if findMilestoneIds returns [] but the milestones
|
|
940
|
-
// directory has contents, something went wrong (permissions, stale worktree
|
|
941
|
-
// cwd, etc). Warn instead of silently starting a new-project flow.
|
|
942
|
-
if (milestoneIds.length === 0) {
|
|
943
|
-
const mDir = milestonesDir(basePath);
|
|
944
|
-
if (existsSync(mDir)) {
|
|
945
|
-
try {
|
|
946
|
-
const entries = readdirSync(mDir);
|
|
947
|
-
if (entries.length > 0) {
|
|
948
|
-
ctx.ui.notify(`Milestone directory has ${entries.length} entries but none were recognized as milestones. ` +
|
|
949
|
-
`This may indicate a corrupted state or wrong working directory. Run \`/gsd doctor\` to diagnose.`, "warning");
|
|
950
|
-
return;
|
|
951
|
-
}
|
|
952
|
-
}
|
|
953
|
-
catch { /* directory exists but unreadable — fall through to normal flow */ }
|
|
954
|
-
}
|
|
955
|
-
}
|
|
956
|
-
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
957
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
958
|
-
const isFirst = milestoneIds.length === 0;
|
|
959
|
-
if (isFirst) {
|
|
960
|
-
// First ever — skip wizard, just ask directly
|
|
961
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: stepMode });
|
|
962
|
-
await dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New project, milestone ${nextId}. Do NOT read or explore .gsd/ — it's empty scaffolding.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
963
|
-
}
|
|
964
|
-
else {
|
|
965
|
-
const choice = await showNextAction(ctx, {
|
|
966
|
-
title: "GSD — Lucent Software Developer",
|
|
967
|
-
summary: ["No active milestone."],
|
|
968
|
-
actions: [
|
|
969
|
-
{
|
|
970
|
-
id: "new_milestone",
|
|
971
|
-
label: "Create next milestone",
|
|
972
|
-
description: "Define what to build next.",
|
|
973
|
-
recommended: true,
|
|
974
|
-
},
|
|
975
|
-
],
|
|
976
|
-
notYetMessage: "Run /gsd when ready.",
|
|
977
|
-
});
|
|
978
|
-
if (choice === "new_milestone") {
|
|
979
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: stepMode });
|
|
980
|
-
await dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
981
|
-
}
|
|
982
|
-
}
|
|
983
|
-
return;
|
|
984
|
-
}
|
|
985
|
-
const milestoneId = state.activeMilestone.id;
|
|
986
|
-
const milestoneTitle = state.activeMilestone.title;
|
|
987
|
-
// ── All milestones complete → New milestone ──────────────────────────
|
|
988
|
-
if (state.phase === "complete") {
|
|
989
|
-
const choice = await showNextAction(ctx, {
|
|
990
|
-
title: `GSD — ${milestoneId}: ${milestoneTitle}`,
|
|
991
|
-
summary: ["All milestones complete."],
|
|
992
|
-
actions: [
|
|
993
|
-
{
|
|
994
|
-
id: "new_milestone",
|
|
995
|
-
label: "Start new milestone",
|
|
996
|
-
description: "Define and plan the next milestone.",
|
|
997
|
-
recommended: true,
|
|
998
|
-
},
|
|
999
|
-
{
|
|
1000
|
-
id: "status",
|
|
1001
|
-
label: "View status",
|
|
1002
|
-
description: "Review what was built.",
|
|
1003
|
-
},
|
|
1004
|
-
],
|
|
1005
|
-
notYetMessage: "Run /gsd when ready.",
|
|
1006
|
-
});
|
|
1007
|
-
if (choice === "new_milestone") {
|
|
1008
|
-
const milestoneIds = findMilestoneIds(basePath);
|
|
1009
|
-
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
1010
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
1011
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: stepMode });
|
|
1012
|
-
await dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
1013
|
-
}
|
|
1014
|
-
else if (choice === "status") {
|
|
1015
|
-
const { fireStatusViaCommand } = await import("./commands.js");
|
|
1016
|
-
await fireStatusViaCommand(ctx);
|
|
1017
|
-
}
|
|
1018
|
-
return;
|
|
1019
|
-
}
|
|
1020
|
-
// ── Draft milestone — needs discussion before planning ────────────────
|
|
1021
|
-
if (state.phase === "needs-discussion") {
|
|
1022
|
-
const draftFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT-DRAFT");
|
|
1023
|
-
const draftContent = draftFile ? await loadFile(draftFile) : null;
|
|
1024
|
-
const choice = await showNextAction(ctx, {
|
|
1025
|
-
title: `GSD — ${milestoneId}: ${milestoneTitle}`,
|
|
1026
|
-
summary: ["This milestone has a draft context from a prior discussion.", "It needs a dedicated discussion before auto-planning can begin."],
|
|
1027
|
-
actions: [
|
|
1028
|
-
{
|
|
1029
|
-
id: "discuss_draft",
|
|
1030
|
-
label: "Discuss from draft",
|
|
1031
|
-
description: "Continue where the prior discussion left off — seed material is loaded automatically.",
|
|
1032
|
-
recommended: true,
|
|
1033
|
-
},
|
|
1034
|
-
{
|
|
1035
|
-
id: "discuss_fresh",
|
|
1036
|
-
label: "Start fresh discussion",
|
|
1037
|
-
description: "Discard the draft and start a new discussion from scratch.",
|
|
1038
|
-
},
|
|
1039
|
-
{
|
|
1040
|
-
id: "skip_milestone",
|
|
1041
|
-
label: "Skip — create new milestone",
|
|
1042
|
-
description: "Leave this milestone as-is and start something new.",
|
|
1043
|
-
},
|
|
1044
|
-
],
|
|
1045
|
-
notYetMessage: "Run /gsd when ready to discuss this milestone.",
|
|
1046
|
-
});
|
|
1047
|
-
if (choice === "discuss_draft") {
|
|
1048
|
-
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
1049
|
-
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
1050
|
-
const basePrompt = loadPrompt("guided-discuss-milestone", {
|
|
1051
|
-
milestoneId, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
|
|
1052
|
-
commitInstruction: buildDocsCommitInstruction(`docs(${milestoneId}): milestone context from discuss`),
|
|
1053
|
-
});
|
|
1054
|
-
const seed = draftContent
|
|
1055
|
-
? `${basePrompt}\n\n## Prior Discussion (Draft Seed)\n\n${draftContent}`
|
|
1056
|
-
: basePrompt;
|
|
1057
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId, step: stepMode });
|
|
1058
|
-
await dispatchWorkflow(pi, seed, "gsd-discuss", ctx, "discuss-milestone");
|
|
1059
|
-
}
|
|
1060
|
-
else if (choice === "discuss_fresh") {
|
|
1061
|
-
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
1062
|
-
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
1063
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId, step: stepMode });
|
|
1064
|
-
await dispatchWorkflow(pi, loadPrompt("guided-discuss-milestone", {
|
|
1065
|
-
milestoneId, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
|
|
1066
|
-
commitInstruction: buildDocsCommitInstruction(`docs(${milestoneId}): milestone context from discuss`),
|
|
1067
|
-
}), "gsd-discuss", ctx, "discuss-milestone");
|
|
1068
|
-
}
|
|
1069
|
-
else if (choice === "skip_milestone") {
|
|
1070
|
-
const milestoneIds = findMilestoneIds(basePath);
|
|
1071
|
-
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
1072
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
1073
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: stepMode });
|
|
1074
|
-
await dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
1075
|
-
}
|
|
1076
|
-
return;
|
|
1077
|
-
}
|
|
1078
|
-
// ── No active slice ──────────────────────────────────────────────────
|
|
1079
|
-
if (!state.activeSlice) {
|
|
1080
|
-
const roadmapFile = resolveMilestoneFile(basePath, milestoneId, "ROADMAP");
|
|
1081
|
-
const hasRoadmap = !!(roadmapFile && await loadFile(roadmapFile));
|
|
1082
|
-
if (!hasRoadmap) {
|
|
1083
|
-
// No roadmap → discuss or plan
|
|
1084
|
-
const contextFile = resolveMilestoneFile(basePath, milestoneId, "CONTEXT");
|
|
1085
|
-
const hasContext = !!(contextFile && await loadFile(contextFile));
|
|
1086
|
-
const actions = [
|
|
1087
|
-
{
|
|
1088
|
-
id: "plan",
|
|
1089
|
-
label: "Create roadmap",
|
|
1090
|
-
description: hasContext
|
|
1091
|
-
? "Context captured. Decompose into slices with a boundary map."
|
|
1092
|
-
: "Decompose the milestone into slices with a boundary map.",
|
|
1093
|
-
recommended: true,
|
|
1094
|
-
},
|
|
1095
|
-
...(!hasContext ? [{
|
|
1096
|
-
id: "discuss",
|
|
1097
|
-
label: "Discuss first",
|
|
1098
|
-
description: "Capture decisions on gray areas before planning.",
|
|
1099
|
-
}] : []),
|
|
1100
|
-
{
|
|
1101
|
-
id: "skip_milestone",
|
|
1102
|
-
label: "Skip — create new milestone",
|
|
1103
|
-
description: "Leave this milestone on disk and start a fresh one.",
|
|
1104
|
-
},
|
|
1105
|
-
{
|
|
1106
|
-
id: "discard_milestone",
|
|
1107
|
-
label: "Discard this milestone",
|
|
1108
|
-
description: "Delete the milestone directory and start over.",
|
|
1109
|
-
},
|
|
1110
|
-
];
|
|
1111
|
-
const choice = await showNextAction(ctx, {
|
|
1112
|
-
title: `GSD — ${milestoneId}: ${milestoneTitle}`,
|
|
1113
|
-
summary: [hasContext ? "Context captured. Ready to create roadmap." : "New milestone — no roadmap yet."],
|
|
1114
|
-
actions,
|
|
1115
|
-
notYetMessage: "Run /gsd when ready.",
|
|
1116
|
-
});
|
|
1117
|
-
if (choice === "plan") {
|
|
1118
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId, step: stepMode });
|
|
1119
|
-
const planMilestoneTemplates = [
|
|
1120
|
-
inlineTemplate("roadmap", "Roadmap"),
|
|
1121
|
-
inlineTemplate("plan", "Slice Plan"),
|
|
1122
|
-
inlineTemplate("task-plan", "Task Plan"),
|
|
1123
|
-
inlineTemplate("secrets-manifest", "Secrets Manifest"),
|
|
1124
|
-
].join("\n\n---\n\n");
|
|
1125
|
-
const secretsOutputPath = relMilestoneFile(basePath, milestoneId, "SECRETS");
|
|
1126
|
-
await dispatchWorkflow(pi, loadPrompt("guided-plan-milestone", {
|
|
1127
|
-
milestoneId,
|
|
1128
|
-
milestoneTitle,
|
|
1129
|
-
secretsOutputPath,
|
|
1130
|
-
inlinedTemplates: planMilestoneTemplates,
|
|
1131
|
-
skillActivation: buildSkillActivationBlock({
|
|
1132
|
-
base: basePath,
|
|
1133
|
-
milestoneId,
|
|
1134
|
-
milestoneTitle,
|
|
1135
|
-
extraContext: [planMilestoneTemplates],
|
|
1136
|
-
}),
|
|
1137
|
-
}), "gsd-run", ctx, "plan-milestone");
|
|
1138
|
-
}
|
|
1139
|
-
else if (choice === "discuss") {
|
|
1140
|
-
const discussMilestoneTemplates = inlineTemplate("context", "Context");
|
|
1141
|
-
const structuredQuestionsAvailable = pi.getActiveTools().includes("ask_user_questions") ? "true" : "false";
|
|
1142
|
-
await dispatchWorkflow(pi, loadPrompt("guided-discuss-milestone", {
|
|
1143
|
-
milestoneId, milestoneTitle, inlinedTemplates: discussMilestoneTemplates, structuredQuestionsAvailable,
|
|
1144
|
-
commitInstruction: buildDocsCommitInstruction(`docs(${milestoneId}): milestone context from discuss`),
|
|
1145
|
-
}), "gsd-run", ctx, "discuss-milestone");
|
|
1146
|
-
}
|
|
1147
|
-
else if (choice === "skip_milestone") {
|
|
1148
|
-
const milestoneIds = findMilestoneIds(basePath);
|
|
1149
|
-
const uniqueMilestoneIds = !!loadEffectiveGSDPreferences()?.preferences?.unique_milestone_ids;
|
|
1150
|
-
const nextId = nextMilestoneIdReserved(milestoneIds, uniqueMilestoneIds);
|
|
1151
|
-
pendingAutoStartMap.set(basePath, { ctx, pi, basePath, milestoneId: nextId, step: stepMode });
|
|
1152
|
-
await dispatchWorkflow(pi, buildDiscussPrompt(nextId, `New milestone ${nextId}.`, basePath), "gsd-run", ctx, "discuss-milestone");
|
|
1153
|
-
}
|
|
1154
|
-
else if (choice === "discard_milestone") {
|
|
1155
|
-
const confirmed = await showConfirm(ctx, {
|
|
1156
|
-
title: "Discard milestone?",
|
|
1157
|
-
message: `This will permanently delete ${milestoneId} and all its contents.`,
|
|
1158
|
-
confirmLabel: "Discard",
|
|
1159
|
-
declineLabel: "Cancel",
|
|
1160
|
-
});
|
|
1161
|
-
if (confirmed) {
|
|
1162
|
-
discardMilestone(basePath, milestoneId);
|
|
1163
|
-
return showSmartEntry(ctx, pi, basePath, options);
|
|
1164
|
-
}
|
|
1165
|
-
}
|
|
1166
|
-
}
|
|
1167
|
-
else {
|
|
1168
|
-
// Roadmap exists — either blocked or ready for auto
|
|
1169
|
-
const actions = [
|
|
1170
|
-
{
|
|
1171
|
-
id: "auto",
|
|
1172
|
-
label: "Go auto",
|
|
1173
|
-
description: "Execute everything automatically until milestone complete.",
|
|
1174
|
-
recommended: true,
|
|
1175
|
-
},
|
|
1176
|
-
{
|
|
1177
|
-
id: "status",
|
|
1178
|
-
label: "View status",
|
|
1179
|
-
description: "See milestone progress and blockers.",
|
|
1180
|
-
},
|
|
1181
|
-
{
|
|
1182
|
-
id: "milestone_actions",
|
|
1183
|
-
label: "Milestone actions",
|
|
1184
|
-
description: "Park, discard, or skip this milestone.",
|
|
1185
|
-
},
|
|
1186
|
-
];
|
|
1187
|
-
const choice = await showNextAction(ctx, {
|
|
1188
|
-
title: `GSD — ${milestoneId}: ${milestoneTitle}`,
|
|
1189
|
-
summary: ["Roadmap exists. Ready to execute."],
|
|
1190
|
-
actions,
|
|
1191
|
-
notYetMessage: "Run /gsd status for details.",
|
|
1192
|
-
});
|
|
1193
|
-
if (choice === "auto") {
|
|
1194
|
-
await startAuto(ctx, pi, basePath, false);
|
|
1195
|
-
}
|
|
1196
|
-
else if (choice === "status") {
|
|
1197
|
-
const { fireStatusViaCommand } = await import("./commands.js");
|
|
1198
|
-
await fireStatusViaCommand(ctx);
|
|
1199
|
-
}
|
|
1200
|
-
else if (choice === "milestone_actions") {
|
|
1201
|
-
const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
|
|
1202
|
-
if (acted)
|
|
1203
|
-
return showSmartEntry(ctx, pi, basePath, options);
|
|
1204
|
-
}
|
|
1205
|
-
}
|
|
1206
|
-
return;
|
|
1207
|
-
}
|
|
1208
|
-
const sliceId = state.activeSlice.id;
|
|
1209
|
-
const sliceTitle = state.activeSlice.title;
|
|
1210
|
-
// ── Slice needs planning ─────────────────────────────────────────────
|
|
1211
|
-
if (state.phase === "planning") {
|
|
1212
|
-
const contextFile = resolveSliceFile(basePath, milestoneId, sliceId, "CONTEXT");
|
|
1213
|
-
const researchFile = resolveSliceFile(basePath, milestoneId, sliceId, "RESEARCH");
|
|
1214
|
-
const hasContext = !!(contextFile && await loadFile(contextFile));
|
|
1215
|
-
const hasResearch = !!(researchFile && await loadFile(researchFile));
|
|
1216
|
-
const actions = [
|
|
1217
|
-
{
|
|
1218
|
-
id: "plan",
|
|
1219
|
-
label: `Plan ${sliceId}`,
|
|
1220
|
-
description: `Decompose "${sliceTitle}" into tasks with must-haves.`,
|
|
1221
|
-
recommended: true,
|
|
1222
|
-
},
|
|
1223
|
-
...(!hasContext ? [{
|
|
1224
|
-
id: "discuss",
|
|
1225
|
-
label: `Discuss ${sliceId} first`,
|
|
1226
|
-
description: "Capture context and decisions for this slice.",
|
|
1227
|
-
}] : []),
|
|
1228
|
-
...(!hasResearch ? [{
|
|
1229
|
-
id: "research",
|
|
1230
|
-
label: `Research ${sliceId} first`,
|
|
1231
|
-
description: "Scout codebase and relevant docs.",
|
|
1232
|
-
}] : []),
|
|
1233
|
-
{
|
|
1234
|
-
id: "status",
|
|
1235
|
-
label: "View status",
|
|
1236
|
-
description: "See milestone progress.",
|
|
1237
|
-
},
|
|
1238
|
-
{
|
|
1239
|
-
id: "milestone_actions",
|
|
1240
|
-
label: "Milestone actions",
|
|
1241
|
-
description: "Park, discard, or skip this milestone.",
|
|
1242
|
-
},
|
|
1243
|
-
];
|
|
1244
|
-
const summaryParts = [];
|
|
1245
|
-
if (hasContext)
|
|
1246
|
-
summaryParts.push("context ✓");
|
|
1247
|
-
if (hasResearch)
|
|
1248
|
-
summaryParts.push("research ✓");
|
|
1249
|
-
const summaryLine = summaryParts.length > 0
|
|
1250
|
-
? `${sliceId}: ${sliceTitle} (${summaryParts.join(", ")})`
|
|
1251
|
-
: `${sliceId}: ${sliceTitle} — ready for planning.`;
|
|
1252
|
-
const choice = await showNextAction(ctx, {
|
|
1253
|
-
title: `GSD — ${milestoneId} / ${sliceId}: ${sliceTitle}`,
|
|
1254
|
-
summary: [summaryLine],
|
|
1255
|
-
actions,
|
|
1256
|
-
notYetMessage: "Run /gsd when ready.",
|
|
1257
|
-
});
|
|
1258
|
-
if (choice === "plan") {
|
|
1259
|
-
const planSliceTemplates = [
|
|
1260
|
-
inlineTemplate("plan", "Slice Plan"),
|
|
1261
|
-
inlineTemplate("task-plan", "Task Plan"),
|
|
1262
|
-
].join("\n\n---\n\n");
|
|
1263
|
-
await dispatchWorkflow(pi, loadPrompt("guided-plan-slice", {
|
|
1264
|
-
milestoneId,
|
|
1265
|
-
sliceId,
|
|
1266
|
-
sliceTitle,
|
|
1267
|
-
inlinedTemplates: planSliceTemplates,
|
|
1268
|
-
skillActivation: buildSkillActivationBlock({
|
|
1269
|
-
base: basePath,
|
|
1270
|
-
milestoneId,
|
|
1271
|
-
sliceId,
|
|
1272
|
-
sliceTitle,
|
|
1273
|
-
extraContext: [planSliceTemplates],
|
|
1274
|
-
}),
|
|
1275
|
-
}), "gsd-run", ctx, "plan-slice");
|
|
1276
|
-
}
|
|
1277
|
-
else if (choice === "discuss") {
|
|
1278
|
-
await dispatchWorkflow(pi, await buildDiscussSlicePrompt(milestoneId, sliceId, sliceTitle, basePath, { rediscuss: hasContext }), "gsd-run", ctx, "discuss-slice");
|
|
1279
|
-
}
|
|
1280
|
-
else if (choice === "research") {
|
|
1281
|
-
const researchTemplates = inlineTemplate("research", "Research");
|
|
1282
|
-
await dispatchWorkflow(pi, loadPrompt("guided-research-slice", {
|
|
1283
|
-
milestoneId,
|
|
1284
|
-
sliceId,
|
|
1285
|
-
sliceTitle,
|
|
1286
|
-
inlinedTemplates: researchTemplates,
|
|
1287
|
-
skillActivation: buildSkillActivationBlock({
|
|
1288
|
-
base: basePath,
|
|
1289
|
-
milestoneId,
|
|
1290
|
-
sliceId,
|
|
1291
|
-
sliceTitle,
|
|
1292
|
-
extraContext: [researchTemplates],
|
|
1293
|
-
}),
|
|
1294
|
-
}), "gsd-run", ctx, "research-slice");
|
|
1295
|
-
}
|
|
1296
|
-
else if (choice === "status") {
|
|
1297
|
-
const { fireStatusViaCommand } = await import("./commands.js");
|
|
1298
|
-
await fireStatusViaCommand(ctx);
|
|
1299
|
-
}
|
|
1300
|
-
else if (choice === "milestone_actions") {
|
|
1301
|
-
const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
|
|
1302
|
-
if (acted)
|
|
1303
|
-
return showSmartEntry(ctx, pi, basePath, options);
|
|
1304
|
-
}
|
|
1305
|
-
return;
|
|
1306
|
-
}
|
|
1307
|
-
// ── All tasks done → Complete slice ──────────────────────────────────
|
|
1308
|
-
if (state.phase === "summarizing") {
|
|
1309
|
-
const choice = await showNextAction(ctx, {
|
|
1310
|
-
title: `GSD — ${milestoneId} / ${sliceId}: ${sliceTitle}`,
|
|
1311
|
-
summary: ["All tasks complete. Ready for slice summary."],
|
|
1312
|
-
actions: [
|
|
1313
|
-
{
|
|
1314
|
-
id: "complete",
|
|
1315
|
-
label: `Complete ${sliceId}`,
|
|
1316
|
-
description: "Write slice summary, UAT, mark done, and squash-merge to main.",
|
|
1317
|
-
recommended: true,
|
|
1318
|
-
},
|
|
1319
|
-
{
|
|
1320
|
-
id: "status",
|
|
1321
|
-
label: "View status",
|
|
1322
|
-
description: "Review tasks before completing.",
|
|
1323
|
-
},
|
|
1324
|
-
{
|
|
1325
|
-
id: "milestone_actions",
|
|
1326
|
-
label: "Milestone actions",
|
|
1327
|
-
description: "Park, discard, or skip this milestone.",
|
|
1328
|
-
},
|
|
1329
|
-
],
|
|
1330
|
-
notYetMessage: "Run /gsd when ready.",
|
|
1331
|
-
});
|
|
1332
|
-
if (choice === "complete") {
|
|
1333
|
-
const completeSliceTemplates = [
|
|
1334
|
-
inlineTemplate("slice-summary", "Slice Summary"),
|
|
1335
|
-
inlineTemplate("uat", "UAT"),
|
|
1336
|
-
].join("\n\n---\n\n");
|
|
1337
|
-
await dispatchWorkflow(pi, loadPrompt("guided-complete-slice", {
|
|
1338
|
-
workingDirectory: basePath,
|
|
1339
|
-
milestoneId,
|
|
1340
|
-
sliceId,
|
|
1341
|
-
sliceTitle,
|
|
1342
|
-
inlinedTemplates: completeSliceTemplates,
|
|
1343
|
-
skillActivation: buildSkillActivationBlock({
|
|
1344
|
-
base: basePath,
|
|
1345
|
-
milestoneId,
|
|
1346
|
-
sliceId,
|
|
1347
|
-
sliceTitle,
|
|
1348
|
-
extraContext: [completeSliceTemplates],
|
|
1349
|
-
}),
|
|
1350
|
-
}), "gsd-run", ctx, "complete-slice");
|
|
1351
|
-
}
|
|
1352
|
-
else if (choice === "status") {
|
|
1353
|
-
const { fireStatusViaCommand } = await import("./commands.js");
|
|
1354
|
-
await fireStatusViaCommand(ctx);
|
|
1355
|
-
}
|
|
1356
|
-
else if (choice === "milestone_actions") {
|
|
1357
|
-
const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
|
|
1358
|
-
if (acted)
|
|
1359
|
-
return showSmartEntry(ctx, pi, basePath, options);
|
|
1360
|
-
}
|
|
1361
|
-
return;
|
|
1362
|
-
}
|
|
1363
|
-
// ── Active task → Execute ────────────────────────────────────────────
|
|
1364
|
-
if (state.activeTask) {
|
|
1365
|
-
const taskId = state.activeTask.id;
|
|
1366
|
-
const taskTitle = state.activeTask.title;
|
|
1367
|
-
const continueFile = resolveSliceFile(basePath, milestoneId, sliceId, "CONTINUE");
|
|
1368
|
-
const sDir = resolveSlicePath(basePath, milestoneId, sliceId);
|
|
1369
|
-
const hasInterrupted = !!(continueFile && await loadFile(continueFile)) ||
|
|
1370
|
-
!!(sDir && await loadFile(join(sDir, "continue.md")));
|
|
1371
|
-
const choice = await showNextAction(ctx, {
|
|
1372
|
-
title: `GSD — ${milestoneId} / ${sliceId}: ${sliceTitle}`,
|
|
1373
|
-
summary: [
|
|
1374
|
-
hasInterrupted
|
|
1375
|
-
? `Resuming: ${taskId} — ${taskTitle}`
|
|
1376
|
-
: `Next: ${taskId} — ${taskTitle}`,
|
|
1377
|
-
],
|
|
1378
|
-
actions: [
|
|
1379
|
-
{
|
|
1380
|
-
id: "execute",
|
|
1381
|
-
label: hasInterrupted ? `Resume ${taskId}` : `Execute ${taskId}`,
|
|
1382
|
-
description: hasInterrupted
|
|
1383
|
-
? "Continue from where you left off."
|
|
1384
|
-
: `Start working on "${taskTitle}".`,
|
|
1385
|
-
recommended: true,
|
|
1386
|
-
},
|
|
1387
|
-
{
|
|
1388
|
-
id: "auto",
|
|
1389
|
-
label: "Go auto",
|
|
1390
|
-
description: "Execute this and all remaining tasks automatically.",
|
|
1391
|
-
},
|
|
1392
|
-
{
|
|
1393
|
-
id: "status",
|
|
1394
|
-
label: "View status",
|
|
1395
|
-
description: "See slice progress before starting.",
|
|
1396
|
-
},
|
|
1397
|
-
{
|
|
1398
|
-
id: "milestone_actions",
|
|
1399
|
-
label: "Milestone actions",
|
|
1400
|
-
description: "Park, discard, or skip this milestone.",
|
|
1401
|
-
},
|
|
1402
|
-
],
|
|
1403
|
-
notYetMessage: "Run /gsd when ready.",
|
|
1404
|
-
});
|
|
1405
|
-
if (choice === "auto") {
|
|
1406
|
-
await startAuto(ctx, pi, basePath, false);
|
|
1407
|
-
return;
|
|
1408
|
-
}
|
|
1409
|
-
if (choice === "execute") {
|
|
1410
|
-
if (hasInterrupted) {
|
|
1411
|
-
await dispatchWorkflow(pi, loadPrompt("guided-resume-task", {
|
|
1412
|
-
milestoneId,
|
|
1413
|
-
sliceId,
|
|
1414
|
-
skillActivation: buildSkillActivationBlock({
|
|
1415
|
-
base: basePath,
|
|
1416
|
-
milestoneId,
|
|
1417
|
-
sliceId,
|
|
1418
|
-
taskId,
|
|
1419
|
-
taskTitle,
|
|
1420
|
-
}),
|
|
1421
|
-
}), "gsd-run", ctx, "execute-task");
|
|
1422
|
-
}
|
|
1423
|
-
else {
|
|
1424
|
-
const executeTaskTemplates = inlineTemplate("task-summary", "Task Summary");
|
|
1425
|
-
await dispatchWorkflow(pi, loadPrompt("guided-execute-task", {
|
|
1426
|
-
milestoneId,
|
|
1427
|
-
sliceId,
|
|
1428
|
-
taskId,
|
|
1429
|
-
taskTitle,
|
|
1430
|
-
inlinedTemplates: executeTaskTemplates,
|
|
1431
|
-
skillActivation: buildSkillActivationBlock({
|
|
1432
|
-
base: basePath,
|
|
1433
|
-
milestoneId,
|
|
1434
|
-
sliceId,
|
|
1435
|
-
taskId,
|
|
1436
|
-
taskTitle,
|
|
1437
|
-
extraContext: [executeTaskTemplates],
|
|
1438
|
-
}),
|
|
1439
|
-
}), "gsd-run", ctx, "execute-task");
|
|
1440
|
-
}
|
|
1441
|
-
}
|
|
1442
|
-
else if (choice === "status") {
|
|
1443
|
-
const { fireStatusViaCommand } = await import("./commands.js");
|
|
1444
|
-
await fireStatusViaCommand(ctx);
|
|
1445
|
-
}
|
|
1446
|
-
else if (choice === "milestone_actions") {
|
|
1447
|
-
const acted = await handleMilestoneActions(ctx, pi, basePath, milestoneId, milestoneTitle, options);
|
|
1448
|
-
if (acted)
|
|
1449
|
-
return showSmartEntry(ctx, pi, basePath, options);
|
|
1450
|
-
}
|
|
1451
|
-
return;
|
|
1452
|
-
}
|
|
1453
|
-
// ── Fallback: show status ────────────────────────────────────────────
|
|
1454
|
-
const { fireStatusViaCommand } = await import("./commands.js");
|
|
1455
|
-
await fireStatusViaCommand(ctx);
|
|
1456
|
-
}
|