hermex 1.3.0-beta.1 → 1.3.0-beta.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/dist/cli.mjs +43 -17
- package/dist/cli.mjs.map +1 -1
- package/package.json +1 -1
package/dist/cli.mjs
CHANGED
|
@@ -11,7 +11,7 @@ import fs$1 from "fs";
|
|
|
11
11
|
import path$1 from "path";
|
|
12
12
|
import semver from "semver";
|
|
13
13
|
import Table from "cli-table3";
|
|
14
|
-
import
|
|
14
|
+
import { load } from "js-yaml";
|
|
15
15
|
import lockfile from "@yarnpkg/lockfile";
|
|
16
16
|
import { pathToFileURL } from "node:url";
|
|
17
17
|
import { z } from "zod";
|
|
@@ -1360,6 +1360,28 @@ function printErrors(errors) {
|
|
|
1360
1360
|
console.log("");
|
|
1361
1361
|
}
|
|
1362
1362
|
//#endregion
|
|
1363
|
+
//#region src/utils/print-json.ts
|
|
1364
|
+
function printJson(aggregated) {
|
|
1365
|
+
const result = {
|
|
1366
|
+
summary: {
|
|
1367
|
+
filesAnalyzed: aggregated.filesAnalyzed,
|
|
1368
|
+
totalImports: aggregated.totalImports,
|
|
1369
|
+
totalComponents: aggregated.totalComponents,
|
|
1370
|
+
totalUsagePatterns: aggregated.totalUsagePatterns
|
|
1371
|
+
},
|
|
1372
|
+
packages: aggregated.packageDistribution,
|
|
1373
|
+
components: aggregated.topComponents.map((c) => ({
|
|
1374
|
+
...c,
|
|
1375
|
+
files: [...c.files]
|
|
1376
|
+
})),
|
|
1377
|
+
patterns: aggregated.patternCounts,
|
|
1378
|
+
versus: aggregated.versusResults,
|
|
1379
|
+
ruleViolations: aggregated.ruleViolations,
|
|
1380
|
+
bannedPackageViolations: aggregated.bannedPackageViolations
|
|
1381
|
+
};
|
|
1382
|
+
process.stdout.write(JSON.stringify(result, null, 2) + "\n");
|
|
1383
|
+
}
|
|
1384
|
+
//#endregion
|
|
1363
1385
|
//#region src/utils/file-utils.ts
|
|
1364
1386
|
/**
|
|
1365
1387
|
* Find files matching a glob pattern
|
|
@@ -1453,8 +1475,7 @@ var PnpmLockfileAdapter = class {
|
|
|
1453
1475
|
}
|
|
1454
1476
|
parse(lockFilePath) {
|
|
1455
1477
|
try {
|
|
1456
|
-
const
|
|
1457
|
-
const lockData = yaml.load(content);
|
|
1478
|
+
const lockData = load(fs$1.readFileSync(lockFilePath, "utf8"));
|
|
1458
1479
|
const versions = {};
|
|
1459
1480
|
if (lockData.importers) {
|
|
1460
1481
|
const rootImporter = lockData.importers["."];
|
|
@@ -1614,7 +1635,8 @@ const HermexConfigSchema = z.object({
|
|
|
1614
1635
|
patterns: z.union([z.enum(["table", "chart"]), z.literal(false)]).default("table"),
|
|
1615
1636
|
details: z.boolean().default(false),
|
|
1616
1637
|
versus: z.boolean().default(true),
|
|
1617
|
-
rules: z.boolean().default(true)
|
|
1638
|
+
rules: z.boolean().default(true),
|
|
1639
|
+
format: z.enum(["human", "json"]).default("human")
|
|
1618
1640
|
}).default(() => ({
|
|
1619
1641
|
summary: "log",
|
|
1620
1642
|
components: "table",
|
|
@@ -1622,7 +1644,8 @@ const HermexConfigSchema = z.object({
|
|
|
1622
1644
|
patterns: "table",
|
|
1623
1645
|
details: false,
|
|
1624
1646
|
versus: true,
|
|
1625
|
-
rules: true
|
|
1647
|
+
rules: true,
|
|
1648
|
+
format: "human"
|
|
1626
1649
|
})),
|
|
1627
1650
|
releaseAge: z.object({
|
|
1628
1651
|
enabled: z.boolean().default(false),
|
|
@@ -1649,10 +1672,11 @@ const HermexConfigSchema = z.object({
|
|
|
1649
1672
|
});
|
|
1650
1673
|
//#endregion
|
|
1651
1674
|
//#region src/config/loader.ts
|
|
1652
|
-
async function loadConfig(cwd) {
|
|
1653
|
-
const configPath = join(cwd, "hermex.config.ts");
|
|
1675
|
+
async function loadConfig(cwd, explicitPath) {
|
|
1676
|
+
const configPath = explicitPath ? resolve(explicitPath) : join(cwd, "hermex.config.ts");
|
|
1677
|
+
if (explicitPath && !existsSync(configPath)) throw new Error(`Config file not found: ${configPath}`);
|
|
1654
1678
|
if (existsSync(configPath)) {
|
|
1655
|
-
const mod = await import(pathToFileURL(
|
|
1679
|
+
const mod = await import(pathToFileURL(configPath).href);
|
|
1656
1680
|
return HermexConfigSchema.parse(mod.default ?? mod);
|
|
1657
1681
|
}
|
|
1658
1682
|
return HermexConfigSchema.parse({});
|
|
@@ -1769,13 +1793,17 @@ async function enrichWithReleaseAge(packages, config) {
|
|
|
1769
1793
|
//#endregion
|
|
1770
1794
|
//#region src/commands/scan.ts
|
|
1771
1795
|
function registerScanCommand(program) {
|
|
1772
|
-
program.command("scan").description("Scan and analyze local files").action(async () => {
|
|
1773
|
-
await executeScan(await loadConfig(process.cwd()));
|
|
1796
|
+
program.command("scan").description("Scan and analyze local files").option("--config <path>", "Path to hermex config file (overrides CWD discovery)").action(async (options) => {
|
|
1797
|
+
await executeScan(await loadConfig(process.cwd(), options.config));
|
|
1774
1798
|
});
|
|
1775
1799
|
}
|
|
1776
1800
|
async function executeScan(config) {
|
|
1777
1801
|
const startTime = Date.now();
|
|
1778
|
-
const
|
|
1802
|
+
const isJson = config.output.format === "json";
|
|
1803
|
+
const spinner = ora({
|
|
1804
|
+
text: "Parsing lockfile...",
|
|
1805
|
+
stream: isJson ? process.stderr : process.stdout
|
|
1806
|
+
}).start();
|
|
1779
1807
|
try {
|
|
1780
1808
|
const lockfileResult = findAndParseLockfile(process.cwd());
|
|
1781
1809
|
spinner.succeed(chalk.blue(`📦 Found ${lockfileResult.lockfileType} lockfile (supports: ${lockfileResult.supportedVersions.join(", ")}) - ${Object.keys(lockfileResult.versions).length} packages`));
|
|
@@ -1814,7 +1842,8 @@ async function executeScan(config) {
|
|
|
1814
1842
|
aggregated.packageDistribution = enriched;
|
|
1815
1843
|
spinner.succeed(chalk.blue(`📅 Release age fetched${skipped > 0 ? chalk.gray(` (${skipped} packages skipped — registry unreachable or not found)`) : ""}`));
|
|
1816
1844
|
}
|
|
1817
|
-
|
|
1845
|
+
if (isJson) printJson(aggregated);
|
|
1846
|
+
else printScanResults(aggregated, config, elapsedTime);
|
|
1818
1847
|
} catch (error) {
|
|
1819
1848
|
spinner.fail(chalk.red("Analysis failed: " + error.message));
|
|
1820
1849
|
console.error(error);
|
|
@@ -1832,17 +1861,14 @@ function printScanResults(aggregated, config, _elapsedTime) {
|
|
|
1832
1861
|
}
|
|
1833
1862
|
//#endregion
|
|
1834
1863
|
//#region package.json
|
|
1835
|
-
var version = "1.
|
|
1864
|
+
var version = "1.3.0-beta.1";
|
|
1836
1865
|
//#endregion
|
|
1837
1866
|
//#region src/cli.ts
|
|
1838
1867
|
const program = new Command();
|
|
1839
|
-
function defineConfig(config) {
|
|
1840
|
-
return config;
|
|
1841
|
-
}
|
|
1842
1868
|
program.name("hermex").description("Analyze React component usage patterns in your codebase").version(version);
|
|
1843
1869
|
registerScanCommand(program);
|
|
1844
1870
|
program.parse(process.argv);
|
|
1845
1871
|
//#endregion
|
|
1846
|
-
export {
|
|
1872
|
+
export { program };
|
|
1847
1873
|
|
|
1848
1874
|
//# sourceMappingURL=cli.mjs.map
|
package/dist/cli.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.mjs","names":["path","fs","printHeader","printHeader","printHeader","printHeader","path","fs","path","fs","path","fs","packageJson.version"],"sources":["../src/swc-parser/core/state.ts","../src/swc-parser/patterns/imports.ts","../src/swc-parser/utils/jsx-helpers.ts","../src/swc-parser/patterns/props.ts","../src/swc-parser/patterns/jsx.ts","../src/swc-parser/utils/matchers.ts","../src/swc-parser/patterns/variables.ts","../src/swc-parser/patterns/conditionals.ts","../src/swc-parser/patterns/collections.ts","../src/swc-parser/patterns/lazy-dynamic.ts","../src/swc-parser/patterns/advanced.ts","../src/swc-parser/core/visitor.ts","../src/swc-parser/core/report.ts","../src/swc-parser/index.ts","../src/rules/shared.ts","../src/rules/file-rules.ts","../src/rules/script-rules.ts","../src/rules/package-field-rules.ts","../src/rules/engine-version.ts","../src/rules/evaluator.ts","../src/utils/aggregator.ts","../src/utils/format-utils.ts","../src/utils/print-summary.ts","../src/utils/print-details.ts","../src/utils/chart-renderer.ts","../src/utils/print-components.ts","../src/utils/print-patterns.ts","../src/utils/print-packages.ts","../src/utils/print-versus.ts","../src/utils/print-rules.ts","../src/utils/print-errors.ts","../src/utils/file-utils.ts","../src/lock-parser/patterns/npm.ts","../src/lock-parser/patterns/pnpm.ts","../src/lock-parser/patterns/yarn.ts","../src/lock-parser/index.ts","../src/config/schema.ts","../src/config/loader.ts","../src/npm-registry/client.ts","../src/npm-registry/enricher.ts","../src/commands/scan.ts","../package.json","../src/cli.ts"],"sourcesContent":["import type { ParserState, UsagePatterns } from '../types';\n\nexport function createState(): ParserState {\n const usagePatterns: UsagePatterns = {\n directImports: new Set(),\n namedImports: new Set(),\n namespaceImports: new Set(),\n defaultImports: new Set(),\n aliasedImports: new Map(),\n variableAssignments: new Map(),\n componentMappings: new Set(),\n lazyImports: new Set(),\n dynamicImports: new Set(),\n conditionalUsage: new Set(),\n arrayMappings: new Set(),\n objectMappings: new Set(),\n hocUsage: new Set(),\n renderProps: new Set(),\n contextUsage: new Set(),\n forwardedRefs: new Set(),\n memoizedComponents: new Set(),\n portalUsage: new Set(),\n jsxUsage: new Map(),\n destructuredUsage: new Set(),\n propsAnalysis: new Map(),\n };\n\n return {\n usagePatterns,\n componentNames: new Set(),\n allIdentifiers: new Set(),\n };\n}\n","import type { ImportDeclaration } from '@swc/core';\nimport type { ParserState } from '../types';\n\n/**\n * Analyzes import declarations and tracks all types:\n * - Default imports\n * - Named imports\n * - Namespace imports\n * - Aliased imports\n */\nexport function analyzeImportDeclaration(\n node: ImportDeclaration,\n state: ParserState,\n): void {\n const source = node.source.value;\n\n // console.log(`📦 Found import: ${source}`);\n\n for (const spec of node.specifiers) {\n switch (spec.type) {\n case 'ImportDefaultSpecifier':\n analyzeDefaultImport(spec, source, node, state);\n break;\n\n case 'ImportNamespaceSpecifier':\n analyzeNamespaceImport(spec, source, node, state);\n break;\n\n case 'ImportSpecifier':\n analyzeNamedImport(spec, source, node, state);\n break;\n }\n }\n}\n\nfunction analyzeDefaultImport(\n spec: any,\n source: string,\n node: ImportDeclaration,\n state: ParserState,\n): void {\n const name = spec.local.value;\n\n state.usagePatterns.defaultImports.add({\n name,\n source,\n line: node.span?.start || 0,\n });\n\n state.componentNames.add(name);\n}\n\nfunction analyzeNamespaceImport(\n spec: any,\n source: string,\n node: ImportDeclaration,\n state: ParserState,\n): void {\n const name = spec.local.value;\n\n state.usagePatterns.namespaceImports.add({\n name,\n source,\n line: node.span?.start || 0,\n });\n\n state.allIdentifiers.add(name);\n}\n\nfunction analyzeNamedImport(\n spec: any,\n source: string,\n node: ImportDeclaration,\n state: ParserState,\n): void {\n const importedName = spec.imported ? spec.imported.value : spec.local.value;\n const localName = spec.local.value;\n\n state.usagePatterns.namedImports.add({\n name: importedName,\n source,\n line: node.span?.start || 0,\n });\n\n // Track aliases\n if (importedName !== localName) {\n state.usagePatterns.aliasedImports.set(localName, {\n imported: importedName,\n local: localName,\n source,\n line: node.span?.start || 0,\n });\n }\n\n state.componentNames.add(localName);\n}\n","import type { ParserState } from '../types';\n\n/**\n * Extracts the name from a JSX element (handles identifiers and member expressions)\n */\nexport function getJSXElementName(nameNode: any): string {\n if (!nameNode) return '';\n\n switch (nameNode.type) {\n case 'Identifier':\n return nameNode.value;\n case 'JSXMemberExpression':\n return `${getJSXElementName(nameNode.object)}.${nameNode.property.value}`;\n default:\n return '';\n }\n}\n\n/**\n * Checks if a JSX member expression is a known component\n */\nexport function isMemberExpressionComponent(\n nameNode: any,\n state: ParserState,\n): boolean {\n if (nameNode?.type === 'JSXMemberExpression') {\n const objectName = getJSXElementName(nameNode.object);\n return state.allIdentifiers.has(objectName);\n }\n return false;\n}\n\n/**\n * Extracts props from JSX attributes\n */\nexport function extractJSXProps(attributes: any[]): Array<{\n name: string;\n value: any;\n isSpread?: boolean;\n}> {\n if (!attributes) return [];\n\n return attributes\n .map((attr) => {\n if (attr.type === 'JSXAttribute') {\n return {\n name: attr.name?.value || attr.name?.name?.value,\n value: extractJSXAttributeValue(attr.value),\n };\n }\n if (attr.type === 'SpreadElement') {\n return {\n name: '...',\n value: '[spread]',\n isSpread: true,\n };\n }\n return null;\n })\n .filter(Boolean) as Array<{\n name: string;\n value: any;\n isSpread?: boolean;\n }>;\n}\n\n/**\n * Extracts value from JSX attribute\n */\nexport function extractJSXAttributeValue(value: any): any {\n if (!value) return true; // boolean attribute\n\n switch (value.type) {\n case 'StringLiteral':\n return value.value;\n case 'JSXExpressionContainer':\n return extractExpressionValue(value.expression);\n default:\n return '[complex]';\n }\n}\n\n/**\n * Extracts a readable value from an expression\n */\nexport function extractExpressionValue(expr: any): any {\n if (!expr) return '[unknown]';\n\n switch (expr.type) {\n case 'StringLiteral':\n case 'NumericLiteral':\n case 'BooleanLiteral':\n return expr.value;\n case 'Identifier':\n return `{${expr.value}}`;\n case 'ArrowFunctionExpression':\n case 'FunctionExpression':\n return '[function]';\n case 'ObjectExpression':\n return '[object]';\n case 'ArrayExpression':\n return '[array]';\n default:\n return '[expression]';\n }\n}\n\n/**\n * Determines the context where a component is being used\n */\nexport function getUsageContext(parent: any): string {\n if (!parent) return 'direct';\n\n switch (parent.type) {\n case 'ConditionalExpression':\n return 'conditional';\n case 'ArrayExpression':\n return 'array';\n case 'ObjectExpression':\n return 'object';\n case 'CallExpression':\n return 'hoc';\n case 'VariableDeclarator':\n return 'variable';\n default:\n return 'jsx';\n }\n}\n","import type { PropsAnalysis, PropDetail, ParserState } from '../types';\n\n/**\n * Analyzes props in detail for a component\n */\nexport function analyzePropsInDetail(\n attributes: any[],\n componentName: string,\n state: ParserState,\n): PropsAnalysis {\n const analysis: PropsAnalysis = {\n namedProps: [],\n hasSpread: false,\n hasComplexProps: false,\n hasEventHandlers: false,\n propDetails: [],\n };\n\n if (!attributes) return analysis;\n\n for (const attr of attributes) {\n if (attr.type === 'JSXAttribute') {\n const propName = attr.name?.value || attr.name?.name?.value;\n if (propName) {\n analysis.namedProps.push(propName);\n\n const propDetail: PropDetail = {\n name: propName,\n type: getPropType(attr.value),\n isEventHandler: propName.startsWith('on'),\n isComplex: isComplexProp(attr.value),\n };\n\n if (propDetail.isEventHandler) {\n analysis.hasEventHandlers = true;\n }\n if (propDetail.isComplex) {\n analysis.hasComplexProps = true;\n }\n\n analysis.propDetails.push(propDetail);\n }\n } else if (attr.type === 'SpreadElement') {\n analysis.hasSpread = true;\n analysis.propDetails.push({\n name: '...',\n type: 'spread',\n isSpread: true,\n isComplex: true,\n isEventHandler: false,\n warning: 'Spread props cannot be statically analyzed',\n });\n analysis.hasComplexProps = true;\n }\n }\n\n // Store in state\n state.usagePatterns.propsAnalysis.set(componentName, analysis);\n\n return analysis;\n}\n\n/**\n * Determines the type of a prop value\n */\nfunction getPropType(value: any): string {\n if (!value) return 'boolean';\n\n switch (value.type) {\n case 'StringLiteral':\n return 'string';\n case 'JSXExpressionContainer': {\n const expr = value.expression;\n if (!expr) return 'unknown';\n switch (expr.type) {\n case 'NumericLiteral':\n return 'number';\n case 'BooleanLiteral':\n return 'boolean';\n case 'StringLiteral':\n return 'string';\n case 'ArrowFunctionExpression':\n case 'FunctionExpression':\n return 'function';\n case 'ObjectExpression':\n return 'object';\n case 'ArrayExpression':\n return 'array';\n case 'Identifier':\n return 'variable';\n default:\n return 'expression';\n }\n }\n default:\n return 'unknown';\n }\n}\n\n/**\n * Checks if a prop value is complex (object, array, call, conditional)\n */\nfunction isComplexProp(value: any): boolean {\n if (!value) return false;\n if (value.type === 'JSXExpressionContainer') {\n const expr = value.expression;\n if (!expr) return false;\n return (\n expr.type === 'ObjectExpression' ||\n expr.type === 'ArrayExpression' ||\n expr.type === 'CallExpression' ||\n expr.type === 'ConditionalExpression'\n );\n }\n return false;\n}\n","import type { ParserState, JSXUsage } from '../types';\nimport {\n getJSXElementName,\n isMemberExpressionComponent,\n extractJSXProps,\n getUsageContext,\n} from '../utils/jsx-helpers';\nimport { analyzePropsInDetail } from './props';\n\n/**\n * Analyzes JSX element usage\n */\nexport function analyzeJSXElement(node: any, state: ParserState): void {\n if (node.opening) {\n analyzeJSXOpeningElement(node.opening, state, node);\n }\n}\n\n/**\n * Analyzes JSX opening element and tracks component usage\n */\nexport function analyzeJSXOpeningElement(\n node: any,\n state: ParserState,\n parent?: any,\n): void {\n const elementName = getJSXElementName(node.name);\n\n // Check if this is a known component\n if (\n !state.componentNames.has(elementName) &&\n !isMemberExpressionComponent(node.name, state)\n ) {\n return;\n }\n\n const propsAnalysis = analyzePropsInDetail(\n node.attributes,\n elementName,\n state,\n );\n const usage: JSXUsage = {\n component: elementName,\n props: extractJSXProps(node.attributes).map((p) => p.name),\n propsAnalysis,\n line: node.span?.start || 0,\n context: getUsageContext(parent),\n };\n\n // Track JSX usage\n if (!state.usagePatterns.jsxUsage.has(elementName)) {\n state.usagePatterns.jsxUsage.set(elementName, usage);\n }\n\n // console.log(`🎨 JSX Usage: <${elementName}>`);\n}\n","import type { ParserState } from '../types';\n\n/**\n * Checks if a name is a known component from imports\n */\nexport function isKnownComponent(name: string, state: ParserState): boolean {\n return state.componentNames.has(name) || state.allIdentifiers.has(name);\n}\n\n/**\n * Checks if a function name matches HOC patterns\n */\nexport function isHOCPattern(name: string): boolean {\n const hocPatterns = ['with', 'enhance', 'wrap', 'connect', 'create'];\n return hocPatterns.some((pattern) => name.startsWith(pattern));\n}\n\n/**\n * Checks if a node represents a HOC function call\n */\nexport function isHOCFunction(callee: any): boolean {\n if (!callee) return false;\n\n if (callee.type === 'Identifier') {\n return isHOCPattern(callee.value);\n }\n\n if (callee.type === 'MemberExpression') {\n const prop = callee.property;\n return prop?.value && isHOCPattern(prop.value);\n }\n\n return false;\n}\n\n/**\n * Checks if an expression looks like a React component\n * (starts with capital letter)\n */\nexport function looksLikeComponent(name: string): boolean {\n return /^[A-Z]/.test(name);\n}\n\n/**\n * Checks if source is from a specific library (for filtering)\n */\nexport function isFromLibrary(source: string, libraryName: string): boolean {\n return source.startsWith(libraryName) || source.includes(libraryName);\n}\n","import type { ParserState } from '../types';\nimport { isKnownComponent } from '../utils/matchers';\n\n/**\n * Analyzes variable declarations for component assignments\n */\nexport function analyzeVariableDeclaration(\n node: any,\n state: ParserState,\n): void {\n if (!node.declarations) return;\n\n for (const decl of node.declarations) {\n if (decl.id?.type === 'Identifier') {\n const varName = decl.id.value;\n\n // Check if it's assigning a component\n if (decl.init) {\n const assignment = extractAssignmentInfo(decl.init);\n if (assignment && isKnownComponent(assignment, state)) {\n state.usagePatterns.variableAssignments.set(varName, {\n assignment,\n line: node.span?.start || 0,\n });\n state.componentNames.add(varName);\n // console.log(`📝 Variable assignment: ${varName} = ${assignment}`);\n }\n }\n }\n\n // Handle destructuring assignments\n if (decl.id?.type === 'ObjectPattern') {\n analyzeDestructuringPattern(decl.id, decl.init, state);\n }\n }\n}\n\n/**\n * Analyzes destructuring patterns\n */\nexport function analyzeDestructuringPattern(\n pattern: any,\n init: any,\n state: ParserState,\n): void {\n if (!pattern.properties) return;\n\n for (const prop of pattern.properties) {\n if (\n prop.type === 'AssignmentPatternProperty' &&\n prop.key?.type === 'Identifier'\n ) {\n const propName = prop.key.value;\n\n if (init?.type === 'Identifier' && state.allIdentifiers.has(init.value)) {\n state.usagePatterns.destructuredUsage.add({\n property: propName,\n source: init.value,\n line: pattern.span?.start || 0,\n });\n state.componentNames.add(propName);\n // console.log(`🔧 Destructuring: ${propName} from ${init.value}`);\n }\n }\n }\n}\n\n/**\n * Extracts assignment information from various node types\n */\nfunction extractAssignmentInfo(node: any): string | null {\n switch (node.type) {\n case 'Identifier':\n return node.value;\n case 'MemberExpression':\n return `${extractAssignmentInfo(node.object)}.${node.property.value}`;\n case 'ConditionalExpression':\n return `${extractAssignmentInfo(node.consequent)} | ${extractAssignmentInfo(node.alternate)}`;\n default:\n return null;\n }\n}\n","import type { ParserState } from '../types';\n\n/**\n * Analyzes conditional expressions (ternary operators) with components\n */\nexport function analyzeConditionalExpression(\n node: any,\n state: ParserState,\n): void {\n const consequent =\n node.consequent?.type === 'Identifier' ? node.consequent.value : null;\n const alternate =\n node.alternate?.type === 'Identifier' ? node.alternate.value : null;\n\n if (\n (consequent && state.componentNames.has(consequent)) ||\n (alternate && state.componentNames.has(alternate))\n ) {\n state.usagePatterns.conditionalUsage.add({\n consequent: consequent || '',\n alternate: alternate || '',\n line: node.span?.start || 0,\n });\n // console.log('🔀 Conditional component usage found');\n }\n}\n","import type { ParserState } from '../types';\n\n/**\n * Analyzes array expressions containing components\n */\nexport function analyzeArrayExpression(node: any, state: ParserState): void {\n // Check if array contains components\n const hasComponents = node.elements?.some((elem: any) => {\n if (elem?.type === 'Identifier') {\n return state.componentNames.has(elem.value);\n }\n return false;\n });\n\n if (hasComponents) {\n state.usagePatterns.arrayMappings.add({\n components: node.elements\n ?.map((elem: any) => elem?.value)\n .filter(Boolean),\n line: node.span?.start || 0,\n });\n // console.log('📋 Array with components found');\n }\n}\n\n/**\n * Analyzes object expressions with component mappings\n */\nexport function analyzeObjectExpression(node: any, state: ParserState): void {\n // Check if object contains component mappings\n const componentProps = node.properties?.filter((prop: any) => {\n if (prop.type === 'KeyValueProperty' && prop.value?.type === 'Identifier') {\n return state.componentNames.has(prop.value.value);\n }\n return false;\n });\n\n if (componentProps?.length > 0) {\n state.usagePatterns.objectMappings.add({\n mappings: componentProps.map((prop: any) => ({\n key: prop.key?.value || '[computed]',\n component: prop.value?.value,\n })),\n line: node.span?.start || 0,\n });\n // console.log('🗺️ Object mapping with components found');\n }\n}\n","import type { ParserState } from '../types';\n\n/**\n * Analyzes React.lazy() imports\n */\nexport function analyzeLazyImport(node: any, state: ParserState): void {\n const arg = node.arguments?.[0];\n if (\n arg?.type === 'ArrowFunctionExpression' &&\n arg.body?.type === 'CallExpression'\n ) {\n const importCall = arg.body;\n if (importCall.callee?.type === 'Import') {\n const source = importCall.arguments?.[0]?.value;\n if (source) {\n state.usagePatterns.lazyImports.add({\n source,\n line: node.span?.start || 0,\n });\n // console.log(`🔄 Found lazy import: ${source}`);\n }\n }\n }\n}\n\n/**\n * Analyzes dynamic import() calls\n */\nexport function analyzeDynamicImport(node: any, state: ParserState): void {\n const source = node.arguments?.[0]?.value;\n if (source) {\n state.usagePatterns.dynamicImports.add({\n source,\n line: node.span?.start || 0,\n });\n // console.log(`⚡ Found dynamic import: ${source}`);\n }\n}\n","import type { ParserState } from '../types';\n\n/**\n * Analyzes Higher-Order Component (HOC) usage\n */\nexport function analyzeHOCUsage(node: any, state: ParserState): void {\n state.usagePatterns.hocUsage.add({\n function: node.callee?.value || '[unknown]',\n component: node.arguments?.[0]?.value || '[unknown]',\n line: node.span?.start || 0,\n });\n // console.log(`🎁 HOC usage found`);\n}\n\n/**\n * Analyzes React.memo() usage\n */\nexport function analyzeMemoUsage(node: any, state: ParserState): void {\n const component = node.arguments?.[0];\n if (\n component?.type === 'Identifier' &&\n state.componentNames.has(component.value)\n ) {\n state.usagePatterns.memoizedComponents.add({\n component: component.value,\n line: node.span?.start || 0,\n });\n // console.log(`🧠 Memoized component: ${component.value}`);\n }\n}\n\n/**\n * Analyzes React.forwardRef() usage\n */\nexport function analyzeForwardRefUsage(node: any, state: ParserState): void {\n state.usagePatterns.forwardedRefs.add({\n line: node.span?.start || 0,\n });\n // console.log('↗️ ForwardRef usage found');\n}\n\n/**\n * Analyzes ReactDOM.createPortal() usage\n */\nexport function analyzePortalUsage(node: any, state: ParserState): void {\n state.usagePatterns.portalUsage.add({\n line: node.span?.start || 0,\n });\n // console.log('🌀 Portal usage found');\n}\n\n/**\n * Analyzes member expression access (e.g., Foundation.Button)\n */\nexport function analyzeMemberExpression(node: any, state: ParserState): void {\n // Check if this is a namespace access like Foundation.Button\n if (\n node.object?.type === 'Identifier' &&\n state.allIdentifiers.has(node.object.value)\n ) {\n // const namespaceName = node.object.value;\n const propertyName = node.property?.value;\n\n if (propertyName) {\n // Track namespace property access\n state.componentNames.add(propertyName);\n // console.log(`🔗 Namespace access: ${namespaceName}.${propertyName}`);\n }\n }\n}\n\n/**\n * Checks if a node represents HOC pattern\n */\nexport function isHOCPattern(node: any, state: ParserState): boolean {\n // Simple heuristic: function that returns a component-like structure\n return (\n node.callee?.type === 'Identifier' &&\n node.arguments?.some(\n (arg: any) =>\n arg.type === 'Identifier' && state.componentNames.has(arg.value),\n )\n );\n}\n","import type { ParserState, VisitorContext } from '../types';\nimport { analyzeImportDeclaration } from '../patterns/imports';\nimport { analyzeJSXElement, analyzeJSXOpeningElement } from '../patterns/jsx';\nimport { analyzeVariableDeclaration } from '../patterns/variables';\nimport { analyzeConditionalExpression } from '../patterns/conditionals';\nimport {\n analyzeArrayExpression,\n analyzeObjectExpression,\n} from '../patterns/collections';\nimport {\n analyzeLazyImport,\n analyzeDynamicImport,\n} from '../patterns/lazy-dynamic';\nimport {\n analyzeHOCUsage,\n analyzeMemoUsage,\n analyzeForwardRefUsage,\n analyzePortalUsage,\n analyzeMemberExpression,\n isHOCPattern,\n} from '../patterns/advanced';\n\n/**\n * Main AST visitor that routes nodes to appropriate pattern analyzers\n */\nexport function visitNode(\n node: any,\n state: ParserState,\n context: VisitorContext = {},\n): void {\n if (!node) return;\n\n switch (node.type) {\n case 'Module':\n // Process imports first (they populate componentNames)\n if (node.body) {\n for (const item of node.body) {\n if (item.type === 'ImportDeclaration') {\n visitNode(item, state, context);\n }\n }\n // Then process everything else\n for (const item of node.body) {\n if (item.type !== 'ImportDeclaration') {\n visitNode(item, state, { ...context, parent: node });\n }\n }\n }\n break;\n\n case 'ImportDeclaration':\n analyzeImportDeclaration(node, state);\n break;\n\n case 'CallExpression':\n analyzeCallExpression(node, state, context);\n break;\n\n case 'VariableDeclaration':\n analyzeVariableDeclaration(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'JSXElement':\n case 'JSXFragment':\n analyzeJSXElement(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'JSXOpeningElement':\n analyzeJSXOpeningElement(node, state, context.parent);\n break;\n\n case 'ArrayExpression':\n analyzeArrayExpression(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'ObjectExpression':\n analyzeObjectExpression(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'MemberExpression':\n analyzeMemberExpression(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'ConditionalExpression':\n analyzeConditionalExpression(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'FunctionDeclaration':\n case 'ClassDeclaration':\n case 'ExpressionStatement':\n case 'ReturnStatement':\n case 'VariableDeclarator':\n case 'ArrowFunctionExpression':\n case 'FunctionExpression':\n visitChildren(node, state, { ...context, parent: node });\n break;\n\n default:\n visitChildren(node, state, context);\n break;\n }\n}\n\n/**\n * Analyzes call expressions and routes to specific analyzers\n */\nfunction analyzeCallExpression(\n node: any,\n state: ParserState,\n context: VisitorContext,\n): void {\n // Analyze lazy imports\n if (\n node.callee?.value === 'lazy' ||\n (node.callee?.object?.value === 'React' &&\n node.callee?.property?.value === 'lazy')\n ) {\n analyzeLazyImport(node, state);\n }\n\n // Analyze dynamic imports\n if (node.callee?.type === 'Import') {\n analyzeDynamicImport(node, state);\n }\n\n // Analyze HOC patterns\n if (isHOCPattern(node, state)) {\n analyzeHOCUsage(node, state);\n }\n\n // Analyze React.memo, React.forwardRef\n if (node.callee?.object?.value === 'React') {\n if (node.callee?.property?.value === 'memo') {\n analyzeMemoUsage(node, state);\n } else if (node.callee?.property?.value === 'forwardRef') {\n analyzeForwardRefUsage(node, state);\n }\n }\n\n // Analyze createPortal\n if (\n node.callee?.property?.value === 'createPortal' ||\n node.callee?.value === 'createPortal'\n ) {\n analyzePortalUsage(node, state);\n }\n\n visitChildren(node, state, context);\n}\n\n/**\n * Visits all children of a node\n */\nfunction visitChildren(\n node: any,\n state: ParserState,\n context: VisitorContext,\n): void {\n if (!node) return;\n\n for (const key in node) {\n const value = node[key];\n\n if (Array.isArray(value)) {\n for (const item of value) {\n if (item && typeof item === 'object') {\n visitNode(item, state, { ...context, parent: node });\n }\n }\n } else if (value && typeof value === 'object' && value.type) {\n visitNode(value, state, { ...context, parent: node });\n }\n }\n}\n","import type { ParserState, UsageReport } from '../types';\n\n/**\n * Generates a comprehensive usage report from parser state\n */\nexport function generateReport(state: ParserState): UsageReport {\n const report: UsageReport = {\n summary: {\n totalImports:\n state.usagePatterns.defaultImports.size +\n state.usagePatterns.namedImports.size +\n state.usagePatterns.namespaceImports.size,\n totalComponents: state.componentNames.size,\n totalUsagePatterns: calculateTotalPatterns(state),\n },\n patterns: {\n imports: {\n default: Array.from(state.usagePatterns.defaultImports),\n named: Array.from(state.usagePatterns.namedImports),\n namespace: Array.from(state.usagePatterns.namespaceImports),\n aliased: Array.from(state.usagePatterns.aliasedImports.values()),\n },\n usage: {\n jsx: Array.from(state.usagePatterns.jsxUsage.values()),\n variables: Array.from(\n state.usagePatterns.variableAssignments.entries(),\n ).map(([key, value]) => ({\n variable: key,\n assignment: value.assignment,\n })),\n destructuring: Array.from(state.usagePatterns.destructuredUsage),\n conditional: Array.from(state.usagePatterns.conditionalUsage),\n arrays: Array.from(state.usagePatterns.arrayMappings),\n objects: Array.from(state.usagePatterns.objectMappings),\n },\n advanced: {\n lazy: Array.from(state.usagePatterns.lazyImports),\n dynamic: Array.from(state.usagePatterns.dynamicImports),\n hoc: Array.from(state.usagePatterns.hocUsage),\n memo: Array.from(state.usagePatterns.memoizedComponents),\n forwardRef: Array.from(state.usagePatterns.forwardedRefs),\n portal: Array.from(state.usagePatterns.portalUsage),\n },\n props: Array.from(state.usagePatterns.propsAnalysis.entries()).map(\n ([component, analysis]) => ({\n component,\n analysis,\n }),\n ),\n },\n components: Array.from(state.componentNames).sort(),\n };\n\n return report;\n}\n\n/**\n * Calculates total number of usage patterns found\n */\nfunction calculateTotalPatterns(state: ParserState): number {\n let sum = 0;\n const patterns = state.usagePatterns;\n\n for (const key in patterns) {\n const pattern = (patterns as any)[key];\n if (pattern instanceof Set) {\n sum += pattern.size;\n } else if (pattern instanceof Map) {\n sum += pattern.size;\n }\n }\n\n return sum;\n}\n","import { parseSync } from '@swc/core';\nimport type { ParseOptions as SwcParseOptions } from '@swc/core';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport type { UsageReport } from './types';\nimport { createState } from './core/state';\nimport { visitNode } from './core/visitor';\nimport { generateReport } from './core/report';\n\nfunction swcOptionsForFile(filePath: string): SwcParseOptions {\n const ext = path.extname(filePath).toLowerCase();\n if (ext === '.ts')\n return {\n syntax: 'typescript',\n tsx: false,\n decorators: true,\n dynamicImport: true,\n };\n if (ext === '.tsx')\n return {\n syntax: 'typescript',\n tsx: true,\n decorators: true,\n dynamicImport: true,\n };\n if (ext === '.jsx')\n return {\n syntax: 'ecmascript',\n jsx: true,\n decorators: true,\n importAssertions: true,\n };\n // .js / .mjs / .cjs\n return {\n syntax: 'ecmascript',\n jsx: false,\n decorators: true,\n importAssertions: true,\n };\n}\n\nexport function parseCode(code: string, filePath = 'file.tsx'): UsageReport {\n const state = createState();\n const ast = parseSync(code, swcOptionsForFile(filePath));\n visitNode(ast, state);\n return generateReport(state);\n}\n\nexport function parseFile(filePath: string): UsageReport | null {\n const code = fs.readFileSync(filePath, 'utf8');\n return parseCode(code, filePath);\n}\n\nexport type { UsageReport } from './types';\n","import { globSync } from 'glob';\nimport fs from 'fs';\nimport path from 'path';\n\nexport interface RuleViolation {\n type:\n | 'forbid_files'\n | 'require_files'\n | 'allow_files'\n | 'forbid_packages'\n | 'require_packages'\n | 'require_scripts'\n | 'require_package_fields'\n | 'engine_version';\n severity: 'error' | 'warn';\n patterns: string[];\n message?: string;\n matchedFiles: string[];\n // engine_version only\n installedRange?: string;\n requiredRange?: string;\n}\n\nexport function toArray<T>(val: T | T[] | undefined): T[] {\n if (!val) return [];\n return Array.isArray(val) ? val : [val];\n}\n\nexport function findMatches(\n patterns: string[],\n repoPath: string,\n ignore: string[],\n): string[] {\n const matches: string[] = [];\n for (const pattern of patterns) {\n const found = globSync(pattern, { cwd: repoPath, nodir: true, ignore });\n matches.push(...found.map((f) => path.join(repoPath, f)));\n }\n return [...new Set(matches)];\n}\n\nexport function readPackageJson(\n repoPath: string,\n): Record<string, unknown> | null {\n try {\n const content = fs.readFileSync(\n path.join(repoPath, 'package.json'),\n 'utf-8',\n );\n return JSON.parse(content) as Record<string, unknown>;\n } catch {\n return null;\n }\n}\n","import type { RulesConfig } from '../config/types';\nimport { toArray, findMatches } from './shared';\nimport type { RuleViolation } from './shared';\n\nexport function evaluateFileRules(\n repoPath: string,\n rulesConfig: RulesConfig,\n excludes: string[],\n): RuleViolation[] {\n const violations: RuleViolation[] = [];\n\n for (const rule of toArray(rulesConfig.forbid_files)) {\n const matches = findMatches(rule.patterns, repoPath, excludes);\n if (matches.length > 0) {\n violations.push({\n type: 'forbid_files',\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: matches,\n });\n }\n }\n\n for (const rule of toArray(rulesConfig.require_files)) {\n const matches = findMatches(rule.patterns, repoPath, excludes);\n if (matches.length === 0) {\n violations.push({\n type: 'require_files',\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: [],\n });\n }\n }\n\n for (const rule of toArray(rulesConfig.allow_files)) {\n const matches = findMatches(rule.patterns, repoPath, excludes);\n if (matches.length === 0) {\n violations.push({\n type: 'allow_files',\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: [],\n });\n }\n }\n\n return violations;\n}\n","import micromatch from 'micromatch';\nimport type { RulesConfig } from '../config/types';\nimport { toArray, readPackageJson } from './shared';\nimport type { RuleViolation } from './shared';\n\nexport function evaluateScriptRules(\n repoPath: string,\n rulesConfig: RulesConfig,\n): RuleViolation[] {\n const rules = toArray(rulesConfig.require_scripts);\n if (rules.length === 0) {\n return [];\n }\n\n const pkg = readPackageJson(repoPath);\n const scriptKeys = Object.keys(\n (pkg?.scripts as Record<string, string> | undefined) ?? {},\n );\n\n return rules\n .filter(\n (rule) =>\n !rule.patterns.some((p) =>\n scriptKeys.some((k) => micromatch.isMatch(k, p)),\n ),\n )\n .map((rule) => ({\n type: 'require_scripts' as const,\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: [],\n }));\n}\n","import type { RulesConfig } from '../config/types';\nimport { toArray, readPackageJson } from './shared';\nimport type { RuleViolation } from './shared';\n\nexport function evaluatePackageFieldRules(\n repoPath: string,\n rulesConfig: RulesConfig,\n): RuleViolation[] {\n const rules = toArray(rulesConfig.require_package_fields);\n if (rules.length === 0) {\n return [];\n }\n\n const pkg = readPackageJson(repoPath);\n const fieldKeys = pkg ? Object.keys(pkg) : [];\n\n return rules\n .filter((rule) => !rule.patterns.some((p) => fieldKeys.includes(p)))\n .map((rule) => ({\n type: 'require_package_fields' as const,\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: [],\n }));\n}\n","import semver from 'semver';\nimport type { RulesConfig } from '../config/types';\nimport { toArray, readPackageJson } from './shared';\nimport type { RuleViolation } from './shared';\n\nexport function evaluateEngineVersion(\n repoPath: string,\n rulesConfig: RulesConfig,\n): RuleViolation[] {\n const rules = toArray(rulesConfig.engine_version);\n if (rules.length === 0) {\n return [];\n }\n\n const pkg = readPackageJson(repoPath);\n const nodeRange = (pkg?.engines as Record<string, string> | undefined)?.node;\n\n return rules.flatMap((rule): RuleViolation[] => {\n if (!nodeRange) {\n return [\n {\n type: 'engine_version',\n severity: rule.severity,\n patterns: [],\n message: rule.message ?? 'engines.node not specified in package.json',\n matchedFiles: [],\n requiredRange: rule.range,\n },\n ];\n }\n\n const minVer = semver.minVersion(nodeRange);\n if (!minVer || !semver.satisfies(minVer, rule.range)) {\n return [\n {\n type: 'engine_version',\n severity: rule.severity,\n patterns: [],\n message: rule.message,\n matchedFiles: [],\n installedRange: nodeRange,\n requiredRange: rule.range,\n },\n ];\n }\n\n return [];\n });\n}\n","import type { RulesConfig } from '../config/types';\nimport { evaluateFileRules } from './file-rules';\nimport { evaluateScriptRules } from './script-rules';\nimport { evaluatePackageFieldRules } from './package-field-rules';\nimport { evaluateEngineVersion } from './engine-version';\n\nexport type { RuleViolation } from './shared';\nexport { toArray } from './shared';\n\nexport function evaluateRules(\n repoPath: string,\n rulesConfig: RulesConfig,\n excludes: string[],\n): import('./shared').RuleViolation[] {\n return [\n ...evaluateFileRules(repoPath, rulesConfig, excludes),\n ...evaluateScriptRules(repoPath, rulesConfig),\n ...evaluatePackageFieldRules(repoPath, rulesConfig),\n ...evaluateEngineVersion(repoPath, rulesConfig),\n ];\n}\n","import micromatch from 'micromatch';\nimport type { UsageReport } from '../swc-parser';\nimport type { HermexConfig, VersusConfig } from '../config/types';\nimport type { MultiVersionMap } from '../lock-parser';\nimport type { RuleViolation } from '../rules/evaluator';\nimport { toArray } from '../rules/evaluator';\nimport type { ReleaseAgeEntry } from '../npm-registry/types';\n\nfunction toPercentage(count: number, total: number): number {\n return total > 0 ? (count / total) * 100 : 0;\n}\n\nexport interface ComponentUsage {\n name: string;\n source: string;\n count: number;\n files: Set<string>;\n}\n\nexport interface PackageDistribution {\n packageName: string;\n version: string | null;\n componentCount: number;\n usageCount: number;\n percentage: number;\n components: string[];\n internal: boolean;\n hasVersionConflict: boolean;\n allVersions: string[];\n releaseAge?: ReleaseAgeEntry;\n}\n\nexport interface PatternCount {\n patternType: string;\n displayName: string;\n count: number;\n}\n\nexport interface VersusEntry {\n packageName: string;\n count: number;\n percentage: number;\n components: string[];\n}\n\nexport interface VersusResult {\n name: string;\n packages: string[];\n entries: VersusEntry[];\n totalCount: number;\n}\n\nexport interface BannedPackageViolation {\n packageName: string;\n severity: 'error' | 'warn';\n message?: string;\n}\n\nexport interface AggregatedReport {\n filesAnalyzed: number;\n totalImports: number;\n totalComponents: number;\n totalUsagePatterns: number;\n patternCounts: PatternCount[];\n componentUsage: Map<string, ComponentUsage>;\n topComponents: ComponentUsage[];\n allComponents: string[];\n packageDistribution: PackageDistribution[];\n versusResults: VersusResult[];\n ruleViolations: RuleViolation[];\n bannedPackageViolations: BannedPackageViolation[];\n reports: UsageReport[];\n}\n\nexport function aggregateReports(\n reports: UsageReport[],\n versions: Record<string, string> = {},\n config?: HermexConfig,\n multiVersions: MultiVersionMap = {},\n): AggregatedReport {\n const componentUsageMap = new Map<string, ComponentUsage>();\n let totalImports = 0;\n let totalUsagePatterns = 0;\n const patternCountMap = new Map<string, number>();\n\n const availablePackages = Object.keys(versions);\n\n for (const report of reports) {\n totalImports += report.summary.totalImports;\n totalUsagePatterns += report.summary.totalUsagePatterns;\n\n for (const jsx of report.patterns.usage.jsx) {\n const key = jsx.component;\n const existing = componentUsageMap.get(key);\n\n if (existing) {\n existing.count++;\n } else {\n const source = findComponentSource(\n jsx.component,\n report,\n availablePackages,\n );\n componentUsageMap.set(key, {\n name: jsx.component,\n source,\n count: 1,\n files: new Set(),\n });\n }\n }\n\n countPatterns(report, patternCountMap);\n }\n\n const topComponents = Array.from(componentUsageMap.values()).sort(\n (a, b) => b.count - a.count,\n );\n\n const allComponents = Array.from(componentUsageMap.keys()).sort();\n\n const patternCounts = Array.from(patternCountMap.entries())\n .map(([type, count]) => ({\n patternType: type,\n displayName: getPatternDisplayName(type),\n count,\n }))\n .sort((a, b) => b.count - a.count);\n\n const packageDistribution = calculatePackageDistribution(\n componentUsageMap,\n versions,\n config,\n multiVersions,\n );\n\n const versusResults = calculateVersusResults(\n packageDistribution,\n config?.versus ?? [],\n );\n const bannedPackageViolations = detectBannedPackages(\n packageDistribution,\n config,\n );\n\n const requiredPackageViolations = detectRequiredPackages(\n packageDistribution,\n versions,\n config,\n );\n\n return {\n filesAnalyzed: reports.length,\n totalImports,\n totalComponents: componentUsageMap.size,\n totalUsagePatterns,\n patternCounts,\n componentUsage: componentUsageMap,\n topComponents,\n allComponents,\n packageDistribution,\n versusResults,\n ruleViolations: requiredPackageViolations,\n bannedPackageViolations,\n reports,\n };\n}\n\nfunction calculateVersusResults(\n distribution: PackageDistribution[],\n versusConfigs: VersusConfig[],\n): VersusResult[] {\n const distMap = new Map(distribution.map((p) => [p.packageName, p]));\n\n return versusConfigs.map((vc) => {\n const entries: VersusEntry[] = vc.packages.map((pkgName) => {\n const pkg = distMap.get(pkgName);\n return {\n packageName: pkgName,\n count: pkg?.usageCount ?? 0,\n percentage: 0,\n components: pkg?.components ?? [],\n };\n });\n\n const totalCount = entries.reduce((sum, e) => sum + e.count, 0);\n\n for (const entry of entries) {\n entry.percentage = toPercentage(entry.count, totalCount);\n }\n\n entries.sort((a, b) => b.count - a.count);\n\n return { name: vc.name, packages: vc.packages, entries, totalCount };\n });\n}\n\nfunction detectBannedPackages(\n distribution: PackageDistribution[],\n config?: HermexConfig,\n): BannedPackageViolation[] {\n const forbidRules = toArray(config?.rules.forbid_packages);\n if (forbidRules.length === 0) {\n return [];\n }\n\n const violations: BannedPackageViolation[] = [];\n for (const pkg of distribution) {\n for (const rule of forbidRules) {\n if (micromatch.isMatch(pkg.packageName, rule.patterns)) {\n violations.push({\n packageName: pkg.packageName,\n severity: rule.severity,\n message: rule.message,\n });\n break;\n }\n }\n }\n return violations;\n}\n\nfunction detectRequiredPackages(\n distribution: PackageDistribution[],\n versions: Record<string, string>,\n config?: HermexConfig,\n): RuleViolation[] {\n const requireRules = toArray(config?.rules.require_packages);\n if (requireRules.length === 0) return [];\n\n // All package names available: from lockfile versions + from import distribution\n const installedNames = new Set([\n ...Object.keys(versions),\n ...distribution.map((p) => p.packageName),\n ]);\n\n const violations: RuleViolation[] = [];\n for (const rule of requireRules) {\n const satisfied = rule.patterns.some((p) =>\n [...installedNames].some((name) => micromatch.isMatch(name, p)),\n );\n if (!satisfied) {\n violations.push({\n type: 'require_packages',\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: [],\n });\n }\n }\n return violations;\n}\n\nfunction resolvePackageFromImportPath(\n importPath: string,\n availablePackages: string[],\n): string {\n if (importPath.startsWith('.') || importPath.startsWith('/')) {\n return 'local';\n }\n\n const sortedPackages = [...availablePackages].sort(\n (a, b) => b.length - a.length,\n );\n\n for (const pkg of sortedPackages) {\n if (importPath === pkg) return pkg;\n if (importPath.startsWith(`${pkg}/`)) return pkg;\n }\n\n return 'unknown';\n}\n\nfunction findComponentSource(\n componentName: string,\n report: UsageReport,\n availablePackages: string[],\n): string {\n const namedImport = report.patterns.imports.named.find(\n (imp) => imp.name === componentName,\n );\n if (namedImport)\n return resolvePackageFromImportPath(namedImport.source, availablePackages);\n\n const defaultImport = report.patterns.imports.default.find(\n (imp) => imp.name === componentName,\n );\n if (defaultImport)\n return resolvePackageFromImportPath(\n defaultImport.source,\n availablePackages,\n );\n\n const aliasedImport = report.patterns.imports.aliased.find(\n (imp) => imp.local === componentName,\n );\n if (aliasedImport)\n return resolvePackageFromImportPath(\n aliasedImport.source,\n availablePackages,\n );\n\n return 'unknown';\n}\n\nfunction countPatterns(report: UsageReport, patternMap: Map<string, number>) {\n increment(\n patternMap,\n 'imports.default',\n report.patterns.imports.default.length,\n );\n increment(patternMap, 'imports.named', report.patterns.imports.named.length);\n increment(\n patternMap,\n 'imports.namespace',\n report.patterns.imports.namespace.length,\n );\n increment(\n patternMap,\n 'imports.aliased',\n report.patterns.imports.aliased.length,\n );\n increment(patternMap, 'usage.jsx', report.patterns.usage.jsx.length);\n increment(\n patternMap,\n 'usage.variables',\n report.patterns.usage.variables.length,\n );\n increment(\n patternMap,\n 'usage.destructuring',\n report.patterns.usage.destructuring.length,\n );\n increment(\n patternMap,\n 'usage.conditional',\n report.patterns.usage.conditional.length,\n );\n increment(patternMap, 'usage.arrays', report.patterns.usage.arrays.length);\n increment(patternMap, 'usage.objects', report.patterns.usage.objects.length);\n increment(patternMap, 'advanced.lazy', report.patterns.advanced.lazy.length);\n increment(\n patternMap,\n 'advanced.dynamic',\n report.patterns.advanced.dynamic.length,\n );\n increment(patternMap, 'advanced.hoc', report.patterns.advanced.hoc.length);\n increment(patternMap, 'advanced.memo', report.patterns.advanced.memo.length);\n increment(\n patternMap,\n 'advanced.forwardRef',\n report.patterns.advanced.forwardRef.length,\n );\n increment(\n patternMap,\n 'advanced.portal',\n report.patterns.advanced.portal.length,\n );\n}\n\nfunction increment(map: Map<string, number>, key: string, value: number) {\n map.set(key, (map.get(key) || 0) + value);\n}\n\nfunction getPatternDisplayName(patternType: string): string {\n const displayNames: Record<string, string> = {\n 'imports.default': 'Default Imports',\n 'imports.named': 'Named Imports',\n 'imports.namespace': 'Namespace Imports',\n 'imports.aliased': 'Aliased Imports',\n 'usage.jsx': 'JSX Usage',\n 'usage.variables': 'Variable Assignments',\n 'usage.destructuring': 'Destructuring',\n 'usage.conditional': 'Conditional Usage',\n 'usage.arrays': 'Array Mappings',\n 'usage.objects': 'Object Mappings',\n 'advanced.lazy': 'Lazy Loading',\n 'advanced.dynamic': 'Dynamic Imports',\n 'advanced.hoc': 'Higher-Order Components',\n 'advanced.memo': 'Memoized Components',\n 'advanced.forwardRef': 'Forward Refs',\n 'advanced.portal': 'Portal Usage',\n };\n return displayNames[patternType] || patternType;\n}\n\nfunction getPackageVersion(\n packageName: string,\n versions: Record<string, string>,\n): string | null {\n if (versions[packageName]) return versions[packageName];\n\n if (packageName.includes('/')) {\n const parts = packageName.split('/');\n if (packageName.startsWith('@') && parts.length > 2) {\n const basePackage = `${parts[0]}/${parts[1]}`;\n if (versions[basePackage]) return versions[basePackage];\n }\n if (!packageName.startsWith('@') && parts.length > 1) {\n if (versions[parts[0]]) return versions[parts[0]];\n }\n }\n\n return null;\n}\n\nfunction calculatePackageDistribution(\n componentUsageMap: Map<string, ComponentUsage>,\n versions: Record<string, string>,\n config?: HermexConfig,\n multiVersions: MultiVersionMap = {},\n): PackageDistribution[] {\n const ignorePatterns = config?.packages.ignore ?? [];\n const internalPatterns = config?.packages.internal ?? [];\n\n const packageMap = new Map<string, PackageDistribution>();\n\n for (const component of componentUsageMap.values()) {\n if (component.source === 'unknown' || component.source === 'local')\n continue;\n\n if (\n ignorePatterns.length > 0 &&\n micromatch.isMatch(component.source, ignorePatterns)\n ) {\n continue;\n }\n\n const existing = packageMap.get(component.source);\n if (existing) {\n existing.componentCount++;\n existing.usageCount += component.count;\n existing.components.push(component.name);\n } else {\n const isInternal =\n internalPatterns.length > 0\n ? micromatch.isMatch(component.source, internalPatterns)\n : false;\n\n const allVersions = multiVersions[component.source] ?? [];\n const hasVersionConflict = allVersions.length > 1;\n\n packageMap.set(component.source, {\n packageName: component.source,\n version: getPackageVersion(component.source, versions),\n componentCount: 1,\n usageCount: component.count,\n percentage: 0,\n components: [component.name],\n internal: isInternal,\n hasVersionConflict,\n allVersions,\n });\n }\n }\n\n const distribution = Array.from(packageMap.values());\n const totalExternalUsage = distribution.reduce(\n (sum, pkg) => sum + pkg.usageCount,\n 0,\n );\n\n for (const pkg of distribution) {\n pkg.percentage =\n totalExternalUsage > 0 ? (pkg.usageCount / totalExternalUsage) * 100 : 0;\n }\n\n return distribution.sort((a, b) => b.usageCount - a.usageCount);\n}\n","/**\n * Format a number with thousand separators\n * @param num - Number to format\n * @returns Formatted string (e.g., 1,234,567)\n */\nexport function formatCount(num: number): string {\n return num.toLocaleString();\n}\n\n/**\n * Format duration in seconds to a readable string\n * @param seconds - Duration in seconds\n * @returns Formatted string (e.g., 10.21s, 1.57s, 0.12s)\n */\nexport function formatDuration(seconds: number): string {\n return `${seconds.toFixed(2)}s`;\n}\n","import chalk from 'chalk';\nimport Table from 'cli-table3';\nimport type { AggregatedReport } from './aggregator';\nimport { formatCount } from './format-utils';\n\nfunction printHeader() {\n console.log(chalk.green.bold('\\n📊 Summary\\n'));\n}\n\nexport function printSummary(aggregated: AggregatedReport) {\n printHeader();\n\n const table = new Table({\n head: ['Metric', 'Count'],\n style: {\n head: ['cyan'],\n border: ['gray'],\n },\n });\n\n // Calculate external components only (filter out unknown and local)\n const externalComponents = aggregated.topComponents.filter(\n (comp) => comp.source !== 'unknown' && comp.source !== 'local',\n ).length;\n\n // Calculate total external package usage\n const totalExternalUsage = aggregated.packageDistribution.reduce(\n (sum, pkg) => sum + pkg.usageCount,\n 0,\n );\n\n table.push(\n ['Files Analyzed', formatCount(aggregated.filesAnalyzed)],\n ['External Packages', formatCount(aggregated.packageDistribution.length)],\n ['External Components', formatCount(externalComponents)],\n ['Total Usages', formatCount(totalExternalUsage)],\n );\n\n console.log(table.toString());\n}\n","import chalk from 'chalk';\nimport type { AggregatedReport } from './aggregator';\nimport { formatCount } from './format-utils';\n\nfunction printHeader() {\n console.log(chalk.cyan.bold('\\n📋 Details\\n'));\n}\n\nexport function printDetails(aggregated: AggregatedReport) {\n printHeader();\n\n console.log(\n chalk.cyan(\n ` Total usage patterns: ${formatCount(aggregated.totalUsagePatterns)}`,\n ),\n );\n\n // Print each pattern type count\n for (const pattern of aggregated.patternCounts) {\n if (pattern.count > 0) {\n console.log(\n chalk.cyan(` ${pattern.displayName}: ${formatCount(pattern.count)}`),\n );\n }\n }\n}\n","import chalk from 'chalk';\nimport { formatCount } from './format-utils';\n\nexport interface ChartData {\n label: string;\n value: number;\n}\n\nexport interface ChartOptions {\n maxWidth?: number;\n showValues?: boolean;\n barChar?: string;\n emptyChar?: string;\n}\n\nexport function renderBarChart(data: ChartData[], options: ChartOptions = {}) {\n const {\n maxWidth = 50,\n showValues = true,\n barChar = '█',\n emptyChar = '░',\n } = options;\n\n if (data.length === 0) {\n console.log(chalk.gray(' No data to display'));\n return;\n }\n\n // Find max value for scaling\n const maxValue = Math.max(...data.map((d) => d.value));\n if (maxValue === 0) {\n console.log(chalk.gray(' All values are zero'));\n return;\n }\n\n // Find longest label for alignment\n const maxLabelLength = Math.max(...data.map((d) => d.label.length));\n\n // Render each bar\n for (const item of data) {\n const percentage = item.value / maxValue;\n const barLength = Math.round(percentage * maxWidth);\n const emptyLength = maxWidth - barLength;\n\n // Pad label\n const paddedLabel = item.label.padEnd(maxLabelLength, ' ');\n\n // Build bar\n const bar =\n chalk.green(barChar.repeat(barLength)) +\n chalk.gray(emptyChar.repeat(emptyLength));\n\n // Build value string\n const valueStr = showValues ? ` ${formatCount(item.value)}` : '';\n\n console.log(`${paddedLabel} ${bar}${valueStr}\\n`);\n }\n}\n","import chalk from 'chalk';\nimport Table from 'cli-table3';\nimport type { AggregatedReport, ComponentUsage } from './aggregator';\nimport { renderBarChart } from './chart-renderer';\n\nfunction printHeader() {\n // FIXME why double space, if single space output is wrong somehow?\n console.log(chalk.magenta.bold('\\n⚛️ Components\\n'));\n}\n\nexport function printComponents(\n aggregated: AggregatedReport,\n mode: 'table' | 'chart',\n) {\n const components = aggregated.topComponents;\n\n if (mode === 'table') {\n printComponentsTable(components);\n } else if (mode === 'chart') {\n printComponentsChart(components);\n }\n}\n\nfunction printComponentsTable(components: ComponentUsage[]) {\n printHeader();\n\n // Filter out unknown and local components - only show external packages\n const externalComponents = components.filter(\n (comp) => comp.source !== 'unknown' && comp.source !== 'local',\n );\n\n if (externalComponents.length === 0) {\n console.log(chalk.gray(' No external components found'));\n return;\n }\n\n const table = new Table({\n head: ['Component', 'Package', 'Count'],\n style: {\n head: ['cyan'],\n border: ['gray'],\n },\n });\n\n externalComponents.forEach((comp) => {\n table.push([comp.name, comp.source, comp.count.toString()]);\n });\n\n console.log(table.toString());\n}\n\nfunction printComponentsChart(components: ComponentUsage[]) {\n printHeader();\n\n // Filter out unknown and local components - only show external packages\n const externalComponents = components.filter(\n (comp) => comp.source !== 'unknown' && comp.source !== 'local',\n );\n\n if (externalComponents.length === 0) {\n console.log(chalk.gray(' No external components found'));\n return;\n }\n\n const data = externalComponents.map((comp) => ({\n label: comp.name,\n value: comp.count,\n }));\n\n renderBarChart(data, { maxWidth: 50 });\n}\n","import chalk from 'chalk';\nimport Table from 'cli-table3';\nimport type { AggregatedReport, PatternCount } from './aggregator';\nimport { renderBarChart } from './chart-renderer';\n\nfunction printHeader() {\n console.log(chalk.blue.bold('\\n🔍 Code Patterns\\n'));\n}\n\nexport function printPatterns(\n aggregated: AggregatedReport,\n mode: 'table' | 'chart',\n) {\n const patterns = aggregated.patternCounts.filter((p) => p.count > 0);\n\n if (mode === 'table') {\n printPatternsTable(patterns);\n } else if (mode === 'chart') {\n printPatternsChart(patterns);\n }\n}\n\nfunction printPatternsTable(patterns: PatternCount[]) {\n printHeader();\n\n if (patterns.length === 0) {\n console.log(chalk.gray(' No patterns found'));\n return;\n }\n\n const table = new Table({\n head: ['Pattern', 'Count'],\n style: {\n head: ['cyan'],\n border: ['gray'],\n },\n });\n\n patterns.forEach((pattern) => {\n table.push([pattern.displayName, pattern.count.toString()]);\n });\n\n console.log(table.toString());\n\n // Show total patterns count\n const totalPatterns = patterns.reduce((sum, p) => sum + p.count, 0);\n console.log(chalk.gray(`\\nTotal: ${totalPatterns} patterns detected`));\n}\n\nfunction printPatternsChart(patterns: PatternCount[]) {\n printHeader();\n\n if (patterns.length === 0) {\n console.log(chalk.gray(' No patterns found'));\n return;\n }\n\n const data = patterns.map((pattern) => ({\n label: pattern.displayName,\n value: pattern.count,\n }));\n\n renderBarChart(data, { maxWidth: 50 });\n}\n","import chalk from 'chalk';\nimport Table from 'cli-table3';\nimport type {\n AggregatedReport,\n BannedPackageViolation,\n PackageDistribution,\n} from './aggregator';\nimport type { ReleaseAgeEntry } from '../npm-registry/types';\nimport { formatCount } from './format-utils';\n\nfunction printHeader() {\n console.log(chalk.blueBright.bold('\\n📦 Packages\\n'));\n}\n\nfunction formatPackageName(\n pkg: PackageDistribution,\n banned?: BannedPackageViolation,\n): string {\n let prefix = '';\n if (pkg.releaseAge?.deprecated) {\n prefix += chalk.red('[DEPRECATED] ');\n }\n if (banned) {\n prefix +=\n banned.severity === 'error'\n ? chalk.red('[BANNED] ')\n : chalk.yellow('[RESTRICTED] ');\n } else if (pkg.internal) {\n prefix += chalk.yellow('[int] ');\n }\n return prefix + pkg.packageName;\n}\n\nfunction formatUpgradeCell(releaseAge?: ReleaseAgeEntry): string {\n if (!releaseAge) return '';\n const { worstLevel, upgrades } = releaseAge;\n if (!worstLevel) return chalk.green('✓');\n\n const top = upgrades[0];\n if (!top) return chalk.green('✓');\n\n if (worstLevel === 'mandatory_upgrade') {\n return chalk.red(\n `⚠ ${top.semverBump} ${top.version} (${top.releasedDaysAgo}d)`,\n );\n }\n return chalk.yellow(\n `↑ ${top.semverBump} ${top.version} (${top.releasedDaysAgo}d)`,\n );\n}\n\nfunction getBannedViolation(\n pkg: PackageDistribution,\n violations: BannedPackageViolation[],\n): BannedPackageViolation | undefined {\n return violations.find((v) => v.packageName === pkg.packageName);\n}\n\nexport function printPackages(\n aggregated: AggregatedReport,\n mode: 'table' | 'chart',\n) {\n const packages = aggregated.packageDistribution;\n const violations = aggregated.bannedPackageViolations;\n\n if (mode === 'table') {\n printPackagesTable(packages, violations);\n } else if (mode === 'chart') {\n printPackagesChart(packages, violations);\n }\n}\n\nfunction printPackagesTable(\n packages: PackageDistribution[],\n violations: BannedPackageViolation[],\n) {\n printHeader();\n\n if (packages.length === 0) {\n console.log(chalk.gray(' No packages found'));\n return;\n }\n\n const hasReleaseAge = packages.some((p) => p.releaseAge !== undefined);\n const head = ['Package', 'Version', 'Components', 'Usage', 'Percentage'];\n if (hasReleaseAge) head.push('Upgrades');\n\n const table = new Table({\n head,\n style: {\n head: ['cyan'],\n border: ['gray'],\n },\n });\n\n packages.forEach((pkg) => {\n const versionCell = pkg.hasVersionConflict\n ? chalk.yellow(\n `⚠ ${pkg.allVersions.join(', ')} (multiple — bundle impact)`,\n )\n : pkg.version || 'N/A';\n\n const row = [\n formatPackageName(pkg, getBannedViolation(pkg, violations)),\n versionCell,\n formatCount(pkg.componentCount),\n formatCount(pkg.usageCount),\n `${pkg.percentage.toFixed(1)}%`,\n ];\n if (hasReleaseAge) row.push(formatUpgradeCell(pkg.releaseAge));\n table.push(row);\n });\n\n console.log(table.toString());\n\n const totalComponents = packages.reduce(\n (sum, p) => sum + p.componentCount,\n 0,\n );\n const totalExternalUsage = packages.reduce((sum, p) => sum + p.usageCount, 0);\n console.log(\n chalk.gray(\n `\\nTotal: ${formatCount(packages.length)} packages | ${formatCount(totalComponents)} unique components | ${formatCount(totalExternalUsage)} total usages`,\n ),\n );\n}\n\nfunction printPackagesChart(\n packages: PackageDistribution[],\n violations: BannedPackageViolation[],\n) {\n printHeader();\n\n if (packages.length === 0) {\n console.log(chalk.gray(' No packages found'));\n return;\n }\n\n const maxBarWidth = 40;\n const maxPercentage = Math.max(...packages.map((p) => p.percentage));\n const maxLabelLength = Math.max(\n ...packages.map((p) => p.packageName.length + (p.internal ? 6 : 0)),\n );\n\n packages.forEach((pkg) => {\n const barLength = Math.round(\n (pkg.percentage / maxPercentage) * maxBarWidth,\n );\n const emptyLength = maxBarWidth - barLength;\n const label = formatPackageName(\n pkg,\n getBannedViolation(pkg, violations),\n ).padEnd(maxLabelLength, ' ');\n\n const bar =\n chalk.green('█'.repeat(barLength)) + chalk.gray('░'.repeat(emptyLength));\n\n console.log(\n `${label} ${bar} ${chalk.bold(pkg.percentage.toFixed(1) + '%')} (${pkg.usageCount})`,\n );\n });\n}\n","import chalk from 'chalk';\nimport type { AggregatedReport, VersusResult } from './aggregator';\n\nconst BAR_WIDTH = 30;\n\nfunction renderBar(percentage: number): string {\n const filled = Math.round((percentage / 100) * BAR_WIDTH);\n const empty = BAR_WIDTH - filled;\n return chalk.cyan('█'.repeat(filled)) + chalk.gray('░'.repeat(empty));\n}\n\nfunction formatComponents(components: string[], max = 3): string {\n if (components.length === 0) return '';\n const shown = components.slice(0, max);\n const rest = components.length - max;\n const list = shown.join(', ');\n return rest > 0 ? `${list} (+${rest} more)` : list;\n}\n\nfunction printVersusResult(result: VersusResult) {\n console.log(chalk.bold(` ${result.name}`));\n console.log(chalk.gray(` ${'─'.repeat(50)}`));\n\n const maxNameLen = Math.max(\n ...result.entries.map((e) => e.packageName.length),\n );\n\n for (const entry of result.entries) {\n const name = entry.packageName.padEnd(maxNameLen);\n const bar = renderBar(entry.percentage);\n const pct = chalk.bold(`${entry.percentage.toFixed(1)}%`);\n const usage = chalk.gray(`(${entry.count} usages)`);\n const components =\n entry.components.length > 0\n ? chalk.gray(` ${formatComponents(entry.components)}`)\n : '';\n\n console.log(` ${name} ${bar} ${pct} ${usage}${components}`);\n }\n\n if (result.totalCount === 0) {\n console.log(\n chalk.gray(' No usage detected for any package in this group.'),\n );\n }\n\n console.log();\n}\n\nexport function printVersus(aggregated: AggregatedReport) {\n if (aggregated.versusResults.length === 0) return;\n\n console.log(chalk.magentaBright.bold('\\n⚖️ Versus\\n'));\n\n for (const result of aggregated.versusResults) {\n printVersusResult(result);\n }\n}\n","import chalk from 'chalk';\nimport type { AggregatedReport } from './aggregator';\nimport type { RuleViolation } from '../rules/evaluator';\n\nfunction formatRuleType(type: RuleViolation['type']): string {\n switch (type) {\n case 'forbid_files':\n return 'forbid_files';\n case 'require_files':\n return 'require_files';\n case 'allow_files':\n return 'allow_files';\n case 'forbid_packages':\n return 'forbid_packages';\n case 'require_packages':\n return 'require_packages';\n case 'require_scripts':\n return 'require_scripts';\n case 'require_package_fields':\n return 'pkg_fields';\n case 'engine_version':\n return 'engine_version';\n }\n}\n\nfunction ruleIcon(violation: RuleViolation): string {\n if (violation.severity === 'error') return chalk.red('✗');\n return chalk.yellow('⚠');\n}\n\nfunction describeViolation(v: RuleViolation): string {\n const patterns = v.patterns.join(', ');\n const suffix = v.message ? chalk.gray(` — ${v.message}`) : '';\n\n if (v.type === 'forbid_files') {\n const files = v.matchedFiles.map((f) => {\n const parts = f.replace(/\\\\/g, '/').split('/');\n return parts[parts.length - 1];\n });\n return `${patterns} found (${files.join(', ')})${suffix}`;\n }\n\n if (v.type === 'require_files') return `${patterns} not found${suffix}`;\n if (v.type === 'allow_files') return `${patterns} not present${suffix}`;\n if (v.type === 'require_packages')\n return `${patterns} not installed${suffix}`;\n if (v.type === 'forbid_packages') return `${patterns} is forbidden${suffix}`;\n if (v.type === 'require_scripts')\n return `script ${patterns} missing in package.json${suffix}`;\n if (v.type === 'require_package_fields')\n return `field ${patterns} missing in package.json${suffix}`;\n\n if (v.type === 'engine_version') {\n if (!v.installedRange)\n return `engines.node not specified (required ${v.requiredRange})${suffix}`;\n return `engines.node is ${chalk.yellow(v.installedRange)}, required ${chalk.cyan(v.requiredRange)}${suffix}`;\n }\n\n return `${patterns} not present${suffix}`;\n}\n\nexport function printRules(aggregated: AggregatedReport): void {\n const { ruleViolations, bannedPackageViolations } = aggregated;\n const hasRuleViolations = ruleViolations.length > 0;\n const hasBannedViolations = bannedPackageViolations.length > 0;\n\n if (!hasRuleViolations && !hasBannedViolations) {\n console.log(chalk.greenBright.bold('\\n✓ Compliance\\n'));\n console.log(chalk.gray(' All compliance checks passed'));\n return;\n }\n\n console.log(chalk.blueBright.bold('\\n🔍 Compliance\\n'));\n\n if (hasRuleViolations) {\n for (const v of ruleViolations) {\n const icon = ruleIcon(v);\n const type = chalk.gray(formatRuleType(v.type).padEnd(14));\n const severityTag =\n v.severity === 'error' ? chalk.red('[ERROR]') : chalk.yellow('[WARN]');\n console.log(` ${icon} ${type} ${describeViolation(v)} ${severityTag}`);\n }\n }\n\n if (hasBannedViolations) {\n if (hasRuleViolations) console.log();\n for (const v of bannedPackageViolations) {\n const icon = v.severity === 'error' ? chalk.red('✗') : chalk.yellow('⚠');\n const tag =\n v.severity === 'error'\n ? chalk.red('[BANNED]')\n : chalk.yellow('[RESTRICTED]');\n const msg = v.message ? chalk.gray(` — ${v.message}`) : '';\n console.log(` ${icon} ${tag} ${v.packageName}${msg}`);\n }\n }\n\n const errorCount = [\n ...ruleViolations.filter((v) => v.severity === 'error'),\n ...bannedPackageViolations.filter((v) => v.severity === 'error'),\n ].length;\n const warnCount = [\n ...ruleViolations.filter((v) => v.severity === 'warn'),\n ...bannedPackageViolations.filter((v) => v.severity === 'warn'),\n ].length;\n\n const parts: string[] = [];\n if (errorCount > 0)\n parts.push(chalk.red(`${errorCount} error${errorCount > 1 ? 's' : ''}`));\n if (warnCount > 0)\n parts.push(chalk.yellow(`${warnCount} warning${warnCount > 1 ? 's' : ''}`));\n console.log(chalk.gray(`\\n ${parts.join(', ')}`));\n}\n","import chalk from 'chalk';\nimport type { ParseError } from '../swc-parser/types';\n\nexport function printErrors(errors: ParseError[]): void {\n if (errors.length === 0) return;\n console.log(chalk.yellow(`\\n⚠ ${errors.length} file(s) failed to parse:`));\n for (const { file, message } of errors) {\n console.log(chalk.yellow(` ${file}`));\n console.log(chalk.gray(` ${message}`));\n }\n console.log('');\n}\n","import fs from 'fs';\nimport { glob } from 'glob';\n\n/**\n * Find files matching a glob pattern\n * @param pattern - Glob pattern\n * @param ignorePatterns - Glob pattenrs to ignore\n * @returns Array of file paths\n */\nexport async function findFiles(\n pattern: string | string[],\n ignorePatterns: string[],\n): Promise<string[]> {\n const files = await glob(pattern, {\n ignore: ignorePatterns,\n nodir: true,\n absolute: true,\n windowsPathsNoEscape: true,\n });\n\n return files;\n}\n\n/**\n * Read file content\n * @param filePath - Path to file\n * @returns File content\n */\nexport function readFile(filePath: string): string {\n return fs.readFileSync(filePath, 'utf8');\n}\n","import fs from 'fs';\nimport path from 'path';\nimport type { LockfileAdapter, MultiVersionMap } from '../lock-file-adapter';\n\nfunction canonicalPackageName(pkgPath: string): string {\n // pkgPath examples:\n // \"node_modules/react\"\n // \"node_modules/@scope/pkg\"\n // \"node_modules/react/node_modules/scheduler\"\n // \"node_modules/@scope/a/node_modules/@scope/b\"\n // We want the last segment after the last \"node_modules/\"\n const idx = pkgPath.lastIndexOf('node_modules/');\n if (idx === -1) return pkgPath;\n return pkgPath.slice(idx + 'node_modules/'.length);\n}\n\nexport class NpmLockfileAdapter implements LockfileAdapter {\n name = 'npm';\n supportedVersions = ['v2', 'v3'];\n\n detect(projectPath: string): string | null {\n const lockfilePath = path.join(projectPath, 'package-lock.json');\n return fs.existsSync(lockfilePath) ? lockfilePath : null;\n }\n\n parse(lockFilePath: string): Record<string, string> {\n try {\n const content = fs.readFileSync(lockFilePath, 'utf8');\n const lockData = JSON.parse(content);\n const versions: Record<string, string> = {};\n\n // npm v7+ uses \"packages\" field (lockfileVersion 2, 3)\n if (lockData.packages) {\n Object.entries(lockData.packages).forEach(\n ([pkgPath, pkgData]: [string, any]) => {\n if (!pkgPath || pkgPath === '') return;\n\n // Only root-level packages (no nested node_modules in path)\n if (pkgPath.split('node_modules/').length > 2) return;\n\n const pkgName = canonicalPackageName(pkgPath);\n if (pkgData.version) {\n versions[pkgName] = pkgData.version;\n }\n },\n );\n }\n\n // npm v6 uses \"dependencies\" field (fallback)\n if (lockData.dependencies && Object.keys(versions).length === 0) {\n function extractVersions(deps: any, prefix = ''): void {\n Object.entries(deps).forEach(([name, data]: [string, any]) => {\n const fullName = prefix ? `${prefix}/${name}` : name;\n if (data.version) {\n versions[fullName] = data.version;\n }\n if (data.dependencies) {\n extractVersions(data.dependencies, fullName);\n }\n });\n }\n extractVersions(lockData.dependencies);\n }\n\n return versions;\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n console.warn(`Warning: Could not parse package-lock.json: ${message}`);\n return {};\n }\n }\n\n parseMultiVersion(lockFilePath: string): MultiVersionMap {\n try {\n const content = fs.readFileSync(lockFilePath, 'utf8');\n const lockData = JSON.parse(content);\n const versionSets: Record<string, Set<string>> = {};\n\n if (lockData.packages) {\n Object.entries(lockData.packages).forEach(\n ([pkgPath, pkgData]: [string, any]) => {\n if (!pkgPath || pkgPath === '') return;\n\n const pkgName = canonicalPackageName(pkgPath);\n const version = (pkgData as any).version;\n if (!version) return;\n\n if (!versionSets[pkgName]) versionSets[pkgName] = new Set();\n versionSets[pkgName].add(version);\n },\n );\n }\n\n const result: MultiVersionMap = {};\n for (const [pkg, versions] of Object.entries(versionSets)) {\n result[pkg] = Array.from(versions).sort();\n }\n return result;\n } catch {\n return {};\n }\n }\n}\n","import fs from 'fs';\nimport path from 'path';\nimport yaml from 'js-yaml';\nimport type { LockfileAdapter } from '../lock-file-adapter';\n\nexport class PnpmLockfileAdapter implements LockfileAdapter {\n name = 'pnpm';\n supportedVersions = ['v5', 'v6', 'v9'];\n\n detect(projectPath: string): string | null {\n const lockfilePath = path.join(projectPath, 'pnpm-lock.yaml');\n return fs.existsSync(lockfilePath) ? lockfilePath : null;\n }\n\n parse(lockFilePath: string): Record<string, string> {\n try {\n const content = fs.readFileSync(lockFilePath, 'utf8');\n const lockData = yaml.load(content) as any;\n const versions: Record<string, string> = {};\n\n // pnpm v9+ uses \"importers\" field\n if (lockData.importers) {\n const rootImporter = lockData.importers['.'];\n if (rootImporter) {\n // Parse dependencies\n if (rootImporter.dependencies) {\n for (const [name, data] of Object.entries(\n rootImporter.dependencies,\n )) {\n if (\n typeof data === 'object' &&\n data !== null &&\n 'version' in data\n ) {\n versions[name] = (data as any).version;\n }\n }\n }\n // Parse devDependencies\n if (rootImporter.devDependencies) {\n for (const [name, data] of Object.entries(\n rootImporter.devDependencies,\n )) {\n if (\n typeof data === 'object' &&\n data !== null &&\n 'version' in data\n ) {\n versions[name] = (data as any).version;\n }\n }\n }\n }\n }\n\n // pnpm v6-8 uses \"packages\" field\n if (lockData.packages && Object.keys(versions).length === 0) {\n Object.keys(lockData.packages).forEach((key) => {\n // Key format: \"/@babel/core/7.22.5\" or \"/package/1.0.0\"\n const match = key.match(/\\/(.+?)\\/(\\d+\\.\\d+\\.\\d+.*?)(?:_|$)/);\n if (match) {\n const [, pkgName, version] = match;\n versions[pkgName] = version;\n }\n });\n }\n\n // pnpm v5 uses \"dependencies\" and \"specifiers\"\n if (lockData.dependencies && Object.keys(versions).length === 0) {\n Object.entries(lockData.dependencies).forEach(\n ([name, versionSpec]: [string, any]) => {\n // versionSpec format: \"1.0.0\" or \"link:../package\"\n if (\n typeof versionSpec === 'string' &&\n !versionSpec.startsWith('link:')\n ) {\n versions[name] = versionSpec;\n } else if (typeof versionSpec === 'object' && versionSpec.version) {\n versions[name] = versionSpec.version;\n }\n },\n );\n }\n\n return versions;\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n console.warn(`Warning: Could not parse pnpm-lock.yaml: ${message}`);\n return {};\n }\n }\n}\n","import fs from 'fs';\nimport path from 'path';\nimport lockfile from '@yarnpkg/lockfile';\nimport type { LockfileAdapter } from '../lock-file-adapter';\n\nexport class YarnLockfileAdapter implements LockfileAdapter {\n name = 'yarn';\n supportedVersions = ['v1', 'v2+'];\n\n detect(projectPath: string): string | null {\n const lockfilePath = path.join(projectPath, 'yarn.lock');\n return fs.existsSync(lockfilePath) ? lockfilePath : null;\n }\n\n parse(lockFilePath: string): Record<string, string> {\n try {\n const content = fs.readFileSync(lockFilePath, 'utf8');\n const parsed = lockfile.parse(content);\n\n if (parsed.type !== 'success') {\n console.warn('Warning: Failed to parse yarn.lock');\n return {};\n }\n\n const versions: Record<string, string> = {};\n\n Object.entries(parsed.object).forEach(([key, value]: [string, any]) => {\n // Key format: \"package@^1.0.0\" or \"@scope/package@^1.0.0\"\n // Extract package name (without version specifier)\n let pkgName = key;\n\n // Handle scoped packages\n if (key.startsWith('@')) {\n const match = key.match(/^(@[^@]+\\/[^@]+)@/);\n if (match) {\n pkgName = match[1];\n }\n } else {\n const match = key.match(/^([^@]+)@/);\n if (match) {\n pkgName = match[1];\n }\n }\n\n if (value.version && (!versions[pkgName] || value.version)) {\n versions[pkgName] = value.version;\n }\n });\n\n return versions;\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n console.warn(`Warning: Could not parse yarn.lock: ${message}`);\n return {};\n }\n }\n}\n","import { NpmLockfileAdapter } from './patterns/npm';\nimport { PnpmLockfileAdapter } from './patterns/pnpm';\nimport { YarnLockfileAdapter } from './patterns/yarn';\nimport type { LockfileAdapter, MultiVersionMap } from './lock-file-adapter';\n\nexport type { MultiVersionMap };\n\nexport interface VersionConflict {\n packageName: string;\n versions: string[];\n}\n\nexport interface LockfileResult {\n versions: Record<string, string>;\n multiVersions: MultiVersionMap;\n versionConflicts: VersionConflict[];\n lockfileType: 'npm' | 'yarn' | 'pnpm' | null;\n lockfilePath: string | null;\n supportedVersions: string[];\n}\n\nconst LOCKFILE_ADAPTERS: LockfileAdapter[] = [\n new NpmLockfileAdapter(),\n new YarnLockfileAdapter(),\n new PnpmLockfileAdapter(),\n];\n\n/**\n * Find and parse the appropriate lockfile in a directory\n * @param projectPath - Path to the project directory\n * @returns Object with versions map and lockfile type\n */\nexport function findAndParseLockfile(projectPath: string): LockfileResult {\n for (const adapter of LOCKFILE_ADAPTERS) {\n const lockfilePath = adapter.detect(projectPath);\n if (lockfilePath) {\n const versions = adapter.parse(lockfilePath);\n const multiVersions = adapter.parseMultiVersion\n ? adapter.parseMultiVersion(lockfilePath)\n : {};\n\n const versionConflicts: VersionConflict[] = Object.entries(multiVersions)\n .filter(([, vers]) => vers.length > 1)\n .map(([packageName, vers]) => ({ packageName, versions: vers }));\n\n return {\n versions,\n multiVersions,\n versionConflicts,\n lockfileType: adapter.name as 'npm' | 'yarn' | 'pnpm',\n lockfilePath,\n supportedVersions: adapter.supportedVersions,\n };\n }\n }\n\n throw new Error('No supported lockfile found');\n}\n\n/**\n * Get the version of a specific package from lockfile\n * @param projectPath - Path to the project directory\n * @param packageName - Name of the package\n * @returns Version string or null if not found\n */\nexport function getPackageVersion(\n projectPath: string,\n packageName: string,\n): string | null {\n const { versions } = findAndParseLockfile(projectPath);\n return versions[packageName] || null;\n}\n\n/**\n * Get versions for multiple packages\n * @param projectPath - Path to the project directory\n * @param packageNames - Array of package names\n * @returns Map of package names to versions\n */\nexport function getPackageVersions(\n projectPath: string,\n packageNames: string[],\n): Record<string, string> {\n const { versions } = findAndParseLockfile(projectPath);\n const result: Record<string, string> = {};\n\n packageNames.forEach((pkgName) => {\n if (versions[pkgName]) {\n result[pkgName] = versions[pkgName];\n }\n });\n\n return result;\n}\n","import { z } from 'zod';\n\n// ── Sub-schemas ────────────────────────────────────────────────────────────────\n\nconst RuleSeveritySchema = z.enum(['error', 'warn']);\n\nconst RuleConfigSchema = z.object({\n severity: RuleSeveritySchema,\n patterns: z.array(z.string()),\n message: z.string().optional(),\n});\n\nconst RuleConfigOrArraySchema = z.union([\n RuleConfigSchema,\n z.array(RuleConfigSchema),\n]);\n\nconst EngineVersionRuleSchema = z.object({\n severity: RuleSeveritySchema,\n range: z.string(),\n message: z.string().optional(),\n});\n\nconst ThresholdSchema = z.union([z.number(), z.literal(false)]);\n\n// ── Main schema with defaults ──────────────────────────────────────────────────\n\nexport const HermexConfigSchema = z.object({\n includes: z.array(z.string()).default(['**/*.{tsx,jsx,ts,js}']),\n excludes: z\n .array(z.string())\n .default(['**/node_modules/**', '**/dist/**', '**/build/**']),\n\n packages: z\n .object({\n internal: z.array(z.string()).default([]),\n ignore: z.array(z.string()).default([]),\n })\n .default(() => ({ internal: [], ignore: [] })),\n\n versus: z\n .array(z.object({ name: z.string(), packages: z.array(z.string()).min(2) }))\n .default([]),\n\n rules: z\n .object({\n forbid_files: RuleConfigOrArraySchema.default([]),\n require_files: RuleConfigOrArraySchema.default([]),\n allow_files: RuleConfigOrArraySchema.default([]),\n forbid_packages: RuleConfigOrArraySchema.default([]),\n require_packages: RuleConfigOrArraySchema.default([]),\n require_scripts: RuleConfigOrArraySchema.default([]),\n require_package_fields: RuleConfigOrArraySchema.default([]),\n engine_version: z\n .union([EngineVersionRuleSchema, z.array(EngineVersionRuleSchema)])\n .optional(),\n })\n .default(() => ({\n forbid_files: [] as RuleConfig[],\n require_files: [] as RuleConfig[],\n allow_files: [] as RuleConfig[],\n forbid_packages: [] as RuleConfig[],\n require_packages: [] as RuleConfig[],\n require_scripts: [] as RuleConfig[],\n require_package_fields: [] as RuleConfig[],\n })),\n\n output: z\n .object({\n summary: z.union([z.literal('log'), z.literal(false)]).default('log'),\n components: z\n .union([z.enum(['table', 'chart']), z.literal(false)])\n .default('table'),\n packages: z\n .union([z.enum(['table', 'chart']), z.literal(false)])\n .default('table'),\n patterns: z\n .union([z.enum(['table', 'chart']), z.literal(false)])\n .default('table'),\n details: z.boolean().default(false),\n versus: z.boolean().default(true),\n rules: z.boolean().default(true),\n })\n .default(() => ({\n summary: 'log' as const,\n components: 'table' as const,\n packages: 'table' as const,\n patterns: 'table' as const,\n details: false,\n versus: true,\n rules: true,\n })),\n\n releaseAge: z\n .object({\n enabled: z.boolean().default(false),\n registry: z.string().default('https://registry.npmjs.org'),\n authToken: z.string().optional(),\n thresholds: z\n .object({\n patch: ThresholdSchema.default(30),\n minor: ThresholdSchema.default(45),\n major: ThresholdSchema.default(60),\n })\n .default(() => ({ patch: 30, minor: 45, major: 60 })),\n })\n .default(() => ({\n enabled: false,\n registry: 'https://registry.npmjs.org',\n thresholds: { patch: 30, minor: 45, major: 60 },\n })),\n});\n\n// ── Derived types ──────────────────────────────────────────────────────────────\n\n/** Config as returned after parsing — all defaults applied, all fields required */\nexport type HermexConfig = z.infer<typeof HermexConfigSchema>;\n\n/** Config as accepted by the user — everything optional */\nexport type HermexConfigInput = z.input<typeof HermexConfigSchema>;\n\n// Sub-types derived from the output shape so they can never drift from the schema\nexport type RuleSeverity = z.infer<typeof RuleSeveritySchema>;\nexport type RuleConfig = z.infer<typeof RuleConfigSchema>;\nexport type EngineVersionRule = z.infer<typeof EngineVersionRuleSchema>;\nexport type PackagesConfig = HermexConfig['packages'];\nexport type VersusConfig = HermexConfig['versus'][number];\nexport type RulesConfig = HermexConfig['rules'];\nexport type OutputConfig = HermexConfig['output'];\nexport type ReleaseAgeConfig = HermexConfig['releaseAge'];\nexport type ReleaseAgeThresholds = HermexConfig['releaseAge']['thresholds'];\n","import { existsSync } from 'node:fs';\nimport { join, resolve } from 'node:path';\nimport { pathToFileURL } from 'node:url';\nimport { HermexConfigSchema } from './schema';\nimport type { HermexConfig } from './schema';\n\nexport async function loadConfig(cwd: string): Promise<HermexConfig> {\n const configPath = join(cwd, 'hermex.config.ts');\n\n if (existsSync(configPath)) {\n const mod = await import(pathToFileURL(resolve(configPath)).href);\n return HermexConfigSchema.parse(mod.default ?? mod);\n }\n\n return HermexConfigSchema.parse({});\n}\n","import type { RegistryPackageInfo } from './types';\n\nexport async function fetchPackageInfo(\n name: string,\n registryUrl: string,\n authToken?: string,\n): Promise<RegistryPackageInfo | null> {\n const url = `${registryUrl.replace(/\\/$/, '')}/${encodeURIComponent(name).replace('%40', '@')}`;\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), 10_000);\n\n try {\n const headers: Record<string, string> = {\n Accept: 'application/json',\n };\n if (authToken) {\n headers['Authorization'] = `Bearer ${authToken}`;\n }\n\n const response = await fetch(url, {\n headers,\n signal: controller.signal,\n });\n\n clearTimeout(timeoutId);\n\n if (!response.ok) return null;\n\n const data = (await response.json()) as RegistryPackageInfo;\n return data;\n } catch {\n clearTimeout(timeoutId);\n return null;\n }\n}\n","import semver from 'semver';\nimport type { PackageDistribution } from '../utils/aggregator';\nimport type { ReleaseAgeConfig } from '../config/types';\nimport type {\n AvailableUpgrade,\n ReleaseAgeEntry,\n SemverBump,\n UpgradeLevel,\n} from './types';\nimport { fetchPackageInfo } from './client';\n\nconst CONCURRENCY = 8;\n\nfunction daysSince(dateStr: string): number {\n const ms = Date.now() - new Date(dateStr).getTime();\n return Math.floor(ms / (1000 * 60 * 60 * 24));\n}\n\nfunction classifyBump(installed: string, candidate: string): SemverBump | null {\n const diff = semver.diff(installed, candidate);\n if (!diff) return null;\n if (diff === 'patch' || diff === 'prepatch') return 'patch';\n if (diff === 'minor' || diff === 'preminor') return 'minor';\n if (diff === 'major' || diff === 'premajor') return 'major';\n return null;\n}\n\nfunction upgradeLevel(\n daysAgo: number,\n bump: SemverBump,\n thresholds: ReleaseAgeConfig['thresholds'],\n): UpgradeLevel | null {\n const threshold = thresholds[bump];\n if (threshold === false || threshold === undefined) return null;\n if (daysAgo > threshold) {\n // major bump past its threshold → mandatory, minor/patch → needs\n return bump === 'major' ? 'mandatory_upgrade' : 'needs_upgrade';\n }\n return null;\n}\n\nfunction computeReleaseAge(\n installedVersion: string,\n timeMap: Record<string, string>,\n deprecated: string | undefined,\n thresholds: ReleaseAgeConfig['thresholds'],\n): ReleaseAgeEntry {\n const upgrades: AvailableUpgrade[] = [];\n\n for (const [version, dateStr] of Object.entries(timeMap)) {\n if (version === 'created' || version === 'modified') continue;\n if (!semver.valid(version)) continue;\n if (semver.lte(version, installedVersion)) continue;\n\n const bump = classifyBump(installedVersion, version);\n if (!bump) continue;\n\n const daysAgo = daysSince(dateStr);\n const level = upgradeLevel(daysAgo, bump, thresholds);\n if (!level) continue;\n\n upgrades.push({\n version,\n releasedDaysAgo: daysAgo,\n semverBump: bump,\n level,\n });\n }\n\n // Keep only the oldest (most stable) release per bump level\n const worstPerBump = new Map<SemverBump, AvailableUpgrade>();\n for (const upgrade of upgrades) {\n const existing = worstPerBump.get(upgrade.semverBump);\n if (!existing || upgrade.releasedDaysAgo > existing.releasedDaysAgo) {\n worstPerBump.set(upgrade.semverBump, upgrade);\n }\n }\n\n const finalUpgrades = Array.from(worstPerBump.values()).sort(\n (a, b) => b.releasedDaysAgo - a.releasedDaysAgo,\n );\n\n const worstLevel: UpgradeLevel | null = finalUpgrades.some(\n (u) => u.level === 'mandatory_upgrade',\n )\n ? 'mandatory_upgrade'\n : finalUpgrades.length > 0\n ? 'needs_upgrade'\n : null;\n\n return {\n installedVersion,\n upgrades: finalUpgrades,\n worstLevel,\n deprecated,\n };\n}\n\nexport async function enrichWithReleaseAge(\n packages: PackageDistribution[],\n config: ReleaseAgeConfig,\n): Promise<{ enriched: PackageDistribution[]; skipped: number }> {\n const registryUrl = config.registry;\n const targets = packages.filter((p) => !p.internal && p.version);\n const enriched = [...packages];\n let skipped = 0;\n\n // Process in batches of CONCURRENCY\n for (let i = 0; i < targets.length; i += CONCURRENCY) {\n const batch = targets.slice(i, i + CONCURRENCY);\n const results = await Promise.all(\n batch.map(async (pkg) => {\n const info = await fetchPackageInfo(\n pkg.packageName,\n registryUrl,\n config.authToken,\n );\n if (!info || !info.time) {\n skipped++;\n return { pkg, entry: null };\n }\n\n const deprecated =\n info.versions?.[pkg.version!]?.deprecated ?? info.deprecated;\n\n const entry = computeReleaseAge(\n pkg.version!,\n info.time,\n typeof deprecated === 'string' ? deprecated : undefined,\n config.thresholds,\n );\n\n return { pkg, entry };\n }),\n );\n\n for (const { pkg, entry } of results) {\n if (!entry) continue;\n const idx = enriched.findIndex((p) => p.packageName === pkg.packageName);\n if (idx !== -1) {\n enriched[idx] = { ...enriched[idx], releaseAge: entry };\n }\n }\n }\n\n return { enriched, skipped };\n}\n","import { Command } from 'commander';\nimport ora from 'ora';\nimport chalk from 'chalk';\nimport { parseFile } from '../swc-parser';\nimport type { UsageReport } from '../swc-parser';\nimport type { ParseError } from '../swc-parser/types';\nimport { aggregateReports } from '../utils/aggregator';\nimport { printSummary } from '../utils/print-summary';\nimport { printDetails } from '../utils/print-details';\nimport { printComponents } from '../utils/print-components';\nimport { printPatterns } from '../utils/print-patterns';\nimport { printPackages } from '../utils/print-packages';\nimport { printVersus } from '../utils/print-versus';\nimport { printRules } from '../utils/print-rules';\nimport { printErrors } from '../utils/print-errors';\nimport { findFiles } from '../utils/file-utils';\nimport { findAndParseLockfile } from '../lock-parser';\nimport { loadConfig } from '../config/loader';\nimport { evaluateRules } from '../rules/evaluator';\nimport { enrichWithReleaseAge } from '../npm-registry/enricher';\nimport type { HermexConfig } from '../config/types';\n\nexport function registerScanCommand(program: Command) {\n program\n .command('scan')\n .description('Scan and analyze local files')\n .action(async () => {\n const config = await loadConfig(process.cwd());\n await executeScan(config);\n });\n}\n\nexport async function executeScan(config: HermexConfig) {\n const startTime = Date.now();\n const spinner = ora('Parsing lockfile...').start();\n\n try {\n const lockfileResult = findAndParseLockfile(process.cwd());\n\n spinner.succeed(\n chalk.blue(\n `📦 Found ${lockfileResult.lockfileType} lockfile (supports: ${lockfileResult.supportedVersions.join(', ')}) - ${Object.keys(lockfileResult.versions).length} packages`,\n ),\n );\n\n spinner.start('Finding files...');\n const files = await findFiles(config.includes, config.excludes);\n\n if (files.length === 0) {\n spinner.fail(\n chalk.red(\n `No files found matching includes: ${config.includes.join(', ')}`,\n ),\n );\n return;\n }\n\n spinner.succeed(chalk.green(` Found ${files.length} files`));\n\n spinner.start('Analyzing files...');\n const reports: UsageReport[] = [];\n const parseErrors: ParseError[] = [];\n\n for (let i = 0; i < files.length; i++) {\n const file = files[i];\n spinner.text = `Analyzing files... (${i + 1}/${files.length})`;\n\n try {\n const report = parseFile(file);\n if (report) {\n reports.push(report);\n }\n } catch (error: any) {\n parseErrors.push({ file, message: error.message ?? String(error) });\n }\n }\n\n spinner.succeed(\n chalk.green(\n `Analysis complete! Analyzed ${reports.length}/${files.length} files`,\n ),\n );\n\n printErrors(parseErrors);\n\n const elapsedTime = (Date.now() - startTime) / 1000;\n\n const aggregated = aggregateReports(\n reports,\n lockfileResult.versions,\n config,\n lockfileResult.multiVersions,\n );\n\n const evaluatorViolations = evaluateRules(\n process.cwd(),\n config.rules,\n config.excludes,\n );\n aggregated.ruleViolations = [\n ...aggregated.ruleViolations,\n ...evaluatorViolations,\n ];\n\n if (config.releaseAge.enabled) {\n spinner.start('Fetching release age from registry...');\n const { enriched, skipped } = await enrichWithReleaseAge(\n aggregated.packageDistribution,\n config.releaseAge,\n );\n aggregated.packageDistribution = enriched;\n spinner.succeed(\n chalk.blue(\n `📅 Release age fetched${skipped > 0 ? chalk.gray(` (${skipped} packages skipped — registry unreachable or not found)`) : ''}`,\n ),\n );\n }\n\n printScanResults(aggregated, config, elapsedTime);\n } catch (error: any) {\n spinner.fail(chalk.red('Analysis failed: ' + error.message));\n console.error(error);\n process.exit(1);\n }\n}\n\nfunction printScanResults(\n aggregated: ReturnType<typeof aggregateReports>,\n config: HermexConfig,\n _elapsedTime: number,\n) {\n if (config.output.packages) {\n printPackages(aggregated, config.output.packages);\n }\n\n if (config.output.versus) {\n printVersus(aggregated);\n }\n\n if (config.output.rules) {\n printRules(aggregated);\n }\n\n if (config.output.details) {\n printDetails(aggregated);\n }\n\n if (config.output.components) {\n printComponents(aggregated, config.output.components);\n }\n\n if (config.output.patterns) {\n printPatterns(aggregated, config.output.patterns);\n }\n\n if (config.output.summary) {\n printSummary(aggregated);\n }\n}\n","","#!/usr/bin/env node\nimport { Command } from 'commander';\nimport { registerScanCommand } from './commands/scan';\nimport packageJson from '../package.json';\nimport type { HermexConfig } from './config/types';\n\nexport const program = new Command();\n\nexport function defineConfig(\n config: Partial<HermexConfig>,\n): Partial<HermexConfig> {\n return config;\n}\n\nprogram\n .name('hermex')\n .description('Analyze React component usage patterns in your codebase')\n .version(packageJson.version);\n\nregisterScanCommand(program);\n\nprogram.parse(process.argv);\n"],"mappings":";;;;;;;;;;;;;;;;;;AAEA,SAAgB,cAA2B;CAyBzC,OAAO;EACL,eAAA;GAxBA,+BAAe,IAAI,IAAI;GACvB,8BAAc,IAAI,IAAI;GACtB,kCAAkB,IAAI,IAAI;GAC1B,gCAAgB,IAAI,IAAI;GACxB,gCAAgB,IAAI,IAAI;GACxB,qCAAqB,IAAI,IAAI;GAC7B,mCAAmB,IAAI,IAAI;GAC3B,6BAAa,IAAI,IAAI;GACrB,gCAAgB,IAAI,IAAI;GACxB,kCAAkB,IAAI,IAAI;GAC1B,+BAAe,IAAI,IAAI;GACvB,gCAAgB,IAAI,IAAI;GACxB,0BAAU,IAAI,IAAI;GAClB,6BAAa,IAAI,IAAI;GACrB,8BAAc,IAAI,IAAI;GACtB,+BAAe,IAAI,IAAI;GACvB,oCAAoB,IAAI,IAAI;GAC5B,6BAAa,IAAI,IAAI;GACrB,0BAAU,IAAI,IAAI;GAClB,mCAAmB,IAAI,IAAI;GAC3B,+BAAe,IAAI,IAAI;EAIX;EACZ,gCAAgB,IAAI,IAAI;EACxB,gCAAgB,IAAI,IAAI;CAC1B;AACF;;;;;;;;;;ACtBA,SAAgB,yBACd,MACA,OACM;CACN,MAAM,SAAS,KAAK,OAAO;CAI3B,KAAK,MAAM,QAAQ,KAAK,YACtB,QAAQ,KAAK,MAAb;EACE,KAAK;GACH,qBAAqB,MAAM,QAAQ,MAAM,KAAK;GAC9C;EAEF,KAAK;GACH,uBAAuB,MAAM,QAAQ,MAAM,KAAK;GAChD;EAEF,KAAK;GACH,mBAAmB,MAAM,QAAQ,MAAM,KAAK;GAC5C;CACJ;AAEJ;AAEA,SAAS,qBACP,MACA,QACA,MACA,OACM;CACN,MAAM,OAAO,KAAK,MAAM;CAExB,MAAM,cAAc,eAAe,IAAI;EACrC;EACA;EACA,MAAM,KAAK,MAAM,SAAS;CAC5B,CAAC;CAED,MAAM,eAAe,IAAI,IAAI;AAC/B;AAEA,SAAS,uBACP,MACA,QACA,MACA,OACM;CACN,MAAM,OAAO,KAAK,MAAM;CAExB,MAAM,cAAc,iBAAiB,IAAI;EACvC;EACA;EACA,MAAM,KAAK,MAAM,SAAS;CAC5B,CAAC;CAED,MAAM,eAAe,IAAI,IAAI;AAC/B;AAEA,SAAS,mBACP,MACA,QACA,MACA,OACM;CACN,MAAM,eAAe,KAAK,WAAW,KAAK,SAAS,QAAQ,KAAK,MAAM;CACtE,MAAM,YAAY,KAAK,MAAM;CAE7B,MAAM,cAAc,aAAa,IAAI;EACnC,MAAM;EACN;EACA,MAAM,KAAK,MAAM,SAAS;CAC5B,CAAC;CAGD,IAAI,iBAAiB,WACnB,MAAM,cAAc,eAAe,IAAI,WAAW;EAChD,UAAU;EACV,OAAO;EACP;EACA,MAAM,KAAK,MAAM,SAAS;CAC5B,CAAC;CAGH,MAAM,eAAe,IAAI,SAAS;AACpC;;;;;;AC1FA,SAAgB,kBAAkB,UAAuB;CACvD,IAAI,CAAC,UAAU,OAAO;CAEtB,QAAQ,SAAS,MAAjB;EACE,KAAK,cACH,OAAO,SAAS;EAClB,KAAK,uBACH,OAAO,GAAG,kBAAkB,SAAS,MAAM,EAAE,GAAG,SAAS,SAAS;EACpE,SACE,OAAO;CACX;AACF;;;;AAKA,SAAgB,4BACd,UACA,OACS;CACT,IAAI,UAAU,SAAS,uBAAuB;EAC5C,MAAM,aAAa,kBAAkB,SAAS,MAAM;EACpD,OAAO,MAAM,eAAe,IAAI,UAAU;CAC5C;CACA,OAAO;AACT;;;;AAKA,SAAgB,gBAAgB,YAI7B;CACD,IAAI,CAAC,YAAY,OAAO,CAAC;CAEzB,OAAO,WACJ,KAAK,SAAS;EACb,IAAI,KAAK,SAAS,gBAChB,OAAO;GACL,MAAM,KAAK,MAAM,SAAS,KAAK,MAAM,MAAM;GAC3C,OAAO,yBAAyB,KAAK,KAAK;EAC5C;EAEF,IAAI,KAAK,SAAS,iBAChB,OAAO;GACL,MAAM;GACN,OAAO;GACP,UAAU;EACZ;EAEF,OAAO;CACT,CAAC,CAAC,CACD,OAAO,OAAO;AAKnB;;;;AAKA,SAAgB,yBAAyB,OAAiB;CACxD,IAAI,CAAC,OAAO,OAAO;CAEnB,QAAQ,MAAM,MAAd;EACE,KAAK,iBACH,OAAO,MAAM;EACf,KAAK,0BACH,OAAO,uBAAuB,MAAM,UAAU;EAChD,SACE,OAAO;CACX;AACF;;;;AAKA,SAAgB,uBAAuB,MAAgB;CACrD,IAAI,CAAC,MAAM,OAAO;CAElB,QAAQ,KAAK,MAAb;EACE,KAAK;EACL,KAAK;EACL,KAAK,kBACH,OAAO,KAAK;EACd,KAAK,cACH,OAAO,IAAI,KAAK,MAAM;EACxB,KAAK;EACL,KAAK,sBACH,OAAO;EACT,KAAK,oBACH,OAAO;EACT,KAAK,mBACH,OAAO;EACT,SACE,OAAO;CACX;AACF;;;;AAKA,SAAgB,gBAAgB,QAAqB;CACnD,IAAI,CAAC,QAAQ,OAAO;CAEpB,QAAQ,OAAO,MAAf;EACE,KAAK,yBACH,OAAO;EACT,KAAK,mBACH,OAAO;EACT,KAAK,oBACH,OAAO;EACT,KAAK,kBACH,OAAO;EACT,KAAK,sBACH,OAAO;EACT,SACE,OAAO;CACX;AACF;;;;;;AC1HA,SAAgB,qBACd,YACA,eACA,OACe;CACf,MAAM,WAA0B;EAC9B,YAAY,CAAC;EACb,WAAW;EACX,iBAAiB;EACjB,kBAAkB;EAClB,aAAa,CAAC;CAChB;CAEA,IAAI,CAAC,YAAY,OAAO;CAExB,KAAK,MAAM,QAAQ,YACjB,IAAI,KAAK,SAAS,gBAAgB;EAChC,MAAM,WAAW,KAAK,MAAM,SAAS,KAAK,MAAM,MAAM;EACtD,IAAI,UAAU;GACZ,SAAS,WAAW,KAAK,QAAQ;GAEjC,MAAM,aAAyB;IAC7B,MAAM;IACN,MAAM,YAAY,KAAK,KAAK;IAC5B,gBAAgB,SAAS,WAAW,IAAI;IACxC,WAAW,cAAc,KAAK,KAAK;GACrC;GAEA,IAAI,WAAW,gBACb,SAAS,mBAAmB;GAE9B,IAAI,WAAW,WACb,SAAS,kBAAkB;GAG7B,SAAS,YAAY,KAAK,UAAU;EACtC;CACF,OAAO,IAAI,KAAK,SAAS,iBAAiB;EACxC,SAAS,YAAY;EACrB,SAAS,YAAY,KAAK;GACxB,MAAM;GACN,MAAM;GACN,UAAU;GACV,WAAW;GACX,gBAAgB;GAChB,SAAS;EACX,CAAC;EACD,SAAS,kBAAkB;CAC7B;CAIF,MAAM,cAAc,cAAc,IAAI,eAAe,QAAQ;CAE7D,OAAO;AACT;;;;AAKA,SAAS,YAAY,OAAoB;CACvC,IAAI,CAAC,OAAO,OAAO;CAEnB,QAAQ,MAAM,MAAd;EACE,KAAK,iBACH,OAAO;EACT,KAAK,0BAA0B;GAC7B,MAAM,OAAO,MAAM;GACnB,IAAI,CAAC,MAAM,OAAO;GAClB,QAAQ,KAAK,MAAb;IACE,KAAK,kBACH,OAAO;IACT,KAAK,kBACH,OAAO;IACT,KAAK,iBACH,OAAO;IACT,KAAK;IACL,KAAK,sBACH,OAAO;IACT,KAAK,oBACH,OAAO;IACT,KAAK,mBACH,OAAO;IACT,KAAK,cACH,OAAO;IACT,SACE,OAAO;GACX;EACF;EACA,SACE,OAAO;CACX;AACF;;;;AAKA,SAAS,cAAc,OAAqB;CAC1C,IAAI,CAAC,OAAO,OAAO;CACnB,IAAI,MAAM,SAAS,0BAA0B;EAC3C,MAAM,OAAO,MAAM;EACnB,IAAI,CAAC,MAAM,OAAO;EAClB,OACE,KAAK,SAAS,sBACd,KAAK,SAAS,qBACd,KAAK,SAAS,oBACd,KAAK,SAAS;CAElB;CACA,OAAO;AACT;;;;;;ACvGA,SAAgB,kBAAkB,MAAW,OAA0B;CACrE,IAAI,KAAK,SACP,yBAAyB,KAAK,SAAS,OAAO,IAAI;AAEtD;;;;AAKA,SAAgB,yBACd,MACA,OACA,QACM;CACN,MAAM,cAAc,kBAAkB,KAAK,IAAI;CAG/C,IACE,CAAC,MAAM,eAAe,IAAI,WAAW,KACrC,CAAC,4BAA4B,KAAK,MAAM,KAAK,GAE7C;CAGF,MAAM,gBAAgB,qBACpB,KAAK,YACL,aACA,KACF;CACA,MAAM,QAAkB;EACtB,WAAW;EACX,OAAO,gBAAgB,KAAK,UAAU,CAAC,CAAC,KAAK,MAAM,EAAE,IAAI;EACzD;EACA,MAAM,KAAK,MAAM,SAAS;EAC1B,SAAS,gBAAgB,MAAM;CACjC;CAGA,IAAI,CAAC,MAAM,cAAc,SAAS,IAAI,WAAW,GAC/C,MAAM,cAAc,SAAS,IAAI,aAAa,KAAK;AAIvD;;;;;;AClDA,SAAgB,iBAAiB,MAAc,OAA6B;CAC1E,OAAO,MAAM,eAAe,IAAI,IAAI,KAAK,MAAM,eAAe,IAAI,IAAI;AACxE;;;;;;ACDA,SAAgB,2BACd,MACA,OACM;CACN,IAAI,CAAC,KAAK,cAAc;CAExB,KAAK,MAAM,QAAQ,KAAK,cAAc;EACpC,IAAI,KAAK,IAAI,SAAS,cAAc;GAClC,MAAM,UAAU,KAAK,GAAG;GAGxB,IAAI,KAAK,MAAM;IACb,MAAM,aAAa,sBAAsB,KAAK,IAAI;IAClD,IAAI,cAAc,iBAAiB,YAAY,KAAK,GAAG;KACrD,MAAM,cAAc,oBAAoB,IAAI,SAAS;MACnD;MACA,MAAM,KAAK,MAAM,SAAS;KAC5B,CAAC;KACD,MAAM,eAAe,IAAI,OAAO;IAElC;GACF;EACF;EAGA,IAAI,KAAK,IAAI,SAAS,iBACpB,4BAA4B,KAAK,IAAI,KAAK,MAAM,KAAK;CAEzD;AACF;;;;AAKA,SAAgB,4BACd,SACA,MACA,OACM;CACN,IAAI,CAAC,QAAQ,YAAY;CAEzB,KAAK,MAAM,QAAQ,QAAQ,YACzB,IACE,KAAK,SAAS,+BACd,KAAK,KAAK,SAAS,cACnB;EACA,MAAM,WAAW,KAAK,IAAI;EAE1B,IAAI,MAAM,SAAS,gBAAgB,MAAM,eAAe,IAAI,KAAK,KAAK,GAAG;GACvE,MAAM,cAAc,kBAAkB,IAAI;IACxC,UAAU;IACV,QAAQ,KAAK;IACb,MAAM,QAAQ,MAAM,SAAS;GAC/B,CAAC;GACD,MAAM,eAAe,IAAI,QAAQ;EAEnC;CACF;AAEJ;;;;AAKA,SAAS,sBAAsB,MAA0B;CACvD,QAAQ,KAAK,MAAb;EACE,KAAK,cACH,OAAO,KAAK;EACd,KAAK,oBACH,OAAO,GAAG,sBAAsB,KAAK,MAAM,EAAE,GAAG,KAAK,SAAS;EAChE,KAAK,yBACH,OAAO,GAAG,sBAAsB,KAAK,UAAU,EAAE,KAAK,sBAAsB,KAAK,SAAS;EAC5F,SACE,OAAO;CACX;AACF;;;;;;AC5EA,SAAgB,6BACd,MACA,OACM;CACN,MAAM,aACJ,KAAK,YAAY,SAAS,eAAe,KAAK,WAAW,QAAQ;CACnE,MAAM,YACJ,KAAK,WAAW,SAAS,eAAe,KAAK,UAAU,QAAQ;CAEjE,IACG,cAAc,MAAM,eAAe,IAAI,UAAU,KACjD,aAAa,MAAM,eAAe,IAAI,SAAS,GAEhD,MAAM,cAAc,iBAAiB,IAAI;EACvC,YAAY,cAAc;EAC1B,WAAW,aAAa;EACxB,MAAM,KAAK,MAAM,SAAS;CAC5B,CAAC;AAGL;;;;;;ACpBA,SAAgB,uBAAuB,MAAW,OAA0B;CAS1E,IAPsB,KAAK,UAAU,MAAM,SAAc;EACvD,IAAI,MAAM,SAAS,cACjB,OAAO,MAAM,eAAe,IAAI,KAAK,KAAK;EAE5C,OAAO;CACT,CAAC,GAGC,MAAM,cAAc,cAAc,IAAI;EACpC,YAAY,KAAK,UACb,KAAK,SAAc,MAAM,KAAK,CAAC,CAChC,OAAO,OAAO;EACjB,MAAM,KAAK,MAAM,SAAS;CAC5B,CAAC;AAGL;;;;AAKA,SAAgB,wBAAwB,MAAW,OAA0B;CAE3E,MAAM,iBAAiB,KAAK,YAAY,QAAQ,SAAc;EAC5D,IAAI,KAAK,SAAS,sBAAsB,KAAK,OAAO,SAAS,cAC3D,OAAO,MAAM,eAAe,IAAI,KAAK,MAAM,KAAK;EAElD,OAAO;CACT,CAAC;CAED,IAAI,gBAAgB,SAAS,GAC3B,MAAM,cAAc,eAAe,IAAI;EACrC,UAAU,eAAe,KAAK,UAAe;GAC3C,KAAK,KAAK,KAAK,SAAS;GACxB,WAAW,KAAK,OAAO;EACzB,EAAE;EACF,MAAM,KAAK,MAAM,SAAS;CAC5B,CAAC;AAGL;;;;;;AC1CA,SAAgB,kBAAkB,MAAW,OAA0B;CACrE,MAAM,MAAM,KAAK,YAAY;CAC7B,IACE,KAAK,SAAS,6BACd,IAAI,MAAM,SAAS,kBACnB;EACA,MAAM,aAAa,IAAI;EACvB,IAAI,WAAW,QAAQ,SAAS,UAAU;GACxC,MAAM,SAAS,WAAW,YAAY,EAAE,EAAE;GAC1C,IAAI,QACF,MAAM,cAAc,YAAY,IAAI;IAClC;IACA,MAAM,KAAK,MAAM,SAAS;GAC5B,CAAC;EAGL;CACF;AACF;;;;AAKA,SAAgB,qBAAqB,MAAW,OAA0B;CACxE,MAAM,SAAS,KAAK,YAAY,EAAE,EAAE;CACpC,IAAI,QACF,MAAM,cAAc,eAAe,IAAI;EACrC;EACA,MAAM,KAAK,MAAM,SAAS;CAC5B,CAAC;AAGL;;;;;;AChCA,SAAgB,gBAAgB,MAAW,OAA0B;CACnE,MAAM,cAAc,SAAS,IAAI;EAC/B,UAAU,KAAK,QAAQ,SAAS;EAChC,WAAW,KAAK,YAAY,EAAE,EAAE,SAAS;EACzC,MAAM,KAAK,MAAM,SAAS;CAC5B,CAAC;AAEH;;;;AAKA,SAAgB,iBAAiB,MAAW,OAA0B;CACpE,MAAM,YAAY,KAAK,YAAY;CACnC,IACE,WAAW,SAAS,gBACpB,MAAM,eAAe,IAAI,UAAU,KAAK,GAExC,MAAM,cAAc,mBAAmB,IAAI;EACzC,WAAW,UAAU;EACrB,MAAM,KAAK,MAAM,SAAS;CAC5B,CAAC;AAGL;;;;AAKA,SAAgB,uBAAuB,MAAW,OAA0B;CAC1E,MAAM,cAAc,cAAc,IAAI,EACpC,MAAM,KAAK,MAAM,SAAS,EAC5B,CAAC;AAEH;;;;AAKA,SAAgB,mBAAmB,MAAW,OAA0B;CACtE,MAAM,cAAc,YAAY,IAAI,EAClC,MAAM,KAAK,MAAM,SAAS,EAC5B,CAAC;AAEH;;;;AAKA,SAAgB,wBAAwB,MAAW,OAA0B;CAE3E,IACE,KAAK,QAAQ,SAAS,gBACtB,MAAM,eAAe,IAAI,KAAK,OAAO,KAAK,GAC1C;EAEA,MAAM,eAAe,KAAK,UAAU;EAEpC,IAAI,cAEF,MAAM,eAAe,IAAI,YAAY;CAGzC;AACF;;;;AAKA,SAAgB,aAAa,MAAW,OAA6B;CAEnE,OACE,KAAK,QAAQ,SAAS,gBACtB,KAAK,WAAW,MACb,QACC,IAAI,SAAS,gBAAgB,MAAM,eAAe,IAAI,IAAI,KAAK,CACnE;AAEJ;;;;;;AC1DA,SAAgB,UACd,MACA,OACA,UAA0B,CAAC,GACrB;CACN,IAAI,CAAC,MAAM;CAEX,QAAQ,KAAK,MAAb;EACE,KAAK;GAEH,IAAI,KAAK,MAAM;IACb,KAAK,MAAM,QAAQ,KAAK,MACtB,IAAI,KAAK,SAAS,qBAChB,UAAU,MAAM,OAAO,OAAO;IAIlC,KAAK,MAAM,QAAQ,KAAK,MACtB,IAAI,KAAK,SAAS,qBAChB,UAAU,MAAM,OAAO;KAAE,GAAG;KAAS,QAAQ;IAAK,CAAC;GAGzD;GACA;EAEF,KAAK;GACH,yBAAyB,MAAM,KAAK;GACpC;EAEF,KAAK;GACH,sBAAsB,MAAM,OAAO,OAAO;GAC1C;EAEF,KAAK;GACH,2BAA2B,MAAM,KAAK;GACtC,cAAc,MAAM,OAAO,OAAO;GAClC;EAEF,KAAK;EACL,KAAK;GACH,kBAAkB,MAAM,KAAK;GAC7B,cAAc,MAAM,OAAO,OAAO;GAClC;EAEF,KAAK;GACH,yBAAyB,MAAM,OAAO,QAAQ,MAAM;GACpD;EAEF,KAAK;GACH,uBAAuB,MAAM,KAAK;GAClC,cAAc,MAAM,OAAO,OAAO;GAClC;EAEF,KAAK;GACH,wBAAwB,MAAM,KAAK;GACnC,cAAc,MAAM,OAAO,OAAO;GAClC;EAEF,KAAK;GACH,wBAAwB,MAAM,KAAK;GACnC,cAAc,MAAM,OAAO,OAAO;GAClC;EAEF,KAAK;GACH,6BAA6B,MAAM,KAAK;GACxC,cAAc,MAAM,OAAO,OAAO;GAClC;EAEF,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;GACH,cAAc,MAAM,OAAO;IAAE,GAAG;IAAS,QAAQ;GAAK,CAAC;GACvD;EAEF;GACE,cAAc,MAAM,OAAO,OAAO;GAClC;CACJ;AACF;;;;AAKA,SAAS,sBACP,MACA,OACA,SACM;CAEN,IACE,KAAK,QAAQ,UAAU,UACtB,KAAK,QAAQ,QAAQ,UAAU,WAC9B,KAAK,QAAQ,UAAU,UAAU,QAEnC,kBAAkB,MAAM,KAAK;CAI/B,IAAI,KAAK,QAAQ,SAAS,UACxB,qBAAqB,MAAM,KAAK;CAIlC,IAAI,aAAa,MAAM,KAAK,GAC1B,gBAAgB,MAAM,KAAK;CAI7B,IAAI,KAAK,QAAQ,QAAQ,UAAU;MAC7B,KAAK,QAAQ,UAAU,UAAU,QACnC,iBAAiB,MAAM,KAAK;OACvB,IAAI,KAAK,QAAQ,UAAU,UAAU,cAC1C,uBAAuB,MAAM,KAAK;CAAA;CAKtC,IACE,KAAK,QAAQ,UAAU,UAAU,kBACjC,KAAK,QAAQ,UAAU,gBAEvB,mBAAmB,MAAM,KAAK;CAGhC,cAAc,MAAM,OAAO,OAAO;AACpC;;;;AAKA,SAAS,cACP,MACA,OACA,SACM;CACN,IAAI,CAAC,MAAM;CAEX,KAAK,MAAM,OAAO,MAAM;EACtB,MAAM,QAAQ,KAAK;EAEnB,IAAI,MAAM,QAAQ,KAAK;QAChB,MAAM,QAAQ,OACjB,IAAI,QAAQ,OAAO,SAAS,UAC1B,UAAU,MAAM,OAAO;IAAE,GAAG;IAAS,QAAQ;GAAK,CAAC;EAAA,OAGlD,IAAI,SAAS,OAAO,UAAU,YAAY,MAAM,MACrD,UAAU,OAAO,OAAO;GAAE,GAAG;GAAS,QAAQ;EAAK,CAAC;CAExD;AACF;;;;;;AC9KA,SAAgB,eAAe,OAAiC;CAgD9D,OAAO;EA9CL,SAAS;GACP,cACE,MAAM,cAAc,eAAe,OACnC,MAAM,cAAc,aAAa,OACjC,MAAM,cAAc,iBAAiB;GACvC,iBAAiB,MAAM,eAAe;GACtC,oBAAoB,uBAAuB,KAAK;EAClD;EACA,UAAU;GACR,SAAS;IACP,SAAS,MAAM,KAAK,MAAM,cAAc,cAAc;IACtD,OAAO,MAAM,KAAK,MAAM,cAAc,YAAY;IAClD,WAAW,MAAM,KAAK,MAAM,cAAc,gBAAgB;IAC1D,SAAS,MAAM,KAAK,MAAM,cAAc,eAAe,OAAO,CAAC;GACjE;GACA,OAAO;IACL,KAAK,MAAM,KAAK,MAAM,cAAc,SAAS,OAAO,CAAC;IACrD,WAAW,MAAM,KACf,MAAM,cAAc,oBAAoB,QAAQ,CAClD,CAAC,CAAC,KAAK,CAAC,KAAK,YAAY;KACvB,UAAU;KACV,YAAY,MAAM;IACpB,EAAE;IACF,eAAe,MAAM,KAAK,MAAM,cAAc,iBAAiB;IAC/D,aAAa,MAAM,KAAK,MAAM,cAAc,gBAAgB;IAC5D,QAAQ,MAAM,KAAK,MAAM,cAAc,aAAa;IACpD,SAAS,MAAM,KAAK,MAAM,cAAc,cAAc;GACxD;GACA,UAAU;IACR,MAAM,MAAM,KAAK,MAAM,cAAc,WAAW;IAChD,SAAS,MAAM,KAAK,MAAM,cAAc,cAAc;IACtD,KAAK,MAAM,KAAK,MAAM,cAAc,QAAQ;IAC5C,MAAM,MAAM,KAAK,MAAM,cAAc,kBAAkB;IACvD,YAAY,MAAM,KAAK,MAAM,cAAc,aAAa;IACxD,QAAQ,MAAM,KAAK,MAAM,cAAc,WAAW;GACpD;GACA,OAAO,MAAM,KAAK,MAAM,cAAc,cAAc,QAAQ,CAAC,CAAC,CAAC,KAC5D,CAAC,WAAW,eAAe;IAC1B;IACA;GACF,EACF;EACF;EACA,YAAY,MAAM,KAAK,MAAM,cAAc,CAAC,CAAC,KAAK;CAGxC;AACd;;;;AAKA,SAAS,uBAAuB,OAA4B;CAC1D,IAAI,MAAM;CACV,MAAM,WAAW,MAAM;CAEvB,KAAK,MAAM,OAAO,UAAU;EAC1B,MAAM,UAAW,SAAiB;EAClC,IAAI,mBAAmB,KACrB,OAAO,QAAQ;OACV,IAAI,mBAAmB,KAC5B,OAAO,QAAQ;CAEnB;CAEA,OAAO;AACT;;;AChEA,SAAS,kBAAkB,UAAmC;CAC5D,MAAM,MAAM,KAAK,QAAQ,QAAQ,CAAC,CAAC,YAAY;CAC/C,IAAI,QAAQ,OACV,OAAO;EACL,QAAQ;EACR,KAAK;EACL,YAAY;EACZ,eAAe;CACjB;CACF,IAAI,QAAQ,QACV,OAAO;EACL,QAAQ;EACR,KAAK;EACL,YAAY;EACZ,eAAe;CACjB;CACF,IAAI,QAAQ,QACV,OAAO;EACL,QAAQ;EACR,KAAK;EACL,YAAY;EACZ,kBAAkB;CACpB;CAEF,OAAO;EACL,QAAQ;EACR,KAAK;EACL,YAAY;EACZ,kBAAkB;CACpB;AACF;AAEA,SAAgB,UAAU,MAAc,WAAW,YAAyB;CAC1E,MAAM,QAAQ,YAAY;CAE1B,UADY,UAAU,MAAM,kBAAkB,QAAQ,CAC1C,GAAG,KAAK;CACpB,OAAO,eAAe,KAAK;AAC7B;AAEA,SAAgB,UAAU,UAAsC;CAE9D,OAAO,UADM,GAAG,aAAa,UAAU,MACnB,GAAG,QAAQ;AACjC;;;AC5BA,SAAgB,QAAW,KAA+B;CACxD,IAAI,CAAC,KAAK,OAAO,CAAC;CAClB,OAAO,MAAM,QAAQ,GAAG,IAAI,MAAM,CAAC,GAAG;AACxC;AAEA,SAAgB,YACd,UACA,UACA,QACU;CACV,MAAM,UAAoB,CAAC;CAC3B,KAAK,MAAM,WAAW,UAAU;EAC9B,MAAM,QAAQ,SAAS,SAAS;GAAE,KAAK;GAAU,OAAO;GAAM;EAAO,CAAC;EACtE,QAAQ,KAAK,GAAG,MAAM,KAAK,MAAMA,OAAK,KAAK,UAAU,CAAC,CAAC,CAAC;CAC1D;CACA,OAAO,CAAC,GAAG,IAAI,IAAI,OAAO,CAAC;AAC7B;AAEA,SAAgB,gBACd,UACgC;CAChC,IAAI;EACF,MAAM,UAAUC,KAAG,aACjBD,OAAK,KAAK,UAAU,cAAc,GAClC,OACF;EACA,OAAO,KAAK,MAAM,OAAO;CAC3B,QAAQ;EACN,OAAO;CACT;AACF;;;ACjDA,SAAgB,kBACd,UACA,aACA,UACiB;CACjB,MAAM,aAA8B,CAAC;CAErC,KAAK,MAAM,QAAQ,QAAQ,YAAY,YAAY,GAAG;EACpD,MAAM,UAAU,YAAY,KAAK,UAAU,UAAU,QAAQ;EAC7D,IAAI,QAAQ,SAAS,GACnB,WAAW,KAAK;GACd,MAAM;GACN,UAAU,KAAK;GACf,UAAU,KAAK;GACf,SAAS,KAAK;GACd,cAAc;EAChB,CAAC;CAEL;CAEA,KAAK,MAAM,QAAQ,QAAQ,YAAY,aAAa,GAElD,IADgB,YAAY,KAAK,UAAU,UAAU,QAC3C,CAAC,CAAC,WAAW,GACrB,WAAW,KAAK;EACd,MAAM;EACN,UAAU,KAAK;EACf,UAAU,KAAK;EACf,SAAS,KAAK;EACd,cAAc,CAAC;CACjB,CAAC;CAIL,KAAK,MAAM,QAAQ,QAAQ,YAAY,WAAW,GAEhD,IADgB,YAAY,KAAK,UAAU,UAAU,QAC3C,CAAC,CAAC,WAAW,GACrB,WAAW,KAAK;EACd,MAAM;EACN,UAAU,KAAK;EACf,UAAU,KAAK;EACf,SAAS,KAAK;EACd,cAAc,CAAC;CACjB,CAAC;CAIL,OAAO;AACT;;;AC9CA,SAAgB,oBACd,UACA,aACiB;CACjB,MAAM,QAAQ,QAAQ,YAAY,eAAe;CACjD,IAAI,MAAM,WAAW,GACnB,OAAO,CAAC;CAGV,MAAM,MAAM,gBAAgB,QAAQ;CACpC,MAAM,aAAa,OAAO,KACvB,KAAK,WAAkD,CAAC,CAC3D;CAEA,OAAO,MACJ,QACE,SACC,CAAC,KAAK,SAAS,MAAM,MACnB,WAAW,MAAM,MAAM,WAAW,QAAQ,GAAG,CAAC,CAAC,CACjD,CACJ,CAAC,CACA,KAAK,UAAU;EACd,MAAM;EACN,UAAU,KAAK;EACf,UAAU,KAAK;EACf,SAAS,KAAK;EACd,cAAc,CAAC;CACjB,EAAE;AACN;;;AC7BA,SAAgB,0BACd,UACA,aACiB;CACjB,MAAM,QAAQ,QAAQ,YAAY,sBAAsB;CACxD,IAAI,MAAM,WAAW,GACnB,OAAO,CAAC;CAGV,MAAM,MAAM,gBAAgB,QAAQ;CACpC,MAAM,YAAY,MAAM,OAAO,KAAK,GAAG,IAAI,CAAC;CAE5C,OAAO,MACJ,QAAQ,SAAS,CAAC,KAAK,SAAS,MAAM,MAAM,UAAU,SAAS,CAAC,CAAC,CAAC,CAAC,CACnE,KAAK,UAAU;EACd,MAAM;EACN,UAAU,KAAK;EACf,UAAU,KAAK;EACf,SAAS,KAAK;EACd,cAAc,CAAC;CACjB,EAAE;AACN;;;ACpBA,SAAgB,sBACd,UACA,aACiB;CACjB,MAAM,QAAQ,QAAQ,YAAY,cAAc;CAChD,IAAI,MAAM,WAAW,GACnB,OAAO,CAAC;CAIV,MAAM,aADM,gBAAgB,QACP,CAAC,EAAE,QAAA,EAAgD;CAExE,OAAO,MAAM,SAAS,SAA0B;EAC9C,IAAI,CAAC,WACH,OAAO,CACL;GACE,MAAM;GACN,UAAU,KAAK;GACf,UAAU,CAAC;GACX,SAAS,KAAK,WAAW;GACzB,cAAc,CAAC;GACf,eAAe,KAAK;EACtB,CACF;EAGF,MAAM,SAAS,OAAO,WAAW,SAAS;EAC1C,IAAI,CAAC,UAAU,CAAC,OAAO,UAAU,QAAQ,KAAK,KAAK,GACjD,OAAO,CACL;GACE,MAAM;GACN,UAAU,KAAK;GACf,UAAU,CAAC;GACX,SAAS,KAAK;GACd,cAAc,CAAC;GACf,gBAAgB;GAChB,eAAe,KAAK;EACtB,CACF;EAGF,OAAO,CAAC;CACV,CAAC;AACH;;;ACvCA,SAAgB,cACd,UACA,aACA,UACoC;CACpC,OAAO;EACL,GAAG,kBAAkB,UAAU,aAAa,QAAQ;EACpD,GAAG,oBAAoB,UAAU,WAAW;EAC5C,GAAG,0BAA0B,UAAU,WAAW;EAClD,GAAG,sBAAsB,UAAU,WAAW;CAChD;AACF;;;ACZA,SAAS,aAAa,OAAe,OAAuB;CAC1D,OAAO,QAAQ,IAAK,QAAQ,QAAS,MAAM;AAC7C;AAgEA,SAAgB,iBACd,SACA,WAAmC,CAAC,GACpC,QACA,gBAAiC,CAAC,GAChB;CAClB,MAAM,oCAAoB,IAAI,IAA4B;CAC1D,IAAI,eAAe;CACnB,IAAI,qBAAqB;CACzB,MAAM,kCAAkB,IAAI,IAAoB;CAEhD,MAAM,oBAAoB,OAAO,KAAK,QAAQ;CAE9C,KAAK,MAAM,UAAU,SAAS;EAC5B,gBAAgB,OAAO,QAAQ;EAC/B,sBAAsB,OAAO,QAAQ;EAErC,KAAK,MAAM,OAAO,OAAO,SAAS,MAAM,KAAK;GAC3C,MAAM,MAAM,IAAI;GAChB,MAAM,WAAW,kBAAkB,IAAI,GAAG;GAE1C,IAAI,UACF,SAAS;QACJ;IACL,MAAM,SAAS,oBACb,IAAI,WACJ,QACA,iBACF;IACA,kBAAkB,IAAI,KAAK;KACzB,MAAM,IAAI;KACV;KACA,OAAO;KACP,uBAAO,IAAI,IAAI;IACjB,CAAC;GACH;EACF;EAEA,cAAc,QAAQ,eAAe;CACvC;CAEA,MAAM,gBAAgB,MAAM,KAAK,kBAAkB,OAAO,CAAC,CAAC,CAAC,MAC1D,GAAG,MAAM,EAAE,QAAQ,EAAE,KACxB;CAEA,MAAM,gBAAgB,MAAM,KAAK,kBAAkB,KAAK,CAAC,CAAC,CAAC,KAAK;CAEhE,MAAM,gBAAgB,MAAM,KAAK,gBAAgB,QAAQ,CAAC,CAAC,CACxD,KAAK,CAAC,MAAM,YAAY;EACvB,aAAa;EACb,aAAa,sBAAsB,IAAI;EACvC;CACF,EAAE,CAAC,CACF,MAAM,GAAG,MAAM,EAAE,QAAQ,EAAE,KAAK;CAEnC,MAAM,sBAAsB,6BAC1B,mBACA,UACA,QACA,aACF;CAEA,MAAM,gBAAgB,uBACpB,qBACA,QAAQ,UAAU,CAAC,CACrB;CACA,MAAM,0BAA0B,qBAC9B,qBACA,MACF;CAEA,MAAM,4BAA4B,uBAChC,qBACA,UACA,MACF;CAEA,OAAO;EACL,eAAe,QAAQ;EACvB;EACA,iBAAiB,kBAAkB;EACnC;EACA;EACA,gBAAgB;EAChB;EACA;EACA;EACA;EACA,gBAAgB;EAChB;EACA;CACF;AACF;AAEA,SAAS,uBACP,cACA,eACgB;CAChB,MAAM,UAAU,IAAI,IAAI,aAAa,KAAK,MAAM,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC;CAEnE,OAAO,cAAc,KAAK,OAAO;EAC/B,MAAM,UAAyB,GAAG,SAAS,KAAK,YAAY;GAC1D,MAAM,MAAM,QAAQ,IAAI,OAAO;GAC/B,OAAO;IACL,aAAa;IACb,OAAO,KAAK,cAAc;IAC1B,YAAY;IACZ,YAAY,KAAK,cAAc,CAAC;GAClC;EACF,CAAC;EAED,MAAM,aAAa,QAAQ,QAAQ,KAAK,MAAM,MAAM,EAAE,OAAO,CAAC;EAE9D,KAAK,MAAM,SAAS,SAClB,MAAM,aAAa,aAAa,MAAM,OAAO,UAAU;EAGzD,QAAQ,MAAM,GAAG,MAAM,EAAE,QAAQ,EAAE,KAAK;EAExC,OAAO;GAAE,MAAM,GAAG;GAAM,UAAU,GAAG;GAAU;GAAS;EAAW;CACrE,CAAC;AACH;AAEA,SAAS,qBACP,cACA,QAC0B;CAC1B,MAAM,cAAc,QAAQ,QAAQ,MAAM,eAAe;CACzD,IAAI,YAAY,WAAW,GACzB,OAAO,CAAC;CAGV,MAAM,aAAuC,CAAC;CAC9C,KAAK,MAAM,OAAO,cAChB,KAAK,MAAM,QAAQ,aACjB,IAAI,WAAW,QAAQ,IAAI,aAAa,KAAK,QAAQ,GAAG;EACtD,WAAW,KAAK;GACd,aAAa,IAAI;GACjB,UAAU,KAAK;GACf,SAAS,KAAK;EAChB,CAAC;EACD;CACF;CAGJ,OAAO;AACT;AAEA,SAAS,uBACP,cACA,UACA,QACiB;CACjB,MAAM,eAAe,QAAQ,QAAQ,MAAM,gBAAgB;CAC3D,IAAI,aAAa,WAAW,GAAG,OAAO,CAAC;CAGvC,MAAM,iCAAiB,IAAI,IAAI,CAC7B,GAAG,OAAO,KAAK,QAAQ,GACvB,GAAG,aAAa,KAAK,MAAM,EAAE,WAAW,CAC1C,CAAC;CAED,MAAM,aAA8B,CAAC;CACrC,KAAK,MAAM,QAAQ,cAIjB,IAAI,CAHc,KAAK,SAAS,MAAM,MACpC,CAAC,GAAG,cAAc,CAAC,CAAC,MAAM,SAAS,WAAW,QAAQ,MAAM,CAAC,CAAC,CAEnD,GACX,WAAW,KAAK;EACd,MAAM;EACN,UAAU,KAAK;EACf,UAAU,KAAK;EACf,SAAS,KAAK;EACd,cAAc,CAAC;CACjB,CAAC;CAGL,OAAO;AACT;AAEA,SAAS,6BACP,YACA,mBACQ;CACR,IAAI,WAAW,WAAW,GAAG,KAAK,WAAW,WAAW,GAAG,GACzD,OAAO;CAGT,MAAM,iBAAiB,CAAC,GAAG,iBAAiB,CAAC,CAAC,MAC3C,GAAG,MAAM,EAAE,SAAS,EAAE,MACzB;CAEA,KAAK,MAAM,OAAO,gBAAgB;EAChC,IAAI,eAAe,KAAK,OAAO;EAC/B,IAAI,WAAW,WAAW,GAAG,IAAI,EAAE,GAAG,OAAO;CAC/C;CAEA,OAAO;AACT;AAEA,SAAS,oBACP,eACA,QACA,mBACQ;CACR,MAAM,cAAc,OAAO,SAAS,QAAQ,MAAM,MAC/C,QAAQ,IAAI,SAAS,aACxB;CACA,IAAI,aACF,OAAO,6BAA6B,YAAY,QAAQ,iBAAiB;CAE3E,MAAM,gBAAgB,OAAO,SAAS,QAAQ,QAAQ,MACnD,QAAQ,IAAI,SAAS,aACxB;CACA,IAAI,eACF,OAAO,6BACL,cAAc,QACd,iBACF;CAEF,MAAM,gBAAgB,OAAO,SAAS,QAAQ,QAAQ,MACnD,QAAQ,IAAI,UAAU,aACzB;CACA,IAAI,eACF,OAAO,6BACL,cAAc,QACd,iBACF;CAEF,OAAO;AACT;AAEA,SAAS,cAAc,QAAqB,YAAiC;CAC3E,UACE,YACA,mBACA,OAAO,SAAS,QAAQ,QAAQ,MAClC;CACA,UAAU,YAAY,iBAAiB,OAAO,SAAS,QAAQ,MAAM,MAAM;CAC3E,UACE,YACA,qBACA,OAAO,SAAS,QAAQ,UAAU,MACpC;CACA,UACE,YACA,mBACA,OAAO,SAAS,QAAQ,QAAQ,MAClC;CACA,UAAU,YAAY,aAAa,OAAO,SAAS,MAAM,IAAI,MAAM;CACnE,UACE,YACA,mBACA,OAAO,SAAS,MAAM,UAAU,MAClC;CACA,UACE,YACA,uBACA,OAAO,SAAS,MAAM,cAAc,MACtC;CACA,UACE,YACA,qBACA,OAAO,SAAS,MAAM,YAAY,MACpC;CACA,UAAU,YAAY,gBAAgB,OAAO,SAAS,MAAM,OAAO,MAAM;CACzE,UAAU,YAAY,iBAAiB,OAAO,SAAS,MAAM,QAAQ,MAAM;CAC3E,UAAU,YAAY,iBAAiB,OAAO,SAAS,SAAS,KAAK,MAAM;CAC3E,UACE,YACA,oBACA,OAAO,SAAS,SAAS,QAAQ,MACnC;CACA,UAAU,YAAY,gBAAgB,OAAO,SAAS,SAAS,IAAI,MAAM;CACzE,UAAU,YAAY,iBAAiB,OAAO,SAAS,SAAS,KAAK,MAAM;CAC3E,UACE,YACA,uBACA,OAAO,SAAS,SAAS,WAAW,MACtC;CACA,UACE,YACA,mBACA,OAAO,SAAS,SAAS,OAAO,MAClC;AACF;AAEA,SAAS,UAAU,KAA0B,KAAa,OAAe;CACvE,IAAI,IAAI,MAAM,IAAI,IAAI,GAAG,KAAK,KAAK,KAAK;AAC1C;AAEA,SAAS,sBAAsB,aAA6B;CAmB1D,OAAO;EAjBL,mBAAmB;EACnB,iBAAiB;EACjB,qBAAqB;EACrB,mBAAmB;EACnB,aAAa;EACb,mBAAmB;EACnB,uBAAuB;EACvB,qBAAqB;EACrB,gBAAgB;EAChB,iBAAiB;EACjB,iBAAiB;EACjB,oBAAoB;EACpB,gBAAgB;EAChB,iBAAiB;EACjB,uBAAuB;EACvB,mBAAmB;CAEH,EAAE,gBAAgB;AACtC;AAEA,SAAS,kBACP,aACA,UACe;CACf,IAAI,SAAS,cAAc,OAAO,SAAS;CAE3C,IAAI,YAAY,SAAS,GAAG,GAAG;EAC7B,MAAM,QAAQ,YAAY,MAAM,GAAG;EACnC,IAAI,YAAY,WAAW,GAAG,KAAK,MAAM,SAAS,GAAG;GACnD,MAAM,cAAc,GAAG,MAAM,GAAG,GAAG,MAAM;GACzC,IAAI,SAAS,cAAc,OAAO,SAAS;EAC7C;EACA,IAAI,CAAC,YAAY,WAAW,GAAG,KAAK,MAAM,SAAS;OAC7C,SAAS,MAAM,KAAK,OAAO,SAAS,MAAM;EAAA;CAElD;CAEA,OAAO;AACT;AAEA,SAAS,6BACP,mBACA,UACA,QACA,gBAAiC,CAAC,GACX;CACvB,MAAM,iBAAiB,QAAQ,SAAS,UAAU,CAAC;CACnD,MAAM,mBAAmB,QAAQ,SAAS,YAAY,CAAC;CAEvD,MAAM,6BAAa,IAAI,IAAiC;CAExD,KAAK,MAAM,aAAa,kBAAkB,OAAO,GAAG;EAClD,IAAI,UAAU,WAAW,aAAa,UAAU,WAAW,SACzD;EAEF,IACE,eAAe,SAAS,KACxB,WAAW,QAAQ,UAAU,QAAQ,cAAc,GAEnD;EAGF,MAAM,WAAW,WAAW,IAAI,UAAU,MAAM;EAChD,IAAI,UAAU;GACZ,SAAS;GACT,SAAS,cAAc,UAAU;GACjC,SAAS,WAAW,KAAK,UAAU,IAAI;EACzC,OAAO;GACL,MAAM,aACJ,iBAAiB,SAAS,IACtB,WAAW,QAAQ,UAAU,QAAQ,gBAAgB,IACrD;GAEN,MAAM,cAAc,cAAc,UAAU,WAAW,CAAC;GACxD,MAAM,qBAAqB,YAAY,SAAS;GAEhD,WAAW,IAAI,UAAU,QAAQ;IAC/B,aAAa,UAAU;IACvB,SAAS,kBAAkB,UAAU,QAAQ,QAAQ;IACrD,gBAAgB;IAChB,YAAY,UAAU;IACtB,YAAY;IACZ,YAAY,CAAC,UAAU,IAAI;IAC3B,UAAU;IACV;IACA;GACF,CAAC;EACH;CACF;CAEA,MAAM,eAAe,MAAM,KAAK,WAAW,OAAO,CAAC;CACnD,MAAM,qBAAqB,aAAa,QACrC,KAAK,QAAQ,MAAM,IAAI,YACxB,CACF;CAEA,KAAK,MAAM,OAAO,cAChB,IAAI,aACF,qBAAqB,IAAK,IAAI,aAAa,qBAAsB,MAAM;CAG3E,OAAO,aAAa,MAAM,GAAG,MAAM,EAAE,aAAa,EAAE,UAAU;AAChE;;;;;;;;AChdA,SAAgB,YAAY,KAAqB;CAC/C,OAAO,IAAI,eAAe;AAC5B;;;ACFA,SAASE,gBAAc;CACrB,QAAQ,IAAI,MAAM,MAAM,KAAK,gBAAgB,CAAC;AAChD;AAEA,SAAgB,aAAa,YAA8B;CACzD,cAAY;CAEZ,MAAM,QAAQ,IAAI,MAAM;EACtB,MAAM,CAAC,UAAU,OAAO;EACxB,OAAO;GACL,MAAM,CAAC,MAAM;GACb,QAAQ,CAAC,MAAM;EACjB;CACF,CAAC;CAGD,MAAM,qBAAqB,WAAW,cAAc,QACjD,SAAS,KAAK,WAAW,aAAa,KAAK,WAAW,OACzD,CAAC,CAAC;CAGF,MAAM,qBAAqB,WAAW,oBAAoB,QACvD,KAAK,QAAQ,MAAM,IAAI,YACxB,CACF;CAEA,MAAM,KACJ,CAAC,kBAAkB,YAAY,WAAW,aAAa,CAAC,GACxD,CAAC,qBAAqB,YAAY,WAAW,oBAAoB,MAAM,CAAC,GACxE,CAAC,uBAAuB,YAAY,kBAAkB,CAAC,GACvD,CAAC,gBAAgB,YAAY,kBAAkB,CAAC,CAClD;CAEA,QAAQ,IAAI,MAAM,SAAS,CAAC;AAC9B;;;ACnCA,SAASC,gBAAc;CACrB,QAAQ,IAAI,MAAM,KAAK,KAAK,gBAAgB,CAAC;AAC/C;AAEA,SAAgB,aAAa,YAA8B;CACzD,cAAY;CAEZ,QAAQ,IACN,MAAM,KACJ,2BAA2B,YAAY,WAAW,kBAAkB,GACtE,CACF;CAGA,KAAK,MAAM,WAAW,WAAW,eAC/B,IAAI,QAAQ,QAAQ,GAClB,QAAQ,IACN,MAAM,KAAK,KAAK,QAAQ,YAAY,IAAI,YAAY,QAAQ,KAAK,GAAG,CACtE;AAGN;;;ACVA,SAAgB,eAAe,MAAmB,UAAwB,CAAC,GAAG;CAC5E,MAAM,EACJ,WAAW,IACX,aAAa,MACb,UAAU,KACV,YAAY,QACV;CAEJ,IAAI,KAAK,WAAW,GAAG;EACrB,QAAQ,IAAI,MAAM,KAAK,sBAAsB,CAAC;EAC9C;CACF;CAGA,MAAM,WAAW,KAAK,IAAI,GAAG,KAAK,KAAK,MAAM,EAAE,KAAK,CAAC;CACrD,IAAI,aAAa,GAAG;EAClB,QAAQ,IAAI,MAAM,KAAK,uBAAuB,CAAC;EAC/C;CACF;CAGA,MAAM,iBAAiB,KAAK,IAAI,GAAG,KAAK,KAAK,MAAM,EAAE,MAAM,MAAM,CAAC;CAGlE,KAAK,MAAM,QAAQ,MAAM;EACvB,MAAM,aAAa,KAAK,QAAQ;EAChC,MAAM,YAAY,KAAK,MAAM,aAAa,QAAQ;EAClD,MAAM,cAAc,WAAW;EAG/B,MAAM,cAAc,KAAK,MAAM,OAAO,gBAAgB,GAAG;EAGzD,MAAM,MACJ,MAAM,MAAM,QAAQ,OAAO,SAAS,CAAC,IACrC,MAAM,KAAK,UAAU,OAAO,WAAW,CAAC;EAG1C,MAAM,WAAW,aAAa,IAAI,YAAY,KAAK,KAAK,MAAM;EAE9D,QAAQ,IAAI,GAAG,YAAY,GAAG,MAAM,SAAS,GAAG;CAClD;AACF;;;ACpDA,SAASC,gBAAc;CAErB,QAAQ,IAAI,MAAM,QAAQ,KAAK,mBAAmB,CAAC;AACrD;AAEA,SAAgB,gBACd,YACA,MACA;CACA,MAAM,aAAa,WAAW;CAE9B,IAAI,SAAS,SACX,qBAAqB,UAAU;MAC1B,IAAI,SAAS,SAClB,qBAAqB,UAAU;AAEnC;AAEA,SAAS,qBAAqB,YAA8B;CAC1D,cAAY;CAGZ,MAAM,qBAAqB,WAAW,QACnC,SAAS,KAAK,WAAW,aAAa,KAAK,WAAW,OACzD;CAEA,IAAI,mBAAmB,WAAW,GAAG;EACnC,QAAQ,IAAI,MAAM,KAAK,gCAAgC,CAAC;EACxD;CACF;CAEA,MAAM,QAAQ,IAAI,MAAM;EACtB,MAAM;GAAC;GAAa;GAAW;EAAO;EACtC,OAAO;GACL,MAAM,CAAC,MAAM;GACb,QAAQ,CAAC,MAAM;EACjB;CACF,CAAC;CAED,mBAAmB,SAAS,SAAS;EACnC,MAAM,KAAK;GAAC,KAAK;GAAM,KAAK;GAAQ,KAAK,MAAM,SAAS;EAAC,CAAC;CAC5D,CAAC;CAED,QAAQ,IAAI,MAAM,SAAS,CAAC;AAC9B;AAEA,SAAS,qBAAqB,YAA8B;CAC1D,cAAY;CAGZ,MAAM,qBAAqB,WAAW,QACnC,SAAS,KAAK,WAAW,aAAa,KAAK,WAAW,OACzD;CAEA,IAAI,mBAAmB,WAAW,GAAG;EACnC,QAAQ,IAAI,MAAM,KAAK,gCAAgC,CAAC;EACxD;CACF;CAOA,eALa,mBAAmB,KAAK,UAAU;EAC7C,OAAO,KAAK;EACZ,OAAO,KAAK;CACd,EAEkB,GAAG,EAAE,UAAU,GAAG,CAAC;AACvC;;;ACjEA,SAASC,gBAAc;CACrB,QAAQ,IAAI,MAAM,KAAK,KAAK,sBAAsB,CAAC;AACrD;AAEA,SAAgB,cACd,YACA,MACA;CACA,MAAM,WAAW,WAAW,cAAc,QAAQ,MAAM,EAAE,QAAQ,CAAC;CAEnE,IAAI,SAAS,SACX,mBAAmB,QAAQ;MACtB,IAAI,SAAS,SAClB,mBAAmB,QAAQ;AAE/B;AAEA,SAAS,mBAAmB,UAA0B;CACpD,cAAY;CAEZ,IAAI,SAAS,WAAW,GAAG;EACzB,QAAQ,IAAI,MAAM,KAAK,qBAAqB,CAAC;EAC7C;CACF;CAEA,MAAM,QAAQ,IAAI,MAAM;EACtB,MAAM,CAAC,WAAW,OAAO;EACzB,OAAO;GACL,MAAM,CAAC,MAAM;GACb,QAAQ,CAAC,MAAM;EACjB;CACF,CAAC;CAED,SAAS,SAAS,YAAY;EAC5B,MAAM,KAAK,CAAC,QAAQ,aAAa,QAAQ,MAAM,SAAS,CAAC,CAAC;CAC5D,CAAC;CAED,QAAQ,IAAI,MAAM,SAAS,CAAC;CAG5B,MAAM,gBAAgB,SAAS,QAAQ,KAAK,MAAM,MAAM,EAAE,OAAO,CAAC;CAClE,QAAQ,IAAI,MAAM,KAAK,YAAY,cAAc,mBAAmB,CAAC;AACvE;AAEA,SAAS,mBAAmB,UAA0B;CACpD,cAAY;CAEZ,IAAI,SAAS,WAAW,GAAG;EACzB,QAAQ,IAAI,MAAM,KAAK,qBAAqB,CAAC;EAC7C;CACF;CAOA,eALa,SAAS,KAAK,aAAa;EACtC,OAAO,QAAQ;EACf,OAAO,QAAQ;CACjB,EAEkB,GAAG,EAAE,UAAU,GAAG,CAAC;AACvC;;;ACrDA,SAAS,cAAc;CACrB,QAAQ,IAAI,MAAM,WAAW,KAAK,iBAAiB,CAAC;AACtD;AAEA,SAAS,kBACP,KACA,QACQ;CACR,IAAI,SAAS;CACb,IAAI,IAAI,YAAY,YAClB,UAAU,MAAM,IAAI,eAAe;CAErC,IAAI,QACF,UACE,OAAO,aAAa,UAChB,MAAM,IAAI,WAAW,IACrB,MAAM,OAAO,eAAe;MAC7B,IAAI,IAAI,UACb,UAAU,MAAM,OAAO,QAAQ;CAEjC,OAAO,SAAS,IAAI;AACtB;AAEA,SAAS,kBAAkB,YAAsC;CAC/D,IAAI,CAAC,YAAY,OAAO;CACxB,MAAM,EAAE,YAAY,aAAa;CACjC,IAAI,CAAC,YAAY,OAAO,MAAM,MAAM,GAAG;CAEvC,MAAM,MAAM,SAAS;CACrB,IAAI,CAAC,KAAK,OAAO,MAAM,MAAM,GAAG;CAEhC,IAAI,eAAe,qBACjB,OAAO,MAAM,IACX,KAAK,IAAI,WAAW,GAAG,IAAI,QAAQ,IAAI,IAAI,gBAAgB,GAC7D;CAEF,OAAO,MAAM,OACX,KAAK,IAAI,WAAW,GAAG,IAAI,QAAQ,IAAI,IAAI,gBAAgB,GAC7D;AACF;AAEA,SAAS,mBACP,KACA,YACoC;CACpC,OAAO,WAAW,MAAM,MAAM,EAAE,gBAAgB,IAAI,WAAW;AACjE;AAEA,SAAgB,cACd,YACA,MACA;CACA,MAAM,WAAW,WAAW;CAC5B,MAAM,aAAa,WAAW;CAE9B,IAAI,SAAS,SACX,mBAAmB,UAAU,UAAU;MAClC,IAAI,SAAS,SAClB,mBAAmB,UAAU,UAAU;AAE3C;AAEA,SAAS,mBACP,UACA,YACA;CACA,YAAY;CAEZ,IAAI,SAAS,WAAW,GAAG;EACzB,QAAQ,IAAI,MAAM,KAAK,qBAAqB,CAAC;EAC7C;CACF;CAEA,MAAM,gBAAgB,SAAS,MAAM,MAAM,EAAE,eAAe,KAAA,CAAS;CACrE,MAAM,OAAO;EAAC;EAAW;EAAW;EAAc;EAAS;CAAY;CACvE,IAAI,eAAe,KAAK,KAAK,UAAU;CAEvC,MAAM,QAAQ,IAAI,MAAM;EACtB;EACA,OAAO;GACL,MAAM,CAAC,MAAM;GACb,QAAQ,CAAC,MAAM;EACjB;CACF,CAAC;CAED,SAAS,SAAS,QAAQ;EACxB,MAAM,cAAc,IAAI,qBACpB,MAAM,OACJ,KAAK,IAAI,YAAY,KAAK,IAAI,EAAE,4BAClC,IACA,IAAI,WAAW;EAEnB,MAAM,MAAM;GACV,kBAAkB,KAAK,mBAAmB,KAAK,UAAU,CAAC;GAC1D;GACA,YAAY,IAAI,cAAc;GAC9B,YAAY,IAAI,UAAU;GAC1B,GAAG,IAAI,WAAW,QAAQ,CAAC,EAAE;EAC/B;EACA,IAAI,eAAe,IAAI,KAAK,kBAAkB,IAAI,UAAU,CAAC;EAC7D,MAAM,KAAK,GAAG;CAChB,CAAC;CAED,QAAQ,IAAI,MAAM,SAAS,CAAC;CAE5B,MAAM,kBAAkB,SAAS,QAC9B,KAAK,MAAM,MAAM,EAAE,gBACpB,CACF;CACA,MAAM,qBAAqB,SAAS,QAAQ,KAAK,MAAM,MAAM,EAAE,YAAY,CAAC;CAC5E,QAAQ,IACN,MAAM,KACJ,YAAY,YAAY,SAAS,MAAM,EAAE,cAAc,YAAY,eAAe,EAAE,uBAAuB,YAAY,kBAAkB,EAAE,cAC7I,CACF;AACF;AAEA,SAAS,mBACP,UACA,YACA;CACA,YAAY;CAEZ,IAAI,SAAS,WAAW,GAAG;EACzB,QAAQ,IAAI,MAAM,KAAK,qBAAqB,CAAC;EAC7C;CACF;CAEA,MAAM,cAAc;CACpB,MAAM,gBAAgB,KAAK,IAAI,GAAG,SAAS,KAAK,MAAM,EAAE,UAAU,CAAC;CACnE,MAAM,iBAAiB,KAAK,IAC1B,GAAG,SAAS,KAAK,MAAM,EAAE,YAAY,UAAU,EAAE,WAAW,IAAI,EAAE,CACpE;CAEA,SAAS,SAAS,QAAQ;EACxB,MAAM,YAAY,KAAK,MACpB,IAAI,aAAa,gBAAiB,WACrC;EACA,MAAM,cAAc,cAAc;EAClC,MAAM,QAAQ,kBACZ,KACA,mBAAmB,KAAK,UAAU,CACpC,CAAC,CAAC,OAAO,gBAAgB,GAAG;EAE5B,MAAM,MACJ,MAAM,MAAM,IAAI,OAAO,SAAS,CAAC,IAAI,MAAM,KAAK,IAAI,OAAO,WAAW,CAAC;EAEzE,QAAQ,IACN,GAAG,MAAM,GAAG,IAAI,GAAG,MAAM,KAAK,IAAI,WAAW,QAAQ,CAAC,IAAI,GAAG,EAAE,IAAI,IAAI,WAAW,EACpF;CACF,CAAC;AACH;;;AC9JA,MAAM,YAAY;AAElB,SAAS,UAAU,YAA4B;CAC7C,MAAM,SAAS,KAAK,MAAO,aAAa,MAAO,SAAS;CACxD,MAAM,QAAQ,YAAY;CAC1B,OAAO,MAAM,KAAK,IAAI,OAAO,MAAM,CAAC,IAAI,MAAM,KAAK,IAAI,OAAO,KAAK,CAAC;AACtE;AAEA,SAAS,iBAAiB,YAAsB,MAAM,GAAW;CAC/D,IAAI,WAAW,WAAW,GAAG,OAAO;CACpC,MAAM,QAAQ,WAAW,MAAM,GAAG,GAAG;CACrC,MAAM,OAAO,WAAW,SAAS;CACjC,MAAM,OAAO,MAAM,KAAK,IAAI;CAC5B,OAAO,OAAO,IAAI,GAAG,KAAK,KAAK,KAAK,UAAU;AAChD;AAEA,SAAS,kBAAkB,QAAsB;CAC/C,QAAQ,IAAI,MAAM,KAAK,KAAK,OAAO,MAAM,CAAC;CAC1C,QAAQ,IAAI,MAAM,KAAK,KAAK,IAAI,OAAO,EAAE,GAAG,CAAC;CAE7C,MAAM,aAAa,KAAK,IACtB,GAAG,OAAO,QAAQ,KAAK,MAAM,EAAE,YAAY,MAAM,CACnD;CAEA,KAAK,MAAM,SAAS,OAAO,SAAS;EAClC,MAAM,OAAO,MAAM,YAAY,OAAO,UAAU;EAChD,MAAM,MAAM,UAAU,MAAM,UAAU;EACtC,MAAM,MAAM,MAAM,KAAK,GAAG,MAAM,WAAW,QAAQ,CAAC,EAAE,EAAE;EACxD,MAAM,QAAQ,MAAM,KAAK,IAAI,MAAM,MAAM,SAAS;EAClD,MAAM,aACJ,MAAM,WAAW,SAAS,IACtB,MAAM,KAAK,KAAK,iBAAiB,MAAM,UAAU,GAAG,IACpD;EAEN,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,GAAG,IAAI,GAAG,QAAQ,YAAY;CAC9D;CAEA,IAAI,OAAO,eAAe,GACxB,QAAQ,IACN,MAAM,KAAK,oDAAoD,CACjE;CAGF,QAAQ,IAAI;AACd;AAEA,SAAgB,YAAY,YAA8B;CACxD,IAAI,WAAW,cAAc,WAAW,GAAG;CAE3C,QAAQ,IAAI,MAAM,cAAc,KAAK,gBAAgB,CAAC;CAEtD,KAAK,MAAM,UAAU,WAAW,eAC9B,kBAAkB,MAAM;AAE5B;;;ACrDA,SAAS,eAAe,MAAqC;CAC3D,QAAQ,MAAR;EACE,KAAK,gBACH,OAAO;EACT,KAAK,iBACH,OAAO;EACT,KAAK,eACH,OAAO;EACT,KAAK,mBACH,OAAO;EACT,KAAK,oBACH,OAAO;EACT,KAAK,mBACH,OAAO;EACT,KAAK,0BACH,OAAO;EACT,KAAK,kBACH,OAAO;CACX;AACF;AAEA,SAAS,SAAS,WAAkC;CAClD,IAAI,UAAU,aAAa,SAAS,OAAO,MAAM,IAAI,GAAG;CACxD,OAAO,MAAM,OAAO,GAAG;AACzB;AAEA,SAAS,kBAAkB,GAA0B;CACnD,MAAM,WAAW,EAAE,SAAS,KAAK,IAAI;CACrC,MAAM,SAAS,EAAE,UAAU,MAAM,KAAK,MAAM,EAAE,SAAS,IAAI;CAE3D,IAAI,EAAE,SAAS,gBAKb,OAAO,GAAG,SAAS,UAJL,EAAE,aAAa,KAAK,MAAM;EACtC,MAAM,QAAQ,EAAE,QAAQ,OAAO,GAAG,CAAC,CAAC,MAAM,GAAG;EAC7C,OAAO,MAAM,MAAM,SAAS;CAC9B,CACiC,CAAC,CAAC,KAAK,IAAI,EAAE,GAAG;CAGnD,IAAI,EAAE,SAAS,iBAAiB,OAAO,GAAG,SAAS,YAAY;CAC/D,IAAI,EAAE,SAAS,eAAe,OAAO,GAAG,SAAS,cAAc;CAC/D,IAAI,EAAE,SAAS,oBACb,OAAO,GAAG,SAAS,gBAAgB;CACrC,IAAI,EAAE,SAAS,mBAAmB,OAAO,GAAG,SAAS,eAAe;CACpE,IAAI,EAAE,SAAS,mBACb,OAAO,UAAU,SAAS,0BAA0B;CACtD,IAAI,EAAE,SAAS,0BACb,OAAO,SAAS,SAAS,0BAA0B;CAErD,IAAI,EAAE,SAAS,kBAAkB;EAC/B,IAAI,CAAC,EAAE,gBACL,OAAO,wCAAwC,EAAE,cAAc,GAAG;EACpE,OAAO,mBAAmB,MAAM,OAAO,EAAE,cAAc,EAAE,aAAa,MAAM,KAAK,EAAE,aAAa,IAAI;CACtG;CAEA,OAAO,GAAG,SAAS,cAAc;AACnC;AAEA,SAAgB,WAAW,YAAoC;CAC7D,MAAM,EAAE,gBAAgB,4BAA4B;CACpD,MAAM,oBAAoB,eAAe,SAAS;CAClD,MAAM,sBAAsB,wBAAwB,SAAS;CAE7D,IAAI,CAAC,qBAAqB,CAAC,qBAAqB;EAC9C,QAAQ,IAAI,MAAM,YAAY,KAAK,kBAAkB,CAAC;EACtD,QAAQ,IAAI,MAAM,KAAK,gCAAgC,CAAC;EACxD;CACF;CAEA,QAAQ,IAAI,MAAM,WAAW,KAAK,mBAAmB,CAAC;CAEtD,IAAI,mBACF,KAAK,MAAM,KAAK,gBAAgB;EAC9B,MAAM,OAAO,SAAS,CAAC;EACvB,MAAM,OAAO,MAAM,KAAK,eAAe,EAAE,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC;EACzD,MAAM,cACJ,EAAE,aAAa,UAAU,MAAM,IAAI,SAAS,IAAI,MAAM,OAAO,QAAQ;EACvE,QAAQ,IAAI,KAAK,KAAK,IAAI,KAAK,GAAG,kBAAkB,CAAC,EAAE,IAAI,aAAa;CAC1E;CAGF,IAAI,qBAAqB;EACvB,IAAI,mBAAmB,QAAQ,IAAI;EACnC,KAAK,MAAM,KAAK,yBAAyB;GACvC,MAAM,OAAO,EAAE,aAAa,UAAU,MAAM,IAAI,GAAG,IAAI,MAAM,OAAO,GAAG;GACvE,MAAM,MACJ,EAAE,aAAa,UACX,MAAM,IAAI,UAAU,IACpB,MAAM,OAAO,cAAc;GACjC,MAAM,MAAM,EAAE,UAAU,MAAM,KAAK,MAAM,EAAE,SAAS,IAAI;GACxD,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,GAAG,EAAE,cAAc,KAAK;EACxD;CACF;CAEA,MAAM,aAAa,CACjB,GAAG,eAAe,QAAQ,MAAM,EAAE,aAAa,OAAO,GACtD,GAAG,wBAAwB,QAAQ,MAAM,EAAE,aAAa,OAAO,CACjE,CAAC,CAAC;CACF,MAAM,YAAY,CAChB,GAAG,eAAe,QAAQ,MAAM,EAAE,aAAa,MAAM,GACrD,GAAG,wBAAwB,QAAQ,MAAM,EAAE,aAAa,MAAM,CAChE,CAAC,CAAC;CAEF,MAAM,QAAkB,CAAC;CACzB,IAAI,aAAa,GACf,MAAM,KAAK,MAAM,IAAI,GAAG,WAAW,QAAQ,aAAa,IAAI,MAAM,IAAI,CAAC;CACzE,IAAI,YAAY,GACd,MAAM,KAAK,MAAM,OAAO,GAAG,UAAU,UAAU,YAAY,IAAI,MAAM,IAAI,CAAC;CAC5E,QAAQ,IAAI,MAAM,KAAK,OAAO,MAAM,KAAK,IAAI,GAAG,CAAC;AACnD;;;AC7GA,SAAgB,YAAY,QAA4B;CACtD,IAAI,OAAO,WAAW,GAAG;CACzB,QAAQ,IAAI,MAAM,OAAO,OAAO,OAAO,OAAO,0BAA0B,CAAC;CACzE,KAAK,MAAM,EAAE,MAAM,aAAa,QAAQ;EACtC,QAAQ,IAAI,MAAM,OAAO,KAAK,MAAM,CAAC;EACrC,QAAQ,IAAI,MAAM,KAAK,OAAO,SAAS,CAAC;CAC1C;CACA,QAAQ,IAAI,EAAE;AAChB;;;;;;;;;ACFA,eAAsB,UACpB,SACA,gBACmB;CAQnB,OAAO,MAPa,KAAK,SAAS;EAChC,QAAQ;EACR,OAAO;EACP,UAAU;EACV,sBAAsB;CACxB,CAAC;AAGH;;;ACjBA,SAAS,qBAAqB,SAAyB;CAOrD,MAAM,MAAM,QAAQ,YAAY,eAAe;CAC/C,IAAI,QAAQ,IAAI,OAAO;CACvB,OAAO,QAAQ,MAAM,MAAM,EAAsB;AACnD;AAEA,IAAa,qBAAb,MAA2D;CACzD,OAAO;CACP,oBAAoB,CAAC,MAAM,IAAI;CAE/B,OAAO,aAAoC;EACzC,MAAM,eAAeC,OAAK,KAAK,aAAa,mBAAmB;EAC/D,OAAOC,KAAG,WAAW,YAAY,IAAI,eAAe;CACtD;CAEA,MAAM,cAA8C;EAClD,IAAI;GACF,MAAM,UAAUA,KAAG,aAAa,cAAc,MAAM;GACpD,MAAM,WAAW,KAAK,MAAM,OAAO;GACnC,MAAM,WAAmC,CAAC;GAG1C,IAAI,SAAS,UACX,OAAO,QAAQ,SAAS,QAAQ,CAAC,CAAC,SAC/B,CAAC,SAAS,aAA4B;IACrC,IAAI,CAAC,WAAW,YAAY,IAAI;IAGhC,IAAI,QAAQ,MAAM,eAAe,CAAC,CAAC,SAAS,GAAG;IAE/C,MAAM,UAAU,qBAAqB,OAAO;IAC5C,IAAI,QAAQ,SACV,SAAS,WAAW,QAAQ;GAEhC,CACF;GAIF,IAAI,SAAS,gBAAgB,OAAO,KAAK,QAAQ,CAAC,CAAC,WAAW,GAAG;IAC/D,SAAS,gBAAgB,MAAW,SAAS,IAAU;KACrD,OAAO,QAAQ,IAAI,CAAC,CAAC,SAAS,CAAC,MAAM,UAAyB;MAC5D,MAAM,WAAW,SAAS,GAAG,OAAO,GAAG,SAAS;MAChD,IAAI,KAAK,SACP,SAAS,YAAY,KAAK;MAE5B,IAAI,KAAK,cACP,gBAAgB,KAAK,cAAc,QAAQ;KAE/C,CAAC;IACH;IACA,gBAAgB,SAAS,YAAY;GACvC;GAEA,OAAO;EACT,SAAS,OAAO;GACd,MAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;GACrE,QAAQ,KAAK,+CAA+C,SAAS;GACrE,OAAO,CAAC;EACV;CACF;CAEA,kBAAkB,cAAuC;EACvD,IAAI;GACF,MAAM,UAAUA,KAAG,aAAa,cAAc,MAAM;GACpD,MAAM,WAAW,KAAK,MAAM,OAAO;GACnC,MAAM,cAA2C,CAAC;GAElD,IAAI,SAAS,UACX,OAAO,QAAQ,SAAS,QAAQ,CAAC,CAAC,SAC/B,CAAC,SAAS,aAA4B;IACrC,IAAI,CAAC,WAAW,YAAY,IAAI;IAEhC,MAAM,UAAU,qBAAqB,OAAO;IAC5C,MAAM,UAAW,QAAgB;IACjC,IAAI,CAAC,SAAS;IAEd,IAAI,CAAC,YAAY,UAAU,YAAY,2BAAW,IAAI,IAAI;IAC1D,YAAY,QAAQ,CAAC,IAAI,OAAO;GAClC,CACF;GAGF,MAAM,SAA0B,CAAC;GACjC,KAAK,MAAM,CAAC,KAAK,aAAa,OAAO,QAAQ,WAAW,GACtD,OAAO,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,KAAK;GAE1C,OAAO;EACT,QAAQ;GACN,OAAO,CAAC;EACV;CACF;AACF;;;ACjGA,IAAa,sBAAb,MAA4D;CAC1D,OAAO;CACP,oBAAoB;EAAC;EAAM;EAAM;CAAI;CAErC,OAAO,aAAoC;EACzC,MAAM,eAAeC,OAAK,KAAK,aAAa,gBAAgB;EAC5D,OAAOC,KAAG,WAAW,YAAY,IAAI,eAAe;CACtD;CAEA,MAAM,cAA8C;EAClD,IAAI;GACF,MAAM,UAAUA,KAAG,aAAa,cAAc,MAAM;GACpD,MAAM,WAAW,KAAK,KAAK,OAAO;GAClC,MAAM,WAAmC,CAAC;GAG1C,IAAI,SAAS,WAAW;IACtB,MAAM,eAAe,SAAS,UAAU;IACxC,IAAI,cAAc;KAEhB,IAAI,aAAa;WACV,MAAM,CAAC,MAAM,SAAS,OAAO,QAChC,aAAa,YACf,GACE,IACE,OAAO,SAAS,YAChB,SAAS,QACT,aAAa,MAEb,SAAS,QAAS,KAAa;KAAA;KAKrC,IAAI,aAAa;WACV,MAAM,CAAC,MAAM,SAAS,OAAO,QAChC,aAAa,eACf,GACE,IACE,OAAO,SAAS,YAChB,SAAS,QACT,aAAa,MAEb,SAAS,QAAS,KAAa;KAAA;IAIvC;GACF;GAGA,IAAI,SAAS,YAAY,OAAO,KAAK,QAAQ,CAAC,CAAC,WAAW,GACxD,OAAO,KAAK,SAAS,QAAQ,CAAC,CAAC,SAAS,QAAQ;IAE9C,MAAM,QAAQ,IAAI,MAAM,oCAAoC;IAC5D,IAAI,OAAO;KACT,MAAM,GAAG,SAAS,WAAW;KAC7B,SAAS,WAAW;IACtB;GACF,CAAC;GAIH,IAAI,SAAS,gBAAgB,OAAO,KAAK,QAAQ,CAAC,CAAC,WAAW,GAC5D,OAAO,QAAQ,SAAS,YAAY,CAAC,CAAC,SACnC,CAAC,MAAM,iBAAgC;IAEtC,IACE,OAAO,gBAAgB,YACvB,CAAC,YAAY,WAAW,OAAO,GAE/B,SAAS,QAAQ;SACZ,IAAI,OAAO,gBAAgB,YAAY,YAAY,SACxD,SAAS,QAAQ,YAAY;GAEjC,CACF;GAGF,OAAO;EACT,SAAS,OAAO;GACd,MAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;GACrE,QAAQ,KAAK,4CAA4C,SAAS;GAClE,OAAO,CAAC;EACV;CACF;AACF;;;ACtFA,IAAa,sBAAb,MAA4D;CAC1D,OAAO;CACP,oBAAoB,CAAC,MAAM,KAAK;CAEhC,OAAO,aAAoC;EACzC,MAAM,eAAeC,OAAK,KAAK,aAAa,WAAW;EACvD,OAAOC,KAAG,WAAW,YAAY,IAAI,eAAe;CACtD;CAEA,MAAM,cAA8C;EAClD,IAAI;GACF,MAAM,UAAUA,KAAG,aAAa,cAAc,MAAM;GACpD,MAAM,SAAS,SAAS,MAAM,OAAO;GAErC,IAAI,OAAO,SAAS,WAAW;IAC7B,QAAQ,KAAK,oCAAoC;IACjD,OAAO,CAAC;GACV;GAEA,MAAM,WAAmC,CAAC;GAE1C,OAAO,QAAQ,OAAO,MAAM,CAAC,CAAC,SAAS,CAAC,KAAK,WAA0B;IAGrE,IAAI,UAAU;IAGd,IAAI,IAAI,WAAW,GAAG,GAAG;KACvB,MAAM,QAAQ,IAAI,MAAM,mBAAmB;KAC3C,IAAI,OACF,UAAU,MAAM;IAEpB,OAAO;KACL,MAAM,QAAQ,IAAI,MAAM,WAAW;KACnC,IAAI,OACF,UAAU,MAAM;IAEpB;IAEA,IAAI,MAAM,YAAY,CAAC,SAAS,YAAY,MAAM,UAChD,SAAS,WAAW,MAAM;GAE9B,CAAC;GAED,OAAO;EACT,SAAS,OAAO;GACd,MAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;GACrE,QAAQ,KAAK,uCAAuC,SAAS;GAC7D,OAAO,CAAC;EACV;CACF;AACF;;;ACnCA,MAAM,oBAAuC;CAC3C,IAAI,mBAAmB;CACvB,IAAI,oBAAoB;CACxB,IAAI,oBAAoB;AAC1B;;;;;;AAOA,SAAgB,qBAAqB,aAAqC;CACxE,KAAK,MAAM,WAAW,mBAAmB;EACvC,MAAM,eAAe,QAAQ,OAAO,WAAW;EAC/C,IAAI,cAAc;GAChB,MAAM,WAAW,QAAQ,MAAM,YAAY;GAC3C,MAAM,gBAAgB,QAAQ,oBAC1B,QAAQ,kBAAkB,YAAY,IACtC,CAAC;GAML,OAAO;IACL;IACA;IACA,kBAP0C,OAAO,QAAQ,aAAa,CAAC,CACtE,QAAQ,GAAG,UAAU,KAAK,SAAS,CAAC,CAAC,CACrC,KAAK,CAAC,aAAa,WAAW;KAAE;KAAa,UAAU;IAAK,EAK9C;IACf,cAAc,QAAQ;IACtB;IACA,mBAAmB,QAAQ;GAC7B;EACF;CACF;CAEA,MAAM,IAAI,MAAM,6BAA6B;AAC/C;;;ACrDA,MAAM,qBAAqB,EAAE,KAAK,CAAC,SAAS,MAAM,CAAC;AAEnD,MAAM,mBAAmB,EAAE,OAAO;CAChC,UAAU;CACV,UAAU,EAAE,MAAM,EAAE,OAAO,CAAC;CAC5B,SAAS,EAAE,OAAO,CAAC,CAAC,SAAS;AAC/B,CAAC;AAED,MAAM,0BAA0B,EAAE,MAAM,CACtC,kBACA,EAAE,MAAM,gBAAgB,CAC1B,CAAC;AAED,MAAM,0BAA0B,EAAE,OAAO;CACvC,UAAU;CACV,OAAO,EAAE,OAAO;CAChB,SAAS,EAAE,OAAO,CAAC,CAAC,SAAS;AAC/B,CAAC;AAED,MAAM,kBAAkB,EAAE,MAAM,CAAC,EAAE,OAAO,GAAG,EAAE,QAAQ,KAAK,CAAC,CAAC;AAI9D,MAAa,qBAAqB,EAAE,OAAO;CACzC,UAAU,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,sBAAsB,CAAC;CAC9D,UAAU,EACP,MAAM,EAAE,OAAO,CAAC,CAAC,CACjB,QAAQ;EAAC;EAAsB;EAAc;CAAa,CAAC;CAE9D,UAAU,EACP,OAAO;EACN,UAAU,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;EACxC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;CACxC,CAAC,CAAC,CACD,eAAe;EAAE,UAAU,CAAC;EAAG,QAAQ,CAAC;CAAE,EAAE;CAE/C,QAAQ,EACL,MAAM,EAAE,OAAO;EAAE,MAAM,EAAE,OAAO;EAAG,UAAU,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;CAAE,CAAC,CAAC,CAAC,CAC3E,QAAQ,CAAC,CAAC;CAEb,OAAO,EACJ,OAAO;EACN,cAAc,wBAAwB,QAAQ,CAAC,CAAC;EAChD,eAAe,wBAAwB,QAAQ,CAAC,CAAC;EACjD,aAAa,wBAAwB,QAAQ,CAAC,CAAC;EAC/C,iBAAiB,wBAAwB,QAAQ,CAAC,CAAC;EACnD,kBAAkB,wBAAwB,QAAQ,CAAC,CAAC;EACpD,iBAAiB,wBAAwB,QAAQ,CAAC,CAAC;EACnD,wBAAwB,wBAAwB,QAAQ,CAAC,CAAC;EAC1D,gBAAgB,EACb,MAAM,CAAC,yBAAyB,EAAE,MAAM,uBAAuB,CAAC,CAAC,CAAC,CAClE,SAAS;CACd,CAAC,CAAC,CACD,eAAe;EACd,cAAc,CAAC;EACf,eAAe,CAAC;EAChB,aAAa,CAAC;EACd,iBAAiB,CAAC;EAClB,kBAAkB,CAAC;EACnB,iBAAiB,CAAC;EAClB,wBAAwB,CAAC;CAC3B,EAAE;CAEJ,QAAQ,EACL,OAAO;EACN,SAAS,EAAE,MAAM,CAAC,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,KAAK;EACpE,YAAY,EACT,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,OAAO,CAAC,GAAG,EAAE,QAAQ,KAAK,CAAC,CAAC,CAAC,CACrD,QAAQ,OAAO;EAClB,UAAU,EACP,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,OAAO,CAAC,GAAG,EAAE,QAAQ,KAAK,CAAC,CAAC,CAAC,CACrD,QAAQ,OAAO;EAClB,UAAU,EACP,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,OAAO,CAAC,GAAG,EAAE,QAAQ,KAAK,CAAC,CAAC,CAAC,CACrD,QAAQ,OAAO;EAClB,SAAS,EAAE,QAAQ,CAAC,CAAC,QAAQ,KAAK;EAClC,QAAQ,EAAE,QAAQ,CAAC,CAAC,QAAQ,IAAI;EAChC,OAAO,EAAE,QAAQ,CAAC,CAAC,QAAQ,IAAI;CACjC,CAAC,CAAC,CACD,eAAe;EACd,SAAS;EACT,YAAY;EACZ,UAAU;EACV,UAAU;EACV,SAAS;EACT,QAAQ;EACR,OAAO;CACT,EAAE;CAEJ,YAAY,EACT,OAAO;EACN,SAAS,EAAE,QAAQ,CAAC,CAAC,QAAQ,KAAK;EAClC,UAAU,EAAE,OAAO,CAAC,CAAC,QAAQ,4BAA4B;EACzD,WAAW,EAAE,OAAO,CAAC,CAAC,SAAS;EAC/B,YAAY,EACT,OAAO;GACN,OAAO,gBAAgB,QAAQ,EAAE;GACjC,OAAO,gBAAgB,QAAQ,EAAE;GACjC,OAAO,gBAAgB,QAAQ,EAAE;EACnC,CAAC,CAAC,CACD,eAAe;GAAE,OAAO;GAAI,OAAO;GAAI,OAAO;EAAG,EAAE;CACxD,CAAC,CAAC,CACD,eAAe;EACd,SAAS;EACT,UAAU;EACV,YAAY;GAAE,OAAO;GAAI,OAAO;GAAI,OAAO;EAAG;CAChD,EAAE;AACN,CAAC;;;ACzGD,eAAsB,WAAW,KAAoC;CACnE,MAAM,aAAa,KAAK,KAAK,kBAAkB;CAE/C,IAAI,WAAW,UAAU,GAAG;EAC1B,MAAM,MAAM,MAAM,OAAO,cAAc,QAAQ,UAAU,CAAC,CAAC,CAAC;EAC5D,OAAO,mBAAmB,MAAM,IAAI,WAAW,GAAG;CACpD;CAEA,OAAO,mBAAmB,MAAM,CAAC,CAAC;AACpC;;;ACbA,eAAsB,iBACpB,MACA,aACA,WACqC;CACrC,MAAM,MAAM,GAAG,YAAY,QAAQ,OAAO,EAAE,EAAE,GAAG,mBAAmB,IAAI,CAAC,CAAC,QAAQ,OAAO,GAAG;CAC5F,MAAM,aAAa,IAAI,gBAAgB;CACvC,MAAM,YAAY,iBAAiB,WAAW,MAAM,GAAG,GAAM;CAE7D,IAAI;EACF,MAAM,UAAkC,EACtC,QAAQ,mBACV;EACA,IAAI,WACF,QAAQ,mBAAmB,UAAU;EAGvC,MAAM,WAAW,MAAM,MAAM,KAAK;GAChC;GACA,QAAQ,WAAW;EACrB,CAAC;EAED,aAAa,SAAS;EAEtB,IAAI,CAAC,SAAS,IAAI,OAAO;EAGzB,OAAO,MADa,SAAS,KAAK;CAEpC,QAAQ;EACN,aAAa,SAAS;EACtB,OAAO;CACT;AACF;;;ACvBA,MAAM,cAAc;AAEpB,SAAS,UAAU,SAAyB;CAC1C,MAAM,KAAK,KAAK,IAAI,IAAI,IAAI,KAAK,OAAO,CAAC,CAAC,QAAQ;CAClD,OAAO,KAAK,MAAM,MAAM,MAAO,KAAK,KAAK,GAAG;AAC9C;AAEA,SAAS,aAAa,WAAmB,WAAsC;CAC7E,MAAM,OAAO,OAAO,KAAK,WAAW,SAAS;CAC7C,IAAI,CAAC,MAAM,OAAO;CAClB,IAAI,SAAS,WAAW,SAAS,YAAY,OAAO;CACpD,IAAI,SAAS,WAAW,SAAS,YAAY,OAAO;CACpD,IAAI,SAAS,WAAW,SAAS,YAAY,OAAO;CACpD,OAAO;AACT;AAEA,SAAS,aACP,SACA,MACA,YACqB;CACrB,MAAM,YAAY,WAAW;CAC7B,IAAI,cAAc,SAAS,cAAc,KAAA,GAAW,OAAO;CAC3D,IAAI,UAAU,WAEZ,OAAO,SAAS,UAAU,sBAAsB;CAElD,OAAO;AACT;AAEA,SAAS,kBACP,kBACA,SACA,YACA,YACiB;CACjB,MAAM,WAA+B,CAAC;CAEtC,KAAK,MAAM,CAAC,SAAS,YAAY,OAAO,QAAQ,OAAO,GAAG;EACxD,IAAI,YAAY,aAAa,YAAY,YAAY;EACrD,IAAI,CAAC,OAAO,MAAM,OAAO,GAAG;EAC5B,IAAI,OAAO,IAAI,SAAS,gBAAgB,GAAG;EAE3C,MAAM,OAAO,aAAa,kBAAkB,OAAO;EACnD,IAAI,CAAC,MAAM;EAEX,MAAM,UAAU,UAAU,OAAO;EACjC,MAAM,QAAQ,aAAa,SAAS,MAAM,UAAU;EACpD,IAAI,CAAC,OAAO;EAEZ,SAAS,KAAK;GACZ;GACA,iBAAiB;GACjB,YAAY;GACZ;EACF,CAAC;CACH;CAGA,MAAM,+BAAe,IAAI,IAAkC;CAC3D,KAAK,MAAM,WAAW,UAAU;EAC9B,MAAM,WAAW,aAAa,IAAI,QAAQ,UAAU;EACpD,IAAI,CAAC,YAAY,QAAQ,kBAAkB,SAAS,iBAClD,aAAa,IAAI,QAAQ,YAAY,OAAO;CAEhD;CAEA,MAAM,gBAAgB,MAAM,KAAK,aAAa,OAAO,CAAC,CAAC,CAAC,MACrD,GAAG,MAAM,EAAE,kBAAkB,EAAE,eAClC;CAUA,OAAO;EACL;EACA,UAAU;EACV,YAXsC,cAAc,MACnD,MAAM,EAAE,UAAU,mBACrB,IACI,sBACA,cAAc,SAAS,IACrB,kBACA;EAMJ;CACF;AACF;AAEA,eAAsB,qBACpB,UACA,QAC+D;CAC/D,MAAM,cAAc,OAAO;CAC3B,MAAM,UAAU,SAAS,QAAQ,MAAM,CAAC,EAAE,YAAY,EAAE,OAAO;CAC/D,MAAM,WAAW,CAAC,GAAG,QAAQ;CAC7B,IAAI,UAAU;CAGd,KAAK,IAAI,IAAI,GAAG,IAAI,QAAQ,QAAQ,KAAK,aAAa;EACpD,MAAM,QAAQ,QAAQ,MAAM,GAAG,IAAI,WAAW;EAC9C,MAAM,UAAU,MAAM,QAAQ,IAC5B,MAAM,IAAI,OAAO,QAAQ;GACvB,MAAM,OAAO,MAAM,iBACjB,IAAI,aACJ,aACA,OAAO,SACT;GACA,IAAI,CAAC,QAAQ,CAAC,KAAK,MAAM;IACvB;IACA,OAAO;KAAE;KAAK,OAAO;IAAK;GAC5B;GAEA,MAAM,aACJ,KAAK,WAAW,IAAI,QAAS,EAAE,cAAc,KAAK;GASpD,OAAO;IAAE;IAAK,OAPA,kBACZ,IAAI,SACJ,KAAK,MACL,OAAO,eAAe,WAAW,aAAa,KAAA,GAC9C,OAAO,UAGS;GAAE;EACtB,CAAC,CACH;EAEA,KAAK,MAAM,EAAE,KAAK,WAAW,SAAS;GACpC,IAAI,CAAC,OAAO;GACZ,MAAM,MAAM,SAAS,WAAW,MAAM,EAAE,gBAAgB,IAAI,WAAW;GACvE,IAAI,QAAQ,IACV,SAAS,OAAO;IAAE,GAAG,SAAS;IAAM,YAAY;GAAM;EAE1D;CACF;CAEA,OAAO;EAAE;EAAU;CAAQ;AAC7B;;;AC5HA,SAAgB,oBAAoB,SAAkB;CACpD,QACG,QAAQ,MAAM,CAAC,CACf,YAAY,8BAA8B,CAAC,CAC3C,OAAO,YAAY;EAElB,MAAM,YAAY,MADG,WAAW,QAAQ,IAAI,CAAC,CACrB;CAC1B,CAAC;AACL;AAEA,eAAsB,YAAY,QAAsB;CACtD,MAAM,YAAY,KAAK,IAAI;CAC3B,MAAM,UAAU,IAAI,qBAAqB,CAAC,CAAC,MAAM;CAEjD,IAAI;EACF,MAAM,iBAAiB,qBAAqB,QAAQ,IAAI,CAAC;EAEzD,QAAQ,QACN,MAAM,KACJ,YAAY,eAAe,aAAa,uBAAuB,eAAe,kBAAkB,KAAK,IAAI,EAAE,MAAM,OAAO,KAAK,eAAe,QAAQ,CAAC,CAAC,OAAO,UAC/J,CACF;EAEA,QAAQ,MAAM,kBAAkB;EAChC,MAAM,QAAQ,MAAM,UAAU,OAAO,UAAU,OAAO,QAAQ;EAE9D,IAAI,MAAM,WAAW,GAAG;GACtB,QAAQ,KACN,MAAM,IACJ,qCAAqC,OAAO,SAAS,KAAK,IAAI,GAChE,CACF;GACA;EACF;EAEA,QAAQ,QAAQ,MAAM,MAAM,UAAU,MAAM,OAAO,OAAO,CAAC;EAE3D,QAAQ,MAAM,oBAAoB;EAClC,MAAM,UAAyB,CAAC;EAChC,MAAM,cAA4B,CAAC;EAEnC,KAAK,IAAI,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;GACrC,MAAM,OAAO,MAAM;GACnB,QAAQ,OAAO,uBAAuB,IAAI,EAAE,GAAG,MAAM,OAAO;GAE5D,IAAI;IACF,MAAM,SAAS,UAAU,IAAI;IAC7B,IAAI,QACF,QAAQ,KAAK,MAAM;GAEvB,SAAS,OAAY;IACnB,YAAY,KAAK;KAAE;KAAM,SAAS,MAAM,WAAW,OAAO,KAAK;IAAE,CAAC;GACpE;EACF;EAEA,QAAQ,QACN,MAAM,MACJ,+BAA+B,QAAQ,OAAO,GAAG,MAAM,OAAO,OAChE,CACF;EAEA,YAAY,WAAW;EAEvB,MAAM,eAAe,KAAK,IAAI,IAAI,aAAa;EAE/C,MAAM,aAAa,iBACjB,SACA,eAAe,UACf,QACA,eAAe,aACjB;EAEA,MAAM,sBAAsB,cAC1B,QAAQ,IAAI,GACZ,OAAO,OACP,OAAO,QACT;EACA,WAAW,iBAAiB,CAC1B,GAAG,WAAW,gBACd,GAAG,mBACL;EAEA,IAAI,OAAO,WAAW,SAAS;GAC7B,QAAQ,MAAM,uCAAuC;GACrD,MAAM,EAAE,UAAU,YAAY,MAAM,qBAClC,WAAW,qBACX,OAAO,UACT;GACA,WAAW,sBAAsB;GACjC,QAAQ,QACN,MAAM,KACJ,yBAAyB,UAAU,IAAI,MAAM,KAAK,KAAK,QAAQ,uDAAuD,IAAI,IAC5H,CACF;EACF;EAEA,iBAAiB,YAAY,QAAQ,WAAW;CAClD,SAAS,OAAY;EACnB,QAAQ,KAAK,MAAM,IAAI,sBAAsB,MAAM,OAAO,CAAC;EAC3D,QAAQ,MAAM,KAAK;EACnB,QAAQ,KAAK,CAAC;CAChB;AACF;AAEA,SAAS,iBACP,YACA,QACA,cACA;CACA,IAAI,OAAO,OAAO,UAChB,cAAc,YAAY,OAAO,OAAO,QAAQ;CAGlD,IAAI,OAAO,OAAO,QAChB,YAAY,UAAU;CAGxB,IAAI,OAAO,OAAO,OAChB,WAAW,UAAU;CAGvB,IAAI,OAAO,OAAO,SAChB,aAAa,UAAU;CAGzB,IAAI,OAAO,OAAO,YAChB,gBAAgB,YAAY,OAAO,OAAO,UAAU;CAGtD,IAAI,OAAO,OAAO,UAChB,cAAc,YAAY,OAAO,OAAO,QAAQ;CAGlD,IAAI,OAAO,OAAO,SAChB,aAAa,UAAU;AAE3B;;;;;;AExJA,MAAa,UAAU,IAAI,QAAQ;AAEnC,SAAgB,aACd,QACuB;CACvB,OAAO;AACT;AAEA,QACG,KAAK,QAAQ,CAAC,CACd,YAAY,yDAAyD,CAAC,CACtE,QAAQC,OAAmB;AAE9B,oBAAoB,OAAO;AAE3B,QAAQ,MAAM,QAAQ,IAAI"}
|
|
1
|
+
{"version":3,"file":"cli.mjs","names":["path","fs","printHeader","printHeader","printHeader","printHeader","path","fs","path","fs","path","fs","packageJson.version"],"sources":["../src/swc-parser/core/state.ts","../src/swc-parser/patterns/imports.ts","../src/swc-parser/utils/jsx-helpers.ts","../src/swc-parser/patterns/props.ts","../src/swc-parser/patterns/jsx.ts","../src/swc-parser/utils/matchers.ts","../src/swc-parser/patterns/variables.ts","../src/swc-parser/patterns/conditionals.ts","../src/swc-parser/patterns/collections.ts","../src/swc-parser/patterns/lazy-dynamic.ts","../src/swc-parser/patterns/advanced.ts","../src/swc-parser/core/visitor.ts","../src/swc-parser/core/report.ts","../src/swc-parser/index.ts","../src/rules/shared.ts","../src/rules/file-rules.ts","../src/rules/script-rules.ts","../src/rules/package-field-rules.ts","../src/rules/engine-version.ts","../src/rules/evaluator.ts","../src/utils/aggregator.ts","../src/utils/format-utils.ts","../src/utils/print-summary.ts","../src/utils/print-details.ts","../src/utils/chart-renderer.ts","../src/utils/print-components.ts","../src/utils/print-patterns.ts","../src/utils/print-packages.ts","../src/utils/print-versus.ts","../src/utils/print-rules.ts","../src/utils/print-errors.ts","../src/utils/print-json.ts","../src/utils/file-utils.ts","../src/lock-parser/patterns/npm.ts","../src/lock-parser/patterns/pnpm.ts","../src/lock-parser/patterns/yarn.ts","../src/lock-parser/index.ts","../src/config/schema.ts","../src/config/loader.ts","../src/npm-registry/client.ts","../src/npm-registry/enricher.ts","../src/commands/scan.ts","../package.json","../src/cli.ts"],"sourcesContent":["import type { ParserState, UsagePatterns } from '../types';\n\nexport function createState(): ParserState {\n const usagePatterns: UsagePatterns = {\n directImports: new Set(),\n namedImports: new Set(),\n namespaceImports: new Set(),\n defaultImports: new Set(),\n aliasedImports: new Map(),\n variableAssignments: new Map(),\n componentMappings: new Set(),\n lazyImports: new Set(),\n dynamicImports: new Set(),\n conditionalUsage: new Set(),\n arrayMappings: new Set(),\n objectMappings: new Set(),\n hocUsage: new Set(),\n renderProps: new Set(),\n contextUsage: new Set(),\n forwardedRefs: new Set(),\n memoizedComponents: new Set(),\n portalUsage: new Set(),\n jsxUsage: new Map(),\n destructuredUsage: new Set(),\n propsAnalysis: new Map(),\n };\n\n return {\n usagePatterns,\n componentNames: new Set(),\n allIdentifiers: new Set(),\n };\n}\n","import type { ImportDeclaration } from '@swc/core';\nimport type { ParserState } from '../types';\n\n/**\n * Analyzes import declarations and tracks all types:\n * - Default imports\n * - Named imports\n * - Namespace imports\n * - Aliased imports\n */\nexport function analyzeImportDeclaration(\n node: ImportDeclaration,\n state: ParserState,\n): void {\n const source = node.source.value;\n\n // console.log(`📦 Found import: ${source}`);\n\n for (const spec of node.specifiers) {\n switch (spec.type) {\n case 'ImportDefaultSpecifier':\n analyzeDefaultImport(spec, source, node, state);\n break;\n\n case 'ImportNamespaceSpecifier':\n analyzeNamespaceImport(spec, source, node, state);\n break;\n\n case 'ImportSpecifier':\n analyzeNamedImport(spec, source, node, state);\n break;\n }\n }\n}\n\nfunction analyzeDefaultImport(\n spec: any,\n source: string,\n node: ImportDeclaration,\n state: ParserState,\n): void {\n const name = spec.local.value;\n\n state.usagePatterns.defaultImports.add({\n name,\n source,\n line: node.span?.start || 0,\n });\n\n state.componentNames.add(name);\n}\n\nfunction analyzeNamespaceImport(\n spec: any,\n source: string,\n node: ImportDeclaration,\n state: ParserState,\n): void {\n const name = spec.local.value;\n\n state.usagePatterns.namespaceImports.add({\n name,\n source,\n line: node.span?.start || 0,\n });\n\n state.allIdentifiers.add(name);\n}\n\nfunction analyzeNamedImport(\n spec: any,\n source: string,\n node: ImportDeclaration,\n state: ParserState,\n): void {\n const importedName = spec.imported ? spec.imported.value : spec.local.value;\n const localName = spec.local.value;\n\n state.usagePatterns.namedImports.add({\n name: importedName,\n source,\n line: node.span?.start || 0,\n });\n\n // Track aliases\n if (importedName !== localName) {\n state.usagePatterns.aliasedImports.set(localName, {\n imported: importedName,\n local: localName,\n source,\n line: node.span?.start || 0,\n });\n }\n\n state.componentNames.add(localName);\n}\n","import type { ParserState } from '../types';\n\n/**\n * Extracts the name from a JSX element (handles identifiers and member expressions)\n */\nexport function getJSXElementName(nameNode: any): string {\n if (!nameNode) return '';\n\n switch (nameNode.type) {\n case 'Identifier':\n return nameNode.value;\n case 'JSXMemberExpression':\n return `${getJSXElementName(nameNode.object)}.${nameNode.property.value}`;\n default:\n return '';\n }\n}\n\n/**\n * Checks if a JSX member expression is a known component\n */\nexport function isMemberExpressionComponent(\n nameNode: any,\n state: ParserState,\n): boolean {\n if (nameNode?.type === 'JSXMemberExpression') {\n const objectName = getJSXElementName(nameNode.object);\n return state.allIdentifiers.has(objectName);\n }\n return false;\n}\n\n/**\n * Extracts props from JSX attributes\n */\nexport function extractJSXProps(attributes: any[]): Array<{\n name: string;\n value: any;\n isSpread?: boolean;\n}> {\n if (!attributes) return [];\n\n return attributes\n .map((attr) => {\n if (attr.type === 'JSXAttribute') {\n return {\n name: attr.name?.value || attr.name?.name?.value,\n value: extractJSXAttributeValue(attr.value),\n };\n }\n if (attr.type === 'SpreadElement') {\n return {\n name: '...',\n value: '[spread]',\n isSpread: true,\n };\n }\n return null;\n })\n .filter(Boolean) as Array<{\n name: string;\n value: any;\n isSpread?: boolean;\n }>;\n}\n\n/**\n * Extracts value from JSX attribute\n */\nexport function extractJSXAttributeValue(value: any): any {\n if (!value) return true; // boolean attribute\n\n switch (value.type) {\n case 'StringLiteral':\n return value.value;\n case 'JSXExpressionContainer':\n return extractExpressionValue(value.expression);\n default:\n return '[complex]';\n }\n}\n\n/**\n * Extracts a readable value from an expression\n */\nexport function extractExpressionValue(expr: any): any {\n if (!expr) return '[unknown]';\n\n switch (expr.type) {\n case 'StringLiteral':\n case 'NumericLiteral':\n case 'BooleanLiteral':\n return expr.value;\n case 'Identifier':\n return `{${expr.value}}`;\n case 'ArrowFunctionExpression':\n case 'FunctionExpression':\n return '[function]';\n case 'ObjectExpression':\n return '[object]';\n case 'ArrayExpression':\n return '[array]';\n default:\n return '[expression]';\n }\n}\n\n/**\n * Determines the context where a component is being used\n */\nexport function getUsageContext(parent: any): string {\n if (!parent) return 'direct';\n\n switch (parent.type) {\n case 'ConditionalExpression':\n return 'conditional';\n case 'ArrayExpression':\n return 'array';\n case 'ObjectExpression':\n return 'object';\n case 'CallExpression':\n return 'hoc';\n case 'VariableDeclarator':\n return 'variable';\n default:\n return 'jsx';\n }\n}\n","import type { PropsAnalysis, PropDetail, ParserState } from '../types';\n\n/**\n * Analyzes props in detail for a component\n */\nexport function analyzePropsInDetail(\n attributes: any[],\n componentName: string,\n state: ParserState,\n): PropsAnalysis {\n const analysis: PropsAnalysis = {\n namedProps: [],\n hasSpread: false,\n hasComplexProps: false,\n hasEventHandlers: false,\n propDetails: [],\n };\n\n if (!attributes) return analysis;\n\n for (const attr of attributes) {\n if (attr.type === 'JSXAttribute') {\n const propName = attr.name?.value || attr.name?.name?.value;\n if (propName) {\n analysis.namedProps.push(propName);\n\n const propDetail: PropDetail = {\n name: propName,\n type: getPropType(attr.value),\n isEventHandler: propName.startsWith('on'),\n isComplex: isComplexProp(attr.value),\n };\n\n if (propDetail.isEventHandler) {\n analysis.hasEventHandlers = true;\n }\n if (propDetail.isComplex) {\n analysis.hasComplexProps = true;\n }\n\n analysis.propDetails.push(propDetail);\n }\n } else if (attr.type === 'SpreadElement') {\n analysis.hasSpread = true;\n analysis.propDetails.push({\n name: '...',\n type: 'spread',\n isSpread: true,\n isComplex: true,\n isEventHandler: false,\n warning: 'Spread props cannot be statically analyzed',\n });\n analysis.hasComplexProps = true;\n }\n }\n\n // Store in state\n state.usagePatterns.propsAnalysis.set(componentName, analysis);\n\n return analysis;\n}\n\n/**\n * Determines the type of a prop value\n */\nfunction getPropType(value: any): string {\n if (!value) return 'boolean';\n\n switch (value.type) {\n case 'StringLiteral':\n return 'string';\n case 'JSXExpressionContainer': {\n const expr = value.expression;\n if (!expr) return 'unknown';\n switch (expr.type) {\n case 'NumericLiteral':\n return 'number';\n case 'BooleanLiteral':\n return 'boolean';\n case 'StringLiteral':\n return 'string';\n case 'ArrowFunctionExpression':\n case 'FunctionExpression':\n return 'function';\n case 'ObjectExpression':\n return 'object';\n case 'ArrayExpression':\n return 'array';\n case 'Identifier':\n return 'variable';\n default:\n return 'expression';\n }\n }\n default:\n return 'unknown';\n }\n}\n\n/**\n * Checks if a prop value is complex (object, array, call, conditional)\n */\nfunction isComplexProp(value: any): boolean {\n if (!value) return false;\n if (value.type === 'JSXExpressionContainer') {\n const expr = value.expression;\n if (!expr) return false;\n return (\n expr.type === 'ObjectExpression' ||\n expr.type === 'ArrayExpression' ||\n expr.type === 'CallExpression' ||\n expr.type === 'ConditionalExpression'\n );\n }\n return false;\n}\n","import type { ParserState, JSXUsage } from '../types';\nimport {\n getJSXElementName,\n isMemberExpressionComponent,\n extractJSXProps,\n getUsageContext,\n} from '../utils/jsx-helpers';\nimport { analyzePropsInDetail } from './props';\n\n/**\n * Analyzes JSX element usage\n */\nexport function analyzeJSXElement(node: any, state: ParserState): void {\n if (node.opening) {\n analyzeJSXOpeningElement(node.opening, state, node);\n }\n}\n\n/**\n * Analyzes JSX opening element and tracks component usage\n */\nexport function analyzeJSXOpeningElement(\n node: any,\n state: ParserState,\n parent?: any,\n): void {\n const elementName = getJSXElementName(node.name);\n\n // Check if this is a known component\n if (\n !state.componentNames.has(elementName) &&\n !isMemberExpressionComponent(node.name, state)\n ) {\n return;\n }\n\n const propsAnalysis = analyzePropsInDetail(\n node.attributes,\n elementName,\n state,\n );\n const usage: JSXUsage = {\n component: elementName,\n props: extractJSXProps(node.attributes).map((p) => p.name),\n propsAnalysis,\n line: node.span?.start || 0,\n context: getUsageContext(parent),\n };\n\n // Track JSX usage\n if (!state.usagePatterns.jsxUsage.has(elementName)) {\n state.usagePatterns.jsxUsage.set(elementName, usage);\n }\n\n // console.log(`🎨 JSX Usage: <${elementName}>`);\n}\n","import type { ParserState } from '../types';\n\n/**\n * Checks if a name is a known component from imports\n */\nexport function isKnownComponent(name: string, state: ParserState): boolean {\n return state.componentNames.has(name) || state.allIdentifiers.has(name);\n}\n\n/**\n * Checks if a function name matches HOC patterns\n */\nexport function isHOCPattern(name: string): boolean {\n const hocPatterns = ['with', 'enhance', 'wrap', 'connect', 'create'];\n return hocPatterns.some((pattern) => name.startsWith(pattern));\n}\n\n/**\n * Checks if a node represents a HOC function call\n */\nexport function isHOCFunction(callee: any): boolean {\n if (!callee) return false;\n\n if (callee.type === 'Identifier') {\n return isHOCPattern(callee.value);\n }\n\n if (callee.type === 'MemberExpression') {\n const prop = callee.property;\n return prop?.value && isHOCPattern(prop.value);\n }\n\n return false;\n}\n\n/**\n * Checks if an expression looks like a React component\n * (starts with capital letter)\n */\nexport function looksLikeComponent(name: string): boolean {\n return /^[A-Z]/.test(name);\n}\n\n/**\n * Checks if source is from a specific library (for filtering)\n */\nexport function isFromLibrary(source: string, libraryName: string): boolean {\n return source.startsWith(libraryName) || source.includes(libraryName);\n}\n","import type { ParserState } from '../types';\nimport { isKnownComponent } from '../utils/matchers';\n\n/**\n * Analyzes variable declarations for component assignments\n */\nexport function analyzeVariableDeclaration(\n node: any,\n state: ParserState,\n): void {\n if (!node.declarations) return;\n\n for (const decl of node.declarations) {\n if (decl.id?.type === 'Identifier') {\n const varName = decl.id.value;\n\n // Check if it's assigning a component\n if (decl.init) {\n const assignment = extractAssignmentInfo(decl.init);\n if (assignment && isKnownComponent(assignment, state)) {\n state.usagePatterns.variableAssignments.set(varName, {\n assignment,\n line: node.span?.start || 0,\n });\n state.componentNames.add(varName);\n // console.log(`📝 Variable assignment: ${varName} = ${assignment}`);\n }\n }\n }\n\n // Handle destructuring assignments\n if (decl.id?.type === 'ObjectPattern') {\n analyzeDestructuringPattern(decl.id, decl.init, state);\n }\n }\n}\n\n/**\n * Analyzes destructuring patterns\n */\nexport function analyzeDestructuringPattern(\n pattern: any,\n init: any,\n state: ParserState,\n): void {\n if (!pattern.properties) return;\n\n for (const prop of pattern.properties) {\n if (\n prop.type === 'AssignmentPatternProperty' &&\n prop.key?.type === 'Identifier'\n ) {\n const propName = prop.key.value;\n\n if (init?.type === 'Identifier' && state.allIdentifiers.has(init.value)) {\n state.usagePatterns.destructuredUsage.add({\n property: propName,\n source: init.value,\n line: pattern.span?.start || 0,\n });\n state.componentNames.add(propName);\n // console.log(`🔧 Destructuring: ${propName} from ${init.value}`);\n }\n }\n }\n}\n\n/**\n * Extracts assignment information from various node types\n */\nfunction extractAssignmentInfo(node: any): string | null {\n switch (node.type) {\n case 'Identifier':\n return node.value;\n case 'MemberExpression':\n return `${extractAssignmentInfo(node.object)}.${node.property.value}`;\n case 'ConditionalExpression':\n return `${extractAssignmentInfo(node.consequent)} | ${extractAssignmentInfo(node.alternate)}`;\n default:\n return null;\n }\n}\n","import type { ParserState } from '../types';\n\n/**\n * Analyzes conditional expressions (ternary operators) with components\n */\nexport function analyzeConditionalExpression(\n node: any,\n state: ParserState,\n): void {\n const consequent =\n node.consequent?.type === 'Identifier' ? node.consequent.value : null;\n const alternate =\n node.alternate?.type === 'Identifier' ? node.alternate.value : null;\n\n if (\n (consequent && state.componentNames.has(consequent)) ||\n (alternate && state.componentNames.has(alternate))\n ) {\n state.usagePatterns.conditionalUsage.add({\n consequent: consequent || '',\n alternate: alternate || '',\n line: node.span?.start || 0,\n });\n // console.log('🔀 Conditional component usage found');\n }\n}\n","import type { ParserState } from '../types';\n\n/**\n * Analyzes array expressions containing components\n */\nexport function analyzeArrayExpression(node: any, state: ParserState): void {\n // Check if array contains components\n const hasComponents = node.elements?.some((elem: any) => {\n if (elem?.type === 'Identifier') {\n return state.componentNames.has(elem.value);\n }\n return false;\n });\n\n if (hasComponents) {\n state.usagePatterns.arrayMappings.add({\n components: node.elements\n ?.map((elem: any) => elem?.value)\n .filter(Boolean),\n line: node.span?.start || 0,\n });\n // console.log('📋 Array with components found');\n }\n}\n\n/**\n * Analyzes object expressions with component mappings\n */\nexport function analyzeObjectExpression(node: any, state: ParserState): void {\n // Check if object contains component mappings\n const componentProps = node.properties?.filter((prop: any) => {\n if (prop.type === 'KeyValueProperty' && prop.value?.type === 'Identifier') {\n return state.componentNames.has(prop.value.value);\n }\n return false;\n });\n\n if (componentProps?.length > 0) {\n state.usagePatterns.objectMappings.add({\n mappings: componentProps.map((prop: any) => ({\n key: prop.key?.value || '[computed]',\n component: prop.value?.value,\n })),\n line: node.span?.start || 0,\n });\n // console.log('🗺️ Object mapping with components found');\n }\n}\n","import type { ParserState } from '../types';\n\n/**\n * Analyzes React.lazy() imports\n */\nexport function analyzeLazyImport(node: any, state: ParserState): void {\n const arg = node.arguments?.[0];\n if (\n arg?.type === 'ArrowFunctionExpression' &&\n arg.body?.type === 'CallExpression'\n ) {\n const importCall = arg.body;\n if (importCall.callee?.type === 'Import') {\n const source = importCall.arguments?.[0]?.value;\n if (source) {\n state.usagePatterns.lazyImports.add({\n source,\n line: node.span?.start || 0,\n });\n // console.log(`🔄 Found lazy import: ${source}`);\n }\n }\n }\n}\n\n/**\n * Analyzes dynamic import() calls\n */\nexport function analyzeDynamicImport(node: any, state: ParserState): void {\n const source = node.arguments?.[0]?.value;\n if (source) {\n state.usagePatterns.dynamicImports.add({\n source,\n line: node.span?.start || 0,\n });\n // console.log(`⚡ Found dynamic import: ${source}`);\n }\n}\n","import type { ParserState } from '../types';\n\n/**\n * Analyzes Higher-Order Component (HOC) usage\n */\nexport function analyzeHOCUsage(node: any, state: ParserState): void {\n state.usagePatterns.hocUsage.add({\n function: node.callee?.value || '[unknown]',\n component: node.arguments?.[0]?.value || '[unknown]',\n line: node.span?.start || 0,\n });\n // console.log(`🎁 HOC usage found`);\n}\n\n/**\n * Analyzes React.memo() usage\n */\nexport function analyzeMemoUsage(node: any, state: ParserState): void {\n const component = node.arguments?.[0];\n if (\n component?.type === 'Identifier' &&\n state.componentNames.has(component.value)\n ) {\n state.usagePatterns.memoizedComponents.add({\n component: component.value,\n line: node.span?.start || 0,\n });\n // console.log(`🧠 Memoized component: ${component.value}`);\n }\n}\n\n/**\n * Analyzes React.forwardRef() usage\n */\nexport function analyzeForwardRefUsage(node: any, state: ParserState): void {\n state.usagePatterns.forwardedRefs.add({\n line: node.span?.start || 0,\n });\n // console.log('↗️ ForwardRef usage found');\n}\n\n/**\n * Analyzes ReactDOM.createPortal() usage\n */\nexport function analyzePortalUsage(node: any, state: ParserState): void {\n state.usagePatterns.portalUsage.add({\n line: node.span?.start || 0,\n });\n // console.log('🌀 Portal usage found');\n}\n\n/**\n * Analyzes member expression access (e.g., Foundation.Button)\n */\nexport function analyzeMemberExpression(node: any, state: ParserState): void {\n // Check if this is a namespace access like Foundation.Button\n if (\n node.object?.type === 'Identifier' &&\n state.allIdentifiers.has(node.object.value)\n ) {\n // const namespaceName = node.object.value;\n const propertyName = node.property?.value;\n\n if (propertyName) {\n // Track namespace property access\n state.componentNames.add(propertyName);\n // console.log(`🔗 Namespace access: ${namespaceName}.${propertyName}`);\n }\n }\n}\n\n/**\n * Checks if a node represents HOC pattern\n */\nexport function isHOCPattern(node: any, state: ParserState): boolean {\n // Simple heuristic: function that returns a component-like structure\n return (\n node.callee?.type === 'Identifier' &&\n node.arguments?.some(\n (arg: any) =>\n arg.type === 'Identifier' && state.componentNames.has(arg.value),\n )\n );\n}\n","import type { ParserState, VisitorContext } from '../types';\nimport { analyzeImportDeclaration } from '../patterns/imports';\nimport { analyzeJSXElement, analyzeJSXOpeningElement } from '../patterns/jsx';\nimport { analyzeVariableDeclaration } from '../patterns/variables';\nimport { analyzeConditionalExpression } from '../patterns/conditionals';\nimport {\n analyzeArrayExpression,\n analyzeObjectExpression,\n} from '../patterns/collections';\nimport {\n analyzeLazyImport,\n analyzeDynamicImport,\n} from '../patterns/lazy-dynamic';\nimport {\n analyzeHOCUsage,\n analyzeMemoUsage,\n analyzeForwardRefUsage,\n analyzePortalUsage,\n analyzeMemberExpression,\n isHOCPattern,\n} from '../patterns/advanced';\n\n/**\n * Main AST visitor that routes nodes to appropriate pattern analyzers\n */\nexport function visitNode(\n node: any,\n state: ParserState,\n context: VisitorContext = {},\n): void {\n if (!node) return;\n\n switch (node.type) {\n case 'Module':\n // Process imports first (they populate componentNames)\n if (node.body) {\n for (const item of node.body) {\n if (item.type === 'ImportDeclaration') {\n visitNode(item, state, context);\n }\n }\n // Then process everything else\n for (const item of node.body) {\n if (item.type !== 'ImportDeclaration') {\n visitNode(item, state, { ...context, parent: node });\n }\n }\n }\n break;\n\n case 'ImportDeclaration':\n analyzeImportDeclaration(node, state);\n break;\n\n case 'CallExpression':\n analyzeCallExpression(node, state, context);\n break;\n\n case 'VariableDeclaration':\n analyzeVariableDeclaration(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'JSXElement':\n case 'JSXFragment':\n analyzeJSXElement(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'JSXOpeningElement':\n analyzeJSXOpeningElement(node, state, context.parent);\n break;\n\n case 'ArrayExpression':\n analyzeArrayExpression(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'ObjectExpression':\n analyzeObjectExpression(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'MemberExpression':\n analyzeMemberExpression(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'ConditionalExpression':\n analyzeConditionalExpression(node, state);\n visitChildren(node, state, context);\n break;\n\n case 'FunctionDeclaration':\n case 'ClassDeclaration':\n case 'ExpressionStatement':\n case 'ReturnStatement':\n case 'VariableDeclarator':\n case 'ArrowFunctionExpression':\n case 'FunctionExpression':\n visitChildren(node, state, { ...context, parent: node });\n break;\n\n default:\n visitChildren(node, state, context);\n break;\n }\n}\n\n/**\n * Analyzes call expressions and routes to specific analyzers\n */\nfunction analyzeCallExpression(\n node: any,\n state: ParserState,\n context: VisitorContext,\n): void {\n // Analyze lazy imports\n if (\n node.callee?.value === 'lazy' ||\n (node.callee?.object?.value === 'React' &&\n node.callee?.property?.value === 'lazy')\n ) {\n analyzeLazyImport(node, state);\n }\n\n // Analyze dynamic imports\n if (node.callee?.type === 'Import') {\n analyzeDynamicImport(node, state);\n }\n\n // Analyze HOC patterns\n if (isHOCPattern(node, state)) {\n analyzeHOCUsage(node, state);\n }\n\n // Analyze React.memo, React.forwardRef\n if (node.callee?.object?.value === 'React') {\n if (node.callee?.property?.value === 'memo') {\n analyzeMemoUsage(node, state);\n } else if (node.callee?.property?.value === 'forwardRef') {\n analyzeForwardRefUsage(node, state);\n }\n }\n\n // Analyze createPortal\n if (\n node.callee?.property?.value === 'createPortal' ||\n node.callee?.value === 'createPortal'\n ) {\n analyzePortalUsage(node, state);\n }\n\n visitChildren(node, state, context);\n}\n\n/**\n * Visits all children of a node\n */\nfunction visitChildren(\n node: any,\n state: ParserState,\n context: VisitorContext,\n): void {\n if (!node) return;\n\n for (const key in node) {\n const value = node[key];\n\n if (Array.isArray(value)) {\n for (const item of value) {\n if (item && typeof item === 'object') {\n visitNode(item, state, { ...context, parent: node });\n }\n }\n } else if (value && typeof value === 'object' && value.type) {\n visitNode(value, state, { ...context, parent: node });\n }\n }\n}\n","import type { ParserState, UsageReport } from '../types';\n\n/**\n * Generates a comprehensive usage report from parser state\n */\nexport function generateReport(state: ParserState): UsageReport {\n const report: UsageReport = {\n summary: {\n totalImports:\n state.usagePatterns.defaultImports.size +\n state.usagePatterns.namedImports.size +\n state.usagePatterns.namespaceImports.size,\n totalComponents: state.componentNames.size,\n totalUsagePatterns: calculateTotalPatterns(state),\n },\n patterns: {\n imports: {\n default: Array.from(state.usagePatterns.defaultImports),\n named: Array.from(state.usagePatterns.namedImports),\n namespace: Array.from(state.usagePatterns.namespaceImports),\n aliased: Array.from(state.usagePatterns.aliasedImports.values()),\n },\n usage: {\n jsx: Array.from(state.usagePatterns.jsxUsage.values()),\n variables: Array.from(\n state.usagePatterns.variableAssignments.entries(),\n ).map(([key, value]) => ({\n variable: key,\n assignment: value.assignment,\n })),\n destructuring: Array.from(state.usagePatterns.destructuredUsage),\n conditional: Array.from(state.usagePatterns.conditionalUsage),\n arrays: Array.from(state.usagePatterns.arrayMappings),\n objects: Array.from(state.usagePatterns.objectMappings),\n },\n advanced: {\n lazy: Array.from(state.usagePatterns.lazyImports),\n dynamic: Array.from(state.usagePatterns.dynamicImports),\n hoc: Array.from(state.usagePatterns.hocUsage),\n memo: Array.from(state.usagePatterns.memoizedComponents),\n forwardRef: Array.from(state.usagePatterns.forwardedRefs),\n portal: Array.from(state.usagePatterns.portalUsage),\n },\n props: Array.from(state.usagePatterns.propsAnalysis.entries()).map(\n ([component, analysis]) => ({\n component,\n analysis,\n }),\n ),\n },\n components: Array.from(state.componentNames).sort(),\n };\n\n return report;\n}\n\n/**\n * Calculates total number of usage patterns found\n */\nfunction calculateTotalPatterns(state: ParserState): number {\n let sum = 0;\n const patterns = state.usagePatterns;\n\n for (const key in patterns) {\n const pattern = (patterns as any)[key];\n if (pattern instanceof Set) {\n sum += pattern.size;\n } else if (pattern instanceof Map) {\n sum += pattern.size;\n }\n }\n\n return sum;\n}\n","import { parseSync } from '@swc/core';\nimport type { ParseOptions as SwcParseOptions } from '@swc/core';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport type { UsageReport } from './types';\nimport { createState } from './core/state';\nimport { visitNode } from './core/visitor';\nimport { generateReport } from './core/report';\n\nfunction swcOptionsForFile(filePath: string): SwcParseOptions {\n const ext = path.extname(filePath).toLowerCase();\n if (ext === '.ts')\n return {\n syntax: 'typescript',\n tsx: false,\n decorators: true,\n dynamicImport: true,\n };\n if (ext === '.tsx')\n return {\n syntax: 'typescript',\n tsx: true,\n decorators: true,\n dynamicImport: true,\n };\n if (ext === '.jsx')\n return {\n syntax: 'ecmascript',\n jsx: true,\n decorators: true,\n importAssertions: true,\n };\n // .js / .mjs / .cjs\n return {\n syntax: 'ecmascript',\n jsx: false,\n decorators: true,\n importAssertions: true,\n };\n}\n\nexport function parseCode(code: string, filePath = 'file.tsx'): UsageReport {\n const state = createState();\n const ast = parseSync(code, swcOptionsForFile(filePath));\n visitNode(ast, state);\n return generateReport(state);\n}\n\nexport function parseFile(filePath: string): UsageReport | null {\n const code = fs.readFileSync(filePath, 'utf8');\n return parseCode(code, filePath);\n}\n\nexport type { UsageReport } from './types';\n","import { globSync } from 'glob';\nimport fs from 'fs';\nimport path from 'path';\n\nexport interface RuleViolation {\n type:\n | 'forbid_files'\n | 'require_files'\n | 'allow_files'\n | 'forbid_packages'\n | 'require_packages'\n | 'require_scripts'\n | 'require_package_fields'\n | 'engine_version';\n severity: 'error' | 'warn';\n patterns: string[];\n message?: string;\n matchedFiles: string[];\n // engine_version only\n installedRange?: string;\n requiredRange?: string;\n}\n\nexport function toArray<T>(val: T | T[] | undefined): T[] {\n if (!val) return [];\n return Array.isArray(val) ? val : [val];\n}\n\nexport function findMatches(\n patterns: string[],\n repoPath: string,\n ignore: string[],\n): string[] {\n const matches: string[] = [];\n for (const pattern of patterns) {\n const found = globSync(pattern, { cwd: repoPath, nodir: true, ignore });\n matches.push(...found.map((f) => path.join(repoPath, f)));\n }\n return [...new Set(matches)];\n}\n\nexport function readPackageJson(\n repoPath: string,\n): Record<string, unknown> | null {\n try {\n const content = fs.readFileSync(\n path.join(repoPath, 'package.json'),\n 'utf-8',\n );\n return JSON.parse(content) as Record<string, unknown>;\n } catch {\n return null;\n }\n}\n","import type { RulesConfig } from '../config/types';\nimport { toArray, findMatches } from './shared';\nimport type { RuleViolation } from './shared';\n\nexport function evaluateFileRules(\n repoPath: string,\n rulesConfig: RulesConfig,\n excludes: string[],\n): RuleViolation[] {\n const violations: RuleViolation[] = [];\n\n for (const rule of toArray(rulesConfig.forbid_files)) {\n const matches = findMatches(rule.patterns, repoPath, excludes);\n if (matches.length > 0) {\n violations.push({\n type: 'forbid_files',\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: matches,\n });\n }\n }\n\n for (const rule of toArray(rulesConfig.require_files)) {\n const matches = findMatches(rule.patterns, repoPath, excludes);\n if (matches.length === 0) {\n violations.push({\n type: 'require_files',\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: [],\n });\n }\n }\n\n for (const rule of toArray(rulesConfig.allow_files)) {\n const matches = findMatches(rule.patterns, repoPath, excludes);\n if (matches.length === 0) {\n violations.push({\n type: 'allow_files',\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: [],\n });\n }\n }\n\n return violations;\n}\n","import micromatch from 'micromatch';\nimport type { RulesConfig } from '../config/types';\nimport { toArray, readPackageJson } from './shared';\nimport type { RuleViolation } from './shared';\n\nexport function evaluateScriptRules(\n repoPath: string,\n rulesConfig: RulesConfig,\n): RuleViolation[] {\n const rules = toArray(rulesConfig.require_scripts);\n if (rules.length === 0) {\n return [];\n }\n\n const pkg = readPackageJson(repoPath);\n const scriptKeys = Object.keys(\n (pkg?.scripts as Record<string, string> | undefined) ?? {},\n );\n\n return rules\n .filter(\n (rule) =>\n !rule.patterns.some((p) =>\n scriptKeys.some((k) => micromatch.isMatch(k, p)),\n ),\n )\n .map((rule) => ({\n type: 'require_scripts' as const,\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: [],\n }));\n}\n","import type { RulesConfig } from '../config/types';\nimport { toArray, readPackageJson } from './shared';\nimport type { RuleViolation } from './shared';\n\nexport function evaluatePackageFieldRules(\n repoPath: string,\n rulesConfig: RulesConfig,\n): RuleViolation[] {\n const rules = toArray(rulesConfig.require_package_fields);\n if (rules.length === 0) {\n return [];\n }\n\n const pkg = readPackageJson(repoPath);\n const fieldKeys = pkg ? Object.keys(pkg) : [];\n\n return rules\n .filter((rule) => !rule.patterns.some((p) => fieldKeys.includes(p)))\n .map((rule) => ({\n type: 'require_package_fields' as const,\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: [],\n }));\n}\n","import semver from 'semver';\nimport type { RulesConfig } from '../config/types';\nimport { toArray, readPackageJson } from './shared';\nimport type { RuleViolation } from './shared';\n\nexport function evaluateEngineVersion(\n repoPath: string,\n rulesConfig: RulesConfig,\n): RuleViolation[] {\n const rules = toArray(rulesConfig.engine_version);\n if (rules.length === 0) {\n return [];\n }\n\n const pkg = readPackageJson(repoPath);\n const nodeRange = (pkg?.engines as Record<string, string> | undefined)?.node;\n\n return rules.flatMap((rule): RuleViolation[] => {\n if (!nodeRange) {\n return [\n {\n type: 'engine_version',\n severity: rule.severity,\n patterns: [],\n message: rule.message ?? 'engines.node not specified in package.json',\n matchedFiles: [],\n requiredRange: rule.range,\n },\n ];\n }\n\n const minVer = semver.minVersion(nodeRange);\n if (!minVer || !semver.satisfies(minVer, rule.range)) {\n return [\n {\n type: 'engine_version',\n severity: rule.severity,\n patterns: [],\n message: rule.message,\n matchedFiles: [],\n installedRange: nodeRange,\n requiredRange: rule.range,\n },\n ];\n }\n\n return [];\n });\n}\n","import type { RulesConfig } from '../config/types';\nimport { evaluateFileRules } from './file-rules';\nimport { evaluateScriptRules } from './script-rules';\nimport { evaluatePackageFieldRules } from './package-field-rules';\nimport { evaluateEngineVersion } from './engine-version';\n\nexport type { RuleViolation } from './shared';\nexport { toArray } from './shared';\n\nexport function evaluateRules(\n repoPath: string,\n rulesConfig: RulesConfig,\n excludes: string[],\n): import('./shared').RuleViolation[] {\n return [\n ...evaluateFileRules(repoPath, rulesConfig, excludes),\n ...evaluateScriptRules(repoPath, rulesConfig),\n ...evaluatePackageFieldRules(repoPath, rulesConfig),\n ...evaluateEngineVersion(repoPath, rulesConfig),\n ];\n}\n","import micromatch from 'micromatch';\nimport type { UsageReport } from '../swc-parser';\nimport type { HermexConfig, VersusConfig } from '../config/types';\nimport type { MultiVersionMap } from '../lock-parser';\nimport type { RuleViolation } from '../rules/evaluator';\nimport { toArray } from '../rules/evaluator';\nimport type { ReleaseAgeEntry } from '../npm-registry/types';\n\nfunction toPercentage(count: number, total: number): number {\n return total > 0 ? (count / total) * 100 : 0;\n}\n\nexport interface ComponentUsage {\n name: string;\n source: string;\n count: number;\n files: Set<string>;\n}\n\nexport interface PackageDistribution {\n packageName: string;\n version: string | null;\n componentCount: number;\n usageCount: number;\n percentage: number;\n components: string[];\n internal: boolean;\n hasVersionConflict: boolean;\n allVersions: string[];\n releaseAge?: ReleaseAgeEntry;\n}\n\nexport interface PatternCount {\n patternType: string;\n displayName: string;\n count: number;\n}\n\nexport interface VersusEntry {\n packageName: string;\n count: number;\n percentage: number;\n components: string[];\n}\n\nexport interface VersusResult {\n name: string;\n packages: string[];\n entries: VersusEntry[];\n totalCount: number;\n}\n\nexport interface BannedPackageViolation {\n packageName: string;\n severity: 'error' | 'warn';\n message?: string;\n}\n\nexport interface AggregatedReport {\n filesAnalyzed: number;\n totalImports: number;\n totalComponents: number;\n totalUsagePatterns: number;\n patternCounts: PatternCount[];\n componentUsage: Map<string, ComponentUsage>;\n topComponents: ComponentUsage[];\n allComponents: string[];\n packageDistribution: PackageDistribution[];\n versusResults: VersusResult[];\n ruleViolations: RuleViolation[];\n bannedPackageViolations: BannedPackageViolation[];\n reports: UsageReport[];\n}\n\nexport function aggregateReports(\n reports: UsageReport[],\n versions: Record<string, string> = {},\n config?: HermexConfig,\n multiVersions: MultiVersionMap = {},\n): AggregatedReport {\n const componentUsageMap = new Map<string, ComponentUsage>();\n let totalImports = 0;\n let totalUsagePatterns = 0;\n const patternCountMap = new Map<string, number>();\n\n const availablePackages = Object.keys(versions);\n\n for (const report of reports) {\n totalImports += report.summary.totalImports;\n totalUsagePatterns += report.summary.totalUsagePatterns;\n\n for (const jsx of report.patterns.usage.jsx) {\n const key = jsx.component;\n const existing = componentUsageMap.get(key);\n\n if (existing) {\n existing.count++;\n } else {\n const source = findComponentSource(\n jsx.component,\n report,\n availablePackages,\n );\n componentUsageMap.set(key, {\n name: jsx.component,\n source,\n count: 1,\n files: new Set(),\n });\n }\n }\n\n countPatterns(report, patternCountMap);\n }\n\n const topComponents = Array.from(componentUsageMap.values()).sort(\n (a, b) => b.count - a.count,\n );\n\n const allComponents = Array.from(componentUsageMap.keys()).sort();\n\n const patternCounts = Array.from(patternCountMap.entries())\n .map(([type, count]) => ({\n patternType: type,\n displayName: getPatternDisplayName(type),\n count,\n }))\n .sort((a, b) => b.count - a.count);\n\n const packageDistribution = calculatePackageDistribution(\n componentUsageMap,\n versions,\n config,\n multiVersions,\n );\n\n const versusResults = calculateVersusResults(\n packageDistribution,\n config?.versus ?? [],\n );\n const bannedPackageViolations = detectBannedPackages(\n packageDistribution,\n config,\n );\n\n const requiredPackageViolations = detectRequiredPackages(\n packageDistribution,\n versions,\n config,\n );\n\n return {\n filesAnalyzed: reports.length,\n totalImports,\n totalComponents: componentUsageMap.size,\n totalUsagePatterns,\n patternCounts,\n componentUsage: componentUsageMap,\n topComponents,\n allComponents,\n packageDistribution,\n versusResults,\n ruleViolations: requiredPackageViolations,\n bannedPackageViolations,\n reports,\n };\n}\n\nfunction calculateVersusResults(\n distribution: PackageDistribution[],\n versusConfigs: VersusConfig[],\n): VersusResult[] {\n const distMap = new Map(distribution.map((p) => [p.packageName, p]));\n\n return versusConfigs.map((vc) => {\n const entries: VersusEntry[] = vc.packages.map((pkgName) => {\n const pkg = distMap.get(pkgName);\n return {\n packageName: pkgName,\n count: pkg?.usageCount ?? 0,\n percentage: 0,\n components: pkg?.components ?? [],\n };\n });\n\n const totalCount = entries.reduce((sum, e) => sum + e.count, 0);\n\n for (const entry of entries) {\n entry.percentage = toPercentage(entry.count, totalCount);\n }\n\n entries.sort((a, b) => b.count - a.count);\n\n return { name: vc.name, packages: vc.packages, entries, totalCount };\n });\n}\n\nfunction detectBannedPackages(\n distribution: PackageDistribution[],\n config?: HermexConfig,\n): BannedPackageViolation[] {\n const forbidRules = toArray(config?.rules.forbid_packages);\n if (forbidRules.length === 0) {\n return [];\n }\n\n const violations: BannedPackageViolation[] = [];\n for (const pkg of distribution) {\n for (const rule of forbidRules) {\n if (micromatch.isMatch(pkg.packageName, rule.patterns)) {\n violations.push({\n packageName: pkg.packageName,\n severity: rule.severity,\n message: rule.message,\n });\n break;\n }\n }\n }\n return violations;\n}\n\nfunction detectRequiredPackages(\n distribution: PackageDistribution[],\n versions: Record<string, string>,\n config?: HermexConfig,\n): RuleViolation[] {\n const requireRules = toArray(config?.rules.require_packages);\n if (requireRules.length === 0) return [];\n\n // All package names available: from lockfile versions + from import distribution\n const installedNames = new Set([\n ...Object.keys(versions),\n ...distribution.map((p) => p.packageName),\n ]);\n\n const violations: RuleViolation[] = [];\n for (const rule of requireRules) {\n const satisfied = rule.patterns.some((p) =>\n [...installedNames].some((name) => micromatch.isMatch(name, p)),\n );\n if (!satisfied) {\n violations.push({\n type: 'require_packages',\n severity: rule.severity,\n patterns: rule.patterns,\n message: rule.message,\n matchedFiles: [],\n });\n }\n }\n return violations;\n}\n\nfunction resolvePackageFromImportPath(\n importPath: string,\n availablePackages: string[],\n): string {\n if (importPath.startsWith('.') || importPath.startsWith('/')) {\n return 'local';\n }\n\n const sortedPackages = [...availablePackages].sort(\n (a, b) => b.length - a.length,\n );\n\n for (const pkg of sortedPackages) {\n if (importPath === pkg) return pkg;\n if (importPath.startsWith(`${pkg}/`)) return pkg;\n }\n\n return 'unknown';\n}\n\nfunction findComponentSource(\n componentName: string,\n report: UsageReport,\n availablePackages: string[],\n): string {\n const namedImport = report.patterns.imports.named.find(\n (imp) => imp.name === componentName,\n );\n if (namedImport)\n return resolvePackageFromImportPath(namedImport.source, availablePackages);\n\n const defaultImport = report.patterns.imports.default.find(\n (imp) => imp.name === componentName,\n );\n if (defaultImport)\n return resolvePackageFromImportPath(\n defaultImport.source,\n availablePackages,\n );\n\n const aliasedImport = report.patterns.imports.aliased.find(\n (imp) => imp.local === componentName,\n );\n if (aliasedImport)\n return resolvePackageFromImportPath(\n aliasedImport.source,\n availablePackages,\n );\n\n return 'unknown';\n}\n\nfunction countPatterns(report: UsageReport, patternMap: Map<string, number>) {\n increment(\n patternMap,\n 'imports.default',\n report.patterns.imports.default.length,\n );\n increment(patternMap, 'imports.named', report.patterns.imports.named.length);\n increment(\n patternMap,\n 'imports.namespace',\n report.patterns.imports.namespace.length,\n );\n increment(\n patternMap,\n 'imports.aliased',\n report.patterns.imports.aliased.length,\n );\n increment(patternMap, 'usage.jsx', report.patterns.usage.jsx.length);\n increment(\n patternMap,\n 'usage.variables',\n report.patterns.usage.variables.length,\n );\n increment(\n patternMap,\n 'usage.destructuring',\n report.patterns.usage.destructuring.length,\n );\n increment(\n patternMap,\n 'usage.conditional',\n report.patterns.usage.conditional.length,\n );\n increment(patternMap, 'usage.arrays', report.patterns.usage.arrays.length);\n increment(patternMap, 'usage.objects', report.patterns.usage.objects.length);\n increment(patternMap, 'advanced.lazy', report.patterns.advanced.lazy.length);\n increment(\n patternMap,\n 'advanced.dynamic',\n report.patterns.advanced.dynamic.length,\n );\n increment(patternMap, 'advanced.hoc', report.patterns.advanced.hoc.length);\n increment(patternMap, 'advanced.memo', report.patterns.advanced.memo.length);\n increment(\n patternMap,\n 'advanced.forwardRef',\n report.patterns.advanced.forwardRef.length,\n );\n increment(\n patternMap,\n 'advanced.portal',\n report.patterns.advanced.portal.length,\n );\n}\n\nfunction increment(map: Map<string, number>, key: string, value: number) {\n map.set(key, (map.get(key) || 0) + value);\n}\n\nfunction getPatternDisplayName(patternType: string): string {\n const displayNames: Record<string, string> = {\n 'imports.default': 'Default Imports',\n 'imports.named': 'Named Imports',\n 'imports.namespace': 'Namespace Imports',\n 'imports.aliased': 'Aliased Imports',\n 'usage.jsx': 'JSX Usage',\n 'usage.variables': 'Variable Assignments',\n 'usage.destructuring': 'Destructuring',\n 'usage.conditional': 'Conditional Usage',\n 'usage.arrays': 'Array Mappings',\n 'usage.objects': 'Object Mappings',\n 'advanced.lazy': 'Lazy Loading',\n 'advanced.dynamic': 'Dynamic Imports',\n 'advanced.hoc': 'Higher-Order Components',\n 'advanced.memo': 'Memoized Components',\n 'advanced.forwardRef': 'Forward Refs',\n 'advanced.portal': 'Portal Usage',\n };\n return displayNames[patternType] || patternType;\n}\n\nfunction getPackageVersion(\n packageName: string,\n versions: Record<string, string>,\n): string | null {\n if (versions[packageName]) return versions[packageName];\n\n if (packageName.includes('/')) {\n const parts = packageName.split('/');\n if (packageName.startsWith('@') && parts.length > 2) {\n const basePackage = `${parts[0]}/${parts[1]}`;\n if (versions[basePackage]) return versions[basePackage];\n }\n if (!packageName.startsWith('@') && parts.length > 1) {\n if (versions[parts[0]]) return versions[parts[0]];\n }\n }\n\n return null;\n}\n\nfunction calculatePackageDistribution(\n componentUsageMap: Map<string, ComponentUsage>,\n versions: Record<string, string>,\n config?: HermexConfig,\n multiVersions: MultiVersionMap = {},\n): PackageDistribution[] {\n const ignorePatterns = config?.packages.ignore ?? [];\n const internalPatterns = config?.packages.internal ?? [];\n\n const packageMap = new Map<string, PackageDistribution>();\n\n for (const component of componentUsageMap.values()) {\n if (component.source === 'unknown' || component.source === 'local')\n continue;\n\n if (\n ignorePatterns.length > 0 &&\n micromatch.isMatch(component.source, ignorePatterns)\n ) {\n continue;\n }\n\n const existing = packageMap.get(component.source);\n if (existing) {\n existing.componentCount++;\n existing.usageCount += component.count;\n existing.components.push(component.name);\n } else {\n const isInternal =\n internalPatterns.length > 0\n ? micromatch.isMatch(component.source, internalPatterns)\n : false;\n\n const allVersions = multiVersions[component.source] ?? [];\n const hasVersionConflict = allVersions.length > 1;\n\n packageMap.set(component.source, {\n packageName: component.source,\n version: getPackageVersion(component.source, versions),\n componentCount: 1,\n usageCount: component.count,\n percentage: 0,\n components: [component.name],\n internal: isInternal,\n hasVersionConflict,\n allVersions,\n });\n }\n }\n\n const distribution = Array.from(packageMap.values());\n const totalExternalUsage = distribution.reduce(\n (sum, pkg) => sum + pkg.usageCount,\n 0,\n );\n\n for (const pkg of distribution) {\n pkg.percentage =\n totalExternalUsage > 0 ? (pkg.usageCount / totalExternalUsage) * 100 : 0;\n }\n\n return distribution.sort((a, b) => b.usageCount - a.usageCount);\n}\n","/**\n * Format a number with thousand separators\n * @param num - Number to format\n * @returns Formatted string (e.g., 1,234,567)\n */\nexport function formatCount(num: number): string {\n return num.toLocaleString();\n}\n\n/**\n * Format duration in seconds to a readable string\n * @param seconds - Duration in seconds\n * @returns Formatted string (e.g., 10.21s, 1.57s, 0.12s)\n */\nexport function formatDuration(seconds: number): string {\n return `${seconds.toFixed(2)}s`;\n}\n","import chalk from 'chalk';\nimport Table from 'cli-table3';\nimport type { AggregatedReport } from './aggregator';\nimport { formatCount } from './format-utils';\n\nfunction printHeader() {\n console.log(chalk.green.bold('\\n📊 Summary\\n'));\n}\n\nexport function printSummary(aggregated: AggregatedReport) {\n printHeader();\n\n const table = new Table({\n head: ['Metric', 'Count'],\n style: {\n head: ['cyan'],\n border: ['gray'],\n },\n });\n\n // Calculate external components only (filter out unknown and local)\n const externalComponents = aggregated.topComponents.filter(\n (comp) => comp.source !== 'unknown' && comp.source !== 'local',\n ).length;\n\n // Calculate total external package usage\n const totalExternalUsage = aggregated.packageDistribution.reduce(\n (sum, pkg) => sum + pkg.usageCount,\n 0,\n );\n\n table.push(\n ['Files Analyzed', formatCount(aggregated.filesAnalyzed)],\n ['External Packages', formatCount(aggregated.packageDistribution.length)],\n ['External Components', formatCount(externalComponents)],\n ['Total Usages', formatCount(totalExternalUsage)],\n );\n\n console.log(table.toString());\n}\n","import chalk from 'chalk';\nimport type { AggregatedReport } from './aggregator';\nimport { formatCount } from './format-utils';\n\nfunction printHeader() {\n console.log(chalk.cyan.bold('\\n📋 Details\\n'));\n}\n\nexport function printDetails(aggregated: AggregatedReport) {\n printHeader();\n\n console.log(\n chalk.cyan(\n ` Total usage patterns: ${formatCount(aggregated.totalUsagePatterns)}`,\n ),\n );\n\n // Print each pattern type count\n for (const pattern of aggregated.patternCounts) {\n if (pattern.count > 0) {\n console.log(\n chalk.cyan(` ${pattern.displayName}: ${formatCount(pattern.count)}`),\n );\n }\n }\n}\n","import chalk from 'chalk';\nimport { formatCount } from './format-utils';\n\nexport interface ChartData {\n label: string;\n value: number;\n}\n\nexport interface ChartOptions {\n maxWidth?: number;\n showValues?: boolean;\n barChar?: string;\n emptyChar?: string;\n}\n\nexport function renderBarChart(data: ChartData[], options: ChartOptions = {}) {\n const {\n maxWidth = 50,\n showValues = true,\n barChar = '█',\n emptyChar = '░',\n } = options;\n\n if (data.length === 0) {\n console.log(chalk.gray(' No data to display'));\n return;\n }\n\n // Find max value for scaling\n const maxValue = Math.max(...data.map((d) => d.value));\n if (maxValue === 0) {\n console.log(chalk.gray(' All values are zero'));\n return;\n }\n\n // Find longest label for alignment\n const maxLabelLength = Math.max(...data.map((d) => d.label.length));\n\n // Render each bar\n for (const item of data) {\n const percentage = item.value / maxValue;\n const barLength = Math.round(percentage * maxWidth);\n const emptyLength = maxWidth - barLength;\n\n // Pad label\n const paddedLabel = item.label.padEnd(maxLabelLength, ' ');\n\n // Build bar\n const bar =\n chalk.green(barChar.repeat(barLength)) +\n chalk.gray(emptyChar.repeat(emptyLength));\n\n // Build value string\n const valueStr = showValues ? ` ${formatCount(item.value)}` : '';\n\n console.log(`${paddedLabel} ${bar}${valueStr}\\n`);\n }\n}\n","import chalk from 'chalk';\nimport Table from 'cli-table3';\nimport type { AggregatedReport, ComponentUsage } from './aggregator';\nimport { renderBarChart } from './chart-renderer';\n\nfunction printHeader() {\n // FIXME why double space, if single space output is wrong somehow?\n console.log(chalk.magenta.bold('\\n⚛️ Components\\n'));\n}\n\nexport function printComponents(\n aggregated: AggregatedReport,\n mode: 'table' | 'chart',\n) {\n const components = aggregated.topComponents;\n\n if (mode === 'table') {\n printComponentsTable(components);\n } else if (mode === 'chart') {\n printComponentsChart(components);\n }\n}\n\nfunction printComponentsTable(components: ComponentUsage[]) {\n printHeader();\n\n // Filter out unknown and local components - only show external packages\n const externalComponents = components.filter(\n (comp) => comp.source !== 'unknown' && comp.source !== 'local',\n );\n\n if (externalComponents.length === 0) {\n console.log(chalk.gray(' No external components found'));\n return;\n }\n\n const table = new Table({\n head: ['Component', 'Package', 'Count'],\n style: {\n head: ['cyan'],\n border: ['gray'],\n },\n });\n\n externalComponents.forEach((comp) => {\n table.push([comp.name, comp.source, comp.count.toString()]);\n });\n\n console.log(table.toString());\n}\n\nfunction printComponentsChart(components: ComponentUsage[]) {\n printHeader();\n\n // Filter out unknown and local components - only show external packages\n const externalComponents = components.filter(\n (comp) => comp.source !== 'unknown' && comp.source !== 'local',\n );\n\n if (externalComponents.length === 0) {\n console.log(chalk.gray(' No external components found'));\n return;\n }\n\n const data = externalComponents.map((comp) => ({\n label: comp.name,\n value: comp.count,\n }));\n\n renderBarChart(data, { maxWidth: 50 });\n}\n","import chalk from 'chalk';\nimport Table from 'cli-table3';\nimport type { AggregatedReport, PatternCount } from './aggregator';\nimport { renderBarChart } from './chart-renderer';\n\nfunction printHeader() {\n console.log(chalk.blue.bold('\\n🔍 Code Patterns\\n'));\n}\n\nexport function printPatterns(\n aggregated: AggregatedReport,\n mode: 'table' | 'chart',\n) {\n const patterns = aggregated.patternCounts.filter((p) => p.count > 0);\n\n if (mode === 'table') {\n printPatternsTable(patterns);\n } else if (mode === 'chart') {\n printPatternsChart(patterns);\n }\n}\n\nfunction printPatternsTable(patterns: PatternCount[]) {\n printHeader();\n\n if (patterns.length === 0) {\n console.log(chalk.gray(' No patterns found'));\n return;\n }\n\n const table = new Table({\n head: ['Pattern', 'Count'],\n style: {\n head: ['cyan'],\n border: ['gray'],\n },\n });\n\n patterns.forEach((pattern) => {\n table.push([pattern.displayName, pattern.count.toString()]);\n });\n\n console.log(table.toString());\n\n // Show total patterns count\n const totalPatterns = patterns.reduce((sum, p) => sum + p.count, 0);\n console.log(chalk.gray(`\\nTotal: ${totalPatterns} patterns detected`));\n}\n\nfunction printPatternsChart(patterns: PatternCount[]) {\n printHeader();\n\n if (patterns.length === 0) {\n console.log(chalk.gray(' No patterns found'));\n return;\n }\n\n const data = patterns.map((pattern) => ({\n label: pattern.displayName,\n value: pattern.count,\n }));\n\n renderBarChart(data, { maxWidth: 50 });\n}\n","import chalk from 'chalk';\nimport Table from 'cli-table3';\nimport type {\n AggregatedReport,\n BannedPackageViolation,\n PackageDistribution,\n} from './aggregator';\nimport type { ReleaseAgeEntry } from '../npm-registry/types';\nimport { formatCount } from './format-utils';\n\nfunction printHeader() {\n console.log(chalk.blueBright.bold('\\n📦 Packages\\n'));\n}\n\nfunction formatPackageName(\n pkg: PackageDistribution,\n banned?: BannedPackageViolation,\n): string {\n let prefix = '';\n if (pkg.releaseAge?.deprecated) {\n prefix += chalk.red('[DEPRECATED] ');\n }\n if (banned) {\n prefix +=\n banned.severity === 'error'\n ? chalk.red('[BANNED] ')\n : chalk.yellow('[RESTRICTED] ');\n } else if (pkg.internal) {\n prefix += chalk.yellow('[int] ');\n }\n return prefix + pkg.packageName;\n}\n\nfunction formatUpgradeCell(releaseAge?: ReleaseAgeEntry): string {\n if (!releaseAge) return '';\n const { worstLevel, upgrades } = releaseAge;\n if (!worstLevel) return chalk.green('✓');\n\n const top = upgrades[0];\n if (!top) return chalk.green('✓');\n\n if (worstLevel === 'mandatory_upgrade') {\n return chalk.red(\n `⚠ ${top.semverBump} ${top.version} (${top.releasedDaysAgo}d)`,\n );\n }\n return chalk.yellow(\n `↑ ${top.semverBump} ${top.version} (${top.releasedDaysAgo}d)`,\n );\n}\n\nfunction getBannedViolation(\n pkg: PackageDistribution,\n violations: BannedPackageViolation[],\n): BannedPackageViolation | undefined {\n return violations.find((v) => v.packageName === pkg.packageName);\n}\n\nexport function printPackages(\n aggregated: AggregatedReport,\n mode: 'table' | 'chart',\n) {\n const packages = aggregated.packageDistribution;\n const violations = aggregated.bannedPackageViolations;\n\n if (mode === 'table') {\n printPackagesTable(packages, violations);\n } else if (mode === 'chart') {\n printPackagesChart(packages, violations);\n }\n}\n\nfunction printPackagesTable(\n packages: PackageDistribution[],\n violations: BannedPackageViolation[],\n) {\n printHeader();\n\n if (packages.length === 0) {\n console.log(chalk.gray(' No packages found'));\n return;\n }\n\n const hasReleaseAge = packages.some((p) => p.releaseAge !== undefined);\n const head = ['Package', 'Version', 'Components', 'Usage', 'Percentage'];\n if (hasReleaseAge) head.push('Upgrades');\n\n const table = new Table({\n head,\n style: {\n head: ['cyan'],\n border: ['gray'],\n },\n });\n\n packages.forEach((pkg) => {\n const versionCell = pkg.hasVersionConflict\n ? chalk.yellow(\n `⚠ ${pkg.allVersions.join(', ')} (multiple — bundle impact)`,\n )\n : pkg.version || 'N/A';\n\n const row = [\n formatPackageName(pkg, getBannedViolation(pkg, violations)),\n versionCell,\n formatCount(pkg.componentCount),\n formatCount(pkg.usageCount),\n `${pkg.percentage.toFixed(1)}%`,\n ];\n if (hasReleaseAge) row.push(formatUpgradeCell(pkg.releaseAge));\n table.push(row);\n });\n\n console.log(table.toString());\n\n const totalComponents = packages.reduce(\n (sum, p) => sum + p.componentCount,\n 0,\n );\n const totalExternalUsage = packages.reduce((sum, p) => sum + p.usageCount, 0);\n console.log(\n chalk.gray(\n `\\nTotal: ${formatCount(packages.length)} packages | ${formatCount(totalComponents)} unique components | ${formatCount(totalExternalUsage)} total usages`,\n ),\n );\n}\n\nfunction printPackagesChart(\n packages: PackageDistribution[],\n violations: BannedPackageViolation[],\n) {\n printHeader();\n\n if (packages.length === 0) {\n console.log(chalk.gray(' No packages found'));\n return;\n }\n\n const maxBarWidth = 40;\n const maxPercentage = Math.max(...packages.map((p) => p.percentage));\n const maxLabelLength = Math.max(\n ...packages.map((p) => p.packageName.length + (p.internal ? 6 : 0)),\n );\n\n packages.forEach((pkg) => {\n const barLength = Math.round(\n (pkg.percentage / maxPercentage) * maxBarWidth,\n );\n const emptyLength = maxBarWidth - barLength;\n const label = formatPackageName(\n pkg,\n getBannedViolation(pkg, violations),\n ).padEnd(maxLabelLength, ' ');\n\n const bar =\n chalk.green('█'.repeat(barLength)) + chalk.gray('░'.repeat(emptyLength));\n\n console.log(\n `${label} ${bar} ${chalk.bold(pkg.percentage.toFixed(1) + '%')} (${pkg.usageCount})`,\n );\n });\n}\n","import chalk from 'chalk';\nimport type { AggregatedReport, VersusResult } from './aggregator';\n\nconst BAR_WIDTH = 30;\n\nfunction renderBar(percentage: number): string {\n const filled = Math.round((percentage / 100) * BAR_WIDTH);\n const empty = BAR_WIDTH - filled;\n return chalk.cyan('█'.repeat(filled)) + chalk.gray('░'.repeat(empty));\n}\n\nfunction formatComponents(components: string[], max = 3): string {\n if (components.length === 0) return '';\n const shown = components.slice(0, max);\n const rest = components.length - max;\n const list = shown.join(', ');\n return rest > 0 ? `${list} (+${rest} more)` : list;\n}\n\nfunction printVersusResult(result: VersusResult) {\n console.log(chalk.bold(` ${result.name}`));\n console.log(chalk.gray(` ${'─'.repeat(50)}`));\n\n const maxNameLen = Math.max(\n ...result.entries.map((e) => e.packageName.length),\n );\n\n for (const entry of result.entries) {\n const name = entry.packageName.padEnd(maxNameLen);\n const bar = renderBar(entry.percentage);\n const pct = chalk.bold(`${entry.percentage.toFixed(1)}%`);\n const usage = chalk.gray(`(${entry.count} usages)`);\n const components =\n entry.components.length > 0\n ? chalk.gray(` ${formatComponents(entry.components)}`)\n : '';\n\n console.log(` ${name} ${bar} ${pct} ${usage}${components}`);\n }\n\n if (result.totalCount === 0) {\n console.log(\n chalk.gray(' No usage detected for any package in this group.'),\n );\n }\n\n console.log();\n}\n\nexport function printVersus(aggregated: AggregatedReport) {\n if (aggregated.versusResults.length === 0) return;\n\n console.log(chalk.magentaBright.bold('\\n⚖️ Versus\\n'));\n\n for (const result of aggregated.versusResults) {\n printVersusResult(result);\n }\n}\n","import chalk from 'chalk';\nimport type { AggregatedReport } from './aggregator';\nimport type { RuleViolation } from '../rules/evaluator';\n\nfunction formatRuleType(type: RuleViolation['type']): string {\n switch (type) {\n case 'forbid_files':\n return 'forbid_files';\n case 'require_files':\n return 'require_files';\n case 'allow_files':\n return 'allow_files';\n case 'forbid_packages':\n return 'forbid_packages';\n case 'require_packages':\n return 'require_packages';\n case 'require_scripts':\n return 'require_scripts';\n case 'require_package_fields':\n return 'pkg_fields';\n case 'engine_version':\n return 'engine_version';\n }\n}\n\nfunction ruleIcon(violation: RuleViolation): string {\n if (violation.severity === 'error') return chalk.red('✗');\n return chalk.yellow('⚠');\n}\n\nfunction describeViolation(v: RuleViolation): string {\n const patterns = v.patterns.join(', ');\n const suffix = v.message ? chalk.gray(` — ${v.message}`) : '';\n\n if (v.type === 'forbid_files') {\n const files = v.matchedFiles.map((f) => {\n const parts = f.replace(/\\\\/g, '/').split('/');\n return parts[parts.length - 1];\n });\n return `${patterns} found (${files.join(', ')})${suffix}`;\n }\n\n if (v.type === 'require_files') return `${patterns} not found${suffix}`;\n if (v.type === 'allow_files') return `${patterns} not present${suffix}`;\n if (v.type === 'require_packages')\n return `${patterns} not installed${suffix}`;\n if (v.type === 'forbid_packages') return `${patterns} is forbidden${suffix}`;\n if (v.type === 'require_scripts')\n return `script ${patterns} missing in package.json${suffix}`;\n if (v.type === 'require_package_fields')\n return `field ${patterns} missing in package.json${suffix}`;\n\n if (v.type === 'engine_version') {\n if (!v.installedRange)\n return `engines.node not specified (required ${v.requiredRange})${suffix}`;\n return `engines.node is ${chalk.yellow(v.installedRange)}, required ${chalk.cyan(v.requiredRange)}${suffix}`;\n }\n\n return `${patterns} not present${suffix}`;\n}\n\nexport function printRules(aggregated: AggregatedReport): void {\n const { ruleViolations, bannedPackageViolations } = aggregated;\n const hasRuleViolations = ruleViolations.length > 0;\n const hasBannedViolations = bannedPackageViolations.length > 0;\n\n if (!hasRuleViolations && !hasBannedViolations) {\n console.log(chalk.greenBright.bold('\\n✓ Compliance\\n'));\n console.log(chalk.gray(' All compliance checks passed'));\n return;\n }\n\n console.log(chalk.blueBright.bold('\\n🔍 Compliance\\n'));\n\n if (hasRuleViolations) {\n for (const v of ruleViolations) {\n const icon = ruleIcon(v);\n const type = chalk.gray(formatRuleType(v.type).padEnd(14));\n const severityTag =\n v.severity === 'error' ? chalk.red('[ERROR]') : chalk.yellow('[WARN]');\n console.log(` ${icon} ${type} ${describeViolation(v)} ${severityTag}`);\n }\n }\n\n if (hasBannedViolations) {\n if (hasRuleViolations) console.log();\n for (const v of bannedPackageViolations) {\n const icon = v.severity === 'error' ? chalk.red('✗') : chalk.yellow('⚠');\n const tag =\n v.severity === 'error'\n ? chalk.red('[BANNED]')\n : chalk.yellow('[RESTRICTED]');\n const msg = v.message ? chalk.gray(` — ${v.message}`) : '';\n console.log(` ${icon} ${tag} ${v.packageName}${msg}`);\n }\n }\n\n const errorCount = [\n ...ruleViolations.filter((v) => v.severity === 'error'),\n ...bannedPackageViolations.filter((v) => v.severity === 'error'),\n ].length;\n const warnCount = [\n ...ruleViolations.filter((v) => v.severity === 'warn'),\n ...bannedPackageViolations.filter((v) => v.severity === 'warn'),\n ].length;\n\n const parts: string[] = [];\n if (errorCount > 0)\n parts.push(chalk.red(`${errorCount} error${errorCount > 1 ? 's' : ''}`));\n if (warnCount > 0)\n parts.push(chalk.yellow(`${warnCount} warning${warnCount > 1 ? 's' : ''}`));\n console.log(chalk.gray(`\\n ${parts.join(', ')}`));\n}\n","import chalk from 'chalk';\nimport type { ParseError } from '../swc-parser/types';\n\nexport function printErrors(errors: ParseError[]): void {\n if (errors.length === 0) return;\n console.log(chalk.yellow(`\\n⚠ ${errors.length} file(s) failed to parse:`));\n for (const { file, message } of errors) {\n console.log(chalk.yellow(` ${file}`));\n console.log(chalk.gray(` ${message}`));\n }\n console.log('');\n}\n","import type { AggregatedReport } from './aggregator';\n\nexport function printJson(aggregated: AggregatedReport): void {\n const result = {\n summary: {\n filesAnalyzed: aggregated.filesAnalyzed,\n totalImports: aggregated.totalImports,\n totalComponents: aggregated.totalComponents,\n totalUsagePatterns: aggregated.totalUsagePatterns,\n },\n packages: aggregated.packageDistribution,\n components: aggregated.topComponents.map((c) => ({\n ...c,\n files: [...c.files],\n })),\n patterns: aggregated.patternCounts,\n versus: aggregated.versusResults,\n ruleViolations: aggregated.ruleViolations,\n bannedPackageViolations: aggregated.bannedPackageViolations,\n };\n process.stdout.write(JSON.stringify(result, null, 2) + '\\n');\n}\n","import fs from 'fs';\nimport { glob } from 'glob';\n\n/**\n * Find files matching a glob pattern\n * @param pattern - Glob pattern\n * @param ignorePatterns - Glob pattenrs to ignore\n * @returns Array of file paths\n */\nexport async function findFiles(\n pattern: string | string[],\n ignorePatterns: string[],\n): Promise<string[]> {\n const files = await glob(pattern, {\n ignore: ignorePatterns,\n nodir: true,\n absolute: true,\n windowsPathsNoEscape: true,\n });\n\n return files;\n}\n\n/**\n * Read file content\n * @param filePath - Path to file\n * @returns File content\n */\nexport function readFile(filePath: string): string {\n return fs.readFileSync(filePath, 'utf8');\n}\n","import fs from 'fs';\nimport path from 'path';\nimport type { LockfileAdapter, MultiVersionMap } from '../lock-file-adapter';\n\nfunction canonicalPackageName(pkgPath: string): string {\n // pkgPath examples:\n // \"node_modules/react\"\n // \"node_modules/@scope/pkg\"\n // \"node_modules/react/node_modules/scheduler\"\n // \"node_modules/@scope/a/node_modules/@scope/b\"\n // We want the last segment after the last \"node_modules/\"\n const idx = pkgPath.lastIndexOf('node_modules/');\n if (idx === -1) return pkgPath;\n return pkgPath.slice(idx + 'node_modules/'.length);\n}\n\nexport class NpmLockfileAdapter implements LockfileAdapter {\n name = 'npm';\n supportedVersions = ['v2', 'v3'];\n\n detect(projectPath: string): string | null {\n const lockfilePath = path.join(projectPath, 'package-lock.json');\n return fs.existsSync(lockfilePath) ? lockfilePath : null;\n }\n\n parse(lockFilePath: string): Record<string, string> {\n try {\n const content = fs.readFileSync(lockFilePath, 'utf8');\n const lockData = JSON.parse(content);\n const versions: Record<string, string> = {};\n\n // npm v7+ uses \"packages\" field (lockfileVersion 2, 3)\n if (lockData.packages) {\n Object.entries(lockData.packages).forEach(\n ([pkgPath, pkgData]: [string, any]) => {\n if (!pkgPath || pkgPath === '') return;\n\n // Only root-level packages (no nested node_modules in path)\n if (pkgPath.split('node_modules/').length > 2) return;\n\n const pkgName = canonicalPackageName(pkgPath);\n if (pkgData.version) {\n versions[pkgName] = pkgData.version;\n }\n },\n );\n }\n\n // npm v6 uses \"dependencies\" field (fallback)\n if (lockData.dependencies && Object.keys(versions).length === 0) {\n function extractVersions(deps: any, prefix = ''): void {\n Object.entries(deps).forEach(([name, data]: [string, any]) => {\n const fullName = prefix ? `${prefix}/${name}` : name;\n if (data.version) {\n versions[fullName] = data.version;\n }\n if (data.dependencies) {\n extractVersions(data.dependencies, fullName);\n }\n });\n }\n extractVersions(lockData.dependencies);\n }\n\n return versions;\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n console.warn(`Warning: Could not parse package-lock.json: ${message}`);\n return {};\n }\n }\n\n parseMultiVersion(lockFilePath: string): MultiVersionMap {\n try {\n const content = fs.readFileSync(lockFilePath, 'utf8');\n const lockData = JSON.parse(content);\n const versionSets: Record<string, Set<string>> = {};\n\n if (lockData.packages) {\n Object.entries(lockData.packages).forEach(\n ([pkgPath, pkgData]: [string, any]) => {\n if (!pkgPath || pkgPath === '') return;\n\n const pkgName = canonicalPackageName(pkgPath);\n const version = (pkgData as any).version;\n if (!version) return;\n\n if (!versionSets[pkgName]) versionSets[pkgName] = new Set();\n versionSets[pkgName].add(version);\n },\n );\n }\n\n const result: MultiVersionMap = {};\n for (const [pkg, versions] of Object.entries(versionSets)) {\n result[pkg] = Array.from(versions).sort();\n }\n return result;\n } catch {\n return {};\n }\n }\n}\n","import fs from 'fs';\nimport path from 'path';\nimport { load } from 'js-yaml';\nimport type { LockfileAdapter } from '../lock-file-adapter';\n\nexport class PnpmLockfileAdapter implements LockfileAdapter {\n name = 'pnpm';\n supportedVersions = ['v5', 'v6', 'v9'];\n\n detect(projectPath: string): string | null {\n const lockfilePath = path.join(projectPath, 'pnpm-lock.yaml');\n return fs.existsSync(lockfilePath) ? lockfilePath : null;\n }\n\n parse(lockFilePath: string): Record<string, string> {\n try {\n const content = fs.readFileSync(lockFilePath, 'utf8');\n const lockData = load(content) as any;\n const versions: Record<string, string> = {};\n\n // pnpm v9+ uses \"importers\" field\n if (lockData.importers) {\n const rootImporter = lockData.importers['.'];\n if (rootImporter) {\n // Parse dependencies\n if (rootImporter.dependencies) {\n for (const [name, data] of Object.entries(\n rootImporter.dependencies,\n )) {\n if (\n typeof data === 'object' &&\n data !== null &&\n 'version' in data\n ) {\n versions[name] = (data as any).version;\n }\n }\n }\n // Parse devDependencies\n if (rootImporter.devDependencies) {\n for (const [name, data] of Object.entries(\n rootImporter.devDependencies,\n )) {\n if (\n typeof data === 'object' &&\n data !== null &&\n 'version' in data\n ) {\n versions[name] = (data as any).version;\n }\n }\n }\n }\n }\n\n // pnpm v6-8 uses \"packages\" field\n if (lockData.packages && Object.keys(versions).length === 0) {\n Object.keys(lockData.packages).forEach((key) => {\n // Key format: \"/@babel/core/7.22.5\" or \"/package/1.0.0\"\n const match = key.match(/\\/(.+?)\\/(\\d+\\.\\d+\\.\\d+.*?)(?:_|$)/);\n if (match) {\n const [, pkgName, version] = match;\n versions[pkgName] = version;\n }\n });\n }\n\n // pnpm v5 uses \"dependencies\" and \"specifiers\"\n if (lockData.dependencies && Object.keys(versions).length === 0) {\n Object.entries(lockData.dependencies).forEach(\n ([name, versionSpec]: [string, any]) => {\n // versionSpec format: \"1.0.0\" or \"link:../package\"\n if (\n typeof versionSpec === 'string' &&\n !versionSpec.startsWith('link:')\n ) {\n versions[name] = versionSpec;\n } else if (typeof versionSpec === 'object' && versionSpec.version) {\n versions[name] = versionSpec.version;\n }\n },\n );\n }\n\n return versions;\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n console.warn(`Warning: Could not parse pnpm-lock.yaml: ${message}`);\n return {};\n }\n }\n}\n","import fs from 'fs';\nimport path from 'path';\nimport lockfile from '@yarnpkg/lockfile';\nimport type { LockfileAdapter } from '../lock-file-adapter';\n\nexport class YarnLockfileAdapter implements LockfileAdapter {\n name = 'yarn';\n supportedVersions = ['v1', 'v2+'];\n\n detect(projectPath: string): string | null {\n const lockfilePath = path.join(projectPath, 'yarn.lock');\n return fs.existsSync(lockfilePath) ? lockfilePath : null;\n }\n\n parse(lockFilePath: string): Record<string, string> {\n try {\n const content = fs.readFileSync(lockFilePath, 'utf8');\n const parsed = lockfile.parse(content);\n\n if (parsed.type !== 'success') {\n console.warn('Warning: Failed to parse yarn.lock');\n return {};\n }\n\n const versions: Record<string, string> = {};\n\n Object.entries(parsed.object).forEach(([key, value]: [string, any]) => {\n // Key format: \"package@^1.0.0\" or \"@scope/package@^1.0.0\"\n // Extract package name (without version specifier)\n let pkgName = key;\n\n // Handle scoped packages\n if (key.startsWith('@')) {\n const match = key.match(/^(@[^@]+\\/[^@]+)@/);\n if (match) {\n pkgName = match[1];\n }\n } else {\n const match = key.match(/^([^@]+)@/);\n if (match) {\n pkgName = match[1];\n }\n }\n\n if (value.version && (!versions[pkgName] || value.version)) {\n versions[pkgName] = value.version;\n }\n });\n\n return versions;\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n console.warn(`Warning: Could not parse yarn.lock: ${message}`);\n return {};\n }\n }\n}\n","import { NpmLockfileAdapter } from './patterns/npm';\nimport { PnpmLockfileAdapter } from './patterns/pnpm';\nimport { YarnLockfileAdapter } from './patterns/yarn';\nimport type { LockfileAdapter, MultiVersionMap } from './lock-file-adapter';\n\nexport type { MultiVersionMap };\n\nexport interface VersionConflict {\n packageName: string;\n versions: string[];\n}\n\nexport interface LockfileResult {\n versions: Record<string, string>;\n multiVersions: MultiVersionMap;\n versionConflicts: VersionConflict[];\n lockfileType: 'npm' | 'yarn' | 'pnpm' | null;\n lockfilePath: string | null;\n supportedVersions: string[];\n}\n\nconst LOCKFILE_ADAPTERS: LockfileAdapter[] = [\n new NpmLockfileAdapter(),\n new YarnLockfileAdapter(),\n new PnpmLockfileAdapter(),\n];\n\n/**\n * Find and parse the appropriate lockfile in a directory\n * @param projectPath - Path to the project directory\n * @returns Object with versions map and lockfile type\n */\nexport function findAndParseLockfile(projectPath: string): LockfileResult {\n for (const adapter of LOCKFILE_ADAPTERS) {\n const lockfilePath = adapter.detect(projectPath);\n if (lockfilePath) {\n const versions = adapter.parse(lockfilePath);\n const multiVersions = adapter.parseMultiVersion\n ? adapter.parseMultiVersion(lockfilePath)\n : {};\n\n const versionConflicts: VersionConflict[] = Object.entries(multiVersions)\n .filter(([, vers]) => vers.length > 1)\n .map(([packageName, vers]) => ({ packageName, versions: vers }));\n\n return {\n versions,\n multiVersions,\n versionConflicts,\n lockfileType: adapter.name as 'npm' | 'yarn' | 'pnpm',\n lockfilePath,\n supportedVersions: adapter.supportedVersions,\n };\n }\n }\n\n throw new Error('No supported lockfile found');\n}\n\n/**\n * Get the version of a specific package from lockfile\n * @param projectPath - Path to the project directory\n * @param packageName - Name of the package\n * @returns Version string or null if not found\n */\nexport function getPackageVersion(\n projectPath: string,\n packageName: string,\n): string | null {\n const { versions } = findAndParseLockfile(projectPath);\n return versions[packageName] || null;\n}\n\n/**\n * Get versions for multiple packages\n * @param projectPath - Path to the project directory\n * @param packageNames - Array of package names\n * @returns Map of package names to versions\n */\nexport function getPackageVersions(\n projectPath: string,\n packageNames: string[],\n): Record<string, string> {\n const { versions } = findAndParseLockfile(projectPath);\n const result: Record<string, string> = {};\n\n packageNames.forEach((pkgName) => {\n if (versions[pkgName]) {\n result[pkgName] = versions[pkgName];\n }\n });\n\n return result;\n}\n","import { z } from 'zod';\n\n// ── Sub-schemas ────────────────────────────────────────────────────────────────\n\nconst RuleSeveritySchema = z.enum(['error', 'warn']);\n\nconst RuleConfigSchema = z.object({\n severity: RuleSeveritySchema,\n patterns: z.array(z.string()),\n message: z.string().optional(),\n});\n\nconst RuleConfigOrArraySchema = z.union([\n RuleConfigSchema,\n z.array(RuleConfigSchema),\n]);\n\nconst EngineVersionRuleSchema = z.object({\n severity: RuleSeveritySchema,\n range: z.string(),\n message: z.string().optional(),\n});\n\nconst ThresholdSchema = z.union([z.number(), z.literal(false)]);\n\n// ── Main schema with defaults ──────────────────────────────────────────────────\n\nexport const HermexConfigSchema = z.object({\n includes: z.array(z.string()).default(['**/*.{tsx,jsx,ts,js}']),\n excludes: z\n .array(z.string())\n .default(['**/node_modules/**', '**/dist/**', '**/build/**']),\n\n packages: z\n .object({\n internal: z.array(z.string()).default([]),\n ignore: z.array(z.string()).default([]),\n })\n .default(() => ({ internal: [], ignore: [] })),\n\n versus: z\n .array(z.object({ name: z.string(), packages: z.array(z.string()).min(2) }))\n .default([]),\n\n rules: z\n .object({\n forbid_files: RuleConfigOrArraySchema.default([]),\n require_files: RuleConfigOrArraySchema.default([]),\n allow_files: RuleConfigOrArraySchema.default([]),\n forbid_packages: RuleConfigOrArraySchema.default([]),\n require_packages: RuleConfigOrArraySchema.default([]),\n require_scripts: RuleConfigOrArraySchema.default([]),\n require_package_fields: RuleConfigOrArraySchema.default([]),\n engine_version: z\n .union([EngineVersionRuleSchema, z.array(EngineVersionRuleSchema)])\n .optional(),\n })\n .default(() => ({\n forbid_files: [] as RuleConfig[],\n require_files: [] as RuleConfig[],\n allow_files: [] as RuleConfig[],\n forbid_packages: [] as RuleConfig[],\n require_packages: [] as RuleConfig[],\n require_scripts: [] as RuleConfig[],\n require_package_fields: [] as RuleConfig[],\n })),\n\n output: z\n .object({\n summary: z.union([z.literal('log'), z.literal(false)]).default('log'),\n components: z\n .union([z.enum(['table', 'chart']), z.literal(false)])\n .default('table'),\n packages: z\n .union([z.enum(['table', 'chart']), z.literal(false)])\n .default('table'),\n patterns: z\n .union([z.enum(['table', 'chart']), z.literal(false)])\n .default('table'),\n details: z.boolean().default(false),\n versus: z.boolean().default(true),\n rules: z.boolean().default(true),\n format: z.enum(['human', 'json']).default('human'),\n })\n .default(() => ({\n summary: 'log' as const,\n components: 'table' as const,\n packages: 'table' as const,\n patterns: 'table' as const,\n details: false,\n versus: true,\n rules: true,\n format: 'human' as const,\n })),\n\n releaseAge: z\n .object({\n enabled: z.boolean().default(false),\n registry: z.string().default('https://registry.npmjs.org'),\n authToken: z.string().optional(),\n thresholds: z\n .object({\n patch: ThresholdSchema.default(30),\n minor: ThresholdSchema.default(45),\n major: ThresholdSchema.default(60),\n })\n .default(() => ({ patch: 30, minor: 45, major: 60 })),\n })\n .default(() => ({\n enabled: false,\n registry: 'https://registry.npmjs.org',\n thresholds: { patch: 30, minor: 45, major: 60 },\n })),\n});\n\n// ── Derived types ──────────────────────────────────────────────────────────────\n\n/** Config as returned after parsing — all defaults applied, all fields required */\nexport type HermexConfig = z.infer<typeof HermexConfigSchema>;\n\n/** Config as accepted by the user — everything optional */\nexport type HermexConfigInput = z.input<typeof HermexConfigSchema>;\n\n// Sub-types derived from the output shape so they can never drift from the schema\nexport type RuleSeverity = z.infer<typeof RuleSeveritySchema>;\nexport type RuleConfig = z.infer<typeof RuleConfigSchema>;\nexport type EngineVersionRule = z.infer<typeof EngineVersionRuleSchema>;\nexport type PackagesConfig = HermexConfig['packages'];\nexport type VersusConfig = HermexConfig['versus'][number];\nexport type RulesConfig = HermexConfig['rules'];\nexport type OutputConfig = HermexConfig['output'];\nexport type ReleaseAgeConfig = HermexConfig['releaseAge'];\nexport type ReleaseAgeThresholds = HermexConfig['releaseAge']['thresholds'];\n","import { existsSync } from 'node:fs';\nimport { join, resolve } from 'node:path';\nimport { pathToFileURL } from 'node:url';\nimport { HermexConfigSchema } from './schema';\nimport type { HermexConfig } from './schema';\n\nexport async function loadConfig(\n cwd: string,\n explicitPath?: string,\n): Promise<HermexConfig> {\n const configPath = explicitPath\n ? resolve(explicitPath)\n : join(cwd, 'hermex.config.ts');\n\n if (explicitPath && !existsSync(configPath)) {\n throw new Error(`Config file not found: ${configPath}`);\n }\n\n if (existsSync(configPath)) {\n const mod = await import(pathToFileURL(configPath).href);\n return HermexConfigSchema.parse(mod.default ?? mod);\n }\n\n return HermexConfigSchema.parse({});\n}\n","import type { RegistryPackageInfo } from './types';\n\nexport async function fetchPackageInfo(\n name: string,\n registryUrl: string,\n authToken?: string,\n): Promise<RegistryPackageInfo | null> {\n const url = `${registryUrl.replace(/\\/$/, '')}/${encodeURIComponent(name).replace('%40', '@')}`;\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), 10_000);\n\n try {\n const headers: Record<string, string> = {\n Accept: 'application/json',\n };\n if (authToken) {\n headers['Authorization'] = `Bearer ${authToken}`;\n }\n\n const response = await fetch(url, {\n headers,\n signal: controller.signal,\n });\n\n clearTimeout(timeoutId);\n\n if (!response.ok) return null;\n\n const data = (await response.json()) as RegistryPackageInfo;\n return data;\n } catch {\n clearTimeout(timeoutId);\n return null;\n }\n}\n","import semver from 'semver';\nimport type { PackageDistribution } from '../utils/aggregator';\nimport type { ReleaseAgeConfig } from '../config/types';\nimport type {\n AvailableUpgrade,\n ReleaseAgeEntry,\n SemverBump,\n UpgradeLevel,\n} from './types';\nimport { fetchPackageInfo } from './client';\n\nconst CONCURRENCY = 8;\n\nfunction daysSince(dateStr: string): number {\n const ms = Date.now() - new Date(dateStr).getTime();\n return Math.floor(ms / (1000 * 60 * 60 * 24));\n}\n\nfunction classifyBump(installed: string, candidate: string): SemverBump | null {\n const diff = semver.diff(installed, candidate);\n if (!diff) return null;\n if (diff === 'patch' || diff === 'prepatch') return 'patch';\n if (diff === 'minor' || diff === 'preminor') return 'minor';\n if (diff === 'major' || diff === 'premajor') return 'major';\n return null;\n}\n\nfunction upgradeLevel(\n daysAgo: number,\n bump: SemverBump,\n thresholds: ReleaseAgeConfig['thresholds'],\n): UpgradeLevel | null {\n const threshold = thresholds[bump];\n if (threshold === false || threshold === undefined) return null;\n if (daysAgo > threshold) {\n // major bump past its threshold → mandatory, minor/patch → needs\n return bump === 'major' ? 'mandatory_upgrade' : 'needs_upgrade';\n }\n return null;\n}\n\nfunction computeReleaseAge(\n installedVersion: string,\n timeMap: Record<string, string>,\n deprecated: string | undefined,\n thresholds: ReleaseAgeConfig['thresholds'],\n): ReleaseAgeEntry {\n const upgrades: AvailableUpgrade[] = [];\n\n for (const [version, dateStr] of Object.entries(timeMap)) {\n if (version === 'created' || version === 'modified') continue;\n if (!semver.valid(version)) continue;\n if (semver.lte(version, installedVersion)) continue;\n\n const bump = classifyBump(installedVersion, version);\n if (!bump) continue;\n\n const daysAgo = daysSince(dateStr);\n const level = upgradeLevel(daysAgo, bump, thresholds);\n if (!level) continue;\n\n upgrades.push({\n version,\n releasedDaysAgo: daysAgo,\n semverBump: bump,\n level,\n });\n }\n\n // Keep only the oldest (most stable) release per bump level\n const worstPerBump = new Map<SemverBump, AvailableUpgrade>();\n for (const upgrade of upgrades) {\n const existing = worstPerBump.get(upgrade.semverBump);\n if (!existing || upgrade.releasedDaysAgo > existing.releasedDaysAgo) {\n worstPerBump.set(upgrade.semverBump, upgrade);\n }\n }\n\n const finalUpgrades = Array.from(worstPerBump.values()).sort(\n (a, b) => b.releasedDaysAgo - a.releasedDaysAgo,\n );\n\n const worstLevel: UpgradeLevel | null = finalUpgrades.some(\n (u) => u.level === 'mandatory_upgrade',\n )\n ? 'mandatory_upgrade'\n : finalUpgrades.length > 0\n ? 'needs_upgrade'\n : null;\n\n return {\n installedVersion,\n upgrades: finalUpgrades,\n worstLevel,\n deprecated,\n };\n}\n\nexport async function enrichWithReleaseAge(\n packages: PackageDistribution[],\n config: ReleaseAgeConfig,\n): Promise<{ enriched: PackageDistribution[]; skipped: number }> {\n const registryUrl = config.registry;\n const targets = packages.filter((p) => !p.internal && p.version);\n const enriched = [...packages];\n let skipped = 0;\n\n // Process in batches of CONCURRENCY\n for (let i = 0; i < targets.length; i += CONCURRENCY) {\n const batch = targets.slice(i, i + CONCURRENCY);\n const results = await Promise.all(\n batch.map(async (pkg) => {\n const info = await fetchPackageInfo(\n pkg.packageName,\n registryUrl,\n config.authToken,\n );\n if (!info || !info.time) {\n skipped++;\n return { pkg, entry: null };\n }\n\n const deprecated =\n info.versions?.[pkg.version!]?.deprecated ?? info.deprecated;\n\n const entry = computeReleaseAge(\n pkg.version!,\n info.time,\n typeof deprecated === 'string' ? deprecated : undefined,\n config.thresholds,\n );\n\n return { pkg, entry };\n }),\n );\n\n for (const { pkg, entry } of results) {\n if (!entry) continue;\n const idx = enriched.findIndex((p) => p.packageName === pkg.packageName);\n if (idx !== -1) {\n enriched[idx] = { ...enriched[idx], releaseAge: entry };\n }\n }\n }\n\n return { enriched, skipped };\n}\n","import { Command } from 'commander';\nimport ora from 'ora';\nimport chalk from 'chalk';\nimport { parseFile } from '../swc-parser';\nimport type { UsageReport } from '../swc-parser';\nimport type { ParseError } from '../swc-parser/types';\nimport { aggregateReports } from '../utils/aggregator';\nimport { printSummary } from '../utils/print-summary';\nimport { printDetails } from '../utils/print-details';\nimport { printComponents } from '../utils/print-components';\nimport { printPatterns } from '../utils/print-patterns';\nimport { printPackages } from '../utils/print-packages';\nimport { printVersus } from '../utils/print-versus';\nimport { printRules } from '../utils/print-rules';\nimport { printErrors } from '../utils/print-errors';\nimport { printJson } from '../utils/print-json';\nimport { findFiles } from '../utils/file-utils';\nimport { findAndParseLockfile } from '../lock-parser';\nimport { loadConfig } from '../config/loader';\nimport { evaluateRules } from '../rules/evaluator';\nimport { enrichWithReleaseAge } from '../npm-registry/enricher';\nimport type { HermexConfig } from '../config/types';\n\nexport function registerScanCommand(program: Command) {\n program\n .command('scan')\n .description('Scan and analyze local files')\n .option(\n '--config <path>',\n 'Path to hermex config file (overrides CWD discovery)',\n )\n .action(async (options: { config?: string }) => {\n const config = await loadConfig(process.cwd(), options.config);\n await executeScan(config);\n });\n}\n\nexport async function executeScan(config: HermexConfig) {\n const startTime = Date.now();\n const isJson = config.output.format === 'json';\n const spinner = ora({\n text: 'Parsing lockfile...',\n stream: isJson ? process.stderr : process.stdout,\n }).start();\n\n try {\n const lockfileResult = findAndParseLockfile(process.cwd());\n\n spinner.succeed(\n chalk.blue(\n `📦 Found ${lockfileResult.lockfileType} lockfile (supports: ${lockfileResult.supportedVersions.join(', ')}) - ${Object.keys(lockfileResult.versions).length} packages`,\n ),\n );\n\n spinner.start('Finding files...');\n const files = await findFiles(config.includes, config.excludes);\n\n if (files.length === 0) {\n spinner.fail(\n chalk.red(\n `No files found matching includes: ${config.includes.join(', ')}`,\n ),\n );\n return;\n }\n\n spinner.succeed(chalk.green(` Found ${files.length} files`));\n\n spinner.start('Analyzing files...');\n const reports: UsageReport[] = [];\n const parseErrors: ParseError[] = [];\n\n for (let i = 0; i < files.length; i++) {\n const file = files[i];\n spinner.text = `Analyzing files... (${i + 1}/${files.length})`;\n\n try {\n const report = parseFile(file);\n if (report) {\n reports.push(report);\n }\n } catch (error: any) {\n parseErrors.push({ file, message: error.message ?? String(error) });\n }\n }\n\n spinner.succeed(\n chalk.green(\n `Analysis complete! Analyzed ${reports.length}/${files.length} files`,\n ),\n );\n\n printErrors(parseErrors);\n\n const elapsedTime = (Date.now() - startTime) / 1000;\n\n const aggregated = aggregateReports(\n reports,\n lockfileResult.versions,\n config,\n lockfileResult.multiVersions,\n );\n\n const evaluatorViolations = evaluateRules(\n process.cwd(),\n config.rules,\n config.excludes,\n );\n aggregated.ruleViolations = [\n ...aggregated.ruleViolations,\n ...evaluatorViolations,\n ];\n\n if (config.releaseAge.enabled) {\n spinner.start('Fetching release age from registry...');\n const { enriched, skipped } = await enrichWithReleaseAge(\n aggregated.packageDistribution,\n config.releaseAge,\n );\n aggregated.packageDistribution = enriched;\n spinner.succeed(\n chalk.blue(\n `📅 Release age fetched${skipped > 0 ? chalk.gray(` (${skipped} packages skipped — registry unreachable or not found)`) : ''}`,\n ),\n );\n }\n\n if (isJson) {\n printJson(aggregated);\n } else {\n printScanResults(aggregated, config, elapsedTime);\n }\n } catch (error: any) {\n spinner.fail(chalk.red('Analysis failed: ' + error.message));\n console.error(error);\n process.exit(1);\n }\n}\n\nfunction printScanResults(\n aggregated: ReturnType<typeof aggregateReports>,\n config: HermexConfig,\n _elapsedTime: number,\n) {\n if (config.output.packages) {\n printPackages(aggregated, config.output.packages);\n }\n\n if (config.output.versus) {\n printVersus(aggregated);\n }\n\n if (config.output.rules) {\n printRules(aggregated);\n }\n\n if (config.output.details) {\n printDetails(aggregated);\n }\n\n if (config.output.components) {\n printComponents(aggregated, config.output.components);\n }\n\n if (config.output.patterns) {\n printPatterns(aggregated, config.output.patterns);\n }\n\n if (config.output.summary) {\n printSummary(aggregated);\n }\n}\n","","#!/usr/bin/env node\nimport { Command } from 'commander';\nimport { registerScanCommand } from './commands/scan';\nimport packageJson from '../package.json';\n\nexport const program = new Command();\n\nprogram\n .name('hermex')\n .description('Analyze React component usage patterns in your codebase')\n .version(packageJson.version);\n\nregisterScanCommand(program);\n\nprogram.parse(process.argv);\n"],"mappings":"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"}
|