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
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"consoleReporter.js","sourceRoot":"","sources":["../../src/reporters/consoleReporter.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"consoleReporter.js","sourceRoot":"","sources":["../../src/reporters/consoleReporter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AACjF,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACvF,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAE1D,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { calculateScore } from '../utils/scoreCalculator.js';
|
|
2
|
+
import { escapeHtml, htmlShell, reportControlsHtml, severityIcon } from './htmlShared.js';
|
|
3
|
+
export function reportAnalysisHtml(report, reportControls) {
|
|
4
|
+
console.log(htmlShell(`Analysis · ${report.projectName}`, analysisBodyHtml(report, reportControls)));
|
|
5
|
+
}
|
|
6
|
+
function analysisBodyHtml(report, reportControls) {
|
|
7
|
+
const { score, grade, errors, warnings, infos } = calculateScore(report.issues);
|
|
8
|
+
return `
|
|
9
|
+
<h1>Project analysis: ${escapeHtml(report.projectName)}</h1>
|
|
10
|
+
${reportControlsHtml(reportControls)}
|
|
11
|
+
<div class="card">
|
|
12
|
+
<div class="score grade-${grade.replace('+', '\\+')}">${grade}</div>
|
|
13
|
+
<div>${score} / 100 · <span class="severity-error">${errors}</span> errors · <span class="severity-warning">${warnings}</span> warnings · <span class="severity-info">${infos}</span> info</div>
|
|
14
|
+
<p class="muted" style="margin-bottom: 0;">${escapeHtml(report.scan.totalFiles.toString())} file(s) · ${escapeHtml(report.scan.totalDirectories.toString())} directories · ${Math.round(report.scan.scanDurationMs)}ms scan</p>
|
|
15
|
+
</div>
|
|
16
|
+
${projectMetadataHtml(report)}
|
|
17
|
+
${languagesTableHtml(report)}
|
|
18
|
+
${issuesTableHtml(report)}
|
|
19
|
+
${filesTableHtml(report)}
|
|
20
|
+
`;
|
|
21
|
+
}
|
|
22
|
+
function projectMetadataHtml(report) {
|
|
23
|
+
const frameworkNames = report.frameworks.frameworks.map((f) => f.name);
|
|
24
|
+
const buildTools = report.frameworks.buildTools;
|
|
25
|
+
return `<div class="card">
|
|
26
|
+
<p><strong>Primary language:</strong> ${escapeHtml(report.languages.primary)}</p>
|
|
27
|
+
<p><strong>Frameworks:</strong> ${frameworkNames.length > 0 ? frameworkNames.map(escapeHtml).join(', ') : '<span class="muted">none detected</span>'}</p>
|
|
28
|
+
<p><strong>Build tools:</strong> ${buildTools.length > 0 ? buildTools.map(escapeHtml).join(', ') : '<span class="muted">none detected</span>'}</p>
|
|
29
|
+
<p><strong>Package manager:</strong> ${escapeHtml(report.frameworks.packageManager)}</p>
|
|
30
|
+
<p><strong>Dependencies:</strong> ${escapeHtml(dependencySummary(report))}</p>
|
|
31
|
+
</div>`;
|
|
32
|
+
}
|
|
33
|
+
function dependencySummary(report) {
|
|
34
|
+
return report.dependencies
|
|
35
|
+
? `${report.dependencies.totalDependencies} production · ${report.dependencies.totalDevDependencies} development`
|
|
36
|
+
: 'No package manifest detected';
|
|
37
|
+
}
|
|
38
|
+
function languagesTableHtml(report) {
|
|
39
|
+
return `<h2>Languages</h2>
|
|
40
|
+
<table>
|
|
41
|
+
<thead><tr><th>Language</th><th class="right">Files</th><th class="right">Share</th><th>Extensions</th></tr></thead>
|
|
42
|
+
<tbody>${languageRowsHtml(report)}</tbody>
|
|
43
|
+
</table>`;
|
|
44
|
+
}
|
|
45
|
+
function languageRowsHtml(report) {
|
|
46
|
+
const rows = Object.values(report.languages.languages)
|
|
47
|
+
.sort((a, b) => b.fileCount - a.fileCount)
|
|
48
|
+
.map((lang) => `<tr>
|
|
49
|
+
<td>${escapeHtml(lang.name)}</td>
|
|
50
|
+
<td class="right">${lang.fileCount}</td>
|
|
51
|
+
<td class="right">${lang.percentage.toFixed(1)}%</td>
|
|
52
|
+
<td class="muted">${lang.extensions.map((ext) => `<code>${escapeHtml(ext)}</code>`).join(' ')}</td>
|
|
53
|
+
</tr>`)
|
|
54
|
+
.join('\n');
|
|
55
|
+
return rows || '<tr><td colspan="4" class="muted">No source files detected.</td></tr>';
|
|
56
|
+
}
|
|
57
|
+
function issuesTableHtml(report) {
|
|
58
|
+
return `<h2>Issues (${report.issues.length})</h2>
|
|
59
|
+
<table>
|
|
60
|
+
<thead><tr><th>Severity</th><th>Issue</th><th>Description</th><th>Location</th></tr></thead>
|
|
61
|
+
<tbody>${issueRowsHtml(report)}</tbody>
|
|
62
|
+
</table>
|
|
63
|
+
${report.issues.length > 100 ? `<p class="muted">… and ${report.issues.length - 100} more issue(s)</p>` : ''}`;
|
|
64
|
+
}
|
|
65
|
+
function issueRowsHtml(report) {
|
|
66
|
+
if (report.issues.length === 0)
|
|
67
|
+
return '<tr><td colspan="4" class="muted">No issues detected.</td></tr>';
|
|
68
|
+
return report.issues
|
|
69
|
+
.slice(0, 100)
|
|
70
|
+
.map((issue) => `<tr>
|
|
71
|
+
<td class="severity-${issue.severity}">${severityIcon(issue.severity)} ${issue.severity}</td>
|
|
72
|
+
<td><code>${escapeHtml(issue.id)}</code><br>${escapeHtml(issue.title)}</td>
|
|
73
|
+
<td class="muted">${escapeHtml(issue.description)}</td>
|
|
74
|
+
<td>${issue.locations?.map((loc) => `<code>${escapeHtml(loc.file)}${loc.line ? `:${loc.line}` : ''}</code>`).join('<br>') ?? '<span class="muted">—</span>'}</td>
|
|
75
|
+
</tr>`)
|
|
76
|
+
.join('\n');
|
|
77
|
+
}
|
|
78
|
+
function filesTableHtml(report) {
|
|
79
|
+
return `<h2>Files (${report.scan.totalFiles})</h2>
|
|
80
|
+
<table>
|
|
81
|
+
<thead><tr><th>File</th><th>Extension</th><th class="right">Bytes</th><th>Directory</th></tr></thead>
|
|
82
|
+
<tbody>${fileRowsHtml(report)}</tbody>
|
|
83
|
+
</table>
|
|
84
|
+
${report.scan.files.length > 100 ? `<p class="muted">… and ${report.scan.files.length - 100} more file(s)</p>` : ''}`;
|
|
85
|
+
}
|
|
86
|
+
function fileRowsHtml(report) {
|
|
87
|
+
const rows = report.scan.files
|
|
88
|
+
.slice(0, 100)
|
|
89
|
+
.map((file) => `<tr>
|
|
90
|
+
<td><code>${escapeHtml(file.relativePath)}</code></td>
|
|
91
|
+
<td>${escapeHtml(file.extension || '(none)')}</td>
|
|
92
|
+
<td class="right">${file.sizeBytes}</td>
|
|
93
|
+
<td class="muted">${escapeHtml(file.directory || '.')}</td>
|
|
94
|
+
</tr>`)
|
|
95
|
+
.join('\n');
|
|
96
|
+
return rows || '<tr><td colspan="4" class="muted">No files detected.</td></tr>';
|
|
97
|
+
}
|
|
98
|
+
//# sourceMappingURL=htmlAnalysisReporter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"htmlAnalysisReporter.js","sourceRoot":"","sources":["../../src/reporters/htmlAnalysisReporter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { escapeHtml, htmlShell } from './htmlShared.js';
|
|
2
|
+
export function reportCoverageHtml(report) {
|
|
3
|
+
if (!report.available) {
|
|
4
|
+
console.log(unavailableCoverageHtml(report));
|
|
5
|
+
return;
|
|
6
|
+
}
|
|
7
|
+
console.log(htmlShell('Coverage × Risk', coverageBodyHtml(report)));
|
|
8
|
+
}
|
|
9
|
+
function unavailableCoverageHtml(report) {
|
|
10
|
+
return htmlShell('Coverage — unavailable', `<h1>Coverage × Risk</h1><p class="muted">${escapeHtml(report.reason ?? 'Coverage unavailable.')}</p>`);
|
|
11
|
+
}
|
|
12
|
+
function coverageBodyHtml(report) {
|
|
13
|
+
const sourceLabel = report.coverageSource ?? 'no coverage source';
|
|
14
|
+
const sourceFile = report.coverageSourceFile
|
|
15
|
+
? ` (<code>${escapeHtml(report.coverageSourceFile)}</code>)`
|
|
16
|
+
: '';
|
|
17
|
+
return `
|
|
18
|
+
<h1>Coverage × Risk</h1>
|
|
19
|
+
<p class="muted">Source: ${escapeHtml(sourceLabel)}${sourceFile} · ${report.entries.length} file(s) ranked.</p>
|
|
20
|
+
<p>Rows highlighted in red have <strong>coverage < 50%</strong> AND <strong>risk score > 50</strong> — the "scariest untested files" combination. The Priority column blends risk and uncovered fraction; rows are sorted by it.</p>
|
|
21
|
+
<table>
|
|
22
|
+
<thead><tr><th>#</th><th>File</th><th class="right">Risk</th><th class="right">Coverage</th><th class="right">Priority</th><th class="right">Lines</th><th>Reasons</th></tr></thead>
|
|
23
|
+
<tbody>${coverageRowsHtml(report)}</tbody>
|
|
24
|
+
</table>
|
|
25
|
+
${report.entries.length > 100 ? `<p class="muted">… and ${report.entries.length - 100} more</p>` : ''}
|
|
26
|
+
`;
|
|
27
|
+
}
|
|
28
|
+
function coverageRowsHtml(report) {
|
|
29
|
+
return report.entries
|
|
30
|
+
.slice(0, 100)
|
|
31
|
+
.map((h, i) => {
|
|
32
|
+
const covPct = coverageLabel(h.coverage);
|
|
33
|
+
const cls = riskyCoverageRowClass(h.coverage, h.riskScore);
|
|
34
|
+
return `<tr${cls}>
|
|
35
|
+
<td class="right">${i + 1}</td>
|
|
36
|
+
<td><code>${escapeHtml(h.relativePath)}</code></td>
|
|
37
|
+
<td class="right">${h.riskScore.toFixed(1)}</td>
|
|
38
|
+
<td class="right">${covPct}</td>
|
|
39
|
+
<td class="right">${h.priority.toFixed(1)}</td>
|
|
40
|
+
<td class="right">${h.lineCount}</td>
|
|
41
|
+
<td class="muted">${escapeHtml(h.reasons.join(', '))}</td>
|
|
42
|
+
</tr>`;
|
|
43
|
+
})
|
|
44
|
+
.join('\n');
|
|
45
|
+
}
|
|
46
|
+
function coverageLabel(coverage) {
|
|
47
|
+
return coverage === null ? '-' : `${Math.round(coverage * 100)}%`;
|
|
48
|
+
}
|
|
49
|
+
function riskyCoverageRowClass(coverage, riskScore) {
|
|
50
|
+
return coverage !== null && coverage < 0.5 && riskScore > 50 ? ' class="severity-error"' : '';
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=htmlCoverageReporter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"htmlCoverageReporter.js","sourceRoot":"","sources":["../../src/reporters/htmlCoverageReporter.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAExD,MAAM,UAAU,kBAAkB,CAAC,MAA4B;IAC7D,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAC,CAAC;QAC7C,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,iBAAiB,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;AACtE,CAAC;AAED,SAAS,uBAAuB,CAAC,MAA4B;IAC3D,OAAO,SAAS,CACd,wBAAwB,EACxB,4CAA4C,UAAU,CAAC,MAAM,CAAC,MAAM,IAAI,uBAAuB,CAAC,MAAM,CACvG,CAAC;AACJ,CAAC;AAED,SAAS,gBAAgB,CAAC,MAA4B;IACpD,MAAM,WAAW,GAAG,MAAM,CAAC,cAAc,IAAI,oBAAoB,CAAC;IAClE,MAAM,UAAU,GAAG,MAAM,CAAC,kBAAkB;QAC1C,CAAC,CAAC,WAAW,UAAU,CAAC,MAAM,CAAC,kBAAkB,CAAC,UAAU;QAC5D,CAAC,CAAC,EAAE,CAAC;IACP,OAAO;;2BAEkB,UAAU,CAAC,WAAW,CAAC,GAAG,UAAU,MAAM,MAAM,CAAC,OAAO,CAAC,MAAM;;;;SAIjF,gBAAgB,CAAC,MAAM,CAAC;;EAE/B,MAAM,CAAC,OAAO,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,0BAA0B,MAAM,CAAC,OAAO,CAAC,MAAM,GAAG,GAAG,WAAW,CAAC,CAAC,CAAC,EAAE;CACpG,CAAC;AACF,CAAC;AAED,SAAS,gBAAgB,CAAC,MAA4B;IACpD,OAAO,MAAM,CAAC,OAAO;SAClB,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC;SACb,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACZ,MAAM,MAAM,GAAG,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;QACzC,MAAM,GAAG,GAAG,qBAAqB,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC;QAC3D,OAAO,MAAM,GAAG;oBACF,CAAC,GAAG,CAAC;YACb,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC;oBAClB,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;oBACtB,MAAM;oBACN,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;oBACrB,CAAC,CAAC,SAAS;oBACX,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;MAC9C,CAAC;IACH,CAAC,CAAC;SACD,IAAI,CAAC,IAAI,CAAC,CAAC;AAChB,CAAC;AAED,SAAS,aAAa,CAAC,QAAuB;IAC5C,OAAO,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,CAAC,GAAG,CAAC;AACpE,CAAC;AAED,SAAS,qBAAqB,CAAC,QAAuB,EAAE,SAAiB;IACvE,OAAO,QAAQ,KAAK,IAAI,IAAI,QAAQ,GAAG,GAAG,IAAI,SAAS,GAAG,EAAE,CAAC,CAAC,CAAC,yBAAyB,CAAC,CAAC,CAAC,EAAE,CAAC;AAChG,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { escapeHtml, htmlShell } from './htmlShared.js';
|
|
2
|
+
export function reportImpactHtml(report) {
|
|
3
|
+
if (!report.available) {
|
|
4
|
+
console.log(unavailableImpactHtml(report));
|
|
5
|
+
return;
|
|
6
|
+
}
|
|
7
|
+
console.log(htmlShell(`Impact: ${report.target.value}`, impactBodyHtml(report)));
|
|
8
|
+
}
|
|
9
|
+
function unavailableImpactHtml(report) {
|
|
10
|
+
return htmlShell('Impact — unavailable', `<h1>Impact</h1><p class="muted">${escapeHtml(report.reason ?? 'Impact unavailable.')}</p>`);
|
|
11
|
+
}
|
|
12
|
+
function impactBodyHtml(report) {
|
|
13
|
+
return `
|
|
14
|
+
<h1>Impact: ${escapeHtml(report.target.kind)} <code>${escapeHtml(report.target.value)}</code></h1>
|
|
15
|
+
<p class="muted">${report.totalReachable} file(s) reachable within distance ${report.maxDistance}${report.truncated ? ' (truncated; more files exist beyond)' : ''}.</p>
|
|
16
|
+
${definitionFilesHtml(report)}
|
|
17
|
+
<h2>Reachable</h2>
|
|
18
|
+
${reachableFilesHtml(report)}
|
|
19
|
+
`;
|
|
20
|
+
}
|
|
21
|
+
function definitionFilesHtml(report) {
|
|
22
|
+
return report.definitionFiles.length === 0
|
|
23
|
+
? ''
|
|
24
|
+
: `<h2>Defined in</h2><ul>${report.definitionFiles.map((f) => `<li><code>${escapeHtml(f)}</code></li>`).join('\n')}</ul>`;
|
|
25
|
+
}
|
|
26
|
+
function reachableFilesHtml(report) {
|
|
27
|
+
if (report.reachable.length === 0) {
|
|
28
|
+
return '<p class="muted">No reachable files.</p>';
|
|
29
|
+
}
|
|
30
|
+
return `<table>
|
|
31
|
+
<thead><tr><th class="right">Distance</th><th>File</th></tr></thead>
|
|
32
|
+
<tbody>${reachableRowsHtml(report)}</tbody>
|
|
33
|
+
</table>`;
|
|
34
|
+
}
|
|
35
|
+
function reachableRowsHtml(report) {
|
|
36
|
+
return report.reachable
|
|
37
|
+
.slice(0, 200)
|
|
38
|
+
.map((n) => `<tr><td class="right">${n.distance}</td><td><code>${escapeHtml(n.file)}</code></td></tr>`)
|
|
39
|
+
.join('\n');
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=htmlImpactReporter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"htmlImpactReporter.js","sourceRoot":"","sources":["../../src/reporters/htmlImpactReporter.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAExD,MAAM,UAAU,gBAAgB,CAAC,MAAoB;IACnD,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC,CAAC;QAC3C,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;AACnF,CAAC;AAED,SAAS,qBAAqB,CAAC,MAAoB;IACjD,OAAO,SAAS,CACd,sBAAsB,EACtB,mCAAmC,UAAU,CAAC,MAAM,CAAC,MAAM,IAAI,qBAAqB,CAAC,MAAM,CAC5F,CAAC;AACJ,CAAC;AAED,SAAS,cAAc,CAAC,MAAoB;IAC1C,OAAO;cACK,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC;mBAClE,MAAM,CAAC,cAAc,sCAAsC,MAAM,CAAC,WAAW,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,uCAAuC,CAAC,CAAC,CAAC,EAAE;EAChK,mBAAmB,CAAC,MAAM,CAAC;;EAE3B,kBAAkB,CAAC,MAAM,CAAC;CAC3B,CAAC;AACF,CAAC;AAED,SAAS,mBAAmB,CAAC,MAAoB;IAC/C,OAAO,MAAM,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC;QACxC,CAAC,CAAC,EAAE;QACJ,CAAC,CAAC,0BAA0B,MAAM,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,aAAa,UAAU,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;AAC9H,CAAC;AAED,SAAS,kBAAkB,CAAC,MAAoB;IAC9C,IAAI,MAAM,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAClC,OAAO,0CAA0C,CAAC;IACpD,CAAC;IAED,OAAO;;SAEA,iBAAiB,CAAC,MAAM,CAAC;SACzB,CAAC;AACV,CAAC;AAED,SAAS,iBAAiB,CAAC,MAAoB;IAC7C,OAAO,MAAM,CAAC,SAAS;SACpB,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC;SACb,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,yBAAyB,CAAC,CAAC,QAAQ,kBAAkB,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC;SACtG,IAAI,CAAC,IAAI,CAAC,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { escapeHtml, htmlShell, signed } from './htmlShared.js';
|
|
2
|
+
export function reportPrDiffHtml(report) {
|
|
3
|
+
if (!report.available) {
|
|
4
|
+
console.log(unavailablePrDiffHtml(report));
|
|
5
|
+
return;
|
|
6
|
+
}
|
|
7
|
+
console.log(htmlShell('PR Structural Diff', prDiffBodyHtml(report)));
|
|
8
|
+
}
|
|
9
|
+
function unavailablePrDiffHtml(report) {
|
|
10
|
+
return htmlShell('PR Diff — unavailable', `<h1>PR Structural Diff</h1><p class="muted">${escapeHtml(report.reason ?? 'PR diff unavailable.')}</p>`);
|
|
11
|
+
}
|
|
12
|
+
function prDiffBodyHtml(report) {
|
|
13
|
+
return `
|
|
14
|
+
<h1>PR Structural Diff</h1>
|
|
15
|
+
<p class="muted">base <code>${escapeHtml(report.base.ref)}</code> (${report.base.resolvedSha?.slice(0, 7) ?? '?'}) → head <code>${escapeHtml(report.head.ref)}</code> (${report.head.resolvedSha?.slice(0, 7) ?? '?'})</p>
|
|
16
|
+
<p><strong>${report.totalFilesChanged}</strong> file(s) changed: <span class="severity-info">+${report.filesAdded.length}</span> added, <span class="severity-error">−${report.filesRemoved.length}</span> removed, <span class="severity-warning">~${report.filesModified.length}</span> modified.</p>
|
|
17
|
+
${addedFilesHtml(report)}
|
|
18
|
+
${removedFilesHtml(report)}
|
|
19
|
+
${modifiedFilesHtml(report)}
|
|
20
|
+
`;
|
|
21
|
+
}
|
|
22
|
+
function addedFilesHtml(report) {
|
|
23
|
+
if (report.filesAdded.length === 0)
|
|
24
|
+
return '';
|
|
25
|
+
return `<h2>Added (${report.filesAdded.length})</h2>
|
|
26
|
+
<ul>${report.filesAdded.map((f) => `<li><code>${escapeHtml(f)}</code></li>`).join('\n')}</ul>`;
|
|
27
|
+
}
|
|
28
|
+
function removedFilesHtml(report) {
|
|
29
|
+
if (report.filesRemoved.length === 0)
|
|
30
|
+
return '';
|
|
31
|
+
return `<h2>Removed (${report.filesRemoved.length})</h2>
|
|
32
|
+
<ul>${report.filesRemoved.map((f) => `<li><code>${escapeHtml(f)}</code></li>`).join('\n')}</ul>`;
|
|
33
|
+
}
|
|
34
|
+
function modifiedFilesHtml(report) {
|
|
35
|
+
if (report.filesModified.length === 0)
|
|
36
|
+
return '';
|
|
37
|
+
return `<h2>Modified (${report.filesModified.length})</h2>
|
|
38
|
+
${report.filesModified.slice(0, 100).map(modifiedFileHtml).join('\n')}
|
|
39
|
+
${modifiedOverflowHtml(report)}`;
|
|
40
|
+
}
|
|
41
|
+
function modifiedFileHtml(file) {
|
|
42
|
+
return `<h3><code>${escapeHtml(file.relativePath)}</code><span class="muted">${modifiedDeltas(file)}</span></h3>
|
|
43
|
+
${modifiedStructuralLinesHtml(file)}`;
|
|
44
|
+
}
|
|
45
|
+
function modifiedDeltas(file) {
|
|
46
|
+
const dCC = file.cyclomaticDelta === null ? '' : ` · ΔCC ${signed(file.cyclomaticDelta)}`;
|
|
47
|
+
const dFI = file.fanInDelta === null || file.fanInDelta === 0
|
|
48
|
+
? ''
|
|
49
|
+
: ` · Δfan-in ${signed(file.fanInDelta)}`;
|
|
50
|
+
return `${dCC}${dFI}`;
|
|
51
|
+
}
|
|
52
|
+
function modifiedStructuralLinesHtml(file) {
|
|
53
|
+
const lines = [
|
|
54
|
+
...symbolListLine('+exports', 'severity-info', file.exportsAdded),
|
|
55
|
+
...symbolListLine('−exports', 'severity-error', file.exportsRemoved),
|
|
56
|
+
...renamedExportLine(file.exportsRenamed),
|
|
57
|
+
...symbolListLine('+imports', 'severity-info', file.importsAdded),
|
|
58
|
+
...symbolListLine('−imports', 'severity-error', file.importsRemoved),
|
|
59
|
+
];
|
|
60
|
+
return lines.length === 0
|
|
61
|
+
? '<p class="muted">No structural change beyond CC / fan-in.</p>'
|
|
62
|
+
: `<ul>${lines.join('\n')}</ul>`;
|
|
63
|
+
}
|
|
64
|
+
function symbolListLine(label, severityClass, symbols) {
|
|
65
|
+
if (symbols.length === 0)
|
|
66
|
+
return [];
|
|
67
|
+
return [
|
|
68
|
+
`<li><strong class="${severityClass}">${label}:</strong> ${symbols.map((s) => `<code>${escapeHtml(s)}</code>`).join(', ')}</li>`,
|
|
69
|
+
];
|
|
70
|
+
}
|
|
71
|
+
function renamedExportLine(exportsRenamed) {
|
|
72
|
+
if (exportsRenamed.length === 0)
|
|
73
|
+
return [];
|
|
74
|
+
const pairs = exportsRenamed
|
|
75
|
+
.map((r) => `<code>${escapeHtml(r.from)}</code> → <code>${escapeHtml(r.to)}</code>`)
|
|
76
|
+
.join(', ');
|
|
77
|
+
return [`<li><strong class="severity-warning">~exports:</strong> ${pairs}</li>`];
|
|
78
|
+
}
|
|
79
|
+
function modifiedOverflowHtml(report) {
|
|
80
|
+
return report.filesModified.length > 100
|
|
81
|
+
? `<p class="muted">… and ${report.filesModified.length - 100} more</p>`
|
|
82
|
+
: '';
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=htmlPrDiffReporter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"htmlPrDiffReporter.js","sourceRoot":"","sources":["../../src/reporters/htmlPrDiffReporter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,24 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
import type { ReviewReport } from '../types/review.js';
|
|
1
|
+
import type { CouplingReport, HotspotReport, Issue } from '../types.js';
|
|
3
2
|
import type { ReportControlsMetadata } from '../core/reportScope.js';
|
|
4
|
-
|
|
5
|
-
export
|
|
6
|
-
export
|
|
3
|
+
export { htmlShell } from './htmlShared.js';
|
|
4
|
+
export { reportAnalysisHtml } from './htmlAnalysisReporter.js';
|
|
5
|
+
export { reportCoverageHtml } from './htmlCoverageReporter.js';
|
|
6
|
+
export { reportImpactHtml } from './htmlImpactReporter.js';
|
|
7
|
+
export { reportPrDiffHtml } from './htmlPrDiffReporter.js';
|
|
8
|
+
export { reportReviewHtml } from './htmlReviewReporter.js';
|
|
9
|
+
/**
|
|
10
|
+
* Standalone HTML report (0.16.0+). Each top-level command has its own
|
|
11
|
+
* renderer; the output is a single self-contained HTML document with
|
|
12
|
+
* inline CSS, no external assets, no JS framework. Suitable for posting
|
|
13
|
+
* as a CI artifact or sharing in a PR comment.
|
|
14
|
+
*
|
|
15
|
+
* Style choices:
|
|
16
|
+
* - System font stack to render readably without webfonts.
|
|
17
|
+
* - Two-tone colour palette (neutral grey + one accent per severity).
|
|
18
|
+
* - Tables for data, no charts. Charts would need JS.
|
|
19
|
+
* - Accessibility: tables get `<th>`s with scope, severity has both
|
|
20
|
+
* colour AND a text glyph so colourblind readers don't lose info.
|
|
21
|
+
*/
|
|
7
22
|
export declare function reportHealthHtml(issues: Issue[], reportControls?: ReportControlsMetadata): void;
|
|
8
23
|
export declare function reportHotspotsHtml(report: HotspotReport): void;
|
|
9
24
|
export declare function reportCouplingHtml(report: CouplingReport): void;
|
|
10
|
-
export declare function reportReviewHtml(report: ReviewReport): void;
|
|
11
|
-
export declare function reportPrDiffHtml(report: PrDiffReport): void;
|
|
12
|
-
export declare function reportCoverageHtml(report: CoverageJoinedReport): void;
|
|
13
|
-
export declare function reportImpactHtml(report: ImpactReport): void;
|