@xylabs/ts-scripts-yarn3 7.4.27 → 7.4.28

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.
@@ -0,0 +1,250 @@
1
+ // src/actions/lintlint.ts
2
+ import { readFileSync, writeFileSync } from "fs";
3
+ import PATH from "path";
4
+ import chalk from "chalk";
5
+ import { findUp } from "find-up";
6
+ function parseRuleValue(value) {
7
+ if (typeof value === "string") {
8
+ return { level: value };
9
+ }
10
+ if (typeof value === "number") {
11
+ return { level: String(value) };
12
+ }
13
+ if (Array.isArray(value) && value.length > 0) {
14
+ return {
15
+ level: String(value[0]),
16
+ options: value.length > 1 ? value.slice(1) : void 0
17
+ };
18
+ }
19
+ return void 0;
20
+ }
21
+ function normalizeLevel(level) {
22
+ if (level === "0" || level === "off") return "off";
23
+ if (level === "1" || level === "warn") return "warn";
24
+ if (level === "2" || level === "error") return "error";
25
+ return level;
26
+ }
27
+ function rulesMatch(a, b) {
28
+ if (normalizeLevel(a.level) !== normalizeLevel(b.level)) return false;
29
+ return JSON.stringify(a.options) === JSON.stringify(b.options);
30
+ }
31
+ function formatRule(entry) {
32
+ if (entry.options) {
33
+ return JSON.stringify([entry.level, ...entry.options]);
34
+ }
35
+ return JSON.stringify([entry.level]);
36
+ }
37
+ function mergeRulesFromBlocks(blocks) {
38
+ const merged = /* @__PURE__ */ new Map();
39
+ for (const block of blocks) {
40
+ if (!block.rules) continue;
41
+ for (const [name, value] of Object.entries(block.rules)) {
42
+ const parsed = parseRuleValue(value);
43
+ if (parsed) merged.set(name, parsed);
44
+ }
45
+ }
46
+ return merged;
47
+ }
48
+ function detectSharedPackage(source) {
49
+ if (source.includes("@xylabs/eslint-config-react-flat")) return "@xylabs/eslint-config-react-flat";
50
+ if (source.includes("@xylabs/eslint-config-flat")) return "@xylabs/eslint-config-flat";
51
+ return void 0;
52
+ }
53
+ function extractLocalRuleBlocks(source) {
54
+ const blocks = [];
55
+ const ruleBlockRegex = /\{\s*(?:files\s*:\s*\[.*?\]\s*,\s*)?rules\s*:\s*\{([^}]*(?:\{[^}]*\}[^}]*)*)\}/g;
56
+ let match;
57
+ while ((match = ruleBlockRegex.exec(source)) !== null) {
58
+ blocks.push(match[1]);
59
+ }
60
+ return blocks;
61
+ }
62
+ function extractRulesFromSourceBlocks(blocks) {
63
+ const rules = /* @__PURE__ */ new Map();
64
+ for (const block of blocks) {
65
+ const ruleRegex = /['"]([^'"]+)['"]\s*:\s*(\[[\s\S]*?\](?=\s*,|\s*$))/gm;
66
+ let match;
67
+ while ((match = ruleRegex.exec(block)) !== null) {
68
+ rules.set(match[1], match[2]);
69
+ }
70
+ }
71
+ return rules;
72
+ }
73
+ async function resolveSharedConfig(configDir, sharedPkg) {
74
+ try {
75
+ const sharedModule = await import(sharedPkg);
76
+ const config = sharedModule.config ?? sharedModule.default;
77
+ if (Array.isArray(config)) return config;
78
+ return [];
79
+ } catch {
80
+ const distPath = PATH.resolve(configDir, "node_modules", sharedPkg, "dist", "node", "index.mjs");
81
+ try {
82
+ const sharedModule = await import(distPath);
83
+ const config = sharedModule.config ?? sharedModule.default;
84
+ if (Array.isArray(config)) return config;
85
+ } catch {
86
+ const neutralPath = PATH.resolve(configDir, "node_modules", sharedPkg, "dist", "neutral", "index.mjs");
87
+ const sharedModule = await import(neutralPath);
88
+ const config = sharedModule.config ?? sharedModule.default;
89
+ if (Array.isArray(config)) return config;
90
+ }
91
+ return [];
92
+ }
93
+ }
94
+ async function loadSharedRules(configDir, sharedPkg, verbose) {
95
+ const sharedBlocks = await resolveSharedConfig(configDir, sharedPkg);
96
+ const sharedRules = mergeRulesFromBlocks(sharedBlocks);
97
+ if (verbose) {
98
+ console.log(chalk.gray(`Shared config defines ${sharedRules.size} rules`));
99
+ }
100
+ if (sharedRules.size === 0) {
101
+ console.error(chalk.red("Could not load rules from shared config. Is it installed and built?"));
102
+ return void 0;
103
+ }
104
+ return sharedRules;
105
+ }
106
+ async function loadLocalRules(eslintConfigPath, source, verbose) {
107
+ const localModule = await import(eslintConfigPath);
108
+ const localConfig = localModule.default ?? localModule;
109
+ const localBlocks = Array.isArray(localConfig) ? localConfig : [localConfig];
110
+ const resolved = mergeRulesFromBlocks(localBlocks);
111
+ const localRuleBlocks = extractLocalRuleBlocks(source);
112
+ const explicit = extractRulesFromSourceBlocks(localRuleBlocks);
113
+ if (verbose) {
114
+ console.log(chalk.gray(`Local config has ${explicit.size} explicit rule setting(s)`));
115
+ }
116
+ return { explicit, resolved };
117
+ }
118
+ function compareRules(explicitRuleNames, allResolvedRules, sharedRules) {
119
+ const redundant = [];
120
+ const overrides = [];
121
+ const additions = [];
122
+ for (const ruleName of explicitRuleNames.keys()) {
123
+ const resolvedEntry = allResolvedRules.get(ruleName);
124
+ const sharedEntry = sharedRules.get(ruleName);
125
+ if (!resolvedEntry) continue;
126
+ if (!sharedEntry) {
127
+ additions.push({ local: resolvedEntry, rule: ruleName });
128
+ } else if (rulesMatch(resolvedEntry, sharedEntry)) {
129
+ redundant.push({
130
+ local: resolvedEntry,
131
+ rule: ruleName,
132
+ shared: sharedEntry
133
+ });
134
+ } else {
135
+ overrides.push({
136
+ local: resolvedEntry,
137
+ rule: ruleName,
138
+ shared: sharedEntry
139
+ });
140
+ }
141
+ }
142
+ return {
143
+ additions,
144
+ overrides,
145
+ redundant
146
+ };
147
+ }
148
+ function reportResults({
149
+ additions,
150
+ overrides,
151
+ redundant
152
+ }, verbose) {
153
+ if (redundant.length > 0) {
154
+ console.log(chalk.yellow(`
155
+ ${redundant.length} redundant rule(s) (same as shared config \u2014 can be removed):`));
156
+ for (const { rule, local } of redundant) {
157
+ console.log(chalk.yellow(` ${rule}: ${formatRule(local)}`));
158
+ }
159
+ }
160
+ if (overrides.length > 0) {
161
+ console.log(chalk.cyan(`
162
+ ${overrides.length} rule override(s) (different from shared config):`));
163
+ for (const {
164
+ rule,
165
+ local,
166
+ shared
167
+ } of overrides) {
168
+ console.log(chalk.cyan(` ${rule}:`));
169
+ console.log(chalk.gray(` shared: ${formatRule(shared)}`));
170
+ console.log(chalk.white(` local: ${formatRule(local)}`));
171
+ }
172
+ }
173
+ if (additions.length > 0 && verbose) {
174
+ console.log(chalk.gray(`
175
+ ${additions.length} local addition(s) (not in shared config):`));
176
+ for (const { rule, local } of additions) {
177
+ console.log(chalk.gray(` ${rule}: ${formatRule(local)}`));
178
+ }
179
+ }
180
+ if (redundant.length === 0 && overrides.length === 0) {
181
+ console.log(chalk.green("No redundant or overridden rules found"));
182
+ }
183
+ }
184
+ function fixRedundantRules(eslintConfigPath, source, redundant) {
185
+ let updated = source;
186
+ for (const { rule } of redundant) {
187
+ const escaped = rule.replaceAll("/", String.raw`\/`);
188
+ const pattern = new RegExp(String.raw`[ \t]*['"]${escaped}['"]\s*:\s*\[[^\]]*\],?[ \t]*\n?`, "g");
189
+ updated = updated.replace(pattern, "");
190
+ }
191
+ updated = updated.replaceAll(/\n{3,}/g, "\n\n");
192
+ if (updated !== source) {
193
+ writeFileSync(eslintConfigPath, updated, "utf8");
194
+ console.log(chalk.green(`
195
+ Fixed: removed ${redundant.length} redundant rule(s)`));
196
+ }
197
+ }
198
+ async function lintlint({ fix, verbose } = {}) {
199
+ const eslintConfigPath = await findUp("eslint.config.mjs");
200
+ if (!eslintConfigPath) {
201
+ console.error(chalk.red("No eslint.config.mjs found"));
202
+ return 1;
203
+ }
204
+ const configDir = PATH.dirname(eslintConfigPath);
205
+ if (verbose) {
206
+ console.log(chalk.gray(`Found config: ${eslintConfigPath}`));
207
+ }
208
+ const source = readFileSync(eslintConfigPath, "utf8");
209
+ const sharedPkg = detectSharedPackage(source);
210
+ if (!sharedPkg) {
211
+ console.log(chalk.yellow("No @xylabs/eslint-config-flat or @xylabs/eslint-config-react-flat imports found"));
212
+ return 0;
213
+ }
214
+ if (verbose) {
215
+ console.log(chalk.gray(`Shared package: ${sharedPkg}`));
216
+ }
217
+ const sharedRules = await loadSharedRules(configDir, sharedPkg, !!verbose);
218
+ if (!sharedRules) return 1;
219
+ const { explicit, resolved } = await loadLocalRules(eslintConfigPath, source, !!verbose);
220
+ const results = compareRules(explicit, resolved, sharedRules);
221
+ reportResults(results, !!verbose);
222
+ if (results.redundant.length > 0 && fix) {
223
+ fixRedundantRules(eslintConfigPath, source, results.redundant);
224
+ }
225
+ return results.redundant.length > 0 && !fix ? 1 : 0;
226
+ }
227
+
228
+ // src/xy/lint/lintlintCommand.ts
229
+ var lintlintCommand = {
230
+ command: "lintlint",
231
+ describe: "Lint Lint - Check for redundant or overridden ESLint rules vs shared config",
232
+ builder: (yargs) => {
233
+ return yargs.option("fix", {
234
+ default: false,
235
+ description: "Remove redundant rules from local config",
236
+ type: "boolean"
237
+ });
238
+ },
239
+ handler: async (argv) => {
240
+ if (argv.verbose) console.log("Lint Lint");
241
+ process.exitCode = await lintlint({
242
+ fix: argv.fix,
243
+ verbose: !!argv.verbose
244
+ });
245
+ }
246
+ };
247
+ export {
248
+ lintlintCommand
249
+ };
250
+ //# sourceMappingURL=lintlintCommand.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/actions/lintlint.ts","../../../src/xy/lint/lintlintCommand.ts"],"sourcesContent":["import { readFileSync, writeFileSync } from 'node:fs'\nimport PATH from 'node:path'\n\nimport chalk from 'chalk'\nimport { findUp } from 'find-up'\n\ninterface RuleEntry {\n level: string\n options?: unknown[]\n}\n\ninterface LintlintParams {\n fix?: boolean\n verbose?: boolean\n}\n\ninterface ConfigBlock {\n rules?: Record<string, unknown>\n}\n\ninterface RuleComparison {\n additions: Array<{ local: RuleEntry; rule: string }>\n overrides: Array<{ local: RuleEntry; rule: string; shared: RuleEntry }>\n redundant: Array<{ local: RuleEntry; rule: string; shared: RuleEntry }>\n}\n\nfunction parseRuleValue(value: unknown): RuleEntry | undefined {\n if (typeof value === 'string') {\n return { level: value }\n }\n if (typeof value === 'number') {\n return { level: String(value) }\n }\n if (Array.isArray(value) && value.length > 0) {\n return {\n level: String(value[0]),\n options: value.length > 1 ? value.slice(1) : undefined,\n }\n }\n return undefined\n}\n\nfunction normalizeLevel(level: string): string {\n if (level === '0' || level === 'off') return 'off'\n if (level === '1' || level === 'warn') return 'warn'\n if (level === '2' || level === 'error') return 'error'\n return level\n}\n\nfunction rulesMatch(a: RuleEntry, b: RuleEntry): boolean {\n if (normalizeLevel(a.level) !== normalizeLevel(b.level)) return false\n return JSON.stringify(a.options) === JSON.stringify(b.options)\n}\n\nfunction formatRule(entry: RuleEntry): string {\n if (entry.options) {\n return JSON.stringify([entry.level, ...entry.options])\n }\n return JSON.stringify([entry.level])\n}\n\nfunction mergeRulesFromBlocks(blocks: ConfigBlock[]): Map<string, RuleEntry> {\n const merged = new Map<string, RuleEntry>()\n for (const block of blocks) {\n if (!block.rules) continue\n for (const [name, value] of Object.entries(block.rules)) {\n const parsed = parseRuleValue(value)\n if (parsed) merged.set(name, parsed)\n }\n }\n return merged\n}\n\nfunction detectSharedPackage(source: string): string | undefined {\n if (source.includes('@xylabs/eslint-config-react-flat')) return '@xylabs/eslint-config-react-flat'\n if (source.includes('@xylabs/eslint-config-flat')) return '@xylabs/eslint-config-flat'\n return undefined\n}\n\nfunction extractLocalRuleBlocks(source: string): string[] {\n const blocks: string[] = []\n const ruleBlockRegex = /\\{\\s*(?:files\\s*:\\s*\\[.*?\\]\\s*,\\s*)?rules\\s*:\\s*\\{([^}]*(?:\\{[^}]*\\}[^}]*)*)\\}/g\n let match\n while ((match = ruleBlockRegex.exec(source)) !== null) {\n blocks.push(match[1])\n }\n return blocks\n}\n\nfunction extractRulesFromSourceBlocks(blocks: string[]): Map<string, string> {\n const rules = new Map<string, string>()\n for (const block of blocks) {\n const ruleRegex = /['\"]([^'\"]+)['\"]\\s*:\\s*(\\[[\\s\\S]*?\\](?=\\s*,|\\s*$))/gm\n let match\n while ((match = ruleRegex.exec(block)) !== null) {\n rules.set(match[1], match[2])\n }\n }\n return rules\n}\n\nasync function resolveSharedConfig(configDir: string, sharedPkg: string): Promise<ConfigBlock[]> {\n try {\n const sharedModule = await import(sharedPkg)\n const config = sharedModule.config ?? sharedModule.default\n if (Array.isArray(config)) return config as ConfigBlock[]\n return []\n } catch {\n const distPath = PATH.resolve(configDir, 'node_modules', sharedPkg, 'dist', 'node', 'index.mjs')\n try {\n const sharedModule = await import(distPath)\n const config = sharedModule.config ?? sharedModule.default\n if (Array.isArray(config)) return config as ConfigBlock[]\n } catch {\n const neutralPath = PATH.resolve(configDir, 'node_modules', sharedPkg, 'dist', 'neutral', 'index.mjs')\n const sharedModule = await import(neutralPath)\n const config = sharedModule.config ?? sharedModule.default\n if (Array.isArray(config)) return config as ConfigBlock[]\n }\n return []\n }\n}\n\nasync function loadSharedRules(configDir: string, sharedPkg: string, verbose: boolean): Promise<Map<string, RuleEntry> | undefined> {\n const sharedBlocks = await resolveSharedConfig(configDir, sharedPkg)\n const sharedRules = mergeRulesFromBlocks(sharedBlocks)\n\n if (verbose) {\n console.log(chalk.gray(`Shared config defines ${sharedRules.size} rules`))\n }\n\n if (sharedRules.size === 0) {\n console.error(chalk.red('Could not load rules from shared config. Is it installed and built?'))\n return undefined\n }\n\n return sharedRules\n}\n\nasync function loadLocalRules(eslintConfigPath: string, source: string, verbose: boolean): Promise<{ explicit: Map<string, string>; resolved: Map<string, RuleEntry> }> {\n const localModule = await import(eslintConfigPath)\n const localConfig = localModule.default ?? localModule\n const localBlocks: ConfigBlock[] = Array.isArray(localConfig) ? localConfig : [localConfig]\n const resolved = mergeRulesFromBlocks(localBlocks)\n\n const localRuleBlocks = extractLocalRuleBlocks(source)\n const explicit = extractRulesFromSourceBlocks(localRuleBlocks)\n\n if (verbose) {\n console.log(chalk.gray(`Local config has ${explicit.size} explicit rule setting(s)`))\n }\n\n return { explicit, resolved }\n}\n\nfunction compareRules(\n explicitRuleNames: Map<string, string>,\n allResolvedRules: Map<string, RuleEntry>,\n sharedRules: Map<string, RuleEntry>,\n): RuleComparison {\n const redundant: RuleComparison['redundant'] = []\n const overrides: RuleComparison['overrides'] = []\n const additions: RuleComparison['additions'] = []\n\n for (const ruleName of explicitRuleNames.keys()) {\n const resolvedEntry = allResolvedRules.get(ruleName)\n const sharedEntry = sharedRules.get(ruleName)\n\n if (!resolvedEntry) continue\n\n if (!sharedEntry) {\n additions.push({ local: resolvedEntry, rule: ruleName })\n } else if (rulesMatch(resolvedEntry, sharedEntry)) {\n redundant.push({\n local: resolvedEntry, rule: ruleName, shared: sharedEntry,\n })\n } else {\n overrides.push({\n local: resolvedEntry, rule: ruleName, shared: sharedEntry,\n })\n }\n }\n\n return {\n additions,\n overrides,\n redundant,\n }\n}\n\nfunction reportResults({\n additions, overrides, redundant,\n}: RuleComparison, verbose: boolean): void {\n if (redundant.length > 0) {\n console.log(chalk.yellow(`\\n${redundant.length} redundant rule(s) (same as shared config — can be removed):`))\n for (const { rule, local } of redundant) {\n console.log(chalk.yellow(` ${rule}: ${formatRule(local)}`))\n }\n }\n\n if (overrides.length > 0) {\n console.log(chalk.cyan(`\\n${overrides.length} rule override(s) (different from shared config):`))\n for (const {\n rule, local, shared,\n } of overrides) {\n console.log(chalk.cyan(` ${rule}:`))\n console.log(chalk.gray(` shared: ${formatRule(shared)}`))\n console.log(chalk.white(` local: ${formatRule(local)}`))\n }\n }\n\n if (additions.length > 0 && verbose) {\n console.log(chalk.gray(`\\n${additions.length} local addition(s) (not in shared config):`))\n for (const { rule, local } of additions) {\n console.log(chalk.gray(` ${rule}: ${formatRule(local)}`))\n }\n }\n\n if (redundant.length === 0 && overrides.length === 0) {\n console.log(chalk.green('No redundant or overridden rules found'))\n }\n}\n\nfunction fixRedundantRules(eslintConfigPath: string, source: string, redundant: RuleComparison['redundant']): void {\n let updated = source\n for (const { rule } of redundant) {\n const escaped = rule.replaceAll('/', String.raw`\\/`)\n const pattern = new RegExp(String.raw`[ \\t]*['\"]${escaped}['\"]\\s*:\\s*\\[[^\\]]*\\],?[ \\t]*\\n?`, 'g')\n updated = updated.replace(pattern, '')\n }\n updated = updated.replaceAll(/\\n{3,}/g, '\\n\\n')\n\n if (updated !== source) {\n writeFileSync(eslintConfigPath, updated, 'utf8')\n console.log(chalk.green(`\\nFixed: removed ${redundant.length} redundant rule(s)`))\n }\n}\n\nexport async function lintlint({ fix, verbose }: LintlintParams = {}): Promise<number> {\n const eslintConfigPath = await findUp('eslint.config.mjs')\n if (!eslintConfigPath) {\n console.error(chalk.red('No eslint.config.mjs found'))\n return 1\n }\n\n const configDir = PATH.dirname(eslintConfigPath)\n\n if (verbose) {\n console.log(chalk.gray(`Found config: ${eslintConfigPath}`))\n }\n\n const source = readFileSync(eslintConfigPath, 'utf8')\n const sharedPkg = detectSharedPackage(source)\n\n if (!sharedPkg) {\n console.log(chalk.yellow('No @xylabs/eslint-config-flat or @xylabs/eslint-config-react-flat imports found'))\n return 0\n }\n\n if (verbose) {\n console.log(chalk.gray(`Shared package: ${sharedPkg}`))\n }\n\n const sharedRules = await loadSharedRules(configDir, sharedPkg, !!verbose)\n if (!sharedRules) return 1\n\n const { explicit, resolved } = await loadLocalRules(eslintConfigPath, source, !!verbose)\n const results = compareRules(explicit, resolved, sharedRules)\n\n reportResults(results, !!verbose)\n\n if (results.redundant.length > 0 && fix) {\n fixRedundantRules(eslintConfigPath, source, results.redundant)\n }\n\n return results.redundant.length > 0 && !fix ? 1 : 0\n}\n","import type { CommandModule } from 'yargs'\n\nimport { lintlint } from '../../actions/index.ts'\n\nexport const lintlintCommand: CommandModule = {\n command: 'lintlint',\n describe: 'Lint Lint - Check for redundant or overridden ESLint rules vs shared config',\n builder: (yargs) => {\n return yargs.option('fix', {\n default: false,\n description: 'Remove redundant rules from local config',\n type: 'boolean',\n })\n },\n handler: async (argv) => {\n if (argv.verbose) console.log('Lint Lint')\n process.exitCode = await lintlint({\n fix: argv.fix as boolean,\n verbose: !!argv.verbose,\n })\n },\n}\n"],"mappings":"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","names":[]}