projscan 4.5.0 → 4.7.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 +30 -16
- package/dist/analyzers/pythonDependencyRiskCheck.js +1 -1
- package/dist/analyzers/pythonDependencyRiskCheck.js.map +1 -1
- package/dist/cli/_shared.d.ts +4 -5
- package/dist/cli/_shared.js +34 -213
- package/dist/cli/_shared.js.map +1 -1
- package/dist/cli/architectureLayers.d.ts +2 -0
- package/dist/cli/architectureLayers.js +112 -0
- package/dist/cli/architectureLayers.js.map +1 -0
- package/dist/cli/bannerDisplay.d.ts +9 -0
- package/dist/cli/bannerDisplay.js +18 -0
- package/dist/cli/bannerDisplay.js.map +1 -0
- package/dist/cli/changedIssueFilter.d.ts +10 -0
- package/dist/cli/changedIssueFilter.js +24 -0
- package/dist/cli/changedIssueFilter.js.map +1 -0
- 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/commandPath.d.ts +2 -0
- package/dist/cli/commandPath.js +12 -0
- package/dist/cli/commandPath.js.map +1 -0
- package/dist/cli/commands/agentBrief.js +11 -0
- package/dist/cli/commands/agentBrief.js.map +1 -1
- package/dist/cli/commands/analyze.js +6 -5
- package/dist/cli/commands/analyze.js.map +1 -1
- package/dist/cli/commands/ci.js +5 -4
- package/dist/cli/commands/ci.js.map +1 -1
- package/dist/cli/commands/coordinate.js +27 -0
- package/dist/cli/commands/coordinate.js.map +1 -1
- package/dist/cli/commands/doctor.js +6 -5
- package/dist/cli/commands/doctor.js.map +1 -1
- 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/cli/pluginReporter.d.ts +14 -0
- package/dist/cli/pluginReporter.js +46 -0
- package/dist/cli/pluginReporter.js.map +1 -0
- package/dist/cli/projectConfig.d.ts +12 -0
- package/dist/cli/projectConfig.js +41 -0
- package/dist/cli/projectConfig.js.map +1 -0
- package/dist/cli/treeSlice.d.ts +3 -0
- package/dist/cli/treeSlice.js +12 -0
- package/dist/cli/treeSlice.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 +4 -81
- package/dist/core/ast.js +11 -637
- package/dist/core/ast.js.map +1 -1
- package/dist/core/astBodySignals.d.ts +17 -0
- package/dist/core/astBodySignals.js +106 -0
- package/dist/core/astBodySignals.js.map +1 -0
- package/dist/core/astFunctionCollector.d.ts +11 -0
- package/dist/core/astFunctionCollector.js +140 -0
- package/dist/core/astFunctionCollector.js.map +1 -0
- package/dist/core/astFunctionNames.d.ts +2 -0
- package/dist/core/astFunctionNames.js +53 -0
- package/dist/core/astFunctionNames.js.map +1 -0
- package/dist/core/astFunctionNodes.d.ts +2 -0
- package/dist/core/astFunctionNodes.js +12 -0
- package/dist/core/astFunctionNodes.js.map +1 -0
- package/dist/core/astMembers.d.ts +14 -0
- package/dist/core/astMembers.js +145 -0
- package/dist/core/astMembers.js.map +1 -0
- package/dist/core/astModuleSignals.d.ts +3 -0
- package/dist/core/astModuleSignals.js +140 -0
- package/dist/core/astModuleSignals.js.map +1 -0
- package/dist/core/astParser.d.ts +11 -0
- package/dist/core/astParser.js +38 -0
- package/dist/core/astParser.js.map +1 -0
- package/dist/core/astProgramSignals.d.ts +11 -0
- package/dist/core/astProgramSignals.js +97 -0
- package/dist/core/astProgramSignals.js.map +1 -0
- package/dist/core/astTypes.d.ts +78 -0
- package/dist/core/astTypes.js +2 -0
- package/dist/core/astTypes.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 +3 -35
- package/dist/core/codeGraph.js +7 -261
- package/dist/core/codeGraph.js.map +1 -1
- package/dist/core/codeGraphFanMetrics.d.ts +17 -0
- package/dist/core/codeGraphFanMetrics.js +89 -0
- package/dist/core/codeGraphFanMetrics.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/codeGraphIndexes.d.ts +23 -0
- package/dist/core/codeGraphIndexes.js +57 -0
- package/dist/core/codeGraphIndexes.js.map +1 -0
- package/dist/core/codeGraphParsing.d.ts +20 -0
- package/dist/core/codeGraphParsing.js +104 -0
- package/dist/core/codeGraphParsing.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/codeGraphTypes.d.ts +28 -0
- package/dist/core/codeGraphTypes.js +2 -0
- package/dist/core/codeGraphTypes.js.map +1 -0
- package/dist/core/collisionDetector.d.ts +2 -0
- package/dist/core/collisionDetector.js +17 -12
- package/dist/core/collisionDetector.js.map +1 -1
- package/dist/core/coordination.d.ts +4 -2
- package/dist/core/coordination.js +40 -4
- package/dist/core/coordination.js.map +1 -1
- package/dist/core/coordinationEvidence.d.ts +32 -0
- package/dist/core/coordinationEvidence.js +101 -0
- package/dist/core/coordinationEvidence.js.map +1 -0
- 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/fileAccess.d.ts +16 -0
- package/dist/core/fileAccess.js +78 -0
- package/dist/core/fileAccess.js.map +1 -0
- package/dist/core/fileExportTypes.d.ts +2 -0
- package/dist/core/fileExportTypes.js +16 -0
- package/dist/core/fileExportTypes.js.map +1 -0
- package/dist/core/fileGraphMetrics.d.ts +4 -0
- package/dist/core/fileGraphMetrics.js +34 -0
- package/dist/core/fileGraphMetrics.js.map +1 -0
- package/dist/core/fileInspectionEvidence.d.ts +13 -0
- package/dist/core/fileInspectionEvidence.js +14 -0
- package/dist/core/fileInspectionEvidence.js.map +1 -0
- package/dist/core/fileInspectionGraph.d.ts +5 -0
- package/dist/core/fileInspectionGraph.js +29 -0
- package/dist/core/fileInspectionGraph.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 +5 -13
- package/dist/core/fileInspector.js +8 -239
- package/dist/core/fileInspector.js.map +1 -1
- package/dist/core/fileIssues.d.ts +1 -0
- package/dist/core/fileIssues.js +18 -0
- package/dist/core/fileIssues.js.map +1 -0
- package/dist/core/filePurpose.d.ts +2 -0
- package/dist/core/filePurpose.js +61 -0
- package/dist/core/filePurpose.js.map +1 -0
- 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.d.ts +4 -0
- package/dist/core/frameworkExpressSources.js +95 -0
- package/dist/core/frameworkExpressSources.js.map +1 -0
- package/dist/core/frameworkFastifySources.d.ts +4 -0
- package/dist/core/frameworkFastifySources.js +74 -0
- package/dist/core/frameworkFastifySources.js.map +1 -0
- package/dist/core/frameworkHonoSources.d.ts +4 -0
- package/dist/core/frameworkHonoSources.js +80 -0
- package/dist/core/frameworkHonoSources.js.map +1 -0
- package/dist/core/frameworkKoaSources.d.ts +4 -0
- package/dist/core/frameworkKoaSources.js +81 -0
- package/dist/core/frameworkKoaSources.js.map +1 -0
- package/dist/core/frameworkNextRouteSources.d.ts +7 -0
- package/dist/core/frameworkNextRouteSources.js +85 -0
- package/dist/core/frameworkNextRouteSources.js.map +1 -0
- 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/frameworkSources.d.ts +15 -3
- package/dist/core/frameworkSources.js +42 -210
- package/dist/core/frameworkSources.js.map +1 -1
- package/dist/core/hotspotAnalyzer.d.ts +2 -18
- package/dist/core/hotspotAnalyzer.js +15 -477
- package/dist/core/hotspotAnalyzer.js.map +1 -1
- package/dist/core/hotspotBuilder.d.ts +14 -0
- package/dist/core/hotspotBuilder.js +70 -0
- package/dist/core/hotspotBuilder.js.map +1 -0
- package/dist/core/hotspotCandidates.d.ts +9 -0
- package/dist/core/hotspotCandidates.js +63 -0
- package/dist/core/hotspotCandidates.js.map +1 -0
- package/dist/core/hotspotGit.d.ts +10 -0
- package/dist/core/hotspotGit.js +152 -0
- package/dist/core/hotspotGit.js.map +1 -0
- package/dist/core/hotspotIssues.d.ts +2 -0
- package/dist/core/hotspotIssues.js +83 -0
- package/dist/core/hotspotIssues.js.map +1 -0
- package/dist/core/hotspotLines.d.ts +2 -0
- package/dist/core/hotspotLines.js +24 -0
- package/dist/core/hotspotLines.js.map +1 -0
- package/dist/core/hotspotMemory.d.ts +2 -0
- package/dist/core/hotspotMemory.js +21 -0
- package/dist/core/hotspotMemory.js.map +1 -0
- package/dist/core/hotspotRanking.d.ts +13 -0
- package/dist/core/hotspotRanking.js +44 -0
- package/dist/core/hotspotRanking.js.map +1 -0
- package/dist/core/hotspotScoring.d.ts +23 -0
- package/dist/core/hotspotScoring.js +128 -0
- package/dist/core/hotspotScoring.js.map +1 -0
- package/dist/core/indexCache.js +3 -1
- package/dist/core/indexCache.js.map +1 -1
- package/dist/core/intentRouter.d.ts +5 -28
- package/dist/core/intentRouter.js +8 -7376
- package/dist/core/intentRouter.js.map +1 -1
- package/dist/core/intentRouterCatalog.d.ts +16 -0
- package/dist/core/intentRouterCatalog.js +1709 -0
- package/dist/core/intentRouterCatalog.js.map +1 -0
- package/dist/core/intentRouterCoordinationSignals.d.ts +12 -0
- package/dist/core/intentRouterCoordinationSignals.js +111 -0
- package/dist/core/intentRouterCoordinationSignals.js.map +1 -0
- package/dist/core/intentRouterDependencySignals.d.ts +9 -0
- package/dist/core/intentRouterDependencySignals.js +226 -0
- package/dist/core/intentRouterDependencySignals.js.map +1 -0
- package/dist/core/intentRouterKeywordContext.d.ts +14 -0
- package/dist/core/intentRouterKeywordContext.js +2 -0
- package/dist/core/intentRouterKeywordContext.js.map +1 -0
- package/dist/core/intentRouterKeywordEarlyGuards.d.ts +2 -0
- package/dist/core/intentRouterKeywordEarlyGuards.js +127 -0
- package/dist/core/intentRouterKeywordEarlyGuards.js.map +1 -0
- package/dist/core/intentRouterKeywordMatches.d.ts +3 -0
- package/dist/core/intentRouterKeywordMatches.js +31 -0
- package/dist/core/intentRouterKeywordMatches.js.map +1 -0
- package/dist/core/intentRouterKeywordSearchGuards.d.ts +2 -0
- package/dist/core/intentRouterKeywordSearchGuards.js +239 -0
- package/dist/core/intentRouterKeywordSearchGuards.js.map +1 -0
- package/dist/core/intentRouterKeywordTargetGuards.d.ts +2 -0
- package/dist/core/intentRouterKeywordTargetGuards.js +191 -0
- package/dist/core/intentRouterKeywordTargetGuards.js.map +1 -0
- package/dist/core/intentRouterKeywordToolGuards.d.ts +2 -0
- package/dist/core/intentRouterKeywordToolGuards.js +133 -0
- package/dist/core/intentRouterKeywordToolGuards.js.map +1 -0
- package/dist/core/intentRouterKeywordWeights.d.ts +4 -0
- package/dist/core/intentRouterKeywordWeights.js +1197 -0
- package/dist/core/intentRouterKeywordWeights.js.map +1 -0
- package/dist/core/intentRouterPlanningSignals.d.ts +7 -0
- package/dist/core/intentRouterPlanningSignals.js +268 -0
- package/dist/core/intentRouterPlanningSignals.js.map +1 -0
- package/dist/core/intentRouterPrDiffSignals.d.ts +1 -0
- package/dist/core/intentRouterPrDiffSignals.js +41 -0
- package/dist/core/intentRouterPrDiffSignals.js.map +1 -0
- package/dist/core/intentRouterPreflightSignals.d.ts +3 -0
- package/dist/core/intentRouterPreflightSignals.js +54 -0
- package/dist/core/intentRouterPreflightSignals.js.map +1 -0
- package/dist/core/intentRouterRegressionKeywordMatches.d.ts +1 -0
- package/dist/core/intentRouterRegressionKeywordMatches.js +176 -0
- package/dist/core/intentRouterRegressionKeywordMatches.js.map +1 -0
- package/dist/core/intentRouterRegressionSignals.d.ts +10 -0
- package/dist/core/intentRouterRegressionSignals.js +207 -0
- package/dist/core/intentRouterRegressionSignals.js.map +1 -0
- package/dist/core/intentRouterReleaseSignals.d.ts +8 -0
- package/dist/core/intentRouterReleaseSignals.js +139 -0
- package/dist/core/intentRouterReleaseSignals.js.map +1 -0
- package/dist/core/intentRouterRepoSignals.d.ts +8 -0
- package/dist/core/intentRouterRepoSignals.js +226 -0
- package/dist/core/intentRouterRepoSignals.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/intentRouterReviewSignals.d.ts +2 -0
- package/dist/core/intentRouterReviewSignals.js +109 -0
- package/dist/core/intentRouterReviewSignals.js.map +1 -0
- package/dist/core/intentRouterRiskSignals.d.ts +12 -0
- package/dist/core/intentRouterRiskSignals.js +242 -0
- package/dist/core/intentRouterRiskSignals.js.map +1 -0
- package/dist/core/intentRouterScoring.d.ts +9 -0
- package/dist/core/intentRouterScoring.js +40 -0
- package/dist/core/intentRouterScoring.js.map +1 -0
- package/dist/core/intentRouterSearchApiSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchApiSignals.js +62 -0
- package/dist/core/intentRouterSearchApiSignals.js.map +1 -0
- package/dist/core/intentRouterSearchBackgroundSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchBackgroundSignals.js +55 -0
- package/dist/core/intentRouterSearchBackgroundSignals.js.map +1 -0
- package/dist/core/intentRouterSearchCommunicationSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchCommunicationSignals.js +74 -0
- package/dist/core/intentRouterSearchCommunicationSignals.js.map +1 -0
- package/dist/core/intentRouterSearchDataSignals.d.ts +2 -0
- package/dist/core/intentRouterSearchDataSignals.js +98 -0
- package/dist/core/intentRouterSearchDataSignals.js.map +1 -0
- package/dist/core/intentRouterSearchDomainSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchDomainSignals.js +71 -0
- package/dist/core/intentRouterSearchDomainSignals.js.map +1 -0
- package/dist/core/intentRouterSearchInfraSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchInfraSignals.js +79 -0
- package/dist/core/intentRouterSearchInfraSignals.js.map +1 -0
- package/dist/core/intentRouterSearchIntegrationSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchIntegrationSignals.js +117 -0
- package/dist/core/intentRouterSearchIntegrationSignals.js.map +1 -0
- package/dist/core/intentRouterSearchLookupSignals.d.ts +10 -0
- package/dist/core/intentRouterSearchLookupSignals.js +310 -0
- package/dist/core/intentRouterSearchLookupSignals.js.map +1 -0
- package/dist/core/intentRouterSearchNavigationSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchNavigationSignals.js +62 -0
- package/dist/core/intentRouterSearchNavigationSignals.js.map +1 -0
- package/dist/core/intentRouterSearchOwnershipSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchOwnershipSignals.js +15 -0
- package/dist/core/intentRouterSearchOwnershipSignals.js.map +1 -0
- package/dist/core/intentRouterSearchPageSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchPageSignals.js +84 -0
- package/dist/core/intentRouterSearchPageSignals.js.map +1 -0
- package/dist/core/intentRouterSearchReliabilitySignals.d.ts +1 -0
- package/dist/core/intentRouterSearchReliabilitySignals.js +94 -0
- package/dist/core/intentRouterSearchReliabilitySignals.js.map +1 -0
- package/dist/core/intentRouterSearchStateSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchStateSignals.js +107 -0
- package/dist/core/intentRouterSearchStateSignals.js.map +1 -0
- package/dist/core/intentRouterSearchStyleSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchStyleSignals.js +99 -0
- package/dist/core/intentRouterSearchStyleSignals.js.map +1 -0
- package/dist/core/intentRouterSearchTestSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchTestSignals.js +34 -0
- package/dist/core/intentRouterSearchTestSignals.js.map +1 -0
- package/dist/core/intentRouterSearchToolingSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchToolingSignals.js +106 -0
- package/dist/core/intentRouterSearchToolingSignals.js.map +1 -0
- package/dist/core/intentRouterSearchUiSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchUiSignals.js +77 -0
- package/dist/core/intentRouterSearchUiSignals.js.map +1 -0
- package/dist/core/intentRouterSecuritySignals.d.ts +4 -0
- package/dist/core/intentRouterSecuritySignals.js +235 -0
- package/dist/core/intentRouterSecuritySignals.js.map +1 -0
- package/dist/core/intentRouterTargetSignals.d.ts +5 -0
- package/dist/core/intentRouterTargetSignals.js +76 -0
- package/dist/core/intentRouterTargetSignals.js.map +1 -0
- package/dist/core/intentRouterTokens.d.ts +1 -0
- package/dist/core/intentRouterTokens.js +36 -0
- package/dist/core/intentRouterTokens.js.map +1 -0
- package/dist/core/intentRouterUnderstandSignals.d.ts +1 -0
- package/dist/core/intentRouterUnderstandSignals.js +171 -0
- package/dist/core/intentRouterUnderstandSignals.js.map +1 -0
- package/dist/core/intentRouterVerificationSignals.d.ts +8 -0
- package/dist/core/intentRouterVerificationSignals.js +119 -0
- package/dist/core/intentRouterVerificationSignals.js.map +1 -0
- package/dist/core/intentRouterWorkSignals.d.ts +4 -0
- package/dist/core/intentRouterWorkSignals.js +175 -0
- package/dist/core/intentRouterWorkSignals.js.map +1 -0
- package/dist/core/languages/pythonLockfiles.d.ts +15 -0
- package/dist/core/languages/pythonLockfiles.js +210 -0
- package/dist/core/languages/pythonLockfiles.js.map +1 -0
- package/dist/core/languages/pythonManifestText.d.ts +7 -0
- package/dist/core/languages/pythonManifestText.js +25 -0
- package/dist/core/languages/pythonManifestText.js.map +1 -0
- package/dist/core/languages/pythonManifests.d.ts +6 -38
- package/dist/core/languages/pythonManifests.js +27 -316
- package/dist/core/languages/pythonManifests.js.map +1 -1
- package/dist/core/languages/pythonPep508.d.ts +4 -0
- package/dist/core/languages/pythonPep508.js +14 -0
- package/dist/core/languages/pythonPep508.js.map +1 -0
- package/dist/core/languages/pythonProjectEvidence.d.ts +2 -0
- package/dist/core/languages/pythonProjectEvidence.js +29 -0
- package/dist/core/languages/pythonProjectEvidence.js.map +1 -0
- package/dist/core/languages/pythonProjectTypes.d.ts +31 -0
- package/dist/core/languages/pythonProjectTypes.js +2 -0
- package/dist/core/languages/pythonProjectTypes.js.map +1 -0
- package/dist/core/languages/pythonPyproject.d.ts +2 -0
- package/dist/core/languages/pythonPyproject.js +160 -0
- package/dist/core/languages/pythonPyproject.js.map +1 -0
- package/dist/core/languages/pythonRequirements.d.ts +9 -0
- package/dist/core/languages/pythonRequirements.js +212 -0
- package/dist/core/languages/pythonRequirements.js.map +1 -0
- package/dist/core/languages/pythonRoots.d.ts +3 -0
- package/dist/core/languages/pythonRoots.js +83 -0
- package/dist/core/languages/pythonRoots.js.map +1 -0
- package/dist/core/languages/pythonSetuptools.d.ts +6 -0
- package/dist/core/languages/pythonSetuptools.js +58 -0
- package/dist/core/languages/pythonSetuptools.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/plugins.d.ts +3 -41
- package/dist/core/plugins.js +2 -129
- package/dist/core/plugins.js.map +1 -1
- package/dist/core/prDiff.js +12 -0
- package/dist/core/prDiff.js.map +1 -1
- package/dist/core/preflight.d.ts +3 -3
- package/dist/core/preflight.js +28 -542
- package/dist/core/preflight.js.map +1 -1
- package/dist/core/preflightChangedFileReasons.d.ts +14 -0
- package/dist/core/preflightChangedFileReasons.js +75 -0
- package/dist/core/preflightChangedFileReasons.js.map +1 -0
- package/dist/core/preflightChangedFiles.d.ts +9 -0
- package/dist/core/preflightChangedFiles.js +34 -0
- package/dist/core/preflightChangedFiles.js.map +1 -0
- package/dist/core/preflightContextReasons.d.ts +17 -0
- package/dist/core/preflightContextReasons.js +73 -0
- package/dist/core/preflightContextReasons.js.map +1 -0
- package/dist/core/preflightEvidence.d.ts +34 -0
- package/dist/core/preflightEvidence.js +119 -0
- package/dist/core/preflightEvidence.js.map +1 -0
- package/dist/core/preflightInputs.d.ts +15 -0
- package/dist/core/preflightInputs.js +31 -0
- package/dist/core/preflightInputs.js.map +1 -0
- package/dist/core/preflightIssueReasons.d.ts +2 -0
- package/dist/core/preflightIssueReasons.js +39 -0
- package/dist/core/preflightIssueReasons.js.map +1 -0
- package/dist/core/preflightLocalEvidence.d.ts +12 -0
- package/dist/core/preflightLocalEvidence.js +36 -0
- package/dist/core/preflightLocalEvidence.js.map +1 -0
- package/dist/core/preflightReleaseScale.d.ts +28 -0
- package/dist/core/preflightReleaseScale.js +95 -0
- package/dist/core/preflightReleaseScale.js.map +1 -0
- package/dist/core/preflightRequiredChecks.d.ts +26 -0
- package/dist/core/preflightRequiredChecks.js +96 -0
- package/dist/core/preflightRequiredChecks.js.map +1 -0
- package/dist/core/preflightReviewEvidence.d.ts +16 -0
- package/dist/core/preflightReviewEvidence.js +31 -0
- package/dist/core/preflightReviewEvidence.js.map +1 -0
- package/dist/core/preflightReviewReasons.d.ts +15 -0
- package/dist/core/preflightReviewReasons.js +76 -0
- package/dist/core/preflightReviewReasons.js.map +1 -0
- package/dist/core/preflightSuggestedActions.d.ts +15 -0
- package/dist/core/preflightSuggestedActions.js +84 -0
- package/dist/core/preflightSuggestedActions.js.map +1 -0
- package/dist/core/preflightTruncation.d.ts +6 -0
- package/dist/core/preflightTruncation.js +7 -0
- package/dist/core/preflightTruncation.js.map +1 -0
- package/dist/core/preflightVerdict.d.ts +3 -0
- package/dist/core/preflightVerdict.js +17 -0
- package/dist/core/preflightVerdict.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.d.ts +4 -3
- package/dist/core/releaseEvidence.js +17 -382
- 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/releaseEvidenceBaseline.d.ts +2 -0
- package/dist/core/releaseEvidenceBaseline.js +28 -0
- package/dist/core/releaseEvidenceBaseline.js.map +1 -0
- package/dist/core/releaseEvidencePrSummary.d.ts +13 -0
- package/dist/core/releaseEvidencePrSummary.js +240 -0
- package/dist/core/releaseEvidencePrSummary.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/releaseTrain.js +3 -317
- package/dist/core/releaseTrain.js.map +1 -1
- package/dist/core/releaseTrainFallbacks.d.ts +3 -0
- package/dist/core/releaseTrainFallbacks.js +318 -0
- package/dist/core/releaseTrainFallbacks.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.d.ts +7 -0
- package/dist/core/reportScope.js +16 -86
- 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.d.ts +2 -25
- package/dist/core/review.js +34 -1034
- package/dist/core/review.js.map +1 -1
- package/dist/core/reviewBaseSnapshot.d.ts +14 -0
- package/dist/core/reviewBaseSnapshot.js +41 -0
- package/dist/core/reviewBaseSnapshot.js.map +1 -0
- package/dist/core/reviewChangedFiles.d.ts +8 -0
- package/dist/core/reviewChangedFiles.js +63 -0
- package/dist/core/reviewChangedFiles.js.map +1 -0
- package/dist/core/reviewContractChanges.d.ts +5 -0
- package/dist/core/reviewContractChanges.js +114 -0
- package/dist/core/reviewContractChanges.js.map +1 -0
- package/dist/core/reviewCycles.d.ts +7 -0
- package/dist/core/reviewCycles.js +53 -0
- package/dist/core/reviewCycles.js.map +1 -0
- package/dist/core/reviewFindings.d.ts +17 -0
- package/dist/core/reviewFindings.js +49 -0
- package/dist/core/reviewFindings.js.map +1 -0
- package/dist/core/reviewFlowDiffs.d.ts +4 -0
- package/dist/core/reviewFlowDiffs.js +99 -0
- package/dist/core/reviewFlowDiffs.js.map +1 -0
- package/dist/core/reviewGit.d.ts +7 -0
- package/dist/core/reviewGit.js +45 -0
- package/dist/core/reviewGit.js.map +1 -0
- package/dist/core/reviewGraphEvidence.d.ts +3 -0
- package/dist/core/reviewGraphEvidence.js +55 -0
- package/dist/core/reviewGraphEvidence.js.map +1 -0
- package/dist/core/reviewHeadSnapshot.d.ts +8 -0
- package/dist/core/reviewHeadSnapshot.js +15 -0
- package/dist/core/reviewHeadSnapshot.js.map +1 -0
- package/dist/core/reviewIntent.d.ts +2 -0
- package/dist/core/reviewIntent.js +18 -0
- package/dist/core/reviewIntent.js.map +1 -0
- package/dist/core/reviewManifests.d.ts +12 -0
- package/dist/core/reviewManifests.js +124 -0
- package/dist/core/reviewManifests.js.map +1 -0
- package/dist/core/reviewNoChanges.d.ts +9 -0
- package/dist/core/reviewNoChanges.js +26 -0
- package/dist/core/reviewNoChanges.js.map +1 -0
- package/dist/core/reviewPackageScope.d.ts +4 -0
- package/dist/core/reviewPackageScope.js +24 -0
- package/dist/core/reviewPackageScope.js.map +1 -0
- package/dist/core/reviewRefs.d.ts +4 -0
- package/dist/core/reviewRefs.js +65 -0
- package/dist/core/reviewRefs.js.map +1 -0
- package/dist/core/reviewRiskyFunctions.d.ts +8 -0
- package/dist/core/reviewRiskyFunctions.js +83 -0
- package/dist/core/reviewRiskyFunctions.js.map +1 -0
- package/dist/core/reviewState.d.ts +21 -0
- package/dist/core/reviewState.js +96 -0
- package/dist/core/reviewState.js.map +1 -0
- package/dist/core/reviewTier.d.ts +18 -0
- package/dist/core/reviewTier.js +99 -0
- package/dist/core/reviewTier.js.map +1 -0
- package/dist/core/reviewVerdict.d.ts +9 -0
- package/dist/core/reviewVerdict.js +121 -0
- package/dist/core/reviewVerdict.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.d.ts +1 -1
- package/dist/core/start.js +14 -87
- package/dist/core/start.js.map +1 -1
- package/dist/core/startAdoptionGaps.d.ts +3 -0
- package/dist/core/startAdoptionGaps.js +12 -0
- package/dist/core/startAdoptionGaps.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/startInputs.d.ts +32 -0
- package/dist/core/startInputs.js +30 -0
- package/dist/core/startInputs.js.map +1 -0
- package/dist/core/startMissionPolicy.js +10 -0
- package/dist/core/startMissionPolicy.js.map +1 -1
- package/dist/core/startMode.js +7 -1
- package/dist/core/startMode.js.map +1 -1
- package/dist/core/startReportBuilder.d.ts +26 -0
- package/dist/core/startReportBuilder.js +45 -0
- package/dist/core/startReportBuilder.js.map +1 -0
- 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/taint.d.ts +2 -67
- package/dist/core/taint.js +41 -276
- 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/taintMatching.d.ts +11 -0
- package/dist/core/taintMatching.js +126 -0
- package/dist/core/taintMatching.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.js +36 -30
- package/dist/core/telemetry.js.map +1 -1
- package/dist/core/upgradePreview.d.ts +1 -12
- package/dist/core/upgradePreview.js +9 -229
- package/dist/core/upgradePreview.js.map +1 -1
- package/dist/core/upgradePreviewNpmEvidence.d.ts +19 -0
- package/dist/core/upgradePreviewNpmEvidence.js +164 -0
- package/dist/core/upgradePreviewNpmEvidence.js.map +1 -0
- package/dist/core/upgradePreviewPython.d.ts +2 -0
- package/dist/core/upgradePreviewPython.js +71 -0
- package/dist/core/upgradePreviewPython.js.map +1 -0
- package/dist/index.d.ts +6 -12
- package/dist/index.js +2 -3
- package/dist/index.js.map +1 -1
- package/dist/mcp/server.d.ts +3 -24
- package/dist/mcp/server.js +32 -414
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp/serverContext.d.ts +6 -0
- package/dist/mcp/serverContext.js +55 -0
- package/dist/mcp/serverContext.js.map +1 -0
- package/dist/mcp/serverDispatch.d.ts +39 -0
- package/dist/mcp/serverDispatch.js +74 -0
- package/dist/mcp/serverDispatch.js.map +1 -0
- package/dist/mcp/serverHandlers.d.ts +15 -0
- package/dist/mcp/serverHandlers.js +94 -0
- package/dist/mcp/serverHandlers.js.map +1 -0
- package/dist/mcp/serverLifecycle.d.ts +14 -0
- package/dist/mcp/serverLifecycle.js +65 -0
- package/dist/mcp/serverLifecycle.js.map +1 -0
- package/dist/mcp/serverMessage.d.ts +11 -0
- package/dist/mcp/serverMessage.js +37 -0
- package/dist/mcp/serverMessage.js.map +1 -0
- package/dist/mcp/serverSession.d.ts +6 -0
- package/dist/mcp/serverSession.js +77 -0
- package/dist/mcp/serverSession.js.map +1 -0
- package/dist/mcp/serverStdio.d.ts +7 -0
- package/dist/mcp/serverStdio.js +34 -0
- package/dist/mcp/serverStdio.js.map +1 -0
- package/dist/mcp/serverTypes.d.ts +18 -0
- package/dist/mcp/serverTypes.js +2 -0
- package/dist/mcp/serverTypes.js.map +1 -0
- package/dist/mcp/serverVersion.d.ts +1 -0
- package/dist/mcp/serverVersion.js +17 -0
- package/dist/mcp/serverVersion.js.map +1 -0
- package/dist/mcp/toolCatalog.d.ts +2 -0
- package/dist/mcp/toolCatalog.js +93 -0
- package/dist/mcp/toolCatalog.js.map +1 -0
- package/dist/mcp/tools.d.ts +2 -3
- package/dist/mcp/tools.js +15 -108
- package/dist/mcp/tools.js.map +1 -1
- package/dist/projscan-sbom.cdx.json +6 -6
- 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/htmlReporter.d.ts +3 -2
- package/dist/reporters/htmlReporter.js +14 -2
- package/dist/reporters/htmlReporter.js.map +1 -1
- package/dist/reporters/jsonReporter.d.ts +4 -3
- package/dist/reporters/jsonReporter.js +9 -4
- package/dist/reporters/jsonReporter.js.map +1 -1
- package/dist/reporters/markdownAnalysisReporter.d.ts +2 -1
- package/dist/reporters/markdownAnalysisReporter.js +8 -1
- package/dist/reporters/markdownAnalysisReporter.js.map +1 -1
- package/dist/reporters/markdownArchitectureReporter.d.ts +3 -0
- package/dist/reporters/markdownArchitectureReporter.js +33 -0
- package/dist/reporters/markdownArchitectureReporter.js.map +1 -0
- package/dist/reporters/markdownCouplingReporter.d.ts +2 -0
- package/dist/reporters/markdownCouplingReporter.js +43 -0
- package/dist/reporters/markdownCouplingReporter.js.map +1 -0
- package/dist/reporters/markdownCoverageReporter.d.ts +2 -0
- package/dist/reporters/markdownCoverageReporter.js +40 -0
- package/dist/reporters/markdownCoverageReporter.js.map +1 -0
- package/dist/reporters/markdownExplanationReporter.d.ts +2 -0
- package/dist/reporters/markdownExplanationReporter.js +37 -0
- package/dist/reporters/markdownExplanationReporter.js.map +1 -0
- package/dist/reporters/markdownHealthReporter.d.ts +4 -0
- package/dist/reporters/markdownHealthReporter.js +66 -0
- package/dist/reporters/markdownHealthReporter.js.map +1 -0
- package/dist/reporters/markdownHotspotReporter.d.ts +2 -0
- package/dist/reporters/markdownHotspotReporter.js +36 -0
- package/dist/reporters/markdownHotspotReporter.js.map +1 -0
- package/dist/reporters/markdownOutdatedReporter.d.ts +2 -0
- package/dist/reporters/markdownOutdatedReporter.js +31 -0
- package/dist/reporters/markdownOutdatedReporter.js.map +1 -0
- package/dist/reporters/markdownPrDiffReporter.d.ts +2 -0
- package/dist/reporters/markdownPrDiffReporter.js +63 -0
- package/dist/reporters/markdownPrDiffReporter.js.map +1 -0
- package/dist/reporters/markdownReporter.d.ts +9 -12
- package/dist/reporters/markdownReporter.js +9 -288
- package/dist/reporters/markdownReporter.js.map +1 -1
- package/dist/reporters/markdownWorkspaceReporter.d.ts +2 -0
- package/dist/reporters/markdownWorkspaceReporter.js +25 -0
- package/dist/reporters/markdownWorkspaceReporter.js.map +1 -0
- package/dist/reporters/sarifReporter.d.ts +6 -4
- package/dist/reporters/sarifReporter.js +8 -7
- package/dist/reporters/sarifReporter.js.map +1 -1
- package/dist/tool-manifest.json +3 -3
- package/dist/types/start.d.ts +14 -0
- package/dist/types.d.ts +34 -34
- package/dist/utils/config.d.ts +2 -8
- package/dist/utils/config.js +13 -211
- package/dist/utils/config.js.map +1 -1
- package/dist/utils/configBasics.d.ts +5 -0
- package/dist/utils/configBasics.js +21 -0
- package/dist/utils/configBasics.js.map +1 -0
- package/dist/utils/configHotspots.d.ts +2 -0
- package/dist/utils/configHotspots.js +15 -0
- package/dist/utils/configHotspots.js.map +1 -0
- package/dist/utils/configIssueRules.d.ts +8 -0
- package/dist/utils/configIssueRules.js +24 -0
- package/dist/utils/configIssueRules.js.map +1 -0
- package/dist/utils/configMonorepo.d.ts +2 -0
- package/dist/utils/configMonorepo.js +38 -0
- package/dist/utils/configMonorepo.js.map +1 -0
- package/dist/utils/configReportPolicies.d.ts +2 -0
- package/dist/utils/configReportPolicies.js +32 -0
- package/dist/utils/configReportPolicies.js.map +1 -0
- package/dist/utils/configScan.d.ts +2 -0
- package/dist/utils/configScan.js +15 -0
- package/dist/utils/configScan.js.map +1 -0
- package/dist/utils/configSeverity.d.ts +2 -0
- package/dist/utils/configSeverity.js +15 -0
- package/dist/utils/configSeverity.js.map +1 -0
- package/dist/utils/configSources.d.ts +5 -0
- package/dist/utils/configSources.js +55 -0
- package/dist/utils/configSources.js.map +1 -0
- package/dist/utils/configTaint.d.ts +2 -0
- package/dist/utils/configTaint.js +15 -0
- package/dist/utils/configTaint.js.map +1 -0
- package/docs/GUIDE.md +22 -11
- package/docs/ROADMAP.md +18 -7
- package/docs/examples/adoption-workflows.md +2 -2
- package/docs/examples/swarm-coordination.md +11 -0
- package/package.json +1 -1
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { buildNoChangeReviewReport } from './reviewNoChanges.js';
|
|
2
|
+
import { isGitRepository, isWorktreeClean, pickDefaultBase, resolveSha } from './reviewRefs.js';
|
|
3
|
+
export async function resolveReviewState(rootPath, options = {}) {
|
|
4
|
+
const unavailable = await repositoryUnavailableState(rootPath, options);
|
|
5
|
+
if (unavailable)
|
|
6
|
+
return unavailable;
|
|
7
|
+
const refs = await resolveReviewRefs(rootPath, options);
|
|
8
|
+
const ready = requireResolvedRefs(refs, options);
|
|
9
|
+
if (ready.kind !== 'ready')
|
|
10
|
+
return ready;
|
|
11
|
+
const noChange = await noChangeReviewState(rootPath, ready);
|
|
12
|
+
if (noChange)
|
|
13
|
+
return noChange;
|
|
14
|
+
return ready;
|
|
15
|
+
}
|
|
16
|
+
async function repositoryUnavailableState(rootPath, options) {
|
|
17
|
+
if (await isGitRepository(rootPath))
|
|
18
|
+
return undefined;
|
|
19
|
+
return {
|
|
20
|
+
kind: 'unavailable',
|
|
21
|
+
report: unavailableReviewReport('Not a git repository - PR review requires git history.', options),
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
async function resolveReviewRefs(rootPath, options) {
|
|
25
|
+
const headRef = options.head ?? 'HEAD';
|
|
26
|
+
const baseRef = options.base ?? (await pickDefaultBase(rootPath));
|
|
27
|
+
return {
|
|
28
|
+
headRef,
|
|
29
|
+
baseRef,
|
|
30
|
+
headSha: await resolveSha(rootPath, headRef),
|
|
31
|
+
baseSha: await resolveSha(rootPath, baseRef),
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
function requireResolvedRefs(refs, options) {
|
|
35
|
+
if (!refs.baseSha) {
|
|
36
|
+
return {
|
|
37
|
+
kind: 'unavailable',
|
|
38
|
+
report: unavailableReviewReport(`Could not resolve base ref "${refs.baseRef}".`, options, refs.baseRef, refs.headRef, refs.headSha),
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
if (!refs.headSha) {
|
|
42
|
+
return {
|
|
43
|
+
kind: 'unavailable',
|
|
44
|
+
report: unavailableReviewReport(`Could not resolve head ref "${refs.headRef}".`, options, refs.baseRef, refs.headRef, null, refs.baseSha),
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
return {
|
|
48
|
+
kind: 'ready',
|
|
49
|
+
baseRef: refs.baseRef,
|
|
50
|
+
baseSha: refs.baseSha,
|
|
51
|
+
headRef: refs.headRef,
|
|
52
|
+
headSha: refs.headSha,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
async function noChangeReviewState(rootPath, refs) {
|
|
56
|
+
if (refs.headSha !== refs.baseSha)
|
|
57
|
+
return undefined;
|
|
58
|
+
if (!(await isWorktreeClean(rootPath)))
|
|
59
|
+
return undefined;
|
|
60
|
+
return {
|
|
61
|
+
kind: 'no-change',
|
|
62
|
+
report: buildNoChangeReviewReport({
|
|
63
|
+
baseRef: refs.baseRef,
|
|
64
|
+
baseSha: refs.baseSha,
|
|
65
|
+
headRef: refs.headRef,
|
|
66
|
+
headSha: refs.headSha,
|
|
67
|
+
}),
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
export function unavailableReviewReport(reason, options, baseRef = options.base ?? '', headRef = options.head ?? 'HEAD', headSha = null, baseSha = null) {
|
|
71
|
+
return {
|
|
72
|
+
available: false,
|
|
73
|
+
reason,
|
|
74
|
+
base: { ref: baseRef, resolvedSha: baseSha },
|
|
75
|
+
head: { ref: headRef, resolvedSha: headSha },
|
|
76
|
+
prDiff: {
|
|
77
|
+
available: false,
|
|
78
|
+
reason,
|
|
79
|
+
base: { ref: baseRef, resolvedSha: baseSha },
|
|
80
|
+
head: { ref: headRef, resolvedSha: headSha },
|
|
81
|
+
filesAdded: [],
|
|
82
|
+
filesRemoved: [],
|
|
83
|
+
filesModified: [],
|
|
84
|
+
totalFilesChanged: 0,
|
|
85
|
+
},
|
|
86
|
+
changedFiles: [],
|
|
87
|
+
newCycles: [],
|
|
88
|
+
riskyFunctions: [],
|
|
89
|
+
dependencyChanges: [],
|
|
90
|
+
newTaintFlows: [],
|
|
91
|
+
newDataflowRisks: [],
|
|
92
|
+
verdict: 'ok',
|
|
93
|
+
summary: [reason],
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=reviewState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewState.js","sourceRoot":"","sources":["../../src/core/reviewState.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { ReviewReport, ReviewTier } from '../types/review.js';
|
|
2
|
+
/**
|
|
3
|
+
* 1.5+ - pick a review tier based on the caller's token budget.
|
|
4
|
+
*
|
|
5
|
+
* <3000 -> 'verdict-only' (verdict + summary + totals)
|
|
6
|
+
* <7000 -> 'summary' (verdict + summary + top files / top cycles / etc.)
|
|
7
|
+
* else -> 'full' (everything)
|
|
8
|
+
*
|
|
9
|
+
* `0`, `undefined`, and any non-positive value all mean "no budget given"
|
|
10
|
+
* - the caller wants the full report. The tier names are stable.
|
|
11
|
+
*/
|
|
12
|
+
export declare function selectReviewTier(maxCostTokens: number | undefined): ReviewTier;
|
|
13
|
+
/**
|
|
14
|
+
* Reshape a full ReviewReport for the chosen tier. The caller passes a
|
|
15
|
+
* fully populated report from `computeReview`; this returns a plain object
|
|
16
|
+
* sized for the tier.
|
|
17
|
+
*/
|
|
18
|
+
export declare function shapeReviewForTier(report: ReviewReport, tier: ReviewTier): Record<string, unknown>;
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 1.5+ - pick a review tier based on the caller's token budget.
|
|
3
|
+
*
|
|
4
|
+
* <3000 -> 'verdict-only' (verdict + summary + totals)
|
|
5
|
+
* <7000 -> 'summary' (verdict + summary + top files / top cycles / etc.)
|
|
6
|
+
* else -> 'full' (everything)
|
|
7
|
+
*
|
|
8
|
+
* `0`, `undefined`, and any non-positive value all mean "no budget given"
|
|
9
|
+
* - the caller wants the full report. The tier names are stable.
|
|
10
|
+
*/
|
|
11
|
+
export function selectReviewTier(maxCostTokens) {
|
|
12
|
+
if (maxCostTokens === undefined)
|
|
13
|
+
return 'full';
|
|
14
|
+
if (hasInvalidReviewBudget(maxCostTokens))
|
|
15
|
+
return 'full';
|
|
16
|
+
if (maxCostTokens < 3000)
|
|
17
|
+
return 'verdict-only';
|
|
18
|
+
if (maxCostTokens < 7000)
|
|
19
|
+
return 'summary';
|
|
20
|
+
return 'full';
|
|
21
|
+
}
|
|
22
|
+
function hasInvalidReviewBudget(maxCostTokens) {
|
|
23
|
+
return !Number.isFinite(maxCostTokens) || maxCostTokens <= 0;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Reshape a full ReviewReport for the chosen tier. The caller passes a
|
|
27
|
+
* fully populated report from `computeReview`; this returns a plain object
|
|
28
|
+
* sized for the tier.
|
|
29
|
+
*/
|
|
30
|
+
export function shapeReviewForTier(report, tier) {
|
|
31
|
+
if (!report.available || tier === 'full') {
|
|
32
|
+
return { ...report, tier };
|
|
33
|
+
}
|
|
34
|
+
const totals = reviewTierTotals(report);
|
|
35
|
+
if (tier === 'verdict-only') {
|
|
36
|
+
return verdictOnlyReview(report, totals, tier);
|
|
37
|
+
}
|
|
38
|
+
return summaryReview(report, totals, tier);
|
|
39
|
+
}
|
|
40
|
+
function reviewTierTotals(report) {
|
|
41
|
+
return {
|
|
42
|
+
filesChanged: report.changedFiles.length,
|
|
43
|
+
cyclesAdded: report.newCycles.length,
|
|
44
|
+
riskyFunctionsAdded: report.riskyFunctions.length,
|
|
45
|
+
depsChanged: report.dependencyChanges.length,
|
|
46
|
+
taintFlowsAdded: report.newTaintFlows?.length ?? 0,
|
|
47
|
+
dataflowRisksAdded: report.newDataflowRisks?.length ?? 0,
|
|
48
|
+
contractChanges: report.contractChanges?.length ?? 0,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
function verdictOnlyReview(report, totals, tier) {
|
|
52
|
+
return {
|
|
53
|
+
available: report.available,
|
|
54
|
+
base: report.base,
|
|
55
|
+
head: report.head,
|
|
56
|
+
verdict: report.verdict,
|
|
57
|
+
summary: report.summary,
|
|
58
|
+
totals,
|
|
59
|
+
graphEvidence: report.graphEvidence,
|
|
60
|
+
tier,
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
function summaryReview(report, totals, tier) {
|
|
64
|
+
const top = 5;
|
|
65
|
+
return {
|
|
66
|
+
available: report.available,
|
|
67
|
+
base: report.base,
|
|
68
|
+
head: report.head,
|
|
69
|
+
prDiff: trimmedPrDiff(report, top),
|
|
70
|
+
changedFiles: report.changedFiles.slice(0, top),
|
|
71
|
+
newCycles: report.newCycles.slice(0, 3),
|
|
72
|
+
riskyFunctions: report.riskyFunctions.slice(0, 3),
|
|
73
|
+
dependencyChanges: report.dependencyChanges.slice(0, 3),
|
|
74
|
+
contractChanges: report.contractChanges?.slice(0, top) ?? [],
|
|
75
|
+
newTaintFlows: report.newTaintFlows?.slice(0, 5) ?? [],
|
|
76
|
+
newDataflowRisks: report.newDataflowRisks?.slice(0, 5) ?? [],
|
|
77
|
+
graphEvidence: report.graphEvidence,
|
|
78
|
+
verdict: report.verdict,
|
|
79
|
+
summary: report.summary,
|
|
80
|
+
totals,
|
|
81
|
+
tier,
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
function trimmedPrDiff(report, top) {
|
|
85
|
+
return {
|
|
86
|
+
available: report.prDiff.available,
|
|
87
|
+
base: report.prDiff.base,
|
|
88
|
+
head: report.prDiff.head,
|
|
89
|
+
totalFilesChanged: report.prDiff.totalFilesChanged,
|
|
90
|
+
filesAdded: report.prDiff.filesAdded.slice(0, top),
|
|
91
|
+
filesRemoved: report.prDiff.filesRemoved.slice(0, top),
|
|
92
|
+
filesModified: report.prDiff.filesModified.slice(0, top).map((file) => ({
|
|
93
|
+
relativePath: file.relativePath,
|
|
94
|
+
cyclomaticDelta: file.cyclomaticDelta,
|
|
95
|
+
fanInDelta: file.fanInDelta,
|
|
96
|
+
})),
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
//# sourceMappingURL=reviewTier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewTier.js","sourceRoot":"","sources":["../../src/core/reviewTier.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ReviewContractChange } from '../types/reviewContract.js';
|
|
2
|
+
import type { ReviewCycle, ReviewDataflowRisk, ReviewDependencyChange, ReviewFile, ReviewFunction, ReviewReport, ReviewTaintFlow } from '../types/review.js';
|
|
3
|
+
type ReviewVerdict = ReviewReport['verdict'];
|
|
4
|
+
interface VerdictDecision {
|
|
5
|
+
verdict: ReviewVerdict;
|
|
6
|
+
summary: string[];
|
|
7
|
+
}
|
|
8
|
+
export declare function decideVerdict(changedFiles: ReviewFile[], newCycles: ReviewCycle[], riskyFunctions: ReviewFunction[], depChanges: ReviewDependencyChange[], contractChanges: ReviewContractChange[], newTaintFlows: ReviewTaintFlow[], newDataflowRisks: ReviewDataflowRisk[]): VerdictDecision;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
const RISK_VERDICT_BLOCK_SCORE = 80;
|
|
2
|
+
const RISK_VERDICT_REVIEW_SCORE = 40;
|
|
3
|
+
export function decideVerdict(changedFiles, newCycles, riskyFunctions, depChanges, contractChanges, newTaintFlows, newDataflowRisks) {
|
|
4
|
+
const decision = { verdict: 'ok', summary: [] };
|
|
5
|
+
const maxRisk = maxChangedFileRisk(changedFiles);
|
|
6
|
+
applyRiskScoreSignal(decision, maxRisk);
|
|
7
|
+
applyCycleSignal(decision, newCycles);
|
|
8
|
+
applyRiskyFunctionSignal(decision, riskyFunctions);
|
|
9
|
+
applyTaintFlowSignal(decision, newTaintFlows);
|
|
10
|
+
applyDataflowRiskSignal(decision, newDataflowRisks);
|
|
11
|
+
appendDependencySummary(decision.summary, depChanges);
|
|
12
|
+
appendManualReleaseSignOff(decision, {
|
|
13
|
+
maxRisk,
|
|
14
|
+
newCycles,
|
|
15
|
+
riskyFunctions,
|
|
16
|
+
contractChanges,
|
|
17
|
+
newTaintFlows,
|
|
18
|
+
newDataflowRisks,
|
|
19
|
+
});
|
|
20
|
+
appendFallbackSummary(decision, changedFiles.length);
|
|
21
|
+
return decision;
|
|
22
|
+
}
|
|
23
|
+
function maxChangedFileRisk(changedFiles) {
|
|
24
|
+
return Math.max(0, ...changedFiles.map((file) => file.riskScore ?? 0));
|
|
25
|
+
}
|
|
26
|
+
function applyRiskScoreSignal(decision, maxRisk) {
|
|
27
|
+
if (maxRisk >= RISK_VERDICT_BLOCK_SCORE) {
|
|
28
|
+
decision.verdict = 'block';
|
|
29
|
+
decision.summary.push(`Maximum changed-file risk score is ${maxRisk.toFixed(1)} (>= ${RISK_VERDICT_BLOCK_SCORE}).`);
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
if (maxRisk >= RISK_VERDICT_REVIEW_SCORE) {
|
|
33
|
+
decision.verdict = bumpTo(decision.verdict, 'review');
|
|
34
|
+
decision.summary.push(`Maximum changed-file risk score is ${maxRisk.toFixed(1)} (>= ${RISK_VERDICT_REVIEW_SCORE}).`);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
function applyCycleSignal(decision, newCycles) {
|
|
38
|
+
if (newCycles.length === 0)
|
|
39
|
+
return;
|
|
40
|
+
const newOnly = newCycles.filter((cycle) => cycle.classification === 'new');
|
|
41
|
+
if (newOnly.length > 0) {
|
|
42
|
+
decision.verdict = 'block';
|
|
43
|
+
decision.summary.push(`${newOnly.length} new import cycle(s) introduced.`);
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
decision.verdict = bumpTo(decision.verdict, 'review');
|
|
47
|
+
decision.summary.push(`${newCycles.length} cycle(s) expanded.`);
|
|
48
|
+
}
|
|
49
|
+
function applyRiskyFunctionSignal(decision, riskyFunctions) {
|
|
50
|
+
if (riskyFunctions.length === 0)
|
|
51
|
+
return;
|
|
52
|
+
decision.verdict = bumpTo(decision.verdict, 'review');
|
|
53
|
+
decision.summary.push(`${riskyFunctions.length} function(s) flagged: high CC added or jumped.`);
|
|
54
|
+
}
|
|
55
|
+
function applyTaintFlowSignal(decision, newTaintFlows) {
|
|
56
|
+
if (newTaintFlows.length === 0)
|
|
57
|
+
return;
|
|
58
|
+
decision.verdict = 'block';
|
|
59
|
+
const sample = newTaintFlows
|
|
60
|
+
.slice(0, 3)
|
|
61
|
+
.map((flow) => `${flow.source}→${flow.sink} (${flow.sourceFn}${flow.pathLength > 1 ? '…' : ''})`)
|
|
62
|
+
.join(', ');
|
|
63
|
+
decision.summary.push(`${newTaintFlows.length} new taint flow(s) detected: ${sample}${newTaintFlows.length > 3 ? ', …' : ''}.`);
|
|
64
|
+
}
|
|
65
|
+
function applyDataflowRiskSignal(decision, newDataflowRisks) {
|
|
66
|
+
if (newDataflowRisks.length === 0)
|
|
67
|
+
return;
|
|
68
|
+
decision.verdict = 'block';
|
|
69
|
+
const sample = newDataflowRisks
|
|
70
|
+
.slice(0, 3)
|
|
71
|
+
.map((risk) => `${risk.source}→${risk.sink} (${risk.bridgeFn ?? risk.sourceFn})`)
|
|
72
|
+
.join(', ');
|
|
73
|
+
decision.summary.push(`${newDataflowRisks.length} new dataflow risk(s) detected: ${sample}${newDataflowRisks.length > 3 ? ', …' : ''}.`);
|
|
74
|
+
}
|
|
75
|
+
function appendDependencySummary(summary, depChanges) {
|
|
76
|
+
if (depChanges.length === 0)
|
|
77
|
+
return;
|
|
78
|
+
const totals = dependencyTotals(depChanges);
|
|
79
|
+
if (totals.added + totals.removed + totals.bumped === 0)
|
|
80
|
+
return;
|
|
81
|
+
summary.push(`Dependency changes: +${totals.added} -${totals.removed} ~${totals.bumped}.`);
|
|
82
|
+
}
|
|
83
|
+
function dependencyTotals(depChanges) {
|
|
84
|
+
return depChanges.reduce((acc, change) => {
|
|
85
|
+
acc.added += change.added.length;
|
|
86
|
+
acc.removed += change.removed.length;
|
|
87
|
+
acc.bumped += change.bumped.length;
|
|
88
|
+
return acc;
|
|
89
|
+
}, { added: 0, removed: 0, bumped: 0 });
|
|
90
|
+
}
|
|
91
|
+
function appendManualReleaseSignOff(decision, signals) {
|
|
92
|
+
if (!isManualReleaseSignOffBlock(decision.verdict, signals))
|
|
93
|
+
return;
|
|
94
|
+
decision.summary.push('Manual release sign-off required: review blocks on release-scale risk signals, not concrete cycle, risky-function, contract, taint, or dataflow defects.');
|
|
95
|
+
}
|
|
96
|
+
function isManualReleaseSignOffBlock(verdict, signals) {
|
|
97
|
+
const concreteSignals = [
|
|
98
|
+
signals.newCycles,
|
|
99
|
+
signals.riskyFunctions,
|
|
100
|
+
signals.contractChanges,
|
|
101
|
+
signals.newTaintFlows,
|
|
102
|
+
signals.newDataflowRisks,
|
|
103
|
+
];
|
|
104
|
+
return (verdict === 'block' &&
|
|
105
|
+
signals.maxRisk >= RISK_VERDICT_BLOCK_SCORE &&
|
|
106
|
+
concreteSignals.every((entries) => entries.length === 0));
|
|
107
|
+
}
|
|
108
|
+
function appendFallbackSummary(decision, changedFileCount) {
|
|
109
|
+
if (changedFileCount === 0 && decision.summary.length === 0) {
|
|
110
|
+
decision.summary.push('No structural changes detected between base and head.');
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
if (decision.verdict === 'ok' && decision.summary.length === 0) {
|
|
114
|
+
decision.summary.push(`${changedFileCount} file(s) changed; no risk signals.`);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
function bumpTo(current, target) {
|
|
118
|
+
const order = { ok: 0, review: 1, block: 2 };
|
|
119
|
+
return order[target] > order[current] ? target : current;
|
|
120
|
+
}
|
|
121
|
+
//# sourceMappingURL=reviewVerdict.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewVerdict.js","sourceRoot":"","sources":["../../src/core/reviewVerdict.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import type { FileEntry } from '../types.js';
|
|
2
2
|
import type { CodeGraph } from './codeGraph.js';
|
|
3
|
+
import { expandQuery, tokenize } from './searchIndexText.js';
|
|
4
|
+
export { expandQuery, tokenize };
|
|
3
5
|
export interface IndexedFile {
|
|
4
6
|
relativePath: string;
|
|
5
7
|
content: string[];
|
|
@@ -47,17 +49,3 @@ export declare function search(index: SearchIndex, query: string, options?: Sear
|
|
|
47
49
|
* the caller only wants paths (e.g., an agent filtering before fetching).
|
|
48
50
|
*/
|
|
49
51
|
export declare function attachExcerpts(rootPath: string, hits: SearchHit[], queryTokens: string[]): Promise<SearchHit[]>;
|
|
50
|
-
/**
|
|
51
|
-
* Tokenize a string for indexing/querying:
|
|
52
|
-
* - lowercase
|
|
53
|
-
* - split on non-identifier chars
|
|
54
|
-
* - split camelCase and snake_case
|
|
55
|
-
* - drop tokens shorter than 2 chars, stopwords, TS keywords
|
|
56
|
-
* - apply basic stem (drop trailing s / ing / ed)
|
|
57
|
-
*/
|
|
58
|
-
export declare function tokenize(input: string): string[];
|
|
59
|
-
/**
|
|
60
|
-
* Expand a user query into a set of candidate tokens. Same rules as tokenize
|
|
61
|
-
* plus: if the raw query has no hits, try progressively looser tokenization.
|
|
62
|
-
*/
|
|
63
|
-
export declare function expandQuery(query: string): string[];
|
package/dist/core/searchIndex.js
CHANGED
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
import fs from 'node:fs/promises';
|
|
2
2
|
import path from 'node:path';
|
|
3
|
+
import { isSearchIndexableFile } from './searchIndexFiles.js';
|
|
4
|
+
import { countHits, expandQuery, tokenize } from './searchIndexText.js';
|
|
3
5
|
import { mapWithConcurrency, DEFAULT_FILE_IO_CONCURRENCY } from '../utils/concurrency.js';
|
|
6
|
+
export { expandQuery, tokenize };
|
|
4
7
|
/**
|
|
5
8
|
* Lightweight BM25-ranked inverted index over source files.
|
|
6
9
|
*
|
|
@@ -16,138 +19,10 @@ import { mapWithConcurrency, DEFAULT_FILE_IO_CONCURRENCY } from '../utils/concur
|
|
|
16
19
|
* zero-dependency and fast enough for sub-second queries on 10k-file repos.
|
|
17
20
|
*/
|
|
18
21
|
const MAX_FILE_SIZE = 512 * 1024;
|
|
19
|
-
const STOPWORDS = new Set([
|
|
20
|
-
'the',
|
|
21
|
-
'a',
|
|
22
|
-
'an',
|
|
23
|
-
'and',
|
|
24
|
-
'or',
|
|
25
|
-
'not',
|
|
26
|
-
'of',
|
|
27
|
-
'to',
|
|
28
|
-
'in',
|
|
29
|
-
'is',
|
|
30
|
-
'it',
|
|
31
|
-
'for',
|
|
32
|
-
'on',
|
|
33
|
-
'with',
|
|
34
|
-
'this',
|
|
35
|
-
'that',
|
|
36
|
-
'by',
|
|
37
|
-
'as',
|
|
38
|
-
'at',
|
|
39
|
-
'be',
|
|
40
|
-
'are',
|
|
41
|
-
'was',
|
|
42
|
-
'were',
|
|
43
|
-
'has',
|
|
44
|
-
'have',
|
|
45
|
-
'had',
|
|
46
|
-
]);
|
|
47
|
-
const TS_KEYWORDS = new Set([
|
|
48
|
-
'const',
|
|
49
|
-
'let',
|
|
50
|
-
'var',
|
|
51
|
-
'function',
|
|
52
|
-
'return',
|
|
53
|
-
'if',
|
|
54
|
-
'else',
|
|
55
|
-
'while',
|
|
56
|
-
'for',
|
|
57
|
-
'do',
|
|
58
|
-
'break',
|
|
59
|
-
'continue',
|
|
60
|
-
'switch',
|
|
61
|
-
'case',
|
|
62
|
-
'default',
|
|
63
|
-
'new',
|
|
64
|
-
'class',
|
|
65
|
-
'extends',
|
|
66
|
-
'implements',
|
|
67
|
-
'interface',
|
|
68
|
-
'type',
|
|
69
|
-
'enum',
|
|
70
|
-
'public',
|
|
71
|
-
'private',
|
|
72
|
-
'protected',
|
|
73
|
-
'static',
|
|
74
|
-
'readonly',
|
|
75
|
-
'async',
|
|
76
|
-
'await',
|
|
77
|
-
'try',
|
|
78
|
-
'catch',
|
|
79
|
-
'finally',
|
|
80
|
-
'throw',
|
|
81
|
-
'import',
|
|
82
|
-
'export',
|
|
83
|
-
'from',
|
|
84
|
-
'as',
|
|
85
|
-
'typeof',
|
|
86
|
-
'instanceof',
|
|
87
|
-
'void',
|
|
88
|
-
'null',
|
|
89
|
-
'undefined',
|
|
90
|
-
'true',
|
|
91
|
-
'false',
|
|
92
|
-
'this',
|
|
93
|
-
'super',
|
|
94
|
-
'yield',
|
|
95
|
-
'delete',
|
|
96
|
-
'in',
|
|
97
|
-
'of',
|
|
98
|
-
'any',
|
|
99
|
-
'never',
|
|
100
|
-
'unknown',
|
|
101
|
-
'string',
|
|
102
|
-
'number',
|
|
103
|
-
'boolean',
|
|
104
|
-
'object',
|
|
105
|
-
'symbol',
|
|
106
|
-
'bigint',
|
|
107
|
-
]);
|
|
108
|
-
const PY_KEYWORDS = new Set([
|
|
109
|
-
'def',
|
|
110
|
-
'class',
|
|
111
|
-
'self',
|
|
112
|
-
'cls',
|
|
113
|
-
'lambda',
|
|
114
|
-
'yield',
|
|
115
|
-
'pass',
|
|
116
|
-
'elif',
|
|
117
|
-
'none',
|
|
118
|
-
'true',
|
|
119
|
-
'false',
|
|
120
|
-
'and',
|
|
121
|
-
'or',
|
|
122
|
-
'not',
|
|
123
|
-
'is',
|
|
124
|
-
'in',
|
|
125
|
-
'import',
|
|
126
|
-
'from',
|
|
127
|
-
'as',
|
|
128
|
-
'with',
|
|
129
|
-
'try',
|
|
130
|
-
'except',
|
|
131
|
-
'finally',
|
|
132
|
-
'raise',
|
|
133
|
-
'assert',
|
|
134
|
-
'global',
|
|
135
|
-
'nonlocal',
|
|
136
|
-
'del',
|
|
137
|
-
'async',
|
|
138
|
-
'await',
|
|
139
|
-
'return',
|
|
140
|
-
'if',
|
|
141
|
-
'else',
|
|
142
|
-
'for',
|
|
143
|
-
'while',
|
|
144
|
-
'break',
|
|
145
|
-
'continue',
|
|
146
|
-
]);
|
|
147
22
|
export async function buildSearchIndex(rootPath, files, graph) {
|
|
148
23
|
const indexed = new Map();
|
|
149
24
|
const postings = new Map();
|
|
150
|
-
const parseable = files.filter((f) => f.sizeBytes <= MAX_FILE_SIZE &&
|
|
25
|
+
const parseable = files.filter((f) => f.sizeBytes <= MAX_FILE_SIZE && isSearchIndexableFile(f.relativePath));
|
|
151
26
|
// Bounded concurrency on file reads — avoids tripping the OS open-files
|
|
152
27
|
// ulimit on large repos. See utils/concurrency.ts for the rationale.
|
|
153
28
|
await mapWithConcurrency(parseable, DEFAULT_FILE_IO_CONCURRENCY, async (file) => {
|
|
@@ -286,102 +161,4 @@ export async function attachExcerpts(rootPath, hits, queryTokens) {
|
|
|
286
161
|
return hit;
|
|
287
162
|
});
|
|
288
163
|
}
|
|
289
|
-
/**
|
|
290
|
-
* Tokenize a string for indexing/querying:
|
|
291
|
-
* - lowercase
|
|
292
|
-
* - split on non-identifier chars
|
|
293
|
-
* - split camelCase and snake_case
|
|
294
|
-
* - drop tokens shorter than 2 chars, stopwords, TS keywords
|
|
295
|
-
* - apply basic stem (drop trailing s / ing / ed)
|
|
296
|
-
*/
|
|
297
|
-
export function tokenize(input) {
|
|
298
|
-
const out = [];
|
|
299
|
-
// Split on non-identifier boundaries. Keep original case so we can also
|
|
300
|
-
// split on camelCase boundaries below.
|
|
301
|
-
const rawTokens = input.match(/[A-Za-z0-9_]+/g) ?? [];
|
|
302
|
-
for (const raw of rawTokens) {
|
|
303
|
-
// Split on underscore and camelCase. camelCase: insert a boundary before
|
|
304
|
-
// each uppercase that follows a lowercase or digit (OR before runs of
|
|
305
|
-
// uppercase followed by lowercase to handle acronyms like "XMLParser").
|
|
306
|
-
const camelSplit = raw
|
|
307
|
-
.replace(/([a-z0-9])([A-Z])/g, '$1 $2')
|
|
308
|
-
.replace(/([A-Z]+)([A-Z][a-z])/g, '$1 $2');
|
|
309
|
-
const parts = camelSplit.split(/[_\s]+/).filter(Boolean);
|
|
310
|
-
for (const part of parts) {
|
|
311
|
-
// Split embedded digits from letters - e.g. "v1api" → "v", "1", "api"
|
|
312
|
-
const subparts = part.split(/(\d+)/).filter(Boolean);
|
|
313
|
-
for (const sp of subparts) {
|
|
314
|
-
const lower = sp.toLowerCase();
|
|
315
|
-
const stemmed = stem(lower);
|
|
316
|
-
if (!keepToken(stemmed))
|
|
317
|
-
continue;
|
|
318
|
-
out.push(stemmed);
|
|
319
|
-
}
|
|
320
|
-
}
|
|
321
|
-
}
|
|
322
|
-
return out;
|
|
323
|
-
}
|
|
324
|
-
/**
|
|
325
|
-
* Expand a user query into a set of candidate tokens. Same rules as tokenize
|
|
326
|
-
* plus: if the raw query has no hits, try progressively looser tokenization.
|
|
327
|
-
*/
|
|
328
|
-
export function expandQuery(query) {
|
|
329
|
-
const tokens = tokenize(query);
|
|
330
|
-
return [...new Set(tokens)];
|
|
331
|
-
}
|
|
332
|
-
function stem(token) {
|
|
333
|
-
if (token.length <= 3)
|
|
334
|
-
return token;
|
|
335
|
-
if (token.endsWith('ing'))
|
|
336
|
-
return token.slice(0, -3);
|
|
337
|
-
if (token.endsWith('ed') && token.length > 4)
|
|
338
|
-
return token.slice(0, -2);
|
|
339
|
-
if (token.endsWith('es') && token.length > 4)
|
|
340
|
-
return token.slice(0, -2);
|
|
341
|
-
if (token.endsWith('s') && !token.endsWith('ss'))
|
|
342
|
-
return token.slice(0, -1);
|
|
343
|
-
return token;
|
|
344
|
-
}
|
|
345
|
-
function keepToken(token) {
|
|
346
|
-
if (token.length < 2)
|
|
347
|
-
return false;
|
|
348
|
-
if (STOPWORDS.has(token))
|
|
349
|
-
return false;
|
|
350
|
-
if (TS_KEYWORDS.has(token))
|
|
351
|
-
return false;
|
|
352
|
-
if (PY_KEYWORDS.has(token))
|
|
353
|
-
return false;
|
|
354
|
-
return true;
|
|
355
|
-
}
|
|
356
|
-
function countHits(tokens, query) {
|
|
357
|
-
let count = 0;
|
|
358
|
-
const set = new Set(tokens);
|
|
359
|
-
for (const q of query)
|
|
360
|
-
if (set.has(q))
|
|
361
|
-
count++;
|
|
362
|
-
return count;
|
|
363
|
-
}
|
|
364
|
-
function isIndexable(relativePath) {
|
|
365
|
-
const ext = path.extname(relativePath).toLowerCase();
|
|
366
|
-
// Index source and markup/docs where it's likely useful
|
|
367
|
-
return (ext === '.ts' ||
|
|
368
|
-
ext === '.tsx' ||
|
|
369
|
-
ext === '.js' ||
|
|
370
|
-
ext === '.jsx' ||
|
|
371
|
-
ext === '.mjs' ||
|
|
372
|
-
ext === '.cjs' ||
|
|
373
|
-
ext === '.mts' ||
|
|
374
|
-
ext === '.cts' ||
|
|
375
|
-
ext === '.py' ||
|
|
376
|
-
ext === '.go' ||
|
|
377
|
-
ext === '.rb' ||
|
|
378
|
-
ext === '.java' ||
|
|
379
|
-
ext === '.rs' ||
|
|
380
|
-
ext === '.php' ||
|
|
381
|
-
ext === '.cs' ||
|
|
382
|
-
ext === '.swift' ||
|
|
383
|
-
ext === '.kt' ||
|
|
384
|
-
ext === '.md' ||
|
|
385
|
-
ext === '.mdx');
|
|
386
|
-
}
|
|
387
164
|
//# sourceMappingURL=searchIndex.js.map
|