@nlabs/lex 1.47.0 → 1.47.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.
Files changed (95) hide show
  1. package/dist/LexConfig.d.ts +79 -0
  2. package/dist/LexConfig.js +13 -3
  3. package/dist/commands/ai/ai.d.ts +17 -0
  4. package/dist/commands/ai/ai.js +10 -10
  5. package/dist/commands/ai/index.d.ts +8 -0
  6. package/dist/commands/ai/index.js +1 -1
  7. package/dist/commands/build/build.cli.test.d.ts +5 -0
  8. package/dist/commands/build/build.d.ts +18 -0
  9. package/dist/commands/build/build.integration.test.d.ts +1 -0
  10. package/dist/commands/build/build.js +58 -8
  11. package/dist/commands/build/build.options.test.d.ts +5 -0
  12. package/dist/commands/clean/clean.cli.test.d.ts +1 -0
  13. package/dist/commands/clean/clean.d.ts +7 -0
  14. package/dist/commands/clean/clean.integration.test.d.ts +1 -0
  15. package/dist/commands/clean/clean.options.test.d.ts +1 -0
  16. package/dist/commands/compile/compile.cli.test.d.ts +1 -0
  17. package/dist/commands/compile/compile.d.ts +2 -0
  18. package/dist/commands/compile/compile.integration.test.d.ts +1 -0
  19. package/dist/commands/compile/compile.js +50 -6
  20. package/dist/commands/compile/compile.options.test.d.ts +1 -0
  21. package/dist/commands/config/config.cli.test.d.ts +1 -0
  22. package/dist/commands/config/config.d.ts +7 -0
  23. package/dist/commands/config/config.integration.test.d.ts +1 -0
  24. package/dist/commands/config/config.options.test.d.ts +1 -0
  25. package/dist/commands/copy/copy.cli.test.d.ts +1 -0
  26. package/dist/commands/copy/copy.d.ts +6 -0
  27. package/dist/commands/copy/copy.integration.test.d.ts +1 -0
  28. package/dist/commands/copy/copy.options.test.d.ts +1 -0
  29. package/dist/commands/create/create.cli.test.d.ts +1 -0
  30. package/dist/commands/create/create.d.ts +8 -0
  31. package/dist/commands/create/create.integration.test.d.ts +1 -0
  32. package/dist/commands/create/create.options.test.d.ts +1 -0
  33. package/dist/commands/dev/dev.cli.test.d.ts +1 -0
  34. package/dist/commands/dev/dev.d.ts +11 -0
  35. package/dist/commands/dev/dev.integration.test.d.ts +1 -0
  36. package/dist/commands/dev/dev.options.test.d.ts +1 -0
  37. package/dist/commands/init/init.cli.test.d.ts +1 -0
  38. package/dist/commands/init/init.d.ts +9 -0
  39. package/dist/commands/init/init.integration.test.d.ts +1 -0
  40. package/dist/commands/init/init.options.test.d.ts +1 -0
  41. package/dist/commands/link/link.cli.test.d.ts +1 -0
  42. package/dist/commands/link/link.d.ts +6 -0
  43. package/dist/commands/link/link.integration.test.d.ts +1 -0
  44. package/dist/commands/link/link.options.test.d.ts +1 -0
  45. package/dist/commands/lint/autofix.d.ts +2 -0
  46. package/dist/commands/lint/lint.cli.test.d.ts +1 -0
  47. package/dist/commands/lint/lint.d.ts +39 -0
  48. package/dist/commands/lint/lint.integration.test.d.ts +1 -0
  49. package/dist/commands/lint/lint.js +198 -34
  50. package/dist/commands/lint/lint.options.test.d.ts +1 -0
  51. package/dist/commands/migrate/migrate.cli.test.d.ts +1 -0
  52. package/dist/commands/migrate/migrate.d.ts +7 -0
  53. package/dist/commands/migrate/migrate.integration.test.d.ts +1 -0
  54. package/dist/commands/migrate/migrate.options.test.d.ts +1 -0
  55. package/dist/commands/publish/publish.cli.test.d.ts +1 -0
  56. package/dist/commands/publish/publish.d.ts +12 -0
  57. package/dist/commands/publish/publish.integration.test.d.ts +1 -0
  58. package/dist/commands/publish/publish.options.test.d.ts +1 -0
  59. package/dist/commands/test/test.cli.test.d.ts +1 -0
  60. package/dist/commands/test/test.d.ts +50 -0
  61. package/dist/commands/test/test.integration.test.d.ts +1 -0
  62. package/dist/commands/test/test.js +5 -5
  63. package/dist/commands/test/test.options.test.d.ts +1 -0
  64. package/dist/commands/test/test.test.d.ts +1 -0
  65. package/dist/commands/update/update.cli.test.d.ts +1 -0
  66. package/dist/commands/update/update.d.ts +9 -0
  67. package/dist/commands/update/update.integration.test.d.ts +1 -0
  68. package/dist/commands/update/update.js +92 -23
  69. package/dist/commands/update/update.options.test.d.ts +1 -0
  70. package/dist/commands/upgrade/upgrade.cli.test.d.ts +1 -0
  71. package/dist/commands/upgrade/upgrade.d.ts +7 -0
  72. package/dist/commands/upgrade/upgrade.integration.test.d.ts +1 -0
  73. package/dist/commands/upgrade/upgrade.options.test.d.ts +1 -0
  74. package/dist/commands/versions/versions.cli.test.d.ts +1 -0
  75. package/dist/commands/versions/versions.d.ts +13 -0
  76. package/dist/commands/versions/versions.integration.test.d.ts +1 -0
  77. package/dist/commands/versions/versions.options.test.d.ts +1 -0
  78. package/dist/create/changelog.d.ts +6 -0
  79. package/dist/index.d.ts +31 -0
  80. package/dist/lex.d.ts +2 -0
  81. package/dist/types.d.ts +5 -0
  82. package/dist/utils/aiService.d.ts +9 -0
  83. package/dist/utils/aiService.js +17 -8
  84. package/dist/utils/app.d.ts +41 -0
  85. package/dist/utils/app.js +51 -1
  86. package/dist/utils/file.d.ts +3 -0
  87. package/dist/utils/file.js +18 -3
  88. package/dist/utils/log.d.ts +1 -0
  89. package/dist/utils/reactShim.d.ts +2 -0
  90. package/eslint.config.js +1 -6
  91. package/jest.config.lex.js +22 -26
  92. package/package.json +22 -19
  93. package/resolver.cjs +125 -14
  94. /package/{dist/jest.config.lex.d.ts → jest.config.lex.d.ts} +0 -0
  95. /package/{dist/webpack.config.d.ts → webpack.config.d.ts} +0 -0
@@ -119,9 +119,11 @@ const ensureModuleType = (cwd) => {
119
119
  }
120
120
  }
121
121
  };
122
- const installDependencies = async (_cwd, useTypescript, quiet) => {
122
+ const installDependencies = async (cwd, useTypescript, quiet) => {
123
123
  if (useTypescript) {
124
- log("Using TypeScript ESLint dependencies from lex...", "info", quiet);
124
+ log("Using TypeScript ESLint from Lex...", "info", quiet);
125
+ } else {
126
+ log("Using ESLint from Lex...", "info", quiet);
125
127
  }
126
128
  };
127
129
  const runEslintWithLex = async (cwd, quiet, cliName, fix, debug, useTypescript, captureOutput) => {
@@ -147,10 +149,15 @@ const runEslintWithLex = async (cwd, quiet, cliName, fix, debug, useTypescript,
147
149
  }
148
150
  }
149
151
  const configPath = hasProjectConfig ? projectConfigPath : lexConfigPath || projectConfigPath;
150
- const jsResult = await execa("npx", [
151
- "-p",
152
- "eslint",
153
- "eslint",
152
+ const lexEslintPath = pathResolve(__dirname, "../../../node_modules/.bin/eslint");
153
+ const globalLexEslintPath = pathResolve(process.env.LEX_HOME || "/usr/local/lib/node_modules/@nlabs/lex", "node_modules/.bin/eslint");
154
+ let eslintBinary = "eslint";
155
+ if (existsSync(lexEslintPath)) {
156
+ eslintBinary = lexEslintPath;
157
+ } else if (existsSync(globalLexEslintPath)) {
158
+ eslintBinary = globalLexEslintPath;
159
+ }
160
+ const jsResult = await execa(eslintBinary, [
154
161
  "src/**/*.{js,jsx}",
155
162
  "--config",
156
163
  configPath,
@@ -180,14 +187,7 @@ const runEslintWithLex = async (cwd, quiet, cliName, fix, debug, useTypescript,
180
187
  }
181
188
  let tsResult = { exitCode: 0, stdout: "", stderr: "" };
182
189
  if (useTypescript) {
183
- tsResult = await execa("npx", [
184
- "-p",
185
- "eslint",
186
- "-p",
187
- "@typescript-eslint/parser",
188
- "-p",
189
- "@typescript-eslint/eslint-plugin",
190
- "eslint",
190
+ tsResult = await execa(eslintBinary, [
191
191
  "src/**/*.{ts,tsx}",
192
192
  "--config",
193
193
  configPath,
@@ -210,6 +210,14 @@ const runEslintWithLex = async (cwd, quiet, cliName, fix, debug, useTypescript,
210
210
  console.error(tsResult.stderr);
211
211
  }
212
212
  }
213
+ const eslintNotFound = jsResult.stderr?.includes("command not found") || jsResult.stderr?.includes("eslint: command not found");
214
+ if (eslintNotFound) {
215
+ spinner.fail("ESLint not found!");
216
+ log(`
217
+ ${cliName} Error: Lex's ESLint binary not found. This may be a Lex installation issue.`, "error", quiet);
218
+ log("Please try reinstalling Lex: npm install -g @nlabs/lex", "info", quiet);
219
+ return 1;
220
+ }
213
221
  if (jsResult.exitCode === 0 && tsResult.exitCode === 0) {
214
222
  spinner.succeed("Linting completed!");
215
223
  return 0;
@@ -306,7 +314,73 @@ const applyAIFix = async (cwd, errors, quiet) => {
306
314
  3. Replacing console.log with log utility
307
315
  4. Fixing no-plusplus issues
308
316
  5. Fixing unnecessary escape characters
309
- 6. Fixing other ESLint errors`;
317
+ 6. Fixing other ESLint errors
318
+
319
+ CRITICAL REQUIREMENTS:
320
+ - ONLY fix the specific lines with ESLint errors
321
+ - DO NOT modify any other lines of code
322
+ - DO NOT remove line breaks unless they are specifically causing ESLint errors
323
+ - DO NOT condense multi-line structures to single lines
324
+ - PRESERVE all existing line breaks and formatting that is not causing errors
325
+
326
+ SPECIFIC FORMATTING RULES:
327
+ - Maintain proper indentation (2 spaces)
328
+ - Keep line breaks between class/interface declaration and their members
329
+ - Keep line breaks between methods
330
+ - Ensure there is a line break after opening braces for classes, interfaces, and methods
331
+ - DO NOT place class/interface properties or methods on the same line as the opening brace
332
+ - Preserve empty lines between logical code blocks
333
+ - PRESERVE multi-line imports - do not condense them to single lines
334
+ - PRESERVE multi-line object/array declarations - do not condense them to single lines
335
+
336
+ SORT-KEYS RULE (HIGHEST PRIORITY):
337
+ - All object literal keys MUST be sorted alphabetically in ascending order
338
+ - This applies to ALL objects in the file, not just those with explicit sort-keys errors
339
+ - Example: {b: 2, a: 1, c: 3} should become {a: 1, b: 2, c: 3}
340
+ - Preserve the original formatting and line breaks when sorting
341
+
342
+ Example of CORRECT formatting (DO NOT CHANGE):
343
+ export class UserConstants {
344
+ static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';
345
+ static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';
346
+ }
347
+
348
+ constructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {
349
+ this.CustomAdapter = CustomAdapter;
350
+ this.flux = flux;
351
+ }
352
+
353
+ import {
354
+ app,
355
+ events,
356
+ images,
357
+ locations,
358
+ messages,
359
+ posts,
360
+ tags,
361
+ users,
362
+ websocket
363
+ } from './stores';
364
+
365
+ const config = {
366
+ apiKey: 'value',
367
+ baseUrl: 'https://api.example.com',
368
+ timeout: 5000
369
+ };
370
+
371
+ Example of INCORRECT formatting (FIX THIS):
372
+ export class UserConstants {static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';
373
+ static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';
374
+ }
375
+
376
+ constructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {this.CustomAdapter = CustomAdapter;
377
+ this.flux = flux;}
378
+
379
+ import {app, events, images, locations, messages, posts, tags, users, websocket} from './stores';
380
+
381
+ const config = {baseUrl: 'https://api.example.com', apiKey: 'value', timeout: 5000};
382
+
383
+ Fix ONLY the specific ESLint errors. Return the properly formatted code.`;
310
384
  try {
311
385
  const promptFile = pathResolve(cwd, ".cursor_prompt_temp.txt");
312
386
  writeFileSync(promptFile, prompt, "utf8");
@@ -348,7 +422,95 @@ Here's the code:
348
422
  ${fileContent}
349
423
  \`\`\`
350
424
 
351
- Return only the fixed code without any explanations.`;
425
+ CRITICAL REQUIREMENTS:
426
+ - ONLY fix the specific lines with ESLint errors
427
+ - DO NOT modify any other lines of code
428
+ - DO NOT remove line breaks unless they are specifically causing ESLint errors
429
+ - DO NOT condense multi-line structures to single lines
430
+ - PRESERVE all existing line breaks and formatting that is not causing errors
431
+
432
+ SPECIFIC FORMATTING RULES:
433
+ - Maintain proper indentation (2 spaces)
434
+ - Keep line breaks between class/interface declaration and their members
435
+ - Keep line breaks between methods
436
+ - Ensure there is a line break after opening braces for classes, interfaces, and methods
437
+ - DO NOT place class/interface properties or methods on the same line as the opening brace
438
+ - Preserve empty lines between logical code blocks
439
+ - PRESERVE multi-line imports - do not condense them to single lines
440
+ - PRESERVE multi-line object/array declarations - do not condense them to single lines
441
+
442
+ SORT-KEYS RULE (HIGHEST PRIORITY):
443
+ - All object literal keys MUST be sorted alphabetically in ascending order
444
+ - This applies to ALL objects in the file, not just those with explicit sort-keys errors
445
+ - Example: {b: 2, a: 1, c: 3} should become {a: 1, b: 2, c: 3}
446
+ - Preserve the original formatting and line breaks when sorting
447
+
448
+ WHAT TO FIX:
449
+ 1. Sorting all object keys alphabetically (sort-keys rule) - ALL objects must have sorted keys
450
+ 2. Fixing naming conventions - ONLY for variables/functions with naming errors
451
+ 3. Replacing console.log with log utility - ONLY for console.log statements
452
+ 4. Fixing no-plusplus issues - ONLY for ++/-- operators
453
+ 5. Fixing unnecessary escape characters - ONLY for escaped characters that don't need escaping
454
+ 6. Proper indentation and spacing - ONLY where specifically required by errors
455
+ 7. String quotes consistency (use single quotes) - ONLY for string literals with quote errors
456
+ 8. Import order and spacing - ONLY for imports with order/spacing errors
457
+ 9. Function parameter formatting - ONLY for functions with parameter errors
458
+ 10. Variable naming conventions - ONLY for variables with naming errors
459
+ 11. No unused variables or imports - ONLY for unused variables/imports
460
+ 12. Avoiding nested ternaries - ONLY for nested ternary expressions
461
+ 13. Any other ESLint errors - ONLY for the specific errors listed above
462
+
463
+ WHAT NOT TO FIX:
464
+ - Do not change properly formatted multi-line structures
465
+ - Do not remove line breaks that are not causing errors
466
+ - Do not change indentation that is already correct
467
+ - Do not modify spacing that is already correct
468
+ - Do not condense readable multi-line code to single lines
469
+ - Do not modify code that is not mentioned in the ESLint errors
470
+
471
+ Example of CORRECT formatting (DO NOT CHANGE):
472
+ export class UserConstants {
473
+ static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';
474
+ static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';
475
+ }
476
+
477
+ constructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {
478
+ this.CustomAdapter = CustomAdapter;
479
+ this.flux = flux;
480
+ }
481
+
482
+ import {
483
+ app,
484
+ events,
485
+ images,
486
+ locations,
487
+ messages,
488
+ posts,
489
+ tags,
490
+ users,
491
+ websocket
492
+ } from './stores';
493
+
494
+ const config = {
495
+ apiKey: 'value',
496
+ baseUrl: 'https://api.example.com',
497
+ timeout: 5000
498
+ };
499
+
500
+ Example of INCORRECT formatting (FIX THIS):
501
+ export class UserConstants {static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';
502
+ static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';
503
+ }
504
+
505
+ constructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {this.CustomAdapter = CustomAdapter;
506
+ this.flux = flux;}
507
+
508
+ import {app, events, images, locations, messages, posts, tags, users, websocket} from './stores';
509
+
510
+ const config = {baseUrl: 'https://api.example.com', apiKey: 'value', timeout: 5000};
511
+
512
+ Fix ONLY the specific ESLint errors listed above. Review the entire file for compliance with all ESLint rules.
513
+ Return only the properly formatted fixed code without any explanations.`;
352
514
  const fixedContent = await callAIService(prompt, quiet);
353
515
  if (fixedContent && fixedContent !== fileContent) {
354
516
  writeFileSync(filePath, fixedContent, "utf8");
@@ -447,12 +609,7 @@ const applyDirectFixes = async (filePath, quiet) => {
447
609
  );
448
610
  newContent = newContent.replace(
449
611
  /const prefix = type === 'error' \? '❌ ' : type === 'success' \? '✅ ' : 'ℹ️ ';/,
450
- `let prefix = '\u2139\uFE0F ';
451
- if(type === 'error') {
452
- prefix = '\u274C ';
453
- } else if(type === 'success') {
454
- prefix = '\u2705 ';
455
- }`
612
+ "let prefix = '\u2139\uFE0F ';\nif(type === 'error') {\n prefix = '\u274C ';\n} else if(type === 'success') {\n prefix = '\u2705 ';\n}"
456
613
  );
457
614
  newContent = newContent.replace(
458
615
  /async function runEslintFix\(\)/g,
@@ -515,17 +672,25 @@ if(type === 'error') {
515
672
  }
516
673
  };
517
674
  const loadAIConfig = async (cwd, quiet) => {
518
- const lexConfigPath = pathResolve(cwd, "lex.config.js");
519
- const lexConfigExists = existsSync(lexConfigPath);
520
- if (lexConfigExists) {
675
+ const configFormats = ["js", "mjs", "cjs", "ts", "json"];
676
+ const configBaseName = "lex.config";
677
+ let lexConfigPath = "";
678
+ for (const format of configFormats) {
679
+ const potentialPath = pathResolve(cwd, `./${configBaseName}.${format}`);
680
+ if (existsSync(potentialPath)) {
681
+ lexConfigPath = potentialPath;
682
+ break;
683
+ }
684
+ }
685
+ if (lexConfigPath) {
521
686
  try {
522
687
  const lexConfig = await import(lexConfigPath);
523
688
  if (lexConfig.default && lexConfig.default.ai) {
524
- log("Found AI configuration in lex.config.js, applying settings...", "info", quiet);
689
+ log(`Found AI configuration in ${pathResolve(cwd, lexConfigPath)}, applying settings...`, "info", quiet);
525
690
  LexConfig.config.ai = { ...LexConfig.config.ai, ...lexConfig.default.ai };
526
691
  }
527
692
  } catch (error) {
528
- log(`Error loading AI configuration from lex.config.js: ${error.message}`, "warn", quiet);
693
+ log(`Error loading AI configuration from ${lexConfigPath}: ${error.message}`, "warn", quiet);
529
694
  }
530
695
  }
531
696
  };
@@ -614,11 +779,11 @@ const lint = async (cmd, callback = process.exit) => {
614
779
  const afterFixResult = await runEslintWithLex(cwd, quiet, cliName, false, debug, useTypescript);
615
780
  callback(afterFixResult);
616
781
  return afterFixResult;
617
- } else {
618
- log("ESLint could not fix all issues automatically.", "warn", quiet);
619
- log("To enable AI-powered fixes, add AI configuration to your lex.config.js:", "info", quiet);
620
- log(`
621
- // In lex.config.js
782
+ }
783
+ log("ESLint could not fix all issues automatically.", "warn", quiet);
784
+ log("To enable AI-powered fixes, add AI configuration to your lex.config file:", "info", quiet);
785
+ log(`
786
+ // In lex.config.js (or lex.config.mjs, lex.config.cjs, etc.)
622
787
  export default {
623
788
  // Your existing config
624
789
  ai: {
@@ -626,7 +791,6 @@ export default {
626
791
  // Additional provider-specific settings
627
792
  }
628
793
  };`, "info", quiet);
629
- }
630
794
  }
631
795
  callback(result);
632
796
  return result;
@@ -653,4 +817,4 @@ ${cliName} Error: ${error.message}`, "error", quiet);
653
817
  export {
654
818
  lint
655
819
  };
656
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/lint/lint.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2022-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {existsSync, writeFileSync, readFileSync, unlinkSync} from 'fs';\nimport {resolve as pathResolve, dirname} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\n// Create __dirname equivalent for ESM\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = dirname(__filename);\n\nexport interface LintOptions {\n  readonly cache?: boolean;\n  readonly cacheFile?: string;\n  readonly cacheLocation?: string;\n  readonly cliName?: string;\n  readonly color?: boolean;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly env?: string;\n  readonly envInfo?: boolean;\n  readonly ext?: string;\n  readonly fix?: boolean;\n  readonly fixDryRun?: boolean;\n  readonly fixType?: string;\n  readonly format?: string;\n  readonly global?: string;\n  readonly ignorePath?: string;\n  readonly ignorePattern?: string;\n  readonly init?: boolean;\n  readonly maxWarnings?: string;\n  readonly noColor?: boolean;\n  readonly noEslintrc?: boolean;\n  readonly noIgnore?: boolean;\n  readonly noInlineConfig?: boolean;\n  readonly outputFile?: string;\n  readonly parser?: string;\n  readonly parserOptions?: string;\n  readonly plugin?: string;\n  readonly printConfig?: string;\n  readonly quiet?: boolean;\n  readonly reportUnusedDisableDirectives?: boolean;\n  readonly resolvePluginsRelativeTo?: string;\n  readonly rule?: string;\n  readonly rulesdir?: string;\n  readonly stdin?: boolean;\n  readonly stdinFilename?: string;\n}\n\nexport type LintCallback = typeof process.exit;\n\ninterface ConfigResult {\n  configPath: string;\n  originalConfig: string | null;\n}\n\n/**\n * Create a temporary ESLint config file\n */\nconst createDefaultESLintConfig = (useTypescript: boolean, cwd: string): ConfigResult => {\n  // Create a flat config file for ESLint 9.x\n  const configPath = pathResolve(cwd, 'eslint.config.js');\n\n  // Save the original config if it exists\n  let originalConfig = null;\n  if(existsSync(configPath)) {\n    try {\n      originalConfig = readFileSync(configPath, 'utf8');\n    } catch(_error) {\n      // Ignore errors\n    }\n  }\n\n  // Try to find Lex's eslint.config.js to copy\n  // Try different potential locations for the Lex config\n  const possiblePaths = [\n    // From src/commands/lint/lint.ts to root\n    pathResolve(__dirname, '../../../../eslint.config.js'),\n    // From packages/lex/src/commands/lint/lint.ts to packages/lex\n    pathResolve(__dirname, '../../../eslint.config.js'),\n    // From packages/lex/src/commands/lint/lint.ts to root\n    pathResolve(__dirname, '../../../../../eslint.config.js'),\n    // Absolute path if Lex is installed globally\n    pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.js')\n  ];\n\n  let foundConfig = '';\n  for(const path of possiblePaths) {\n    if(existsSync(path)) {\n      foundConfig = path;\n      break;\n    }\n  }\n\n  let eslintConfig;\n\n  if(foundConfig) {\n    // Copy Lex's config file\n    try {\n      eslintConfig = readFileSync(foundConfig, 'utf8');\n    } catch(_error) {\n      // Fall back to default config if we can't read Lex's config\n      eslintConfig = createBasicESLintConfig(useTypescript);\n    }\n  } else {\n    // Create a simple config if Lex's config doesn't exist\n    eslintConfig = createBasicESLintConfig(useTypescript);\n  }\n\n  // Write the config\n  writeFileSync(configPath, eslintConfig, 'utf8');\n\n  // Return both the config path and the original config\n  return {\n    configPath,\n    originalConfig\n  };\n};\n\n/**\n * Create a basic ESLint config as a fallback\n */\nconst createBasicESLintConfig = (useTypescript: boolean): string => {\n  let config = `// ESLint configuration\nexport default [\n  {\n    ignores: ['**/node_modules/**', '**/dist/**', '**/build/**']\n  },\n  // Config for JavaScript files\n  {\n    files: ['**/*.{js,jsx}'],\n    languageOptions: {\n      ecmaVersion: 'latest',\n      sourceType: 'module'\n    },\n    rules: {\n      'indent': ['error', 2],\n      'quotes': ['error', 'single'],\n      'semi': ['error', 'always'],\n      'no-unused-vars': ['warn', { 'argsIgnorePattern': '^_', 'varsIgnorePattern': '^_', 'caughtErrors': 'all', 'caughtErrorsIgnorePattern': '^_' }],\n      'eqeqeq': ['error', 'always']\n    }\n  }`;\n\n  // Add TypeScript configuration if needed\n  if(useTypescript) {\n    config += `,\n  // Config for TypeScript files\n  {\n    files: ['**/*.{ts,tsx}'],\n    languageOptions: {\n      ecmaVersion: 'latest',\n      sourceType: 'module',\n      parser: {\n        importSource: '@typescript-eslint/parser'\n      },\n      parserOptions: {\n        project: './tsconfig.json'\n      }\n    },\n    plugins: {\n      '@typescript-eslint': {\n        importSource: '@typescript-eslint/eslint-plugin'\n      }\n    },\n    rules: {\n      'indent': ['error', 2],\n      'quotes': ['error', 'single'],\n      'semi': ['error', 'always'],\n      'no-unused-vars': 'off',\n      '@typescript-eslint/no-unused-vars': ['warn', { 'argsIgnorePattern': '^_', 'varsIgnorePattern': '^_', 'caughtErrors': 'all', 'caughtErrorsIgnorePattern': '^_' }],\n      'eqeqeq': ['error', 'always']\n    }\n  }`;\n  }\n\n  // Close the array\n  config += `\n];`;\n\n  return config;\n};\n\n/**\n * Check if TypeScript is being used by looking for tsconfig.json\n */\nconst detectTypeScript = (cwd: string): boolean => existsSync(pathResolve(cwd, 'tsconfig.json'));\n\n/**\n * Ensure package.json has type: module for ESM support\n */\nconst ensureModuleType = (cwd: string): void => {\n  const packageJsonPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(packageJsonPath)) {\n    try {\n      const packageJsonContent = readFileSync(packageJsonPath, 'utf8');\n      const packageJson = JSON.parse(packageJsonContent);\n\n      // If type is not set to module, set it\n      if(packageJson.type !== 'module') {\n        packageJson.type = 'module';\n        writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2), 'utf8');\n      }\n    } catch(_error) {\n      // Ignore errors\n    }\n  }\n};\n\n/**\n * No need to install dependencies as we'll use the ones from lex\n */\nconst installDependencies = async (_cwd: string, useTypescript: boolean, quiet: boolean): Promise<void> => {\n  if(useTypescript) {\n    log('Using TypeScript ESLint dependencies from lex...', 'info', quiet);\n  }\n};\n\n// Function removed as it's no longer needed\n\n/**\n * Run ESLint directly from lex's node_modules\n */\nconst runEslintWithLex = async (\n  cwd: string,\n  quiet: boolean,\n  cliName: string,\n  fix: boolean,\n  debug: boolean,\n  useTypescript: boolean,\n  captureOutput?: (output: string) => void\n): Promise<number> => {\n  const spinner = createSpinner(quiet);\n\n  try {\n    // Determine which ESLint config to use\n    // First check if the project has its own eslint.config.js\n    const projectConfigPath = pathResolve(cwd, 'eslint.config.js');\n    const hasProjectConfig = existsSync(projectConfigPath);\n\n    // If not, try to find Lex's default config\n    // Try different potential locations for the Lex config\n    const possiblePaths = [\n      // From src/commands/lint/lint.ts to root\n      pathResolve(__dirname, '../../../../eslint.config.js'),\n      // From packages/lex/src/commands/lint/lint.ts to packages/lex\n      pathResolve(__dirname, '../../../eslint.config.js'),\n      // From packages/lex/src/commands/lint/lint.ts to root\n      pathResolve(__dirname, '../../../../../eslint.config.js'),\n      // Absolute path if Lex is installed globally\n      pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.js')\n    ];\n\n    let lexConfigPath = '';\n    for(const path of possiblePaths) {\n      if(existsSync(path)) {\n        lexConfigPath = path;\n        break;\n      }\n    }\n\n    // Determine which config file to use\n    const configPath = hasProjectConfig ? projectConfigPath : (lexConfigPath || projectConfigPath);\n\n    // Use npx to run eslint - this will use the one from lex if available\n    // or download a temporary one if needed\n\n    // Run eslint on JS files with config using npx with package specification\n    const jsResult = await execa('npx', [\n      '-p', 'eslint',\n      'eslint',\n      'src/**/*.{js,jsx}',\n      '--config', configPath, // Use the determined config\n      ...(fix ? ['--fix'] : []),\n      ...(debug ? ['--debug'] : []),\n      '--no-error-on-unmatched-pattern' // Don't error if no files are found\n    ], {\n      reject: false,\n      stdio: 'pipe',\n      cwd,\n      shell: true // Needed for glob pattern expansion\n    });\n\n    // Display JS output and capture it if needed\n    if(jsResult.stdout) {\n      console.log(jsResult.stdout);\n      if(captureOutput) {\n        captureOutput(jsResult.stdout);\n      }\n    }\n\n    if(jsResult.stderr) {\n      console.error(jsResult.stderr);\n      if(captureOutput) {\n        captureOutput(jsResult.stderr);\n      }\n    }\n\n    // Run eslint on TS files if needed\n    let tsResult: any = {exitCode: 0, stdout: '', stderr: ''};\n    if(useTypescript) {\n      tsResult = await execa('npx', [\n        '-p', 'eslint',\n        '-p', '@typescript-eslint/parser',\n        '-p', '@typescript-eslint/eslint-plugin',\n        'eslint',\n        'src/**/*.{ts,tsx}',\n        '--config', configPath, // Use the determined config\n        ...(fix ? ['--fix'] : []),\n        ...(debug ? ['--debug'] : []),\n        '--no-error-on-unmatched-pattern' // Don't error if no files are found\n      ], {\n        reject: false,\n        stdio: 'pipe',\n        cwd,\n        shell: true // Needed for glob pattern expansion\n      });\n\n      // Display TS output\n      if(tsResult.stdout) {\n        console.log(tsResult.stdout);\n      }\n\n      if(tsResult.stderr) {\n        console.error(tsResult.stderr);\n      }\n    }\n\n    // Success if both exit codes are 0\n    if(jsResult.exitCode === 0 && tsResult.exitCode === 0) {\n      spinner.succeed('Linting completed!');\n      return 0;\n    }\n    // Check for special cases - no files found\n    const noFilesFound =\n        (jsResult.stderr?.includes('No such file or directory') || jsResult.stdout?.includes('No such file or directory')) &&\n        (!useTypescript || tsResult.stderr?.includes('No such file or directory') || tsResult.stdout?.includes('No such file or directory'));\n\n    if(noFilesFound) {\n      spinner.succeed('No files found to lint');\n      return 0;\n    }\n    spinner.fail('Linting failed!');\n    log(`\\n${cliName} Error: ESLint found issues in your code.`, 'error', quiet);\n    return 1;\n  } catch(error) {\n    spinner.fail('Linting failed!');\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    return 1;\n  }\n};\n\n/**\n * Use AI to fix linting errors that couldn't be fixed automatically\n */\nconst applyAIFix = async (\n  cwd: string,\n  errors: string,\n  quiet: boolean\n): Promise<void> => {\n  const spinner = createSpinner(quiet);\n  spinner.start('Using AI to fix remaining lint issues...');\n\n  try {\n    // Extract file paths and errors from the ESLint output\n    const fileErrorMap = new Map<string, string[]>();\n    const lines = errors.split('\\n');\n    let currentFile = '';\n\n    // Improved parsing of ESLint output\n    for(const line of lines) {\n      // Match file paths (they typically start with / or C:\\ on Windows)\n      if(line.match(/^(\\/|[A-Z]:\\\\).*?\\.(js|jsx|ts|tsx)$/)) {\n        currentFile = line.trim();\n        if(!fileErrorMap.has(currentFile)) {\n          fileErrorMap.set(currentFile, []);\n        }\n      }\n      // Match error lines (they typically have line:column format)\n      else if(currentFile && line.trim() && line.match(/\\s+\\d+:\\d+\\s+(error|warning)\\s+/)) {\n        const errorArray = fileErrorMap.get(currentFile);\n        if(errorArray) {\n          errorArray.push(line.trim());\n        }\n      }\n    }\n\n    // If no errors were found using the regex approach, try a different parsing strategy\n    if(fileErrorMap.size === 0) {\n      log('Using alternative error parsing strategy', 'info', quiet);\n\n      // Reset and try a different parsing approach\n      const sections = errors.split('\\n\\n');\n\n      for(const section of sections) {\n        if(section.trim() === '') {\n          continue;\n        }\n\n        const lines = section.split('\\n');\n        const filePath = lines[0].trim();\n\n        // Only process if it looks like a file path\n        if(filePath.match(/\\.(js|jsx|ts|tsx)$/)) {\n          fileErrorMap.set(filePath, []);\n\n          for(let i = 1; i < lines.length; i++) {\n            if(lines[i].trim() !== '') {\n              fileErrorMap.get(filePath)?.push(lines[i].trim());\n            }\n          }\n        }\n      }\n    }\n\n    // If still no files found, try to extract file paths directly\n    if(fileErrorMap.size === 0) {\n      log('Using direct file path extraction', 'info', quiet);\n      \n      // Find all file paths in the error output\n      const filePathRegex = /(?:\\/|[A-Z]:\\\\)(?:[^:\\n]+\\/)*[^:\\n]+\\.(js|jsx|ts|tsx)/g;\n      const filePaths = errors.match(filePathRegex) || [];\n      \n      for(const filePath of filePaths) {\n        if(!fileErrorMap.has(filePath) && existsSync(filePath)) {\n          fileErrorMap.set(filePath, []);\n        }\n      }\n      \n      // Add known problematic files if they exist\n      const knownFiles = [\n        '/Users/nitrog7/Development/lex/packages/lex/src/create/changelog.ts',\n        '/Users/nitrog7/Development/lex/packages/lex/src/utils/aiService.ts',\n        '/Users/nitrog7/Development/lex/packages/lex/src/utils/app.ts',\n        '/Users/nitrog7/Development/lex/packages/lex/src/utils/reactShim.ts',\n        '/Users/nitrog7/Development/lex/packages/lex/src/commands/lint/autofix.js'\n      ];\n      \n      for(const file of knownFiles) {\n        if(existsSync(file) && !fileErrorMap.has(file)) {\n          fileErrorMap.set(file, []);\n        }\n      }\n    }\n\n    // Process each file with errors\n    for(const filePath of fileErrorMap.keys()) {\n      if(!existsSync(filePath)) {\n        log(`File not found: ${filePath}`, 'warn', quiet);\n        continue;\n      }\n\n      log(`Processing file: ${filePath}`, 'info', quiet);\n      \n      // Check if we're running in Cursor IDE\n      const isCursorIDE = LexConfig.config.ai?.provider === 'cursor' || process.env.CURSOR_IDE === 'true';\n      \n      if(isCursorIDE) {\n        // If we're in Cursor IDE, use its built-in AI capabilities\n        try {\n          // Create a prompt for Cursor AI\n          const prompt = `Fix all ESLint errors in this file. Focus on:\n1. Fixing naming conventions\n2. Fixing sort-keys issues\n3. Replacing console.log with log utility\n4. Fixing no-plusplus issues\n5. Fixing unnecessary escape characters\n6. Fixing other ESLint errors`;\n\n          // Try to use Cursor CLI if available\n          try {\n            // Create a temporary prompt file\n            const promptFile = pathResolve(cwd, '.cursor_prompt_temp.txt');\n            writeFileSync(promptFile, prompt, 'utf8');\n            \n            // Use Cursor CLI to fix the file\n            await execa('cursor', ['edit', '--file', filePath, '--prompt-file', promptFile], {\n              reject: false,\n              stdio: 'pipe',\n              cwd\n            });\n            \n            // Clean up\n            try {\n              unlinkSync(promptFile);\n            } catch(_error) {\n              // Ignore cleanup errors\n            }\n            \n            log(`Applied Cursor AI fixes to ${filePath}`, 'info', quiet);\n          } catch(error) {\n            // If Cursor CLI fails, fall back to direct fixes\n            const wasModified = await applyDirectFixes(filePath, quiet);\n            if(wasModified) {\n              log(`Applied direct fixes to ${filePath}`, 'info', quiet);\n            }\n          }\n        } catch(error) {\n          log(`Error using Cursor AI: ${error.message}`, 'error', quiet);\n          // Fall back to direct fixes\n          await applyDirectFixes(filePath, quiet);\n        }\n      } else {\n        // For non-Cursor environments, apply direct fixes and then use AI service\n        const wasModified = await applyDirectFixes(filePath, quiet);\n        if(wasModified) {\n          log(`Applied direct fixes to ${filePath}`, 'info', quiet);\n        }\n        \n        // For remaining issues, use the AI service\n        const fileErrors = fileErrorMap.get(filePath) || [];\n        if(fileErrors.length > 0) {\n          try {\n            // Import the AI service dynamically to avoid circular dependencies\n            const {callAIService} = await import('../../utils/aiService.js');\n            \n            // Read the file content again in case it was modified by automated fixes\n            const fileContent = readFileSync(filePath, 'utf8');\n            \n            // Prepare a prompt for AI\n            const prompt = `Fix the following ESLint errors in this code:\n${fileErrors.join('\\n')}\n\nHere's the code:\n\\`\\`\\`\n${fileContent}\n\\`\\`\\`\n\nReturn only the fixed code without any explanations.`;\n            \n            // Call the AI service to get fixed code\n            const fixedContent = await callAIService(prompt, quiet);\n            \n            if(fixedContent && fixedContent !== fileContent) {\n              writeFileSync(filePath, fixedContent, 'utf8');\n              log(`Applied AI fixes to ${filePath}`, 'info', quiet);\n            }\n          } catch(error) {\n            log(`Error applying AI fixes to ${filePath}: ${error.message}`, 'error', quiet);\n          }\n        }\n      }\n    }\n\n    spinner.succeed('AI fixes applied successfully!');\n  } catch(error) {\n    spinner.fail('Failed to apply AI fixes');\n    log(`Error: ${error.message}`, 'error', quiet);\n    if(!quiet) {\n      console.error(error);\n    }\n  }\n};\n\n/**\n * Apply direct fixes to common ESLint issues\n */\nconst applyDirectFixes = async (filePath: string, quiet: boolean): Promise<boolean> => {\n  let wasModified = false;\n  \n  try {\n    // Read file content\n    const fileContent = readFileSync(filePath, 'utf8');\n    let newContent = fileContent;\n    \n    // Fix issues based on filename\n    if(filePath.includes('aiService.ts')) {\n      log('Fixing issues in aiService.ts', 'info', quiet);\n      \n      // Fix the order of keys in headers objects\n      newContent = newContent.replace(\n        /'Content-Type': 'application\\/json',\\s*'Authorization': `Bearer/g,\n        '\\'Authorization\\': `Bearer\\', \\'Content-Type\\': \\'application/json\\''\n      );\n      \n      // Fix method and headers order\n      newContent = newContent.replace(\n        /headers: {([^}]*)},\\s*method: 'POST'/g,\n        'method: \\'POST\\',\\n      headers: {$1}'\n      );\n      \n      // Fix role and content order\n      newContent = newContent.replace(\n        /{role: 'system', content:/g,\n        '{content:, role: \\'system\\','\n      );\n      newContent = newContent.replace(\n        /{role: 'user', content:/g,\n        '{content:, role: \\'user\\','\n      );\n      \n      // Fix naming convention issues - parameter names with leading underscores\n      newContent = newContent.replace(\n        /\\(([^)]*?)_([a-zA-Z0-9]+)(\\s*:[^)]*)\\)/g,\n        '($1$2$3)'\n      );\n      \n      // Replace console.log statements\n      newContent = newContent.replace(/console\\.log\\(/g, 'log(');\n      \n      // Add log import if needed\n      if(!newContent.includes('import {log}') && newContent.includes('log(')) {\n        newContent = newContent.replace(\n          /import {([^}]*)} from '(.*)';/,\n          'import {$1} from \\'$2\\';\\nimport {log} from \\'./log.js\\';'\n        );\n      }\n    }\n    \n    // Fix reactShim.ts naming conventions\n    if(filePath.includes('reactShim.ts')) {\n      log('Fixing naming-convention issues in reactShim.ts', 'info', quiet);\n      \n      // Fix React import naming\n      newContent = newContent.replace(\n        'import * as React from',\n        'import * as react from'\n      );\n      \n      // Fix React usage\n      newContent = newContent.replace(/React\\./g, 'react.');\n    }\n    \n    // Fix changelog.ts issues\n    if(filePath.includes('changelog.ts')) {\n      log('Fixing issues in changelog.ts', 'info', quiet);\n      \n      // Fix no-plusplus\n      newContent = newContent.replace(/(\\w+)\\+\\+/g, '$1 += 1');\n      \n      // Fix unnecessary escape characters\n      newContent = newContent.replace(/\\\\\\$/g, '$');\n      newContent = newContent.replace(/\\\\\\./g, '.');\n      newContent = newContent.replace(/\\\\\\*/g, '*');\n      newContent = newContent.replace(/\\\\:/g, ':');\n    }\n    \n    // Fix app.ts issues\n    if(filePath.includes('app.ts')) {\n      log('Fixing issues in app.ts', 'info', quiet);\n      \n      // Fix console.log\n      newContent = newContent.replace(/console\\.log\\(/g, 'log(');\n      \n      // Add log import if needed\n      if(!newContent.includes('import {log}') && newContent.includes('log(')) {\n        newContent = newContent.replace(\n          /import boxen from 'boxen';/,\n          'import boxen from \\'boxen\\';\\nimport {log} from \\'./log.js\\';'\n        );\n      }\n      \n      // Fix unnecessary escape characters\n      newContent = newContent.replace(/\\\\\\//g, '/');\n    }\n    \n    // Fix autofix.js issues\n    if(filePath.includes('autofix.js')) {\n      log('Fixing issues in autofix.js', 'info', quiet);\n      \n      // Fix import style\n      newContent = newContent.replace(\n        /import {([^}]*)} from 'path';[\\s\\n]*import {([^}]*)} from 'path';/,\n        'import {$1, $2} from \\'path\\';'\n      );\n      \n      // Fix variable naming convention\n      newContent = newContent.replace(\n        /__filename/g,\n        'currentFilename'\n      );\n      newContent = newContent.replace(\n        /__dirname/g,\n        'currentDirname'\n      );\n      \n      // Fix nested ternary\n      newContent = newContent.replace(\n        /const prefix = type === 'error' \\? '\u274C ' : type === 'success' \\? '\u2705 ' : '\u2139\uFE0F ';/,\n        `let prefix = '\u2139\uFE0F ';\\nif(type === 'error') {\\n  prefix = '\u274C ';\\n} else if(type === 'success') {\\n  prefix = '\u2705 ';\\n}`\n      );\n      \n      // Fix function style\n      newContent = newContent.replace(\n        /async function runEslintFix\\(\\)/g,\n        'const runEslintFix = async ()'\n      );\n      newContent = newContent.replace(\n        /async function getFilesWithErrors\\(\\)/g,\n        'const getFilesWithErrors = async ()'\n      );\n      newContent = newContent.replace(\n        /async function isCursorAvailable\\(\\)/g,\n        'const isCursorAvailable = async ()'\n      );\n      newContent = newContent.replace(\n        /async function fixFileWithCursorAI\\(filePath\\)/g,\n        'const fixFileWithCursorAI = async (filePath)'\n      );\n      newContent = newContent.replace(\n        /async function main\\(\\)/g,\n        'const main = async ()'\n      );\n      \n      // Fix unused variables\n      newContent = newContent.replace(\n        /import {existsSync, readFileSync, writeFileSync}/g,\n        'import {writeFileSync}'\n      );\n      \n      // Fix console.log\n      newContent = newContent.replace(\n        /console\\.log\\(`\\${prefix} \\${message}`\\);/g,\n        'process.stdout.write(`${prefix} ${message}\\\\n`);'\n      );\n      \n      // Fix unused error variables\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*\\/\\/ Ignore cleanup errors/g,\n        '} catch(_) {\\n      // Ignore cleanup errors'\n      );\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*log\\(/g,\n        '} catch(err) {\\n    log('\n      );\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*return false;/g,\n        '} catch(_) {\\n    return false;'\n      );\n      \n      // Fix await in loop\n      newContent = newContent.replace(\n        /for\\(const filePath of filesWithErrors\\) {[\\s\\n]*const success = await fixFileWithCursorAI\\(filePath\\);/g,\n        'const fixResults = await Promise.all(filesWithErrors.map(filePath => fixFileWithCursorAI(filePath)));\\nfor(const success of fixResults) {'\n      );\n      \n      // Fix increment\n      newContent = newContent.replace(\n        /fixedCount\\+\\+;/g,\n        'fixedCount += 1;'\n      );\n    }\n    \n    // Write the modified content back if changes were made\n    if(newContent !== fileContent) {\n      writeFileSync(filePath, newContent, 'utf8');\n      log(`Fixed issues in ${filePath}`, 'info', quiet);\n      wasModified = true;\n    }\n    \n    return wasModified;\n  } catch(error) {\n    log(`Error applying direct fixes to ${filePath}: ${error.message}`, 'error', quiet);\n    return false;\n  }\n};\n\n/**\n * Check for AI configuration in main lex.config.js file\n */\nconst loadAIConfig = async (cwd: string, quiet: boolean): Promise<void> => {\n  const lexConfigPath = pathResolve(cwd, 'lex.config.js');\n  const lexConfigExists = existsSync(lexConfigPath);\n\n  if(lexConfigExists) {\n    try {\n      const lexConfig = await import(lexConfigPath);\n      if(lexConfig.default && lexConfig.default.ai) {\n        log('Found AI configuration in lex.config.js, applying settings...', 'info', quiet);\n        // Update the AI configuration in LexConfig\n        LexConfig.config.ai = {...LexConfig.config.ai, ...lexConfig.default.ai};\n      }\n    } catch(error) {\n      log(`Error loading AI configuration from lex.config.js: ${error.message}`, 'warn', quiet);\n    }\n  }\n};\n\nexport const lint = async (cmd: LintOptions, callback: LintCallback = process.exit): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    fix = false,\n    debug = false,\n    quiet = false,\n    config = null\n  } = cmd;\n\n  log(`${cliName} linting...`, 'info', quiet);\n\n  const cwd = process.cwd();\n  const spinner = createSpinner(quiet);\n\n  // Load AI configuration if available\n  await loadAIConfig(cwd, quiet);\n\n  // Track if we need to restore an original config\n  let originalConfig: string | null = null;\n  let tempConfigPath: string | null = null;\n\n  try {\n    // Detect TypeScript directly\n    const useTypescript = detectTypeScript(cwd);\n    log(`TypeScript ${useTypescript ? 'detected' : 'not detected'} from tsconfig.json`, 'info', quiet);\n\n    // Ensure package.json has type: module for ESM support\n    ensureModuleType(cwd);\n\n    // Install necessary dependencies\n    await installDependencies(cwd, useTypescript, quiet);\n\n    // Check for ESLint configuration files\n    const projectConfigPath = pathResolve(cwd, 'eslint.config.js');\n    const hasEslintConfig = existsSync(projectConfigPath) ||\n                          existsSync(pathResolve(cwd, '.eslintrc.js')) ||\n                          existsSync(pathResolve(cwd, '.eslintrc.json')) ||\n                          existsSync(pathResolve(cwd, '.eslintrc.yml')) ||\n                          existsSync(pathResolve(cwd, '.eslintrc.yaml')) ||\n                          existsSync(pathResolve(cwd, '.eslintrc'));\n\n    // Remove any existing .eslintrc.json file to avoid conflicts with eslint.config.js\n    if(existsSync(pathResolve(cwd, '.eslintrc.json'))) {\n      unlinkSync(pathResolve(cwd, '.eslintrc.json'));\n    }\n\n    // Try to find Lex's ESLint config if needed\n    let lexConfigPath = '';\n    let shouldCreateTempConfig = false;\n\n    if(!hasEslintConfig) {\n      // Try different potential locations for the Lex config\n      const possiblePaths = [\n        // From src/commands/lint/lint.ts to root\n        pathResolve(__dirname, '../../../../eslint.config.js'),\n        // From packages/lex/src/commands/lint/lint.ts to packages/lex\n        pathResolve(__dirname, '../../../eslint.config.js'),\n        // From packages/lex/src/commands/lint/lint.ts to root\n        pathResolve(__dirname, '../../../../../eslint.config.js'),\n        // Absolute path if Lex is installed globally\n        pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.js')\n      ];\n\n      // Find the first existing config\n      for(const path of possiblePaths) {\n        if(existsSync(path)) {\n          lexConfigPath = path;\n          break;\n        }\n      }\n\n      if(debug) {\n        log(`Current directory: ${__dirname}`, 'info', quiet);\n        log(`Project config path: ${projectConfigPath}`, 'info', quiet);\n        log(`Project config exists: ${hasEslintConfig}`, 'info', quiet);\n        log(`Found Lex config: ${lexConfigPath}`, 'info', quiet);\n        log(`Lex config exists: ${!!lexConfigPath && existsSync(lexConfigPath)}`, 'info', quiet);\n      }\n\n      // If we found Lex's config, use it\n      if(lexConfigPath && existsSync(lexConfigPath)) {\n        log('No ESLint configuration found in project. Using Lex\\'s default configuration.', 'info', quiet);\n      } else {\n        // Otherwise, we need to create a temporary config\n        shouldCreateTempConfig = true;\n      }\n    }\n\n    // If user specified a config file, use that\n    if(config) {\n      const userConfigPath = pathResolve(cwd, config);\n      if(existsSync(userConfigPath)) {\n        log(`Using specified ESLint configuration: ${config}`, 'info', quiet);\n        // User-specified config takes precedence\n        shouldCreateTempConfig = false;\n      } else {\n        log(`Specified ESLint configuration not found: ${config}. Using Lex's default configuration.`, 'warn', quiet);\n      }\n    }\n\n    // Create a temporary config if needed\n    if(shouldCreateTempConfig) {\n      log('No ESLint configuration found. Creating a temporary configuration...', 'info', quiet);\n      const configResult = createDefaultESLintConfig(useTypescript, cwd);\n      tempConfigPath = configResult.configPath;\n      originalConfig = configResult.originalConfig;\n    }\n\n    // Capture the ESLint output for AI fix if needed\n    let eslintOutput = '';\n    const captureOutput = (output: string) => {\n      eslintOutput += `${output}\\n`;\n    };\n\n    // Always run ESLint with --fix first to apply built-in fixes\n    const result = await runEslintWithLex(cwd, quiet, cliName, true, debug, useTypescript, captureOutput);\n\n    // If there are still errors and fix flag is set, try to fix them with AI\n    if(result !== 0 && fix) {\n      // Check if AI is configured\n      const aiConfigured = LexConfig.config.ai?.provider && LexConfig.config.ai.provider !== 'none';\n\n      if(aiConfigured) {\n        log('Applying AI fixes to remaining issues...', 'info', quiet);\n        await applyAIFix(cwd, eslintOutput, quiet);\n\n        // Run ESLint again to check if all issues are fixed\n        const afterFixResult = await runEslintWithLex(cwd, quiet, cliName, false, debug, useTypescript);\n\n        // Return the result of the second run\n        callback(afterFixResult);\n        return afterFixResult;\n      } else {\n        // If AI is not configured, suggest configuring it\n        log('ESLint could not fix all issues automatically.', 'warn', quiet);\n        log('To enable AI-powered fixes, add AI configuration to your lex.config.js:', 'info', quiet);\n        log(`\n// In lex.config.js\nexport default {\n  // Your existing config\n  ai: {\n    provider: 'cursor' // or 'openai', 'anthropic', etc.\n    // Additional provider-specific settings\n  }\n};`, 'info', quiet);\n      }\n    }\n\n    callback(result);\n    return result;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    spinner.fail('Linting failed!');\n    callback(1);\n    return 1;\n  } finally {\n    // Restore the original config if we created a temporary one\n    if(tempConfigPath && originalConfig) {\n      try {\n        writeFileSync(tempConfigPath, originalConfig, 'utf8');\n      } catch(_error) {\n        // Ignore errors\n      }\n    } else if(tempConfigPath) {\n      // Remove the temporary config if there was no original\n      try {\n        unlinkSync(tempConfigPath);\n      } catch(_error) {\n        // Ignore errors\n      }\n    }\n  }\n};"],
  "mappings": "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",
  "names": ["lines"]
}

820
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/lint/lint.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2022-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {existsSync, writeFileSync, readFileSync, unlinkSync} from 'fs';\nimport {resolve as pathResolve, dirname} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\n// Create __dirname equivalent for ESM\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = dirname(__filename);\n\nexport interface LintOptions {\n  readonly cache?: boolean;\n  readonly cacheFile?: string;\n  readonly cacheLocation?: string;\n  readonly cliName?: string;\n  readonly color?: boolean;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly env?: string;\n  readonly envInfo?: boolean;\n  readonly ext?: string;\n  readonly fix?: boolean;\n  readonly fixDryRun?: boolean;\n  readonly fixType?: string;\n  readonly format?: string;\n  readonly global?: string;\n  readonly ignorePath?: string;\n  readonly ignorePattern?: string;\n  readonly init?: boolean;\n  readonly maxWarnings?: string;\n  readonly noColor?: boolean;\n  readonly noEslintrc?: boolean;\n  readonly noIgnore?: boolean;\n  readonly noInlineConfig?: boolean;\n  readonly outputFile?: string;\n  readonly parser?: string;\n  readonly parserOptions?: string;\n  readonly plugin?: string;\n  readonly printConfig?: string;\n  readonly quiet?: boolean;\n  readonly reportUnusedDisableDirectives?: boolean;\n  readonly resolvePluginsRelativeTo?: string;\n  readonly rule?: string;\n  readonly rulesdir?: string;\n  readonly stdin?: boolean;\n  readonly stdinFilename?: string;\n}\n\nexport type LintCallback = typeof process.exit;\n\ninterface ConfigResult {\n  configPath: string;\n  originalConfig: string | null;\n}\n\n/**\n * Create a temporary ESLint config file\n */\nconst createDefaultESLintConfig = (useTypescript: boolean, cwd: string): ConfigResult => {\n  // Create a flat config file for ESLint 9.x\n  const configPath = pathResolve(cwd, 'eslint.config.js');\n\n  // Save the original config if it exists\n  let originalConfig = null;\n  if(existsSync(configPath)) {\n    try {\n      originalConfig = readFileSync(configPath, 'utf8');\n    } catch(_error) {\n      // Ignore errors\n    }\n  }\n\n  // Try to find Lex's eslint.config.js to copy\n  // Try different potential locations for the Lex config\n  const possiblePaths = [\n    // From src/commands/lint/lint.ts to root\n    pathResolve(__dirname, '../../../../eslint.config.js'),\n    // From packages/lex/src/commands/lint/lint.ts to packages/lex\n    pathResolve(__dirname, '../../../eslint.config.js'),\n    // From packages/lex/src/commands/lint/lint.ts to root\n    pathResolve(__dirname, '../../../../../eslint.config.js'),\n    // Absolute path if Lex is installed globally\n    pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.js')\n  ];\n\n  let foundConfig = '';\n  for(const path of possiblePaths) {\n    if(existsSync(path)) {\n      foundConfig = path;\n      break;\n    }\n  }\n\n  let eslintConfig;\n\n  if(foundConfig) {\n    // Copy Lex's config file\n    try {\n      eslintConfig = readFileSync(foundConfig, 'utf8');\n    } catch(_error) {\n      // Fall back to default config if we can't read Lex's config\n      eslintConfig = createBasicESLintConfig(useTypescript);\n    }\n  } else {\n    // Create a simple config if Lex's config doesn't exist\n    eslintConfig = createBasicESLintConfig(useTypescript);\n  }\n\n  // Write the config\n  writeFileSync(configPath, eslintConfig, 'utf8');\n\n  // Return both the config path and the original config\n  return {\n    configPath,\n    originalConfig\n  };\n};\n\n/**\n * Create a basic ESLint config as a fallback\n */\nconst createBasicESLintConfig = (useTypescript: boolean): string => {\n  let config = `// ESLint configuration\nexport default [\n  {\n    ignores: ['**/node_modules/**', '**/dist/**', '**/build/**']\n  },\n  // Config for JavaScript files\n  {\n    files: ['**/*.{js,jsx}'],\n    languageOptions: {\n      ecmaVersion: 'latest',\n      sourceType: 'module'\n    },\n    rules: {\n      'indent': ['error', 2],\n      'quotes': ['error', 'single'],\n      'semi': ['error', 'always'],\n      'no-unused-vars': ['warn', { 'argsIgnorePattern': '^_', 'varsIgnorePattern': '^_', 'caughtErrors': 'all', 'caughtErrorsIgnorePattern': '^_' }],\n      'eqeqeq': ['error', 'always']\n    }\n  }`;\n\n  // Add TypeScript configuration if needed\n  if(useTypescript) {\n    config += `,\n  // Config for TypeScript files\n  {\n    files: ['**/*.{ts,tsx}'],\n    languageOptions: {\n      ecmaVersion: 'latest',\n      sourceType: 'module',\n      parser: {\n        importSource: '@typescript-eslint/parser'\n      },\n      parserOptions: {\n        project: './tsconfig.json'\n      }\n    },\n    plugins: {\n      '@typescript-eslint': {\n        importSource: '@typescript-eslint/eslint-plugin'\n      }\n    },\n    rules: {\n      'indent': ['error', 2],\n      'quotes': ['error', 'single'],\n      'semi': ['error', 'always'],\n      'no-unused-vars': 'off',\n      '@typescript-eslint/no-unused-vars': ['warn', { 'argsIgnorePattern': '^_', 'varsIgnorePattern': '^_', 'caughtErrors': 'all', 'caughtErrorsIgnorePattern': '^_' }],\n      'eqeqeq': ['error', 'always']\n    }\n  }`;\n  }\n\n  // Close the array\n  config += `\n];`;\n\n  return config;\n};\n\n/**\n * Check if TypeScript is being used by looking for tsconfig.json\n */\nconst detectTypeScript = (cwd: string): boolean => existsSync(pathResolve(cwd, 'tsconfig.json'));\n\n/**\n * Ensure package.json has type: module for ESM support\n */\nconst ensureModuleType = (cwd: string): void => {\n  const packageJsonPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(packageJsonPath)) {\n    try {\n      const packageJsonContent = readFileSync(packageJsonPath, 'utf8');\n      const packageJson = JSON.parse(packageJsonContent);\n\n      // If type is not set to module, set it\n      if(packageJson.type !== 'module') {\n        packageJson.type = 'module';\n        writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2), 'utf8');\n      }\n    } catch(_error) {\n      // Ignore errors\n    }\n  }\n};\n\n/**\n * Log which ESLint version is being used\n * Lex provides its own ESLint, so no installation is needed in the project\n */\nconst installDependencies = async (cwd: string, useTypescript: boolean, quiet: boolean): Promise<void> => {\n  // Lex provides its own ESLint, so we don't need to install it in the project\n  if(useTypescript) {\n    log('Using TypeScript ESLint from Lex...', 'info', quiet);\n  } else {\n    log('Using ESLint from Lex...', 'info', quiet);\n  }\n};\n\n// Function removed as it's no longer needed\n\n/**\n * Run ESLint using Lex's own ESLint binary\n */\nconst runEslintWithLex = async (\n  cwd: string,\n  quiet: boolean,\n  cliName: string,\n  fix: boolean,\n  debug: boolean,\n  useTypescript: boolean,\n  captureOutput?: (output: string) => void\n): Promise<number> => {\n  const spinner = createSpinner(quiet);\n\n  try {\n    // Determine which ESLint config to use\n    // First check if the project has its own eslint.config.js\n    const projectConfigPath = pathResolve(cwd, 'eslint.config.js');\n    const hasProjectConfig = existsSync(projectConfigPath);\n\n    // If not, try to find Lex's default config\n    // Try different potential locations for the Lex config\n    const possiblePaths = [\n      // From src/commands/lint/lint.ts to root\n      pathResolve(__dirname, '../../../../eslint.config.js'),\n      // From packages/lex/src/commands/lint/lint.ts to packages/lex\n      pathResolve(__dirname, '../../../eslint.config.js'),\n      // From packages/lex/src/commands/lint/lint.ts to root\n      pathResolve(__dirname, '../../../../../eslint.config.js'),\n      // Absolute path if Lex is installed globally\n      pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.js')\n    ];\n\n    let lexConfigPath = '';\n    for(const path of possiblePaths) {\n      if(existsSync(path)) {\n        lexConfigPath = path;\n        break;\n      }\n    }\n\n    // Determine which config file to use\n    const configPath = hasProjectConfig ? projectConfigPath : (lexConfigPath || projectConfigPath);\n\n    // Find Lex's ESLint binary\n    const lexEslintPath = pathResolve(__dirname, '../../../node_modules/.bin/eslint');\n    const globalLexEslintPath = pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'node_modules/.bin/eslint');\n\n    let eslintBinary = 'eslint'; // fallback to npx\n    if(existsSync(lexEslintPath)) {\n      eslintBinary = lexEslintPath;\n    } else if(existsSync(globalLexEslintPath)) {\n      eslintBinary = globalLexEslintPath;\n    }\n\n    // Run eslint on JS files with config using Lex's ESLint\n    const jsResult = await execa(eslintBinary, [\n      'src/**/*.{js,jsx}',\n      '--config', configPath, // Use the determined config\n      ...(fix ? ['--fix'] : []),\n      ...(debug ? ['--debug'] : []),\n      '--no-error-on-unmatched-pattern' // Don't error if no files are found\n    ], {\n      reject: false,\n      stdio: 'pipe',\n      cwd,\n      shell: true // Needed for glob pattern expansion\n    });\n\n    // Display JS output and capture it if needed\n    if(jsResult.stdout) {\n      console.log(jsResult.stdout);\n      if(captureOutput) {\n        captureOutput(jsResult.stdout);\n      }\n    }\n\n    if(jsResult.stderr) {\n      console.error(jsResult.stderr);\n      if(captureOutput) {\n        captureOutput(jsResult.stderr);\n      }\n    }\n\n    // Run eslint on TS files if needed\n    let tsResult: any = {exitCode: 0, stdout: '', stderr: ''};\n    if(useTypescript) {\n      tsResult = await execa(eslintBinary, [\n        'src/**/*.{ts,tsx}',\n        '--config', configPath, // Use the determined config\n        ...(fix ? ['--fix'] : []),\n        ...(debug ? ['--debug'] : []),\n        '--no-error-on-unmatched-pattern' // Don't error if no files are found\n      ], {\n        reject: false,\n        stdio: 'pipe',\n        cwd,\n        shell: true // Needed for glob pattern expansion\n      });\n\n      // Display TS output\n      if(tsResult.stdout) {\n        console.log(tsResult.stdout);\n      }\n\n      if(tsResult.stderr) {\n        console.error(tsResult.stderr);\n      }\n    }\n\n    // Check for ESLint command not found error\n    const eslintNotFound = jsResult.stderr?.includes('command not found') || jsResult.stderr?.includes('eslint: command not found');\n    if(eslintNotFound) {\n      spinner.fail('ESLint not found!');\n      log(`\\n${cliName} Error: Lex's ESLint binary not found. This may be a Lex installation issue.`, 'error', quiet);\n      log('Please try reinstalling Lex: npm install -g @nlabs/lex', 'info', quiet);\n      return 1;\n    }\n\n    // Success if both exit codes are 0\n    if(jsResult.exitCode === 0 && tsResult.exitCode === 0) {\n      spinner.succeed('Linting completed!');\n      return 0;\n    }\n    // Check for special cases - no files found\n    const noFilesFound =\n        (jsResult.stderr?.includes('No such file or directory') || jsResult.stdout?.includes('No such file or directory')) &&\n        (!useTypescript || tsResult.stderr?.includes('No such file or directory') || tsResult.stdout?.includes('No such file or directory'));\n\n    if(noFilesFound) {\n      spinner.succeed('No files found to lint');\n      return 0;\n    }\n    spinner.fail('Linting failed!');\n    log(`\\n${cliName} Error: ESLint found issues in your code.`, 'error', quiet);\n    return 1;\n  } catch(error) {\n    spinner.fail('Linting failed!');\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    return 1;\n  }\n};\n\n/**\n * Use AI to fix linting errors that couldn't be fixed automatically\n */\nconst applyAIFix = async (\n  cwd: string,\n  errors: string,\n  quiet: boolean\n): Promise<void> => {\n  const spinner = createSpinner(quiet);\n  spinner.start('Using AI to fix remaining lint issues...');\n\n  try {\n    // Extract file paths and errors from the ESLint output\n    const fileErrorMap = new Map<string, string[]>();\n    const lines = errors.split('\\n');\n    let currentFile = '';\n\n    // Improved parsing of ESLint output\n    for(const line of lines) {\n      // Match file paths (they typically start with / or C:\\ on Windows)\n      if(line.match(/^(\\/|[A-Z]:\\\\).*?\\.(js|jsx|ts|tsx)$/)) {\n        currentFile = line.trim();\n        if(!fileErrorMap.has(currentFile)) {\n          fileErrorMap.set(currentFile, []);\n        }\n      }\n      // Match error lines (they typically have line:column format)\n      else if(currentFile && line.trim() && line.match(/\\s+\\d+:\\d+\\s+(error|warning)\\s+/)) {\n        const errorArray = fileErrorMap.get(currentFile);\n        if(errorArray) {\n          errorArray.push(line.trim());\n        }\n      }\n    }\n\n    // If no errors were found using the regex approach, try a different parsing strategy\n    if(fileErrorMap.size === 0) {\n      log('Using alternative error parsing strategy', 'info', quiet);\n\n      // Reset and try a different parsing approach\n      const sections = errors.split('\\n\\n');\n\n      for(const section of sections) {\n        if(section.trim() === '') {\n          continue;\n        }\n\n        const lines = section.split('\\n');\n        const filePath = lines[0].trim();\n\n        // Only process if it looks like a file path\n        if(filePath.match(/\\.(js|jsx|ts|tsx)$/)) {\n          fileErrorMap.set(filePath, []);\n\n          for(let i = 1; i < lines.length; i++) {\n            if(lines[i].trim() !== '') {\n              fileErrorMap.get(filePath)?.push(lines[i].trim());\n            }\n          }\n        }\n      }\n    }\n\n    // If still no files found, try to extract file paths directly\n    if(fileErrorMap.size === 0) {\n      log('Using direct file path extraction', 'info', quiet);\n\n      // Find all file paths in the error output\n      const filePathRegex = /(?:\\/|[A-Z]:\\\\)(?:[^:\\n]+\\/)*[^:\\n]+\\.(js|jsx|ts|tsx)/g;\n      const filePaths = errors.match(filePathRegex) || [];\n\n      for(const filePath of filePaths) {\n        if(!fileErrorMap.has(filePath) && existsSync(filePath)) {\n          fileErrorMap.set(filePath, []);\n        }\n      }\n\n      // Add known problematic files if they exist\n      const knownFiles = [\n        '/Users/nitrog7/Development/lex/packages/lex/src/create/changelog.ts',\n        '/Users/nitrog7/Development/lex/packages/lex/src/utils/aiService.ts',\n        '/Users/nitrog7/Development/lex/packages/lex/src/utils/app.ts',\n        '/Users/nitrog7/Development/lex/packages/lex/src/utils/reactShim.ts',\n        '/Users/nitrog7/Development/lex/packages/lex/src/commands/lint/autofix.js'\n      ];\n\n      for(const file of knownFiles) {\n        if(existsSync(file) && !fileErrorMap.has(file)) {\n          fileErrorMap.set(file, []);\n        }\n      }\n    }\n\n    // Process each file with errors\n    for(const filePath of fileErrorMap.keys()) {\n      if(!existsSync(filePath)) {\n        log(`File not found: ${filePath}`, 'warn', quiet);\n        continue;\n      }\n\n      log(`Processing file: ${filePath}`, 'info', quiet);\n\n      // Check if we're running in Cursor IDE\n      const isCursorIDE = LexConfig.config.ai?.provider === 'cursor' || process.env.CURSOR_IDE === 'true';\n\n      if(isCursorIDE) {\n        // If we're in Cursor IDE, use its built-in AI capabilities\n        try {\n          // Create a prompt for Cursor AI\n          const prompt = `Fix all ESLint errors in this file. Focus on:\n1. Fixing naming conventions\n2. Fixing sort-keys issues\n3. Replacing console.log with log utility\n4. Fixing no-plusplus issues\n5. Fixing unnecessary escape characters\n6. Fixing other ESLint errors\n\nCRITICAL REQUIREMENTS:\n- ONLY fix the specific lines with ESLint errors\n- DO NOT modify any other lines of code\n- DO NOT remove line breaks unless they are specifically causing ESLint errors\n- DO NOT condense multi-line structures to single lines\n- PRESERVE all existing line breaks and formatting that is not causing errors\n\nSPECIFIC FORMATTING RULES:\n- Maintain proper indentation (2 spaces)\n- Keep line breaks between class/interface declaration and their members\n- Keep line breaks between methods\n- Ensure there is a line break after opening braces for classes, interfaces, and methods\n- DO NOT place class/interface properties or methods on the same line as the opening brace\n- Preserve empty lines between logical code blocks\n- PRESERVE multi-line imports - do not condense them to single lines\n- PRESERVE multi-line object/array declarations - do not condense them to single lines\n\nSORT-KEYS RULE (HIGHEST PRIORITY):\n- All object literal keys MUST be sorted alphabetically in ascending order\n- This applies to ALL objects in the file, not just those with explicit sort-keys errors\n- Example: {b: 2, a: 1, c: 3} should become {a: 1, b: 2, c: 3}\n- Preserve the original formatting and line breaks when sorting\n\nExample of CORRECT formatting (DO NOT CHANGE):\nexport class UserConstants {\n  static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {\n  this.CustomAdapter = CustomAdapter;\n  this.flux = flux;\n}\n\nimport {\n  app,\n  events,\n  images,\n  locations,\n  messages,\n  posts,\n  tags,\n  users,\n  websocket\n} from './stores';\n\nconst config = {\n  apiKey: 'value',\n  baseUrl: 'https://api.example.com',\n  timeout: 5000\n};\n\nExample of INCORRECT formatting (FIX THIS):\nexport class UserConstants {static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {this.CustomAdapter = CustomAdapter;\n  this.flux = flux;}\n\nimport {app, events, images, locations, messages, posts, tags, users, websocket} from './stores';\n\nconst config = {baseUrl: 'https://api.example.com', apiKey: 'value', timeout: 5000};\n\nFix ONLY the specific ESLint errors. Return the properly formatted code.`;\n\n          // Try to use Cursor CLI if available\n          try {\n            // Create a temporary prompt file\n            const promptFile = pathResolve(cwd, '.cursor_prompt_temp.txt');\n            writeFileSync(promptFile, prompt, 'utf8');\n\n            // Use Cursor CLI to fix the file\n            await execa('cursor', ['edit', '--file', filePath, '--prompt-file', promptFile], {\n              reject: false,\n              stdio: 'pipe',\n              cwd\n            });\n\n            // Clean up\n            try {\n              unlinkSync(promptFile);\n            } catch(_error) {\n              // Ignore cleanup errors\n            }\n\n            log(`Applied Cursor AI fixes to ${filePath}`, 'info', quiet);\n          } catch(error) {\n            // If Cursor CLI fails, fall back to direct fixes\n            const wasModified = await applyDirectFixes(filePath, quiet);\n            if(wasModified) {\n              log(`Applied direct fixes to ${filePath}`, 'info', quiet);\n            }\n          }\n        } catch(error) {\n          log(`Error using Cursor AI: ${error.message}`, 'error', quiet);\n          // Fall back to direct fixes\n          await applyDirectFixes(filePath, quiet);\n        }\n      } else {\n        // For non-Cursor environments, apply direct fixes and then use AI service\n        const wasModified = await applyDirectFixes(filePath, quiet);\n        if(wasModified) {\n          log(`Applied direct fixes to ${filePath}`, 'info', quiet);\n        }\n\n        // For remaining issues, use the AI service\n        const fileErrors = fileErrorMap.get(filePath) || [];\n        if(fileErrors.length > 0) {\n          try {\n            // Import the AI service dynamically to avoid circular dependencies\n            const {callAIService} = await import('../../utils/aiService.js');\n\n            // Read the file content again in case it was modified by automated fixes\n            const fileContent = readFileSync(filePath, 'utf8');\n\n            // Prepare a prompt for AI\n            const prompt = `Fix the following ESLint errors in this code:\n${fileErrors.join('\\n')}\n\nHere's the code:\n\\`\\`\\`\n${fileContent}\n\\`\\`\\`\n\nCRITICAL REQUIREMENTS:\n- ONLY fix the specific lines with ESLint errors\n- DO NOT modify any other lines of code\n- DO NOT remove line breaks unless they are specifically causing ESLint errors\n- DO NOT condense multi-line structures to single lines\n- PRESERVE all existing line breaks and formatting that is not causing errors\n\nSPECIFIC FORMATTING RULES:\n- Maintain proper indentation (2 spaces)\n- Keep line breaks between class/interface declaration and their members\n- Keep line breaks between methods\n- Ensure there is a line break after opening braces for classes, interfaces, and methods\n- DO NOT place class/interface properties or methods on the same line as the opening brace\n- Preserve empty lines between logical code blocks\n- PRESERVE multi-line imports - do not condense them to single lines\n- PRESERVE multi-line object/array declarations - do not condense them to single lines\n\nSORT-KEYS RULE (HIGHEST PRIORITY):\n- All object literal keys MUST be sorted alphabetically in ascending order\n- This applies to ALL objects in the file, not just those with explicit sort-keys errors\n- Example: {b: 2, a: 1, c: 3} should become {a: 1, b: 2, c: 3}\n- Preserve the original formatting and line breaks when sorting\n\nWHAT TO FIX:\n1. Sorting all object keys alphabetically (sort-keys rule) - ALL objects must have sorted keys\n2. Fixing naming conventions - ONLY for variables/functions with naming errors\n3. Replacing console.log with log utility - ONLY for console.log statements\n4. Fixing no-plusplus issues - ONLY for ++/-- operators\n5. Fixing unnecessary escape characters - ONLY for escaped characters that don't need escaping\n6. Proper indentation and spacing - ONLY where specifically required by errors\n7. String quotes consistency (use single quotes) - ONLY for string literals with quote errors\n8. Import order and spacing - ONLY for imports with order/spacing errors\n9. Function parameter formatting - ONLY for functions with parameter errors\n10. Variable naming conventions - ONLY for variables with naming errors\n11. No unused variables or imports - ONLY for unused variables/imports\n12. Avoiding nested ternaries - ONLY for nested ternary expressions\n13. Any other ESLint errors - ONLY for the specific errors listed above\n\nWHAT NOT TO FIX:\n- Do not change properly formatted multi-line structures\n- Do not remove line breaks that are not causing errors\n- Do not change indentation that is already correct\n- Do not modify spacing that is already correct\n- Do not condense readable multi-line code to single lines\n- Do not modify code that is not mentioned in the ESLint errors\n\nExample of CORRECT formatting (DO NOT CHANGE):\nexport class UserConstants {\n  static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {\n  this.CustomAdapter = CustomAdapter;\n  this.flux = flux;\n}\n\nimport {\n  app,\n  events,\n  images,\n  locations,\n  messages,\n  posts,\n  tags,\n  users,\n  websocket\n} from './stores';\n\nconst config = {\n  apiKey: 'value',\n  baseUrl: 'https://api.example.com',\n  timeout: 5000\n};\n\nExample of INCORRECT formatting (FIX THIS):\nexport class UserConstants {static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {this.CustomAdapter = CustomAdapter;\n  this.flux = flux;}\n\nimport {app, events, images, locations, messages, posts, tags, users, websocket} from './stores';\n\nconst config = {baseUrl: 'https://api.example.com', apiKey: 'value', timeout: 5000};\n\nFix ONLY the specific ESLint errors listed above. Review the entire file for compliance with all ESLint rules.\nReturn only the properly formatted fixed code without any explanations.`;\n\n            const fixedContent = await callAIService(prompt, quiet);\n\n            if(fixedContent && fixedContent !== fileContent) {\n              writeFileSync(filePath, fixedContent, 'utf8');\n              log(`Applied AI fixes to ${filePath}`, 'info', quiet);\n            }\n          } catch(error) {\n            log(`Error applying AI fixes to ${filePath}: ${error.message}`, 'error', quiet);\n          }\n        }\n      }\n    }\n\n    spinner.succeed('AI fixes applied successfully!');\n  } catch(error) {\n    spinner.fail('Failed to apply AI fixes');\n    log(`Error: ${error.message}`, 'error', quiet);\n    if(!quiet) {\n      console.error(error);\n    }\n  }\n};\n\n/**\n * Apply direct fixes to common ESLint issues\n */\nconst applyDirectFixes = async (filePath: string, quiet: boolean): Promise<boolean> => {\n  let wasModified = false;\n\n  try {\n    // Read file content\n    const fileContent = readFileSync(filePath, 'utf8');\n    let newContent = fileContent;\n\n    // Fix issues based on filename\n    if(filePath.includes('aiService.ts')) {\n      log('Fixing issues in aiService.ts', 'info', quiet);\n\n      // Fix the order of keys in headers objects\n      newContent = newContent.replace(\n        /'Content-Type': 'application\\/json',\\s*'Authorization': `Bearer/g,\n        '\\'Authorization\\': `Bearer\\', \\'Content-Type\\': \\'application/json\\''\n      );\n\n      // Fix method and headers order\n      newContent = newContent.replace(\n        /headers: {([^}]*)},\\s*method: 'POST'/g,\n        'method: \\'POST\\',\\n      headers: {$1}'\n      );\n\n      // Fix role and content order\n      newContent = newContent.replace(\n        /{role: 'system', content:/g,\n        '{content:, role: \\'system\\','\n      );\n      newContent = newContent.replace(\n        /{role: 'user', content:/g,\n        '{content:, role: \\'user\\','\n      );\n\n      // Fix naming convention issues - parameter names with leading underscores\n      newContent = newContent.replace(\n        /\\(([^)]*?)_([a-zA-Z0-9]+)(\\s*:[^)]*)\\)/g,\n        '($1$2$3)'\n      );\n\n      // Replace console.log statements\n      newContent = newContent.replace(/console\\.log\\(/g, 'log(');\n\n      // Add log import if needed\n      if(!newContent.includes('import {log}') && newContent.includes('log(')) {\n        newContent = newContent.replace(\n          /import {([^}]*)} from '(.*)';/,\n          'import {$1} from \\'$2\\';\\nimport {log} from \\'./log.js\\';'\n        );\n      }\n    }\n\n    // Fix reactShim.ts naming conventions\n    if(filePath.includes('reactShim.ts')) {\n      log('Fixing naming-convention issues in reactShim.ts', 'info', quiet);\n\n      // Fix React import naming\n      newContent = newContent.replace(\n        'import * as React from',\n        'import * as react from'\n      );\n\n      // Fix React usage\n      newContent = newContent.replace(/React\\./g, 'react.');\n    }\n\n    // Fix changelog.ts issues\n    if(filePath.includes('changelog.ts')) {\n      log('Fixing issues in changelog.ts', 'info', quiet);\n\n      // Fix no-plusplus\n      newContent = newContent.replace(/(\\w+)\\+\\+/g, '$1 += 1');\n\n      // Fix unnecessary escape characters\n      newContent = newContent.replace(/\\\\\\$/g, '$');\n      newContent = newContent.replace(/\\\\\\./g, '.');\n      newContent = newContent.replace(/\\\\\\*/g, '*');\n      newContent = newContent.replace(/\\\\:/g, ':');\n    }\n\n    // Fix app.ts issues\n    if(filePath.includes('app.ts')) {\n      log('Fixing issues in app.ts', 'info', quiet);\n\n      // Fix console.log\n      newContent = newContent.replace(/console\\.log\\(/g, 'log(');\n\n      // Add log import if needed\n      if(!newContent.includes('import {log}') && newContent.includes('log(')) {\n        newContent = newContent.replace(\n          /import boxen from 'boxen';/,\n          'import boxen from \\'boxen\\';\\nimport {log} from \\'./log.js\\';'\n        );\n      }\n\n      // Fix unnecessary escape characters\n      newContent = newContent.replace(/\\\\\\//g, '/');\n    }\n\n    // Fix autofix.js issues\n    if(filePath.includes('autofix.js')) {\n      log('Fixing issues in autofix.js', 'info', quiet);\n\n      // Fix import style\n      newContent = newContent.replace(\n        /import {([^}]*)} from 'path';[\\s\\n]*import {([^}]*)} from 'path';/,\n        'import {$1, $2} from \\'path\\';'\n      );\n\n      // Fix variable naming convention\n      newContent = newContent.replace(\n        /__filename/g,\n        'currentFilename'\n      );\n      newContent = newContent.replace(\n        /__dirname/g,\n        'currentDirname'\n      );\n\n      // Fix nested ternary\n      newContent = newContent.replace(\n        /const prefix = type === 'error' \\? '\u274C ' : type === 'success' \\? '\u2705 ' : '\u2139\uFE0F ';/,\n        'let prefix = \\'\u2139\uFE0F \\';\\nif(type === \\'error\\') {\\n  prefix = \\'\u274C \\';\\n} else if(type === \\'success\\') {\\n  prefix = \\'\u2705 \\';\\n}'\n      );\n\n      // Fix function style\n      newContent = newContent.replace(\n        /async function runEslintFix\\(\\)/g,\n        'const runEslintFix = async ()'\n      );\n      newContent = newContent.replace(\n        /async function getFilesWithErrors\\(\\)/g,\n        'const getFilesWithErrors = async ()'\n      );\n      newContent = newContent.replace(\n        /async function isCursorAvailable\\(\\)/g,\n        'const isCursorAvailable = async ()'\n      );\n      newContent = newContent.replace(\n        /async function fixFileWithCursorAI\\(filePath\\)/g,\n        'const fixFileWithCursorAI = async (filePath)'\n      );\n      newContent = newContent.replace(\n        /async function main\\(\\)/g,\n        'const main = async ()'\n      );\n\n      // Fix unused variables\n      newContent = newContent.replace(\n        /import {existsSync, readFileSync, writeFileSync}/g,\n        'import {writeFileSync}'\n      );\n\n      // Fix console.log\n      newContent = newContent.replace(\n        /console\\.log\\(`\\${prefix} \\${message}`\\);/g,\n        'process.stdout.write(`${prefix} ${message}\\\\n`);'\n      );\n\n      // Fix unused error variables\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*\\/\\/ Ignore cleanup errors/g,\n        '} catch(_) {\\n      // Ignore cleanup errors'\n      );\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*log\\(/g,\n        '} catch(err) {\\n    log('\n      );\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*return false;/g,\n        '} catch(_) {\\n    return false;'\n      );\n\n      // Fix await in loop\n      newContent = newContent.replace(\n        /for\\(const filePath of filesWithErrors\\) {[\\s\\n]*const success = await fixFileWithCursorAI\\(filePath\\);/g,\n        'const fixResults = await Promise.all(filesWithErrors.map(filePath => fixFileWithCursorAI(filePath)));\\nfor(const success of fixResults) {'\n      );\n\n      // Fix increment\n      newContent = newContent.replace(\n        /fixedCount\\+\\+;/g,\n        'fixedCount += 1;'\n      );\n    }\n\n    // Write the modified content back if changes were made\n    if(newContent !== fileContent) {\n      writeFileSync(filePath, newContent, 'utf8');\n      log(`Fixed issues in ${filePath}`, 'info', quiet);\n      wasModified = true;\n    }\n\n    return wasModified;\n  } catch(error) {\n    log(`Error applying direct fixes to ${filePath}: ${error.message}`, 'error', quiet);\n    return false;\n  }\n};\n\n/**\n * Check for AI configuration in main lex.config file (supports js, mjs, cjs, ts, json formats)\n */\nconst loadAIConfig = async (cwd: string, quiet: boolean): Promise<void> => {\n  // Search for config files in multiple formats like LexConfig.parseConfig does\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n  const configBaseName = 'lex.config';\n  let lexConfigPath = '';\n\n  for(const format of configFormats) {\n    const potentialPath = pathResolve(cwd, `./${configBaseName}.${format}`);\n    if(existsSync(potentialPath)) {\n      lexConfigPath = potentialPath;\n      break;\n    }\n  }\n\n  if(lexConfigPath) {\n    try {\n      const lexConfig = await import(lexConfigPath);\n      if(lexConfig.default && lexConfig.default.ai) {\n        log(`Found AI configuration in ${pathResolve(cwd, lexConfigPath)}, applying settings...`, 'info', quiet);\n        // Update the AI configuration in LexConfig\n        LexConfig.config.ai = {...LexConfig.config.ai, ...lexConfig.default.ai};\n      }\n    } catch(error) {\n      log(`Error loading AI configuration from ${lexConfigPath}: ${error.message}`, 'warn', quiet);\n    }\n  }\n};\n\nexport const lint = async (cmd: LintOptions, callback: LintCallback = process.exit): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    fix = false,\n    debug = false,\n    quiet = false,\n    config = null\n  } = cmd;\n\n  log(`${cliName} linting...`, 'info', quiet);\n\n  const cwd = process.cwd();\n  const spinner = createSpinner(quiet);\n\n  // Load AI configuration if available\n  await loadAIConfig(cwd, quiet);\n\n  // Track if we need to restore an original config\n  let originalConfig: string | null = null;\n  let tempConfigPath: string | null = null;\n\n  try {\n    // Detect TypeScript directly\n    const useTypescript = detectTypeScript(cwd);\n    log(`TypeScript ${useTypescript ? 'detected' : 'not detected'} from tsconfig.json`, 'info', quiet);\n\n    // Ensure package.json has type: module for ESM support\n    ensureModuleType(cwd);\n\n    // Install necessary dependencies\n    await installDependencies(cwd, useTypescript, quiet);\n\n    // Check for ESLint configuration files\n    const projectConfigPath = pathResolve(cwd, 'eslint.config.js');\n    const hasEslintConfig = existsSync(projectConfigPath) ||\n                          existsSync(pathResolve(cwd, '.eslintrc.js')) ||\n                          existsSync(pathResolve(cwd, '.eslintrc.json')) ||\n                          existsSync(pathResolve(cwd, '.eslintrc.yml')) ||\n                          existsSync(pathResolve(cwd, '.eslintrc.yaml')) ||\n                          existsSync(pathResolve(cwd, '.eslintrc'));\n\n    // Remove any existing .eslintrc.json file to avoid conflicts with eslint.config.js\n    if(existsSync(pathResolve(cwd, '.eslintrc.json'))) {\n      unlinkSync(pathResolve(cwd, '.eslintrc.json'));\n    }\n\n    // Try to find Lex's ESLint config if needed\n    let lexConfigPath = '';\n    let shouldCreateTempConfig = false;\n\n    if(!hasEslintConfig) {\n      // Try different potential locations for the Lex config\n      const possiblePaths = [\n        // From src/commands/lint/lint.ts to root\n        pathResolve(__dirname, '../../../../eslint.config.js'),\n        // From packages/lex/src/commands/lint/lint.ts to packages/lex\n        pathResolve(__dirname, '../../../eslint.config.js'),\n        // From packages/lex/src/commands/lint/lint.ts to root\n        pathResolve(__dirname, '../../../../../eslint.config.js'),\n        // Absolute path if Lex is installed globally\n        pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.js')\n      ];\n\n      // Find the first existing config\n      for(const path of possiblePaths) {\n        if(existsSync(path)) {\n          lexConfigPath = path;\n          break;\n        }\n      }\n\n      if(debug) {\n        log(`Current directory: ${__dirname}`, 'info', quiet);\n        log(`Project config path: ${projectConfigPath}`, 'info', quiet);\n        log(`Project config exists: ${hasEslintConfig}`, 'info', quiet);\n        log(`Found Lex config: ${lexConfigPath}`, 'info', quiet);\n        log(`Lex config exists: ${!!lexConfigPath && existsSync(lexConfigPath)}`, 'info', quiet);\n      }\n\n      // If we found Lex's config, use it\n      if(lexConfigPath && existsSync(lexConfigPath)) {\n        log('No ESLint configuration found in project. Using Lex\\'s default configuration.', 'info', quiet);\n      } else {\n        // Otherwise, we need to create a temporary config\n        shouldCreateTempConfig = true;\n      }\n    }\n\n    // If user specified a config file, use that\n    if(config) {\n      const userConfigPath = pathResolve(cwd, config);\n      if(existsSync(userConfigPath)) {\n        log(`Using specified ESLint configuration: ${config}`, 'info', quiet);\n        // User-specified config takes precedence\n        shouldCreateTempConfig = false;\n      } else {\n        log(`Specified ESLint configuration not found: ${config}. Using Lex's default configuration.`, 'warn', quiet);\n      }\n    }\n\n    // Create a temporary config if needed\n    if(shouldCreateTempConfig) {\n      log('No ESLint configuration found. Creating a temporary configuration...', 'info', quiet);\n      const configResult = createDefaultESLintConfig(useTypescript, cwd);\n      tempConfigPath = configResult.configPath;\n      originalConfig = configResult.originalConfig;\n    }\n\n    // Capture the ESLint output for AI fix if needed\n    let eslintOutput = '';\n    const captureOutput = (output: string) => {\n      eslintOutput += `${output}\\n`;\n    };\n\n    // Always run ESLint with --fix first to apply built-in fixes\n    const result = await runEslintWithLex(cwd, quiet, cliName, true, debug, useTypescript, captureOutput);\n\n    // If there are still errors and fix flag is set, try to fix them with AI\n    if(result !== 0 && fix) {\n      // Check if AI is configured\n      const aiConfigured = LexConfig.config.ai?.provider && LexConfig.config.ai.provider !== 'none';\n\n      if(aiConfigured) {\n        log('Applying AI fixes to remaining issues...', 'info', quiet);\n        await applyAIFix(cwd, eslintOutput, quiet);\n\n        // Run ESLint again to check if all issues are fixed\n        const afterFixResult = await runEslintWithLex(cwd, quiet, cliName, false, debug, useTypescript);\n\n        // Return the result of the second run\n        callback(afterFixResult);\n        return afterFixResult;\n      }\n      // If AI is not configured, suggest configuring it\n      log('ESLint could not fix all issues automatically.', 'warn', quiet);\n      log('To enable AI-powered fixes, add AI configuration to your lex.config file:', 'info', quiet);\n      log(`\n// In lex.config.js (or lex.config.mjs, lex.config.cjs, etc.)\nexport default {\n  // Your existing config\n  ai: {\n    provider: 'cursor' // or 'openai', 'anthropic', etc.\n    // Additional provider-specific settings\n  }\n};`, 'info', quiet);\n    }\n\n    callback(result);\n    return result;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    spinner.fail('Linting failed!');\n    callback(1);\n    return 1;\n  } finally {\n    // Restore the original config if we created a temporary one\n    if(tempConfigPath && originalConfig) {\n      try {\n        writeFileSync(tempConfigPath, originalConfig, 'utf8');\n      } catch(_error) {\n        // Ignore errors\n      }\n    } else if(tempConfigPath) {\n      // Remove the temporary config if there was no original\n      try {\n        unlinkSync(tempConfigPath);\n      } catch(_error) {\n        // Ignore errors\n      }\n    }\n  }\n};"],
  "mappings": "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",
  "names": ["lines"]
}

@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,7 @@
1
+ export interface MigrateOptions {
2
+ readonly cliName?: string;
3
+ readonly packageManager?: string;
4
+ readonly quiet?: boolean;
5
+ }
6
+ export type MigrateCallback = typeof process.exit;
7
+ export declare const migrate: (cmd: MigrateOptions, callback?: MigrateCallback) => Promise<number>;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};