css-to-tailwind-react 0.3.4 ā 0.4.1
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.js +107 -24
- package/dist/cssParser.d.ts +6 -1
- package/dist/cssParser.js +56 -6
- package/dist/fileWriter.d.ts +11 -3
- package/dist/fileWriter.js +34 -39
- package/dist/index.d.ts +4 -2
- package/dist/index.js +11 -2
- package/dist/transformer.d.ts +6 -0
- package/dist/transformer.js +162 -59
- package/dist/utils/diff.d.ts +26 -0
- package/dist/utils/diff.js +197 -0
- package/dist/utils/logger.d.ts +2 -0
- package/dist/utils/logger.js +21 -7
- package/dist/utils/reporter.d.ts +50 -0
- package/dist/utils/reporter.js +215 -0
- package/package.json +1 -1
package/dist/transformer.js
CHANGED
|
@@ -4,37 +4,80 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.transformFiles = transformFiles;
|
|
7
|
+
exports.transformFilesDetailed = transformFilesDetailed;
|
|
7
8
|
const fs_1 = __importDefault(require("fs"));
|
|
8
9
|
const path_1 = __importDefault(require("path"));
|
|
9
10
|
const tailwindMapper_1 = require("./tailwindMapper");
|
|
10
11
|
const jsxParser_1 = require("./jsxParser");
|
|
11
12
|
const cssParser_1 = require("./cssParser");
|
|
12
|
-
const fileWriter_1 = require("./fileWriter");
|
|
13
13
|
const logger_1 = require("./utils/logger");
|
|
14
14
|
const breakpointResolver_1 = require("./utils/breakpointResolver");
|
|
15
15
|
const variantAssembler_1 = require("./utils/variantAssembler");
|
|
16
16
|
const jsxDescendantTransformer_1 = require("./jsxDescendantTransformer");
|
|
17
17
|
const conflictResolver_1 = require("./utils/conflictResolver");
|
|
18
|
+
const variableRegistry_1 = require("./utils/variableRegistry");
|
|
18
19
|
async function transformFiles(files, options) {
|
|
19
|
-
const
|
|
20
|
+
const detailed = await transformFilesDetailed(files, options);
|
|
21
|
+
return {
|
|
22
|
+
filesScanned: detailed.stats.filesScanned,
|
|
23
|
+
filesModified: detailed.stats.filesModified,
|
|
24
|
+
stylesConverted: detailed.stats.utilitiesGenerated,
|
|
25
|
+
classesReplaced: detailed.stats.classesReplaced,
|
|
26
|
+
warnings: detailed.stats.warnings
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
async function transformFilesDetailed(files, options) {
|
|
30
|
+
const stats = {
|
|
20
31
|
filesScanned: files.length,
|
|
21
32
|
filesModified: 0,
|
|
22
|
-
|
|
33
|
+
filesUnchanged: 0,
|
|
34
|
+
filesWithError: 0,
|
|
35
|
+
utilitiesGenerated: 0,
|
|
23
36
|
classesReplaced: 0,
|
|
37
|
+
conflictsResolved: 0,
|
|
38
|
+
unsupportedSelectors: 0,
|
|
39
|
+
errors: 0,
|
|
24
40
|
warnings: 0
|
|
25
41
|
};
|
|
42
|
+
const fileResults = [];
|
|
26
43
|
const mapper = new tailwindMapper_1.TailwindMapper(options.tailwindConfig || {});
|
|
27
44
|
const jsxParser = new jsxParser_1.JSXParser(mapper);
|
|
28
45
|
const screens = options.tailwindConfig?.theme?.screens;
|
|
29
|
-
const
|
|
30
|
-
const
|
|
46
|
+
const sharedVariableRegistry = new variableRegistry_1.VariableRegistry();
|
|
47
|
+
const cssParser = new cssParser_1.CSSParser(mapper, screens, sharedVariableRegistry);
|
|
31
48
|
(0, breakpointResolver_1.clearBreakpointCache)();
|
|
32
49
|
const cssClassMap = {};
|
|
33
50
|
const allDescendantRules = [];
|
|
51
|
+
const cssFiles = files.filter(f => f.type === 'css');
|
|
52
|
+
const jsxFiles = files.filter(f => f.type === 'jsx');
|
|
53
|
+
logger_1.logger.info('\nš Phase 0: Collecting CSS variables from all files...');
|
|
54
|
+
if (!options.skipExternal) {
|
|
55
|
+
for (const file of cssFiles) {
|
|
56
|
+
try {
|
|
57
|
+
const content = fs_1.default.readFileSync(file.path, 'utf-8');
|
|
58
|
+
await cssParser.collectVariablesOnly(content, file.path);
|
|
59
|
+
}
|
|
60
|
+
catch (error) {
|
|
61
|
+
logger_1.logger.warn(`Failed to collect variables from ${file.path}: ${error}`);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
for (const file of jsxFiles) {
|
|
65
|
+
if (options.skipInternal)
|
|
66
|
+
continue;
|
|
67
|
+
try {
|
|
68
|
+
const content = fs_1.default.readFileSync(file.path, 'utf-8');
|
|
69
|
+
await cssParser.collectVariablesFromInternalCSS(content, file.path);
|
|
70
|
+
}
|
|
71
|
+
catch (error) {
|
|
72
|
+
logger_1.logger.warn(`Failed to collect internal CSS variables from ${file.path}: ${error}`);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
logger_1.logger.verbose(`Collected ${sharedVariableRegistry.getRegisteredVariables().length} unique CSS variables`);
|
|
76
|
+
}
|
|
77
|
+
logger_1.logger.info('\nš Phase 1: Analyzing CSS files...');
|
|
34
78
|
const cssFileResults = new Map();
|
|
35
|
-
logger_1.logger.info('\nš Phase 1: Analyzing files...');
|
|
36
79
|
if (!options.skipExternal) {
|
|
37
|
-
for (const file of
|
|
80
|
+
for (const file of cssFiles) {
|
|
38
81
|
try {
|
|
39
82
|
const content = fs_1.default.readFileSync(file.path, 'utf-8');
|
|
40
83
|
const result = await cssParser.parse(content, file.path);
|
|
@@ -46,7 +89,7 @@ async function transformFiles(files, options) {
|
|
|
46
89
|
if (rule.isDescendant) {
|
|
47
90
|
if (rule.convertedClasses.length > 0) {
|
|
48
91
|
allDescendantRules.push(rule);
|
|
49
|
-
|
|
92
|
+
stats.utilitiesGenerated += rule.declarations.length;
|
|
50
93
|
}
|
|
51
94
|
}
|
|
52
95
|
else if (rule.className && rule.convertedClasses.length > 0) {
|
|
@@ -58,23 +101,25 @@ async function transformFiles(files, options) {
|
|
|
58
101
|
cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);
|
|
59
102
|
}
|
|
60
103
|
if (rule.fullyConverted) {
|
|
61
|
-
|
|
104
|
+
stats.utilitiesGenerated += rule.declarations.length;
|
|
62
105
|
}
|
|
63
106
|
else {
|
|
64
|
-
|
|
107
|
+
stats.utilitiesGenerated += rule.convertedClasses.length;
|
|
65
108
|
logger_1.logger.verbose(` Rule .${rule.className}: partial conversion (${rule.convertedClasses.length}/${rule.declarations.length} declarations)`);
|
|
66
109
|
}
|
|
67
110
|
}
|
|
68
111
|
});
|
|
69
112
|
cssFileResults.set(file.path, {
|
|
113
|
+
path: file.path,
|
|
70
114
|
content,
|
|
71
115
|
newContent: result.css,
|
|
72
116
|
rules: result.rules,
|
|
73
117
|
canDelete: result.canDelete,
|
|
74
118
|
hasChanges: result.hasChanges,
|
|
75
|
-
fullyConvertible
|
|
119
|
+
fullyConvertible,
|
|
120
|
+
warnings: result.warnings
|
|
76
121
|
});
|
|
77
|
-
|
|
122
|
+
stats.warnings += result.warnings.length;
|
|
78
123
|
logger_1.logger.verbose(`Analyzed ${file.path}:`);
|
|
79
124
|
logger_1.logger.verbose(` - Total rules: ${totalRules}`);
|
|
80
125
|
logger_1.logger.verbose(` - Fully converted rules: ${fullyConvertedRules}`);
|
|
@@ -85,26 +130,41 @@ async function transformFiles(files, options) {
|
|
|
85
130
|
});
|
|
86
131
|
}
|
|
87
132
|
catch (error) {
|
|
133
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
88
134
|
logger_1.logger.error(`Failed to analyze ${file.path}:`, error);
|
|
89
|
-
|
|
135
|
+
cssFileResults.set(file.path, {
|
|
136
|
+
path: file.path,
|
|
137
|
+
content: '',
|
|
138
|
+
newContent: '',
|
|
139
|
+
rules: [],
|
|
140
|
+
canDelete: false,
|
|
141
|
+
hasChanges: false,
|
|
142
|
+
fullyConvertible: false,
|
|
143
|
+
warnings: [],
|
|
144
|
+
error: errorMessage
|
|
145
|
+
});
|
|
146
|
+
stats.errors++;
|
|
147
|
+
stats.warnings++;
|
|
90
148
|
}
|
|
91
149
|
}
|
|
92
150
|
}
|
|
93
151
|
logger_1.logger.info('\nāļø Phase 2: Transforming React components...');
|
|
94
152
|
const jsxFileResults = new Map();
|
|
95
|
-
for (const file of
|
|
153
|
+
for (const file of jsxFiles) {
|
|
96
154
|
try {
|
|
97
155
|
let content = fs_1.default.readFileSync(file.path, 'utf-8');
|
|
98
156
|
const originalContent = content;
|
|
99
157
|
let hasChanges = false;
|
|
100
158
|
let fileWarnings = [];
|
|
159
|
+
let utilitiesGenerated = 0;
|
|
160
|
+
let classesReplaced = 0;
|
|
101
161
|
if (!options.skipInline) {
|
|
102
162
|
try {
|
|
103
163
|
const jsxResult = jsxParser.parse(content, file.path);
|
|
104
164
|
if (jsxResult.hasChanges) {
|
|
105
165
|
content = jsxResult.code;
|
|
106
166
|
hasChanges = true;
|
|
107
|
-
|
|
167
|
+
utilitiesGenerated += jsxResult.transformations.reduce((sum, t) => sum + t.classes.length, 0);
|
|
108
168
|
fileWarnings.push(...jsxResult.warnings);
|
|
109
169
|
}
|
|
110
170
|
}
|
|
@@ -123,7 +183,7 @@ async function transformFiles(files, options) {
|
|
|
123
183
|
if (rule.isDescendant) {
|
|
124
184
|
if (rule.convertedClasses.length > 0) {
|
|
125
185
|
allDescendantRules.push(rule);
|
|
126
|
-
|
|
186
|
+
utilitiesGenerated += rule.declarations.length;
|
|
127
187
|
}
|
|
128
188
|
}
|
|
129
189
|
else if (rule.convertedClasses.length > 0 && rule.className) {
|
|
@@ -134,7 +194,7 @@ async function transformFiles(files, options) {
|
|
|
134
194
|
else {
|
|
135
195
|
cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);
|
|
136
196
|
}
|
|
137
|
-
|
|
197
|
+
utilitiesGenerated += rule.declarations.length;
|
|
138
198
|
}
|
|
139
199
|
});
|
|
140
200
|
fileWarnings.push(...internalResult.warnings);
|
|
@@ -146,30 +206,48 @@ async function transformFiles(files, options) {
|
|
|
146
206
|
}
|
|
147
207
|
}
|
|
148
208
|
jsxFileResults.set(file.path, {
|
|
209
|
+
path: file.path,
|
|
149
210
|
content: originalContent,
|
|
150
211
|
newContent: content,
|
|
151
|
-
hasChanges
|
|
212
|
+
hasChanges,
|
|
213
|
+
warnings: fileWarnings,
|
|
214
|
+
utilitiesGenerated,
|
|
215
|
+
classesReplaced
|
|
152
216
|
});
|
|
153
|
-
|
|
217
|
+
stats.warnings += fileWarnings.length;
|
|
154
218
|
fileWarnings.forEach(warning => {
|
|
155
219
|
logger_1.logger.verbose(`ā ļø ${file.path}: ${warning}`);
|
|
156
220
|
});
|
|
157
221
|
}
|
|
158
222
|
catch (error) {
|
|
223
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
159
224
|
logger_1.logger.error(`Failed to process ${file.path}:`, error);
|
|
160
|
-
|
|
225
|
+
jsxFileResults.set(file.path, {
|
|
226
|
+
path: file.path,
|
|
227
|
+
content: '',
|
|
228
|
+
newContent: '',
|
|
229
|
+
hasChanges: false,
|
|
230
|
+
warnings: [],
|
|
231
|
+
utilitiesGenerated: 0,
|
|
232
|
+
classesReplaced: 0,
|
|
233
|
+
error: errorMessage
|
|
234
|
+
});
|
|
235
|
+
stats.errors++;
|
|
161
236
|
}
|
|
162
237
|
}
|
|
163
238
|
if (Object.keys(cssClassMap).length > 0) {
|
|
164
239
|
logger_1.logger.info('\nš Phase 3: Replacing className references...');
|
|
165
240
|
for (const [filePath, fileResult] of jsxFileResults) {
|
|
241
|
+
if (fileResult.error)
|
|
242
|
+
continue;
|
|
166
243
|
let content = fileResult.newContent;
|
|
167
244
|
let hasChanges = fileResult.hasChanges;
|
|
168
245
|
const replacementResult = replaceClassNameReferences(content, cssClassMap);
|
|
169
246
|
if (replacementResult.hasChanges) {
|
|
170
247
|
content = replacementResult.code;
|
|
171
248
|
hasChanges = true;
|
|
172
|
-
|
|
249
|
+
fileResult.classesReplaced += replacementResult.replacements;
|
|
250
|
+
stats.classesReplaced += replacementResult.replacements;
|
|
173
251
|
logger_1.logger.verbose(`Replaced ${replacementResult.replacements} class references in ${path_1.default.basename(filePath)}`);
|
|
174
252
|
}
|
|
175
253
|
jsxFileResults.set(filePath, {
|
|
@@ -182,17 +260,20 @@ async function transformFiles(files, options) {
|
|
|
182
260
|
if (allDescendantRules.length > 0) {
|
|
183
261
|
logger_1.logger.info('\nš³ Phase 3.5: Applying descendant selector rules...');
|
|
184
262
|
for (const [filePath, fileResult] of jsxFileResults) {
|
|
263
|
+
if (fileResult.error)
|
|
264
|
+
continue;
|
|
185
265
|
let content = fileResult.newContent;
|
|
186
266
|
let hasChanges = fileResult.hasChanges;
|
|
187
267
|
const descendantResult = (0, jsxDescendantTransformer_1.transformDescendantSelectors)(content, allDescendantRules);
|
|
188
268
|
if (descendantResult.hasChanges) {
|
|
189
269
|
content = descendantResult.code;
|
|
190
270
|
hasChanges = true;
|
|
191
|
-
|
|
271
|
+
fileResult.classesReplaced += descendantResult.transformations;
|
|
272
|
+
stats.classesReplaced += descendantResult.transformations;
|
|
192
273
|
logger_1.logger.verbose(`Applied ${descendantResult.transformations} descendant transformations in ${path_1.default.basename(filePath)}`);
|
|
193
274
|
}
|
|
194
275
|
if (descendantResult.warnings.length > 0) {
|
|
195
|
-
|
|
276
|
+
stats.warnings += descendantResult.warnings.length;
|
|
196
277
|
descendantResult.warnings.forEach(warning => {
|
|
197
278
|
logger_1.logger.verbose(`ā ļø ${filePath}: ${warning}`);
|
|
198
279
|
});
|
|
@@ -204,47 +285,69 @@ async function transformFiles(files, options) {
|
|
|
204
285
|
});
|
|
205
286
|
}
|
|
206
287
|
}
|
|
207
|
-
logger_1.logger.info('\nš¾ Phase 4: Writing changes...');
|
|
208
288
|
for (const [filePath, fileResult] of jsxFileResults) {
|
|
209
|
-
if (fileResult.
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
289
|
+
if (fileResult.error) {
|
|
290
|
+
fileResults.push({
|
|
291
|
+
filePath,
|
|
292
|
+
originalContent: fileResult.content,
|
|
293
|
+
newContent: fileResult.newContent,
|
|
294
|
+
hasChanges: false,
|
|
295
|
+
status: 'error',
|
|
296
|
+
error: fileResult.error
|
|
297
|
+
});
|
|
298
|
+
stats.filesWithError++;
|
|
299
|
+
continue;
|
|
300
|
+
}
|
|
301
|
+
const hasChanges = fileResult.newContent !== fileResult.content;
|
|
302
|
+
fileResults.push({
|
|
303
|
+
filePath,
|
|
304
|
+
originalContent: fileResult.content,
|
|
305
|
+
newContent: fileResult.newContent,
|
|
306
|
+
hasChanges,
|
|
307
|
+
status: hasChanges ? 'modified' : 'unchanged',
|
|
308
|
+
transformations: {
|
|
309
|
+
utilitiesGenerated: fileResult.utilitiesGenerated,
|
|
310
|
+
classesReplaced: fileResult.classesReplaced,
|
|
311
|
+
conflictsResolved: 0
|
|
213
312
|
}
|
|
313
|
+
});
|
|
314
|
+
if (hasChanges) {
|
|
315
|
+
stats.filesModified++;
|
|
316
|
+
}
|
|
317
|
+
else {
|
|
318
|
+
stats.filesUnchanged++;
|
|
214
319
|
}
|
|
215
320
|
}
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
logger_1.logger.info(`š ${path_1.default.basename(filePath)}: converted ${convertedCount}/${totalCount} rules (unconverted properties kept)`);
|
|
243
|
-
}
|
|
244
|
-
}
|
|
321
|
+
for (const [filePath, fileResult] of cssFileResults) {
|
|
322
|
+
if (fileResult.error) {
|
|
323
|
+
fileResults.push({
|
|
324
|
+
filePath,
|
|
325
|
+
originalContent: fileResult.content,
|
|
326
|
+
newContent: fileResult.newContent,
|
|
327
|
+
hasChanges: false,
|
|
328
|
+
status: 'error',
|
|
329
|
+
error: fileResult.error
|
|
330
|
+
});
|
|
331
|
+
stats.filesWithError++;
|
|
332
|
+
continue;
|
|
333
|
+
}
|
|
334
|
+
const hasChanges = fileResult.hasChanges && fileResult.newContent !== fileResult.content;
|
|
335
|
+
fileResults.push({
|
|
336
|
+
filePath,
|
|
337
|
+
originalContent: fileResult.content,
|
|
338
|
+
newContent: fileResult.newContent,
|
|
339
|
+
hasChanges,
|
|
340
|
+
status: hasChanges ? 'modified' : 'unchanged'
|
|
341
|
+
});
|
|
342
|
+
if (hasChanges) {
|
|
343
|
+
stats.filesModified++;
|
|
344
|
+
}
|
|
345
|
+
else {
|
|
346
|
+
stats.filesUnchanged++;
|
|
245
347
|
}
|
|
246
348
|
}
|
|
247
|
-
|
|
349
|
+
stats.utilitiesGenerated = stats.classesReplaced + stats.utilitiesGenerated;
|
|
350
|
+
return { fileResults, stats };
|
|
248
351
|
}
|
|
249
352
|
function buildClassInfoFromRule(rule, sourceFile) {
|
|
250
353
|
return {
|
|
@@ -336,4 +439,4 @@ function replaceClassNameReferences(code, classMap) {
|
|
|
336
439
|
});
|
|
337
440
|
return { code: modifiedCode, hasChanges, replacements };
|
|
338
441
|
}
|
|
339
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transformer.js","sourceRoot":"","sources":["../src/transformer.ts"],"names":[],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport { ScannedFile } from './scanner';\nimport { TailwindMapper } from './tailwindMapper';\nimport { JSXParser } from './jsxParser';\nimport { CSSParser, CSSRule, UtilityWithVariant } from './cssParser';\nimport { FileWriter } from './fileWriter';\nimport { TailwindConfig } from './utils/config';\nimport { logger } from './utils/logger';\nimport { clearBreakpointCache } from './utils/breakpointResolver';\nimport { \n  assembleUtilities, \n  mergeUtilities,\n  normalizeVariantOrder \n} from './utils/variantAssembler';\nimport { transformDescendantSelectors } from './jsxDescendantTransformer';\nimport { \n  UtilityWithMeta, \n  ResolvedUtility, \n  resolveConflicts, \n  resolvedUtilitiesToStrings \n} from './utils/conflictResolver';\nimport { Specificity, ZERO_SPECIFICITY } from './utils/specificityCalculator';\n\nexport interface TransformOptions {\n  dryRun: boolean;\n  deleteCss: boolean;\n  skipExternal: boolean;\n  skipInline: boolean;\n  skipInternal: boolean;\n  tailwindConfig: TailwindConfig | null;\n  projectRoot: string;\n}\n\nexport interface TransformResults {\n  filesScanned: number;\n  filesModified: number;\n  stylesConverted: number;\n  classesReplaced: number;\n  warnings: number;\n}\n\ninterface ClassInfo {\n  utilities: UtilityWithMeta[];\n  sourceFile: string;\n  fullyConvertible: boolean;\n}\n\ninterface CSSClassMap {\n  [className: string]: ClassInfo;\n}\n\ninterface CollectedRules {\n  simpleRules: CSSRule[];\n  descendantRules: CSSRule[];\n}\n\nexport async function transformFiles(\n  files: ScannedFile[],\n  options: TransformOptions\n): Promise<TransformResults> {\n  const results: TransformResults = {\n    filesScanned: files.length,\n    filesModified: 0,\n    stylesConverted: 0,\n    classesReplaced: 0,\n    warnings: 0\n  };\n\n  const mapper = new TailwindMapper(options.tailwindConfig || {});\n  const jsxParser = new JSXParser(mapper);\n  const screens = options.tailwindConfig?.theme?.screens;\n  const cssParser = new CSSParser(mapper, screens);\n  const fileWriter = new FileWriter({ dryRun: options.dryRun });\n\n  clearBreakpointCache();\n\n  const cssClassMap: CSSClassMap = {};\n  const allDescendantRules: CSSRule[] = [];\n  const cssFileResults: Map<string, {\n    content: string;\n    newContent: string;\n    rules: CSSRule[];\n    canDelete: boolean;\n    hasChanges: boolean;\n    fullyConvertible: boolean;\n  }> = new Map();\n\n  logger.info('\\n🔍 Phase 1: Analyzing files...');\n\n  if (!options.skipExternal) {\n    for (const file of files.filter(f => f.type === 'css')) {\n      try {\n        const content = fs.readFileSync(file.path, 'utf-8');\n        const result = await cssParser.parse(content, file.path);\n\n        const totalRules = result.rules.length;\n        const fullyConvertedRules = result.rules.filter(r => r.fullyConverted).length;\n        const partiallyConvertedRules = result.rules.filter(r => r.partialConversion).length;\n        const fullyConvertible = totalRules > 0 && totalRules === fullyConvertedRules && partiallyConvertedRules === 0;\n\n        result.rules.forEach(rule => {\n          if (rule.isDescendant) {\n            if (rule.convertedClasses.length > 0) {\n              allDescendantRules.push(rule);\n              results.stylesConverted += rule.declarations.length;\n            }\n          } else if (rule.className && rule.convertedClasses.length > 0) {\n            const existing = cssClassMap[rule.className];\n            if (existing) {\n              mergeRuleIntoClassInfo(existing, rule);\n            } else {\n              cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);\n            }\n            if (rule.fullyConverted) {\n              results.stylesConverted += rule.declarations.length;\n            } else {\n              results.stylesConverted += rule.convertedClasses.length;\n              logger.verbose(`  Rule .${rule.className}: partial conversion (${rule.convertedClasses.length}/${rule.declarations.length} declarations)`);\n            }\n          }\n        });\n\n        cssFileResults.set(file.path, {\n          content,\n          newContent: result.css,\n          rules: result.rules,\n          canDelete: result.canDelete,\n          hasChanges: result.hasChanges,\n          fullyConvertible\n        });\n\n        results.warnings += result.warnings.length;\n\n        logger.verbose(`Analyzed ${file.path}:`);\n        logger.verbose(`  - Total rules: ${totalRules}`);\n        logger.verbose(`  - Fully converted rules: ${fullyConvertedRules}`);\n        logger.verbose(`  - Partially converted rules: ${partiallyConvertedRules}`);\n        logger.verbose(`  - Fully convertible: ${fullyConvertible}`);\n\n        result.warnings.forEach(warning => {\n          logger.verbose(`⚠️  ${file.path}: ${warning}`);\n        });\n\n      } catch (error) {\n        logger.error(`Failed to analyze ${file.path}:`, error);\n        results.warnings++;\n      }\n    }\n  }\n\n  logger.info('\\n⚛️  Phase 2: Transforming React components...');\n\n  const jsxFileResults: Map<string, {\n    content: string;\n    newContent: string;\n    hasChanges: boolean;\n  }> = new Map();\n\n  for (const file of files.filter(f => f.type === 'jsx')) {\n    try {\n      let content = fs.readFileSync(file.path, 'utf-8');\n      const originalContent = content;\n      let hasChanges = false;\n      let fileWarnings: string[] = [];\n\n      if (!options.skipInline) {\n        try {\n          const jsxResult = jsxParser.parse(content, file.path);\n          \n          if (jsxResult.hasChanges) {\n            content = jsxResult.code;\n            hasChanges = true;\n            results.stylesConverted += jsxResult.transformations.reduce(\n              (sum, t) => sum + t.classes.length, 0\n            );\n            fileWarnings.push(...jsxResult.warnings);\n          }\n        } catch (error) {\n          logger.warn(`Failed to parse JSX inline styles in ${file.path}: ${error}`);\n          fileWarnings.push(`JSX parse error: ${error}`);\n        }\n      }\n\n      if (!options.skipInternal) {\n        try {\n          const internalResult = await cssParser.parseInternalCSS(content, file.path);\n          \n          if (internalResult.hasChanges) {\n            content = internalResult.html;\n            hasChanges = true;\n            \n            internalResult.rules.forEach(rule => {\n              if (rule.isDescendant) {\n                if (rule.convertedClasses.length > 0) {\n                  allDescendantRules.push(rule);\n                  results.stylesConverted += rule.declarations.length;\n                }\n              } else if (rule.convertedClasses.length > 0 && rule.className) {\n                const existing = cssClassMap[rule.className];\n                if (existing) {\n                  mergeRuleIntoClassInfo(existing, rule);\n                } else {\n                  cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);\n                }\n                results.stylesConverted += rule.declarations.length;\n              }\n            });\n            \n            fileWarnings.push(...internalResult.warnings);\n          }\n        } catch (error) {\n          logger.warn(`Failed to parse internal CSS in ${file.path}: ${error}`);\n          fileWarnings.push(`Internal CSS parse error: ${error}`);\n        }\n      }\n\n      jsxFileResults.set(file.path, {\n        content: originalContent,\n        newContent: content,\n        hasChanges\n      });\n\n      results.warnings += fileWarnings.length;\n\n      fileWarnings.forEach(warning => {\n        logger.verbose(`⚠️  ${file.path}: ${warning}`);\n      });\n\n    } catch (error) {\n      logger.error(`Failed to process ${file.path}:`, error);\n      results.warnings++;\n    }\n  }\n\n  if (Object.keys(cssClassMap).length > 0) {\n    logger.info('\\n🔄 Phase 3: Replacing className references...');\n\n    for (const [filePath, fileResult] of jsxFileResults) {\n      let content = fileResult.newContent;\n      let hasChanges = fileResult.hasChanges;\n\n      const replacementResult = replaceClassNameReferences(content, cssClassMap);\n      if (replacementResult.hasChanges) {\n        content = replacementResult.code;\n        hasChanges = true;\n        results.classesReplaced += replacementResult.replacements;\n        \n        logger.verbose(`Replaced ${replacementResult.replacements} class references in ${path.basename(filePath)}`);\n      }\n\n      jsxFileResults.set(filePath, {\n        ...fileResult,\n        newContent: content,\n        hasChanges\n      });\n    }\n  }\n\n  if (allDescendantRules.length > 0) {\n    logger.info('\\n🌳 Phase 3.5: Applying descendant selector rules...');\n\n    for (const [filePath, fileResult] of jsxFileResults) {\n      let content = fileResult.newContent;\n      let hasChanges = fileResult.hasChanges;\n\n      const descendantResult = transformDescendantSelectors(content, allDescendantRules);\n      if (descendantResult.hasChanges) {\n        content = descendantResult.code;\n        hasChanges = true;\n        results.classesReplaced += descendantResult.transformations;\n        \n        logger.verbose(`Applied ${descendantResult.transformations} descendant transformations in ${path.basename(filePath)}`);\n      }\n\n      if (descendantResult.warnings.length > 0) {\n        results.warnings += descendantResult.warnings.length;\n        descendantResult.warnings.forEach(warning => {\n          logger.verbose(`⚠️  ${filePath}: ${warning}`);\n        });\n      }\n\n      jsxFileResults.set(filePath, {\n        ...fileResult,\n        newContent: content,\n        hasChanges\n      });\n    }\n  }\n\n  logger.info('\\n💾 Phase 4: Writing changes...');\n\n  for (const [filePath, fileResult] of jsxFileResults) {\n    if (fileResult.hasChanges) {\n      const success = await fileWriter.writeFile(filePath, fileResult.newContent, fileResult.content);\n      if (success) {\n        results.filesModified++;\n      }\n    }\n  }\n\n  if (!options.skipExternal) {\n    for (const [filePath, fileResult] of cssFileResults) {\n      if (!fileResult.hasChanges) continue;\n\n      if (fileResult.canDelete && options.deleteCss) {\n        const success = await fileWriter.deleteFile(filePath);\n        if (success) {\n          results.filesModified++;\n          logger.info(`🗑️  Deleted ${path.basename(filePath)} (all rules converted)`);\n        }\n      } else if (fileResult.canDelete && !options.deleteCss) {\n        logger.info(`ℹ️  ${path.basename(filePath)} is now empty (use --delete-css to remove)`);\n      } else if (fileResult.fullyConvertible) {\n        const success = await fileWriter.writeFile(filePath, fileResult.newContent, fileResult.content);\n        if (success) {\n          results.filesModified++;\n        }\n      } else {\n        const success = await fileWriter.writeFile(filePath, fileResult.newContent, fileResult.content);\n        if (success) {\n          results.filesModified++;\n          const convertedCount = fileResult.rules.filter(r => r.convertedClasses.length > 0).length;\n          const totalCount = fileResult.rules.length;\n          logger.info(`📝 ${path.basename(filePath)}: converted ${convertedCount}/${totalCount} rules (unconverted properties kept)`);\n        }\n      }\n    }\n  }\n\n  return results;\n}\n\nfunction buildClassInfoFromRule(rule: CSSRule, sourceFile: string): ClassInfo {\n  return {\n    utilities: rule.utilities.map(u => ({\n      value: u.value,\n      variants: normalizeVariantOrder([...u.variants]),\n      cssProperty: u.cssProperty,\n      specificity: u.specificity,\n      sourceOrder: u.sourceOrder,\n      originalSelector: rule.selector\n    })),\n    sourceFile,\n    fullyConvertible: rule.fullyConverted\n  };\n}\n\nfunction mergeRuleIntoClassInfo(info: ClassInfo, rule: CSSRule): void {\n  for (const utility of rule.utilities) {\n    const utilityWithMeta: UtilityWithMeta = {\n      value: utility.value,\n      variants: normalizeVariantOrder([...utility.variants]),\n      cssProperty: utility.cssProperty,\n      specificity: utility.specificity,\n      sourceOrder: utility.sourceOrder,\n      originalSelector: rule.selector\n    };\n    \n    info.utilities.push(utilityWithMeta);\n  }\n}\n\nfunction assembleTailwindClasses(info: ClassInfo): string {\n  const { resolved } = resolveConflicts(info.utilities, false);\n  return resolvedUtilitiesToStrings(resolved).join(' ');\n}\n\nfunction replaceClassNameReferences(\n  code: string, \n  classMap: CSSClassMap\n): { \n  code: string; \n  hasChanges: boolean; \n  replacements: number \n} {\n  let hasChanges = false;\n  let replacements = 0;\n  let modifiedCode = code;\n\n  Object.entries(classMap).forEach(([oldClass, info]) => {\n    if (info.utilities.length === 0) {\n      return;\n    }\n\n    const tailwindClassString = assembleTailwindClasses(info);\n    \n    if (info.fullyConvertible) {\n      const pattern1 = new RegExp(`className=\"${oldClass}\"`, 'g');\n      if (pattern1.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern1, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className=\"${oldClass}\" with \"${tailwindClassString}\"`);\n      }\n\n      const pattern2 = new RegExp(`className=\\\\{\"${oldClass}\"\\\\}`, 'g');\n      if (pattern2.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern2, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className={\"${oldClass}\"} with \"${tailwindClassString}\"`);\n      }\n\n      const pattern3 = new RegExp(`className=\\\\{\\`\\\\s*${oldClass}\\\\s*\\`\\\\}`, 'g');\n      if (pattern3.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern3, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className={\\`${oldClass}\\`} with \"${tailwindClassString}\"`);\n      }\n    } else {\n      const combinedClassString = `${oldClass} ${tailwindClassString}`;\n      \n      const pattern1 = new RegExp(`className=\"${oldClass}\"`, 'g');\n      if (pattern1.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern1, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className=\"${oldClass}\" → \"${combinedClassString}\"`);\n      }\n\n      const pattern2 = new RegExp(`className=\\\\{\"${oldClass}\"\\\\}`, 'g');\n      if (pattern2.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern2, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className={\"${oldClass}\"} → \"${combinedClassString}\"`);\n      }\n\n      const pattern3 = new RegExp(`className=\\\\{\\`\\\\s*${oldClass}\\\\s*\\`\\\\}`, 'g');\n      if (pattern3.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern3, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className={\\`${oldClass}\\`} → \"${combinedClassString}\"`);\n      }\n    }\n  });\n\n  return { code: modifiedCode, hasChanges, replacements };\n}"]}
|
|
442
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transformer.js","sourceRoot":"","sources":["../src/transformer.ts"],"names":[],"mappings":";;;;;AA+EA,wCAYC;AAED,wDA+WC;AA5cD,4CAAoB;AACpB,gDAAwB;AAExB,qDAAkD;AAClD,2CAAwC;AACxC,2CAAqE;AAErE,2CAAwC;AACxC,mEAAkE;AAClE,+DAGkC;AAClC,yEAA0E;AAC1E,+DAIkC;AAGlC,+DAA4D;AA0DrD,KAAK,UAAU,cAAc,CAClC,KAAoB,EACpB,OAAyB;IAEzB,MAAM,QAAQ,GAAG,MAAM,sBAAsB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IAC9D,OAAO;QACL,YAAY,EAAE,QAAQ,CAAC,KAAK,CAAC,YAAY;QACzC,aAAa,EAAE,QAAQ,CAAC,KAAK,CAAC,aAAa;QAC3C,eAAe,EAAE,QAAQ,CAAC,KAAK,CAAC,kBAAkB;QAClD,eAAe,EAAE,QAAQ,CAAC,KAAK,CAAC,eAAe;QAC/C,QAAQ,EAAE,QAAQ,CAAC,KAAK,CAAC,QAAQ;KAClC,CAAC;AACJ,CAAC;AAEM,KAAK,UAAU,sBAAsB,CAC1C,KAAoB,EACpB,OAAyB;IAEzB,MAAM,KAAK,GAAiB;QAC1B,YAAY,EAAE,KAAK,CAAC,MAAM;QAC1B,aAAa,EAAE,CAAC;QAChB,cAAc,EAAE,CAAC;QACjB,cAAc,EAAE,CAAC;QACjB,kBAAkB,EAAE,CAAC;QACrB,eAAe,EAAE,CAAC;QAClB,iBAAiB,EAAE,CAAC;QACpB,oBAAoB,EAAE,CAAC;QACvB,MAAM,EAAE,CAAC;QACT,QAAQ,EAAE,CAAC;KACZ,CAAC;IAEF,MAAM,WAAW,GAAiB,EAAE,CAAC;IAErC,MAAM,MAAM,GAAG,IAAI,+BAAc,CAAC,OAAO,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC;IAChE,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,MAAM,CAAC,CAAC;IACxC,MAAM,OAAO,GAAG,OAAO,CAAC,cAAc,EAAE,KAAK,EAAE,OAAO,CAAC;IAEvD,MAAM,sBAAsB,GAAG,IAAI,mCAAgB,EAAE,CAAC;IACtD,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,MAAM,EAAE,OAAO,EAAE,sBAAsB,CAAC,CAAC;IAEzE,IAAA,yCAAoB,GAAE,CAAC;IAEvB,MAAM,WAAW,GAAgB,EAAE,CAAC;IACpC,MAAM,kBAAkB,GAAc,EAAE,CAAC;IAEzC,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,KAAK,CAAC,CAAC;IACrD,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,KAAK,CAAC,CAAC;IAErD,eAAM,CAAC,IAAI,CAAC,0DAA0D,CAAC,CAAC;IAExE,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;QAC1B,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;YAC5B,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,YAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;gBACpD,MAAM,SAAS,CAAC,oBAAoB,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC3D,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,eAAM,CAAC,IAAI,CAAC,oCAAoC,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC,CAAC;YACzE,CAAC;QACH,CAAC;QAED,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;YAC5B,IAAI,OAAO,CAAC,YAAY;gBAAE,SAAS;YACnC,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,YAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;gBACpD,MAAM,SAAS,CAAC,+BAA+B,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACtE,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,eAAM,CAAC,IAAI,CAAC,iDAAiD,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC,CAAC;YACtF,CAAC;QACH,CAAC;QAED,eAAM,CAAC,OAAO,CAAC,aAAa,sBAAsB,CAAC,sBAAsB,EAAE,CAAC,MAAM,uBAAuB,CAAC,CAAC;IAC7G,CAAC;IAED,eAAM,CAAC,IAAI,CAAC,sCAAsC,CAAC,CAAC;IAEpD,MAAM,cAAc,GAAkC,IAAI,GAAG,EAAE,CAAC;IAEhE,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;QAC1B,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;YAC5B,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,YAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;gBACpD,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;gBAEzD,MAAM,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC;gBACvC,MAAM,mBAAmB,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC;gBAC9E,MAAM,uBAAuB,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC;gBACrF,MAAM,gBAAgB,GAAG,UAAU,GAAG,CAAC,IAAI,UAAU,KAAK,mBAAmB,IAAI,uBAAuB,KAAK,CAAC,CAAC;gBAE/G,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;oBAC1B,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;wBACtB,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;4BACrC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;4BAC9B,KAAK,CAAC,kBAAkB,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;wBACvD,CAAC;oBACH,CAAC;yBAAM,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;wBAC9D,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;wBAC7C,IAAI,QAAQ,EAAE,CAAC;4BACb,sBAAsB,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;wBACzC,CAAC;6BAAM,CAAC;4BACN,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,sBAAsB,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;wBACxE,CAAC;wBACD,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;4BACxB,KAAK,CAAC,kBAAkB,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;wBACvD,CAAC;6BAAM,CAAC;4BACN,KAAK,CAAC,kBAAkB,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC;4BACzD,eAAM,CAAC,OAAO,CAAC,WAAW,IAAI,CAAC,SAAS,yBAAyB,IAAI,CAAC,gBAAgB,CAAC,MAAM,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,gBAAgB,CAAC,CAAC;wBAC7I,CAAC;oBACH,CAAC;gBACH,CAAC,CAAC,CAAC;gBAEH,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE;oBAC5B,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,OAAO;oBACP,UAAU,EAAE,MAAM,CAAC,GAAG;oBACtB,KAAK,EAAE,MAAM,CAAC,KAAK;oBACnB,SAAS,EAAE,MAAM,CAAC,SAAS;oBAC3B,UAAU,EAAE,MAAM,CAAC,UAAU;oBAC7B,gBAAgB;oBAChB,QAAQ,EAAE,MAAM,CAAC,QAAQ;iBAC1B,CAAC,CAAC;gBAEH,KAAK,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;gBAEzC,eAAM,CAAC,OAAO,CAAC,YAAY,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;gBACzC,eAAM,CAAC,OAAO,CAAC,oBAAoB,UAAU,EAAE,CAAC,CAAC;gBACjD,eAAM,CAAC,OAAO,CAAC,8BAA8B,mBAAmB,EAAE,CAAC,CAAC;gBACpE,eAAM,CAAC,OAAO,CAAC,kCAAkC,uBAAuB,EAAE,CAAC,CAAC;gBAC5E,eAAM,CAAC,OAAO,CAAC,0BAA0B,gBAAgB,EAAE,CAAC,CAAC;gBAE7D,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;oBAChC,eAAM,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC,CAAC;gBACjD,CAAC,CAAC,CAAC;YAEL,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBAC5E,eAAM,CAAC,KAAK,CAAC,qBAAqB,IAAI,CAAC,IAAI,GAAG,EAAE,KAAK,CAAC,CAAC;gBACvD,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE;oBAC5B,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,OAAO,EAAE,EAAE;oBACX,UAAU,EAAE,EAAE;oBACd,KAAK,EAAE,EAAE;oBACT,SAAS,EAAE,KAAK;oBAChB,UAAU,EAAE,KAAK;oBACjB,gBAAgB,EAAE,KAAK;oBACvB,QAAQ,EAAE,EAAE;oBACZ,KAAK,EAAE,YAAY;iBACpB,CAAC,CAAC;gBACH,KAAK,CAAC,MAAM,EAAE,CAAC;gBACf,KAAK,CAAC,QAAQ,EAAE,CAAC;YACnB,CAAC;QACH,CAAC;IACH,CAAC;IAED,eAAM,CAAC,IAAI,CAAC,iDAAiD,CAAC,CAAC;IAE/D,MAAM,cAAc,GAAkC,IAAI,GAAG,EAAE,CAAC;IAEhE,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;QAC5B,IAAI,CAAC;YACH,IAAI,OAAO,GAAG,YAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;YAClD,MAAM,eAAe,GAAG,OAAO,CAAC;YAChC,IAAI,UAAU,GAAG,KAAK,CAAC;YACvB,IAAI,YAAY,GAAa,EAAE,CAAC;YAChC,IAAI,kBAAkB,GAAG,CAAC,CAAC;YAC3B,IAAI,eAAe,GAAG,CAAC,CAAC;YAExB,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;gBACxB,IAAI,CAAC;oBACH,MAAM,SAAS,GAAG,SAAS,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;oBAEtD,IAAI,SAAS,CAAC,UAAU,EAAE,CAAC;wBACzB,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC;wBACzB,UAAU,GAAG,IAAI,CAAC;wBAClB,kBAAkB,IAAI,SAAS,CAAC,eAAe,CAAC,MAAM,CACpD,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CACtC,CAAC;wBACF,YAAY,CAAC,IAAI,CAAC,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;oBAC3C,CAAC;gBACH,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,eAAM,CAAC,IAAI,CAAC,wCAAwC,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC,CAAC;oBAC3E,YAAY,CAAC,IAAI,CAAC,oBAAoB,KAAK,EAAE,CAAC,CAAC;gBACjD,CAAC;YACH,CAAC;YAED,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;gBAC1B,IAAI,CAAC;oBACH,MAAM,cAAc,GAAG,MAAM,SAAS,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;oBAE5E,IAAI,cAAc,CAAC,UAAU,EAAE,CAAC;wBAC9B,OAAO,GAAG,cAAc,CAAC,IAAI,CAAC;wBAC9B,UAAU,GAAG,IAAI,CAAC;wBAElB,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;4BAClC,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gCACtB,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oCACrC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oCAC9B,kBAAkB,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;gCACjD,CAAC;4BACH,CAAC;iCAAM,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;gCAC9D,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;gCAC7C,IAAI,QAAQ,EAAE,CAAC;oCACb,sBAAsB,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;gCACzC,CAAC;qCAAM,CAAC;oCACN,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,sBAAsB,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;gCACxE,CAAC;gCACD,kBAAkB,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;4BACjD,CAAC;wBACH,CAAC,CAAC,CAAC;wBAEH,YAAY,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,QAAQ,CAAC,CAAC;oBAChD,CAAC;gBACH,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,eAAM,CAAC,IAAI,CAAC,mCAAmC,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC,CAAC;oBACtE,YAAY,CAAC,IAAI,CAAC,6BAA6B,KAAK,EAAE,CAAC,CAAC;gBAC1D,CAAC;YACH,CAAC;YAED,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE;gBAC5B,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,OAAO,EAAE,eAAe;gBACxB,UAAU,EAAE,OAAO;gBACnB,UAAU;gBACV,QAAQ,EAAE,YAAY;gBACtB,kBAAkB;gBAClB,eAAe;aAChB,CAAC,CAAC;YAEH,KAAK,CAAC,QAAQ,IAAI,YAAY,CAAC,MAAM,CAAC;YAEtC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC7B,eAAM,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC,CAAC;YACjD,CAAC,CAAC,CAAC;QAEL,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAC5E,eAAM,CAAC,KAAK,CAAC,qBAAqB,IAAI,CAAC,IAAI,GAAG,EAAE,KAAK,CAAC,CAAC;YACvD,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE;gBAC5B,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,OAAO,EAAE,EAAE;gBACX,UAAU,EAAE,EAAE;gBACd,UAAU,EAAE,KAAK;gBACjB,QAAQ,EAAE,EAAE;gBACZ,kBAAkB,EAAE,CAAC;gBACrB,eAAe,EAAE,CAAC;gBAClB,KAAK,EAAE,YAAY;aACpB,CAAC,CAAC;YACH,KAAK,CAAC,MAAM,EAAE,CAAC;QACjB,CAAC;IACH,CAAC;IAED,IAAI,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACxC,eAAM,CAAC,IAAI,CAAC,iDAAiD,CAAC,CAAC;QAE/D,KAAK,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,IAAI,cAAc,EAAE,CAAC;YACpD,IAAI,UAAU,CAAC,KAAK;gBAAE,SAAS;YAE/B,IAAI,OAAO,GAAG,UAAU,CAAC,UAAU,CAAC;YACpC,IAAI,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC;YAEvC,MAAM,iBAAiB,GAAG,0BAA0B,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;YAC3E,IAAI,iBAAiB,CAAC,UAAU,EAAE,CAAC;gBACjC,OAAO,GAAG,iBAAiB,CAAC,IAAI,CAAC;gBACjC,UAAU,GAAG,IAAI,CAAC;gBAClB,UAAU,CAAC,eAAe,IAAI,iBAAiB,CAAC,YAAY,CAAC;gBAC7D,KAAK,CAAC,eAAe,IAAI,iBAAiB,CAAC,YAAY,CAAC;gBAExD,eAAM,CAAC,OAAO,CAAC,YAAY,iBAAiB,CAAC,YAAY,wBAAwB,cAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAC9G,CAAC;YAED,cAAc,CAAC,GAAG,CAAC,QAAQ,EAAE;gBAC3B,GAAG,UAAU;gBACb,UAAU,EAAE,OAAO;gBACnB,UAAU;aACX,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,IAAI,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAClC,eAAM,CAAC,IAAI,CAAC,uDAAuD,CAAC,CAAC;QAErE,KAAK,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,IAAI,cAAc,EAAE,CAAC;YACpD,IAAI,UAAU,CAAC,KAAK;gBAAE,SAAS;YAE/B,IAAI,OAAO,GAAG,UAAU,CAAC,UAAU,CAAC;YACpC,IAAI,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC;YAEvC,MAAM,gBAAgB,GAAG,IAAA,uDAA4B,EAAC,OAAO,EAAE,kBAAkB,CAAC,CAAC;YACnF,IAAI,gBAAgB,CAAC,UAAU,EAAE,CAAC;gBAChC,OAAO,GAAG,gBAAgB,CAAC,IAAI,CAAC;gBAChC,UAAU,GAAG,IAAI,CAAC;gBAClB,UAAU,CAAC,eAAe,IAAI,gBAAgB,CAAC,eAAe,CAAC;gBAC/D,KAAK,CAAC,eAAe,IAAI,gBAAgB,CAAC,eAAe,CAAC;gBAE1D,eAAM,CAAC,OAAO,CAAC,WAAW,gBAAgB,CAAC,eAAe,kCAAkC,cAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YACzH,CAAC;YAED,IAAI,gBAAgB,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACzC,KAAK,CAAC,QAAQ,IAAI,gBAAgB,CAAC,QAAQ,CAAC,MAAM,CAAC;gBACnD,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;oBAC1C,eAAM,CAAC,OAAO,CAAC,OAAO,QAAQ,KAAK,OAAO,EAAE,CAAC,CAAC;gBAChD,CAAC,CAAC,CAAC;YACL,CAAC;YAED,cAAc,CAAC,GAAG,CAAC,QAAQ,EAAE;gBAC3B,GAAG,UAAU;gBACb,UAAU,EAAE,OAAO;gBACnB,UAAU;aACX,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,KAAK,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,IAAI,cAAc,EAAE,CAAC;QACpD,IAAI,UAAU,CAAC,KAAK,EAAE,CAAC;YACrB,WAAW,CAAC,IAAI,CAAC;gBACf,QAAQ;gBACR,eAAe,EAAE,UAAU,CAAC,OAAO;gBACnC,UAAU,EAAE,UAAU,CAAC,UAAU;gBACjC,UAAU,EAAE,KAAK;gBACjB,MAAM,EAAE,OAAO;gBACf,KAAK,EAAE,UAAU,CAAC,KAAK;aACxB,CAAC,CAAC;YACH,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,SAAS;QACX,CAAC;QAED,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,KAAK,UAAU,CAAC,OAAO,CAAC;QAEhE,WAAW,CAAC,IAAI,CAAC;YACf,QAAQ;YACR,eAAe,EAAE,UAAU,CAAC,OAAO;YACnC,UAAU,EAAE,UAAU,CAAC,UAAU;YACjC,UAAU;YACV,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW;YAC7C,eAAe,EAAE;gBACf,kBAAkB,EAAE,UAAU,CAAC,kBAAkB;gBACjD,eAAe,EAAE,UAAU,CAAC,eAAe;gBAC3C,iBAAiB,EAAE,CAAC;aACrB;SACF,CAAC,CAAC;QAEH,IAAI,UAAU,EAAE,CAAC;YACf,KAAK,CAAC,aAAa,EAAE,CAAC;QACxB,CAAC;aAAM,CAAC;YACN,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,CAAC;IACH,CAAC;IAED,KAAK,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,IAAI,cAAc,EAAE,CAAC;QACpD,IAAI,UAAU,CAAC,KAAK,EAAE,CAAC;YACrB,WAAW,CAAC,IAAI,CAAC;gBACf,QAAQ;gBACR,eAAe,EAAE,UAAU,CAAC,OAAO;gBACnC,UAAU,EAAE,UAAU,CAAC,UAAU;gBACjC,UAAU,EAAE,KAAK;gBACjB,MAAM,EAAE,OAAO;gBACf,KAAK,EAAE,UAAU,CAAC,KAAK;aACxB,CAAC,CAAC;YACH,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,SAAS;QACX,CAAC;QAED,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,IAAI,UAAU,CAAC,UAAU,KAAK,UAAU,CAAC,OAAO,CAAC;QAEzF,WAAW,CAAC,IAAI,CAAC;YACf,QAAQ;YACR,eAAe,EAAE,UAAU,CAAC,OAAO;YACnC,UAAU,EAAE,UAAU,CAAC,UAAU;YACjC,UAAU;YACV,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW;SAC9C,CAAC,CAAC;QAEH,IAAI,UAAU,EAAE,CAAC;YACf,KAAK,CAAC,aAAa,EAAE,CAAC;QACxB,CAAC;aAAM,CAAC;YACN,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,CAAC;IACH,CAAC;IAED,KAAK,CAAC,kBAAkB,GAAG,KAAK,CAAC,eAAe,GAAG,KAAK,CAAC,kBAAkB,CAAC;IAE5E,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC;AAChC,CAAC;AAED,SAAS,sBAAsB,CAAC,IAAa,EAAE,UAAkB;IAC/D,OAAO;QACL,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAClC,KAAK,EAAE,CAAC,CAAC,KAAK;YACd,QAAQ,EAAE,IAAA,wCAAqB,EAAC,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC;YAChD,WAAW,EAAE,CAAC,CAAC,WAAW;YAC1B,WAAW,EAAE,CAAC,CAAC,WAAW;YAC1B,WAAW,EAAE,CAAC,CAAC,WAAW;YAC1B,gBAAgB,EAAE,IAAI,CAAC,QAAQ;SAChC,CAAC,CAAC;QACH,UAAU;QACV,gBAAgB,EAAE,IAAI,CAAC,cAAc;KACtC,CAAC;AACJ,CAAC;AAED,SAAS,sBAAsB,CAAC,IAAe,EAAE,IAAa;IAC5D,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;QACrC,MAAM,eAAe,GAAoB;YACvC,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,QAAQ,EAAE,IAAA,wCAAqB,EAAC,CAAC,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;YACtD,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,gBAAgB,EAAE,IAAI,CAAC,QAAQ;SAChC,CAAC;QAEF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACvC,CAAC;AACH,CAAC;AAED,SAAS,uBAAuB,CAAC,IAAe;IAC9C,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAA,mCAAgB,EAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;IAC7D,OAAO,IAAA,6CAA0B,EAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACxD,CAAC;AAED,SAAS,0BAA0B,CACjC,IAAY,EACZ,QAAqB;IAMrB,IAAI,UAAU,GAAG,KAAK,CAAC;IACvB,IAAI,YAAY,GAAG,CAAC,CAAC;IACrB,IAAI,YAAY,GAAG,IAAI,CAAC;IAExB,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,EAAE;QACpD,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAChC,OAAO;QACT,CAAC;QAED,MAAM,mBAAmB,GAAG,uBAAuB,CAAC,IAAI,CAAC,CAAC;QAE1D,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,MAAM,QAAQ,GAAG,IAAI,MAAM,CAAC,cAAc,QAAQ,GAAG,EAAE,GAAG,CAAC,CAAC;YAC5D,IAAI,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;gBAChC,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,EAAE,cAAc,mBAAmB,GAAG,CAAC,CAAC;gBACpF,UAAU,GAAG,IAAI,CAAC;gBAClB,YAAY,EAAE,CAAC;gBACf,eAAM,CAAC,OAAO,CAAC,uBAAuB,QAAQ,WAAW,mBAAmB,GAAG,CAAC,CAAC;YACnF,CAAC;YAED,MAAM,QAAQ,GAAG,IAAI,MAAM,CAAC,iBAAiB,QAAQ,MAAM,EAAE,GAAG,CAAC,CAAC;YAClE,IAAI,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;gBAChC,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,EAAE,cAAc,mBAAmB,GAAG,CAAC,CAAC;gBACpF,UAAU,GAAG,IAAI,CAAC;gBAClB,YAAY,EAAE,CAAC;gBACf,eAAM,CAAC,OAAO,CAAC,wBAAwB,QAAQ,YAAY,mBAAmB,GAAG,CAAC,CAAC;YACrF,CAAC;YAED,MAAM,QAAQ,GAAG,IAAI,MAAM,CAAC,sBAAsB,QAAQ,WAAW,EAAE,GAAG,CAAC,CAAC;YAC5E,IAAI,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;gBAChC,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,EAAE,cAAc,mBAAmB,GAAG,CAAC,CAAC;gBACpF,UAAU,GAAG,IAAI,CAAC;gBAClB,YAAY,EAAE,CAAC;gBACf,eAAM,CAAC,OAAO,CAAC,yBAAyB,QAAQ,aAAa,mBAAmB,GAAG,CAAC,CAAC;YACvF,CAAC;QACH,CAAC;aAAM,CAAC;YACN,MAAM,mBAAmB,GAAG,GAAG,QAAQ,IAAI,mBAAmB,EAAE,CAAC;YAEjE,MAAM,QAAQ,GAAG,IAAI,MAAM,CAAC,cAAc,QAAQ,GAAG,EAAE,GAAG,CAAC,CAAC;YAC5D,IAAI,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;gBAChC,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,EAAE,cAAc,mBAAmB,GAAG,CAAC,CAAC;gBACpF,UAAU,GAAG,IAAI,CAAC;gBAClB,YAAY,EAAE,CAAC;gBACf,eAAM,CAAC,OAAO,CAAC,0BAA0B,QAAQ,QAAQ,mBAAmB,GAAG,CAAC,CAAC;YACnF,CAAC;YAED,MAAM,QAAQ,GAAG,IAAI,MAAM,CAAC,iBAAiB,QAAQ,MAAM,EAAE,GAAG,CAAC,CAAC;YAClE,IAAI,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;gBAChC,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,EAAE,cAAc,mBAAmB,GAAG,CAAC,CAAC;gBACpF,UAAU,GAAG,IAAI,CAAC;gBAClB,YAAY,EAAE,CAAC;gBACf,eAAM,CAAC,OAAO,CAAC,2BAA2B,QAAQ,SAAS,mBAAmB,GAAG,CAAC,CAAC;YACrF,CAAC;YAED,MAAM,QAAQ,GAAG,IAAI,MAAM,CAAC,sBAAsB,QAAQ,WAAW,EAAE,GAAG,CAAC,CAAC;YAC5E,IAAI,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;gBAChC,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,EAAE,cAAc,mBAAmB,GAAG,CAAC,CAAC;gBACpF,UAAU,GAAG,IAAI,CAAC;gBAClB,YAAY,EAAE,CAAC;gBACf,eAAM,CAAC,OAAO,CAAC,4BAA4B,QAAQ,UAAU,mBAAmB,GAAG,CAAC,CAAC;YACvF,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,UAAU,EAAE,YAAY,EAAE,CAAC;AAC1D,CAAC","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport { ScannedFile } from './scanner';\nimport { TailwindMapper } from './tailwindMapper';\nimport { JSXParser } from './jsxParser';\nimport { CSSParser, CSSRule, UtilityWithVariant } from './cssParser';\nimport { TailwindConfig } from './utils/config';\nimport { logger } from './utils/logger';\nimport { clearBreakpointCache } from './utils/breakpointResolver';\nimport { \n  assembleUtilities, \n  normalizeVariantOrder \n} from './utils/variantAssembler';\nimport { transformDescendantSelectors } from './jsxDescendantTransformer';\nimport { \n  UtilityWithMeta, \n  resolveConflicts, \n  resolvedUtilitiesToStrings \n} from './utils/conflictResolver';\nimport { Specificity } from './utils/specificityCalculator';\nimport { FileResult, SummaryStats } from './utils/reporter';\nimport { VariableRegistry } from './utils/variableRegistry';\n\nexport interface TransformOptions {\n  dryRun: boolean;\n  deleteCss: boolean;\n  skipExternal: boolean;\n  skipInline: boolean;\n  skipInternal: boolean;\n  tailwindConfig: TailwindConfig | null;\n  projectRoot: string;\n}\n\nexport interface TransformResults {\n  filesScanned: number;\n  filesModified: number;\n  stylesConverted: number;\n  classesReplaced: number;\n  warnings: number;\n}\n\nexport interface DetailedTransformResults {\n  fileResults: FileResult[];\n  stats: SummaryStats;\n}\n\ninterface ClassInfo {\n  utilities: UtilityWithMeta[];\n  sourceFile: string;\n  fullyConvertible: boolean;\n}\n\ninterface CSSClassMap {\n  [className: string]: ClassInfo;\n}\n\ninterface ProcessedCSSFile {\n  path: string;\n  content: string;\n  newContent: string;\n  rules: CSSRule[];\n  canDelete: boolean;\n  hasChanges: boolean;\n  fullyConvertible: boolean;\n  warnings: string[];\n  error?: string;\n}\n\ninterface ProcessedJSXFile {\n  path: string;\n  content: string;\n  newContent: string;\n  hasChanges: boolean;\n  warnings: string[];\n  error?: string;\n  utilitiesGenerated: number;\n  classesReplaced: number;\n}\n\nexport async function transformFiles(\n  files: ScannedFile[],\n  options: TransformOptions\n): Promise<TransformResults> {\n  const detailed = await transformFilesDetailed(files, options);\n  return {\n    filesScanned: detailed.stats.filesScanned,\n    filesModified: detailed.stats.filesModified,\n    stylesConverted: detailed.stats.utilitiesGenerated,\n    classesReplaced: detailed.stats.classesReplaced,\n    warnings: detailed.stats.warnings\n  };\n}\n\nexport async function transformFilesDetailed(\n  files: ScannedFile[],\n  options: TransformOptions\n): Promise<DetailedTransformResults> {\n  const stats: SummaryStats = {\n    filesScanned: files.length,\n    filesModified: 0,\n    filesUnchanged: 0,\n    filesWithError: 0,\n    utilitiesGenerated: 0,\n    classesReplaced: 0,\n    conflictsResolved: 0,\n    unsupportedSelectors: 0,\n    errors: 0,\n    warnings: 0\n  };\n\n  const fileResults: FileResult[] = [];\n\n  const mapper = new TailwindMapper(options.tailwindConfig || {});\n  const jsxParser = new JSXParser(mapper);\n  const screens = options.tailwindConfig?.theme?.screens;\n  \n  const sharedVariableRegistry = new VariableRegistry();\n  const cssParser = new CSSParser(mapper, screens, sharedVariableRegistry);\n\n  clearBreakpointCache();\n\n  const cssClassMap: CSSClassMap = {};\n  const allDescendantRules: CSSRule[] = [];\n\n  const cssFiles = files.filter(f => f.type === 'css');\n  const jsxFiles = files.filter(f => f.type === 'jsx');\n\n  logger.info('\\n🔍 Phase 0: Collecting CSS variables from all files...');\n\n  if (!options.skipExternal) {\n    for (const file of cssFiles) {\n      try {\n        const content = fs.readFileSync(file.path, 'utf-8');\n        await cssParser.collectVariablesOnly(content, file.path);\n      } catch (error) {\n        logger.warn(`Failed to collect variables from ${file.path}: ${error}`);\n      }\n    }\n    \n    for (const file of jsxFiles) {\n      if (options.skipInternal) continue;\n      try {\n        const content = fs.readFileSync(file.path, 'utf-8');\n        await cssParser.collectVariablesFromInternalCSS(content, file.path);\n      } catch (error) {\n        logger.warn(`Failed to collect internal CSS variables from ${file.path}: ${error}`);\n      }\n    }\n    \n    logger.verbose(`Collected ${sharedVariableRegistry.getRegisteredVariables().length} unique CSS variables`);\n  }\n\n  logger.info('\\n🔍 Phase 1: Analyzing CSS files...');\n\n  const cssFileResults: Map<string, ProcessedCSSFile> = new Map();\n\n  if (!options.skipExternal) {\n    for (const file of cssFiles) {\n      try {\n        const content = fs.readFileSync(file.path, 'utf-8');\n        const result = await cssParser.parse(content, file.path);\n\n        const totalRules = result.rules.length;\n        const fullyConvertedRules = result.rules.filter(r => r.fullyConverted).length;\n        const partiallyConvertedRules = result.rules.filter(r => r.partialConversion).length;\n        const fullyConvertible = totalRules > 0 && totalRules === fullyConvertedRules && partiallyConvertedRules === 0;\n\n        result.rules.forEach(rule => {\n          if (rule.isDescendant) {\n            if (rule.convertedClasses.length > 0) {\n              allDescendantRules.push(rule);\n              stats.utilitiesGenerated += rule.declarations.length;\n            }\n          } else if (rule.className && rule.convertedClasses.length > 0) {\n            const existing = cssClassMap[rule.className];\n            if (existing) {\n              mergeRuleIntoClassInfo(existing, rule);\n            } else {\n              cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);\n            }\n            if (rule.fullyConverted) {\n              stats.utilitiesGenerated += rule.declarations.length;\n            } else {\n              stats.utilitiesGenerated += rule.convertedClasses.length;\n              logger.verbose(`  Rule .${rule.className}: partial conversion (${rule.convertedClasses.length}/${rule.declarations.length} declarations)`);\n            }\n          }\n        });\n\n        cssFileResults.set(file.path, {\n          path: file.path,\n          content,\n          newContent: result.css,\n          rules: result.rules,\n          canDelete: result.canDelete,\n          hasChanges: result.hasChanges,\n          fullyConvertible,\n          warnings: result.warnings\n        });\n\n        stats.warnings += result.warnings.length;\n\n        logger.verbose(`Analyzed ${file.path}:`);\n        logger.verbose(`  - Total rules: ${totalRules}`);\n        logger.verbose(`  - Fully converted rules: ${fullyConvertedRules}`);\n        logger.verbose(`  - Partially converted rules: ${partiallyConvertedRules}`);\n        logger.verbose(`  - Fully convertible: ${fullyConvertible}`);\n\n        result.warnings.forEach(warning => {\n          logger.verbose(`⚠️  ${file.path}: ${warning}`);\n        });\n\n      } catch (error) {\n        const errorMessage = error instanceof Error ? error.message : String(error);\n        logger.error(`Failed to analyze ${file.path}:`, error);\n        cssFileResults.set(file.path, {\n          path: file.path,\n          content: '',\n          newContent: '',\n          rules: [],\n          canDelete: false,\n          hasChanges: false,\n          fullyConvertible: false,\n          warnings: [],\n          error: errorMessage\n        });\n        stats.errors++;\n        stats.warnings++;\n      }\n    }\n  }\n\n  logger.info('\\n⚛️  Phase 2: Transforming React components...');\n\n  const jsxFileResults: Map<string, ProcessedJSXFile> = new Map();\n\n  for (const file of jsxFiles) {\n    try {\n      let content = fs.readFileSync(file.path, 'utf-8');\n      const originalContent = content;\n      let hasChanges = false;\n      let fileWarnings: string[] = [];\n      let utilitiesGenerated = 0;\n      let classesReplaced = 0;\n\n      if (!options.skipInline) {\n        try {\n          const jsxResult = jsxParser.parse(content, file.path);\n          \n          if (jsxResult.hasChanges) {\n            content = jsxResult.code;\n            hasChanges = true;\n            utilitiesGenerated += jsxResult.transformations.reduce(\n              (sum, t) => sum + t.classes.length, 0\n            );\n            fileWarnings.push(...jsxResult.warnings);\n          }\n        } catch (error) {\n          logger.warn(`Failed to parse JSX inline styles in ${file.path}: ${error}`);\n          fileWarnings.push(`JSX parse error: ${error}`);\n        }\n      }\n\n      if (!options.skipInternal) {\n        try {\n          const internalResult = await cssParser.parseInternalCSS(content, file.path);\n          \n          if (internalResult.hasChanges) {\n            content = internalResult.html;\n            hasChanges = true;\n            \n            internalResult.rules.forEach(rule => {\n              if (rule.isDescendant) {\n                if (rule.convertedClasses.length > 0) {\n                  allDescendantRules.push(rule);\n                  utilitiesGenerated += rule.declarations.length;\n                }\n              } else if (rule.convertedClasses.length > 0 && rule.className) {\n                const existing = cssClassMap[rule.className];\n                if (existing) {\n                  mergeRuleIntoClassInfo(existing, rule);\n                } else {\n                  cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);\n                }\n                utilitiesGenerated += rule.declarations.length;\n              }\n            });\n            \n            fileWarnings.push(...internalResult.warnings);\n          }\n        } catch (error) {\n          logger.warn(`Failed to parse internal CSS in ${file.path}: ${error}`);\n          fileWarnings.push(`Internal CSS parse error: ${error}`);\n        }\n      }\n\n      jsxFileResults.set(file.path, {\n        path: file.path,\n        content: originalContent,\n        newContent: content,\n        hasChanges,\n        warnings: fileWarnings,\n        utilitiesGenerated,\n        classesReplaced\n      });\n\n      stats.warnings += fileWarnings.length;\n\n      fileWarnings.forEach(warning => {\n        logger.verbose(`⚠️  ${file.path}: ${warning}`);\n      });\n\n    } catch (error) {\n      const errorMessage = error instanceof Error ? error.message : String(error);\n      logger.error(`Failed to process ${file.path}:`, error);\n      jsxFileResults.set(file.path, {\n        path: file.path,\n        content: '',\n        newContent: '',\n        hasChanges: false,\n        warnings: [],\n        utilitiesGenerated: 0,\n        classesReplaced: 0,\n        error: errorMessage\n      });\n      stats.errors++;\n    }\n  }\n\n  if (Object.keys(cssClassMap).length > 0) {\n    logger.info('\\n🔄 Phase 3: Replacing className references...');\n\n    for (const [filePath, fileResult] of jsxFileResults) {\n      if (fileResult.error) continue;\n      \n      let content = fileResult.newContent;\n      let hasChanges = fileResult.hasChanges;\n\n      const replacementResult = replaceClassNameReferences(content, cssClassMap);\n      if (replacementResult.hasChanges) {\n        content = replacementResult.code;\n        hasChanges = true;\n        fileResult.classesReplaced += replacementResult.replacements;\n        stats.classesReplaced += replacementResult.replacements;\n        \n        logger.verbose(`Replaced ${replacementResult.replacements} class references in ${path.basename(filePath)}`);\n      }\n\n      jsxFileResults.set(filePath, {\n        ...fileResult,\n        newContent: content,\n        hasChanges\n      });\n    }\n  }\n\n  if (allDescendantRules.length > 0) {\n    logger.info('\\n🌳 Phase 3.5: Applying descendant selector rules...');\n\n    for (const [filePath, fileResult] of jsxFileResults) {\n      if (fileResult.error) continue;\n      \n      let content = fileResult.newContent;\n      let hasChanges = fileResult.hasChanges;\n\n      const descendantResult = transformDescendantSelectors(content, allDescendantRules);\n      if (descendantResult.hasChanges) {\n        content = descendantResult.code;\n        hasChanges = true;\n        fileResult.classesReplaced += descendantResult.transformations;\n        stats.classesReplaced += descendantResult.transformations;\n        \n        logger.verbose(`Applied ${descendantResult.transformations} descendant transformations in ${path.basename(filePath)}`);\n      }\n\n      if (descendantResult.warnings.length > 0) {\n        stats.warnings += descendantResult.warnings.length;\n        descendantResult.warnings.forEach(warning => {\n          logger.verbose(`⚠️  ${filePath}: ${warning}`);\n        });\n      }\n\n      jsxFileResults.set(filePath, {\n        ...fileResult,\n        newContent: content,\n        hasChanges\n      });\n    }\n  }\n\n  for (const [filePath, fileResult] of jsxFileResults) {\n    if (fileResult.error) {\n      fileResults.push({\n        filePath,\n        originalContent: fileResult.content,\n        newContent: fileResult.newContent,\n        hasChanges: false,\n        status: 'error',\n        error: fileResult.error\n      });\n      stats.filesWithError++;\n      continue;\n    }\n    \n    const hasChanges = fileResult.newContent !== fileResult.content;\n    \n    fileResults.push({\n      filePath,\n      originalContent: fileResult.content,\n      newContent: fileResult.newContent,\n      hasChanges,\n      status: hasChanges ? 'modified' : 'unchanged',\n      transformations: {\n        utilitiesGenerated: fileResult.utilitiesGenerated,\n        classesReplaced: fileResult.classesReplaced,\n        conflictsResolved: 0\n      }\n    });\n    \n    if (hasChanges) {\n      stats.filesModified++;\n    } else {\n      stats.filesUnchanged++;\n    }\n  }\n\n  for (const [filePath, fileResult] of cssFileResults) {\n    if (fileResult.error) {\n      fileResults.push({\n        filePath,\n        originalContent: fileResult.content,\n        newContent: fileResult.newContent,\n        hasChanges: false,\n        status: 'error',\n        error: fileResult.error\n      });\n      stats.filesWithError++;\n      continue;\n    }\n    \n    const hasChanges = fileResult.hasChanges && fileResult.newContent !== fileResult.content;\n    \n    fileResults.push({\n      filePath,\n      originalContent: fileResult.content,\n      newContent: fileResult.newContent,\n      hasChanges,\n      status: hasChanges ? 'modified' : 'unchanged'\n    });\n    \n    if (hasChanges) {\n      stats.filesModified++;\n    } else {\n      stats.filesUnchanged++;\n    }\n  }\n\n  stats.utilitiesGenerated = stats.classesReplaced + stats.utilitiesGenerated;\n\n  return { fileResults, stats };\n}\n\nfunction buildClassInfoFromRule(rule: CSSRule, sourceFile: string): ClassInfo {\n  return {\n    utilities: rule.utilities.map(u => ({\n      value: u.value,\n      variants: normalizeVariantOrder([...u.variants]),\n      cssProperty: u.cssProperty,\n      specificity: u.specificity,\n      sourceOrder: u.sourceOrder,\n      originalSelector: rule.selector\n    })),\n    sourceFile,\n    fullyConvertible: rule.fullyConverted\n  };\n}\n\nfunction mergeRuleIntoClassInfo(info: ClassInfo, rule: CSSRule): void {\n  for (const utility of rule.utilities) {\n    const utilityWithMeta: UtilityWithMeta = {\n      value: utility.value,\n      variants: normalizeVariantOrder([...utility.variants]),\n      cssProperty: utility.cssProperty,\n      specificity: utility.specificity,\n      sourceOrder: utility.sourceOrder,\n      originalSelector: rule.selector\n    };\n    \n    info.utilities.push(utilityWithMeta);\n  }\n}\n\nfunction assembleTailwindClasses(info: ClassInfo): string {\n  const { resolved } = resolveConflicts(info.utilities, false);\n  return resolvedUtilitiesToStrings(resolved).join(' ');\n}\n\nfunction replaceClassNameReferences(\n  code: string, \n  classMap: CSSClassMap\n): { \n  code: string; \n  hasChanges: boolean; \n  replacements: number \n} {\n  let hasChanges = false;\n  let replacements = 0;\n  let modifiedCode = code;\n\n  Object.entries(classMap).forEach(([oldClass, info]) => {\n    if (info.utilities.length === 0) {\n      return;\n    }\n\n    const tailwindClassString = assembleTailwindClasses(info);\n    \n    if (info.fullyConvertible) {\n      const pattern1 = new RegExp(`className=\"${oldClass}\"`, 'g');\n      if (pattern1.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern1, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className=\"${oldClass}\" with \"${tailwindClassString}\"`);\n      }\n\n      const pattern2 = new RegExp(`className=\\\\{\"${oldClass}\"\\\\}`, 'g');\n      if (pattern2.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern2, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className={\"${oldClass}\"} with \"${tailwindClassString}\"`);\n      }\n\n      const pattern3 = new RegExp(`className=\\\\{\\`\\\\s*${oldClass}\\\\s*\\`\\\\}`, 'g');\n      if (pattern3.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern3, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className={\\`${oldClass}\\`} with \"${tailwindClassString}\"`);\n      }\n    } else {\n      const combinedClassString = `${oldClass} ${tailwindClassString}`;\n      \n      const pattern1 = new RegExp(`className=\"${oldClass}\"`, 'g');\n      if (pattern1.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern1, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className=\"${oldClass}\" → \"${combinedClassString}\"`);\n      }\n\n      const pattern2 = new RegExp(`className=\\\\{\"${oldClass}\"\\\\}`, 'g');\n      if (pattern2.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern2, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className={\"${oldClass}\"} → \"${combinedClassString}\"`);\n      }\n\n      const pattern3 = new RegExp(`className=\\\\{\\`\\\\s*${oldClass}\\\\s*\\`\\\\}`, 'g');\n      if (pattern3.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern3, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className={\\`${oldClass}\\`} → \"${combinedClassString}\"`);\n      }\n    }\n  });\n\n  return { code: modifiedCode, hasChanges, replacements };\n}\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export interface DiffLine {
|
|
2
|
+
type: 'context' | 'added' | 'removed';
|
|
3
|
+
content: string;
|
|
4
|
+
oldLineNumber?: number;
|
|
5
|
+
newLineNumber?: number;
|
|
6
|
+
}
|
|
7
|
+
export interface DiffHunk {
|
|
8
|
+
oldStart: number;
|
|
9
|
+
oldLines: number;
|
|
10
|
+
newStart: number;
|
|
11
|
+
newLines: number;
|
|
12
|
+
lines: DiffLine[];
|
|
13
|
+
}
|
|
14
|
+
export interface DiffResult {
|
|
15
|
+
hunks: DiffHunk[];
|
|
16
|
+
hasChanges: boolean;
|
|
17
|
+
}
|
|
18
|
+
export declare function computeUnifiedDiff(oldContent: string, newContent: string, contextLines?: number): DiffResult;
|
|
19
|
+
export declare function formatDiffHeader(filePath: string): string;
|
|
20
|
+
export declare function formatDiffHunk(hunk: DiffHunk): string;
|
|
21
|
+
export declare function formatDiff(filePath: string, diff: DiffResult): string;
|
|
22
|
+
export declare function computeAndFormatDiff(oldContent: string, newContent: string, filePath: string): string;
|
|
23
|
+
export declare function getChangeStats(diff: DiffResult): {
|
|
24
|
+
added: number;
|
|
25
|
+
removed: number;
|
|
26
|
+
};
|