projscan 4.8.0 → 4.9.2
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 +102 -58
- package/dist/analyzers/deadCodeCheck.js +93 -0
- package/dist/analyzers/deadCodeCheck.js.map +1 -1
- package/dist/analyzers/unusedDependencyCheck.js +10 -10
- package/dist/analyzers/unusedDependencyCheck.js.map +1 -1
- package/dist/cli/commands/bugHunt.js +37 -8
- package/dist/cli/commands/bugHunt.js.map +1 -1
- package/dist/cli/commands/feedback.js +47 -1
- package/dist/cli/commands/feedback.js.map +1 -1
- package/dist/cli/commands/preflight.js +18 -2
- package/dist/cli/commands/preflight.js.map +1 -1
- package/dist/cli/commands/privacyCheck.js +5 -2
- package/dist/cli/commands/privacyCheck.js.map +1 -1
- package/dist/cli/commands/releaseTrain.js +9 -1
- package/dist/cli/commands/releaseTrain.js.map +1 -1
- package/dist/cli/commands/startAction.d.ts +2 -1
- package/dist/cli/commands/startAction.js +4 -4
- package/dist/cli/commands/startAction.js.map +1 -1
- package/dist/cli/commands/startConsole.d.ts +1 -0
- package/dist/cli/commands/startConsole.js +83 -7
- package/dist/cli/commands/startConsole.js.map +1 -1
- package/dist/cli/commands/startOptionsRegistration.js +1 -1
- package/dist/cli/commands/startOptionsRegistration.js.map +1 -1
- package/dist/core/adoption.js +13 -0
- package/dist/core/adoption.js.map +1 -1
- package/dist/core/bugHunt.js +62 -22
- package/dist/core/bugHunt.js.map +1 -1
- package/dist/core/bugHuntPreflightFindings.js +5 -2
- package/dist/core/bugHuntPreflightFindings.js.map +1 -1
- package/dist/core/evidenceComment.d.ts +2 -1
- package/dist/core/evidenceComment.js +45 -7
- package/dist/core/evidenceComment.js.map +1 -1
- package/dist/core/feedback.d.ts +2 -1
- package/dist/core/feedback.js +186 -0
- package/dist/core/feedback.js.map +1 -1
- package/dist/core/frameworkAstroSources.d.ts +2 -0
- package/dist/core/frameworkAstroSources.js +71 -0
- package/dist/core/frameworkAstroSources.js.map +1 -0
- package/dist/core/frameworkSourceResolvers.js +6 -0
- package/dist/core/frameworkSourceResolvers.js.map +1 -1
- package/dist/core/frameworkSources.js +2 -0
- package/dist/core/frameworkSources.js.map +1 -1
- package/dist/core/importGraph.d.ts +2 -0
- package/dist/core/importGraph.js +14 -5
- package/dist/core/importGraph.js.map +1 -1
- package/dist/core/intentRouterCatalog.js +8 -3
- package/dist/core/intentRouterCatalog.js.map +1 -1
- package/dist/core/intentRouterDependencySignals.d.ts +1 -0
- package/dist/core/intentRouterDependencySignals.js +14 -0
- package/dist/core/intentRouterDependencySignals.js.map +1 -1
- package/dist/core/intentRouterKeywordEarlyGuards.js +24 -1
- package/dist/core/intentRouterKeywordEarlyGuards.js.map +1 -1
- package/dist/core/intentRouterKeywordWeights.js +6 -0
- package/dist/core/intentRouterKeywordWeights.js.map +1 -1
- package/dist/core/intentRouterPreflightSignals.js +7 -2
- package/dist/core/intentRouterPreflightSignals.js.map +1 -1
- package/dist/core/intentRouterRegressionKeywordMatches.js +9 -2
- package/dist/core/intentRouterRegressionKeywordMatches.js.map +1 -1
- package/dist/core/intentRouterRegressionSignals.d.ts +1 -0
- package/dist/core/intentRouterRegressionSignals.js +11 -1
- package/dist/core/intentRouterRegressionSignals.js.map +1 -1
- package/dist/core/intentRouterReleaseSignals.js +2 -2
- package/dist/core/intentRouterReleaseSignals.js.map +1 -1
- package/dist/core/intentRouterVerificationSignals.js +5 -0
- package/dist/core/intentRouterVerificationSignals.js.map +1 -1
- package/dist/core/intentRouterWorkSignals.js +4 -2
- package/dist/core/intentRouterWorkSignals.js.map +1 -1
- package/dist/core/languages/LanguageAdapter.d.ts +2 -0
- package/dist/core/languages/javascriptAdapter.js +7 -28
- package/dist/core/languages/javascriptAdapter.js.map +1 -1
- package/dist/core/languages/javascriptProjectConfig.d.ts +20 -0
- package/dist/core/languages/javascriptProjectConfig.js +479 -0
- package/dist/core/languages/javascriptProjectConfig.js.map +1 -0
- package/dist/core/preflightCautionBudget.d.ts +2 -0
- package/dist/core/preflightCautionBudget.js +85 -0
- package/dist/core/preflightCautionBudget.js.map +1 -0
- package/dist/core/preflightInputs.d.ts +30 -2
- package/dist/core/preflightInputs.js +39 -12
- package/dist/core/preflightInputs.js.map +1 -1
- package/dist/core/preflightReasons.js +35 -9
- package/dist/core/preflightReasons.js.map +1 -1
- package/dist/core/preflightReleaseScale.js +16 -5
- package/dist/core/preflightReleaseScale.js.map +1 -1
- package/dist/core/preflightReport.js +3 -0
- package/dist/core/preflightReport.js.map +1 -1
- package/dist/core/preflightSuggestedActions.js +3 -1
- package/dist/core/preflightSuggestedActions.js.map +1 -1
- package/dist/core/preflightVerdict.js +3 -0
- package/dist/core/preflightVerdict.js.map +1 -1
- package/dist/core/qualityScorecard.js +39 -21
- package/dist/core/qualityScorecard.js.map +1 -1
- package/dist/core/releaseEvidence.d.ts +2 -2
- package/dist/core/releaseEvidence.js +3 -2
- package/dist/core/releaseEvidence.js.map +1 -1
- package/dist/core/releaseEvidenceArtifacts.js +12 -4
- package/dist/core/releaseEvidenceArtifacts.js.map +1 -1
- package/dist/core/releaseTrain.d.ts +11 -1
- package/dist/core/releaseTrain.js +54 -2
- package/dist/core/releaseTrain.js.map +1 -1
- package/dist/core/repositoryScanner.js +5 -2
- package/dist/core/repositoryScanner.js.map +1 -1
- package/dist/core/reviewVerdict.js +37 -5
- package/dist/core/reviewVerdict.js.map +1 -1
- package/dist/core/startAdoptionGaps.js +1 -1
- package/dist/core/startAdoptionGaps.js.map +1 -1
- package/dist/core/startClaimTargets.d.ts +2 -0
- package/dist/core/startClaimTargets.js +14 -0
- package/dist/core/startClaimTargets.js.map +1 -0
- package/dist/core/startDailyWorkflows.d.ts +2 -0
- package/dist/core/startDailyWorkflows.js +50 -0
- package/dist/core/startDailyWorkflows.js.map +1 -0
- package/dist/core/startEnvTargets.d.ts +1 -0
- package/dist/core/startEnvTargets.js +9 -0
- package/dist/core/startEnvTargets.js.map +1 -0
- package/dist/core/startFileTargets.d.ts +2 -0
- package/dist/core/startFileTargets.js +19 -0
- package/dist/core/startFileTargets.js.map +1 -0
- package/dist/core/startGeneratedConfigSearchTargets.d.ts +1 -0
- package/dist/core/startGeneratedConfigSearchTargets.js +22 -0
- package/dist/core/startGeneratedConfigSearchTargets.js.map +1 -0
- package/dist/core/startGraphTargets.d.ts +10 -0
- package/dist/core/startGraphTargets.js +82 -0
- package/dist/core/startGraphTargets.js.map +1 -0
- package/dist/core/startHighPrioritySearchTargets.d.ts +1 -0
- package/dist/core/startHighPrioritySearchTargets.js +24 -0
- package/dist/core/startHighPrioritySearchTargets.js.map +1 -0
- package/dist/core/startImpactTargets.d.ts +1 -0
- package/dist/core/startImpactTargets.js +18 -0
- package/dist/core/startImpactTargets.js.map +1 -0
- package/dist/core/startIntentApiContractQueries.d.ts +1 -0
- package/dist/core/startIntentApiContractQueries.js +50 -0
- package/dist/core/startIntentApiContractQueries.js.map +1 -0
- package/dist/core/startIntentAuthorizationQueries.d.ts +1 -0
- package/dist/core/startIntentAuthorizationQueries.js +29 -0
- package/dist/core/startIntentAuthorizationQueries.js.map +1 -0
- package/dist/core/startIntentBackgroundWorkQueries.d.ts +1 -0
- package/dist/core/startIntentBackgroundWorkQueries.js +23 -0
- package/dist/core/startIntentBackgroundWorkQueries.js.map +1 -0
- package/dist/core/startIntentCommunicationArtifactQueries.d.ts +1 -0
- package/dist/core/startIntentCommunicationArtifactQueries.js +25 -0
- package/dist/core/startIntentCommunicationArtifactQueries.js.map +1 -0
- package/dist/core/startIntentDataAccessQueries.d.ts +1 -0
- package/dist/core/startIntentDataAccessQueries.js +60 -0
- package/dist/core/startIntentDataAccessQueries.js.map +1 -0
- package/dist/core/startIntentDataContractQueries.d.ts +1 -0
- package/dist/core/startIntentDataContractQueries.js +75 -0
- package/dist/core/startIntentDataContractQueries.js.map +1 -0
- package/dist/core/startIntentDomainSearchQueries.d.ts +1 -0
- package/dist/core/startIntentDomainSearchQueries.js +47 -0
- package/dist/core/startIntentDomainSearchQueries.js.map +1 -0
- package/dist/core/startIntentDomainWorkflowQueries.d.ts +1 -0
- package/dist/core/startIntentDomainWorkflowQueries.js +28 -0
- package/dist/core/startIntentDomainWorkflowQueries.js.map +1 -0
- package/dist/core/startIntentFrontendPageRouteQueries.d.ts +1 -0
- package/dist/core/startIntentFrontendPageRouteQueries.js +26 -0
- package/dist/core/startIntentFrontendPageRouteQueries.js.map +1 -0
- package/dist/core/startIntentInfraArtifactQueries.d.ts +1 -0
- package/dist/core/startIntentInfraArtifactQueries.js +62 -0
- package/dist/core/startIntentInfraArtifactQueries.js.map +1 -0
- package/dist/core/startIntentIntegrationQueries.d.ts +1 -0
- package/dist/core/startIntentIntegrationQueries.js +96 -0
- package/dist/core/startIntentIntegrationQueries.js.map +1 -0
- package/dist/core/startIntentNavigationLayoutQueries.d.ts +1 -0
- package/dist/core/startIntentNavigationLayoutQueries.js +22 -0
- package/dist/core/startIntentNavigationLayoutQueries.js.map +1 -0
- package/dist/core/startIntentObservabilityQueries.d.ts +1 -0
- package/dist/core/startIntentObservabilityQueries.js +26 -0
- package/dist/core/startIntentObservabilityQueries.js.map +1 -0
- package/dist/core/startIntentReliabilityQueries.d.ts +1 -0
- package/dist/core/startIntentReliabilityQueries.js +85 -0
- package/dist/core/startIntentReliabilityQueries.js.map +1 -0
- package/dist/core/startIntentStateManagementQueries.d.ts +1 -0
- package/dist/core/startIntentStateManagementQueries.js +61 -0
- package/dist/core/startIntentStateManagementQueries.js.map +1 -0
- package/dist/core/startIntentStyleSystemQueries.d.ts +1 -0
- package/dist/core/startIntentStyleSystemQueries.js +26 -0
- package/dist/core/startIntentStyleSystemQueries.js.map +1 -0
- package/dist/core/startIntentTargetText.d.ts +2 -0
- package/dist/core/startIntentTargetText.js +9 -0
- package/dist/core/startIntentTargetText.js.map +1 -0
- package/dist/core/startIntentTargets.d.ts +10 -24
- package/dist/core/startIntentTargets.js +15 -1123
- package/dist/core/startIntentTargets.js.map +1 -1
- package/dist/core/startIntentTestDataQueries.d.ts +1 -0
- package/dist/core/startIntentTestDataQueries.js +28 -0
- package/dist/core/startIntentTestDataQueries.js.map +1 -0
- package/dist/core/startIntentToolingConfigQueries.d.ts +1 -0
- package/dist/core/startIntentToolingConfigQueries.js +31 -0
- package/dist/core/startIntentToolingConfigQueries.js.map +1 -0
- package/dist/core/startIntentUiInteractionQueries.d.ts +1 -0
- package/dist/core/startIntentUiInteractionQueries.js +71 -0
- package/dist/core/startIntentUiInteractionQueries.js.map +1 -0
- package/dist/core/startIssueTargets.d.ts +1 -0
- package/dist/core/startIssueTargets.js +19 -0
- package/dist/core/startIssueTargets.js.map +1 -0
- package/dist/core/startMissionPolicy.d.ts +2 -2
- package/dist/core/startMissionPolicy.js +63 -7
- package/dist/core/startMissionPolicy.js.map +1 -1
- package/dist/core/startMode.d.ts +3 -1
- package/dist/core/startMode.js +39 -7
- package/dist/core/startMode.js.map +1 -1
- package/dist/core/startOptions.d.ts +2 -2
- package/dist/core/startOptions.js +1 -1
- package/dist/core/startOptions.js.map +1 -1
- package/dist/core/startOwnershipSearchTargets.d.ts +2 -0
- package/dist/core/startOwnershipSearchTargets.js +23 -0
- package/dist/core/startOwnershipSearchTargets.js.map +1 -0
- package/dist/core/startPackageTargets.d.ts +4 -0
- package/dist/core/startPackageTargets.js +91 -0
- package/dist/core/startPackageTargets.js.map +1 -0
- package/dist/core/startQuotedTextTargets.d.ts +1 -0
- package/dist/core/startQuotedTextTargets.js +7 -0
- package/dist/core/startQuotedTextTargets.js.map +1 -0
- package/dist/core/startReportBuilder.d.ts +1 -0
- package/dist/core/startReportBuilder.js +2 -1
- package/dist/core/startReportBuilder.js.map +1 -1
- package/dist/core/startReportContext.d.ts +1 -0
- package/dist/core/startReportContext.js +3 -0
- package/dist/core/startReportContext.js.map +1 -1
- package/dist/core/startReportScopeTargets.d.ts +1 -0
- package/dist/core/startReportScopeTargets.js +56 -0
- package/dist/core/startReportScopeTargets.js.map +1 -0
- package/dist/core/startShellArgs.d.ts +4 -0
- package/dist/core/startShellArgs.js +19 -0
- package/dist/core/startShellArgs.js.map +1 -0
- package/dist/core/startSymbolTargets.d.ts +2 -0
- package/dist/core/startSymbolTargets.js +28 -0
- package/dist/core/startSymbolTargets.js.map +1 -0
- package/dist/core/startTestRouteSearchTargets.d.ts +1 -0
- package/dist/core/startTestRouteSearchTargets.js +34 -0
- package/dist/core/startTestRouteSearchTargets.js.map +1 -0
- package/dist/core/understand.js +20 -22
- package/dist/core/understand.js.map +1 -1
- package/dist/core/workplan.js +24 -12
- package/dist/core/workplan.js.map +1 -1
- package/dist/mcp/tools/workspaceGraph.js +12 -9
- package/dist/mcp/tools/workspaceGraph.js.map +1 -1
- package/dist/projscan-sbom.cdx.json +6 -6
- package/dist/publicAgent.d.ts +1 -1
- package/dist/publicAgent.js +1 -1
- package/dist/publicAgent.js.map +1 -1
- package/dist/tool-manifest.json +2 -2
- package/dist/types/bugHunt.d.ts +1 -1
- package/dist/types/dogfood.d.ts +17 -0
- package/dist/types/evidencePack.d.ts +8 -0
- package/dist/types/preflight.d.ts +18 -0
- package/dist/types/releaseTrain.d.ts +7 -0
- package/dist/types/startCommon.d.ts +8 -0
- package/dist/types/startMissionControl.d.ts +2 -1
- package/dist/utils/fileWalker.d.ts +1 -0
- package/dist/utils/fileWalker.js +6 -1
- package/dist/utils/fileWalker.js.map +1 -1
- package/dist/utils/formatSupport.d.ts +1 -0
- package/dist/utils/formatSupport.js +1 -0
- package/dist/utils/formatSupport.js.map +1 -1
- package/docs/GUIDE.md +50 -11
- package/docs/ROADMAP.md +41 -16
- package/docs/demos/projscan-4-1-demo.html +4 -4
- package/docs/examples/adoption-workflows.md +48 -0
- package/docs/projscan-mission-control.gif +0 -0
- package/docs/projscan-mission-control.png +0 -0
- package/docs/projscan-mission-proof.gif +0 -0
- package/docs/projscan-proof-router.png +0 -0
- package/package.json +12 -12
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { type StartModeResolution } from './startMode.js';
|
|
1
|
+
import { type StartModeInput, type StartModeResolution } from './startMode.js';
|
|
2
2
|
import type { WorkplanMode } from '../types.js';
|
|
3
3
|
export interface ComputeStartOptions {
|
|
4
|
-
mode?:
|
|
4
|
+
mode?: StartModeInput;
|
|
5
5
|
intent?: string;
|
|
6
6
|
missionDir?: string;
|
|
7
7
|
maxTasks?: number;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"startOptions.js","sourceRoot":"","sources":["../../src/core/startOptions.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"startOptions.js","sourceRoot":"","sources":["../../src/core/startOptions.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gBAAgB,GAGjB,MAAM,gBAAgB,CAAC;AAoBxB,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAC5B,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAC5B,MAAM,eAAe,GAAG,EAAE,CAAC;AAE3B,MAAM,UAAU,qBAAqB,CAAC,UAA+B,EAAE;IACrE,MAAM,MAAM,GAAG,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC/C,MAAM,cAAc,GAAG,gBAAgB,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC9D,OAAO;QACL,MAAM;QACN,cAAc;QACd,IAAI,EAAE,cAAc,CAAC,IAAI;QACzB,QAAQ,EAAE,cAAc,CAAC,OAAO,CAAC,QAAQ,EAAE,iBAAiB,EAAE,eAAe,CAAC;QAC9E,QAAQ,EAAE,cAAc,CAAC,OAAO,CAAC,QAAQ,EAAE,iBAAiB,EAAE,eAAe,CAAC;KAC/E,CAAC;AACJ,CAAC;AAED,SAAS,eAAe,CAAC,KAAyB;IAChD,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,SAAS,CAAC;IAChD,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAClD,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,SAAS,CAAC;IAC3C,OAAO,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC/B,CAAC;AAED,SAAS,cAAc,CAAC,KAAyB,EAAE,QAAgB,EAAE,GAAW;IAC9E,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,QAAQ,CAAC;IAC1E,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACvD,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { unwrapTarget } from './startIntentTargetText.js';
|
|
2
|
+
export function searchQueryFromOwnership(trimmed) {
|
|
3
|
+
const ownership = trimmed.match(/\b(?:who|which\s+team)\s+owns?\s+(.+?)\s*[?!.]*$/i);
|
|
4
|
+
if (ownership?.[1])
|
|
5
|
+
return unwrapTarget(ownership[1].trim());
|
|
6
|
+
const ownershipHelp = trimmed.match(/\bwho\s+(?:should\s+i\s+ask|can\s+help|knows|is\s+(?:the\s+)?(?:expert|contact))\s*(?:about|with|for)?\s+(.+?)\s*[?!.]*$/i);
|
|
7
|
+
if (ownershipHelp?.[1])
|
|
8
|
+
return unwrapTarget(ownershipHelp[1].trim());
|
|
9
|
+
const expertLookup = trimmed.match(/\b(?:find|locate|search(?:\s+for)?|lookup)\s+(?:an?\s+)?(?:expert|experts|contact|contacts)\s+(?:for|on|about|with)\s+(.+?)\s*[?!.]*$/i);
|
|
10
|
+
if (expertLookup?.[1])
|
|
11
|
+
return unwrapTarget(expertLookup[1].trim());
|
|
12
|
+
const codeOwners = trimmed.match(/\b(?:find|locate|search(?:\s+for)?|lookup)\s+(?:code\s+)?owners?\s+(?:for|of)\s+(.+?)\s*[?!.]*$/i);
|
|
13
|
+
if (codeOwners?.[1])
|
|
14
|
+
return unwrapTarget(codeOwners[1].trim());
|
|
15
|
+
return undefined;
|
|
16
|
+
}
|
|
17
|
+
export function searchQueryFromImplementation(trimmed) {
|
|
18
|
+
const whereImplemented = trimmed.match(/\bwhere\s+(?:is|are|do|does|we)?\s*(.+?)\s+(?:implemented|handled|configured|created|defined|loaded|parsed|documented)\b/i);
|
|
19
|
+
if (whereImplemented?.[1])
|
|
20
|
+
return unwrapTarget(whereImplemented[1].trim());
|
|
21
|
+
return undefined;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=startOwnershipSearchTargets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startOwnershipSearchTargets.js","sourceRoot":"","sources":["../../src/core/startOwnershipSearchTargets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAE1D,MAAM,UAAU,wBAAwB,CAAC,OAAe;IACtD,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,mDAAmD,CAAC,CAAC;IACrF,IAAI,SAAS,EAAE,CAAC,CAAC,CAAC;QAAE,OAAO,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IAC7D,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,CACjC,2HAA2H,CAC5H,CAAC;IACF,IAAI,aAAa,EAAE,CAAC,CAAC,CAAC;QAAE,OAAO,YAAY,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IACrE,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAChC,wIAAwI,CACzI,CAAC;IACF,IAAI,YAAY,EAAE,CAAC,CAAC,CAAC;QAAE,OAAO,YAAY,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IACnE,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAC9B,kGAAkG,CACnG,CAAC;IACF,IAAI,UAAU,EAAE,CAAC,CAAC,CAAC;QAAE,OAAO,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IAC/D,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,6BAA6B,CAAC,OAAe;IAC3D,MAAM,gBAAgB,GAAG,OAAO,CAAC,KAAK,CACpC,2HAA2H,CAC5H,CAAC;IACF,IAAI,gBAAgB,EAAE,CAAC,CAAC,CAAC;QAAE,OAAO,YAAY,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IAC3E,OAAO,SAAS,CAAC;AACnB,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export declare function extractPackageTarget(intent: string): string | undefined;
|
|
2
|
+
export declare function extractAuditPackageTarget(intent: string): string | undefined;
|
|
3
|
+
export declare function isPackageNameTarget(target: string): boolean;
|
|
4
|
+
export declare function normalizePackageName(target: string): string;
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
const PACKAGE_TARGET_PATTERNS = [
|
|
2
|
+
{ pattern: /[`'"](@?[A-Za-z0-9][\w.-]*(?:\/[A-Za-z0-9][\w.-]*)?)[`'"]/ },
|
|
3
|
+
{
|
|
4
|
+
pattern: /\b(?:bump|upgrade|update|remove|drop|uninstall)\s+(?:the\s+)?(?:(?:package|dependency)\s+)?(@?[A-Za-z0-9][\w.-]*(?:\/[A-Za-z0-9][\w.-]*)?)(?=\s|$)/i,
|
|
5
|
+
skip: isPythonUpgradeCoverageTopic,
|
|
6
|
+
},
|
|
7
|
+
{
|
|
8
|
+
pattern: /\b(@?[A-Za-z0-9][\w.-]*(?:\/[A-Za-z0-9][\w.-]*)?)\s+(?:safe\s+to\s+)?(?:remove|drop|uninstall)\b/i,
|
|
9
|
+
},
|
|
10
|
+
{
|
|
11
|
+
pattern: /\b(?:package|dependency)\s+(?:named\s+|called\s+)?(@?[A-Za-z0-9][\w.-]*(?:\/[A-Za-z0-9][\w.-]*)?)(?=\s|$)/i,
|
|
12
|
+
},
|
|
13
|
+
];
|
|
14
|
+
export function extractPackageTarget(intent) {
|
|
15
|
+
return firstPackageTarget(compactIntentTargetText(intent), PACKAGE_TARGET_PATTERNS);
|
|
16
|
+
}
|
|
17
|
+
export function extractAuditPackageTarget(intent) {
|
|
18
|
+
const packageName = extractPackageTarget(intent);
|
|
19
|
+
if (packageName)
|
|
20
|
+
return packageName;
|
|
21
|
+
const compactIntent = compactIntentTargetText(intent);
|
|
22
|
+
const subject = compactIntent.match(/\b(?:does|is|can)\s+(@?[A-Za-z0-9][\w.-]*(?:\/[A-Za-z0-9][\w.-]*)?)\s+(?:have|has|contain|contains|affected|vulnerable|secure|safe)\b/i);
|
|
23
|
+
if (subject?.[1] && isPackageNameTarget(subject[1]))
|
|
24
|
+
return normalizePackageName(subject[1]);
|
|
25
|
+
const command = compactIntent.match(/\b(?:audit|check|scan)\s+(@?[A-Za-z0-9][\w.-]*(?:\/[A-Za-z0-9][\w.-]*)?)\s+(?:for\s+)?(?:cve|cves|vulnerabilities|vulnerability|security)\b/i);
|
|
26
|
+
if (command?.[1] && isPackageNameTarget(command[1]))
|
|
27
|
+
return normalizePackageName(command[1]);
|
|
28
|
+
return undefined;
|
|
29
|
+
}
|
|
30
|
+
function compactIntentTargetText(intent) {
|
|
31
|
+
return intent.trim().replace(/[?!\s]+$/g, '');
|
|
32
|
+
}
|
|
33
|
+
function firstPackageTarget(compactIntent, patterns) {
|
|
34
|
+
for (const { pattern, skip } of patterns) {
|
|
35
|
+
const target = compactIntent.match(pattern)?.[1];
|
|
36
|
+
if (!target || skip?.(target, compactIntent) || !isPackageNameTarget(target))
|
|
37
|
+
continue;
|
|
38
|
+
return normalizePackageName(target);
|
|
39
|
+
}
|
|
40
|
+
return undefined;
|
|
41
|
+
}
|
|
42
|
+
function isPythonUpgradeCoverageTopic(target, intent) {
|
|
43
|
+
return (target.toLowerCase() === 'coverage' &&
|
|
44
|
+
/\b(?:upgrade|upgrading|bump|update)\s+coverage\b/i.test(intent) &&
|
|
45
|
+
/\b(?:python|poetry|pyproject|requirements?|pip|pipenv|pinned)\b/i.test(intent));
|
|
46
|
+
}
|
|
47
|
+
export function isPackageNameTarget(target) {
|
|
48
|
+
const lower = target.toLowerCase();
|
|
49
|
+
if ([
|
|
50
|
+
'package',
|
|
51
|
+
'dependency',
|
|
52
|
+
'dependencies',
|
|
53
|
+
'version',
|
|
54
|
+
'latest',
|
|
55
|
+
'upgrade',
|
|
56
|
+
'bump',
|
|
57
|
+
'update',
|
|
58
|
+
'for',
|
|
59
|
+
'doc',
|
|
60
|
+
'docs',
|
|
61
|
+
'document',
|
|
62
|
+
'documentation',
|
|
63
|
+
'documented',
|
|
64
|
+
'readme',
|
|
65
|
+
'changelog',
|
|
66
|
+
'example',
|
|
67
|
+
'examples',
|
|
68
|
+
'guide',
|
|
69
|
+
'should',
|
|
70
|
+
'could',
|
|
71
|
+
'would',
|
|
72
|
+
'can',
|
|
73
|
+
'what',
|
|
74
|
+
'which',
|
|
75
|
+
'the',
|
|
76
|
+
'this',
|
|
77
|
+
'that',
|
|
78
|
+
'it',
|
|
79
|
+
'my',
|
|
80
|
+
].includes(lower))
|
|
81
|
+
return false;
|
|
82
|
+
if (target.length === 0 || target.length > 214 || target !== target.trim())
|
|
83
|
+
return false;
|
|
84
|
+
if (target.includes('..') || target.includes('\\'))
|
|
85
|
+
return false;
|
|
86
|
+
return /^(?:@[a-z0-9][\w.-]*\/)?[a-z0-9][\w.-]*$/i.test(target);
|
|
87
|
+
}
|
|
88
|
+
export function normalizePackageName(target) {
|
|
89
|
+
return target.toLowerCase();
|
|
90
|
+
}
|
|
91
|
+
//# sourceMappingURL=startPackageTargets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startPackageTargets.js","sourceRoot":"","sources":["../../src/core/startPackageTargets.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function extractQuotedTextTarget(intent: string): string | undefined;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { isGenericReferenceTarget } from './startIntentTargetText.js';
|
|
2
|
+
export function extractQuotedTextTarget(intent) {
|
|
3
|
+
const quoted = intent.match(/(["'`])(.{2,200}?)\1/);
|
|
4
|
+
const target = quoted?.[2]?.trim();
|
|
5
|
+
return target && !isGenericReferenceTarget(target) ? target : undefined;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=startQuotedTextTargets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startQuotedTextTargets.js","sourceRoot":"","sources":["../../src/core/startQuotedTextTargets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAEtE,MAAM,UAAU,uBAAuB,CAAC,MAAc;IACpD,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC;IACpD,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC;IACnC,OAAO,MAAM,IAAI,CAAC,wBAAwB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;AAC1E,CAAC"}
|
|
@@ -13,6 +13,7 @@ export interface BuildStartReportInput {
|
|
|
13
13
|
riskSources: StartReport['evidence']['riskSources'];
|
|
14
14
|
roadmapPreview?: StartReport['evidence']['roadmapPreview'];
|
|
15
15
|
workflow: StartReport['recommendedWorkflow'];
|
|
16
|
+
dailyWorkflows: NonNullable<StartReport['dailyWorkflows']>;
|
|
16
17
|
firstTenMinutes: StartReport['firstTenMinutes'];
|
|
17
18
|
missionControl: StartReport['missionControl'];
|
|
18
19
|
coordinationHints: StartReport['coordinationHints'];
|
|
@@ -8,12 +8,13 @@ export function buildStartReport(input) {
|
|
|
8
8
|
mode: input.mode,
|
|
9
9
|
modeSource: input.modeSource,
|
|
10
10
|
modeReason: input.modeReason,
|
|
11
|
-
summary: summarize(input.mode, input.workplan, input.quality.topRisks.length, input.adoptionGaps.length, input.fixFirst?.title),
|
|
11
|
+
summary: summarize(input.mode, input.workplan, input.quality.topRisks.length, input.adoptionGaps.length, input.fixFirst?.title, input.quality.verdict),
|
|
12
12
|
setup: {
|
|
13
13
|
overall: input.setup.overall,
|
|
14
14
|
diagnostics: input.setup.diagnostics,
|
|
15
15
|
},
|
|
16
16
|
recommendedWorkflow: input.workflow,
|
|
17
|
+
dailyWorkflows: input.dailyWorkflows,
|
|
17
18
|
firstTenMinutes: input.firstTenMinutes,
|
|
18
19
|
missionControl: input.missionControl,
|
|
19
20
|
coordinationHints: input.coordinationHints,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"startReportBuilder.js","sourceRoot":"","sources":["../../src/core/startReportBuilder.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"startReportBuilder.js","sourceRoot":"","sources":["../../src/core/startReportBuilder.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AA4BrD,MAAM,UAAU,gBAAgB,CAAC,KAA4B;IAC3D,OAAO;QACL,aAAa,EAAE,CAAC;QAChB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,OAAO,EAAE,SAAS,CAChB,KAAK,CAAC,IAAI,EACV,KAAK,CAAC,QAAQ,EACd,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,EAC7B,KAAK,CAAC,YAAY,CAAC,MAAM,EACzB,KAAK,CAAC,QAAQ,EAAE,KAAK,EACrB,KAAK,CAAC,OAAO,CAAC,OAAO,CACtB;QACD,KAAK,EAAE;YACL,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,OAAO;YAC5B,WAAW,EAAE,KAAK,CAAC,KAAK,CAAC,WAAW;SACrC;QACD,mBAAmB,EAAE,KAAK,CAAC,QAAQ;QACnC,cAAc,EAAE,KAAK,CAAC,cAAc;QACpC,eAAe,EAAE,KAAK,CAAC,eAAe;QACtC,cAAc,EAAE,KAAK,CAAC,cAAc;QACpC,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;QAC1C,QAAQ,EAAE;YACR,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,OAAO;YACvC,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,OAAO;YACvC,cAAc,EAAE,KAAK,CAAC,OAAO,CAAC,OAAO;YACrC,cAAc,EAAE,KAAK,CAAC,OAAO,CAAC,OAAO;YACrC,WAAW,EAAE,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK;YACvC,QAAQ,EAAE,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC;YAC/B,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,cAAc,EAAE,KAAK,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC1E;QACD,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACvD,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,oBAAoB,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAClF,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KAC3E,CAAC;AACJ,CAAC;AAED,SAAS,QAAQ,CAAC,KAAqB;IACrC,OAAO,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,KAAK,aAAa,CAAC,EAAE,MAAM,KAAK,MAAM,CAAC;AACpG,CAAC;AAED,SAAS,WAAW,CAAC,QAAwB,EAAE,OAA+B;IAC5E,OAAO,QAAQ,CAAC,SAAS,KAAK,IAAI,IAAI,OAAO,CAAC,SAAS,KAAK,IAAI,CAAC;AACnE,CAAC"}
|
|
@@ -9,6 +9,7 @@ export interface BuildStartReportContextInput extends LoadedStartInputs {
|
|
|
9
9
|
}
|
|
10
10
|
export interface StartReportContext {
|
|
11
11
|
workflow: StartReport['recommendedWorkflow'];
|
|
12
|
+
dailyWorkflows: NonNullable<StartReport['dailyWorkflows']>;
|
|
12
13
|
firstTenMinutes: StartReport['firstTenMinutes'];
|
|
13
14
|
missionControl: StartReport['missionControl'];
|
|
14
15
|
coordinationHints: StartReport['coordinationHints'];
|
|
@@ -3,6 +3,7 @@ import { fixFirstFromStartRisk } from './fixFirst.js';
|
|
|
3
3
|
import { buildFirstTenMinutes } from './onboarding.js';
|
|
4
4
|
import { buildAdoptionLoop } from './startAdoptionLoop.js';
|
|
5
5
|
import { buildStartAdoptionGaps } from './startAdoptionGaps.js';
|
|
6
|
+
import { buildStartDailyWorkflows } from './startDailyWorkflows.js';
|
|
6
7
|
import { buildStartCoordinationHints } from './startEvidence.js';
|
|
7
8
|
import { buildMissionControl } from './startMissionControl.js';
|
|
8
9
|
import { chooseWorkflow, combineRisks } from './startMissionPolicy.js';
|
|
@@ -13,6 +14,7 @@ export function buildStartReportContext(input) {
|
|
|
13
14
|
const fixFirst = input.workplan.fixFirst ?? fixFirstFromStartRisk(topRisks[0]);
|
|
14
15
|
const adoptionGaps = buildStartAdoptionGaps(input.setup.diagnostics);
|
|
15
16
|
const adoptionLoop = buildAdoptionLoop();
|
|
17
|
+
const dailyWorkflows = buildStartDailyWorkflows();
|
|
16
18
|
const firstTenMinutes = buildFirstTenMinutes(input.mode);
|
|
17
19
|
const coordinationHints = buildStartCoordinationHints(input.riskSources, input.mode, input.harnessHints, input.intent);
|
|
18
20
|
const missionControl = buildMissionControl({
|
|
@@ -37,6 +39,7 @@ export function buildStartReportContext(input) {
|
|
|
37
39
|
});
|
|
38
40
|
return {
|
|
39
41
|
workflow,
|
|
42
|
+
dailyWorkflows,
|
|
40
43
|
firstTenMinutes,
|
|
41
44
|
missionControl,
|
|
42
45
|
coordinationHints,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"startReportContext.js","sourceRoot":"","sources":["../../src/core/startReportContext.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,2BAA2B,EAAE,MAAM,oBAAoB,CAAC;AAEjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvE,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"startReportContext.js","sourceRoot":"","sources":["../../src/core/startReportContext.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAC;AACpE,OAAO,EAAE,2BAA2B,EAAE,MAAM,oBAAoB,CAAC;AAEjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvE,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AA0B9D,MAAM,UAAU,uBAAuB,CAAC,KAAmC;IACzE,MAAM,QAAQ,GAAG,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,kBAAkB,EAAE,CAAC,OAAO,CAAC,CAAC;IAC1E,MAAM,QAAQ,GAAG,YAAY,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;IACtF,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC,QAAQ,IAAI,qBAAqB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/E,MAAM,YAAY,GAAG,sBAAsB,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IACrE,MAAM,YAAY,GAAG,iBAAiB,EAAE,CAAC;IACzC,MAAM,cAAc,GAAG,wBAAwB,EAAE,CAAC;IAClD,MAAM,eAAe,GAAG,oBAAoB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACzD,MAAM,iBAAiB,GAAG,2BAA2B,CACnD,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,IAAI,EACV,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,MAAM,CACb,CAAC;IACF,MAAM,cAAc,GAAG,mBAAmB,CAAC;QACzC,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,YAAY,EAAE,KAAK,CAAC,KAAK,CAAC,OAAO;QACjC,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,QAAQ;QACR,QAAQ;QACR,YAAY;QACZ,iBAAiB;QACjB,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,cAAc,EAAE,KAAK,CAAC,cAAc;KACrC,CAAC,CAAC;IACH,MAAM,WAAW,GAAG,qBAAqB,CAAC;QACxC,cAAc;QACd,eAAe;QACf,QAAQ;QACR,YAAY;QACZ,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,OAAO,EAAE,KAAK,CAAC,OAAO;KACvB,CAAC,CAAC;IACH,OAAO;QACL,QAAQ;QACR,cAAc;QACd,eAAe;QACf,cAAc;QACd,iBAAiB;QACjB,QAAQ;QACR,QAAQ;QACR,YAAY;QACZ,YAAY;QACZ,WAAW;QACX,cAAc,EAAE,KAAK,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS;KAC5E,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function extractReportScopeTarget(intent: string): string | undefined;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
const REPORT_SCOPE_DIRECTORY_TARGETS = new Set([
|
|
2
|
+
'app',
|
|
3
|
+
'apps',
|
|
4
|
+
'docs',
|
|
5
|
+
'examples',
|
|
6
|
+
'lib',
|
|
7
|
+
'libs',
|
|
8
|
+
'packages',
|
|
9
|
+
'scripts',
|
|
10
|
+
'src',
|
|
11
|
+
'test',
|
|
12
|
+
'tests',
|
|
13
|
+
]);
|
|
14
|
+
export function extractReportScopeTarget(intent) {
|
|
15
|
+
const compactIntent = intent.trim().replace(/[?!.\s]+$/g, '');
|
|
16
|
+
const explicitScopes = extractReportScopeTargets(compactIntent);
|
|
17
|
+
if (explicitScopes.length > 0)
|
|
18
|
+
return explicitScopes.join(',');
|
|
19
|
+
const scopedDirectory = compactIntent.match(/\b(?:for|under|inside|within|from|scope(?:d)?\s+to|scope)\s+(?:the\s+)?([A-Za-z][A-Za-z0-9_-]{1,63})(?=\s|$)/i);
|
|
20
|
+
const candidate = scopedDirectory?.[1];
|
|
21
|
+
return candidate && isReportScopeDirectoryTarget(candidate) ? candidate : undefined;
|
|
22
|
+
}
|
|
23
|
+
function extractReportScopeTargets(intent) {
|
|
24
|
+
const candidates = [
|
|
25
|
+
...Array.from(intent.matchAll(/[`'"]([^`'"]+)[`'"]/g), (match) => unwrapTarget(match[1])),
|
|
26
|
+
...Array.from(intent.matchAll(/(?:^|\s)([A-Za-z][A-Za-z0-9_-]*(?:\/[A-Za-z0-9_.:@-]+)+|[A-Za-z][A-Za-z0-9_-]*\.[A-Za-z0-9]{1,12})(?=\s|$|,)/g), (match) => unwrapTarget(match[1])),
|
|
27
|
+
];
|
|
28
|
+
const seen = new Set();
|
|
29
|
+
const scopes = [];
|
|
30
|
+
for (const candidate of candidates) {
|
|
31
|
+
if (!isReportScopePathTarget(candidate) || seen.has(candidate))
|
|
32
|
+
continue;
|
|
33
|
+
seen.add(candidate);
|
|
34
|
+
scopes.push(candidate);
|
|
35
|
+
}
|
|
36
|
+
return scopes;
|
|
37
|
+
}
|
|
38
|
+
function isReportScopePathTarget(candidate) {
|
|
39
|
+
if (isFilePathTarget(candidate))
|
|
40
|
+
return true;
|
|
41
|
+
const topLevel = candidate.split('/')[0];
|
|
42
|
+
return topLevel ? isReportScopeDirectoryTarget(topLevel) : false;
|
|
43
|
+
}
|
|
44
|
+
function isReportScopeDirectoryTarget(candidate) {
|
|
45
|
+
return REPORT_SCOPE_DIRECTORY_TARGETS.has(candidate.toLowerCase());
|
|
46
|
+
}
|
|
47
|
+
function isFilePathTarget(target) {
|
|
48
|
+
return ((target.includes('/') || target.startsWith('.') || /\.[A-Za-z0-9]{1,12}$/.test(target)) &&
|
|
49
|
+
!/\s/.test(target));
|
|
50
|
+
}
|
|
51
|
+
function unwrapTarget(value) {
|
|
52
|
+
const trimmed = value.trim();
|
|
53
|
+
const wrapped = trimmed.match(/^([`'"])(.+)\1$/);
|
|
54
|
+
return (wrapped?.[2] ?? trimmed).trim();
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=startReportScopeTargets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startReportScopeTargets.js","sourceRoot":"","sources":["../../src/core/startReportScopeTargets.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export function isPlaceholder(value) {
|
|
2
|
+
return /^<[^<>]+>$/.test(value);
|
|
3
|
+
}
|
|
4
|
+
export function escapeDoubleQuoted(value) {
|
|
5
|
+
return value
|
|
6
|
+
.replace(/\\/g, '\\\\')
|
|
7
|
+
.replace(/"/g, '\\"')
|
|
8
|
+
.replace(/\$/g, '\\$')
|
|
9
|
+
.replace(/`/g, '\\`');
|
|
10
|
+
}
|
|
11
|
+
export function quoteShellArg(value) {
|
|
12
|
+
return /^[A-Za-z0-9_./:@-]+$/.test(value) ? value : `"${escapeDoubleQuoted(value)}"`;
|
|
13
|
+
}
|
|
14
|
+
export function quoteShellArgOrPlaceholder(value) {
|
|
15
|
+
if (isPlaceholder(value))
|
|
16
|
+
return value;
|
|
17
|
+
return quoteShellArg(value);
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=startShellArgs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startShellArgs.js","sourceRoot":"","sources":["../../src/core/startShellArgs.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,aAAa,CAAC,KAAa;IACzC,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AAClC,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAAa;IAC9C,OAAO,KAAK;SACT,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC;SACtB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC;SACpB,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;SACrB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;AAC1B,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,KAAa;IACzC,OAAO,sBAAsB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,kBAAkB,CAAC,KAAK,CAAC,GAAG,CAAC;AACvF,CAAC;AAED,MAAM,UAAU,0BAA0B,CAAC,KAAa;IACtD,IAAI,aAAa,CAAC,KAAK,CAAC;QAAE,OAAO,KAAK,CAAC;IACvC,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;AAC9B,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export function extractSymbolTarget(intent) {
|
|
2
|
+
const compactIntent = intent.trim().replace(/[?!\s]+$/g, '');
|
|
3
|
+
const wrapped = compactIntent.match(/[`'"]([A-Za-z_$][\w$]*)[`'"]/);
|
|
4
|
+
if (wrapped?.[1])
|
|
5
|
+
return wrapped[1];
|
|
6
|
+
const definitionMatch = compactIntent.match(/\bwhere\s+(?:is|are)\s+(?:the\s+)?([A-Za-z_$][\w$]*)\s+(?:defined|declared|implemented)\b/i);
|
|
7
|
+
if (definitionMatch?.[1] && isSymbolNameTarget(definitionMatch[1]))
|
|
8
|
+
return definitionMatch[1];
|
|
9
|
+
const match = compactIntent.match(/\b(?:symbol|function|class|const|type|interface)\s+([A-Za-z_$][\w$]*)\b/i);
|
|
10
|
+
return match?.[1] && isSymbolNameTarget(match[1]) ? match[1] : undefined;
|
|
11
|
+
}
|
|
12
|
+
export function isExactSymbolTarget(target) {
|
|
13
|
+
return /^[A-Za-z_$][\w$]*(?:\.[A-Za-z_$][\w$]*)?$/.test(target);
|
|
14
|
+
}
|
|
15
|
+
function isSymbolNameTarget(target) {
|
|
16
|
+
return ![
|
|
17
|
+
'symbol',
|
|
18
|
+
'function',
|
|
19
|
+
'class',
|
|
20
|
+
'const',
|
|
21
|
+
'type',
|
|
22
|
+
'interface',
|
|
23
|
+
'defined',
|
|
24
|
+
'declared',
|
|
25
|
+
'implemented',
|
|
26
|
+
].includes(target.toLowerCase());
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=startSymbolTargets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startSymbolTargets.js","sourceRoot":"","sources":["../../src/core/startSymbolTargets.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,mBAAmB,CAAC,MAAc;IAChD,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;IAC7D,MAAM,OAAO,GAAG,aAAa,CAAC,KAAK,CAAC,8BAA8B,CAAC,CAAC;IACpE,IAAI,OAAO,EAAE,CAAC,CAAC,CAAC;QAAE,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;IACpC,MAAM,eAAe,GAAG,aAAa,CAAC,KAAK,CACzC,4FAA4F,CAC7F,CAAC;IACF,IAAI,eAAe,EAAE,CAAC,CAAC,CAAC,IAAI,kBAAkB,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAAE,OAAO,eAAe,CAAC,CAAC,CAAC,CAAC;IAC9F,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,CAC/B,0EAA0E,CAC3E,CAAC;IACF,OAAO,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;AAC3E,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,MAAc;IAChD,OAAO,2CAA2C,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AAClE,CAAC;AAED,SAAS,kBAAkB,CAAC,MAAc;IACxC,OAAO,CAAC;QACN,QAAQ;QACR,UAAU;QACV,OAAO;QACP,OAAO;QACP,MAAM;QACN,WAAW;QACX,SAAS;QACT,UAAU;QACV,aAAa;KACd,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC;AACnC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function searchQueryFromTestAndRouteLookups(trimmed: string): string | undefined;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { unwrapTarget } from './startIntentTargetText.js';
|
|
2
|
+
export function searchQueryFromTestAndRouteLookups(trimmed) {
|
|
3
|
+
const testCoverageLookup = trimmed.match(/\b(?:which|what|find|locate|search(?:\s+for)?|where\s+(?:are|is))\s+(?:the\s+)?(?:tests?|specs?)\s+(?:that\s+)?(?:cover|covers|covering)\s+(.+?)\s*[?!.]*$/i);
|
|
4
|
+
if (testCoverageLookup?.[1])
|
|
5
|
+
return `tests for ${unwrapTarget(testCoverageLookup[1].trim())}`;
|
|
6
|
+
const testLocation = trimmed.match(/\b(?:where\s+(?:are|is)\s+|find\s+|locate\s+|search\s+(?:for\s+)?|lookup\s+)?(?:the\s+)?(?:tests?|specs?)\s+(?:for|of)\s+(.+?)\s*[?!.]*$/i);
|
|
7
|
+
if (testLocation?.[1])
|
|
8
|
+
return `tests for ${unwrapTarget(testLocation[1].trim())}`;
|
|
9
|
+
const routePath = trimmed.match(/(?:^|\s)((?:(?:GET|POST|PUT|PATCH|DELETE|OPTIONS|HEAD)\s+)?\/[A-Za-z0-9_./:{}-]+)/i);
|
|
10
|
+
if (routePath?.[1] &&
|
|
11
|
+
/\b(?:handler|handles?|handled|route|routes|endpoint|endpoints|where|find|locate|search)\b/i.test(trimmed)) {
|
|
12
|
+
return routePath[1].trim();
|
|
13
|
+
}
|
|
14
|
+
const codeHandler = trimmed.match(/\b(?:what|which)\s+(?:code|file|files)?\s*(?:handles?|contains|loads?|parses?|configures?|creates?)\s+(.+?)\s*[?!.]*$/i);
|
|
15
|
+
if (codeHandler?.[1])
|
|
16
|
+
return unwrapTarget(codeHandler[1].trim());
|
|
17
|
+
const featureFlags = trimmed.match(/\b(?:which|what|where|find|locate|search(?:\s+for)?|lookup)\s+(?:are\s+|is\s+|do\s+|does\s+)?(?:the\s+)?((?:feature\s+)?flags?)\s+(?:exist|exists|configured|loaded|defined)?\s*[?!.]*$/i);
|
|
18
|
+
if (featureFlags?.[1])
|
|
19
|
+
return featureFlags[1].toLowerCase().includes('feature') ? 'feature flags' : 'flags';
|
|
20
|
+
return migrationSearchQuery(trimmed);
|
|
21
|
+
}
|
|
22
|
+
function migrationSearchQuery(trimmed) {
|
|
23
|
+
const migrationLookup = trimmed.match(/\b(?:where\s+(?:are|is)|which|what|find|locate|search(?:\s+for)?|lookup|show)\s+(?:me\s+)?(?:the\s+)?((?:database\s+|prisma\s+)?migrations?|(?:database\s+)?migration\s+files?)\s*(?:exist|exists|ran|located|live)?\s*[?!.]*$/i);
|
|
24
|
+
if (migrationLookup?.[1]) {
|
|
25
|
+
const target = migrationLookup[1].trim().toLowerCase();
|
|
26
|
+
if (target.includes('prisma'))
|
|
27
|
+
return 'Prisma migrations';
|
|
28
|
+
if (target.includes('database'))
|
|
29
|
+
return target.includes('file') ? 'database migration files' : 'database migrations';
|
|
30
|
+
return target.includes('file') ? 'migration files' : 'migrations';
|
|
31
|
+
}
|
|
32
|
+
return undefined;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=startTestRouteSearchTargets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startTestRouteSearchTargets.js","sourceRoot":"","sources":["../../src/core/startTestRouteSearchTargets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAE1D,MAAM,UAAU,kCAAkC,CAAC,OAAe;IAChE,MAAM,kBAAkB,GAAG,OAAO,CAAC,KAAK,CACtC,6JAA6J,CAC9J,CAAC;IACF,IAAI,kBAAkB,EAAE,CAAC,CAAC,CAAC;QAAE,OAAO,aAAa,YAAY,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC;IAC9F,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAChC,2IAA2I,CAC5I,CAAC;IACF,IAAI,YAAY,EAAE,CAAC,CAAC,CAAC;QAAE,OAAO,aAAa,YAAY,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC;IAClF,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAC7B,oFAAoF,CACrF,CAAC;IACF,IACE,SAAS,EAAE,CAAC,CAAC,CAAC;QACd,4FAA4F,CAAC,IAAI,CAC/F,OAAO,CACR,EACD,CAAC;QACD,OAAO,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;IACD,MAAM,WAAW,GAAG,OAAO,CAAC,KAAK,CAC/B,wHAAwH,CACzH,CAAC;IACF,IAAI,WAAW,EAAE,CAAC,CAAC,CAAC;QAAE,OAAO,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IACjE,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAChC,0LAA0L,CAC3L,CAAC;IACF,IAAI,YAAY,EAAE,CAAC,CAAC,CAAC;QACnB,OAAO,YAAY,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,OAAO,CAAC;IACvF,OAAO,oBAAoB,CAAC,OAAO,CAAC,CAAC;AACvC,CAAC;AAED,SAAS,oBAAoB,CAAC,OAAe;IAC3C,MAAM,eAAe,GAAG,OAAO,CAAC,KAAK,CACnC,iOAAiO,CAClO,CAAC;IACF,IAAI,eAAe,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACzB,MAAM,MAAM,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QACvD,IAAI,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC;YAAE,OAAO,mBAAmB,CAAC;QAC1D,IAAI,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC;YAC7B,OAAO,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,qBAAqB,CAAC;QACtF,OAAO,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,YAAY,CAAC;IACpE,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC"}
|
package/dist/core/understand.js
CHANGED
|
@@ -185,14 +185,12 @@ function buildBoundaries(graph, maxItems) {
|
|
|
185
185
|
const fileNames = new Set(files.map((file) => file.relativePath));
|
|
186
186
|
const dependsOn = new Set();
|
|
187
187
|
for (const file of files) {
|
|
188
|
-
for (const
|
|
189
|
-
|
|
190
|
-
if (local && !fileNames.has(local))
|
|
188
|
+
for (const local of localDependenciesFor(file.relativePath, graph)) {
|
|
189
|
+
if (!fileNames.has(local))
|
|
191
190
|
dependsOn.add(boundaryName(local));
|
|
192
|
-
const source = imp.source.split('/')[0];
|
|
193
|
-
if (source && !imp.source.startsWith('.'))
|
|
194
|
-
dependsOn.add(source);
|
|
195
191
|
}
|
|
192
|
+
for (const pkg of packageDependenciesFor(file.relativePath, graph))
|
|
193
|
+
dependsOn.add(pkg);
|
|
196
194
|
}
|
|
197
195
|
const publicExports = files
|
|
198
196
|
.flatMap((file) => file.exports.map((entry) => entry.name).filter(Boolean))
|
|
@@ -302,8 +300,7 @@ function reachableFiles(entryFile, graph, maxDepth) {
|
|
|
302
300
|
const graphFile = graph.files.get(current.file);
|
|
303
301
|
if (!graphFile)
|
|
304
302
|
continue;
|
|
305
|
-
for (const
|
|
306
|
-
const target = resolveLocalImport(current.file, imp.source, graph);
|
|
303
|
+
for (const target of localDependenciesFor(current.file, graph)) {
|
|
307
304
|
if (target && !seen.has(target)) {
|
|
308
305
|
seen.add(target);
|
|
309
306
|
result.push(target);
|
|
@@ -313,20 +310,21 @@ function reachableFiles(entryFile, graph, maxDepth) {
|
|
|
313
310
|
}
|
|
314
311
|
return result;
|
|
315
312
|
}
|
|
316
|
-
function
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
313
|
+
function localDependenciesFor(file, graph) {
|
|
314
|
+
const dependencies = [];
|
|
315
|
+
for (const [target, importers] of graph.localImporters) {
|
|
316
|
+
if (importers.has(file))
|
|
317
|
+
dependencies.push(target);
|
|
318
|
+
}
|
|
319
|
+
return dependencies.sort();
|
|
320
|
+
}
|
|
321
|
+
function packageDependenciesFor(file, graph) {
|
|
322
|
+
const dependencies = [];
|
|
323
|
+
for (const [pkg, importers] of graph.packageImporters) {
|
|
324
|
+
if (importers.has(file))
|
|
325
|
+
dependencies.push(pkg);
|
|
326
|
+
}
|
|
327
|
+
return dependencies.sort();
|
|
330
328
|
}
|
|
331
329
|
async function buildContracts(rootPath, graph, files, changedFiles, maxItems) {
|
|
332
330
|
const packageExports = [...packageEntrypointFiles(rootPath)].map((file) => ({
|