specweave 0.17.1 → 0.17.3
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/bin/specweave.js +16 -16
- package/dist/plugins/specweave-github/lib/github-spec-sync.d.ts +109 -6
- package/dist/plugins/specweave-github/lib/github-spec-sync.d.ts.map +1 -1
- package/dist/plugins/specweave-github/lib/github-spec-sync.js +435 -49
- package/dist/plugins/specweave-github/lib/github-spec-sync.js.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/github-multi-repo.d.ts +10 -2
- package/dist/src/cli/helpers/issue-tracker/github-multi-repo.d.ts.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/github-multi-repo.js +28 -14
- package/dist/src/cli/helpers/issue-tracker/github-multi-repo.js.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/github.d.ts.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/github.js +10 -1
- package/dist/src/cli/helpers/issue-tracker/github.js.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/index.d.ts.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/index.js +20 -0
- package/dist/src/cli/helpers/issue-tracker/index.js.map +1 -1
- package/dist/src/core/project-manager.d.ts +25 -21
- package/dist/src/core/project-manager.d.ts.map +1 -1
- package/dist/src/core/project-manager.js +41 -51
- package/dist/src/core/project-manager.js.map +1 -1
- package/dist/src/core/repo-structure/folder-detector.d.ts +19 -0
- package/dist/src/core/repo-structure/folder-detector.d.ts.map +1 -0
- package/dist/src/core/repo-structure/folder-detector.js +95 -0
- package/dist/src/core/repo-structure/folder-detector.js.map +1 -0
- package/dist/src/core/repo-structure/repo-structure-manager.d.ts +4 -1
- package/dist/src/core/repo-structure/repo-structure-manager.d.ts.map +1 -1
- package/dist/src/core/repo-structure/repo-structure-manager.js +41 -27
- package/dist/src/core/repo-structure/repo-structure-manager.js.map +1 -1
- package/dist/src/core/types/spec-metadata.d.ts +34 -1
- package/dist/src/core/types/spec-metadata.d.ts.map +1 -1
- package/dist/src/core/types/sync-profile.d.ts +30 -0
- package/dist/src/core/types/sync-profile.d.ts.map +1 -1
- package/dist/src/core/types/sync-profile.js.map +1 -1
- package/dist/src/utils/project-validator.d.ts +27 -0
- package/dist/src/utils/project-validator.d.ts.map +1 -0
- package/dist/src/utils/project-validator.js +68 -0
- package/dist/src/utils/project-validator.js.map +1 -0
- package/package.json +1 -1
- package/plugins/specweave/lib/hooks/git-diff-analyzer.js +129 -213
- package/plugins/specweave/lib/hooks/invoke-translator-skill.js +146 -192
- package/plugins/specweave/lib/hooks/prepare-reflection-context.js +103 -116
- package/plugins/specweave/lib/hooks/reflection-config-loader.js +85 -125
- package/plugins/specweave/lib/hooks/reflection-parser.js +267 -385
- package/plugins/specweave/lib/hooks/reflection-prompt-builder.js +169 -226
- package/plugins/specweave/lib/hooks/reflection-storage.js +223 -297
- package/plugins/specweave/lib/hooks/run-self-reflection.js +120 -191
- package/plugins/specweave/lib/hooks/translate-file.js +239 -300
- package/plugins/specweave/lib/hooks/translate-living-docs.js +88 -144
- package/plugins/specweave/lib/hooks/types/reflection-types.js +57 -72
- package/plugins/specweave/lib/hooks/update-tasks-md.js +117 -179
- package/plugins/specweave-ado/lib/ado-board-resolver.js +135 -205
- package/plugins/specweave-ado/lib/ado-client-v2.js +405 -449
- package/plugins/specweave-ado/lib/ado-hierarchical-sync.js +223 -335
- package/plugins/specweave-ado/lib/ado-spec-commit-sync.js +173 -194
- package/plugins/specweave-ado/lib/ado-spec-sync.js +380 -414
- package/plugins/specweave-ado/lib/conflict-resolver.ts +1 -1
- package/plugins/specweave-ado/lib/project-selector.js +168 -196
- package/plugins/specweave-github/MULTI-PROJECT-SYNC-ARCHITECTURE.md +658 -0
- package/plugins/specweave-github/SYNC-ARCHITECTURE-FIX-SUMMARY.md +302 -0
- package/plugins/specweave-github/hooks/post-task-completion.sh +55 -157
- package/plugins/specweave-github/lib/cli-sync-increment-changes.js +9 -20
- package/plugins/specweave-github/lib/github-board-resolver.js +69 -115
- package/plugins/specweave-github/lib/github-client-v2.js +400 -389
- package/plugins/specweave-github/lib/github-client.js +246 -280
- package/plugins/specweave-github/lib/github-hierarchical-sync.js +168 -251
- package/plugins/specweave-github/lib/github-spec-commit-sync.js +171 -194
- package/plugins/specweave-github/lib/github-spec-sync.js +742 -418
- package/plugins/specweave-github/lib/github-spec-sync.ts +597 -61
- package/plugins/specweave-github/lib/index.js +11 -10
- package/plugins/specweave-github/lib/repo-selector.js +174 -201
- package/plugins/specweave-github/lib/subtask-sync.js +132 -125
- package/plugins/specweave-github/lib/task-parser.js +191 -207
- package/plugins/specweave-github/lib/task-sync.js +344 -296
- package/plugins/specweave-github/lib/types.js +0 -5
- package/plugins/specweave-github/skills/github-sync/SKILL.md +234 -242
- package/plugins/specweave-jira/lib/jira-board-resolver.js +50 -79
- package/plugins/specweave-jira/lib/jira-hierarchical-sync.js +119 -191
- package/plugins/specweave-jira/lib/jira-spec-commit-sync.js +241 -263
- package/plugins/specweave-jira/lib/jira-spec-sync.js +366 -405
- package/plugins/specweave-jira/lib/project-selector.js +172 -201
- package/plugins/specweave-jira/lib/reorganization-detector.js +202 -237
- package/plugins/specweave-jira/lib/setup-wizard.js +162 -204
- package/dist/adapters/adapter-base.d.ts +0 -71
- package/dist/adapters/adapter-base.d.ts.map +0 -1
- package/dist/adapters/adapter-base.js +0 -139
- package/dist/adapters/adapter-base.js.map +0 -1
- package/dist/adapters/adapter-interface.d.ts +0 -149
- package/dist/adapters/adapter-interface.d.ts.map +0 -1
- package/dist/adapters/adapter-interface.js +0 -8
- package/dist/adapters/adapter-interface.js.map +0 -1
- package/dist/adapters/adapter-loader.d.ts +0 -91
- package/dist/adapters/adapter-loader.d.ts.map +0 -1
- package/dist/adapters/adapter-loader.js +0 -238
- package/dist/adapters/adapter-loader.js.map +0 -1
- package/dist/adapters/agents-md-generator.d.ts +0 -48
- package/dist/adapters/agents-md-generator.d.ts.map +0 -1
- package/dist/adapters/agents-md-generator.js +0 -193
- package/dist/adapters/agents-md-generator.js.map +0 -1
- package/dist/adapters/claude/adapter.d.ts +0 -128
- package/dist/adapters/claude/adapter.d.ts.map +0 -1
- package/dist/adapters/claude/adapter.js +0 -415
- package/dist/adapters/claude/adapter.js.map +0 -1
- package/dist/adapters/claude-md-generator.d.ts +0 -78
- package/dist/adapters/claude-md-generator.d.ts.map +0 -1
- package/dist/adapters/claude-md-generator.js +0 -307
- package/dist/adapters/claude-md-generator.js.map +0 -1
- package/dist/adapters/codex/adapter.d.ts +0 -50
- package/dist/adapters/codex/adapter.d.ts.map +0 -1
- package/dist/adapters/codex/adapter.js +0 -316
- package/dist/adapters/codex/adapter.js.map +0 -1
- package/dist/adapters/cursor/adapter.d.ts +0 -98
- package/dist/adapters/cursor/adapter.d.ts.map +0 -1
- package/dist/adapters/cursor/adapter.js +0 -406
- package/dist/adapters/cursor/adapter.js.map +0 -1
- package/dist/adapters/doc-generator.d.ts +0 -69
- package/dist/adapters/doc-generator.d.ts.map +0 -1
- package/dist/adapters/doc-generator.js +0 -247
- package/dist/adapters/doc-generator.js.map +0 -1
- package/dist/adapters/gemini/adapter.d.ts +0 -50
- package/dist/adapters/gemini/adapter.d.ts.map +0 -1
- package/dist/adapters/gemini/adapter.js +0 -281
- package/dist/adapters/gemini/adapter.js.map +0 -1
- package/dist/adapters/generic/adapter.d.ts +0 -86
- package/dist/adapters/generic/adapter.d.ts.map +0 -1
- package/dist/adapters/generic/adapter.js +0 -338
- package/dist/adapters/generic/adapter.js.map +0 -1
- package/dist/cli/commands/abandon.d.ts +0 -13
- package/dist/cli/commands/abandon.d.ts.map +0 -1
- package/dist/cli/commands/abandon.js +0 -15
- package/dist/cli/commands/abandon.js.map +0 -1
- package/dist/cli/commands/check-discipline.d.ts +0 -16
- package/dist/cli/commands/check-discipline.d.ts.map +0 -1
- package/dist/cli/commands/check-discipline.js +0 -79
- package/dist/cli/commands/check-discipline.js.map +0 -1
- package/dist/cli/commands/import-docs.d.ts +0 -21
- package/dist/cli/commands/import-docs.d.ts.map +0 -1
- package/dist/cli/commands/import-docs.js +0 -146
- package/dist/cli/commands/import-docs.js.map +0 -1
- package/dist/cli/commands/init-multiproject.d.ts +0 -11
- package/dist/cli/commands/init-multiproject.d.ts.map +0 -1
- package/dist/cli/commands/init-multiproject.js +0 -202
- package/dist/cli/commands/init-multiproject.js.map +0 -1
- package/dist/cli/commands/init.d.ts +0 -10
- package/dist/cli/commands/init.d.ts.map +0 -1
- package/dist/cli/commands/init.js +0 -1328
- package/dist/cli/commands/init.js.map +0 -1
- package/dist/cli/commands/install.d.ts +0 -9
- package/dist/cli/commands/install.d.ts.map +0 -1
- package/dist/cli/commands/install.js +0 -127
- package/dist/cli/commands/install.js.map +0 -1
- package/dist/cli/commands/list.d.ts +0 -8
- package/dist/cli/commands/list.d.ts.map +0 -1
- package/dist/cli/commands/list.js +0 -119
- package/dist/cli/commands/list.js.map +0 -1
- package/dist/cli/commands/migrate-to-multiproject.d.ts +0 -37
- package/dist/cli/commands/migrate-to-multiproject.d.ts.map +0 -1
- package/dist/cli/commands/migrate-to-multiproject.js +0 -189
- package/dist/cli/commands/migrate-to-multiproject.js.map +0 -1
- package/dist/cli/commands/migrate-to-profiles.d.ts +0 -25
- package/dist/cli/commands/migrate-to-profiles.d.ts.map +0 -1
- package/dist/cli/commands/migrate-to-profiles.js +0 -348
- package/dist/cli/commands/migrate-to-profiles.js.map +0 -1
- package/dist/cli/commands/pause.d.ts +0 -13
- package/dist/cli/commands/pause.d.ts.map +0 -1
- package/dist/cli/commands/pause.js +0 -15
- package/dist/cli/commands/pause.js.map +0 -1
- package/dist/cli/commands/qa.d.ts +0 -54
- package/dist/cli/commands/qa.d.ts.map +0 -1
- package/dist/cli/commands/qa.js +0 -98
- package/dist/cli/commands/qa.js.map +0 -1
- package/dist/cli/commands/resume.d.ts +0 -12
- package/dist/cli/commands/resume.d.ts.map +0 -1
- package/dist/cli/commands/resume.js +0 -14
- package/dist/cli/commands/resume.js.map +0 -1
- package/dist/cli/commands/revert-wip-limit.js +0 -60
- package/dist/cli/commands/status-line.d.ts +0 -14
- package/dist/cli/commands/status-line.d.ts.map +0 -1
- package/dist/cli/commands/status-line.js +0 -75
- package/dist/cli/commands/status-line.js.map +0 -1
- package/dist/cli/commands/status.d.ts +0 -12
- package/dist/cli/commands/status.d.ts.map +0 -1
- package/dist/cli/commands/status.js +0 -23
- package/dist/cli/commands/status.js.map +0 -1
- package/dist/cli/commands/switch-project.d.ts +0 -13
- package/dist/cli/commands/switch-project.d.ts.map +0 -1
- package/dist/cli/commands/switch-project.js +0 -91
- package/dist/cli/commands/switch-project.js.map +0 -1
- package/dist/cli/commands/sync-spec-commits.d.ts +0 -9
- package/dist/cli/commands/sync-spec-commits.d.ts.map +0 -1
- package/dist/cli/commands/sync-spec-commits.js +0 -186
- package/dist/cli/commands/sync-spec-commits.js.map +0 -1
- package/dist/cli/commands/validate-jira.d.ts +0 -35
- package/dist/cli/commands/validate-jira.d.ts.map +0 -1
- package/dist/cli/commands/validate-jira.js +0 -112
- package/dist/cli/commands/validate-jira.js.map +0 -1
- package/dist/cli/commands/validate-plugins.d.ts +0 -41
- package/dist/cli/commands/validate-plugins.d.ts.map +0 -1
- package/dist/cli/commands/validate-plugins.js +0 -171
- package/dist/cli/commands/validate-plugins.js.map +0 -1
- package/dist/cli/helpers/github/increment-profile-selector.d.ts +0 -47
- package/dist/cli/helpers/github/increment-profile-selector.d.ts.map +0 -1
- package/dist/cli/helpers/github/increment-profile-selector.js +0 -186
- package/dist/cli/helpers/github/increment-profile-selector.js.map +0 -1
- package/dist/cli/helpers/github/profile-manager.d.ts +0 -119
- package/dist/cli/helpers/github/profile-manager.d.ts.map +0 -1
- package/dist/cli/helpers/github/profile-manager.js +0 -311
- package/dist/cli/helpers/github/profile-manager.js.map +0 -1
- package/dist/cli/helpers/issue-tracker/ado.d.ts +0 -57
- package/dist/cli/helpers/issue-tracker/ado.d.ts.map +0 -1
- package/dist/cli/helpers/issue-tracker/ado.js +0 -243
- package/dist/cli/helpers/issue-tracker/ado.js.map +0 -1
- package/dist/cli/helpers/issue-tracker/github-multi-repo.d.ts +0 -86
- package/dist/cli/helpers/issue-tracker/github-multi-repo.d.ts.map +0 -1
- package/dist/cli/helpers/issue-tracker/github-multi-repo.js +0 -417
- package/dist/cli/helpers/issue-tracker/github-multi-repo.js.map +0 -1
- package/dist/cli/helpers/issue-tracker/github.d.ts +0 -80
- package/dist/cli/helpers/issue-tracker/github.d.ts.map +0 -1
- package/dist/cli/helpers/issue-tracker/github.js +0 -324
- package/dist/cli/helpers/issue-tracker/github.js.map +0 -1
- package/dist/cli/helpers/issue-tracker/index.d.ts +0 -22
- package/dist/cli/helpers/issue-tracker/index.d.ts.map +0 -1
- package/dist/cli/helpers/issue-tracker/index.js +0 -562
- package/dist/cli/helpers/issue-tracker/index.js.map +0 -1
- package/dist/cli/helpers/issue-tracker/jira.d.ts +0 -61
- package/dist/cli/helpers/issue-tracker/jira.d.ts.map +0 -1
- package/dist/cli/helpers/issue-tracker/jira.js +0 -404
- package/dist/cli/helpers/issue-tracker/jira.js.map +0 -1
- package/dist/cli/helpers/issue-tracker/types.d.ts +0 -108
- package/dist/cli/helpers/issue-tracker/types.d.ts.map +0 -1
- package/dist/cli/helpers/issue-tracker/types.js +0 -16
- package/dist/cli/helpers/issue-tracker/types.js.map +0 -1
- package/dist/cli/helpers/issue-tracker/utils.d.ts +0 -120
- package/dist/cli/helpers/issue-tracker/utils.d.ts.map +0 -1
- package/dist/cli/helpers/issue-tracker/utils.js +0 -293
- package/dist/cli/helpers/issue-tracker/utils.js.map +0 -1
- package/dist/core/agent-model-manager.d.ts +0 -52
- package/dist/core/agent-model-manager.d.ts.map +0 -1
- package/dist/core/agent-model-manager.js +0 -120
- package/dist/core/agent-model-manager.js.map +0 -1
- package/dist/core/brownfield/analyzer.d.ts +0 -86
- package/dist/core/brownfield/analyzer.d.ts.map +0 -1
- package/dist/core/brownfield/analyzer.js +0 -365
- package/dist/core/brownfield/analyzer.js.map +0 -1
- package/dist/core/brownfield/importer.d.ts +0 -76
- package/dist/core/brownfield/importer.d.ts.map +0 -1
- package/dist/core/brownfield/importer.js +0 -287
- package/dist/core/brownfield/importer.js.map +0 -1
- package/dist/core/comment-builder.d.ts +0 -57
- package/dist/core/comment-builder.d.ts.map +0 -1
- package/dist/core/comment-builder.js +0 -239
- package/dist/core/comment-builder.js.map +0 -1
- package/dist/core/config-manager.d.ts +0 -47
- package/dist/core/config-manager.d.ts.map +0 -1
- package/dist/core/config-manager.js +0 -136
- package/dist/core/config-manager.js.map +0 -1
- package/dist/core/cost-tracker.d.ts +0 -108
- package/dist/core/cost-tracker.d.ts.map +0 -1
- package/dist/core/cost-tracker.js +0 -281
- package/dist/core/cost-tracker.js.map +0 -1
- package/dist/core/credentials-manager.d.ts +0 -107
- package/dist/core/credentials-manager.d.ts.map +0 -1
- package/dist/core/credentials-manager.js +0 -457
- package/dist/core/credentials-manager.js.map +0 -1
- package/dist/core/i18n/language-detector.d.ts +0 -29
- package/dist/core/i18n/language-detector.d.ts.map +0 -1
- package/dist/core/i18n/language-detector.js +0 -143
- package/dist/core/i18n/language-detector.js.map +0 -1
- package/dist/core/i18n/language-manager.d.ts +0 -101
- package/dist/core/i18n/language-manager.d.ts.map +0 -1
- package/dist/core/i18n/language-manager.js +0 -232
- package/dist/core/i18n/language-manager.js.map +0 -1
- package/dist/core/i18n/language-registry.d.ts +0 -44
- package/dist/core/i18n/language-registry.d.ts.map +0 -1
- package/dist/core/i18n/language-registry.js +0 -234
- package/dist/core/i18n/language-registry.js.map +0 -1
- package/dist/core/i18n/locale-manager.d.ts +0 -62
- package/dist/core/i18n/locale-manager.d.ts.map +0 -1
- package/dist/core/i18n/locale-manager.js +0 -137
- package/dist/core/i18n/locale-manager.js.map +0 -1
- package/dist/core/i18n/system-prompt-injector.d.ts +0 -33
- package/dist/core/i18n/system-prompt-injector.d.ts.map +0 -1
- package/dist/core/i18n/system-prompt-injector.js +0 -131
- package/dist/core/i18n/system-prompt-injector.js.map +0 -1
- package/dist/core/i18n/types.d.ts +0 -151
- package/dist/core/i18n/types.d.ts.map +0 -1
- package/dist/core/i18n/types.js +0 -11
- package/dist/core/i18n/types.js.map +0 -1
- package/dist/core/increment/active-increment-manager.d.ts +0 -79
- package/dist/core/increment/active-increment-manager.d.ts.map +0 -1
- package/dist/core/increment/active-increment-manager.js +0 -153
- package/dist/core/increment/active-increment-manager.js.map +0 -1
- package/dist/core/increment/discipline-checker.d.ts +0 -60
- package/dist/core/increment/discipline-checker.d.ts.map +0 -1
- package/dist/core/increment/discipline-checker.js +0 -274
- package/dist/core/increment/discipline-checker.js.map +0 -1
- package/dist/core/increment/limits.d.ts +0 -68
- package/dist/core/increment/limits.d.ts.map +0 -1
- package/dist/core/increment/limits.js +0 -224
- package/dist/core/increment/limits.js.map +0 -1
- package/dist/core/increment/metadata-manager.d.ts +0 -116
- package/dist/core/increment/metadata-manager.d.ts.map +0 -1
- package/dist/core/increment/metadata-manager.js.map +0 -1
- package/dist/core/increment/metadata-validator.d.ts +0 -33
- package/dist/core/increment/metadata-validator.d.ts.map +0 -1
- package/dist/core/increment/metadata-validator.js +0 -147
- package/dist/core/increment/metadata-validator.js.map +0 -1
- package/dist/core/increment/status-commands.d.ts +0 -43
- package/dist/core/increment/status-commands.d.ts.map +0 -1
- package/dist/core/increment/status-commands.js +0 -277
- package/dist/core/increment/status-commands.js.map +0 -1
- package/dist/core/increment/types.d.ts +0 -88
- package/dist/core/increment/types.d.ts.map +0 -1
- package/dist/core/increment/types.js +0 -8
- package/dist/core/increment/types.js.map +0 -1
- package/dist/core/increment-status.d.ts +0 -72
- package/dist/core/increment-status.d.ts.map +0 -1
- package/dist/core/increment-status.js +0 -227
- package/dist/core/increment-status.js.map +0 -1
- package/dist/core/model-selector.d.ts +0 -57
- package/dist/core/model-selector.d.ts.map +0 -1
- package/dist/core/model-selector.js +0 -115
- package/dist/core/model-selector.js.map +0 -1
- package/dist/core/phase-detector.d.ts +0 -62
- package/dist/core/phase-detector.d.ts.map +0 -1
- package/dist/core/phase-detector.js +0 -229
- package/dist/core/phase-detector.js.map +0 -1
- package/dist/core/plugin-loader.d.ts +0 -131
- package/dist/core/plugin-loader.d.ts.map +0 -1
- package/dist/core/plugin-loader.js +0 -421
- package/dist/core/plugin-loader.js.map +0 -1
- package/dist/core/project-manager.d.ts +0 -127
- package/dist/core/project-manager.d.ts.map +0 -1
- package/dist/core/project-manager.js +0 -524
- package/dist/core/project-manager.js.map +0 -1
- package/dist/core/project-structure-detector.d.ts +0 -92
- package/dist/core/project-structure-detector.d.ts.map +0 -1
- package/dist/core/project-structure-detector.js +0 -289
- package/dist/core/project-structure-detector.js.map +0 -1
- package/dist/core/qa/qa-runner.d.ts +0 -16
- package/dist/core/qa/qa-runner.d.ts.map +0 -1
- package/dist/core/qa/qa-runner.js +0 -422
- package/dist/core/qa/qa-runner.js.map +0 -1
- package/dist/core/qa/quality-gate-decider.d.ts +0 -53
- package/dist/core/qa/quality-gate-decider.d.ts.map +0 -1
- package/dist/core/qa/quality-gate-decider.js +0 -268
- package/dist/core/qa/quality-gate-decider.js.map +0 -1
- package/dist/core/qa/risk-calculator.d.ts +0 -126
- package/dist/core/qa/risk-calculator.d.ts.map +0 -1
- package/dist/core/qa/risk-calculator.js +0 -247
- package/dist/core/qa/risk-calculator.js.map +0 -1
- package/dist/core/qa/types.d.ts +0 -315
- package/dist/core/qa/types.d.ts.map +0 -1
- package/dist/core/qa/types.js +0 -8
- package/dist/core/qa/types.js.map +0 -1
- package/dist/core/repo-structure/repo-structure-manager.d.ts +0 -82
- package/dist/core/repo-structure/repo-structure-manager.d.ts.map +0 -1
- package/dist/core/repo-structure/repo-structure-manager.js +0 -581
- package/dist/core/repo-structure/repo-structure-manager.js.map +0 -1
- package/dist/core/rfc-generator-v2.d.ts +0 -149
- package/dist/core/rfc-generator-v2.d.ts.map +0 -1
- package/dist/core/rfc-generator-v2.js +0 -399
- package/dist/core/rfc-generator-v2.js.map +0 -1
- package/dist/core/spec-task-mapper.d.ts +0 -71
- package/dist/core/spec-task-mapper.d.ts.map +0 -1
- package/dist/core/spec-task-mapper.js +0 -208
- package/dist/core/spec-task-mapper.js.map +0 -1
- package/dist/core/specs/spec-metadata-manager.d.ts +0 -70
- package/dist/core/specs/spec-metadata-manager.d.ts.map +0 -1
- package/dist/core/specs/spec-metadata-manager.js +0 -371
- package/dist/core/specs/spec-metadata-manager.js.map +0 -1
- package/dist/core/specs/spec-parser.d.ts +0 -66
- package/dist/core/specs/spec-parser.d.ts.map +0 -1
- package/dist/core/specs/spec-parser.js +0 -276
- package/dist/core/specs/spec-parser.js.map +0 -1
- package/dist/core/status-line/status-line-manager.d.ts +0 -62
- package/dist/core/status-line/status-line-manager.d.ts.map +0 -1
- package/dist/core/status-line/status-line-manager.js +0 -169
- package/dist/core/status-line/status-line-manager.js.map +0 -1
- package/dist/core/status-line/types.d.ts +0 -50
- package/dist/core/status-line/types.d.ts.map +0 -1
- package/dist/core/status-line/types.js +0 -17
- package/dist/core/status-line/types.js.map +0 -1
- package/dist/core/sync/bidirectional-engine.d.ts +0 -110
- package/dist/core/sync/bidirectional-engine.d.ts.map +0 -1
- package/dist/core/sync/bidirectional-engine.js +0 -356
- package/dist/core/sync/bidirectional-engine.js.map +0 -1
- package/dist/core/sync/folder-mapper.d.ts +0 -71
- package/dist/core/sync/folder-mapper.d.ts.map +0 -1
- package/dist/core/sync/folder-mapper.js +0 -203
- package/dist/core/sync/folder-mapper.js.map +0 -1
- package/dist/core/sync/profile-manager.d.ts +0 -72
- package/dist/core/sync/profile-manager.d.ts.map +0 -1
- package/dist/core/sync/profile-manager.js +0 -338
- package/dist/core/sync/profile-manager.js.map +0 -1
- package/dist/core/sync/profile-selector.d.ts +0 -52
- package/dist/core/sync/profile-selector.d.ts.map +0 -1
- package/dist/core/sync/profile-selector.js +0 -179
- package/dist/core/sync/profile-selector.js.map +0 -1
- package/dist/core/sync/profile-validator.d.ts +0 -52
- package/dist/core/sync/profile-validator.d.ts.map +0 -1
- package/dist/core/sync/profile-validator.js +0 -170
- package/dist/core/sync/profile-validator.js.map +0 -1
- package/dist/core/sync/project-context.d.ts +0 -81
- package/dist/core/sync/project-context.d.ts.map +0 -1
- package/dist/core/sync/project-context.js +0 -354
- package/dist/core/sync/project-context.js.map +0 -1
- package/dist/core/sync/rate-limiter.d.ts +0 -116
- package/dist/core/sync/rate-limiter.d.ts.map +0 -1
- package/dist/core/sync/rate-limiter.js +0 -308
- package/dist/core/sync/rate-limiter.js.map +0 -1
- package/dist/core/sync/time-range-selector.d.ts +0 -48
- package/dist/core/sync/time-range-selector.d.ts.map +0 -1
- package/dist/core/sync/time-range-selector.js +0 -224
- package/dist/core/sync/time-range-selector.js.map +0 -1
- package/dist/core/types/config.d.ts +0 -90
- package/dist/core/types/config.d.ts.map +0 -1
- package/dist/core/types/config.js +0 -44
- package/dist/core/types/config.js.map +0 -1
- package/dist/core/types/increment-metadata.d.ts +0 -120
- package/dist/core/types/increment-metadata.d.ts.map +0 -1
- package/dist/core/types/increment-metadata.js +0 -138
- package/dist/core/types/increment-metadata.js.map +0 -1
- package/dist/core/types/plugin.d.ts +0 -283
- package/dist/core/types/plugin.d.ts.map +0 -1
- package/dist/core/types/plugin.js +0 -49
- package/dist/core/types/plugin.js.map +0 -1
- package/dist/core/types/spec-metadata.d.ts +0 -229
- package/dist/core/types/spec-metadata.d.ts.map +0 -1
- package/dist/core/types/spec-metadata.js +0 -14
- package/dist/core/types/spec-metadata.js.map +0 -1
- package/dist/core/types/sync-profile.d.ts +0 -349
- package/dist/core/types/sync-profile.d.ts.map +0 -1
- package/dist/core/types/sync-profile.js +0 -79
- package/dist/core/types/sync-profile.js.map +0 -1
- package/dist/hooks/lib/git-diff-analyzer.d.ts +0 -89
- package/dist/hooks/lib/git-diff-analyzer.d.ts.map +0 -1
- package/dist/hooks/lib/git-diff-analyzer.js +0 -226
- package/dist/hooks/lib/git-diff-analyzer.js.map +0 -1
- package/dist/hooks/lib/invoke-translator-skill.d.ts +0 -60
- package/dist/hooks/lib/invoke-translator-skill.d.ts.map +0 -1
- package/dist/hooks/lib/invoke-translator-skill.js +0 -201
- package/dist/hooks/lib/invoke-translator-skill.js.map +0 -1
- package/dist/hooks/lib/prepare-reflection-context.d.ts +0 -42
- package/dist/hooks/lib/prepare-reflection-context.d.ts.map +0 -1
- package/dist/hooks/lib/prepare-reflection-context.js +0 -123
- package/dist/hooks/lib/prepare-reflection-context.js.map +0 -1
- package/dist/hooks/lib/reflection-config-loader.d.ts +0 -45
- package/dist/hooks/lib/reflection-config-loader.d.ts.map +0 -1
- package/dist/hooks/lib/reflection-config-loader.js +0 -132
- package/dist/hooks/lib/reflection-config-loader.js.map +0 -1
- package/dist/hooks/lib/reflection-parser.d.ts +0 -33
- package/dist/hooks/lib/reflection-parser.d.ts.map +0 -1
- package/dist/hooks/lib/reflection-parser.js +0 -419
- package/dist/hooks/lib/reflection-parser.js.map +0 -1
- package/dist/hooks/lib/reflection-prompt-builder.d.ts +0 -56
- package/dist/hooks/lib/reflection-prompt-builder.d.ts.map +0 -1
- package/dist/hooks/lib/reflection-prompt-builder.js +0 -239
- package/dist/hooks/lib/reflection-prompt-builder.js.map +0 -1
- package/dist/hooks/lib/reflection-storage.d.ts +0 -64
- package/dist/hooks/lib/reflection-storage.d.ts.map +0 -1
- package/dist/hooks/lib/reflection-storage.js +0 -305
- package/dist/hooks/lib/reflection-storage.js.map +0 -1
- package/dist/hooks/lib/run-self-reflection.d.ts +0 -43
- package/dist/hooks/lib/run-self-reflection.d.ts.map +0 -1
- package/dist/hooks/lib/run-self-reflection.js +0 -203
- package/dist/hooks/lib/run-self-reflection.js.map +0 -1
- package/dist/hooks/lib/sync-living-docs.d.ts +0 -27
- package/dist/hooks/lib/sync-living-docs.d.ts.map +0 -1
- package/dist/hooks/lib/sync-living-docs.js +0 -116
- package/dist/hooks/lib/sync-living-docs.js.map +0 -1
- package/dist/hooks/lib/translate-file.d.ts +0 -59
- package/dist/hooks/lib/translate-file.d.ts.map +0 -1
- package/dist/hooks/lib/translate-file.js +0 -350
- package/dist/hooks/lib/translate-file.js.map +0 -1
- package/dist/hooks/lib/translate-living-docs.d.ts +0 -13
- package/dist/hooks/lib/translate-living-docs.d.ts.map +0 -1
- package/dist/hooks/lib/translate-living-docs.js +0 -175
- package/dist/hooks/lib/translate-living-docs.js.map +0 -1
- package/dist/hooks/lib/types/reflection-types.d.ts +0 -164
- package/dist/hooks/lib/types/reflection-types.d.ts.map +0 -1
- package/dist/hooks/lib/types/reflection-types.js +0 -73
- package/dist/hooks/lib/types/reflection-types.js.map +0 -1
- package/dist/hooks/lib/update-tasks-md.d.ts +0 -29
- package/dist/hooks/lib/update-tasks-md.d.ts.map +0 -1
- package/dist/hooks/lib/update-tasks-md.js +0 -203
- package/dist/hooks/lib/update-tasks-md.js.map +0 -1
- package/dist/integrations/ado/ado-client.d.ts +0 -127
- package/dist/integrations/ado/ado-client.d.ts.map +0 -1
- package/dist/integrations/ado/ado-client.js +0 -416
- package/dist/integrations/ado/ado-client.js.map +0 -1
- package/dist/integrations/jira/jira-client.d.ts +0 -139
- package/dist/integrations/jira/jira-client.d.ts.map +0 -1
- package/dist/integrations/jira/jira-client.js +0 -386
- package/dist/integrations/jira/jira-client.js.map +0 -1
- package/dist/integrations/jira/jira-incremental-mapper.d.ts +0 -75
- package/dist/integrations/jira/jira-incremental-mapper.d.ts.map +0 -1
- package/dist/integrations/jira/jira-incremental-mapper.js +0 -474
- package/dist/integrations/jira/jira-incremental-mapper.js.map +0 -1
- package/dist/integrations/jira/jira-mapper.d.ts +0 -105
- package/dist/integrations/jira/jira-mapper.d.ts.map +0 -1
- package/dist/integrations/jira/jira-mapper.js +0 -494
- package/dist/integrations/jira/jira-mapper.js.map +0 -1
- package/dist/metrics/calculators/change-failure-rate.d.ts +0 -22
- package/dist/metrics/calculators/change-failure-rate.d.ts.map +0 -1
- package/dist/metrics/calculators/change-failure-rate.js +0 -70
- package/dist/metrics/calculators/change-failure-rate.js.map +0 -1
- package/dist/metrics/calculators/deployment-frequency.d.ts +0 -20
- package/dist/metrics/calculators/deployment-frequency.d.ts.map +0 -1
- package/dist/metrics/calculators/deployment-frequency.js +0 -61
- package/dist/metrics/calculators/deployment-frequency.js.map +0 -1
- package/dist/metrics/calculators/lead-time.d.ts +0 -22
- package/dist/metrics/calculators/lead-time.d.ts.map +0 -1
- package/dist/metrics/calculators/lead-time.js +0 -82
- package/dist/metrics/calculators/lead-time.js.map +0 -1
- package/dist/metrics/calculators/mttr.d.ts +0 -21
- package/dist/metrics/calculators/mttr.d.ts.map +0 -1
- package/dist/metrics/calculators/mttr.js +0 -60
- package/dist/metrics/calculators/mttr.js.map +0 -1
- package/dist/metrics/dora-calculator.d.ts +0 -28
- package/dist/metrics/dora-calculator.d.ts.map +0 -1
- package/dist/metrics/dora-calculator.js +0 -117
- package/dist/metrics/dora-calculator.js.map +0 -1
- package/dist/metrics/github-client.d.ts +0 -51
- package/dist/metrics/github-client.d.ts.map +0 -1
- package/dist/metrics/github-client.js +0 -133
- package/dist/metrics/github-client.js.map +0 -1
- package/dist/metrics/report-generator.d.ts +0 -17
- package/dist/metrics/report-generator.d.ts.map +0 -1
- package/dist/metrics/report-generator.js +0 -403
- package/dist/metrics/report-generator.js.map +0 -1
- package/dist/metrics/types.d.ts +0 -112
- package/dist/metrics/types.d.ts.map +0 -1
- package/dist/metrics/types.js +0 -10
- package/dist/metrics/types.js.map +0 -1
- package/dist/metrics/utils/percentile.d.ts +0 -25
- package/dist/metrics/utils/percentile.d.ts.map +0 -1
- package/dist/metrics/utils/percentile.js +0 -46
- package/dist/metrics/utils/percentile.js.map +0 -1
- package/dist/metrics/utils/tier-classifier.d.ts +0 -61
- package/dist/metrics/utils/tier-classifier.d.ts.map +0 -1
- package/dist/metrics/utils/tier-classifier.js +0 -100
- package/dist/metrics/utils/tier-classifier.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-board-resolver.d.ts +0 -94
- package/dist/plugins/specweave-ado/lib/ado-board-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-board-resolver.js +0 -219
- package/dist/plugins/specweave-ado/lib/ado-board-resolver.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.d.ts +0 -40
- package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.js +0 -370
- package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-multi-project-sync.d.ts +0 -149
- package/dist/plugins/specweave-ado/lib/ado-multi-project-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-multi-project-sync.js +0 -517
- package/dist/plugins/specweave-ado/lib/ado-multi-project-sync.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-project-detector.d.ts +0 -72
- package/dist/plugins/specweave-ado/lib/ado-project-detector.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-project-detector.js +0 -416
- package/dist/plugins/specweave-ado/lib/ado-project-detector.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/conflict-resolver.d.ts +0 -99
- package/dist/plugins/specweave-ado/lib/conflict-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/conflict-resolver.js +0 -331
- package/dist/plugins/specweave-ado/lib/conflict-resolver.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/project-selector.d.ts +0 -42
- package/dist/plugins/specweave-ado/lib/project-selector.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/project-selector.js +0 -211
- package/dist/plugins/specweave-ado/lib/project-selector.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-board-resolver.d.ts +0 -54
- package/dist/plugins/specweave-github/lib/github-board-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-board-resolver.js +0 -122
- package/dist/plugins/specweave-github/lib/github-board-resolver.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-hierarchical-sync.d.ts +0 -29
- package/dist/plugins/specweave-github/lib/github-hierarchical-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-hierarchical-sync.js +0 -268
- package/dist/plugins/specweave-github/lib/github-hierarchical-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-multi-project-sync.d.ts +0 -126
- package/dist/plugins/specweave-github/lib/github-multi-project-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-multi-project-sync.js +0 -420
- package/dist/plugins/specweave-github/lib/github-multi-project-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/repo-selector.d.ts +0 -49
- package/dist/plugins/specweave-github/lib/repo-selector.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/repo-selector.js +0 -216
- package/dist/plugins/specweave-github/lib/repo-selector.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.d.ts +0 -50
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.js +0 -84
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.d.ts +0 -33
- package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.js +0 -206
- package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-multi-project-sync.d.ts +0 -95
- package/dist/plugins/specweave-jira/lib/jira-multi-project-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-multi-project-sync.js +0 -301
- package/dist/plugins/specweave-jira/lib/jira-multi-project-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/project-selector.d.ts +0 -42
- package/dist/plugins/specweave-jira/lib/project-selector.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/project-selector.js +0 -216
- package/dist/plugins/specweave-jira/lib/project-selector.js.map +0 -1
- package/dist/project-mapper.js +0 -272
- package/dist/scripts/split-spec-by-project.js +0 -105
- package/dist/spec-splitter.js +0 -283
- package/dist/src/core/agent-model-manager.d.ts +0 -52
- package/dist/src/core/agent-model-manager.d.ts.map +0 -1
- package/dist/src/core/agent-model-manager.js +0 -120
- package/dist/src/core/agent-model-manager.js.map +0 -1
- package/dist/src/core/model-selector.d.ts +0 -57
- package/dist/src/core/model-selector.d.ts.map +0 -1
- package/dist/src/core/model-selector.js +0 -115
- package/dist/src/core/model-selector.js.map +0 -1
- package/dist/src/core/phase-detector.d.ts +0 -62
- package/dist/src/core/phase-detector.d.ts.map +0 -1
- package/dist/src/core/phase-detector.js +0 -229
- package/dist/src/core/phase-detector.js.map +0 -1
- package/dist/src/hooks/lib/git-diff-analyzer.d.ts +0 -89
- package/dist/src/hooks/lib/git-diff-analyzer.d.ts.map +0 -1
- package/dist/src/hooks/lib/git-diff-analyzer.js +0 -226
- package/dist/src/hooks/lib/git-diff-analyzer.js.map +0 -1
- package/dist/src/hooks/lib/invoke-translator-skill.d.ts +0 -60
- package/dist/src/hooks/lib/invoke-translator-skill.d.ts.map +0 -1
- package/dist/src/hooks/lib/invoke-translator-skill.js +0 -201
- package/dist/src/hooks/lib/invoke-translator-skill.js.map +0 -1
- package/dist/src/hooks/lib/prepare-reflection-context.d.ts +0 -42
- package/dist/src/hooks/lib/prepare-reflection-context.d.ts.map +0 -1
- package/dist/src/hooks/lib/prepare-reflection-context.js +0 -123
- package/dist/src/hooks/lib/prepare-reflection-context.js.map +0 -1
- package/dist/src/hooks/lib/reflection-config-loader.d.ts +0 -45
- package/dist/src/hooks/lib/reflection-config-loader.d.ts.map +0 -1
- package/dist/src/hooks/lib/reflection-config-loader.js +0 -132
- package/dist/src/hooks/lib/reflection-config-loader.js.map +0 -1
- package/dist/src/hooks/lib/reflection-parser.d.ts +0 -33
- package/dist/src/hooks/lib/reflection-parser.d.ts.map +0 -1
- package/dist/src/hooks/lib/reflection-parser.js +0 -419
- package/dist/src/hooks/lib/reflection-parser.js.map +0 -1
- package/dist/src/hooks/lib/reflection-prompt-builder.d.ts +0 -56
- package/dist/src/hooks/lib/reflection-prompt-builder.d.ts.map +0 -1
- package/dist/src/hooks/lib/reflection-prompt-builder.js +0 -239
- package/dist/src/hooks/lib/reflection-prompt-builder.js.map +0 -1
- package/dist/src/hooks/lib/reflection-storage.d.ts +0 -64
- package/dist/src/hooks/lib/reflection-storage.d.ts.map +0 -1
- package/dist/src/hooks/lib/reflection-storage.js +0 -305
- package/dist/src/hooks/lib/reflection-storage.js.map +0 -1
- package/dist/src/hooks/lib/run-self-reflection.d.ts +0 -43
- package/dist/src/hooks/lib/run-self-reflection.d.ts.map +0 -1
- package/dist/src/hooks/lib/run-self-reflection.js +0 -203
- package/dist/src/hooks/lib/run-self-reflection.js.map +0 -1
- package/dist/src/hooks/lib/sync-living-docs.d.ts +0 -27
- package/dist/src/hooks/lib/sync-living-docs.d.ts.map +0 -1
- package/dist/src/hooks/lib/sync-living-docs.js +0 -116
- package/dist/src/hooks/lib/sync-living-docs.js.map +0 -1
- package/dist/src/hooks/lib/translate-file.d.ts +0 -59
- package/dist/src/hooks/lib/translate-file.d.ts.map +0 -1
- package/dist/src/hooks/lib/translate-file.js +0 -350
- package/dist/src/hooks/lib/translate-file.js.map +0 -1
- package/dist/src/hooks/lib/translate-living-docs.d.ts +0 -13
- package/dist/src/hooks/lib/translate-living-docs.d.ts.map +0 -1
- package/dist/src/hooks/lib/translate-living-docs.js +0 -175
- package/dist/src/hooks/lib/translate-living-docs.js.map +0 -1
- package/dist/src/hooks/lib/types/reflection-types.d.ts +0 -164
- package/dist/src/hooks/lib/types/reflection-types.d.ts.map +0 -1
- package/dist/src/hooks/lib/types/reflection-types.js +0 -73
- package/dist/src/hooks/lib/types/reflection-types.js.map +0 -1
- package/dist/src/hooks/lib/update-tasks-md.d.ts +0 -29
- package/dist/src/hooks/lib/update-tasks-md.d.ts.map +0 -1
- package/dist/src/hooks/lib/update-tasks-md.js +0 -203
- package/dist/src/hooks/lib/update-tasks-md.js.map +0 -1
- package/dist/testing/test-generator.d.ts +0 -117
- package/dist/testing/test-generator.d.ts.map +0 -1
- package/dist/testing/test-generator.js +0 -370
- package/dist/testing/test-generator.js.map +0 -1
- package/dist/types/cost-tracking.d.ts +0 -43
- package/dist/types/cost-tracking.d.ts.map +0 -1
- package/dist/types/cost-tracking.js +0 -8
- package/dist/types/cost-tracking.js.map +0 -1
- package/dist/types/model-selection.d.ts +0 -53
- package/dist/types/model-selection.d.ts.map +0 -1
- package/dist/types/model-selection.js +0 -12
- package/dist/types/model-selection.js.map +0 -1
- package/dist/utils/agents-md-compiler.d.ts +0 -68
- package/dist/utils/agents-md-compiler.d.ts.map +0 -1
- package/dist/utils/agents-md-compiler.js +0 -420
- package/dist/utils/agents-md-compiler.js.map +0 -1
- package/dist/utils/auth-helpers.d.ts +0 -58
- package/dist/utils/auth-helpers.d.ts.map +0 -1
- package/dist/utils/auth-helpers.js +0 -108
- package/dist/utils/auth-helpers.js.map +0 -1
- package/dist/utils/auto-install.d.ts +0 -47
- package/dist/utils/auto-install.d.ts.map +0 -1
- package/dist/utils/auto-install.js +0 -211
- package/dist/utils/auto-install.js.map +0 -1
- package/dist/utils/claude-cli-detector.d.ts +0 -75
- package/dist/utils/claude-cli-detector.d.ts.map +0 -1
- package/dist/utils/claude-cli-detector.js +0 -285
- package/dist/utils/claude-cli-detector.js.map +0 -1
- package/dist/utils/cost-reporter.d.ts +0 -58
- package/dist/utils/cost-reporter.d.ts.map +0 -1
- package/dist/utils/cost-reporter.js +0 -224
- package/dist/utils/cost-reporter.js.map +0 -1
- package/dist/utils/docs-preview/config-generator.d.ts +0 -46
- package/dist/utils/docs-preview/config-generator.d.ts.map +0 -1
- package/dist/utils/docs-preview/config-generator.js +0 -377
- package/dist/utils/docs-preview/config-generator.js.map +0 -1
- package/dist/utils/docs-preview/docusaurus-setup.d.ts +0 -38
- package/dist/utils/docs-preview/docusaurus-setup.d.ts.map +0 -1
- package/dist/utils/docs-preview/docusaurus-setup.js +0 -177
- package/dist/utils/docs-preview/docusaurus-setup.js.map +0 -1
- package/dist/utils/docs-preview/index.d.ts +0 -7
- package/dist/utils/docs-preview/index.d.ts.map +0 -1
- package/dist/utils/docs-preview/index.js +0 -7
- package/dist/utils/docs-preview/index.js.map +0 -1
- package/dist/utils/docs-preview/package-installer.d.ts +0 -42
- package/dist/utils/docs-preview/package-installer.d.ts.map +0 -1
- package/dist/utils/docs-preview/package-installer.js +0 -182
- package/dist/utils/docs-preview/package-installer.js.map +0 -1
- package/dist/utils/docs-preview/server-manager.d.ts +0 -30
- package/dist/utils/docs-preview/server-manager.d.ts.map +0 -1
- package/dist/utils/docs-preview/server-manager.js +0 -212
- package/dist/utils/docs-preview/server-manager.js.map +0 -1
- package/dist/utils/docs-preview/sidebar-builder.d.ts +0 -32
- package/dist/utils/docs-preview/sidebar-builder.d.ts.map +0 -1
- package/dist/utils/docs-preview/sidebar-builder.js +0 -202
- package/dist/utils/docs-preview/sidebar-builder.js.map +0 -1
- package/dist/utils/docs-preview/types.d.ts +0 -57
- package/dist/utils/docs-preview/types.d.ts.map +0 -1
- package/dist/utils/docs-preview/types.js +0 -2
- package/dist/utils/docs-preview/types.js.map +0 -1
- package/dist/utils/env-file.d.ts +0 -88
- package/dist/utils/env-file.d.ts.map +0 -1
- package/dist/utils/env-file.js +0 -180
- package/dist/utils/env-file.js.map +0 -1
- package/dist/utils/env-multi-project-parser.d.ts +0 -220
- package/dist/utils/env-multi-project-parser.d.ts.map +0 -1
- package/dist/utils/env-multi-project-parser.js +0 -401
- package/dist/utils/env-multi-project-parser.js.map +0 -1
- package/dist/utils/esm-helpers.d.ts +0 -50
- package/dist/utils/esm-helpers.d.ts.map +0 -1
- package/dist/utils/esm-helpers.js +0 -57
- package/dist/utils/esm-helpers.js.map +0 -1
- package/dist/utils/execFileNoThrow.d.ts +0 -99
- package/dist/utils/execFileNoThrow.d.ts.map +0 -1
- package/dist/utils/execFileNoThrow.js +0 -137
- package/dist/utils/execFileNoThrow.js.map +0 -1
- package/dist/utils/external-resource-validator.d.ts +0 -102
- package/dist/utils/external-resource-validator.d.ts.map +0 -1
- package/dist/utils/external-resource-validator.js +0 -504
- package/dist/utils/external-resource-validator.js.map +0 -1
- package/dist/utils/generate-skills-index.d.ts +0 -24
- package/dist/utils/generate-skills-index.d.ts.map +0 -1
- package/dist/utils/generate-skills-index.js +0 -410
- package/dist/utils/generate-skills-index.js.map +0 -1
- package/dist/utils/git-detector.d.ts +0 -84
- package/dist/utils/git-detector.d.ts.map +0 -1
- package/dist/utils/git-detector.js +0 -233
- package/dist/utils/git-detector.js.map +0 -1
- package/dist/utils/git-utils.d.ts +0 -74
- package/dist/utils/git-utils.d.ts.map +0 -1
- package/dist/utils/git-utils.js +0 -272
- package/dist/utils/git-utils.js.map +0 -1
- package/dist/utils/model-selection.d.ts +0 -75
- package/dist/utils/model-selection.d.ts.map +0 -1
- package/dist/utils/model-selection.js +0 -204
- package/dist/utils/model-selection.js.map +0 -1
- package/dist/utils/plugin-validator.d.ts +0 -161
- package/dist/utils/plugin-validator.d.ts.map +0 -1
- package/dist/utils/plugin-validator.js +0 -558
- package/dist/utils/plugin-validator.js.map +0 -1
- package/dist/utils/pricing-constants.d.ts +0 -70
- package/dist/utils/pricing-constants.d.ts.map +0 -1
- package/dist/utils/pricing-constants.js +0 -71
- package/dist/utils/pricing-constants.js.map +0 -1
- package/dist/utils/project-detection.d.ts +0 -141
- package/dist/utils/project-detection.d.ts.map +0 -1
- package/dist/utils/project-detection.js +0 -321
- package/dist/utils/project-detection.js.map +0 -1
- package/dist/utils/project-mapper.d.ts +0 -92
- package/dist/utils/project-mapper.d.ts.map +0 -1
- package/dist/utils/project-mapper.js +0 -276
- package/dist/utils/project-mapper.js.map +0 -1
- package/dist/utils/spec-splitter.d.ts +0 -75
- package/dist/utils/spec-splitter.d.ts.map +0 -1
- package/dist/utils/spec-splitter.js +0 -332
- package/dist/utils/spec-splitter.js.map +0 -1
- package/dist/utils/string-utils.d.ts +0 -40
- package/dist/utils/string-utils.d.ts.map +0 -1
- package/dist/utils/string-utils.js +0 -58
- package/dist/utils/string-utils.js.map +0 -1
- package/dist/utils/translation.d.ts +0 -187
- package/dist/utils/translation.d.ts.map +0 -1
- package/dist/utils/translation.js +0 -414
- package/dist/utils/translation.js.map +0 -1
- /package/dist/{locales → src/locales}/de/.gitkeep +0 -0
- /package/dist/{locales → src/locales}/de/cli.json +0 -0
- /package/dist/{locales → src/locales}/en/cli.json +0 -0
- /package/dist/{locales → src/locales}/en/errors.json +0 -0
- /package/dist/{locales → src/locales}/en/templates.json +0 -0
- /package/dist/{locales → src/locales}/es/.gitkeep +0 -0
- /package/dist/{locales → src/locales}/es/cli.json +0 -0
- /package/dist/{locales → src/locales}/fr/.gitkeep +0 -0
- /package/dist/{locales → src/locales}/fr/cli.json +0 -0
- /package/dist/{locales → src/locales}/ja/.gitkeep +0 -0
- /package/dist/{locales → src/locales}/ja/cli.json +0 -0
- /package/dist/{locales → src/locales}/ko/.gitkeep +0 -0
- /package/dist/{locales → src/locales}/ko/cli.json +0 -0
- /package/dist/{locales → src/locales}/pt/.gitkeep +0 -0
- /package/dist/{locales → src/locales}/pt/cli.json +0 -0
- /package/dist/{locales → src/locales}/ru/.gitkeep +0 -0
- /package/dist/{locales → src/locales}/ru/cli.json +0 -0
- /package/dist/{locales → src/locales}/zh/.gitkeep +0 -0
- /package/dist/{locales → src/locales}/zh/cli.json +0 -0
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Agent Model Manager
|
|
3
|
-
*
|
|
4
|
-
* Loads and manages agent model preferences from AGENT.md frontmatter.
|
|
5
|
-
* Each agent declares:
|
|
6
|
-
* - model_preference: sonnet | haiku | opus | auto
|
|
7
|
-
* - cost_profile: planning | execution | hybrid
|
|
8
|
-
* - fallback_behavior: strict | flexible | auto
|
|
9
|
-
*
|
|
10
|
-
* Planning agents (PM, Architect, Security) prefer Sonnet.
|
|
11
|
-
* Execution agents (Frontend, Backend, DevOps) prefer Haiku.
|
|
12
|
-
* Hybrid agents (Diagrams, Docs) use auto (context-dependent).
|
|
13
|
-
*/
|
|
14
|
-
import type { AgentModelPreference, Model, CostProfile, FallbackBehavior } from '../types/model-selection';
|
|
15
|
-
export declare class AgentModelManager {
|
|
16
|
-
private preferences;
|
|
17
|
-
private agentsPath;
|
|
18
|
-
constructor(agentsPath?: string);
|
|
19
|
-
/**
|
|
20
|
-
* Load all agent preferences from src/agents/
|
|
21
|
-
*/
|
|
22
|
-
loadAllPreferences(): Promise<void>;
|
|
23
|
-
/**
|
|
24
|
-
* Load preference for a specific agent
|
|
25
|
-
*/
|
|
26
|
-
loadAgentPreference(agentName: string): Promise<AgentModelPreference | null>;
|
|
27
|
-
/**
|
|
28
|
-
* Extract YAML frontmatter from markdown content
|
|
29
|
-
*/
|
|
30
|
-
private extractFrontmatter;
|
|
31
|
-
/**
|
|
32
|
-
* Get preferred model for an agent (returns 'auto' if not found)
|
|
33
|
-
*/
|
|
34
|
-
getPreferredModel(agentName: string): Model;
|
|
35
|
-
/**
|
|
36
|
-
* Get cost profile for an agent (returns 'hybrid' if not found)
|
|
37
|
-
*/
|
|
38
|
-
getCostProfile(agentName: string): CostProfile;
|
|
39
|
-
/**
|
|
40
|
-
* Get fallback behavior for an agent
|
|
41
|
-
*/
|
|
42
|
-
getFallbackBehavior(agentName: string): FallbackBehavior;
|
|
43
|
-
/**
|
|
44
|
-
* Get all loaded preferences (for debugging/reporting)
|
|
45
|
-
*/
|
|
46
|
-
getAllPreferences(): Map<string, AgentModelPreference>;
|
|
47
|
-
/**
|
|
48
|
-
* Check if an agent has explicit preference (not 'auto')
|
|
49
|
-
*/
|
|
50
|
-
hasExplicitPreference(agentName: string): boolean;
|
|
51
|
-
}
|
|
52
|
-
//# sourceMappingURL=agent-model-manager.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"agent-model-manager.d.ts","sourceRoot":"","sources":["../../../src/core/agent-model-manager.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAKH,OAAO,KAAK,EAAE,oBAAoB,EAAE,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAE3G,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,WAAW,CAAgD;IACnE,OAAO,CAAC,UAAU,CAAS;gBAEf,UAAU,CAAC,EAAE,MAAM;IAK/B;;OAEG;IACG,kBAAkB,IAAI,OAAO,CAAC,IAAI,CAAC;IAoBzC;;OAEG;IACG,mBAAmB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,GAAG,IAAI,CAAC;IA2BlF;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAY1B;;OAEG;IACH,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,KAAK;IAK3C;;OAEG;IACH,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,WAAW;IAK9C;;OAEG;IACH,mBAAmB,CAAC,SAAS,EAAE,MAAM,GAAG,gBAAgB;IAKxD;;OAEG;IACH,iBAAiB,IAAI,GAAG,CAAC,MAAM,EAAE,oBAAoB,CAAC;IAItD;;OAEG;IACH,qBAAqB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO;CAIlD"}
|
|
@@ -1,120 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Agent Model Manager
|
|
3
|
-
*
|
|
4
|
-
* Loads and manages agent model preferences from AGENT.md frontmatter.
|
|
5
|
-
* Each agent declares:
|
|
6
|
-
* - model_preference: sonnet | haiku | opus | auto
|
|
7
|
-
* - cost_profile: planning | execution | hybrid
|
|
8
|
-
* - fallback_behavior: strict | flexible | auto
|
|
9
|
-
*
|
|
10
|
-
* Planning agents (PM, Architect, Security) prefer Sonnet.
|
|
11
|
-
* Execution agents (Frontend, Backend, DevOps) prefer Haiku.
|
|
12
|
-
* Hybrid agents (Diagrams, Docs) use auto (context-dependent).
|
|
13
|
-
*/
|
|
14
|
-
import fs from 'fs-extra';
|
|
15
|
-
import path from 'path';
|
|
16
|
-
import yaml from 'js-yaml';
|
|
17
|
-
export class AgentModelManager {
|
|
18
|
-
constructor(agentsPath) {
|
|
19
|
-
this.preferences = new Map();
|
|
20
|
-
// Default to src/agents (works in development and after build)
|
|
21
|
-
this.agentsPath = agentsPath || path.join(__dirname, '../agents');
|
|
22
|
-
}
|
|
23
|
-
/**
|
|
24
|
-
* Load all agent preferences from src/agents/
|
|
25
|
-
*/
|
|
26
|
-
async loadAllPreferences() {
|
|
27
|
-
try {
|
|
28
|
-
const agentDirs = await fs.readdir(this.agentsPath);
|
|
29
|
-
for (const agentDir of agentDirs) {
|
|
30
|
-
const agentMdPath = path.join(this.agentsPath, agentDir, 'AGENT.md');
|
|
31
|
-
if (await fs.pathExists(agentMdPath)) {
|
|
32
|
-
const preference = await this.loadAgentPreference(agentDir);
|
|
33
|
-
if (preference) {
|
|
34
|
-
this.preferences.set(agentDir, preference);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
catch (error) {
|
|
40
|
-
console.warn('Failed to load agent preferences:', error);
|
|
41
|
-
// Continue with empty preferences (fallback to defaults)
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
/**
|
|
45
|
-
* Load preference for a specific agent
|
|
46
|
-
*/
|
|
47
|
-
async loadAgentPreference(agentName) {
|
|
48
|
-
const agentMdPath = path.join(this.agentsPath, agentName, 'AGENT.md');
|
|
49
|
-
if (!await fs.pathExists(agentMdPath)) {
|
|
50
|
-
return null;
|
|
51
|
-
}
|
|
52
|
-
try {
|
|
53
|
-
const content = await fs.readFile(agentMdPath, 'utf-8');
|
|
54
|
-
const frontmatter = this.extractFrontmatter(content);
|
|
55
|
-
if (!frontmatter) {
|
|
56
|
-
return null;
|
|
57
|
-
}
|
|
58
|
-
return {
|
|
59
|
-
agent: agentName,
|
|
60
|
-
preference: frontmatter.model_preference || 'auto',
|
|
61
|
-
profile: frontmatter.cost_profile || 'hybrid',
|
|
62
|
-
fallback: frontmatter.fallback_behavior || 'auto',
|
|
63
|
-
};
|
|
64
|
-
}
|
|
65
|
-
catch (error) {
|
|
66
|
-
console.warn(`Failed to load preference for agent ${agentName}:`, error);
|
|
67
|
-
return null;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Extract YAML frontmatter from markdown content
|
|
72
|
-
*/
|
|
73
|
-
extractFrontmatter(content) {
|
|
74
|
-
const match = content.match(/^---\n([\s\S]*?)\n---/);
|
|
75
|
-
if (!match)
|
|
76
|
-
return null;
|
|
77
|
-
try {
|
|
78
|
-
return yaml.load(match[1]);
|
|
79
|
-
}
|
|
80
|
-
catch (error) {
|
|
81
|
-
console.error('Failed to parse YAML frontmatter:', error);
|
|
82
|
-
return null;
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
/**
|
|
86
|
-
* Get preferred model for an agent (returns 'auto' if not found)
|
|
87
|
-
*/
|
|
88
|
-
getPreferredModel(agentName) {
|
|
89
|
-
const preference = this.preferences.get(agentName);
|
|
90
|
-
return preference?.preference || 'auto';
|
|
91
|
-
}
|
|
92
|
-
/**
|
|
93
|
-
* Get cost profile for an agent (returns 'hybrid' if not found)
|
|
94
|
-
*/
|
|
95
|
-
getCostProfile(agentName) {
|
|
96
|
-
const preference = this.preferences.get(agentName);
|
|
97
|
-
return preference?.profile || 'hybrid';
|
|
98
|
-
}
|
|
99
|
-
/**
|
|
100
|
-
* Get fallback behavior for an agent
|
|
101
|
-
*/
|
|
102
|
-
getFallbackBehavior(agentName) {
|
|
103
|
-
const preference = this.preferences.get(agentName);
|
|
104
|
-
return preference?.fallback || 'auto';
|
|
105
|
-
}
|
|
106
|
-
/**
|
|
107
|
-
* Get all loaded preferences (for debugging/reporting)
|
|
108
|
-
*/
|
|
109
|
-
getAllPreferences() {
|
|
110
|
-
return new Map(this.preferences);
|
|
111
|
-
}
|
|
112
|
-
/**
|
|
113
|
-
* Check if an agent has explicit preference (not 'auto')
|
|
114
|
-
*/
|
|
115
|
-
hasExplicitPreference(agentName) {
|
|
116
|
-
const pref = this.getPreferredModel(agentName);
|
|
117
|
-
return pref !== 'auto';
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
//# sourceMappingURL=agent-model-manager.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"agent-model-manager.js","sourceRoot":"","sources":["../../../src/core/agent-model-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Model Selector
|
|
3
|
-
*
|
|
4
|
-
* Decision engine that combines agent preferences + phase detection to select
|
|
5
|
-
* the optimal AI model for each task.
|
|
6
|
-
*
|
|
7
|
-
* Decision hierarchy:
|
|
8
|
-
* 1. User override (--model flag) - Always wins
|
|
9
|
-
* 2. Agent preference (from AGENT.md) - Used when not 'auto'
|
|
10
|
-
* 3. Phase detection - Used for 'auto' agents with high confidence
|
|
11
|
-
* 4. Safe default (Sonnet) - Used when confidence is low
|
|
12
|
-
*
|
|
13
|
-
* Achieves 60-70% cost savings by routing execution to Haiku.
|
|
14
|
-
*/
|
|
15
|
-
import type { Model, ModelSelectionDecision } from '../types/model-selection';
|
|
16
|
-
import type { ExecutionContext } from './phase-detector';
|
|
17
|
-
import { AgentModelManager } from './agent-model-manager';
|
|
18
|
-
import { PhaseDetector } from './phase-detector';
|
|
19
|
-
export interface ModelSelectionConfig {
|
|
20
|
-
mode: 'auto' | 'balanced' | 'manual';
|
|
21
|
-
forceModel?: Exclude<Model, 'auto'>;
|
|
22
|
-
highConfidenceThreshold: number;
|
|
23
|
-
mediumConfidenceThreshold: number;
|
|
24
|
-
defaultPlanningModel: 'sonnet' | 'opus';
|
|
25
|
-
defaultExecutionModel: 'haiku' | 'sonnet';
|
|
26
|
-
defaultReviewModel: 'sonnet' | 'opus';
|
|
27
|
-
logDecisions: boolean;
|
|
28
|
-
showReasoning: boolean;
|
|
29
|
-
}
|
|
30
|
-
export declare class ModelSelector {
|
|
31
|
-
private agentModelManager;
|
|
32
|
-
private phaseDetector;
|
|
33
|
-
private config;
|
|
34
|
-
constructor(agentModelManager: AgentModelManager, phaseDetector: PhaseDetector, config?: Partial<ModelSelectionConfig>);
|
|
35
|
-
/**
|
|
36
|
-
* Select optimal model for a given task
|
|
37
|
-
*
|
|
38
|
-
* @param prompt - User's prompt/task description
|
|
39
|
-
* @param agent - Agent name (e.g., 'pm', 'frontend', 'architect')
|
|
40
|
-
* @param context - Execution context (command, increment state, etc.)
|
|
41
|
-
* @returns Model selection decision with reasoning
|
|
42
|
-
*/
|
|
43
|
-
select(prompt: string, agent: string, context?: ExecutionContext): ModelSelectionDecision;
|
|
44
|
-
/**
|
|
45
|
-
* Log model selection decision (if logging enabled)
|
|
46
|
-
*/
|
|
47
|
-
logDecision(decision: ModelSelectionDecision, agent: string): void;
|
|
48
|
-
/**
|
|
49
|
-
* Update configuration
|
|
50
|
-
*/
|
|
51
|
-
updateConfig(config: Partial<ModelSelectionConfig>): void;
|
|
52
|
-
/**
|
|
53
|
-
* Get current configuration
|
|
54
|
-
*/
|
|
55
|
-
getConfig(): ModelSelectionConfig;
|
|
56
|
-
}
|
|
57
|
-
//# sourceMappingURL=model-selector.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"model-selector.d.ts","sourceRoot":"","sources":["../../../src/core/model-selector.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,KAAK,EAAE,KAAK,EAAS,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AACrF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,MAAM,GAAG,UAAU,GAAG,QAAQ,CAAC;IACrC,UAAU,CAAC,EAAE,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACpC,uBAAuB,EAAE,MAAM,CAAC;IAChC,yBAAyB,EAAE,MAAM,CAAC;IAClC,oBAAoB,EAAE,QAAQ,GAAG,MAAM,CAAC;IACxC,qBAAqB,EAAE,OAAO,GAAG,QAAQ,CAAC;IAC1C,kBAAkB,EAAE,QAAQ,GAAG,MAAM,CAAC;IACtC,YAAY,EAAE,OAAO,CAAC;IACtB,aAAa,EAAE,OAAO,CAAC;CACxB;AAsBD,qBAAa,aAAa;IACxB,OAAO,CAAC,iBAAiB,CAAoB;IAC7C,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,MAAM,CAAuB;gBAGnC,iBAAiB,EAAE,iBAAiB,EACpC,aAAa,EAAE,aAAa,EAC5B,MAAM,GAAE,OAAO,CAAC,oBAAoB,CAAM;IAO5C;;;;;;;OAOG;IACH,MAAM,CACJ,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EACb,OAAO,GAAE,gBAAqB,GAC7B,sBAAsB;IA8CzB;;OAEG;IACH,WAAW,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAalE;;OAEG;IACH,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,oBAAoB,CAAC,GAAG,IAAI;IAIzD;;OAEG;IACH,SAAS,IAAI,oBAAoB;CAGlC"}
|
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Model Selector
|
|
3
|
-
*
|
|
4
|
-
* Decision engine that combines agent preferences + phase detection to select
|
|
5
|
-
* the optimal AI model for each task.
|
|
6
|
-
*
|
|
7
|
-
* Decision hierarchy:
|
|
8
|
-
* 1. User override (--model flag) - Always wins
|
|
9
|
-
* 2. Agent preference (from AGENT.md) - Used when not 'auto'
|
|
10
|
-
* 3. Phase detection - Used for 'auto' agents with high confidence
|
|
11
|
-
* 4. Safe default (Sonnet) - Used when confidence is low
|
|
12
|
-
*
|
|
13
|
-
* Achieves 60-70% cost savings by routing execution to Haiku.
|
|
14
|
-
*/
|
|
15
|
-
const DEFAULT_CONFIG = {
|
|
16
|
-
mode: 'auto',
|
|
17
|
-
highConfidenceThreshold: 0.7,
|
|
18
|
-
mediumConfidenceThreshold: 0.4,
|
|
19
|
-
defaultPlanningModel: 'sonnet',
|
|
20
|
-
defaultExecutionModel: 'haiku',
|
|
21
|
-
defaultReviewModel: 'sonnet',
|
|
22
|
-
logDecisions: true,
|
|
23
|
-
showReasoning: true,
|
|
24
|
-
};
|
|
25
|
-
/**
|
|
26
|
-
* Phase-to-model mapping (when agent is 'auto')
|
|
27
|
-
*/
|
|
28
|
-
const PHASE_MODEL_MAP = {
|
|
29
|
-
planning: 'sonnet',
|
|
30
|
-
execution: 'haiku',
|
|
31
|
-
review: 'sonnet',
|
|
32
|
-
};
|
|
33
|
-
export class ModelSelector {
|
|
34
|
-
constructor(agentModelManager, phaseDetector, config = {}) {
|
|
35
|
-
this.agentModelManager = agentModelManager;
|
|
36
|
-
this.phaseDetector = phaseDetector;
|
|
37
|
-
this.config = { ...DEFAULT_CONFIG, ...config };
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Select optimal model for a given task
|
|
41
|
-
*
|
|
42
|
-
* @param prompt - User's prompt/task description
|
|
43
|
-
* @param agent - Agent name (e.g., 'pm', 'frontend', 'architect')
|
|
44
|
-
* @param context - Execution context (command, increment state, etc.)
|
|
45
|
-
* @returns Model selection decision with reasoning
|
|
46
|
-
*/
|
|
47
|
-
select(prompt, agent, context = {}) {
|
|
48
|
-
// Step 1: Check explicit user override
|
|
49
|
-
if (this.config.forceModel) {
|
|
50
|
-
return {
|
|
51
|
-
model: this.config.forceModel,
|
|
52
|
-
reason: 'user_override',
|
|
53
|
-
reasoning: `User explicitly forced ${this.config.forceModel} model via --model flag`,
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
// Step 2: Load agent preference
|
|
57
|
-
const agentPref = this.agentModelManager.getPreferredModel(agent);
|
|
58
|
-
const costProfile = this.agentModelManager.getCostProfile(agent);
|
|
59
|
-
// If agent has explicit preference (not 'auto'), use it
|
|
60
|
-
if (agentPref !== 'auto') {
|
|
61
|
-
return {
|
|
62
|
-
model: agentPref,
|
|
63
|
-
reason: 'agent_preference',
|
|
64
|
-
reasoning: `Agent '${agent}' prefers ${agentPref} for ${costProfile} work`,
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
// Step 3: Detect phase (for 'auto' agents)
|
|
68
|
-
const phaseDetection = this.phaseDetector.detect(prompt, context);
|
|
69
|
-
// Step 4: Apply decision matrix based on confidence
|
|
70
|
-
if (phaseDetection.confidence >= this.config.highConfidenceThreshold) {
|
|
71
|
-
// High confidence - use phase-based model
|
|
72
|
-
return {
|
|
73
|
-
model: PHASE_MODEL_MAP[phaseDetection.phase],
|
|
74
|
-
reason: 'phase_detection',
|
|
75
|
-
confidence: phaseDetection.confidence,
|
|
76
|
-
reasoning: phaseDetection.reasoning,
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
// Step 5: Low confidence - default to Sonnet for safety
|
|
80
|
-
return {
|
|
81
|
-
model: 'sonnet',
|
|
82
|
-
reason: 'low_confidence_default',
|
|
83
|
-
confidence: phaseDetection.confidence,
|
|
84
|
-
reasoning: `Low confidence (${(phaseDetection.confidence * 100).toFixed(0)}%), defaulting to Sonnet for safety. Detected: ${phaseDetection.reasoning}`,
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
/**
|
|
88
|
-
* Log model selection decision (if logging enabled)
|
|
89
|
-
*/
|
|
90
|
-
logDecision(decision, agent) {
|
|
91
|
-
if (!this.config.logDecisions)
|
|
92
|
-
return;
|
|
93
|
-
const timestamp = new Date().toISOString();
|
|
94
|
-
const logMessage = `[${timestamp}] [Model Selection] Agent: ${agent} → ${decision.model} (${decision.reason})`;
|
|
95
|
-
if (this.config.showReasoning) {
|
|
96
|
-
console.log(`${logMessage}\n Reasoning: ${decision.reasoning}`);
|
|
97
|
-
}
|
|
98
|
-
else {
|
|
99
|
-
console.log(logMessage);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
/**
|
|
103
|
-
* Update configuration
|
|
104
|
-
*/
|
|
105
|
-
updateConfig(config) {
|
|
106
|
-
this.config = { ...this.config, ...config };
|
|
107
|
-
}
|
|
108
|
-
/**
|
|
109
|
-
* Get current configuration
|
|
110
|
-
*/
|
|
111
|
-
getConfig() {
|
|
112
|
-
return { ...this.config };
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
//# sourceMappingURL=model-selector.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"model-selector.js","sourceRoot":"","sources":["../../../src/core/model-selector.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Phase Detector
|
|
3
|
-
*
|
|
4
|
-
* Multi-signal phase detection algorithm that analyzes user prompts and context
|
|
5
|
-
* to determine whether work is in planning, execution, or review phase.
|
|
6
|
-
*
|
|
7
|
-
* Uses 4 signals with weighted scoring:
|
|
8
|
-
* 1. Keyword analysis (40%) - Planning/execution/review keywords
|
|
9
|
-
* 2. Command analysis (30%) - Slash commands hint at phase
|
|
10
|
-
* 3. Context analysis (20%) - Increment state, file types
|
|
11
|
-
* 4. Explicit hints (10%) - User explicitly states phase
|
|
12
|
-
*
|
|
13
|
-
* Target accuracy: >95%
|
|
14
|
-
*/
|
|
15
|
-
import type { Phase } from '../types/model-selection';
|
|
16
|
-
export interface PhaseDetectionResult {
|
|
17
|
-
phase: Phase;
|
|
18
|
-
confidence: number;
|
|
19
|
-
signals: {
|
|
20
|
-
keywords: string[];
|
|
21
|
-
command?: string;
|
|
22
|
-
context: string[];
|
|
23
|
-
};
|
|
24
|
-
reasoning: string;
|
|
25
|
-
}
|
|
26
|
-
export interface ExecutionContext {
|
|
27
|
-
command?: string;
|
|
28
|
-
incrementState?: 'backlog' | 'planned' | 'in-progress' | 'completed' | 'closed';
|
|
29
|
-
previousPhases?: Phase[];
|
|
30
|
-
filesModified?: string[];
|
|
31
|
-
}
|
|
32
|
-
export declare class PhaseDetector {
|
|
33
|
-
private readonly planningKeywords;
|
|
34
|
-
private readonly executionKeywords;
|
|
35
|
-
private readonly reviewKeywords;
|
|
36
|
-
private readonly commandPhaseMap;
|
|
37
|
-
/**
|
|
38
|
-
* Detect phase from user prompt and execution context
|
|
39
|
-
*/
|
|
40
|
-
detect(prompt: string, context?: ExecutionContext): PhaseDetectionResult;
|
|
41
|
-
/**
|
|
42
|
-
* Analyze keywords in prompt
|
|
43
|
-
*/
|
|
44
|
-
private analyzeKeywords;
|
|
45
|
-
/**
|
|
46
|
-
* Analyze command hints
|
|
47
|
-
*/
|
|
48
|
-
private analyzeCommand;
|
|
49
|
-
/**
|
|
50
|
-
* Analyze execution context
|
|
51
|
-
*/
|
|
52
|
-
private analyzeContext;
|
|
53
|
-
/**
|
|
54
|
-
* Analyze explicit hints in prompt
|
|
55
|
-
*/
|
|
56
|
-
private analyzeHints;
|
|
57
|
-
/**
|
|
58
|
-
* Generate human-readable reasoning
|
|
59
|
-
*/
|
|
60
|
-
private generateReasoning;
|
|
61
|
-
}
|
|
62
|
-
//# sourceMappingURL=phase-detector.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"phase-detector.d.ts","sourceRoot":"","sources":["../../../src/core/phase-detector.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAC;AAEtD,MAAM,WAAW,oBAAoB;IACnC,KAAK,EAAE,KAAK,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE;QACP,QAAQ,EAAE,MAAM,EAAE,CAAC;QACnB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,OAAO,EAAE,MAAM,EAAE,CAAC;KACnB,CAAC;IACF,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,cAAc,CAAC,EAAE,SAAS,GAAG,SAAS,GAAG,aAAa,GAAG,WAAW,GAAG,QAAQ,CAAC;IAChF,cAAc,CAAC,EAAE,KAAK,EAAE,CAAC;IACzB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;CAC1B;AAED,qBAAa,aAAa;IAExB,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAK/B;IAEF,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAKhC;IAEF,OAAO,CAAC,QAAQ,CAAC,cAAc,CAI7B;IAGF,OAAO,CAAC,QAAQ,CAAC,eAAe,CAU9B;IAEF;;OAEG;IACH,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,GAAE,gBAAqB,GAAG,oBAAoB;IA4C5E;;OAEG;IACH,OAAO,CAAC,eAAe;IA4CvB;;OAEG;IACH,OAAO,CAAC,cAAc;IActB;;OAEG;IACH,OAAO,CAAC,cAAc;IAuDtB;;OAEG;IACH,OAAO,CAAC,YAAY;IAwBpB;;OAEG;IACH,OAAO,CAAC,iBAAiB;CAuC1B"}
|
|
@@ -1,229 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Phase Detector
|
|
3
|
-
*
|
|
4
|
-
* Multi-signal phase detection algorithm that analyzes user prompts and context
|
|
5
|
-
* to determine whether work is in planning, execution, or review phase.
|
|
6
|
-
*
|
|
7
|
-
* Uses 4 signals with weighted scoring:
|
|
8
|
-
* 1. Keyword analysis (40%) - Planning/execution/review keywords
|
|
9
|
-
* 2. Command analysis (30%) - Slash commands hint at phase
|
|
10
|
-
* 3. Context analysis (20%) - Increment state, file types
|
|
11
|
-
* 4. Explicit hints (10%) - User explicitly states phase
|
|
12
|
-
*
|
|
13
|
-
* Target accuracy: >95%
|
|
14
|
-
*/
|
|
15
|
-
export class PhaseDetector {
|
|
16
|
-
constructor() {
|
|
17
|
-
// Keyword dictionaries for each phase
|
|
18
|
-
this.planningKeywords = [
|
|
19
|
-
'plan', 'design', 'analyze', 'research', 'architecture', 'decide',
|
|
20
|
-
'strategy', 'requirements', 'specification', 'feasibility', 'explore',
|
|
21
|
-
'brainstorm', 'assess', 'evaluate', 'investigate', 'study', 'conceive',
|
|
22
|
-
'blueprint', 'roadmap', 'scope', 'estimate', 'proposal'
|
|
23
|
-
];
|
|
24
|
-
this.executionKeywords = [
|
|
25
|
-
'implement', 'build', 'create', 'write', 'code', 'generate',
|
|
26
|
-
'develop', 'construct', 'refactor', 'fix', 'update', 'modify',
|
|
27
|
-
'add', 'delete', 'remove', 'change', 'integrate', 'deploy',
|
|
28
|
-
'setup', 'configure', 'install', 'run', 'execute'
|
|
29
|
-
];
|
|
30
|
-
this.reviewKeywords = [
|
|
31
|
-
'review', 'validate', 'audit', 'assess', 'check', 'verify',
|
|
32
|
-
'test', 'evaluate', 'inspect', 'examine', 'quality',
|
|
33
|
-
'debug', 'troubleshoot', 'analyze error', 'find bug', 'measure'
|
|
34
|
-
];
|
|
35
|
-
// Command-to-phase mapping
|
|
36
|
-
this.commandPhaseMap = {
|
|
37
|
-
'/specweave.inc': 'planning',
|
|
38
|
-
'/specweave': 'planning',
|
|
39
|
-
'/increment': 'planning',
|
|
40
|
-
'/specweave.do': 'execution',
|
|
41
|
-
'/do': 'execution',
|
|
42
|
-
'/specweave.validate': 'review',
|
|
43
|
-
'/validate': 'review',
|
|
44
|
-
'/specweave.done': 'review',
|
|
45
|
-
'/spec-driven-brainstorming': 'planning',
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
/**
|
|
49
|
-
* Detect phase from user prompt and execution context
|
|
50
|
-
*/
|
|
51
|
-
detect(prompt, context = {}) {
|
|
52
|
-
const scores = {
|
|
53
|
-
planning: 0,
|
|
54
|
-
execution: 0,
|
|
55
|
-
review: 0,
|
|
56
|
-
};
|
|
57
|
-
const signals = {
|
|
58
|
-
keywords: [],
|
|
59
|
-
context: [],
|
|
60
|
-
};
|
|
61
|
-
// Signal 1: Keyword analysis (40% weight)
|
|
62
|
-
const keywordScore = this.analyzeKeywords(prompt, scores, signals);
|
|
63
|
-
// Signal 2: Command analysis (30% weight)
|
|
64
|
-
const commandScore = this.analyzeCommand(context, scores, signals);
|
|
65
|
-
// Signal 3: Context analysis (20% weight)
|
|
66
|
-
const contextScore = this.analyzeContext(context, scores, signals);
|
|
67
|
-
// Signal 4: Explicit hints (10% weight)
|
|
68
|
-
const hintScore = this.analyzeHints(prompt, scores, signals);
|
|
69
|
-
// Calculate total signal strength
|
|
70
|
-
const totalSignals = keywordScore + commandScore + contextScore + hintScore;
|
|
71
|
-
// Determine winning phase
|
|
72
|
-
const phase = Object.keys(scores).reduce((a, b) => scores[a] > scores[b] ? a : b);
|
|
73
|
-
// Calculate confidence (normalized score of winning phase)
|
|
74
|
-
const maxScore = Math.max(...Object.values(scores));
|
|
75
|
-
const confidence = maxScore > 0 ? scores[phase] / maxScore : 0.5;
|
|
76
|
-
return {
|
|
77
|
-
phase,
|
|
78
|
-
confidence,
|
|
79
|
-
signals,
|
|
80
|
-
reasoning: this.generateReasoning(phase, confidence, signals, totalSignals),
|
|
81
|
-
};
|
|
82
|
-
}
|
|
83
|
-
/**
|
|
84
|
-
* Analyze keywords in prompt
|
|
85
|
-
*/
|
|
86
|
-
analyzeKeywords(prompt, scores, signals) {
|
|
87
|
-
const lowerPrompt = prompt.toLowerCase();
|
|
88
|
-
let matchCount = 0;
|
|
89
|
-
// Check planning keywords
|
|
90
|
-
for (const keyword of this.planningKeywords) {
|
|
91
|
-
if (lowerPrompt.includes(keyword)) {
|
|
92
|
-
scores.planning++;
|
|
93
|
-
if (signals.keywords.length < 5) { // Limit to first 5
|
|
94
|
-
signals.keywords.push(`planning:${keyword}`);
|
|
95
|
-
}
|
|
96
|
-
matchCount++;
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
// Check execution keywords
|
|
100
|
-
for (const keyword of this.executionKeywords) {
|
|
101
|
-
if (lowerPrompt.includes(keyword)) {
|
|
102
|
-
scores.execution++;
|
|
103
|
-
if (signals.keywords.length < 5) {
|
|
104
|
-
signals.keywords.push(`execution:${keyword}`);
|
|
105
|
-
}
|
|
106
|
-
matchCount++;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
// Check review keywords
|
|
110
|
-
for (const keyword of this.reviewKeywords) {
|
|
111
|
-
if (lowerPrompt.includes(keyword)) {
|
|
112
|
-
scores.review++;
|
|
113
|
-
if (signals.keywords.length < 5) {
|
|
114
|
-
signals.keywords.push(`review:${keyword}`);
|
|
115
|
-
}
|
|
116
|
-
matchCount++;
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
return matchCount > 0 ? 1 : 0;
|
|
120
|
-
}
|
|
121
|
-
/**
|
|
122
|
-
* Analyze command hints
|
|
123
|
-
*/
|
|
124
|
-
analyzeCommand(context, scores, signals) {
|
|
125
|
-
if (context.command && this.commandPhaseMap[context.command]) {
|
|
126
|
-
const phase = this.commandPhaseMap[context.command];
|
|
127
|
-
scores[phase] += 3; // Strong signal
|
|
128
|
-
signals.command = context.command;
|
|
129
|
-
return 1;
|
|
130
|
-
}
|
|
131
|
-
return 0;
|
|
132
|
-
}
|
|
133
|
-
/**
|
|
134
|
-
* Analyze execution context
|
|
135
|
-
*/
|
|
136
|
-
analyzeContext(context, scores, signals) {
|
|
137
|
-
let signalCount = 0;
|
|
138
|
-
// Increment state signals
|
|
139
|
-
if (context.incrementState === 'backlog' || context.incrementState === 'planned') {
|
|
140
|
-
scores.planning++;
|
|
141
|
-
signals.context.push(`increment:${context.incrementState}`);
|
|
142
|
-
signalCount++;
|
|
143
|
-
}
|
|
144
|
-
else if (context.incrementState === 'in-progress') {
|
|
145
|
-
scores.execution++;
|
|
146
|
-
signals.context.push('increment:in-progress');
|
|
147
|
-
signalCount++;
|
|
148
|
-
}
|
|
149
|
-
else if (context.incrementState === 'completed') {
|
|
150
|
-
scores.review++;
|
|
151
|
-
signals.context.push('increment:completed');
|
|
152
|
-
signalCount++;
|
|
153
|
-
}
|
|
154
|
-
// File modification signals
|
|
155
|
-
if (context.filesModified && context.filesModified.length > 0) {
|
|
156
|
-
const hasArchitectureDocs = context.filesModified.some(f => f.includes('/architecture/') || f.includes('/adr/') || f.includes('spec.md') || f.includes('plan.md'));
|
|
157
|
-
const hasCodeFiles = context.filesModified.some(f => f.endsWith('.ts') || f.endsWith('.js') || f.endsWith('.py') ||
|
|
158
|
-
f.endsWith('.tsx') || f.endsWith('.jsx') || f.endsWith('.java'));
|
|
159
|
-
const hasTestFiles = context.filesModified.some(f => f.includes('.test.') || f.includes('.spec.') || f.includes('__tests__/'));
|
|
160
|
-
if (hasArchitectureDocs) {
|
|
161
|
-
scores.planning++;
|
|
162
|
-
signals.context.push('files:architecture-docs');
|
|
163
|
-
signalCount++;
|
|
164
|
-
}
|
|
165
|
-
if (hasCodeFiles) {
|
|
166
|
-
scores.execution++;
|
|
167
|
-
signals.context.push('files:code-files');
|
|
168
|
-
signalCount++;
|
|
169
|
-
}
|
|
170
|
-
if (hasTestFiles) {
|
|
171
|
-
scores.review++;
|
|
172
|
-
signals.context.push('files:test-files');
|
|
173
|
-
signalCount++;
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
return signalCount > 0 ? 1 : 0;
|
|
177
|
-
}
|
|
178
|
-
/**
|
|
179
|
-
* Analyze explicit hints in prompt
|
|
180
|
-
*/
|
|
181
|
-
analyzeHints(prompt, scores, signals) {
|
|
182
|
-
const lowerPrompt = prompt.toLowerCase();
|
|
183
|
-
// Explicit phase mentions
|
|
184
|
-
if (lowerPrompt.includes('planning phase') || lowerPrompt.includes('plan for')) {
|
|
185
|
-
scores.planning += 2;
|
|
186
|
-
return 1;
|
|
187
|
-
}
|
|
188
|
-
if (lowerPrompt.includes('implementation') || lowerPrompt.includes('execution phase') || lowerPrompt.includes('build phase')) {
|
|
189
|
-
scores.execution += 2;
|
|
190
|
-
return 1;
|
|
191
|
-
}
|
|
192
|
-
if (lowerPrompt.includes('review phase') || lowerPrompt.includes('validation phase')) {
|
|
193
|
-
scores.review += 2;
|
|
194
|
-
return 1;
|
|
195
|
-
}
|
|
196
|
-
return 0;
|
|
197
|
-
}
|
|
198
|
-
/**
|
|
199
|
-
* Generate human-readable reasoning
|
|
200
|
-
*/
|
|
201
|
-
generateReasoning(phase, confidence, signals, totalSignals) {
|
|
202
|
-
const reasons = [];
|
|
203
|
-
if (signals.command) {
|
|
204
|
-
reasons.push(`command '${signals.command}' indicates ${phase}`);
|
|
205
|
-
}
|
|
206
|
-
const planningKeywords = signals.keywords.filter(k => k.startsWith('planning:')).map(k => k.substring(9));
|
|
207
|
-
const executionKeywords = signals.keywords.filter(k => k.startsWith('execution:')).map(k => k.substring(10));
|
|
208
|
-
const reviewKeywords = signals.keywords.filter(k => k.startsWith('review:')).map(k => k.substring(7));
|
|
209
|
-
if (planningKeywords.length > 0) {
|
|
210
|
-
reasons.push(`planning keywords: ${planningKeywords.slice(0, 3).join(', ')}`);
|
|
211
|
-
}
|
|
212
|
-
if (executionKeywords.length > 0) {
|
|
213
|
-
reasons.push(`execution keywords: ${executionKeywords.slice(0, 3).join(', ')}`);
|
|
214
|
-
}
|
|
215
|
-
if (reviewKeywords.length > 0) {
|
|
216
|
-
reasons.push(`review keywords: ${reviewKeywords.slice(0, 3).join(', ')}`);
|
|
217
|
-
}
|
|
218
|
-
if (signals.context.length > 0) {
|
|
219
|
-
reasons.push(`context: ${signals.context.join(', ')}`);
|
|
220
|
-
}
|
|
221
|
-
const confidencePercent = (confidence * 100).toFixed(0);
|
|
222
|
-
const signalStrength = totalSignals >= 3 ? 'strong' : totalSignals >= 2 ? 'moderate' : 'weak';
|
|
223
|
-
if (reasons.length === 0) {
|
|
224
|
-
return `${phase} phase (${confidencePercent}% confidence, ${signalStrength} signals) - defaulting due to low signal`;
|
|
225
|
-
}
|
|
226
|
-
return `${phase} phase (${confidencePercent}% confidence, ${signalStrength} signals) - ${reasons.join('; ')}`;
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
//# sourceMappingURL=phase-detector.js.map
|