projscan 4.6.0 → 4.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +25 -12
- package/dist/cli/_shared.js +12 -44
- package/dist/cli/_shared.js.map +1 -1
- package/dist/cli/changedOnly.d.ts +16 -0
- package/dist/cli/changedOnly.js +28 -0
- package/dist/cli/changedOnly.js.map +1 -0
- package/dist/cli/commands/start.js +5 -28
- package/dist/cli/commands/start.js.map +1 -1
- package/dist/cli/commands/startOptionsRegistration.d.ts +2 -0
- package/dist/cli/commands/startOptionsRegistration.js +29 -0
- package/dist/cli/commands/startOptionsRegistration.js.map +1 -0
- package/dist/cli/formatOptions.d.ts +4 -0
- package/dist/cli/formatOptions.js +30 -0
- package/dist/cli/formatOptions.js.map +1 -0
- package/dist/core/agentBrief.js +6 -1
- package/dist/core/agentBrief.js.map +1 -1
- package/dist/core/ast.d.ts +2 -17
- package/dist/core/ast.js +4 -33
- package/dist/core/ast.js.map +1 -1
- package/dist/core/astBodySignals.js +2 -3
- package/dist/core/astBodySignals.js.map +1 -1
- package/dist/core/astMembers.d.ts +1 -0
- package/dist/core/astMembers.js +38 -9
- package/dist/core/astMembers.js.map +1 -1
- package/dist/core/astResult.d.ts +20 -0
- package/dist/core/astResult.js +39 -0
- package/dist/core/astResult.js.map +1 -0
- package/dist/core/bugHunt.js +2 -142
- package/dist/core/bugHunt.js.map +1 -1
- package/dist/core/bugHuntHotspotFindings.d.ts +2 -0
- package/dist/core/bugHuntHotspotFindings.js +68 -0
- package/dist/core/bugHuntHotspotFindings.js.map +1 -0
- package/dist/core/bugHuntPreflightFindings.d.ts +3 -0
- package/dist/core/bugHuntPreflightFindings.js +115 -0
- package/dist/core/bugHuntPreflightFindings.js.map +1 -0
- package/dist/core/codeGraph.d.ts +2 -24
- package/dist/core/codeGraph.js +8 -119
- package/dist/core/codeGraph.js.map +1 -1
- package/dist/core/codeGraphAdapterContexts.d.ts +8 -0
- package/dist/core/codeGraphAdapterContexts.js +14 -0
- package/dist/core/codeGraphAdapterContexts.js.map +1 -0
- package/dist/core/codeGraphFileSelection.d.ts +7 -0
- package/dist/core/codeGraphFileSelection.js +19 -0
- package/dist/core/codeGraphFileSelection.js.map +1 -0
- package/dist/core/codeGraphIncremental.d.ts +17 -0
- package/dist/core/codeGraphIncremental.js +64 -0
- package/dist/core/codeGraphIncremental.js.map +1 -0
- package/dist/core/codeGraphQueries.d.ts +9 -0
- package/dist/core/codeGraphQueries.js +25 -0
- package/dist/core/codeGraphQueries.js.map +1 -0
- package/dist/core/collisionDetector.d.ts +1 -0
- package/dist/core/collisionDetector.js +3 -0
- package/dist/core/collisionDetector.js.map +1 -1
- package/dist/core/coordination.js +23 -5
- package/dist/core/coordination.js.map +1 -1
- package/dist/core/coordinationEvidence.d.ts +1 -0
- package/dist/core/coordinationEvidence.js.map +1 -1
- package/dist/core/dataflow.js +3 -338
- package/dist/core/dataflow.js.map +1 -1
- package/dist/core/dataflowDatabaseSinks.d.ts +8 -0
- package/dist/core/dataflowDatabaseSinks.js +78 -0
- package/dist/core/dataflowDatabaseSinks.js.map +1 -0
- package/dist/core/dataflowRiskAssembly.d.ts +11 -0
- package/dist/core/dataflowRiskAssembly.js +117 -0
- package/dist/core/dataflowRiskAssembly.js.map +1 -0
- package/dist/core/dataflowTraversal.d.ts +25 -0
- package/dist/core/dataflowTraversal.js +200 -0
- package/dist/core/dataflowTraversal.js.map +1 -0
- package/dist/core/fileInspectionReport.d.ts +13 -0
- package/dist/core/fileInspectionReport.js +49 -0
- package/dist/core/fileInspectionReport.js.map +1 -0
- package/dist/core/fileInspector.d.ts +3 -11
- package/dist/core/fileInspector.js +2 -46
- package/dist/core/fileInspector.js.map +1 -1
- package/dist/core/fixSuggest.d.ts +1 -9
- package/dist/core/fixSuggest.js +2 -58
- package/dist/core/fixSuggest.js.map +1 -1
- package/dist/core/fixSuggestDependencyNames.d.ts +1 -0
- package/dist/core/fixSuggestDependencyNames.js +9 -0
- package/dist/core/fixSuggestDependencyNames.js.map +1 -0
- package/dist/core/fixSuggestPreview.d.ts +10 -0
- package/dist/core/fixSuggestPreview.js +87 -0
- package/dist/core/fixSuggestPreview.js.map +1 -0
- package/dist/core/frameworkExpressSources.js +6 -31
- package/dist/core/frameworkExpressSources.js.map +1 -1
- package/dist/core/frameworkFastifySources.js +5 -22
- package/dist/core/frameworkFastifySources.js.map +1 -1
- package/dist/core/frameworkHonoSources.js +12 -24
- package/dist/core/frameworkHonoSources.js.map +1 -1
- package/dist/core/frameworkKoaSources.js +5 -24
- package/dist/core/frameworkKoaSources.js.map +1 -1
- package/dist/core/frameworkNextRouteSources.d.ts +6 -1
- package/dist/core/frameworkNextRouteSources.js +31 -1
- package/dist/core/frameworkNextRouteSources.js.map +1 -1
- package/dist/core/frameworkRemixSources.d.ts +2 -0
- package/dist/core/frameworkRemixSources.js +63 -0
- package/dist/core/frameworkRemixSources.js.map +1 -0
- package/dist/core/frameworkSourceContext.d.ts +15 -0
- package/dist/core/frameworkSourceContext.js +2 -0
- package/dist/core/frameworkSourceContext.js.map +1 -0
- package/dist/core/frameworkSourceMatching.d.ts +6 -0
- package/dist/core/frameworkSourceMatching.js +29 -0
- package/dist/core/frameworkSourceMatching.js.map +1 -0
- package/dist/core/frameworkSourceResolvers.d.ts +2 -0
- package/dist/core/frameworkSourceResolvers.js +45 -0
- package/dist/core/frameworkSourceResolvers.js.map +1 -0
- package/dist/core/frameworkSources.d.ts +3 -3
- package/dist/core/frameworkSources.js +17 -15
- package/dist/core/frameworkSources.js.map +1 -1
- package/dist/core/frameworkSvelteKitSources.d.ts +2 -0
- package/dist/core/frameworkSvelteKitSources.js +118 -0
- package/dist/core/frameworkSvelteKitSources.js.map +1 -0
- package/dist/core/intentRouter.d.ts +4 -14
- package/dist/core/intentRouter.js +2 -33
- package/dist/core/intentRouter.js.map +1 -1
- package/dist/core/intentRouterCatalog.js +49 -0
- package/dist/core/intentRouterCatalog.js.map +1 -1
- package/dist/core/intentRouterKeywordToolGuards.js +5 -0
- package/dist/core/intentRouterKeywordToolGuards.js.map +1 -1
- package/dist/core/intentRouterKeywordWeights.js +36 -0
- package/dist/core/intentRouterKeywordWeights.js.map +1 -1
- package/dist/core/intentRouterReleaseSignals.js +104 -39
- package/dist/core/intentRouterReleaseSignals.js.map +1 -1
- package/dist/core/intentRouterResolution.d.ts +3 -0
- package/dist/core/intentRouterResolution.js +11 -0
- package/dist/core/intentRouterResolution.js.map +1 -0
- package/dist/core/intentRouterResult.d.ts +16 -0
- package/dist/core/intentRouterResult.js +34 -0
- package/dist/core/intentRouterResult.js.map +1 -0
- package/dist/core/intentRouterWorkSignals.js +18 -0
- package/dist/core/intentRouterWorkSignals.js.map +1 -1
- package/dist/core/languages/pythonLockfiles.d.ts +4 -0
- package/dist/core/languages/pythonLockfiles.js +6 -2
- package/dist/core/languages/pythonLockfiles.js.map +1 -1
- package/dist/core/languages/pythonManifests.js +11 -24
- package/dist/core/languages/pythonManifests.js.map +1 -1
- package/dist/core/languages/pythonPep508.js +1 -1
- package/dist/core/languages/pythonPep508.js.map +1 -1
- package/dist/core/languages/pythonProjectEvidence.js +4 -4
- package/dist/core/languages/pythonProjectEvidence.js.map +1 -1
- package/dist/core/languages/pythonPyproject.js +1 -1
- package/dist/core/languages/pythonPyproject.js.map +1 -1
- package/dist/core/languages/pythonPyprojectEvidence.d.ts +7 -0
- package/dist/core/languages/pythonPyprojectEvidence.js +23 -0
- package/dist/core/languages/pythonPyprojectEvidence.js.map +1 -0
- package/dist/core/languages/pythonRequirements.d.ts +2 -0
- package/dist/core/languages/pythonRequirements.js +215 -24
- package/dist/core/languages/pythonRequirements.js.map +1 -1
- package/dist/core/pluginAnalyzerLoading.d.ts +3 -0
- package/dist/core/pluginAnalyzerLoading.js +55 -0
- package/dist/core/pluginAnalyzerLoading.js.map +1 -0
- package/dist/core/pluginAnalyzerRunning.d.ts +10 -0
- package/dist/core/pluginAnalyzerRunning.js +32 -0
- package/dist/core/pluginAnalyzerRunning.js.map +1 -0
- package/dist/core/pluginIssueValidation.d.ts +2 -0
- package/dist/core/pluginIssueValidation.js +22 -0
- package/dist/core/pluginIssueValidation.js.map +1 -0
- package/dist/core/pluginManifestDiscovery.d.ts +25 -0
- package/dist/core/pluginManifestDiscovery.js +80 -0
- package/dist/core/pluginManifestDiscovery.js.map +1 -0
- package/dist/core/pluginManifestValidation.d.ts +41 -0
- package/dist/core/pluginManifestValidation.js +179 -0
- package/dist/core/pluginManifestValidation.js.map +1 -0
- package/dist/core/pluginModuleLoading.d.ts +8 -0
- package/dist/core/pluginModuleLoading.js +91 -0
- package/dist/core/pluginModuleLoading.js.map +1 -0
- package/dist/core/pluginReporterLoading.d.ts +41 -0
- package/dist/core/pluginReporterLoading.js +105 -0
- package/dist/core/pluginReporterLoading.js.map +1 -0
- package/dist/core/pluginRuntimeTypes.d.ts +20 -0
- package/dist/core/pluginRuntimeTypes.js +2 -0
- package/dist/core/pluginRuntimeTypes.js.map +1 -0
- package/dist/core/plugins.d.ts +11 -126
- package/dist/core/plugins.js +13 -478
- package/dist/core/plugins.js.map +1 -1
- package/dist/core/preflight.d.ts +1 -2
- package/dist/core/preflight.js +4 -91
- package/dist/core/preflight.js.map +1 -1
- package/dist/core/preflightEvidence.js +11 -0
- package/dist/core/preflightEvidence.js.map +1 -1
- package/dist/core/preflightInputs.d.ts +1 -0
- package/dist/core/preflightInputs.js.map +1 -1
- package/dist/core/preflightReasons.d.ts +21 -0
- package/dist/core/preflightReasons.js +28 -0
- package/dist/core/preflightReasons.js.map +1 -0
- package/dist/core/preflightReport.d.ts +9 -0
- package/dist/core/preflightReport.js +67 -0
- package/dist/core/preflightReport.js.map +1 -0
- package/dist/core/regressionPlan.d.ts +2 -1
- package/dist/core/regressionPlan.js +7 -1
- package/dist/core/regressionPlan.js.map +1 -1
- package/dist/core/releaseEvidence.js +6 -120
- package/dist/core/releaseEvidence.js.map +1 -1
- package/dist/core/releaseEvidenceArtifacts.d.ts +3 -0
- package/dist/core/releaseEvidenceArtifacts.js +65 -0
- package/dist/core/releaseEvidenceArtifacts.js.map +1 -0
- package/dist/core/releaseEvidenceVerdict.d.ts +6 -0
- package/dist/core/releaseEvidenceVerdict.js +54 -0
- package/dist/core/releaseEvidenceVerdict.js.map +1 -0
- package/dist/core/reportPathRedaction.d.ts +4 -0
- package/dist/core/reportPathRedaction.js +64 -0
- package/dist/core/reportPathRedaction.js.map +1 -0
- package/dist/core/reportScope.js +2 -163
- package/dist/core/reportScope.js.map +1 -1
- package/dist/core/reportScopeFiltering.d.ts +9 -0
- package/dist/core/reportScopeFiltering.js +102 -0
- package/dist/core/reportScopeFiltering.js.map +1 -0
- package/dist/core/review.js +2 -47
- package/dist/core/review.js.map +1 -1
- package/dist/core/reviewChangedReport.d.ts +13 -0
- package/dist/core/reviewChangedReport.js +38 -0
- package/dist/core/reviewChangedReport.js.map +1 -0
- package/dist/core/reviewComputation.d.ts +9 -0
- package/dist/core/reviewComputation.js +14 -0
- package/dist/core/reviewComputation.js.map +1 -0
- package/dist/core/reviewContractChanges.js +22 -8
- package/dist/core/reviewContractChanges.js.map +1 -1
- package/dist/core/reviewDataflow.js +18 -0
- package/dist/core/reviewDataflow.js.map +1 -1
- package/dist/core/roadmapCatalog.js +7 -203
- package/dist/core/roadmapCatalog.js.map +1 -1
- package/dist/core/roadmapCatalogPost44.d.ts +2 -0
- package/dist/core/roadmapCatalogPost44.js +205 -0
- package/dist/core/roadmapCatalogPost44.js.map +1 -0
- package/dist/core/roadmapCatalogTypes.d.ts +6 -0
- package/dist/core/roadmapCatalogTypes.js +2 -0
- package/dist/core/roadmapCatalogTypes.js.map +1 -0
- package/dist/core/searchIndex.d.ts +2 -14
- package/dist/core/searchIndex.js +4 -227
- package/dist/core/searchIndex.js.map +1 -1
- package/dist/core/searchIndexFiles.d.ts +1 -0
- package/dist/core/searchIndexFiles.js +26 -0
- package/dist/core/searchIndexFiles.js.map +1 -0
- package/dist/core/searchIndexText.d.ts +15 -0
- package/dist/core/searchIndexText.js +204 -0
- package/dist/core/searchIndexText.js.map +1 -0
- package/dist/core/start.js +5 -46
- package/dist/core/start.js.map +1 -1
- package/dist/core/startClaimRouteCriteria.d.ts +7 -0
- package/dist/core/startClaimRouteCriteria.js +16 -0
- package/dist/core/startClaimRouteCriteria.js.map +1 -0
- package/dist/core/startCouplingRouteCriteria.d.ts +2 -0
- package/dist/core/startCouplingRouteCriteria.js +13 -0
- package/dist/core/startCouplingRouteCriteria.js.map +1 -0
- package/dist/core/startDependencyRouteCriteria.d.ts +2 -0
- package/dist/core/startDependencyRouteCriteria.js +43 -0
- package/dist/core/startDependencyRouteCriteria.js.map +1 -0
- package/dist/core/startEvidence.d.ts +1 -1
- package/dist/core/startEvidence.js +16 -1
- package/dist/core/startEvidence.js.map +1 -1
- package/dist/core/startFileRouteCriteria.d.ts +2 -0
- package/dist/core/startFileRouteCriteria.js +56 -0
- package/dist/core/startFileRouteCriteria.js.map +1 -0
- package/dist/core/startFixedRouteCriteria.d.ts +1 -0
- package/dist/core/startFixedRouteCriteria.js +90 -0
- package/dist/core/startFixedRouteCriteria.js.map +1 -0
- package/dist/core/startImpactRouteCriteria.d.ts +7 -0
- package/dist/core/startImpactRouteCriteria.js +14 -0
- package/dist/core/startImpactRouteCriteria.js.map +1 -0
- package/dist/core/startInputs.d.ts +1 -0
- package/dist/core/startInputs.js +4 -1
- package/dist/core/startInputs.js.map +1 -1
- package/dist/core/startIntentTargets.d.ts +1 -0
- package/dist/core/startIntentTargets.js +28 -0
- package/dist/core/startIntentTargets.js.map +1 -1
- package/dist/core/startMissionControl.js +8 -2
- package/dist/core/startMissionControl.js.map +1 -1
- package/dist/core/startMissionPolicy.js +12 -0
- package/dist/core/startMissionPolicy.js.map +1 -1
- package/dist/core/startMode.d.ts +1 -0
- package/dist/core/startMode.js +10 -2
- package/dist/core/startMode.js.map +1 -1
- package/dist/core/startPreflightRouteCriteria.d.ts +11 -0
- package/dist/core/startPreflightRouteCriteria.js +29 -0
- package/dist/core/startPreflightRouteCriteria.js.map +1 -0
- package/dist/core/startProductPlanningRouteCriteria.d.ts +8 -0
- package/dist/core/startProductPlanningRouteCriteria.js +29 -0
- package/dist/core/startProductPlanningRouteCriteria.js.map +1 -0
- package/dist/core/startRegressionRouteCriteria.d.ts +3 -0
- package/dist/core/startRegressionRouteCriteria.js +62 -0
- package/dist/core/startRegressionRouteCriteria.js.map +1 -0
- package/dist/core/startReportBuilder.d.ts +1 -0
- package/dist/core/startReportBuilder.js +1 -0
- package/dist/core/startReportBuilder.js.map +1 -1
- package/dist/core/startReportContext.d.ts +23 -0
- package/dist/core/startReportContext.js +51 -0
- package/dist/core/startReportContext.js.map +1 -0
- package/dist/core/startRoadmapPreview.d.ts +2 -0
- package/dist/core/startRoadmapPreview.js +31 -0
- package/dist/core/startRoadmapPreview.js.map +1 -0
- package/dist/core/startRouteActions.js +39 -1
- package/dist/core/startRouteActions.js.map +1 -1
- package/dist/core/startSuccessCriteria.d.ts +2 -3
- package/dist/core/startSuccessCriteria.js +15 -419
- package/dist/core/startSuccessCriteria.js.map +1 -1
- package/dist/core/startUnderstandRouteCriteria.d.ts +3 -0
- package/dist/core/startUnderstandRouteCriteria.js +97 -0
- package/dist/core/startUnderstandRouteCriteria.js.map +1 -0
- package/dist/core/taint.d.ts +2 -67
- package/dist/core/taint.js +41 -164
- package/dist/core/taint.js.map +1 -1
- package/dist/core/taintIndex.d.ts +20 -0
- package/dist/core/taintIndex.js +81 -0
- package/dist/core/taintIndex.js.map +1 -0
- package/dist/core/taintTraversal.d.ts +8 -0
- package/dist/core/taintTraversal.js +113 -0
- package/dist/core/taintTraversal.js.map +1 -0
- package/dist/core/taintTypes.d.ts +67 -0
- package/dist/core/taintTypes.js +2 -0
- package/dist/core/taintTypes.js.map +1 -0
- package/dist/core/telemetry.d.ts +9 -89
- package/dist/core/telemetry.js +35 -387
- package/dist/core/telemetry.js.map +1 -1
- package/dist/core/telemetryConfig.d.ts +58 -0
- package/dist/core/telemetryConfig.js +171 -0
- package/dist/core/telemetryConfig.js.map +1 -0
- package/dist/core/telemetryEvents.d.ts +57 -0
- package/dist/core/telemetryEvents.js +143 -0
- package/dist/core/telemetryEvents.js.map +1 -0
- package/dist/core/telemetryFlushing.d.ts +10 -0
- package/dist/core/telemetryFlushing.js +42 -0
- package/dist/core/telemetryFlushing.js.map +1 -0
- package/dist/core/telemetryRecording.d.ts +26 -0
- package/dist/core/telemetryRecording.js +38 -0
- package/dist/core/telemetryRecording.js.map +1 -0
- package/dist/core/telemetrySender.d.ts +9 -0
- package/dist/core/telemetrySender.js +22 -0
- package/dist/core/telemetrySender.js.map +1 -0
- package/dist/core/upgradePreviewPython.js +1 -1
- package/dist/core/upgradePreviewPython.js.map +1 -1
- package/dist/index.d.ts +4 -60
- package/dist/index.js +4 -60
- package/dist/index.js.map +1 -1
- package/dist/mcp/server.js +2 -13
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp/serverMessageHandling.d.ts +3 -0
- package/dist/mcp/serverMessageHandling.js +16 -0
- package/dist/mcp/serverMessageHandling.js.map +1 -0
- package/dist/mcp/toolDefinitions.d.ts +3 -0
- package/dist/mcp/toolDefinitions.js +15 -0
- package/dist/mcp/toolDefinitions.js.map +1 -0
- package/dist/mcp/tools.js +2 -13
- package/dist/mcp/tools.js.map +1 -1
- package/dist/projscan-sbom.cdx.json +6 -6
- package/dist/publicAgent.d.ts +22 -0
- package/dist/publicAgent.js +23 -0
- package/dist/publicAgent.js.map +1 -0
- package/dist/publicCore.d.ts +29 -0
- package/dist/publicCore.js +30 -0
- package/dist/publicCore.js.map +1 -0
- package/dist/publicLanguages.d.ts +1 -0
- package/dist/publicLanguages.js +2 -0
- package/dist/publicLanguages.js.map +1 -0
- package/dist/publicMcp.d.ts +8 -0
- package/dist/publicMcp.js +9 -0
- package/dist/publicMcp.js.map +1 -0
- package/dist/reporters/consoleFixReporter.d.ts +3 -0
- package/dist/reporters/consoleFixReporter.js +41 -0
- package/dist/reporters/consoleFixReporter.js.map +1 -0
- package/dist/reporters/consoleReporter.d.ts +1 -3
- package/dist/reporters/consoleReporter.js +1 -42
- package/dist/reporters/consoleReporter.js.map +1 -1
- package/dist/reporters/htmlAnalysisReporter.d.ts +3 -0
- package/dist/reporters/htmlAnalysisReporter.js +98 -0
- package/dist/reporters/htmlAnalysisReporter.js.map +1 -0
- package/dist/reporters/htmlCoverageReporter.d.ts +2 -0
- package/dist/reporters/htmlCoverageReporter.js +52 -0
- package/dist/reporters/htmlCoverageReporter.js.map +1 -0
- package/dist/reporters/htmlImpactReporter.d.ts +2 -0
- package/dist/reporters/htmlImpactReporter.js +41 -0
- package/dist/reporters/htmlImpactReporter.js.map +1 -0
- package/dist/reporters/htmlPrDiffReporter.d.ts +2 -0
- package/dist/reporters/htmlPrDiffReporter.js +84 -0
- package/dist/reporters/htmlPrDiffReporter.js.map +1 -0
- package/dist/reporters/htmlReporter.d.ts +20 -9
- package/dist/reporters/htmlReporter.js +7 -365
- package/dist/reporters/htmlReporter.js.map +1 -1
- package/dist/reporters/htmlReviewReporter.d.ts +2 -0
- package/dist/reporters/htmlReviewReporter.js +94 -0
- package/dist/reporters/htmlReviewReporter.js.map +1 -0
- package/dist/reporters/htmlShared.d.ts +7 -0
- package/dist/reporters/htmlShared.js +106 -0
- package/dist/reporters/htmlShared.js.map +1 -0
- package/dist/tool-manifest.json +2 -2
- package/dist/types/preflight.d.ts +19 -0
- package/dist/types/start.d.ts +7 -437
- package/dist/types/startCommon.d.ts +79 -0
- package/dist/types/startCommon.js +2 -0
- package/dist/types/startCommon.js.map +1 -0
- package/dist/types/startExecution.d.ts +44 -0
- package/dist/types/startExecution.js +2 -0
- package/dist/types/startExecution.js.map +1 -0
- package/dist/types/startMissionControl.d.ts +91 -0
- package/dist/types/startMissionControl.js +2 -0
- package/dist/types/startMissionControl.js.map +1 -0
- package/dist/types/startMissionProof.d.ts +91 -0
- package/dist/types/startMissionProof.js +2 -0
- package/dist/types/startMissionProof.js.map +1 -0
- package/dist/types/startMissionResume.d.ts +100 -0
- package/dist/types/startMissionResume.js +2 -0
- package/dist/types/startMissionResume.js.map +1 -0
- package/dist/types/startMissionReview.d.ts +45 -0
- package/dist/types/startMissionReview.js +2 -0
- package/dist/types/startMissionReview.js.map +1 -0
- package/dist/types/startMissionTooling.d.ts +16 -0
- package/dist/types/startMissionTooling.js +2 -0
- package/dist/types/startMissionTooling.js.map +1 -0
- package/dist/utils/changedFiles.d.ts +1 -0
- package/dist/utils/changedFiles.js +7 -4
- package/dist/utils/changedFiles.js.map +1 -1
- package/docs/GUIDE.md +9 -7
- package/docs/ROADMAP.md +18 -7
- package/docs/examples/adoption-workflows.md +12 -1
- package/docs/examples/swarm-coordination.md +11 -2
- package/package.json +1 -1
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
const STOPWORDS = new Set([
|
|
2
|
+
'the',
|
|
3
|
+
'a',
|
|
4
|
+
'an',
|
|
5
|
+
'and',
|
|
6
|
+
'or',
|
|
7
|
+
'not',
|
|
8
|
+
'of',
|
|
9
|
+
'to',
|
|
10
|
+
'in',
|
|
11
|
+
'is',
|
|
12
|
+
'it',
|
|
13
|
+
'for',
|
|
14
|
+
'on',
|
|
15
|
+
'with',
|
|
16
|
+
'this',
|
|
17
|
+
'that',
|
|
18
|
+
'by',
|
|
19
|
+
'as',
|
|
20
|
+
'at',
|
|
21
|
+
'be',
|
|
22
|
+
'are',
|
|
23
|
+
'was',
|
|
24
|
+
'were',
|
|
25
|
+
'has',
|
|
26
|
+
'have',
|
|
27
|
+
'had',
|
|
28
|
+
]);
|
|
29
|
+
const TS_KEYWORDS = new Set([
|
|
30
|
+
'const',
|
|
31
|
+
'let',
|
|
32
|
+
'var',
|
|
33
|
+
'function',
|
|
34
|
+
'return',
|
|
35
|
+
'if',
|
|
36
|
+
'else',
|
|
37
|
+
'while',
|
|
38
|
+
'for',
|
|
39
|
+
'do',
|
|
40
|
+
'break',
|
|
41
|
+
'continue',
|
|
42
|
+
'switch',
|
|
43
|
+
'case',
|
|
44
|
+
'default',
|
|
45
|
+
'new',
|
|
46
|
+
'class',
|
|
47
|
+
'extends',
|
|
48
|
+
'implements',
|
|
49
|
+
'interface',
|
|
50
|
+
'type',
|
|
51
|
+
'enum',
|
|
52
|
+
'public',
|
|
53
|
+
'private',
|
|
54
|
+
'protected',
|
|
55
|
+
'static',
|
|
56
|
+
'readonly',
|
|
57
|
+
'async',
|
|
58
|
+
'await',
|
|
59
|
+
'try',
|
|
60
|
+
'catch',
|
|
61
|
+
'finally',
|
|
62
|
+
'throw',
|
|
63
|
+
'import',
|
|
64
|
+
'export',
|
|
65
|
+
'from',
|
|
66
|
+
'as',
|
|
67
|
+
'typeof',
|
|
68
|
+
'instanceof',
|
|
69
|
+
'void',
|
|
70
|
+
'null',
|
|
71
|
+
'undefined',
|
|
72
|
+
'true',
|
|
73
|
+
'false',
|
|
74
|
+
'this',
|
|
75
|
+
'super',
|
|
76
|
+
'yield',
|
|
77
|
+
'delete',
|
|
78
|
+
'in',
|
|
79
|
+
'of',
|
|
80
|
+
'any',
|
|
81
|
+
'never',
|
|
82
|
+
'unknown',
|
|
83
|
+
'string',
|
|
84
|
+
'number',
|
|
85
|
+
'boolean',
|
|
86
|
+
'object',
|
|
87
|
+
'symbol',
|
|
88
|
+
'bigint',
|
|
89
|
+
]);
|
|
90
|
+
const PY_KEYWORDS = new Set([
|
|
91
|
+
'def',
|
|
92
|
+
'class',
|
|
93
|
+
'self',
|
|
94
|
+
'cls',
|
|
95
|
+
'lambda',
|
|
96
|
+
'yield',
|
|
97
|
+
'pass',
|
|
98
|
+
'elif',
|
|
99
|
+
'none',
|
|
100
|
+
'true',
|
|
101
|
+
'false',
|
|
102
|
+
'and',
|
|
103
|
+
'or',
|
|
104
|
+
'not',
|
|
105
|
+
'is',
|
|
106
|
+
'in',
|
|
107
|
+
'import',
|
|
108
|
+
'from',
|
|
109
|
+
'as',
|
|
110
|
+
'with',
|
|
111
|
+
'try',
|
|
112
|
+
'except',
|
|
113
|
+
'finally',
|
|
114
|
+
'raise',
|
|
115
|
+
'assert',
|
|
116
|
+
'global',
|
|
117
|
+
'nonlocal',
|
|
118
|
+
'del',
|
|
119
|
+
'async',
|
|
120
|
+
'await',
|
|
121
|
+
'return',
|
|
122
|
+
'if',
|
|
123
|
+
'else',
|
|
124
|
+
'for',
|
|
125
|
+
'while',
|
|
126
|
+
'break',
|
|
127
|
+
'continue',
|
|
128
|
+
]);
|
|
129
|
+
/**
|
|
130
|
+
* Tokenize a string for indexing/querying:
|
|
131
|
+
* - lowercase
|
|
132
|
+
* - split on non-identifier chars
|
|
133
|
+
* - split camelCase and snake_case
|
|
134
|
+
* - drop tokens shorter than 2 chars, stopwords, TS keywords
|
|
135
|
+
* - apply basic stem (drop trailing s / ing / ed)
|
|
136
|
+
*/
|
|
137
|
+
export function tokenize(input) {
|
|
138
|
+
const out = [];
|
|
139
|
+
// Split on non-identifier boundaries. Keep original case so we can also
|
|
140
|
+
// split on camelCase boundaries below.
|
|
141
|
+
const rawTokens = input.match(/[A-Za-z0-9_]+/g) ?? [];
|
|
142
|
+
for (const raw of rawTokens) {
|
|
143
|
+
// Split on underscore and camelCase. camelCase: insert a boundary before
|
|
144
|
+
// each uppercase that follows a lowercase or digit (OR before runs of
|
|
145
|
+
// uppercase followed by lowercase to handle acronyms like "XMLParser").
|
|
146
|
+
const camelSplit = raw
|
|
147
|
+
.replace(/([a-z0-9])([A-Z])/g, '$1 $2')
|
|
148
|
+
.replace(/([A-Z]+)([A-Z][a-z])/g, '$1 $2');
|
|
149
|
+
const parts = camelSplit.split(/[_\s]+/).filter(Boolean);
|
|
150
|
+
for (const part of parts) {
|
|
151
|
+
// Split embedded digits from letters - e.g. "v1api" -> "v", "1", "api"
|
|
152
|
+
const subparts = part.split(/(\d+)/).filter(Boolean);
|
|
153
|
+
for (const sp of subparts) {
|
|
154
|
+
const lower = sp.toLowerCase();
|
|
155
|
+
const stemmed = stem(lower);
|
|
156
|
+
if (!keepToken(stemmed))
|
|
157
|
+
continue;
|
|
158
|
+
out.push(stemmed);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
return out;
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Expand a user query into a set of candidate tokens. Same rules as tokenize
|
|
166
|
+
* plus: if the raw query has no hits, try progressively looser tokenization.
|
|
167
|
+
*/
|
|
168
|
+
export function expandQuery(query) {
|
|
169
|
+
const tokens = tokenize(query);
|
|
170
|
+
return [...new Set(tokens)];
|
|
171
|
+
}
|
|
172
|
+
export function countHits(tokens, query) {
|
|
173
|
+
let count = 0;
|
|
174
|
+
const set = new Set(tokens);
|
|
175
|
+
for (const q of query)
|
|
176
|
+
if (set.has(q))
|
|
177
|
+
count++;
|
|
178
|
+
return count;
|
|
179
|
+
}
|
|
180
|
+
function stem(token) {
|
|
181
|
+
if (token.length <= 3)
|
|
182
|
+
return token;
|
|
183
|
+
if (token.endsWith('ing'))
|
|
184
|
+
return token.slice(0, -3);
|
|
185
|
+
if (token.endsWith('ed') && token.length > 4)
|
|
186
|
+
return token.slice(0, -2);
|
|
187
|
+
if (token.endsWith('es') && token.length > 4)
|
|
188
|
+
return token.slice(0, -2);
|
|
189
|
+
if (token.endsWith('s') && !token.endsWith('ss'))
|
|
190
|
+
return token.slice(0, -1);
|
|
191
|
+
return token;
|
|
192
|
+
}
|
|
193
|
+
function keepToken(token) {
|
|
194
|
+
if (token.length < 2)
|
|
195
|
+
return false;
|
|
196
|
+
if (STOPWORDS.has(token))
|
|
197
|
+
return false;
|
|
198
|
+
if (TS_KEYWORDS.has(token))
|
|
199
|
+
return false;
|
|
200
|
+
if (PY_KEYWORDS.has(token))
|
|
201
|
+
return false;
|
|
202
|
+
return true;
|
|
203
|
+
}
|
|
204
|
+
//# sourceMappingURL=searchIndexText.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"searchIndexText.js","sourceRoot":"","sources":["../../src/core/searchIndexText.ts"],"names":[],"mappings":"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"}
|
package/dist/core/start.js
CHANGED
|
@@ -1,45 +1,12 @@
|
|
|
1
|
-
import { getWorkflowRecipes } from './adoption.js';
|
|
2
|
-
import { fixFirstFromStartRisk } from './fixFirst.js';
|
|
3
|
-
import { buildFirstTenMinutes } from './onboarding.js';
|
|
4
|
-
import { buildAdoptionLoop } from './startAdoptionLoop.js';
|
|
5
|
-
import { buildStartCoordinationHints } from './startEvidence.js';
|
|
6
1
|
import { loadStartInputs } from './startInputs.js';
|
|
7
|
-
import { buildStartNextActions } from './startNextActions.js';
|
|
8
2
|
import { normalizeStartOptions } from './startOptions.js';
|
|
9
|
-
import {
|
|
10
|
-
import { buildMissionControl } from './startMissionControl.js';
|
|
11
|
-
import { buildStartAdoptionGaps } from './startAdoptionGaps.js';
|
|
3
|
+
import { buildStartReportContext } from './startReportContext.js';
|
|
12
4
|
import { buildStartReport } from './startReportBuilder.js';
|
|
13
5
|
export async function computeStartReport(rootPath, options = {}) {
|
|
14
6
|
const { intent, modeResolution, mode, maxTasks, maxRisks } = normalizeStartOptions(options);
|
|
15
|
-
const
|
|
16
|
-
const
|
|
17
|
-
const
|
|
18
|
-
const fixFirst = workplan.fixFirst ?? fixFirstFromStartRisk(topRisks[0]);
|
|
19
|
-
const adoptionGaps = buildStartAdoptionGaps(setup.diagnostics);
|
|
20
|
-
const adoptionLoop = buildAdoptionLoop();
|
|
21
|
-
const firstTenMinutes = buildFirstTenMinutes(mode);
|
|
22
|
-
const coordinationHints = buildStartCoordinationHints(riskSources, mode, harnessHints);
|
|
23
|
-
const missionControl = buildMissionControl({
|
|
24
|
-
mode,
|
|
25
|
-
intent,
|
|
26
|
-
setupOverall: setup.overall,
|
|
27
|
-
workplan,
|
|
28
|
-
workflow,
|
|
29
|
-
fixFirst,
|
|
30
|
-
adoptionGaps,
|
|
31
|
-
coordinationHints,
|
|
32
|
-
riskSources,
|
|
33
|
-
missionOutcome,
|
|
34
|
-
});
|
|
35
|
-
const nextActions = buildStartNextActions({
|
|
36
|
-
missionControl,
|
|
37
|
-
firstTenMinutes,
|
|
38
|
-
workflow,
|
|
39
|
-
adoptionLoop,
|
|
40
|
-
workplan,
|
|
41
|
-
quality,
|
|
42
|
-
});
|
|
7
|
+
const inputs = await loadStartInputs(rootPath, options, { mode, maxTasks, maxRisks });
|
|
8
|
+
const { setup, workplan, quality, riskSources } = inputs;
|
|
9
|
+
const context = buildStartReportContext({ ...inputs, mode, intent, maxRisks });
|
|
43
10
|
return buildStartReport({
|
|
44
11
|
rootPath,
|
|
45
12
|
mode,
|
|
@@ -49,15 +16,7 @@ export async function computeStartReport(rootPath, options = {}) {
|
|
|
49
16
|
workplan,
|
|
50
17
|
quality,
|
|
51
18
|
riskSources,
|
|
52
|
-
|
|
53
|
-
firstTenMinutes,
|
|
54
|
-
missionControl,
|
|
55
|
-
coordinationHints,
|
|
56
|
-
topRisks,
|
|
57
|
-
fixFirst,
|
|
58
|
-
adoptionGaps,
|
|
59
|
-
adoptionLoop,
|
|
60
|
-
nextActions,
|
|
19
|
+
...context,
|
|
61
20
|
includeHandoff: options.includeHandoff,
|
|
62
21
|
});
|
|
63
22
|
}
|
package/dist/core/start.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"start.js","sourceRoot":"","sources":["../../src/core/start.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"start.js","sourceRoot":"","sources":["../../src/core/start.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,qBAAqB,EAA4B,MAAM,mBAAmB,CAAC;AACpF,OAAO,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAK3D,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,QAAgB,EAChB,UAA+B,EAAE;IAEjC,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,qBAAqB,CAAC,OAAO,CAAC,CAAC;IAC5F,MAAM,MAAM,GAAG,MAAM,eAAe,CAAC,QAAQ,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;IACtF,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,MAAM,CAAC;IACzD,MAAM,OAAO,GAAG,uBAAuB,CAAC,EAAE,GAAG,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC/E,OAAO,gBAAgB,CAAC;QACtB,QAAQ;QACR,IAAI;QACJ,UAAU,EAAE,cAAc,CAAC,MAAM;QACjC,UAAU,EAAE,cAAc,CAAC,MAAM;QACjC,KAAK;QACL,QAAQ;QACR,OAAO;QACP,WAAW;QACX,GAAG,OAAO;QACV,cAAc,EAAE,OAAO,CAAC,cAAc;KACvC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { PreflightSuggestedAction } from '../types/preflight.js';
|
|
2
|
+
import type { StartRoutedIntent } from '../types/start.js';
|
|
3
|
+
export interface ClaimSuccessCriteriaInput {
|
|
4
|
+
route?: StartRoutedIntent;
|
|
5
|
+
actionPlan: PreflightSuggestedAction[];
|
|
6
|
+
}
|
|
7
|
+
export declare function claimRouteSuccessCriteria(context: ClaimSuccessCriteriaInput): string[] | undefined;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export function claimRouteSuccessCriteria(context) {
|
|
2
|
+
if (context.route?.tool !== 'projscan_claim')
|
|
3
|
+
return undefined;
|
|
4
|
+
const hasAddAction = context.actionPlan.some((action) => action.args && 'action' in action.args && action.args.action === 'add');
|
|
5
|
+
if (hasAddAction) {
|
|
6
|
+
return [
|
|
7
|
+
'Active claims are reviewed before a new file, directory, or symbol claim is added.',
|
|
8
|
+
'The target is claimed with a real agent name, and any returned contention is assigned or resolved before parallel editing continues.',
|
|
9
|
+
];
|
|
10
|
+
}
|
|
11
|
+
return [
|
|
12
|
+
'Active claims, owners, leases, and contention warnings are reviewed before parallel work continues.',
|
|
13
|
+
'Any stale or contended claim has a release, owner, or coordination follow-up before editing resumes.',
|
|
14
|
+
];
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=startClaimRouteCriteria.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startClaimRouteCriteria.js","sourceRoot":"","sources":["../../src/core/startClaimRouteCriteria.ts"],"names":[],"mappings":"AAQA,MAAM,UAAU,yBAAyB,CACvC,OAAkC;IAElC,IAAI,OAAO,CAAC,KAAK,EAAE,IAAI,KAAK,gBAAgB;QAAE,OAAO,SAAS,CAAC;IAC/D,MAAM,YAAY,GAAG,OAAO,CAAC,UAAU,CAAC,IAAI,CAC1C,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,IAAI,QAAQ,IAAI,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,KAAK,KAAK,CACnF,CAAC;IACF,IAAI,YAAY,EAAE,CAAC;QACjB,OAAO;YACL,oFAAoF;YACpF,sIAAsI;SACvI,CAAC;IACJ,CAAC;IACD,OAAO;QACL,qGAAqG;QACrG,sGAAsG;KACvG,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
const COUPLING_FOLLOW_UP_CRITERION = 'Every high-coupling or circular-import target has an owner, refactor decision, or verification follow-up before architecture work starts.';
|
|
2
|
+
export function couplingSuccessCriteria(primaryAction) {
|
|
3
|
+
const direction = primaryAction?.args && 'direction' in primaryAction.args
|
|
4
|
+
? String(primaryAction.args.direction)
|
|
5
|
+
: 'all';
|
|
6
|
+
return [
|
|
7
|
+
direction === 'cycles_only'
|
|
8
|
+
? 'Circular-import cycles are reviewed with the exact files participating in each strongly connected component.'
|
|
9
|
+
: 'Fan-in, fan-out, instability, cross-package edges, and circular-import cycles are reviewed before refactoring boundaries.',
|
|
10
|
+
COUPLING_FOLLOW_UP_CRITERION,
|
|
11
|
+
];
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=startCouplingRouteCriteria.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startCouplingRouteCriteria.js","sourceRoot":"","sources":["../../src/core/startCouplingRouteCriteria.ts"],"names":[],"mappings":"AAEA,MAAM,4BAA4B,GAChC,2IAA2I,CAAC;AAE9I,MAAM,UAAU,uBAAuB,CACrC,aAAmD;IAEnD,MAAM,SAAS,GACb,aAAa,EAAE,IAAI,IAAI,WAAW,IAAI,aAAa,CAAC,IAAI;QACtD,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC;QACtC,CAAC,CAAC,KAAK,CAAC;IACZ,OAAO;QACL,SAAS,KAAK,aAAa;YACzB,CAAC,CAAC,8GAA8G;YAChH,CAAC,CAAC,2HAA2H;QAC/H,4BAA4B;KAC7B,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
const DEPENDENCY_LICENSE_KEYWORDS = [
|
|
2
|
+
'license',
|
|
3
|
+
'licenses',
|
|
4
|
+
'gpl',
|
|
5
|
+
'copyleft',
|
|
6
|
+
'notice',
|
|
7
|
+
'notices',
|
|
8
|
+
'third',
|
|
9
|
+
'party',
|
|
10
|
+
'open',
|
|
11
|
+
'source',
|
|
12
|
+
'compliance',
|
|
13
|
+
];
|
|
14
|
+
const DEPENDENCY_BUNDLE_KEYWORDS = [
|
|
15
|
+
'bundle',
|
|
16
|
+
'bundles',
|
|
17
|
+
'size',
|
|
18
|
+
'sizes',
|
|
19
|
+
'large',
|
|
20
|
+
'heavy',
|
|
21
|
+
'bloat',
|
|
22
|
+
'bloated',
|
|
23
|
+
'weight',
|
|
24
|
+
'footprint',
|
|
25
|
+
'reduce',
|
|
26
|
+
'slim',
|
|
27
|
+
];
|
|
28
|
+
export function dependencySuccessCriteria(route) {
|
|
29
|
+
const criteria = [];
|
|
30
|
+
if (matchesAnyKeyword(route, DEPENDENCY_LICENSE_KEYWORDS)) {
|
|
31
|
+
criteria.push('Dependency license counts, unknown licenses, and copyleft risks are reviewed before third-party notices or compliance sign-off.');
|
|
32
|
+
}
|
|
33
|
+
if (matchesAnyKeyword(route, DEPENDENCY_BUNDLE_KEYWORDS)) {
|
|
34
|
+
criteria.push('Installed package-size totals and largest packages are reviewed before bundle-size or dependency-bloat work starts.');
|
|
35
|
+
}
|
|
36
|
+
criteria.push('Declared production and development dependencies are inventoried before package changes are planned.');
|
|
37
|
+
criteria.push('Any dependency risks, workspace-specific counts, or missing lockfile signal has an owner or follow-up command.');
|
|
38
|
+
return criteria;
|
|
39
|
+
}
|
|
40
|
+
function matchesAnyKeyword(route, keywords) {
|
|
41
|
+
return route.matchedKeywords.some((keyword) => keywords.includes(keyword));
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=startDependencyRouteCriteria.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startDependencyRouteCriteria.js","sourceRoot":"","sources":["../../src/core/startDependencyRouteCriteria.ts"],"names":[],"mappings":"AAEA,MAAM,2BAA2B,GAAG;IAClC,SAAS;IACT,UAAU;IACV,KAAK;IACL,UAAU;IACV,QAAQ;IACR,SAAS;IACT,OAAO;IACP,OAAO;IACP,MAAM;IACN,QAAQ;IACR,YAAY;CACb,CAAC;AAEF,MAAM,0BAA0B,GAAG;IACjC,QAAQ;IACR,SAAS;IACT,MAAM;IACN,OAAO;IACP,OAAO;IACP,OAAO;IACP,OAAO;IACP,SAAS;IACT,QAAQ;IACR,WAAW;IACX,QAAQ;IACR,MAAM;CACP,CAAC;AAEF,MAAM,UAAU,yBAAyB,CAAC,KAAwB;IAChE,MAAM,QAAQ,GAAa,EAAE,CAAC;IAC9B,IAAI,iBAAiB,CAAC,KAAK,EAAE,2BAA2B,CAAC,EAAE,CAAC;QAC1D,QAAQ,CAAC,IAAI,CACX,iIAAiI,CAClI,CAAC;IACJ,CAAC;IACD,IAAI,iBAAiB,CAAC,KAAK,EAAE,0BAA0B,CAAC,EAAE,CAAC;QACzD,QAAQ,CAAC,IAAI,CACX,qHAAqH,CACtH,CAAC;IACJ,CAAC;IACD,QAAQ,CAAC,IAAI,CACX,sGAAsG,CACvG,CAAC;IACF,QAAQ,CAAC,IAAI,CACX,gHAAgH,CACjH,CAAC;IACF,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,SAAS,iBAAiB,CAAC,KAAwB,EAAE,QAAkB;IACrE,OAAO,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;AAC7E,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { SessionCoordinationHint } from '../types/session.js';
|
|
2
2
|
import type { StartReport } from '../types/start.js';
|
|
3
3
|
import type { WorkplanMode } from '../types/workplan.js';
|
|
4
|
-
export declare function buildStartCoordinationHints(riskSources: StartReport['evidence']['riskSources'], mode: WorkplanMode, harnessHints?: SessionCoordinationHint[]): SessionCoordinationHint[];
|
|
4
|
+
export declare function buildStartCoordinationHints(riskSources: StartReport['evidence']['riskSources'], mode: WorkplanMode, harnessHints?: SessionCoordinationHint[], intent?: string): SessionCoordinationHint[];
|
|
5
5
|
export declare function buildStartRiskSources(rootPath: string): Promise<StartReport['evidence']['riskSources']>;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { loadSession } from './session.js';
|
|
2
|
+
import { routesForIntent } from './startMode.js';
|
|
2
3
|
import { preflightModeForMission } from './startSuccessCriteria.js';
|
|
3
4
|
import { getChangedFiles } from '../utils/changedFiles.js';
|
|
4
|
-
export function buildStartCoordinationHints(riskSources, mode, harnessHints = []) {
|
|
5
|
+
export function buildStartCoordinationHints(riskSources, mode, harnessHints = [], intent) {
|
|
5
6
|
const preflightMode = preflightModeForMission(mode);
|
|
6
7
|
const hints = [
|
|
7
8
|
{
|
|
@@ -11,6 +12,9 @@ export function buildStartCoordinationHints(riskSources, mode, harnessHints = []
|
|
|
11
12
|
command: `projscan preflight --mode ${preflightMode} --format json`,
|
|
12
13
|
},
|
|
13
14
|
];
|
|
15
|
+
const swarmHint = swarmCoordinationHintForIntent(intent);
|
|
16
|
+
if (swarmHint)
|
|
17
|
+
hints.push(swarmHint);
|
|
14
18
|
hints.push(...harnessHints);
|
|
15
19
|
if (riskSources.sessionMemory.totalTouchedFiles > 0) {
|
|
16
20
|
hints.push({
|
|
@@ -22,6 +26,17 @@ export function buildStartCoordinationHints(riskSources, mode, harnessHints = []
|
|
|
22
26
|
}
|
|
23
27
|
return hints;
|
|
24
28
|
}
|
|
29
|
+
function swarmCoordinationHintForIntent(intent) {
|
|
30
|
+
const primaryRoute = routesForIntent(intent)[0];
|
|
31
|
+
if (primaryRoute?.tool !== 'projscan_coordinate')
|
|
32
|
+
return null;
|
|
33
|
+
return {
|
|
34
|
+
id: 'swarm-coordination',
|
|
35
|
+
label: 'Validate swarm coordination locally',
|
|
36
|
+
message: 'Intent routes to the one-call swarm coordination read; run it before parallel edits so collisions, claims, and merge order are checked from local worktree evidence.',
|
|
37
|
+
command: 'projscan coordinate --format json',
|
|
38
|
+
};
|
|
39
|
+
}
|
|
25
40
|
export async function buildStartRiskSources(rootPath) {
|
|
26
41
|
const [changed, sessionResult] = await Promise.all([
|
|
27
42
|
getChangedFiles(rootPath).catch((err) => ({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"startEvidence.js","sourceRoot":"","sources":["../../src/core/startEvidence.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC;AACpE,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAK3D,MAAM,UAAU,2BAA2B,CACzC,WAAmD,EACnD,IAAkB,EAClB,eAA0C,EAAE;
|
|
1
|
+
{"version":3,"file":"startEvidence.js","sourceRoot":"","sources":["../../src/core/startEvidence.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
const FILE_CRITERIA_RULES = [
|
|
2
|
+
{
|
|
3
|
+
keywords: ['risk', 'risks', 'risky', 'dangerous'],
|
|
4
|
+
criterion: 'Hotspot reasons, related issues, imports, exports, and ownership explain why the file is risky.',
|
|
5
|
+
},
|
|
6
|
+
{
|
|
7
|
+
keywords: [
|
|
8
|
+
'last',
|
|
9
|
+
'touched',
|
|
10
|
+
'touch',
|
|
11
|
+
'changed',
|
|
12
|
+
'recently',
|
|
13
|
+
'history',
|
|
14
|
+
'author',
|
|
15
|
+
'authors',
|
|
16
|
+
'blame',
|
|
17
|
+
],
|
|
18
|
+
criterion: 'Primary author, recent history, and ownership signals are reviewed before routing reviewers or changing the file.',
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
keywords: ['coverage', 'covered', 'uncovered', 'test', 'tests'],
|
|
22
|
+
criterion: 'Coverage, hotspot risk, and related test evidence for the file are reviewed before editing starts.',
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
matches: matchesFileTestDesignCriteria,
|
|
26
|
+
criterion: 'File purpose, risky functions, coverage, and existing test evidence are reviewed before designing a new test.',
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
keywords: ['read'],
|
|
30
|
+
criterion: 'Purpose, imports, exports, ownership, tests, and risk are reviewed before changing the named file.',
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
keywords: ['review', 'reviewer', 'reviewers'],
|
|
34
|
+
criterion: 'Ownership, primary author, hotspot risk, and related issues are reviewed before choosing a reviewer.',
|
|
35
|
+
},
|
|
36
|
+
];
|
|
37
|
+
export function fileSuccessCriteria(route) {
|
|
38
|
+
const matched = new Set(route.matchedKeywords);
|
|
39
|
+
return [
|
|
40
|
+
...FILE_CRITERIA_RULES.filter((rule) => fileCriteriaRuleMatches(rule, matched)).map((rule) => rule.criterion),
|
|
41
|
+
'The file purpose, imports, exports, ownership, and risk are reviewed before editing starts.',
|
|
42
|
+
'Any follow-up impact, owner, or test command from the file report is added to the workplan.',
|
|
43
|
+
];
|
|
44
|
+
}
|
|
45
|
+
function fileCriteriaRuleMatches(rule, matched) {
|
|
46
|
+
if (rule.matches)
|
|
47
|
+
return rule.matches(matched);
|
|
48
|
+
return (rule.keywords ?? []).some((keyword) => matched.has(keyword));
|
|
49
|
+
}
|
|
50
|
+
function matchesFileTestDesignCriteria(matched) {
|
|
51
|
+
const explicitAuthoring = ['add', 'write'].some((keyword) => matched.has(keyword));
|
|
52
|
+
const testWithoutCoverage = matched.has('test') &&
|
|
53
|
+
!['coverage', 'covered', 'uncovered'].some((keyword) => matched.has(keyword));
|
|
54
|
+
return explicitAuthoring || testWithoutCoverage;
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=startFileRouteCriteria.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startFileRouteCriteria.js","sourceRoot":"","sources":["../../src/core/startFileRouteCriteria.ts"],"names":[],"mappings":"AAQA,MAAM,mBAAmB,GAAuB;IAC9C;QACE,QAAQ,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,WAAW,CAAC;QACjD,SAAS,EACP,iGAAiG;KACpG;IACD;QACE,QAAQ,EAAE;YACR,MAAM;YACN,SAAS;YACT,OAAO;YACP,SAAS;YACT,UAAU;YACV,SAAS;YACT,QAAQ;YACR,SAAS;YACT,OAAO;SACR;QACD,SAAS,EACP,mHAAmH;KACtH;IACD;QACE,QAAQ,EAAE,CAAC,UAAU,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,EAAE,OAAO,CAAC;QAC/D,SAAS,EACP,oGAAoG;KACvG;IACD;QACE,OAAO,EAAE,6BAA6B;QACtC,SAAS,EACP,+GAA+G;KAClH;IACD;QACE,QAAQ,EAAE,CAAC,MAAM,CAAC;QAClB,SAAS,EACP,oGAAoG;KACvG;IACD;QACE,QAAQ,EAAE,CAAC,QAAQ,EAAE,UAAU,EAAE,WAAW,CAAC;QAC7C,SAAS,EACP,sGAAsG;KACzG;CACF,CAAC;AAEF,MAAM,UAAU,mBAAmB,CAAC,KAAwB;IAC1D,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;IAC/C,OAAO;QACL,GAAG,mBAAmB,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,uBAAuB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,CACjF,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CACzB;QACD,6FAA6F;QAC7F,6FAA6F;KAC9F,CAAC;AACJ,CAAC;AAED,SAAS,uBAAuB,CAAC,IAAsB,EAAE,OAAoB;IAC3E,IAAI,IAAI,CAAC,OAAO;QAAE,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAC/C,OAAO,CAAC,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;AACvE,CAAC;AAED,SAAS,6BAA6B,CAAC,OAAoB;IACzD,MAAM,iBAAiB,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;IACnF,MAAM,mBAAmB,GACvB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC;QACnB,CAAC,CAAC,UAAU,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;IAChF,OAAO,iBAAiB,IAAI,mBAAmB,CAAC;AAClD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const FIXED_ROUTE_CRITERIA: Record<string, string[]>;
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
export const FIXED_ROUTE_CRITERIA = {
|
|
2
|
+
projscan_release_train: [
|
|
3
|
+
'Release train readiness has no blockers before packaging or publishing continues.',
|
|
4
|
+
'Changelog, package, SBOM, and provenance evidence are reviewed before a release handoff.',
|
|
5
|
+
],
|
|
6
|
+
projscan_bug_hunt: [
|
|
7
|
+
'Bug-hunt findings are triaged by severity with a first fix candidate selected.',
|
|
8
|
+
'The selected fix has a runnable verification command before editing starts.',
|
|
9
|
+
],
|
|
10
|
+
projscan_workplan: [
|
|
11
|
+
'The workplan identifies the first safe implementation or review step before edits begin.',
|
|
12
|
+
'The selected action has a focused verification command before handoff.',
|
|
13
|
+
],
|
|
14
|
+
projscan_agent_brief: [
|
|
15
|
+
'The agent brief summarizes focus items, repo context, guardrails, and suggested next actions for the next developer.',
|
|
16
|
+
'The handoff includes enough proof commands for the next agent to resume without rerunning broad discovery.',
|
|
17
|
+
],
|
|
18
|
+
projscan_session: [
|
|
19
|
+
'Remembered touched files and recent session events are reviewed before resuming work.',
|
|
20
|
+
'The current worktree preflight is rerun after session context is reviewed, so stale memory does not override live risk.',
|
|
21
|
+
],
|
|
22
|
+
projscan_coordinate: [
|
|
23
|
+
'Coordination readiness, collisions, claims, and merge order are reviewed before parallel work continues.',
|
|
24
|
+
'Any conflicted files, contended claims, or merge-order blockers have an owner or follow-up command before editing resumes.',
|
|
25
|
+
],
|
|
26
|
+
projscan_privacy_check: [
|
|
27
|
+
'Telemetry state, offline mode, scan root, ignored-file handling, .env content policy, plugin execution, local writes, and network-capable endpoints are reviewed.',
|
|
28
|
+
'Any required trust-boundary change is made explicitly before broader analysis or report sharing continues.',
|
|
29
|
+
],
|
|
30
|
+
projscan_quality_scorecard: [
|
|
31
|
+
'Quality dimensions, top risks, and verification commands are reviewed before choosing the next task.',
|
|
32
|
+
'The developer knows whether health, security, tests, maintainability, or coordination needs attention first.',
|
|
33
|
+
],
|
|
34
|
+
projscan_review: [
|
|
35
|
+
'The structural PR review reports a verdict and identifies any risk that needs owner follow-up.',
|
|
36
|
+
'Review, preflight, or evidence-pack follow-up is chosen before the branch is handed to reviewers.',
|
|
37
|
+
],
|
|
38
|
+
projscan_evidence_pack: [
|
|
39
|
+
'The evidence pack produces a paste-ready PR comment with verdict, top risks, owner routing, and next commands.',
|
|
40
|
+
'The reviewer-facing comment is validated before it is shared or used for approval.',
|
|
41
|
+
],
|
|
42
|
+
projscan_analyze: [
|
|
43
|
+
'The scoped analysis, health, and CI artifacts are generated with path redaction enabled before sharing outside the repo.',
|
|
44
|
+
'The reviewer can correlate redacted-path-N labels without seeing raw repo structure.',
|
|
45
|
+
],
|
|
46
|
+
projscan_doctor: [
|
|
47
|
+
'Dead code, unused exports, lint, dependency, security, and config issues are reviewed before cleanup starts.',
|
|
48
|
+
'Any issue chosen for cleanup has a fix-suggest, impact, or verification follow-up before files are deleted.',
|
|
49
|
+
],
|
|
50
|
+
projscan_fix_suggest: [
|
|
51
|
+
'A concrete fix suggestion is produced for the selected issue id.',
|
|
52
|
+
'The suggestion names the file, fix instruction, and verification step before editing starts.',
|
|
53
|
+
],
|
|
54
|
+
projscan_explain_issue: [
|
|
55
|
+
'A deep issue explanation is produced for the selected issue id.',
|
|
56
|
+
'The explanation identifies surrounding code, related issues, similar fixes, and the next fix prompt before editing starts.',
|
|
57
|
+
],
|
|
58
|
+
projscan_pr_diff: [
|
|
59
|
+
'The structural diff is reviewed for changed exports, imports, call sites, and complexity before a full review verdict.',
|
|
60
|
+
'The developer knows which changed files or symbols need deeper review.',
|
|
61
|
+
],
|
|
62
|
+
projscan_coverage: [
|
|
63
|
+
'Coverage gaps are ranked by risk so the next test target is explicit.',
|
|
64
|
+
'The selected file has either a new test plan, an owner, or a documented reason to defer.',
|
|
65
|
+
],
|
|
66
|
+
projscan_upgrade: [
|
|
67
|
+
'The upgrade preview identifies declared version, installed version, breaking markers, and importers.',
|
|
68
|
+
'Importer files are reviewed before changing the package version.',
|
|
69
|
+
],
|
|
70
|
+
projscan_audit: [
|
|
71
|
+
'npm audit findings are reviewed for critical, high, moderate, low, and info vulnerabilities.',
|
|
72
|
+
'Any vulnerable dependency has a fix, upgrade preview, or documented deferral before the branch is trusted.',
|
|
73
|
+
],
|
|
74
|
+
projscan_workspaces: [
|
|
75
|
+
'Monorepo workspace packages are listed with names and relative paths before package-scoped work begins.',
|
|
76
|
+
'The selected workspace name is available for package-scoped follow-up commands such as hotspots, coupling, review, or audit.',
|
|
77
|
+
],
|
|
78
|
+
projscan_dataflow: [
|
|
79
|
+
'Dataflow findings are reviewed for direct, propagated, and bridge source-to-sink paths.',
|
|
80
|
+
'Any confirmed source-to-sink path has an owner, mitigation, and rerunnable verification command before editing continues.',
|
|
81
|
+
],
|
|
82
|
+
projscan_semantic_graph: [
|
|
83
|
+
'The targeted graph query answers the importer/import/export question without dumping the full graph.',
|
|
84
|
+
'Any returned files are reviewed before editing the queried file or symbol.',
|
|
85
|
+
],
|
|
86
|
+
projscan_search: [
|
|
87
|
+
'Search results identify the target files or symbols with enough confidence to choose the next tool.',
|
|
88
|
+
],
|
|
89
|
+
};
|
|
90
|
+
//# sourceMappingURL=startFixedRouteCriteria.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startFixedRouteCriteria.js","sourceRoot":"","sources":["../../src/core/startFixedRouteCriteria.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,oBAAoB,GAA6B;IAC5D,sBAAsB,EAAE;QACtB,mFAAmF;QACnF,0FAA0F;KAC3F;IACD,iBAAiB,EAAE;QACjB,gFAAgF;QAChF,6EAA6E;KAC9E;IACD,iBAAiB,EAAE;QACjB,0FAA0F;QAC1F,wEAAwE;KACzE;IACD,oBAAoB,EAAE;QACpB,sHAAsH;QACtH,4GAA4G;KAC7G;IACD,gBAAgB,EAAE;QAChB,uFAAuF;QACvF,yHAAyH;KAC1H;IACD,mBAAmB,EAAE;QACnB,0GAA0G;QAC1G,4HAA4H;KAC7H;IACD,sBAAsB,EAAE;QACtB,mKAAmK;QACnK,4GAA4G;KAC7G;IACD,0BAA0B,EAAE;QAC1B,sGAAsG;QACtG,8GAA8G;KAC/G;IACD,eAAe,EAAE;QACf,gGAAgG;QAChG,mGAAmG;KACpG;IACD,sBAAsB,EAAE;QACtB,gHAAgH;QAChH,oFAAoF;KACrF;IACD,gBAAgB,EAAE;QAChB,0HAA0H;QAC1H,sFAAsF;KACvF;IACD,eAAe,EAAE;QACf,8GAA8G;QAC9G,6GAA6G;KAC9G;IACD,oBAAoB,EAAE;QACpB,kEAAkE;QAClE,8FAA8F;KAC/F;IACD,sBAAsB,EAAE;QACtB,iEAAiE;QACjE,4HAA4H;KAC7H;IACD,gBAAgB,EAAE;QAChB,wHAAwH;QACxH,wEAAwE;KACzE;IACD,iBAAiB,EAAE;QACjB,uEAAuE;QACvE,0FAA0F;KAC3F;IACD,gBAAgB,EAAE;QAChB,sGAAsG;QACtG,kEAAkE;KACnE;IACD,cAAc,EAAE;QACd,8FAA8F;QAC9F,4GAA4G;KAC7G;IACD,mBAAmB,EAAE;QACnB,yGAAyG;QACzG,8HAA8H;KAC/H;IACD,iBAAiB,EAAE;QACjB,yFAAyF;QACzF,2HAA2H;KAC5H;IACD,uBAAuB,EAAE;QACvB,sGAAsG;QACtG,4EAA4E;KAC7E;IACD,eAAe,EAAE;QACf,qGAAqG;KACtG;CACF,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { PreflightSuggestedAction } from '../types/preflight.js';
|
|
2
|
+
import type { StartRoutedIntent } from '../types/start.js';
|
|
3
|
+
export interface ImpactSuccessCriteriaInput {
|
|
4
|
+
route?: StartRoutedIntent;
|
|
5
|
+
primaryAction?: PreflightSuggestedAction;
|
|
6
|
+
}
|
|
7
|
+
export declare function impactSuccessCriteria(context: ImpactSuccessCriteriaInput): string[] | undefined;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export function impactSuccessCriteria(context) {
|
|
2
|
+
if (context.route?.tool !== 'projscan_impact')
|
|
3
|
+
return undefined;
|
|
4
|
+
return [
|
|
5
|
+
...(context.primaryAction?.tool === 'projscan_search'
|
|
6
|
+
? [
|
|
7
|
+
'An exact symbol or file path is selected from search results before impact analysis continues.',
|
|
8
|
+
]
|
|
9
|
+
: []),
|
|
10
|
+
'The impact report is reviewed for direct and transitive dependents before editing starts.',
|
|
11
|
+
'Affected call sites, tests, or owners are added to the workplan before code changes begin.',
|
|
12
|
+
];
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=startImpactRouteCriteria.js.map
|