projscan 4.3.0 → 4.4.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/CONTRIBUTING.md +5 -1
- package/PRIVACY.md +1 -0
- package/README.md +307 -234
- package/THIRD-PARTY-NOTICES.md +31 -31
- package/dist/analyzers/architectureCheck.js.map +1 -1
- package/dist/analyzers/crossPackageImportCheck.js +3 -2
- package/dist/analyzers/crossPackageImportCheck.js.map +1 -1
- package/dist/analyzers/deadCodeCheck.js +10 -2
- package/dist/analyzers/deadCodeCheck.js.map +1 -1
- package/dist/analyzers/dependencyRiskCheck.js +1 -5
- package/dist/analyzers/dependencyRiskCheck.js.map +1 -1
- package/dist/analyzers/eslintCheck.js +3 -1
- package/dist/analyzers/eslintCheck.js.map +1 -1
- package/dist/analyzers/prettierCheck.js +16 -3
- package/dist/analyzers/prettierCheck.js.map +1 -1
- package/dist/analyzers/pythonDependencyRiskCheck.js +4 -17
- package/dist/analyzers/pythonDependencyRiskCheck.js.map +1 -1
- package/dist/analyzers/pythonLinterCheck.js +2 -12
- package/dist/analyzers/pythonLinterCheck.js.map +1 -1
- package/dist/analyzers/securityCheck.js +26 -9
- package/dist/analyzers/securityCheck.js.map +1 -1
- package/dist/analyzers/supplyChainCheck.js +6 -2
- package/dist/analyzers/supplyChainCheck.js.map +1 -1
- package/dist/analyzers/testCheck.js +10 -1
- package/dist/analyzers/testCheck.js.map +1 -1
- package/dist/analyzers/unusedDependencyCheck.js +8 -8
- package/dist/analyzers/unusedDependencyCheck.js.map +1 -1
- package/dist/cli/_shared.d.ts +2 -1
- package/dist/cli/_shared.js +14 -2
- package/dist/cli/_shared.js.map +1 -1
- package/dist/cli/commands/agentBrief.js +7 -1
- package/dist/cli/commands/agentBrief.js.map +1 -1
- package/dist/cli/commands/analyze.js.map +1 -1
- package/dist/cli/commands/applyFix.js +1 -1
- package/dist/cli/commands/applyFix.js.map +1 -1
- package/dist/cli/commands/audit.js +4 -2
- package/dist/cli/commands/audit.js.map +1 -1
- package/dist/cli/commands/badge.js.map +1 -1
- package/dist/cli/commands/bugHunt.js +2 -2
- package/dist/cli/commands/bugHunt.js.map +1 -1
- package/dist/cli/commands/ci.js.map +1 -1
- package/dist/cli/commands/claim.js +3 -3
- package/dist/cli/commands/claim.js.map +1 -1
- package/dist/cli/commands/collision.js +4 -2
- package/dist/cli/commands/collision.js.map +1 -1
- package/dist/cli/commands/coordinate.js +4 -2
- package/dist/cli/commands/coordinate.js.map +1 -1
- package/dist/cli/commands/coupling.js.map +1 -1
- package/dist/cli/commands/coverage.js.map +1 -1
- package/dist/cli/commands/dataflow.js.map +1 -1
- package/dist/cli/commands/dependencies.js +1 -1
- package/dist/cli/commands/dependencies.js.map +1 -1
- package/dist/cli/commands/diff.js.map +1 -1
- package/dist/cli/commands/doctor.js.map +1 -1
- package/dist/cli/commands/dogfood.js +30 -5
- package/dist/cli/commands/dogfood.js.map +1 -1
- package/dist/cli/commands/evidencePack.js.map +1 -1
- package/dist/cli/commands/explainIssue.js +1 -1
- package/dist/cli/commands/explainIssue.js.map +1 -1
- package/dist/cli/commands/feedback.js +19 -5
- package/dist/cli/commands/feedback.js.map +1 -1
- package/dist/cli/commands/file.js +1 -1
- package/dist/cli/commands/file.js.map +1 -1
- package/dist/cli/commands/fix.js.map +1 -1
- package/dist/cli/commands/fixSuggest.js +12 -4
- package/dist/cli/commands/fixSuggest.js.map +1 -1
- package/dist/cli/commands/hotspots.js.map +1 -1
- package/dist/cli/commands/impact.js +1 -1
- package/dist/cli/commands/impact.js.map +1 -1
- package/dist/cli/commands/init.js +13 -5
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/installHook.js +2 -2
- package/dist/cli/commands/installHook.js.map +1 -1
- package/dist/cli/commands/mcp.js.map +1 -1
- package/dist/cli/commands/memory.js +5 -2
- package/dist/cli/commands/memory.js.map +1 -1
- package/dist/cli/commands/mergeRisk.js +1 -1
- package/dist/cli/commands/mergeRisk.js.map +1 -1
- package/dist/cli/commands/missionProof.js +422 -3
- package/dist/cli/commands/missionProof.js.map +1 -1
- package/dist/cli/commands/outdated.js +1 -1
- package/dist/cli/commands/outdated.js.map +1 -1
- package/dist/cli/commands/plugin.js +10 -6
- package/dist/cli/commands/plugin.js.map +1 -1
- package/dist/cli/commands/prDiff.js +1 -1
- package/dist/cli/commands/prDiff.js.map +1 -1
- package/dist/cli/commands/preflight.js +1 -5
- package/dist/cli/commands/preflight.js.map +1 -1
- package/dist/cli/commands/privacyCheck.js +3 -1
- package/dist/cli/commands/privacyCheck.js.map +1 -1
- package/dist/cli/commands/qualityScorecard.js.map +1 -1
- package/dist/cli/commands/recipes.js.map +1 -1
- package/dist/cli/commands/regressionPlan.js.map +1 -1
- package/dist/cli/commands/releaseTrain.js.map +1 -1
- package/dist/cli/commands/review.js +1 -1
- package/dist/cli/commands/review.js.map +1 -1
- package/dist/cli/commands/route.js.map +1 -1
- package/dist/cli/commands/search.js +5 -2
- package/dist/cli/commands/search.js.map +1 -1
- package/dist/cli/commands/semanticGraph.js.map +1 -1
- package/dist/cli/commands/session.js +2 -2
- package/dist/cli/commands/session.js.map +1 -1
- package/dist/cli/commands/start.js +3 -1177
- package/dist/cli/commands/start.js.map +1 -1
- package/dist/cli/commands/startAction.d.ts +36 -0
- package/dist/cli/commands/startAction.js +70 -0
- package/dist/cli/commands/startAction.js.map +1 -0
- package/dist/cli/commands/startConsole.d.ts +7 -0
- package/dist/cli/commands/startConsole.js +309 -0
- package/dist/cli/commands/startConsole.js.map +1 -0
- package/dist/cli/commands/startMissionBundle.d.ts +41 -0
- package/dist/cli/commands/startMissionBundle.js +645 -0
- package/dist/cli/commands/startMissionBundle.js.map +1 -0
- package/dist/cli/commands/startOutput.d.ts +31 -0
- package/dist/cli/commands/startOutput.js +232 -0
- package/dist/cli/commands/startOutput.js.map +1 -0
- package/dist/cli/commands/startShortcuts.d.ts +26 -0
- package/dist/cli/commands/startShortcuts.js +117 -0
- package/dist/cli/commands/startShortcuts.js.map +1 -0
- package/dist/cli/commands/telemetry.js +2 -1
- package/dist/cli/commands/telemetry.js.map +1 -1
- package/dist/cli/commands/trial.js +19 -4
- package/dist/cli/commands/trial.js.map +1 -1
- package/dist/cli/commands/understand.js +3 -1
- package/dist/cli/commands/understand.js.map +1 -1
- package/dist/cli/commands/upgrade.js.map +1 -1
- package/dist/cli/commands/watch.js +1 -1
- package/dist/cli/commands/watch.js.map +1 -1
- package/dist/cli/commands/workplan.js.map +1 -1
- package/dist/cli/commands/workspace.js +1 -1
- package/dist/cli/commands/workspace.js.map +1 -1
- package/dist/cli/commands/workspaces.js +1 -1
- package/dist/cli/commands/workspaces.js.map +1 -1
- package/dist/cli/index.js +2 -117
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/registerCommands.d.ts +4 -0
- package/dist/cli/registerCommands.js +125 -0
- package/dist/cli/registerCommands.js.map +1 -0
- package/dist/core/adoption.d.ts +2 -1
- package/dist/core/adoption.js +40 -13
- package/dist/core/adoption.js.map +1 -1
- package/dist/core/agentBrief.js +19 -6
- package/dist/core/agentBrief.js.map +1 -1
- package/dist/core/applyFix.js.map +1 -1
- package/dist/core/ast.js +30 -19
- package/dist/core/ast.js.map +1 -1
- package/dist/core/auditRunner.js.map +1 -1
- package/dist/core/bugHunt.js +119 -17
- package/dist/core/bugHunt.js.map +1 -1
- package/dist/core/claims.js +5 -2
- package/dist/core/claims.js.map +1 -1
- package/dist/core/codeGraph.js +10 -0
- package/dist/core/codeGraph.js.map +1 -1
- package/dist/core/codeGraphReexports.d.ts +9 -0
- package/dist/core/codeGraphReexports.js +59 -0
- package/dist/core/codeGraphReexports.js.map +1 -0
- package/dist/core/collisionDetector.js +14 -4
- package/dist/core/collisionDetector.js.map +1 -1
- package/dist/core/coordination.js +4 -6
- package/dist/core/coordination.js.map +1 -1
- package/dist/core/couplingAnalyzer.d.ts +2 -1
- package/dist/core/couplingAnalyzer.js.map +1 -1
- package/dist/core/coverageParser.js.map +1 -1
- package/dist/core/dataflow.js +11 -2
- package/dist/core/dataflow.js.map +1 -1
- package/dist/core/dataflowFilters.js +8 -3
- package/dist/core/dataflowFilters.js.map +1 -1
- package/dist/core/dependencyAnalyzer.js +4 -1
- package/dist/core/dependencyAnalyzer.js.map +1 -1
- package/dist/core/dogfood.d.ts +1 -1
- package/dist/core/dogfood.js +39 -5
- package/dist/core/dogfood.js.map +1 -1
- package/dist/core/embeddings.js.map +1 -1
- package/dist/core/evidenceComment.js +34 -12
- package/dist/core/evidenceComment.js.map +1 -1
- package/dist/core/explainIssue.js +1 -2
- package/dist/core/explainIssue.js.map +1 -1
- package/dist/core/feedback.d.ts +1 -1
- package/dist/core/feedback.js +15 -4
- package/dist/core/feedback.js.map +1 -1
- package/dist/core/fileInspector.js +8 -2
- package/dist/core/fileInspector.js.map +1 -1
- package/dist/core/fixFirst.d.ts +3 -1
- package/dist/core/fixFirst.js +17 -4
- package/dist/core/fixFirst.js.map +1 -1
- package/dist/core/fixSuggest.js +20 -12
- package/dist/core/fixSuggest.js.map +1 -1
- package/dist/core/frameworkDetector.js +5 -3
- package/dist/core/frameworkDetector.js.map +1 -1
- package/dist/core/frameworkSources.js +22 -2
- package/dist/core/frameworkSources.js.map +1 -1
- package/dist/core/graphCorpus.d.ts +1 -1
- package/dist/core/graphCorpus.js +9 -1
- package/dist/core/graphCorpus.js.map +1 -1
- package/dist/core/graphQuery.js.map +1 -1
- package/dist/core/hotspotAnalyzer.js +26 -6
- package/dist/core/hotspotAnalyzer.js.map +1 -1
- package/dist/core/impact.d.ts +1 -1
- package/dist/core/impact.js.map +1 -1
- package/dist/core/importGraph.js.map +1 -1
- package/dist/core/indexCache.js.map +1 -1
- package/dist/core/intent.d.ts +1 -1
- package/dist/core/intent.js +143 -46
- package/dist/core/intent.js.map +1 -1
- package/dist/core/intentRouter.js +5467 -445
- package/dist/core/intentRouter.js.map +1 -1
- package/dist/core/issueEngine.js +1 -1
- package/dist/core/issueEngine.js.map +1 -1
- package/dist/core/languageDetector.js +1 -9
- package/dist/core/languageDetector.js.map +1 -1
- package/dist/core/languages/cppAdapter.js +3 -1
- package/dist/core/languages/cppAdapter.js.map +1 -1
- package/dist/core/languages/cppExports.js +6 -1
- package/dist/core/languages/cppExports.js.map +1 -1
- package/dist/core/languages/cppFunctions.js +3 -1
- package/dist/core/languages/cppFunctions.js.map +1 -1
- package/dist/core/languages/csharpAdapter.js.map +1 -1
- package/dist/core/languages/csharpFunctions.js +3 -1
- package/dist/core/languages/csharpFunctions.js.map +1 -1
- package/dist/core/languages/csharpImports.js +2 -1
- package/dist/core/languages/csharpImports.js.map +1 -1
- package/dist/core/languages/goAdapter.js.map +1 -1
- package/dist/core/languages/goExports.js.map +1 -1
- package/dist/core/languages/goFunctions.js +9 -3
- package/dist/core/languages/goFunctions.js.map +1 -1
- package/dist/core/languages/javaAdapter.js +1 -2
- package/dist/core/languages/javaAdapter.js.map +1 -1
- package/dist/core/languages/javaFunctions.js +6 -2
- package/dist/core/languages/javaFunctions.js.map +1 -1
- package/dist/core/languages/javascriptAdapter.js +43 -8
- package/dist/core/languages/javascriptAdapter.js.map +1 -1
- package/dist/core/languages/kotlinAdapter.js +5 -2
- package/dist/core/languages/kotlinAdapter.js.map +1 -1
- package/dist/core/languages/kotlinFunctions.js +5 -6
- package/dist/core/languages/kotlinFunctions.js.map +1 -1
- package/dist/core/languages/kotlinImports.js +3 -1
- package/dist/core/languages/kotlinImports.js.map +1 -1
- package/dist/core/languages/kotlinManifests.js +7 -1
- package/dist/core/languages/kotlinManifests.js.map +1 -1
- package/dist/core/languages/phpAdapter.js +4 -1
- package/dist/core/languages/phpAdapter.js.map +1 -1
- package/dist/core/languages/phpExports.js.map +1 -1
- package/dist/core/languages/phpFunctions.js +18 -6
- package/dist/core/languages/phpFunctions.js.map +1 -1
- package/dist/core/languages/phpManifests.js.map +1 -1
- package/dist/core/languages/pythonAdapter.js.map +1 -1
- package/dist/core/languages/pythonFunctions.js +9 -3
- package/dist/core/languages/pythonFunctions.js.map +1 -1
- package/dist/core/languages/pythonManifests.js.map +1 -1
- package/dist/core/languages/rubyAdapter.js.map +1 -1
- package/dist/core/languages/rubyFunctions.js +6 -2
- package/dist/core/languages/rubyFunctions.js.map +1 -1
- package/dist/core/languages/rustAdapter.js.map +1 -1
- package/dist/core/languages/rustFunctions.js +6 -2
- package/dist/core/languages/rustFunctions.js.map +1 -1
- package/dist/core/languages/swiftAdapter.js +3 -1
- package/dist/core/languages/swiftAdapter.js.map +1 -1
- package/dist/core/languages/swiftCyclomatic.js.map +1 -1
- package/dist/core/languages/swiftFunctions.js +3 -1
- package/dist/core/languages/swiftFunctions.js.map +1 -1
- package/dist/core/languages/swiftImports.js.map +1 -1
- package/dist/core/mergeRisk.js +5 -1
- package/dist/core/mergeRisk.js.map +1 -1
- package/dist/core/missionOutcome.d.ts +1 -1
- package/dist/core/missionOutcome.js +9 -4
- package/dist/core/missionOutcome.js.map +1 -1
- package/dist/core/missionProof.d.ts +1 -1
- package/dist/core/missionProof.js +10 -39
- package/dist/core/missionProof.js.map +1 -1
- package/dist/core/missionProofBaseline.d.ts +10 -0
- package/dist/core/missionProofBaseline.js +137 -0
- package/dist/core/missionProofBaseline.js.map +1 -0
- package/dist/core/missionProofMarkdown.d.ts +2 -0
- package/dist/core/missionProofMarkdown.js +83 -0
- package/dist/core/missionProofMarkdown.js.map +1 -0
- package/dist/core/missionProofSummary.d.ts +2 -0
- package/dist/core/missionProofSummary.js +16 -0
- package/dist/core/missionProofSummary.js.map +1 -0
- package/dist/core/monorepo.d.ts +1 -1
- package/dist/core/monorepo.js +4 -2
- package/dist/core/monorepo.js.map +1 -1
- package/dist/core/onboarding.d.ts +2 -1
- package/dist/core/onboarding.js.map +1 -1
- package/dist/core/outdatedDetector.js +5 -1
- package/dist/core/outdatedDetector.js.map +1 -1
- package/dist/core/ownership.js +3 -1
- package/dist/core/ownership.js.map +1 -1
- package/dist/core/pathClassifiers.js.map +1 -1
- package/dist/core/pluginDx.js +2 -1
- package/dist/core/pluginDx.js.map +1 -1
- package/dist/core/pluginTrust.js +1 -3
- package/dist/core/pluginTrust.js.map +1 -1
- package/dist/core/plugins.js +5 -5
- package/dist/core/plugins.js.map +1 -1
- package/dist/core/prDiff.d.ts +1 -2
- package/dist/core/prDiff.js +5 -1
- package/dist/core/prDiff.js.map +1 -1
- package/dist/core/preflight.js +15 -6
- package/dist/core/preflight.js.map +1 -1
- package/dist/core/privacy.js.map +1 -1
- package/dist/core/qualityScorecard.d.ts +1 -1
- package/dist/core/qualityScorecard.js +43 -11
- package/dist/core/qualityScorecard.js.map +1 -1
- package/dist/core/regressionPlan.js +25 -7
- package/dist/core/regressionPlan.js.map +1 -1
- package/dist/core/releaseEvidence.js +41 -17
- package/dist/core/releaseEvidence.js.map +1 -1
- package/dist/core/releaseTrain.js +66 -38
- package/dist/core/releaseTrain.js.map +1 -1
- package/dist/core/repositoryScanner.js +1 -3
- package/dist/core/repositoryScanner.js.map +1 -1
- package/dist/core/review.d.ts +1 -1
- package/dist/core/review.js +72 -10
- package/dist/core/review.js.map +1 -1
- package/dist/core/reviewDataflow.js +7 -1
- package/dist/core/reviewDataflow.js.map +1 -1
- package/dist/core/reviewPublicSurface.d.ts +13 -0
- package/dist/core/reviewPublicSurface.js +134 -0
- package/dist/core/reviewPublicSurface.js.map +1 -0
- package/dist/core/roadmapCatalog.js +122 -23
- package/dist/core/roadmapCatalog.js.map +1 -1
- package/dist/core/searchIndex.js +124 -17
- package/dist/core/searchIndex.js.map +1 -1
- package/dist/core/semanticGraph.js.map +1 -1
- package/dist/core/semanticSearch.js +20 -4
- package/dist/core/semanticSearch.js.map +1 -1
- package/dist/core/session.js +1 -2
- package/dist/core/session.js.map +1 -1
- package/dist/core/sessionResources.js +6 -2
- package/dist/core/sessionResources.js.map +1 -1
- package/dist/core/start.d.ts +3 -9
- package/dist/core/start.js +22 -3231
- package/dist/core/start.js.map +1 -1
- package/dist/core/startAdoptionLoop.d.ts +2 -0
- package/dist/core/startAdoptionLoop.js +41 -0
- package/dist/core/startAdoptionLoop.js.map +1 -0
- package/dist/core/startEvidence.d.ts +5 -0
- package/dist/core/startEvidence.js +62 -0
- package/dist/core/startEvidence.js.map +1 -0
- package/dist/core/startExecutionPlan.d.ts +16 -0
- package/dist/core/startExecutionPlan.js +185 -0
- package/dist/core/startExecutionPlan.js.map +1 -0
- package/dist/core/startHarness.d.ts +3 -0
- package/dist/core/startHarness.js +47 -0
- package/dist/core/startHarness.js.map +1 -0
- package/dist/core/startIntentTargets.d.ts +24 -0
- package/dist/core/startIntentTargets.js +1106 -0
- package/dist/core/startIntentTargets.js.map +1 -0
- package/dist/core/startMissionControl.d.ts +16 -0
- package/dist/core/startMissionControl.js +145 -0
- package/dist/core/startMissionControl.js.map +1 -0
- package/dist/core/startMissionPolicy.d.ts +19 -0
- package/dist/core/startMissionPolicy.js +246 -0
- package/dist/core/startMissionPolicy.js.map +1 -0
- package/dist/core/startMode.d.ts +11 -0
- package/dist/core/startMode.js +139 -0
- package/dist/core/startMode.js.map +1 -0
- package/dist/core/startOptions.d.ts +18 -0
- package/dist/core/startOptions.js +29 -0
- package/dist/core/startOptions.js.map +1 -0
- package/dist/core/startResume.d.ts +7 -0
- package/dist/core/startResume.js +468 -0
- package/dist/core/startResume.js.map +1 -0
- package/dist/core/startReviewGate.d.ts +11 -0
- package/dist/core/startReviewGate.js +200 -0
- package/dist/core/startReviewGate.js.map +1 -0
- package/dist/core/startRouteActions.d.ts +7 -0
- package/dist/core/startRouteActions.js +497 -0
- package/dist/core/startRouteActions.js.map +1 -0
- package/dist/core/startRunbook.d.ts +24 -0
- package/dist/core/startRunbook.js +271 -0
- package/dist/core/startRunbook.js.map +1 -0
- package/dist/core/startSuccessCriteria.d.ts +14 -0
- package/dist/core/startSuccessCriteria.js +497 -0
- package/dist/core/startSuccessCriteria.js.map +1 -0
- package/dist/core/taint.js +12 -3
- package/dist/core/taint.js.map +1 -1
- package/dist/core/telemetry.js +19 -5
- package/dist/core/telemetry.js.map +1 -1
- package/dist/core/trial.d.ts +1 -1
- package/dist/core/trial.js +15 -6
- package/dist/core/trial.js.map +1 -1
- package/dist/core/understand.d.ts +1 -1
- package/dist/core/understand.js +165 -51
- package/dist/core/understand.js.map +1 -1
- package/dist/core/upgradePreview.js +1 -1
- package/dist/core/upgradePreview.js.map +1 -1
- package/dist/core/watcher.js +18 -3
- package/dist/core/watcher.js.map +1 -1
- package/dist/core/workplan.js +87 -17
- package/dist/core/workplan.js.map +1 -1
- package/dist/core/workspace.js.map +1 -1
- package/dist/index.d.ts +12 -9
- package/dist/index.js +10 -7
- package/dist/index.js.map +1 -1
- package/dist/mcp/pagination.js.map +1 -1
- package/dist/mcp/prompts.js +28 -20
- package/dist/mcp/prompts.js.map +1 -1
- package/dist/mcp/server.js +6 -74
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp/serverPayload.d.ts +13 -0
- package/dist/mcp/serverPayload.js +61 -0
- package/dist/mcp/serverPayload.js.map +1 -0
- package/dist/mcp/tokenBudget.js.map +1 -1
- package/dist/mcp/tools/_shared.js.map +1 -1
- package/dist/mcp/tools/agentBrief.js +7 -1
- package/dist/mcp/tools/agentBrief.js.map +1 -1
- package/dist/mcp/tools/applyFix.js +1 -1
- package/dist/mcp/tools/applyFix.js.map +1 -1
- package/dist/mcp/tools/audit.js.map +1 -1
- package/dist/mcp/tools/bugHunt.js +2 -2
- package/dist/mcp/tools/bugHunt.js.map +1 -1
- package/dist/mcp/tools/claim.js +8 -3
- package/dist/mcp/tools/claim.js.map +1 -1
- package/dist/mcp/tools/collision.js +3 -1
- package/dist/mcp/tools/collision.js.map +1 -1
- package/dist/mcp/tools/coordinate.js.map +1 -1
- package/dist/mcp/tools/coordinateWatch.js +5 -2
- package/dist/mcp/tools/coordinateWatch.js.map +1 -1
- package/dist/mcp/tools/costSummary.js.map +1 -1
- package/dist/mcp/tools/coupling.js.map +1 -1
- package/dist/mcp/tools/coverage.js.map +1 -1
- package/dist/mcp/tools/dataflow.js.map +1 -1
- package/dist/mcp/tools/dependencies.js +4 -1
- package/dist/mcp/tools/dependencies.js.map +1 -1
- package/dist/mcp/tools/doctor.js.map +1 -1
- package/dist/mcp/tools/explainIssue.js +4 -1
- package/dist/mcp/tools/explainIssue.js.map +1 -1
- package/dist/mcp/tools/fixSuggest.js +5 -2
- package/dist/mcp/tools/fixSuggest.js.map +1 -1
- package/dist/mcp/tools/hotspots.js +4 -1
- package/dist/mcp/tools/hotspots.js.map +1 -1
- package/dist/mcp/tools/impact.js +10 -3
- package/dist/mcp/tools/impact.js.map +1 -1
- package/dist/mcp/tools/mergeRisk.js.map +1 -1
- package/dist/mcp/tools/plugin.js +6 -1
- package/dist/mcp/tools/plugin.js.map +1 -1
- package/dist/mcp/tools/prDiff.js.map +1 -1
- package/dist/mcp/tools/preflight.js +1 -5
- package/dist/mcp/tools/preflight.js.map +1 -1
- package/dist/mcp/tools/review.js.map +1 -1
- package/dist/mcp/tools/reviewWatch.d.ts +1 -1
- package/dist/mcp/tools/reviewWatch.js +9 -9
- package/dist/mcp/tools/reviewWatch.js.map +1 -1
- package/dist/mcp/tools/route.js +1 -1
- package/dist/mcp/tools/route.js.map +1 -1
- package/dist/mcp/tools/search.js.map +1 -1
- package/dist/mcp/tools/semanticGraph.js +8 -2
- package/dist/mcp/tools/semanticGraph.js.map +1 -1
- package/dist/mcp/tools/start.js.map +1 -1
- package/dist/mcp/tools/structure.js +7 -1
- package/dist/mcp/tools/structure.js.map +1 -1
- package/dist/mcp/tools/understand.js.map +1 -1
- package/dist/mcp/tools/workspaceGraph.js +10 -1
- package/dist/mcp/tools/workspaceGraph.js.map +1 -1
- package/dist/mcp/tools.js +3 -1
- package/dist/mcp/tools.js.map +1 -1
- package/dist/projscan-sbom.cdx.json +2136 -904
- package/dist/reporters/consoleAnalysisReporter.d.ts +2 -0
- package/dist/reporters/consoleAnalysisReporter.js +89 -0
- package/dist/reporters/consoleAnalysisReporter.js.map +1 -0
- package/dist/reporters/consoleArchitectureReporter.d.ts +3 -0
- package/dist/reporters/consoleArchitectureReporter.js +47 -0
- package/dist/reporters/consoleArchitectureReporter.js.map +1 -0
- package/dist/reporters/consoleAuditReporter.d.ts +2 -0
- package/dist/reporters/consoleAuditReporter.js +46 -0
- package/dist/reporters/consoleAuditReporter.js.map +1 -0
- package/dist/reporters/consoleCiReporter.d.ts +2 -0
- package/dist/reporters/consoleCiReporter.js +27 -0
- package/dist/reporters/consoleCiReporter.js.map +1 -0
- package/dist/reporters/consoleCouplingReporter.d.ts +2 -0
- package/dist/reporters/consoleCouplingReporter.js +53 -0
- package/dist/reporters/consoleCouplingReporter.js.map +1 -0
- package/dist/reporters/consoleCoverageReporter.d.ts +2 -0
- package/dist/reporters/consoleCoverageReporter.js +62 -0
- package/dist/reporters/consoleCoverageReporter.js.map +1 -0
- package/dist/reporters/consoleDependencyReporter.d.ts +2 -0
- package/dist/reporters/consoleDependencyReporter.js +64 -0
- package/dist/reporters/consoleDependencyReporter.js.map +1 -0
- package/dist/reporters/consoleDiffReporter.d.ts +2 -0
- package/dist/reporters/consoleDiffReporter.js +80 -0
- package/dist/reporters/consoleDiffReporter.js.map +1 -0
- package/dist/reporters/consoleExplanationReporter.d.ts +2 -0
- package/dist/reporters/consoleExplanationReporter.js +33 -0
- package/dist/reporters/consoleExplanationReporter.js.map +1 -0
- package/dist/reporters/consoleFileReporter.d.ts +2 -0
- package/dist/reporters/consoleFileReporter.js +133 -0
- package/dist/reporters/consoleFileReporter.js.map +1 -0
- package/dist/reporters/consoleFixGuidanceReporter.d.ts +8 -0
- package/dist/reporters/consoleFixGuidanceReporter.js +135 -0
- package/dist/reporters/consoleFixGuidanceReporter.js.map +1 -0
- package/dist/reporters/consoleHealthReporter.d.ts +13 -0
- package/dist/reporters/consoleHealthReporter.js +111 -0
- package/dist/reporters/consoleHealthReporter.js.map +1 -0
- package/dist/reporters/consoleHotspotReporter.d.ts +2 -0
- package/dist/reporters/consoleHotspotReporter.js +68 -0
- package/dist/reporters/consoleHotspotReporter.js.map +1 -0
- package/dist/reporters/consoleImpactReporter.d.ts +2 -0
- package/dist/reporters/consoleImpactReporter.js +65 -0
- package/dist/reporters/consoleImpactReporter.js.map +1 -0
- package/dist/reporters/consoleOutdatedReporter.d.ts +2 -0
- package/dist/reporters/consoleOutdatedReporter.js +54 -0
- package/dist/reporters/consoleOutdatedReporter.js.map +1 -0
- package/dist/reporters/consolePrDiffReporter.d.ts +2 -0
- package/dist/reporters/consolePrDiffReporter.js +75 -0
- package/dist/reporters/consolePrDiffReporter.js.map +1 -0
- package/dist/reporters/consoleReporter.d.ts +21 -38
- package/dist/reporters/consoleReporter.js +19 -1000
- package/dist/reporters/consoleReporter.js.map +1 -1
- package/dist/reporters/consoleReviewReporter.d.ts +2 -0
- package/dist/reporters/consoleReviewReporter.js +101 -0
- package/dist/reporters/consoleReviewReporter.js.map +1 -0
- package/dist/reporters/consoleUpgradeReporter.d.ts +2 -0
- package/dist/reporters/consoleUpgradeReporter.js +67 -0
- package/dist/reporters/consoleUpgradeReporter.js.map +1 -0
- package/dist/reporters/consoleWorkspaceReporter.d.ts +2 -0
- package/dist/reporters/consoleWorkspaceReporter.js +24 -0
- package/dist/reporters/consoleWorkspaceReporter.js.map +1 -0
- package/dist/reporters/htmlReporter.d.ts +2 -1
- package/dist/reporters/htmlReporter.js +9 -3
- package/dist/reporters/htmlReporter.js.map +1 -1
- package/dist/reporters/jsonReporter.d.ts +2 -1
- package/dist/reporters/jsonReporter.js.map +1 -1
- package/dist/reporters/markdownAnalysisReporter.d.ts +2 -0
- package/dist/reporters/markdownAnalysisReporter.js +40 -0
- package/dist/reporters/markdownAnalysisReporter.js.map +1 -0
- package/dist/reporters/markdownAuditReporter.d.ts +2 -0
- package/dist/reporters/markdownAuditReporter.js +27 -0
- package/dist/reporters/markdownAuditReporter.js.map +1 -0
- package/dist/reporters/markdownDependencyReporter.d.ts +2 -0
- package/dist/reporters/markdownDependencyReporter.js +33 -0
- package/dist/reporters/markdownDependencyReporter.js.map +1 -0
- package/dist/reporters/markdownDiffReporter.d.ts +2 -0
- package/dist/reporters/markdownDiffReporter.js +65 -0
- package/dist/reporters/markdownDiffReporter.js.map +1 -0
- package/dist/reporters/markdownFileReporter.d.ts +2 -0
- package/dist/reporters/markdownFileReporter.js +92 -0
- package/dist/reporters/markdownFileReporter.js.map +1 -0
- package/dist/reporters/markdownFixGuidanceReporter.d.ts +8 -0
- package/dist/reporters/markdownFixGuidanceReporter.js +95 -0
- package/dist/reporters/markdownFixGuidanceReporter.js.map +1 -0
- package/dist/reporters/markdownImpactReporter.d.ts +2 -0
- package/dist/reporters/markdownImpactReporter.js +52 -0
- package/dist/reporters/markdownImpactReporter.js.map +1 -0
- package/dist/reporters/markdownReporter.d.ts +10 -16
- package/dist/reporters/markdownReporter.js +9 -452
- package/dist/reporters/markdownReporter.js.map +1 -1
- package/dist/reporters/markdownReviewReporter.d.ts +2 -0
- package/dist/reporters/markdownReviewReporter.js +84 -0
- package/dist/reporters/markdownReviewReporter.js.map +1 -0
- package/dist/reporters/markdownUpgradeReporter.d.ts +2 -0
- package/dist/reporters/markdownUpgradeReporter.js +47 -0
- package/dist/reporters/markdownUpgradeReporter.js.map +1 -0
- package/dist/reporters/sarifReporter.js.map +1 -1
- package/dist/tool-manifest.json +4 -4
- package/dist/types/agentBrief.d.ts +48 -0
- package/dist/types/agentBrief.js +2 -0
- package/dist/types/agentBrief.js.map +1 -0
- package/dist/types/analysis.d.ts +32 -0
- package/dist/types/analysis.js +2 -0
- package/dist/types/analysis.js.map +1 -0
- package/dist/types/baseline.d.ts +59 -0
- package/dist/types/baseline.js +2 -0
- package/dist/types/baseline.js.map +1 -0
- package/dist/types/bugHunt.d.ts +41 -0
- package/dist/types/bugHunt.js +2 -0
- package/dist/types/bugHunt.js.map +1 -0
- package/dist/types/common.d.ts +34 -0
- package/dist/types/common.js +2 -0
- package/dist/types/common.js.map +1 -0
- package/dist/types/config.d.ts +56 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/coupling.d.ts +40 -0
- package/dist/types/coupling.js +2 -0
- package/dist/types/coupling.js.map +1 -0
- package/dist/types/coverage.d.ts +32 -0
- package/dist/types/coverage.js +2 -0
- package/dist/types/coverage.js.map +1 -0
- package/dist/types/dependencyHealth.d.ts +61 -0
- package/dist/types/dependencyHealth.js +2 -0
- package/dist/types/dependencyHealth.js.map +1 -0
- package/dist/types/dogfood.d.ts +185 -0
- package/dist/types/dogfood.js +2 -0
- package/dist/types/dogfood.js.map +1 -0
- package/dist/types/evidencePack.d.ts +76 -0
- package/dist/types/evidencePack.js +2 -0
- package/dist/types/evidencePack.js.map +1 -0
- package/dist/types/fixes.d.ts +77 -0
- package/dist/types/fixes.js +2 -0
- package/dist/types/fixes.js.map +1 -0
- package/dist/types/graph.d.ts +80 -0
- package/dist/types/graph.js +2 -0
- package/dist/types/graph.js.map +1 -0
- package/dist/types/graphCorpus.d.ts +16 -0
- package/dist/types/graphCorpus.js +2 -0
- package/dist/types/graphCorpus.js.map +1 -0
- package/dist/types/hotspots.d.ts +42 -0
- package/dist/types/hotspots.js +2 -0
- package/dist/types/hotspots.js.map +1 -0
- package/dist/types/impact.d.ts +62 -0
- package/dist/types/impact.js +2 -0
- package/dist/types/impact.js.map +1 -0
- package/dist/types/inspection.d.ts +47 -0
- package/dist/types/inspection.js +2 -0
- package/dist/types/inspection.js.map +1 -0
- package/dist/types/mcp.d.ts +39 -0
- package/dist/types/mcp.js +2 -0
- package/dist/types/mcp.js.map +1 -0
- package/dist/types/pluginDx.d.ts +42 -0
- package/dist/types/pluginDx.js +2 -0
- package/dist/types/pluginDx.js.map +1 -0
- package/dist/types/prDiff.d.ts +41 -0
- package/dist/types/prDiff.js +2 -0
- package/dist/types/prDiff.js.map +1 -0
- package/dist/types/preflight.d.ts +122 -0
- package/dist/types/preflight.js +2 -0
- package/dist/types/preflight.js.map +1 -0
- package/dist/types/qualityScorecard.d.ts +34 -0
- package/dist/types/qualityScorecard.js +2 -0
- package/dist/types/qualityScorecard.js.map +1 -0
- package/dist/types/regressionPlan.d.ts +32 -0
- package/dist/types/regressionPlan.js +2 -0
- package/dist/types/regressionPlan.js.map +1 -0
- package/dist/types/releaseTrain.d.ts +37 -0
- package/dist/types/releaseTrain.js +2 -0
- package/dist/types/releaseTrain.js.map +1 -0
- package/dist/types/review.d.ts +203 -0
- package/dist/types/review.js +2 -0
- package/dist/types/review.js.map +1 -0
- package/dist/types/reviewContract.d.ts +9 -0
- package/dist/types/reviewContract.js +2 -0
- package/dist/types/reviewContract.js.map +1 -0
- package/dist/types/scanning.d.ts +111 -0
- package/dist/types/scanning.js +2 -0
- package/dist/types/scanning.js.map +1 -0
- package/dist/types/session.d.ts +42 -0
- package/dist/types/session.js +2 -0
- package/dist/types/session.js.map +1 -0
- package/dist/types/start.d.ts +437 -0
- package/dist/types/start.js +2 -0
- package/dist/types/start.js.map +1 -0
- package/dist/types/trial.d.ts +27 -0
- package/dist/types/trial.js +2 -0
- package/dist/types/trial.js.map +1 -0
- package/dist/types/understand.d.ts +153 -0
- package/dist/types/understand.js +2 -0
- package/dist/types/understand.js.map +1 -0
- package/dist/types/workplan.d.ts +67 -0
- package/dist/types/workplan.js +2 -0
- package/dist/types/workplan.js.map +1 -0
- package/dist/types/workplanHandoff.d.ts +11 -0
- package/dist/types/workplanHandoff.js +2 -0
- package/dist/types/workplanHandoff.js.map +1 -0
- package/dist/types/workspace.d.ts +18 -0
- package/dist/types/workspace.js +2 -0
- package/dist/types/workspace.js.map +1 -0
- package/dist/types.d.ts +34 -2348
- package/dist/types.js +0 -1
- package/dist/types.js.map +1 -1
- package/dist/utils/banner.js +15 -6
- package/dist/utils/banner.js.map +1 -1
- package/dist/utils/baseline.js +11 -9
- package/dist/utils/baseline.js.map +1 -1
- package/dist/utils/changedFiles.js +1 -1
- package/dist/utils/changedFiles.js.map +1 -1
- package/dist/utils/config.d.ts +2 -1
- package/dist/utils/config.js.map +1 -1
- package/dist/utils/formatSupport.d.ts +2 -2
- package/dist/utils/formatSupport.js +8 -2
- package/dist/utils/formatSupport.js.map +1 -1
- package/dist/utils/packageJsonLocator.js.map +1 -1
- package/docs/GUIDE.md +209 -147
- package/docs/PLUGIN-GALLERY.md +9 -1
- package/docs/ROADMAP.md +69 -68
- package/docs/demos/projscan-4-1-demo.html +46 -79
- package/docs/demos/projscan-mission-control.tape +13 -0
- package/docs/demos/projscan-mission-proof.tape +25 -0
- package/docs/examples/plugins/graph-context.mjs +1 -2
- package/docs/examples/plugins/security-sensitive-files.mjs +2 -1
- package/docs/projscan-mission-control.gif +0 -0
- package/docs/projscan-mission-proof.gif +0 -0
- package/package.json +17 -5
- package/scripts/capture-vhs-demos.mjs +80 -0
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import { routeIntent } from './intentRouter.js';
|
|
2
|
+
import { isProductPlanningWorkplanRoute } from './startSuccessCriteria.js';
|
|
3
|
+
import { isWorkplanMode } from './workplan.js';
|
|
4
|
+
const MODE_RESOLVERS = [
|
|
5
|
+
releaseMode,
|
|
6
|
+
bugHuntMode,
|
|
7
|
+
productPlanningMode,
|
|
8
|
+
hardeningMode,
|
|
9
|
+
evidencePackMode,
|
|
10
|
+
reviewMode,
|
|
11
|
+
regressionMode,
|
|
12
|
+
prDiffMode,
|
|
13
|
+
mergeRiskMode,
|
|
14
|
+
primaryPreflightMode,
|
|
15
|
+
fallbackPreflightMode,
|
|
16
|
+
];
|
|
17
|
+
export function resolveStartMode(value, intent) {
|
|
18
|
+
if (typeof value === 'string' && isWorkplanMode(value)) {
|
|
19
|
+
return {
|
|
20
|
+
mode: value,
|
|
21
|
+
source: 'explicit',
|
|
22
|
+
reason: `Mode ${value} was provided explicitly.`,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
const inferred = inferModeFromIntent(intent);
|
|
26
|
+
if (inferred) {
|
|
27
|
+
return {
|
|
28
|
+
mode: inferred,
|
|
29
|
+
source: 'intent',
|
|
30
|
+
reason: `Intent "${intent}" maps to the ${inferred} workflow.`,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
return {
|
|
34
|
+
mode: 'before_edit',
|
|
35
|
+
source: 'default',
|
|
36
|
+
reason: defaultModeReason(intent, routesForIntent(intent).length > 0),
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
export function inferModeFromIntent(intent) {
|
|
40
|
+
const routes = routesForIntent(intent);
|
|
41
|
+
const context = {
|
|
42
|
+
intent: intent ?? '',
|
|
43
|
+
routes,
|
|
44
|
+
primaryRoute: routes[0],
|
|
45
|
+
};
|
|
46
|
+
for (const resolver of MODE_RESOLVERS) {
|
|
47
|
+
const mode = resolver(context);
|
|
48
|
+
if (mode)
|
|
49
|
+
return mode;
|
|
50
|
+
}
|
|
51
|
+
return undefined;
|
|
52
|
+
}
|
|
53
|
+
export function routesForIntent(intent) {
|
|
54
|
+
if (!intent)
|
|
55
|
+
return [];
|
|
56
|
+
return routeIntent(intent).matches.map(routeEntryToStartIntent);
|
|
57
|
+
}
|
|
58
|
+
export function preflightModeFromIntent(intent) {
|
|
59
|
+
const text = intent.toLowerCase();
|
|
60
|
+
if (/\b(?:merge|merged|merging|release|rebase|rebasing|conflict|conflicts|resolve|resolving)\b/.test(text))
|
|
61
|
+
return 'before_merge';
|
|
62
|
+
if (/\bcommit|committing|committed|pr|pull\s+request\b/.test(text))
|
|
63
|
+
return 'before_commit';
|
|
64
|
+
return 'before_edit';
|
|
65
|
+
}
|
|
66
|
+
function defaultModeReason(intent, routed) {
|
|
67
|
+
if (!intent)
|
|
68
|
+
return 'No mode-specific intent or explicit mode was supplied, so start defaults to before_edit.';
|
|
69
|
+
if (routed) {
|
|
70
|
+
return `Mission Control routed the intent, but no workflow-mode hint matched "${intent}", so start defaults to before_edit.`;
|
|
71
|
+
}
|
|
72
|
+
return `No mode-specific intent matched "${intent}", so start defaults to before_edit.`;
|
|
73
|
+
}
|
|
74
|
+
function routeEntryToStartIntent(entry) {
|
|
75
|
+
return {
|
|
76
|
+
intent: entry.intent,
|
|
77
|
+
category: entry.category,
|
|
78
|
+
tool: entry.tool,
|
|
79
|
+
cli: entry.cli,
|
|
80
|
+
why: entry.why,
|
|
81
|
+
example: entry.example,
|
|
82
|
+
confidence: entry.confidence,
|
|
83
|
+
rank: entry.rank,
|
|
84
|
+
score: entry.score,
|
|
85
|
+
matchedKeywords: entry.matchedKeywords,
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
function releaseMode({ primaryRoute }) {
|
|
89
|
+
return primaryRoute?.tool === 'projscan_release_train' ? 'release' : undefined;
|
|
90
|
+
}
|
|
91
|
+
function bugHuntMode({ primaryRoute }) {
|
|
92
|
+
return primaryRoute?.tool === 'projscan_bug_hunt' && primaryRoute.confidence === 'high'
|
|
93
|
+
? 'bug_hunt'
|
|
94
|
+
: undefined;
|
|
95
|
+
}
|
|
96
|
+
function productPlanningMode({ primaryRoute }) {
|
|
97
|
+
return isProductPlanningWorkplanRoute(primaryRoute) ? 'bug_hunt' : undefined;
|
|
98
|
+
}
|
|
99
|
+
function hardeningMode({ primaryRoute }) {
|
|
100
|
+
return primaryRoute?.tool === 'projscan_dataflow' && primaryRoute.confidence === 'high'
|
|
101
|
+
? 'hardening'
|
|
102
|
+
: undefined;
|
|
103
|
+
}
|
|
104
|
+
function evidencePackMode({ primaryRoute }) {
|
|
105
|
+
return primaryRoute?.tool === 'projscan_evidence_pack' ? 'before_commit' : undefined;
|
|
106
|
+
}
|
|
107
|
+
function reviewMode({ intent, primaryRoute }) {
|
|
108
|
+
return primaryRoute?.tool === 'projscan_review' ? reviewModeFromIntent(intent) : undefined;
|
|
109
|
+
}
|
|
110
|
+
function regressionMode({ intent, primaryRoute }) {
|
|
111
|
+
return primaryRoute?.tool === 'projscan_regression_plan'
|
|
112
|
+
? regressionModeFromIntent(intent)
|
|
113
|
+
: undefined;
|
|
114
|
+
}
|
|
115
|
+
function prDiffMode({ primaryRoute }) {
|
|
116
|
+
return primaryRoute?.tool === 'projscan_pr_diff' ? 'before_commit' : undefined;
|
|
117
|
+
}
|
|
118
|
+
function mergeRiskMode({ primaryRoute }) {
|
|
119
|
+
return primaryRoute?.tool === 'projscan_merge_risk' ? 'before_merge' : undefined;
|
|
120
|
+
}
|
|
121
|
+
function primaryPreflightMode({ intent, primaryRoute, }) {
|
|
122
|
+
return primaryRoute?.tool === 'projscan_preflight' ? preflightModeFromIntent(intent) : undefined;
|
|
123
|
+
}
|
|
124
|
+
function fallbackPreflightMode({ intent, routes }) {
|
|
125
|
+
if (routes.some((route) => route.tool === 'projscan_preflight') && hasPreflightModeHint(intent)) {
|
|
126
|
+
return preflightModeFromIntent(intent);
|
|
127
|
+
}
|
|
128
|
+
return undefined;
|
|
129
|
+
}
|
|
130
|
+
function hasPreflightModeHint(intent) {
|
|
131
|
+
return /\b(?:safe|safety|gate|preflight|commit|committing|committed|merge|merged|merging|rebase|rebasing|conflict|conflicts|resolve|resolving|edit|proceed|block|blocked|blocker|blockers|blocking|allowed)\b/i.test(intent);
|
|
132
|
+
}
|
|
133
|
+
function regressionModeFromIntent(intent) {
|
|
134
|
+
return /\bmerge|merged|merging|release\b/i.test(intent) ? 'before_merge' : 'before_commit';
|
|
135
|
+
}
|
|
136
|
+
function reviewModeFromIntent(intent) {
|
|
137
|
+
return /\bmerge|merged|merging\b/i.test(intent) ? 'before_merge' : 'before_commit';
|
|
138
|
+
}
|
|
139
|
+
//# sourceMappingURL=startMode.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startMode.js","sourceRoot":"","sources":["../../src/core/startMode.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { type StartModeResolution } from './startMode.js';
|
|
2
|
+
import type { WorkplanMode } from '../types.js';
|
|
3
|
+
export interface ComputeStartOptions {
|
|
4
|
+
mode?: WorkplanMode;
|
|
5
|
+
intent?: string;
|
|
6
|
+
missionDir?: string;
|
|
7
|
+
maxTasks?: number;
|
|
8
|
+
maxRisks?: number;
|
|
9
|
+
includeHandoff?: boolean;
|
|
10
|
+
}
|
|
11
|
+
export interface NormalizedStartOptions {
|
|
12
|
+
intent?: string;
|
|
13
|
+
modeResolution: StartModeResolution;
|
|
14
|
+
mode: WorkplanMode;
|
|
15
|
+
maxTasks: number;
|
|
16
|
+
maxRisks: number;
|
|
17
|
+
}
|
|
18
|
+
export declare function normalizeStartOptions(options?: ComputeStartOptions): NormalizedStartOptions;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { resolveStartMode } from './startMode.js';
|
|
2
|
+
const DEFAULT_MAX_TASKS = 5;
|
|
3
|
+
const DEFAULT_MAX_RISKS = 5;
|
|
4
|
+
const MAX_START_ITEMS = 12;
|
|
5
|
+
export function normalizeStartOptions(options = {}) {
|
|
6
|
+
const intent = normalizeIntent(options.intent);
|
|
7
|
+
const modeResolution = resolveStartMode(options.mode, intent);
|
|
8
|
+
return {
|
|
9
|
+
intent,
|
|
10
|
+
modeResolution,
|
|
11
|
+
mode: modeResolution.mode,
|
|
12
|
+
maxTasks: normalizeLimit(options.maxTasks, DEFAULT_MAX_TASKS, MAX_START_ITEMS),
|
|
13
|
+
maxRisks: normalizeLimit(options.maxRisks, DEFAULT_MAX_RISKS, MAX_START_ITEMS),
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
function normalizeIntent(value) {
|
|
17
|
+
if (typeof value !== 'string')
|
|
18
|
+
return undefined;
|
|
19
|
+
const trimmed = value.trim().replace(/\s+/g, ' ');
|
|
20
|
+
if (trimmed.length === 0)
|
|
21
|
+
return undefined;
|
|
22
|
+
return trimmed.slice(0, 240);
|
|
23
|
+
}
|
|
24
|
+
function normalizeLimit(value, fallback, max) {
|
|
25
|
+
if (typeof value !== 'number' || !Number.isFinite(value))
|
|
26
|
+
return fallback;
|
|
27
|
+
return Math.max(1, Math.min(max, Math.floor(value)));
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=startOptions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startOptions.js","sourceRoot":"","sources":["../../src/core/startOptions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAA4B,MAAM,gBAAgB,CAAC;AAoB5E,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAC5B,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAC5B,MAAM,eAAe,GAAG,EAAE,CAAC;AAE3B,MAAM,UAAU,qBAAqB,CAAC,UAA+B,EAAE;IACrE,MAAM,MAAM,GAAG,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC/C,MAAM,cAAc,GAAG,gBAAgB,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC9D,OAAO;QACL,MAAM;QACN,cAAc;QACd,IAAI,EAAE,cAAc,CAAC,IAAI;QACzB,QAAQ,EAAE,cAAc,CAAC,OAAO,CAAC,QAAQ,EAAE,iBAAiB,EAAE,eAAe,CAAC;QAC9E,QAAQ,EAAE,cAAc,CAAC,OAAO,CAAC,QAAQ,EAAE,iBAAiB,EAAE,eAAe,CAAC;KAC/E,CAAC;AACJ,CAAC;AAED,SAAS,eAAe,CAAC,KAAyB;IAChD,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,SAAS,CAAC;IAChD,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAClD,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,SAAS,CAAC;IAC3C,OAAO,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC/B,CAAC;AAED,SAAS,cAAc,CAAC,KAAyB,EAAE,QAAgB,EAAE,GAAW;IAC9E,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,QAAQ,CAAC;IAC1E,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACvD,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { MissionOutcome, StartExecutionCursor, StartExecutionPhase, StartExecutionPlan, StartMissionResume } from '../types/start.js';
|
|
2
|
+
export declare function missionResume(plan: StartExecutionPlan, outcome?: MissionOutcome): StartMissionResume;
|
|
3
|
+
export declare function proofCommandToolCall(command: string): StartMissionResume['toolCall'] | undefined;
|
|
4
|
+
export declare function executionCursor(phases: StartExecutionPhase[]): StartExecutionCursor;
|
|
5
|
+
export declare function argsAreReady(value: unknown): boolean;
|
|
6
|
+
export declare function isRunnableCommand(command: string): boolean;
|
|
7
|
+
export declare function uniqueStrings(values: string[]): string[];
|
|
@@ -0,0 +1,468 @@
|
|
|
1
|
+
import { isPlaceholder } from './startIntentTargets.js';
|
|
2
|
+
const CURSOR_SELECTORS = [
|
|
3
|
+
(phase, step) => phase.id === 'ready_now' && step.status === 'ready' && typeof step.command === 'string',
|
|
4
|
+
(phase, step) => phase.id === 'resolve_inputs' && step.status === 'blocked',
|
|
5
|
+
(phase, step) => phase.id === 'proof' && step.status === 'ready',
|
|
6
|
+
(phase) => phase.id === 'done_when',
|
|
7
|
+
(phase) => phase.id === 'next_action',
|
|
8
|
+
];
|
|
9
|
+
const CURSOR_REASON_RULES = [
|
|
10
|
+
{ matches: (step) => step.status === 'ready' && step.kind === 'tool', reason: readyToolReason },
|
|
11
|
+
{
|
|
12
|
+
matches: (step) => step.status === 'blocked' && step.kind === 'input',
|
|
13
|
+
reason: () => 'Resolve this blocked input before running dependent follow-up steps.',
|
|
14
|
+
},
|
|
15
|
+
{
|
|
16
|
+
matches: (step) => step.status === 'ready' && step.kind === 'proof',
|
|
17
|
+
reason: () => 'Run this proof command when action steps are complete.',
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
matches: (step) => step.kind === 'criterion',
|
|
21
|
+
reason: () => 'Use this criterion to decide when the task is complete.',
|
|
22
|
+
},
|
|
23
|
+
];
|
|
24
|
+
function readyToolReason(step) {
|
|
25
|
+
return step.unlocks && step.unlocks.length > 0
|
|
26
|
+
? 'Run this ready command next; it can unlock later inputs or follow-up steps.'
|
|
27
|
+
: 'Run this ready command next.';
|
|
28
|
+
}
|
|
29
|
+
export function missionResume(plan, outcome) {
|
|
30
|
+
const cursor = plan.cursor;
|
|
31
|
+
const commandBlock = runnableCursorCommand(cursor);
|
|
32
|
+
const toolCall = resumeToolCall(plan, cursor);
|
|
33
|
+
const followUps = resumeFollowUps(plan, cursor);
|
|
34
|
+
const inputBindings = resumeInputBindings(plan, cursor);
|
|
35
|
+
const checklist = resumeChecklist(plan, cursor, inputBindings, followUps);
|
|
36
|
+
const remainingProofItems = resumeRemainingProofItems(checklist);
|
|
37
|
+
const remainingProofCommands = resumeRemainingProofCommands(checklist);
|
|
38
|
+
const remainingProofToolCalls = resumeRemainingProofToolCalls(checklist);
|
|
39
|
+
const unlocks = resolveResumeReferences(plan, cursor.unlocks);
|
|
40
|
+
const blockedBy = resolveResumeReferences(plan, cursor.blockedBy);
|
|
41
|
+
const instruction = resumeInstruction(cursor, commandBlock);
|
|
42
|
+
const prompt = resumePrompt(cursor, commandBlock, instruction, unlocks, blockedBy, outcome);
|
|
43
|
+
const resume = {
|
|
44
|
+
currentStep: cursor,
|
|
45
|
+
status: cursor.status,
|
|
46
|
+
instruction,
|
|
47
|
+
prompt,
|
|
48
|
+
};
|
|
49
|
+
attachResumeAction(resume, commandBlock, toolCall);
|
|
50
|
+
attachResumeCollections(resume, {
|
|
51
|
+
followUps,
|
|
52
|
+
inputBindings,
|
|
53
|
+
checklist,
|
|
54
|
+
remainingProofItems,
|
|
55
|
+
remainingProofCommands,
|
|
56
|
+
remainingProofToolCalls,
|
|
57
|
+
unlocks,
|
|
58
|
+
blockedBy,
|
|
59
|
+
});
|
|
60
|
+
return resume;
|
|
61
|
+
}
|
|
62
|
+
function runnableCursorCommand(cursor) {
|
|
63
|
+
return cursor.command && isRunnableCommand(cursor.command) ? cursor.command : undefined;
|
|
64
|
+
}
|
|
65
|
+
function resumeInstruction(cursor, commandBlock) {
|
|
66
|
+
if (commandBlock)
|
|
67
|
+
return `Run ${commandBlock}.`;
|
|
68
|
+
if (cursor.instruction)
|
|
69
|
+
return `Resolve ${cursor.label}: ${cursor.instruction}`;
|
|
70
|
+
return `Continue with ${cursor.label}.`;
|
|
71
|
+
}
|
|
72
|
+
function resumePrompt(cursor, commandBlock, instruction, unlocks, blockedBy, outcome) {
|
|
73
|
+
const base = commandBlock
|
|
74
|
+
? `Resume at ${cursor.stepId} in ${cursor.phaseId}: run \`${commandBlock}\`.${resumeUnlocksSentence(unlocks, cursor.unlocks)}`
|
|
75
|
+
: `Resume at ${cursor.stepId} in ${cursor.phaseId}: ${instruction}${resumeBlockersSentence(blockedBy, cursor.blockedBy)}`;
|
|
76
|
+
return outcome?.available ? `${outcome.resumePrompt} ${base}` : base;
|
|
77
|
+
}
|
|
78
|
+
function attachResumeAction(resume, commandBlock, toolCall) {
|
|
79
|
+
if (commandBlock)
|
|
80
|
+
resume.commandBlock = commandBlock;
|
|
81
|
+
if (toolCall)
|
|
82
|
+
resume.toolCall = toolCall;
|
|
83
|
+
}
|
|
84
|
+
function attachResumeCollections(resume, collections) {
|
|
85
|
+
if (collections.followUps.length > 0)
|
|
86
|
+
resume.followUps = collections.followUps;
|
|
87
|
+
if (collections.inputBindings.length > 0)
|
|
88
|
+
resume.inputBindings = collections.inputBindings;
|
|
89
|
+
if (collections.checklist.length > 0)
|
|
90
|
+
resume.checklist = collections.checklist;
|
|
91
|
+
if (collections.remainingProofItems.length > 0)
|
|
92
|
+
resume.remainingProofItems = collections.remainingProofItems;
|
|
93
|
+
if (collections.remainingProofCommands.length > 0)
|
|
94
|
+
resume.remainingProofCommands = collections.remainingProofCommands;
|
|
95
|
+
if (collections.remainingProofToolCalls.length > 0)
|
|
96
|
+
resume.remainingProofToolCalls = collections.remainingProofToolCalls;
|
|
97
|
+
if (collections.unlocks.length > 0)
|
|
98
|
+
resume.unlocks = collections.unlocks;
|
|
99
|
+
if (collections.blockedBy.length > 0)
|
|
100
|
+
resume.blockedBy = collections.blockedBy;
|
|
101
|
+
}
|
|
102
|
+
function resumeRemainingProofCommands(checklist) {
|
|
103
|
+
return checklist
|
|
104
|
+
.filter((item) => item.kind === 'run_proof' && typeof item.command === 'string')
|
|
105
|
+
.map((item) => item.command);
|
|
106
|
+
}
|
|
107
|
+
function resumeRemainingProofItems(checklist) {
|
|
108
|
+
return checklist.flatMap((item) => {
|
|
109
|
+
if (item.kind !== 'run_proof' || typeof item.command !== 'string')
|
|
110
|
+
return [];
|
|
111
|
+
const toolCall = proofChecklistToolCall(item);
|
|
112
|
+
return [
|
|
113
|
+
{
|
|
114
|
+
stepId: item.stepId,
|
|
115
|
+
status: item.status,
|
|
116
|
+
label: item.label,
|
|
117
|
+
command: item.command,
|
|
118
|
+
...(toolCall ? { toolCall } : {}),
|
|
119
|
+
},
|
|
120
|
+
];
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
function resumeRemainingProofToolCalls(checklist) {
|
|
124
|
+
return checklist.flatMap((item) => {
|
|
125
|
+
if (item.kind !== 'run_proof' || typeof item.command !== 'string')
|
|
126
|
+
return [];
|
|
127
|
+
const toolCall = proofChecklistToolCall(item);
|
|
128
|
+
return toolCall ? [{ stepId: item.stepId, command: item.command, ...toolCall }] : [];
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
function proofChecklistToolCall(item) {
|
|
132
|
+
if (item.tool) {
|
|
133
|
+
return {
|
|
134
|
+
tool: item.tool,
|
|
135
|
+
...(typeof item.args !== 'undefined' ? { args: item.args } : {}),
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
return typeof item.command === 'string' ? proofCommandToolCall(item.command) : undefined;
|
|
139
|
+
}
|
|
140
|
+
export function proofCommandToolCall(command) {
|
|
141
|
+
const preflightMatch = /^projscan preflight(?: --mode ([a-z_]+))? --format json$/.exec(command);
|
|
142
|
+
if (preflightMatch) {
|
|
143
|
+
return {
|
|
144
|
+
tool: 'projscan_preflight',
|
|
145
|
+
args: preflightMatch[1] ? { mode: preflightMatch[1] } : {},
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
const understandMatch = /^projscan understand --view ([a-z_]+)(?: --intent "((?:\\.|[^"\\])*)")? --format json$/.exec(command);
|
|
149
|
+
if (understandMatch) {
|
|
150
|
+
return {
|
|
151
|
+
tool: 'projscan_understand',
|
|
152
|
+
args: {
|
|
153
|
+
view: understandMatch[1],
|
|
154
|
+
...(understandMatch[2] ? { intent: unescapeDoubleQuoted(understandMatch[2]) } : {}),
|
|
155
|
+
},
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
if (command === 'projscan session touched --format json') {
|
|
159
|
+
return {
|
|
160
|
+
tool: 'projscan_session',
|
|
161
|
+
args: { action: 'touched' },
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
return undefined;
|
|
165
|
+
}
|
|
166
|
+
function unescapeDoubleQuoted(value) {
|
|
167
|
+
return value.replace(/\\(["\\$`])/g, '$1');
|
|
168
|
+
}
|
|
169
|
+
function resumeChecklist(plan, cursor, inputBindings, followUps) {
|
|
170
|
+
const current = findStepInPlan(plan, cursor.stepId);
|
|
171
|
+
const currentItem = current
|
|
172
|
+
? resumeChecklistItemFromStep(current.phase, current.step, currentChecklistKind(current.step), cursor.stepId)
|
|
173
|
+
: undefined;
|
|
174
|
+
const includedStepIds = new Set(currentItem ? [currentItem.stepId] : []);
|
|
175
|
+
const inputItems = inputBindings.flatMap((binding) => {
|
|
176
|
+
if (includedStepIds.has(binding.inputId))
|
|
177
|
+
return [];
|
|
178
|
+
const found = findStepInPlan(plan, binding.inputId);
|
|
179
|
+
if (!found)
|
|
180
|
+
return [];
|
|
181
|
+
includedStepIds.add(found.step.id);
|
|
182
|
+
return [
|
|
183
|
+
{
|
|
184
|
+
id: `resume-${found.step.id}`,
|
|
185
|
+
kind: 'resolve_input',
|
|
186
|
+
phaseId: found.phase.id,
|
|
187
|
+
stepId: found.step.id,
|
|
188
|
+
status: found.step.status,
|
|
189
|
+
label: binding.label,
|
|
190
|
+
placeholder: binding.placeholder,
|
|
191
|
+
instruction: binding.instruction,
|
|
192
|
+
followUpIds: binding.followUpIds,
|
|
193
|
+
...(found.step.dependsOn && found.step.dependsOn.length > 0
|
|
194
|
+
? { dependsOn: found.step.dependsOn }
|
|
195
|
+
: {}),
|
|
196
|
+
...(found.step.unlocks && found.step.unlocks.length > 0
|
|
197
|
+
? { unlocks: found.step.unlocks }
|
|
198
|
+
: {}),
|
|
199
|
+
},
|
|
200
|
+
];
|
|
201
|
+
});
|
|
202
|
+
const followUpItems = followUps.flatMap((followUp) => {
|
|
203
|
+
if (includedStepIds.has(followUp.id))
|
|
204
|
+
return [];
|
|
205
|
+
includedStepIds.add(followUp.id);
|
|
206
|
+
return [
|
|
207
|
+
{
|
|
208
|
+
id: `resume-${followUp.id}`,
|
|
209
|
+
kind: 'run_follow_up',
|
|
210
|
+
phaseId: followUp.phaseId,
|
|
211
|
+
stepId: followUp.id,
|
|
212
|
+
status: followUp.status,
|
|
213
|
+
label: followUp.label,
|
|
214
|
+
...(followUp.command ? { command: followUp.command } : {}),
|
|
215
|
+
...(followUp.tool ? { tool: followUp.tool } : {}),
|
|
216
|
+
...(followUp.args ? { args: followUp.args } : {}),
|
|
217
|
+
...(followUp.blockedBy && followUp.blockedBy.length > 0
|
|
218
|
+
? { blockedBy: followUp.blockedBy }
|
|
219
|
+
: {}),
|
|
220
|
+
...(followUp.dependsOn && followUp.dependsOn.length > 0
|
|
221
|
+
? { dependsOn: followUp.dependsOn }
|
|
222
|
+
: {}),
|
|
223
|
+
},
|
|
224
|
+
];
|
|
225
|
+
});
|
|
226
|
+
const currentCommand = current?.step.command;
|
|
227
|
+
const proofItems = stepsForPhase(plan, 'proof')
|
|
228
|
+
.filter(({ step }) => step.command && step.command !== currentCommand)
|
|
229
|
+
.map(({ phase, step }) => resumeChecklistItemFromStep(phase, step, 'run_proof', step.id));
|
|
230
|
+
const doneItems = stepsForPhase(plan, 'done_when').map(({ phase, step }) => resumeChecklistItemFromStep(phase, step, 'confirm_done', step.id));
|
|
231
|
+
return [
|
|
232
|
+
...(currentItem ? [currentItem] : []),
|
|
233
|
+
...inputItems,
|
|
234
|
+
...followUpItems,
|
|
235
|
+
...proofItems,
|
|
236
|
+
...doneItems,
|
|
237
|
+
];
|
|
238
|
+
}
|
|
239
|
+
function resumeChecklistItemFromStep(phase, step, kind, stepId) {
|
|
240
|
+
const item = {
|
|
241
|
+
id: `resume-${stepId}`,
|
|
242
|
+
kind,
|
|
243
|
+
phaseId: phase.id,
|
|
244
|
+
stepId,
|
|
245
|
+
status: step.status,
|
|
246
|
+
label: step.label,
|
|
247
|
+
};
|
|
248
|
+
appendChecklistStepFields(item, step);
|
|
249
|
+
return item;
|
|
250
|
+
}
|
|
251
|
+
function appendChecklistStepFields(item, step) {
|
|
252
|
+
addTruthyValue(item, 'command', step.command);
|
|
253
|
+
addTruthyValue(item, 'tool', step.tool);
|
|
254
|
+
addTruthyValue(item, 'args', step.args);
|
|
255
|
+
addTruthyValue(item, 'placeholder', step.placeholder);
|
|
256
|
+
addTruthyValue(item, 'instruction', step.instruction);
|
|
257
|
+
addNonEmptyStrings(item, 'blockedBy', step.blockedBy);
|
|
258
|
+
addNonEmptyStrings(item, 'dependsOn', step.dependsOn);
|
|
259
|
+
addNonEmptyStrings(item, 'unlocks', step.unlocks);
|
|
260
|
+
}
|
|
261
|
+
function currentChecklistKind(step) {
|
|
262
|
+
if (step.kind === 'input')
|
|
263
|
+
return 'resolve_input';
|
|
264
|
+
if (step.kind === 'proof')
|
|
265
|
+
return 'run_proof';
|
|
266
|
+
if (step.kind === 'criterion')
|
|
267
|
+
return 'confirm_done';
|
|
268
|
+
return 'run_current';
|
|
269
|
+
}
|
|
270
|
+
function resumeInputBindings(plan, cursor) {
|
|
271
|
+
const ids = uniqueStrings([
|
|
272
|
+
...(cursor.kind === 'input' ? [cursor.stepId] : []),
|
|
273
|
+
...(cursor.unlocks ?? []),
|
|
274
|
+
]);
|
|
275
|
+
return ids.flatMap((id) => {
|
|
276
|
+
const found = findStepInPlan(plan, id);
|
|
277
|
+
if (!found || found.step.kind !== 'input' || !found.step.placeholder || !found.step.instruction)
|
|
278
|
+
return [];
|
|
279
|
+
const followUpIds = (found.step.unlocks ?? []).filter((unlockedId) => findStepInPlan(plan, unlockedId)?.phase.id === 'follow_up');
|
|
280
|
+
return [
|
|
281
|
+
{
|
|
282
|
+
inputId: found.step.id,
|
|
283
|
+
label: found.step.label,
|
|
284
|
+
placeholder: found.step.placeholder,
|
|
285
|
+
instruction: found.step.instruction,
|
|
286
|
+
followUpIds,
|
|
287
|
+
},
|
|
288
|
+
];
|
|
289
|
+
});
|
|
290
|
+
}
|
|
291
|
+
function resumeFollowUps(plan, cursor) {
|
|
292
|
+
const followUpIds = new Set();
|
|
293
|
+
for (const id of cursor.unlocks ?? []) {
|
|
294
|
+
const found = findStepInPlan(plan, id);
|
|
295
|
+
if (!found)
|
|
296
|
+
continue;
|
|
297
|
+
if (found.phase.id === 'follow_up')
|
|
298
|
+
followUpIds.add(found.step.id);
|
|
299
|
+
for (const unlockedId of found.step.unlocks ?? []) {
|
|
300
|
+
const unlocked = findStepInPlan(plan, unlockedId);
|
|
301
|
+
if (unlocked?.phase.id === 'follow_up')
|
|
302
|
+
followUpIds.add(unlocked.step.id);
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
return Array.from(followUpIds).flatMap((id) => {
|
|
306
|
+
const found = findStepInPlan(plan, id);
|
|
307
|
+
if (!found)
|
|
308
|
+
return [];
|
|
309
|
+
return [
|
|
310
|
+
{
|
|
311
|
+
id: found.step.id,
|
|
312
|
+
phaseId: found.phase.id,
|
|
313
|
+
kind: found.step.kind,
|
|
314
|
+
status: found.step.status,
|
|
315
|
+
label: found.step.label,
|
|
316
|
+
...(found.step.command ? { command: found.step.command } : {}),
|
|
317
|
+
...(found.step.tool ? { tool: found.step.tool } : {}),
|
|
318
|
+
...(found.step.args ? { args: found.step.args } : {}),
|
|
319
|
+
...(found.step.blockedBy && found.step.blockedBy.length > 0
|
|
320
|
+
? { blockedBy: found.step.blockedBy }
|
|
321
|
+
: {}),
|
|
322
|
+
...(found.step.dependsOn && found.step.dependsOn.length > 0
|
|
323
|
+
? { dependsOn: found.step.dependsOn }
|
|
324
|
+
: {}),
|
|
325
|
+
},
|
|
326
|
+
];
|
|
327
|
+
});
|
|
328
|
+
}
|
|
329
|
+
function resumeToolCall(plan, cursor) {
|
|
330
|
+
const found = findStepInPlan(plan, cursor.stepId);
|
|
331
|
+
if (!found?.step.tool || !argsAreReady(found.step.args))
|
|
332
|
+
return undefined;
|
|
333
|
+
return {
|
|
334
|
+
tool: found.step.tool,
|
|
335
|
+
...(typeof found.step.args !== 'undefined' ? { args: found.step.args } : {}),
|
|
336
|
+
};
|
|
337
|
+
}
|
|
338
|
+
function resolveResumeReferences(plan, ids) {
|
|
339
|
+
if (!ids || ids.length === 0)
|
|
340
|
+
return [];
|
|
341
|
+
const references = [];
|
|
342
|
+
for (const id of ids) {
|
|
343
|
+
const found = findStepInPlan(plan, id);
|
|
344
|
+
if (!found)
|
|
345
|
+
continue;
|
|
346
|
+
references.push({
|
|
347
|
+
id: found.step.id,
|
|
348
|
+
phaseId: found.phase.id,
|
|
349
|
+
kind: found.step.kind,
|
|
350
|
+
status: found.step.status,
|
|
351
|
+
label: found.step.label,
|
|
352
|
+
...(found.step.instruction ? { instruction: found.step.instruction } : {}),
|
|
353
|
+
...(found.step.command ? { command: found.step.command } : {}),
|
|
354
|
+
...(found.step.placeholder ? { placeholder: found.step.placeholder } : {}),
|
|
355
|
+
});
|
|
356
|
+
}
|
|
357
|
+
return references;
|
|
358
|
+
}
|
|
359
|
+
function findStepInPlan(plan, id) {
|
|
360
|
+
for (const phase of plan.phases) {
|
|
361
|
+
for (const step of phase.steps) {
|
|
362
|
+
if (step.id === id)
|
|
363
|
+
return { phase, step };
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
return undefined;
|
|
367
|
+
}
|
|
368
|
+
function stepsForPhase(plan, phaseId) {
|
|
369
|
+
const phase = plan.phases.find((item) => item.id === phaseId);
|
|
370
|
+
return phase ? phase.steps.map((step) => ({ phase, step })) : [];
|
|
371
|
+
}
|
|
372
|
+
function resumeUnlocksSentence(unlocks, rawIds) {
|
|
373
|
+
if (unlocks.length > 0)
|
|
374
|
+
return ` This can unlock ${unlocks.map(formatResumeReferenceLabel).join(', ')}.`;
|
|
375
|
+
return rawIds && rawIds.length > 0 ? ` This can unlock ${rawIds.join(', ')}.` : '';
|
|
376
|
+
}
|
|
377
|
+
function resumeBlockersSentence(blockedBy, rawIds) {
|
|
378
|
+
if (blockedBy.length > 0)
|
|
379
|
+
return ` Blocked by ${blockedBy.map(formatResumeReferenceLabel).join(', ')}.`;
|
|
380
|
+
return rawIds && rawIds.length > 0 ? ` Blocked by ${rawIds.join(', ')}.` : '';
|
|
381
|
+
}
|
|
382
|
+
function formatResumeReferenceLabel(reference) {
|
|
383
|
+
return `${reference.id} (${reference.label})`;
|
|
384
|
+
}
|
|
385
|
+
export function executionCursor(phases) {
|
|
386
|
+
const selected = selectExecutionStep(phases);
|
|
387
|
+
return selected ? executionCursorFromSelection(selected) : fallbackExecutionCursor();
|
|
388
|
+
}
|
|
389
|
+
function selectExecutionStep(phases) {
|
|
390
|
+
for (const selector of CURSOR_SELECTORS) {
|
|
391
|
+
const selected = findExecutionStep(phases, selector);
|
|
392
|
+
if (selected)
|
|
393
|
+
return selected;
|
|
394
|
+
}
|
|
395
|
+
return undefined;
|
|
396
|
+
}
|
|
397
|
+
function fallbackExecutionCursor() {
|
|
398
|
+
return {
|
|
399
|
+
phaseId: 'done_when',
|
|
400
|
+
stepId: 'criterion-1',
|
|
401
|
+
status: 'pending',
|
|
402
|
+
kind: 'criterion',
|
|
403
|
+
label: 'The next action is complete and verified.',
|
|
404
|
+
reason: 'Use this criterion to decide when the task is complete.',
|
|
405
|
+
};
|
|
406
|
+
}
|
|
407
|
+
function executionCursorFromSelection(selected) {
|
|
408
|
+
const cursor = {
|
|
409
|
+
phaseId: selected.phase.id,
|
|
410
|
+
stepId: selected.step.id,
|
|
411
|
+
status: selected.step.status,
|
|
412
|
+
kind: selected.step.kind,
|
|
413
|
+
label: selected.step.label,
|
|
414
|
+
reason: executionCursorReason(selected.step),
|
|
415
|
+
};
|
|
416
|
+
appendCursorStepFields(cursor, selected.step);
|
|
417
|
+
return cursor;
|
|
418
|
+
}
|
|
419
|
+
function appendCursorStepFields(cursor, step) {
|
|
420
|
+
addTruthyValue(cursor, 'command', step.command);
|
|
421
|
+
addTruthyValue(cursor, 'tool', step.tool);
|
|
422
|
+
addDefinedValue(cursor, 'args', step.args);
|
|
423
|
+
addTruthyValue(cursor, 'instruction', step.instruction);
|
|
424
|
+
addTruthyValue(cursor, 'placeholder', step.placeholder);
|
|
425
|
+
addNonEmptyStrings(cursor, 'blockedBy', step.blockedBy);
|
|
426
|
+
addNonEmptyStrings(cursor, 'unlocks', step.unlocks);
|
|
427
|
+
}
|
|
428
|
+
function findExecutionStep(phases, predicate) {
|
|
429
|
+
for (const phase of phases) {
|
|
430
|
+
for (const step of phase.steps) {
|
|
431
|
+
if (predicate(phase, step))
|
|
432
|
+
return { phase, step };
|
|
433
|
+
}
|
|
434
|
+
}
|
|
435
|
+
return undefined;
|
|
436
|
+
}
|
|
437
|
+
function executionCursorReason(step) {
|
|
438
|
+
return (CURSOR_REASON_RULES.find((rule) => rule.matches(step))?.reason(step) ??
|
|
439
|
+
'Use this step as the current execution pointer.');
|
|
440
|
+
}
|
|
441
|
+
export function argsAreReady(value) {
|
|
442
|
+
if (typeof value === 'string')
|
|
443
|
+
return !isPlaceholder(value);
|
|
444
|
+
if (Array.isArray(value))
|
|
445
|
+
return value.every(argsAreReady);
|
|
446
|
+
if (value && typeof value === 'object')
|
|
447
|
+
return Object.values(value).every(argsAreReady);
|
|
448
|
+
return true;
|
|
449
|
+
}
|
|
450
|
+
export function isRunnableCommand(command) {
|
|
451
|
+
return !/<[^<>]+>/.test(command);
|
|
452
|
+
}
|
|
453
|
+
export function uniqueStrings(values) {
|
|
454
|
+
return [...new Set(values.filter((value) => value.length > 0))];
|
|
455
|
+
}
|
|
456
|
+
function addTruthyValue(target, key, value) {
|
|
457
|
+
if (value)
|
|
458
|
+
target[key] = value;
|
|
459
|
+
}
|
|
460
|
+
function addDefinedValue(target, key, value) {
|
|
461
|
+
if (typeof value !== 'undefined')
|
|
462
|
+
target[key] = value;
|
|
463
|
+
}
|
|
464
|
+
function addNonEmptyStrings(target, key, values) {
|
|
465
|
+
if (values && values.length > 0)
|
|
466
|
+
target[key] = values;
|
|
467
|
+
}
|
|
468
|
+
//# sourceMappingURL=startResume.js.map
|