deslop-js 0.0.19-dev.be8757d → 0.0.20-dev.867c5c6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -4883,7 +4883,7 @@ const extractNextConfigPluginFiles = (directory) => {
4883
4883
  const VITEST_INCLUDE_ITEM_PATTERN = /['"]([^'"]+)['"]/g;
4884
4884
  const COVERAGE_BLOCK_PATTERN = /coverage\s*:\s*\{/g;
4885
4885
  const TEST_MATCH_ARRAY_PATTERN = /testMatch\s*:\s*\[([^\]]*)\]/;
4886
- const STRING_LITERAL_PATTERN = /['"]([^'"]+)['"]/g;
4886
+ const STRING_LITERAL_PATTERN$1 = /['"]([^'"]+)['"]/g;
4887
4887
  const extractJestTestMatchPatterns = (directory) => {
4888
4888
  const configPaths = fast_glob.default.sync(["jest.config.{ts,js,mjs,cjs}"], {
4889
4889
  cwd: directory,
@@ -4905,9 +4905,9 @@ const extractJestTestMatchPatterns = (directory) => {
4905
4905
  if (!testMatchMatch) continue;
4906
4906
  const arrayContent = testMatchMatch[1];
4907
4907
  const patterns = [];
4908
- STRING_LITERAL_PATTERN.lastIndex = 0;
4908
+ STRING_LITERAL_PATTERN$1.lastIndex = 0;
4909
4909
  let itemMatch;
4910
- while ((itemMatch = STRING_LITERAL_PATTERN.exec(arrayContent)) !== null) patterns.push(itemMatch[1]);
4910
+ while ((itemMatch = STRING_LITERAL_PATTERN$1.exec(arrayContent)) !== null) patterns.push(itemMatch[1]);
4911
4911
  if (patterns.length > 0) return convertJestTestMatchToGlobs(patterns);
4912
4912
  } catch {}
4913
4913
  return [];
@@ -6324,6 +6324,19 @@ const isPlatformBuiltinOrVirtualSpecifier = (specifier) => {
6324
6324
  return BUILTIN_SUBPATH_NODE_MODULES.has(baseName);
6325
6325
  };
6326
6326
 
6327
+ //#endregion
6328
+ //#region src/utils/sanitize-import-specifier.ts
6329
+ const sanitizeImportSpecifier = (specifier) => {
6330
+ if (specifier.startsWith("node:") || specifier.startsWith("data:") || specifier.includes("://")) return specifier;
6331
+ const lastLoaderSeparator = specifier.lastIndexOf("!");
6332
+ let cleaned = lastLoaderSeparator === -1 ? specifier : specifier.slice(lastLoaderSeparator + 1);
6333
+ const queryIndex = cleaned.indexOf("?");
6334
+ if (queryIndex !== -1) cleaned = cleaned.slice(0, queryIndex);
6335
+ const fragmentIndex = cleaned.indexOf("#", 1);
6336
+ if (fragmentIndex !== -1) cleaned = cleaned.slice(0, fragmentIndex);
6337
+ return cleaned || specifier;
6338
+ };
6339
+
6327
6340
  //#endregion
6328
6341
  //#region src/resolver/resolve.ts
6329
6342
  const fileExistsCache = /* @__PURE__ */ new Map();
@@ -6388,6 +6401,50 @@ const resolvePathWithExtensionFallback = (candidatePath) => {
6388
6401
  }
6389
6402
  return candidatePath;
6390
6403
  };
6404
+ const resolveAliasTarget = (target) => {
6405
+ if (existsAsFile(target)) return target;
6406
+ for (const extension of RESOLVER_EXTENSIONS) if (cachedExistsSync(target + extension)) return target + extension;
6407
+ const sourceTarget = target.replace(/\.[cm]?js$/, "");
6408
+ if (sourceTarget !== target) {
6409
+ for (const extension of RESOLVER_EXTENSIONS) if (cachedExistsSync(sourceTarget + extension)) return sourceTarget + extension;
6410
+ }
6411
+ const indexCandidate = (0, node_path.join)(target, "index");
6412
+ for (const extension of RESOLVER_EXTENSIONS) if (cachedExistsSync(indexCandidate + extension)) return indexCandidate + extension;
6413
+ };
6414
+ const pathMappingSpecificity = (mapping) => mapping.isWildcard ? mapping.prefix.length + mapping.suffix.length : Number.MAX_SAFE_INTEGER;
6415
+ const compilePathMappings = (entries) => {
6416
+ const compiled = [];
6417
+ for (const [pattern, targets] of entries) {
6418
+ const wildcardIndex = pattern.indexOf("*");
6419
+ if (wildcardIndex === -1) compiled.push({
6420
+ prefix: pattern,
6421
+ suffix: "",
6422
+ isWildcard: false,
6423
+ targets
6424
+ });
6425
+ else compiled.push({
6426
+ prefix: pattern.slice(0, wildcardIndex),
6427
+ suffix: pattern.slice(wildcardIndex + 1),
6428
+ isWildcard: true,
6429
+ targets
6430
+ });
6431
+ }
6432
+ compiled.sort((left, right) => pathMappingSpecificity(right) - pathMappingSpecificity(left));
6433
+ return compiled;
6434
+ };
6435
+ const matchCompiledMapping = (specifier, mappings) => {
6436
+ for (const mapping of mappings) {
6437
+ let matchedWildcard = "";
6438
+ if (mapping.isWildcard) {
6439
+ if (!specifier.startsWith(mapping.prefix) || !specifier.endsWith(mapping.suffix)) continue;
6440
+ matchedWildcard = specifier.slice(mapping.prefix.length, specifier.length - mapping.suffix.length);
6441
+ } else if (specifier !== mapping.prefix) continue;
6442
+ for (const target of mapping.targets) {
6443
+ const resolved = resolveAliasTarget(target.replace("*", matchedWildcard));
6444
+ if (resolved) return resolved;
6445
+ }
6446
+ }
6447
+ };
6391
6448
  const COMMON_RESOLVER_OPTIONS = {
6392
6449
  conditionNames: [
6393
6450
  "import",
@@ -6419,11 +6476,26 @@ const WEBPACK_CONFIG_GLOBS = [
6419
6476
  "**/webpack.config*.{js,ts,mjs,cjs}",
6420
6477
  "**/webpack*.config*.babel.{js,ts}"
6421
6478
  ];
6422
- const WEBPACK_ALIAS_BLOCK_PATTERN = /alias\s*:\s*\{([\s\S]*?)\}/g;
6423
- const WEBPACK_ALIAS_ENTRY_PATTERN = /["']?([@\w$./-]+)["']?\s*:\s*(?:path\.(?:resolve|join)\(\s*__dirname\s*,\s*((?:["'][^"']+["']\s*,?\s*)+)\)|["']([^"']+)["'])/g;
6479
+ const VITE_CONFIG_GLOBS = [
6480
+ "vite.config.{js,ts,mjs,cjs,mts,cts}",
6481
+ "vitest.config.{js,ts,mjs,cjs,mts,cts}",
6482
+ "**/vite.config.{js,ts,mjs,cjs,mts,cts}",
6483
+ "**/vitest.config.{js,ts,mjs,cjs,mts,cts}"
6484
+ ];
6485
+ const BABEL_CONFIG_GLOBS = [
6486
+ "babel.config.{js,cjs,mjs,json}",
6487
+ ".babelrc",
6488
+ ".babelrc.{js,cjs,mjs,json}",
6489
+ "**/babel.config.{js,cjs,mjs,json}"
6490
+ ];
6491
+ const JEST_CONFIG_GLOBS = ["jest.config.{js,ts,mjs,cjs,json}", "**/jest.config.{js,ts,mjs,cjs,json}"];
6492
+ const ALIAS_BLOCK_PATTERN = /alias\s*:\s*\{([\s\S]*?)\}/g;
6493
+ const ALIAS_ENTRY_PATTERN = /["']?([@\w$./-]+)["']?\s*:\s*(?:path\.(?:resolve|join)\(\s*__dirname\s*,\s*((?:["'][^"']+["']\s*,?\s*)+)\)|fileURLToPath\(\s*new URL\(\s*["']([^"']+)["']\s*,\s*import\.meta\.url\s*\)\s*\)|["']([^"']+)["'])/g;
6494
+ const JEST_MODULE_NAME_MAPPER_BLOCK_PATTERN = /moduleNameMapper\s*:\s*\{([\s\S]*?)\}/g;
6495
+ const JEST_MODULE_NAME_MAPPER_ENTRY_PATTERN = /["']([^"']+)["']\s*:\s*["']([^"']+)["']/g;
6424
6496
  const WEBPACK_MODULES_BLOCK_PATTERN = /modules\s*:\s*\[([\s\S]*?)\]/g;
6425
6497
  const WEBPACK_PATH_CALL_PATTERN = /path\.(?:resolve|join)\(\s*__dirname\s*,\s*((?:["'][^"']+["']\s*,?\s*)+)\)/g;
6426
- const WEBPACK_STRING_LITERAL_PATTERN = /["']([^"']+)["']/g;
6498
+ const STRING_LITERAL_PATTERN = /["']([^"']+)["']/g;
6427
6499
  const TSCONFIG_FILENAMES = [
6428
6500
  "tsconfig.json",
6429
6501
  "tsconfig.web.json",
@@ -6480,15 +6552,15 @@ const isInsideDirectory = (filePath, directory) => {
6480
6552
  const extractQuotedSegments = (value) => {
6481
6553
  const segments = [];
6482
6554
  let segmentMatch;
6483
- WEBPACK_STRING_LITERAL_PATTERN.lastIndex = 0;
6484
- while ((segmentMatch = WEBPACK_STRING_LITERAL_PATTERN.exec(value)) !== null) segments.push(segmentMatch[1]);
6555
+ STRING_LITERAL_PATTERN.lastIndex = 0;
6556
+ while ((segmentMatch = STRING_LITERAL_PATTERN.exec(value)) !== null) segments.push(segmentMatch[1]);
6485
6557
  return segments;
6486
6558
  };
6487
- const resolveWebpackPathValue = (value, configDirectory) => {
6559
+ const resolveConfigPathValue = (value, configDirectory) => {
6488
6560
  if ((0, node_path.isAbsolute)(value)) return value;
6489
6561
  return (0, node_path.resolve)(configDirectory, value);
6490
6562
  };
6491
- const findWebpackConfigScope = (configPath, rootDir) => {
6563
+ const findConfigScope = (configPath, rootDir) => {
6492
6564
  let currentDirectory = (0, node_path.dirname)(configPath);
6493
6565
  const absoluteRoot = (0, node_path.resolve)(rootDir);
6494
6566
  while (currentDirectory.length >= absoluteRoot.length) {
@@ -6499,24 +6571,25 @@ const findWebpackConfigScope = (configPath, rootDir) => {
6499
6571
  }
6500
6572
  return absoluteRoot;
6501
6573
  };
6502
- const extractWebpackAliases = (content, configDirectory) => {
6574
+ const extractBundlerAliases = (content, configDirectory) => {
6503
6575
  const aliases = [];
6504
6576
  let aliasBlockMatch;
6505
- WEBPACK_ALIAS_BLOCK_PATTERN.lastIndex = 0;
6506
- while ((aliasBlockMatch = WEBPACK_ALIAS_BLOCK_PATTERN.exec(content)) !== null) {
6577
+ ALIAS_BLOCK_PATTERN.lastIndex = 0;
6578
+ while ((aliasBlockMatch = ALIAS_BLOCK_PATTERN.exec(content)) !== null) {
6507
6579
  const aliasBlock = aliasBlockMatch[1];
6508
6580
  let aliasEntryMatch;
6509
- WEBPACK_ALIAS_ENTRY_PATTERN.lastIndex = 0;
6510
- while ((aliasEntryMatch = WEBPACK_ALIAS_ENTRY_PATTERN.exec(aliasBlock)) !== null) {
6581
+ ALIAS_ENTRY_PATTERN.lastIndex = 0;
6582
+ while ((aliasEntryMatch = ALIAS_ENTRY_PATTERN.exec(aliasBlock)) !== null) {
6511
6583
  const rawName = aliasEntryMatch[1];
6512
6584
  const pathCallSegments = aliasEntryMatch[2];
6513
- const stringTarget = aliasEntryMatch[3];
6514
- if (!pathCallSegments && !stringTarget) continue;
6585
+ const fileUrlTarget = aliasEntryMatch[3];
6586
+ const stringTarget = aliasEntryMatch[4];
6515
6587
  const isExact = rawName.endsWith("$");
6516
6588
  const name = isExact ? rawName.slice(0, -1) : rawName.replace(/\/$/, "");
6517
6589
  let targetDirectory;
6518
6590
  if (pathCallSegments) targetDirectory = (0, node_path.resolve)(configDirectory, ...extractQuotedSegments(pathCallSegments));
6519
- else if (stringTarget) targetDirectory = resolveWebpackPathValue(stringTarget, configDirectory);
6591
+ else if (fileUrlTarget) targetDirectory = (0, node_path.resolve)(configDirectory, fileUrlTarget);
6592
+ else if (stringTarget) targetDirectory = resolveConfigPathValue(stringTarget, configDirectory);
6520
6593
  else continue;
6521
6594
  aliases.push({
6522
6595
  name,
@@ -6527,6 +6600,32 @@ const extractWebpackAliases = (content, configDirectory) => {
6527
6600
  }
6528
6601
  return aliases;
6529
6602
  };
6603
+ const compileJestModuleNameMapperAlias = (pattern, target, configDirectory) => {
6604
+ if (!target.includes("<rootDir>")) return void 0;
6605
+ const isWildcard = pattern.includes("(.*)") || pattern.includes("(.+)");
6606
+ const aliasName = pattern.replace(/^\^/, "").replace(/\$$/, "").replace(/\\(.)/g, "$1").replace(/\/?\((?:\.\*|\.\+)\)$/, "").replace(/\/$/, "");
6607
+ if (!aliasName) return void 0;
6608
+ return {
6609
+ name: aliasName,
6610
+ targetDirectory: (0, node_path.resolve)(target.replace(/<rootDir>/g, configDirectory).replace(/\/?\$\d+$/, "")),
6611
+ isExact: !isWildcard
6612
+ };
6613
+ };
6614
+ const extractJestModuleNameMapperAliases = (content, configDirectory) => {
6615
+ const aliases = [];
6616
+ let blockMatch;
6617
+ JEST_MODULE_NAME_MAPPER_BLOCK_PATTERN.lastIndex = 0;
6618
+ while ((blockMatch = JEST_MODULE_NAME_MAPPER_BLOCK_PATTERN.exec(content)) !== null) {
6619
+ const block = blockMatch[1];
6620
+ let entryMatch;
6621
+ JEST_MODULE_NAME_MAPPER_ENTRY_PATTERN.lastIndex = 0;
6622
+ while ((entryMatch = JEST_MODULE_NAME_MAPPER_ENTRY_PATTERN.exec(block)) !== null) {
6623
+ const alias = compileJestModuleNameMapperAlias(entryMatch[1], entryMatch[2], configDirectory);
6624
+ if (alias) aliases.push(alias);
6625
+ }
6626
+ }
6627
+ return aliases;
6628
+ };
6530
6629
  const extractWebpackModuleDirectories = (content, configDirectory) => {
6531
6630
  const moduleDirectories = [];
6532
6631
  let modulesBlockMatch;
@@ -6537,17 +6636,39 @@ const extractWebpackModuleDirectories = (content, configDirectory) => {
6537
6636
  WEBPACK_PATH_CALL_PATTERN.lastIndex = 0;
6538
6637
  while ((pathCallMatch = WEBPACK_PATH_CALL_PATTERN.exec(modulesBlock)) !== null) moduleDirectories.push((0, node_path.resolve)(configDirectory, ...extractQuotedSegments(pathCallMatch[1])));
6539
6638
  let stringMatch;
6540
- WEBPACK_STRING_LITERAL_PATTERN.lastIndex = 0;
6541
- while ((stringMatch = WEBPACK_STRING_LITERAL_PATTERN.exec(modulesBlock)) !== null) {
6639
+ STRING_LITERAL_PATTERN.lastIndex = 0;
6640
+ while ((stringMatch = STRING_LITERAL_PATTERN.exec(modulesBlock)) !== null) {
6542
6641
  const moduleDirectory = stringMatch[1];
6543
6642
  if (moduleDirectory === "node_modules") continue;
6544
- moduleDirectories.push(resolveWebpackPathValue(moduleDirectory, configDirectory));
6643
+ moduleDirectories.push(resolveConfigPathValue(moduleDirectory, configDirectory));
6545
6644
  }
6546
6645
  }
6547
6646
  return [...new Set(moduleDirectories)];
6548
6647
  };
6549
- const loadWebpackResolverConfigs = (rootDir) => {
6550
- const configPaths = fast_glob.default.sync(WEBPACK_CONFIG_GLOBS, {
6648
+ const isJestConfigPath = (configPath) => /(?:^|[\\/])jest\.config\.[^\\/]+$/.test(configPath);
6649
+ const isWebpackConfigPath = (configPath) => /webpack/.test(configPath);
6650
+ const extractPackageJsonJestAliases = (rootDir) => {
6651
+ try {
6652
+ const moduleNameMapper = JSON.parse(cachedReadFileSync((0, node_path.join)(rootDir, "package.json")))?.jest?.moduleNameMapper;
6653
+ if (!moduleNameMapper || typeof moduleNameMapper !== "object") return [];
6654
+ const aliases = [];
6655
+ for (const [pattern, target] of Object.entries(moduleNameMapper)) {
6656
+ if (typeof target !== "string") continue;
6657
+ const alias = compileJestModuleNameMapperAlias(pattern, target, rootDir);
6658
+ if (alias) aliases.push(alias);
6659
+ }
6660
+ return aliases;
6661
+ } catch {
6662
+ return [];
6663
+ }
6664
+ };
6665
+ const loadBundlerAliasConfigs = (rootDir) => {
6666
+ const configPaths = fast_glob.default.sync([
6667
+ ...WEBPACK_CONFIG_GLOBS,
6668
+ ...VITE_CONFIG_GLOBS,
6669
+ ...BABEL_CONFIG_GLOBS,
6670
+ ...JEST_CONFIG_GLOBS
6671
+ ], {
6551
6672
  cwd: rootDir,
6552
6673
  absolute: true,
6553
6674
  onlyFiles: true,
@@ -6562,17 +6683,24 @@ const loadWebpackResolverConfigs = (rootDir) => {
6562
6683
  for (const configPath of configPaths) try {
6563
6684
  const content = cachedReadFileSync(configPath);
6564
6685
  const configDirectory = (0, node_path.dirname)(configPath);
6565
- const aliases = extractWebpackAliases(content, configDirectory);
6566
- const moduleDirectories = extractWebpackModuleDirectories(content, configDirectory);
6686
+ const aliases = extractBundlerAliases(content, configDirectory);
6687
+ if (isJestConfigPath(configPath)) aliases.push(...extractJestModuleNameMapperAliases(content, configDirectory));
6688
+ const moduleDirectories = isWebpackConfigPath(configPath) ? extractWebpackModuleDirectories(content, configDirectory) : [];
6567
6689
  if (aliases.length === 0 && moduleDirectories.length === 0) continue;
6568
6690
  configs.push({
6569
- scopeDirectory: findWebpackConfigScope(configPath, rootDir),
6691
+ scopeDirectory: findConfigScope(configPath, rootDir),
6570
6692
  aliases,
6571
6693
  moduleDirectories
6572
6694
  });
6573
6695
  } catch {
6574
6696
  continue;
6575
6697
  }
6698
+ const packageJsonJestAliases = extractPackageJsonJestAliases(rootDir);
6699
+ if (packageJsonJestAliases.length > 0) configs.push({
6700
+ scopeDirectory: (0, node_path.resolve)(rootDir),
6701
+ aliases: packageJsonJestAliases,
6702
+ moduleDirectories: []
6703
+ });
6576
6704
  return configs;
6577
6705
  };
6578
6706
  const createResolver = (config, workspacePackages = [], options = {}) => {
@@ -6611,7 +6739,36 @@ const createResolver = (config, workspacePackages = [], options = {}) => {
6611
6739
  };
6612
6740
  const workspaceNameToDirectory = /* @__PURE__ */ new Map();
6613
6741
  for (const workspacePackage of workspacePackages) workspaceNameToDirectory.set(workspacePackage.name, workspacePackage.directory);
6614
- const webpackResolverConfigs = (options.monorepoRoot && options.monorepoRoot !== config.rootDir ? [config.rootDir, options.monorepoRoot] : [config.rootDir]).flatMap(loadWebpackResolverConfigs).sort((leftConfig, rightConfig) => rightConfig.scopeDirectory.length - leftConfig.scopeDirectory.length);
6742
+ const structuralAliasToDirectory = /* @__PURE__ */ new Map();
6743
+ const workspaceScopes = /* @__PURE__ */ new Set();
6744
+ for (const workspacePackage of workspacePackages) {
6745
+ if (!workspacePackage.name.startsWith("@")) continue;
6746
+ const slashIndex = workspacePackage.name.indexOf("/");
6747
+ if (slashIndex !== -1) workspaceScopes.add(workspacePackage.name.slice(0, slashIndex));
6748
+ }
6749
+ if (workspaceScopes.size > 0) {
6750
+ const ambiguousStructuralKeys = /* @__PURE__ */ new Set();
6751
+ const registerStructuralAlias = (aliasKey, directory) => {
6752
+ if (workspaceNameToDirectory.has(aliasKey)) return;
6753
+ const existing = structuralAliasToDirectory.get(aliasKey);
6754
+ if (existing !== void 0 && existing !== directory) {
6755
+ ambiguousStructuralKeys.add(aliasKey);
6756
+ return;
6757
+ }
6758
+ structuralAliasToDirectory.set(aliasKey, directory);
6759
+ };
6760
+ for (const workspacePackage of workspacePackages) {
6761
+ const directoryBasename = (0, node_path.basename)(workspacePackage.directory);
6762
+ const slashIndex = workspacePackage.name.indexOf("/");
6763
+ const unscopedName = workspacePackage.name.startsWith("@") && slashIndex !== -1 ? workspacePackage.name.slice(slashIndex + 1) : workspacePackage.name;
6764
+ for (const scope of workspaceScopes) {
6765
+ registerStructuralAlias(`${scope}/${directoryBasename}`, workspacePackage.directory);
6766
+ if (unscopedName && unscopedName !== directoryBasename) registerStructuralAlias(`${scope}/${unscopedName}`, workspacePackage.directory);
6767
+ }
6768
+ }
6769
+ for (const ambiguousKey of ambiguousStructuralKeys) structuralAliasToDirectory.delete(ambiguousKey);
6770
+ }
6771
+ const bundlerAliasConfigs = (options.monorepoRoot && options.monorepoRoot !== config.rootDir ? [config.rootDir, options.monorepoRoot] : [config.rootDir]).flatMap(loadBundlerAliasConfigs).sort((leftConfig, rightConfig) => rightConfig.scopeDirectory.length - leftConfig.scopeDirectory.length);
6615
6772
  let rootTsconfigPath;
6616
6773
  if (config.tsConfigPath) rootTsconfigPath = (0, node_path.resolve)(config.rootDir, config.tsConfigPath);
6617
6774
  else {
@@ -6629,6 +6786,7 @@ const createResolver = (config, workspacePackages = [], options = {}) => {
6629
6786
  }
6630
6787
  const tsconfigPathCache = /* @__PURE__ */ new Map();
6631
6788
  const tsconfigPathAliasCache = /* @__PURE__ */ new Map();
6789
+ const tsconfigCompiledAliasCache = /* @__PURE__ */ new Map();
6632
6790
  const findTsconfigForFile = (filePath) => {
6633
6791
  const fileDir = (0, node_path.dirname)(filePath);
6634
6792
  const cached = tsconfigPathCache.get(fileDir);
@@ -6775,64 +6933,127 @@ const createResolver = (config, workspacePackages = [], options = {}) => {
6775
6933
  tsconfigPathAliasCache.set(tsconfigFile, aliasMap);
6776
6934
  return aliasMap;
6777
6935
  };
6936
+ const getCompiledPathAliases = (tsconfigFile) => {
6937
+ const cached = tsconfigCompiledAliasCache.get(tsconfigFile);
6938
+ if (cached) return cached;
6939
+ const compiled = compilePathMappings(getPathAliases(tsconfigFile));
6940
+ tsconfigCompiledAliasCache.set(tsconfigFile, compiled);
6941
+ return compiled;
6942
+ };
6778
6943
  const tryResolveViaPathAlias = (specifier, fromFile) => {
6779
6944
  const tsconfigFile = findTsconfigForFile(fromFile);
6780
6945
  if (!tsconfigFile) return void 0;
6781
- const aliases = getPathAliases(tsconfigFile);
6782
- for (const [pattern, targetPatterns] of aliases) {
6783
- const wildcardIndex = pattern.indexOf("*");
6784
- if (wildcardIndex === -1) {
6785
- if (specifier === pattern) for (const targetPattern of targetPatterns) {
6786
- const candidate = targetPattern.replace("*", "");
6787
- if (existsAsFile(candidate)) return candidate;
6788
- for (const ext of RESOLVER_EXTENSIONS) if (cachedExistsSync(candidate + ext)) return candidate + ext;
6789
- const indexCandidate = (0, node_path.join)(candidate, "index");
6790
- for (const ext of RESOLVER_EXTENSIONS) if (cachedExistsSync(indexCandidate + ext)) return indexCandidate + ext;
6791
- }
6792
- continue;
6793
- }
6794
- const prefix = pattern.slice(0, wildcardIndex);
6795
- const suffix = pattern.slice(wildcardIndex + 1);
6796
- if (!specifier.startsWith(prefix) || !specifier.endsWith(suffix)) continue;
6797
- const matchedWildcard = specifier.slice(prefix.length, specifier.length - suffix.length);
6798
- for (const targetPattern of targetPatterns) {
6799
- const resolvedTarget = targetPattern.replace("*", matchedWildcard);
6800
- if (existsAsFile(resolvedTarget)) return resolvedTarget;
6801
- for (const ext of RESOLVER_EXTENSIONS) if (cachedExistsSync(resolvedTarget + ext)) return resolvedTarget + ext;
6802
- const strippedTarget = resolvedTarget.replace(/\.[cm]?js$/, "");
6803
- if (strippedTarget !== resolvedTarget) {
6804
- for (const ext of RESOLVER_EXTENSIONS) if (cachedExistsSync(strippedTarget + ext)) return strippedTarget + ext;
6805
- }
6806
- const indexCandidate = (0, node_path.join)(resolvedTarget, "index");
6807
- for (const ext of RESOLVER_EXTENSIONS) if (cachedExistsSync(indexCandidate + ext)) return indexCandidate + ext;
6808
- }
6809
- }
6946
+ return matchCompiledMapping(specifier, getCompiledPathAliases(tsconfigFile));
6810
6947
  };
6811
6948
  const tryResolveFromDirectory = (directory, specifier) => {
6812
6949
  const candidatePath = resolvePathWithExtensionFallback((0, node_path.resolve)(directory, specifier));
6813
6950
  if (existsAsFile(candidatePath)) return candidatePath;
6814
6951
  };
6815
- const tryResolveViaWebpackConfig = (specifier, fromFile) => {
6816
- if (webpackResolverConfigs.length === 0) return void 0;
6952
+ const tryResolveViaBundlerAlias = (specifier, fromFile) => {
6953
+ if (bundlerAliasConfigs.length === 0) return void 0;
6817
6954
  if (!isBareSpecifier(specifier)) return void 0;
6818
- for (const webpackConfig of webpackResolverConfigs) {
6819
- if (!isInsideDirectory(fromFile, webpackConfig.scopeDirectory)) continue;
6820
- for (const alias of webpackConfig.aliases) {
6955
+ for (const bundlerConfig of bundlerAliasConfigs) {
6956
+ if (!isInsideDirectory(fromFile, bundlerConfig.scopeDirectory)) continue;
6957
+ for (const alias of bundlerConfig.aliases) {
6821
6958
  if (alias.isExact && specifier !== alias.name) continue;
6822
6959
  const suffix = specifier === alias.name ? "" : specifier.startsWith(`${alias.name}/`) ? specifier.slice(alias.name.length + 1) : void 0;
6823
6960
  if (suffix === void 0) continue;
6824
6961
  const aliasCandidate = tryResolveFromDirectory(alias.targetDirectory, suffix);
6825
6962
  if (aliasCandidate) return aliasCandidate;
6826
6963
  }
6827
- for (const moduleDirectory of webpackConfig.moduleDirectories) {
6964
+ for (const moduleDirectory of bundlerConfig.moduleDirectories) {
6828
6965
  const moduleCandidate = tryResolveFromDirectory(moduleDirectory, specifier);
6829
6966
  if (moduleCandidate) return moduleCandidate;
6830
6967
  }
6831
6968
  }
6832
6969
  };
6970
+ const compiledConfigPaths = config.paths ? compilePathMappings(Object.entries(config.paths).map(([pattern, targets]) => [pattern, targets.map((target) => (0, node_path.resolve)(config.rootDir, target))])) : [];
6971
+ const tryResolveViaConfigPaths = (specifier) => compiledConfigPaths.length === 0 ? void 0 : matchCompiledMapping(specifier, compiledConfigPaths);
6972
+ const resolveWorkspaceSubpath = (workspaceDirectory, subpath) => {
6973
+ const workspacePackageJsonPath = (0, node_path.join)(workspaceDirectory, "package.json");
6974
+ try {
6975
+ const workspacePackageContent = cachedReadFileSync(workspacePackageJsonPath);
6976
+ const workspacePackageJson = JSON.parse(workspacePackageContent);
6977
+ let resolvedEntryPath;
6978
+ if (subpath && workspacePackageJson.exports) {
6979
+ const exportKey = `./${subpath}`;
6980
+ const exportValue = workspacePackageJson.exports[exportKey];
6981
+ if (typeof exportValue === "string") {
6982
+ const candidatePath = resolvePathWithExtensionFallback((0, node_path.resolve)(workspaceDirectory, exportValue));
6983
+ resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6984
+ } else if (typeof exportValue === "object" && exportValue !== null) {
6985
+ const conditionValue = exportValue.import ?? exportValue.require ?? exportValue.default ?? exportValue.types;
6986
+ if (typeof conditionValue === "string") {
6987
+ const candidatePath = resolvePathWithExtensionFallback((0, node_path.resolve)(workspaceDirectory, conditionValue));
6988
+ resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6989
+ }
6990
+ }
6991
+ if (!resolvedEntryPath) for (const [wildcardPattern, wildcardTarget] of Object.entries(workspacePackageJson.exports)) {
6992
+ if (typeof wildcardPattern !== "string" || !wildcardPattern.includes("*")) continue;
6993
+ const wildcardTargetRecord = typeof wildcardTarget === "object" && wildcardTarget !== null ? wildcardTarget : void 0;
6994
+ const wildcardTargetValue = typeof wildcardTarget === "string" ? wildcardTarget : wildcardTargetRecord ? String(wildcardTargetRecord["import"] ?? wildcardTargetRecord["require"] ?? wildcardTargetRecord["default"] ?? wildcardTargetRecord["types"] ?? "") : void 0;
6995
+ if (typeof wildcardTargetValue !== "string") continue;
6996
+ const wildcardPrefix = wildcardPattern.slice(0, wildcardPattern.indexOf("*"));
6997
+ const wildcardSuffix = wildcardPattern.slice(wildcardPattern.indexOf("*") + 1);
6998
+ if (exportKey.startsWith(wildcardPrefix) && exportKey.endsWith(wildcardSuffix)) {
6999
+ const matchedSegment = exportKey.slice(wildcardPrefix.length, exportKey.length - wildcardSuffix.length || void 0);
7000
+ const candidatePath = resolvePathWithExtensionFallback((0, node_path.resolve)(workspaceDirectory, wildcardTargetValue.replace("*", matchedSegment)));
7001
+ resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
7002
+ break;
7003
+ }
7004
+ }
7005
+ }
7006
+ if (subpath && !resolvedEntryPath) {
7007
+ const subpathCandidates = [(0, node_path.resolve)(workspaceDirectory, subpath), (0, node_path.resolve)(workspaceDirectory, "src", subpath)];
7008
+ for (const directSubpath of subpathCandidates) {
7009
+ for (const candidateExtension of RESOLVER_EXTENSIONS) {
7010
+ const candidate = directSubpath + candidateExtension;
7011
+ if (cachedExistsSync(candidate)) {
7012
+ resolvedEntryPath = candidate;
7013
+ break;
7014
+ }
7015
+ }
7016
+ if (resolvedEntryPath) break;
7017
+ for (const candidateExtension of RESOLVER_EXTENSIONS) {
7018
+ const indexCandidate = (0, node_path.join)(directSubpath, `index${candidateExtension}`);
7019
+ if (cachedExistsSync(indexCandidate)) {
7020
+ resolvedEntryPath = indexCandidate;
7021
+ break;
7022
+ }
7023
+ }
7024
+ if (resolvedEntryPath) break;
7025
+ }
7026
+ }
7027
+ if (!subpath) {
7028
+ const mainField = workspacePackageJson.main ?? workspacePackageJson.module;
7029
+ if (typeof mainField === "string") resolvedEntryPath = (0, node_path.resolve)(workspaceDirectory, mainField);
7030
+ if (!resolvedEntryPath && workspacePackageJson.exports?.["."]) {
7031
+ const dotExport = workspacePackageJson.exports["."];
7032
+ if (typeof dotExport === "string") resolvedEntryPath = (0, node_path.resolve)(workspaceDirectory, dotExport);
7033
+ else if (typeof dotExport === "object" && dotExport !== null) {
7034
+ const conditionValue = dotExport.import ?? dotExport.require ?? dotExport.default ?? dotExport.types;
7035
+ if (typeof conditionValue === "string") resolvedEntryPath = (0, node_path.resolve)(workspaceDirectory, conditionValue);
7036
+ }
7037
+ }
7038
+ }
7039
+ if (resolvedEntryPath) {
7040
+ const finalPath = resolveSourcePath(resolvedEntryPath, workspaceDirectory) ?? resolvedEntryPath;
7041
+ if (cachedExistsSync(finalPath)) return finalPath;
7042
+ const sourceFallbackPath = trySourceFallback(resolvedEntryPath);
7043
+ if (sourceFallbackPath) return sourceFallbackPath;
7044
+ }
7045
+ } catch {}
7046
+ };
7047
+ const tryResolveViaWorkspaceStructure = (specifier) => {
7048
+ if (structuralAliasToDirectory.size === 0) return void 0;
7049
+ if (!isBareSpecifier(specifier)) return void 0;
7050
+ const packageKey = extractPackageNameFromSpecifier(specifier);
7051
+ const directory = structuralAliasToDirectory.get(packageKey);
7052
+ if (!directory) return void 0;
7053
+ return resolveWorkspaceSubpath(directory, specifier.length > packageKey.length ? specifier.slice(packageKey.length + 1) : "");
7054
+ };
6833
7055
  const resolveModule = (specifier, fromFile) => {
6834
- const queryIndex = specifier.indexOf("?");
6835
- const cleanedSpecifier = queryIndex !== -1 ? specifier.slice(0, queryIndex) : specifier;
7056
+ const cleanedSpecifier = sanitizeImportSpecifier(specifier);
6836
7057
  const fromDir = (0, node_path.dirname)(fromFile);
6837
7058
  const cacheKey = `${fromDir}::${cleanedSpecifier}`;
6838
7059
  const cached = resolveResultCache.get(cacheKey);
@@ -6862,96 +7083,16 @@ const createResolver = (config, workspacePackages = [], options = {}) => {
6862
7083
  const packageName = extractPackageNameFromSpecifier(cleanedSpecifier);
6863
7084
  const workspaceDirectory = workspaceNameToDirectory.get(packageName);
6864
7085
  if (workspaceDirectory) {
6865
- const subpath = cleanedSpecifier.slice(packageName.length + 1);
6866
- const workspacePackageJsonPath = (0, node_path.join)(workspaceDirectory, "package.json");
6867
- try {
6868
- const workspacePackageContent = cachedReadFileSync(workspacePackageJsonPath);
6869
- const workspacePackageJson = JSON.parse(workspacePackageContent);
6870
- let resolvedEntryPath;
6871
- if (subpath && workspacePackageJson.exports) {
6872
- const exportKey = `./${subpath}`;
6873
- const exportValue = workspacePackageJson.exports[exportKey];
6874
- if (typeof exportValue === "string") {
6875
- const candidatePath = resolvePathWithExtensionFallback((0, node_path.resolve)(workspaceDirectory, exportValue));
6876
- resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6877
- } else if (typeof exportValue === "object" && exportValue !== null) {
6878
- const conditionValue = exportValue.import ?? exportValue.require ?? exportValue.default ?? exportValue.types;
6879
- if (typeof conditionValue === "string") {
6880
- const candidatePath = resolvePathWithExtensionFallback((0, node_path.resolve)(workspaceDirectory, conditionValue));
6881
- resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6882
- }
6883
- }
6884
- if (!resolvedEntryPath) for (const [wildcardPattern, wildcardTarget] of Object.entries(workspacePackageJson.exports)) {
6885
- if (typeof wildcardPattern !== "string" || !wildcardPattern.includes("*")) continue;
6886
- const wildcardTargetRecord = typeof wildcardTarget === "object" && wildcardTarget !== null ? wildcardTarget : void 0;
6887
- const wildcardTargetValue = typeof wildcardTarget === "string" ? wildcardTarget : wildcardTargetRecord ? String(wildcardTargetRecord["import"] ?? wildcardTargetRecord["require"] ?? wildcardTargetRecord["default"] ?? wildcardTargetRecord["types"] ?? "") : void 0;
6888
- if (typeof wildcardTargetValue !== "string") continue;
6889
- const wildcardPrefix = wildcardPattern.slice(0, wildcardPattern.indexOf("*"));
6890
- const wildcardSuffix = wildcardPattern.slice(wildcardPattern.indexOf("*") + 1);
6891
- if (exportKey.startsWith(wildcardPrefix) && exportKey.endsWith(wildcardSuffix)) {
6892
- const matchedSegment = exportKey.slice(wildcardPrefix.length, exportKey.length - wildcardSuffix.length || void 0);
6893
- const candidatePath = resolvePathWithExtensionFallback((0, node_path.resolve)(workspaceDirectory, wildcardTargetValue.replace("*", matchedSegment)));
6894
- resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6895
- break;
6896
- }
6897
- }
6898
- }
6899
- if (subpath && !resolvedEntryPath) {
6900
- const subpathCandidates = [(0, node_path.resolve)(workspaceDirectory, subpath), (0, node_path.resolve)(workspaceDirectory, "src", subpath)];
6901
- for (const directSubpath of subpathCandidates) {
6902
- for (const candidateExtension of RESOLVER_EXTENSIONS) {
6903
- const candidate = directSubpath + candidateExtension;
6904
- if (cachedExistsSync(candidate)) {
6905
- resolvedEntryPath = candidate;
6906
- break;
6907
- }
6908
- }
6909
- if (resolvedEntryPath) break;
6910
- for (const candidateExtension of RESOLVER_EXTENSIONS) {
6911
- const indexCandidate = (0, node_path.join)(directSubpath, `index${candidateExtension}`);
6912
- if (cachedExistsSync(indexCandidate)) {
6913
- resolvedEntryPath = indexCandidate;
6914
- break;
6915
- }
6916
- }
6917
- if (resolvedEntryPath) break;
6918
- }
6919
- }
6920
- if (!subpath) {
6921
- const mainField = workspacePackageJson.main ?? workspacePackageJson.module;
6922
- if (typeof mainField === "string") resolvedEntryPath = (0, node_path.resolve)(workspaceDirectory, mainField);
6923
- if (!resolvedEntryPath && workspacePackageJson.exports?.["."]) {
6924
- const dotExport = workspacePackageJson.exports["."];
6925
- if (typeof dotExport === "string") resolvedEntryPath = (0, node_path.resolve)(workspaceDirectory, dotExport);
6926
- else if (typeof dotExport === "object" && dotExport !== null) {
6927
- const conditionValue = dotExport.import ?? dotExport.require ?? dotExport.default ?? dotExport.types;
6928
- if (typeof conditionValue === "string") resolvedEntryPath = (0, node_path.resolve)(workspaceDirectory, conditionValue);
6929
- }
6930
- }
6931
- }
6932
- if (resolvedEntryPath) {
6933
- const finalPath = resolveSourcePath(resolvedEntryPath, workspaceDirectory) ?? resolvedEntryPath;
6934
- if (cachedExistsSync(finalPath)) {
6935
- const resolvedResult = {
6936
- resolvedPath: finalPath,
6937
- isExternal: false,
6938
- packageName: void 0
6939
- };
6940
- resolveResultCache.set(cacheKey, resolvedResult);
6941
- return resolvedResult;
6942
- }
6943
- const sourceFallbackPath = trySourceFallback(resolvedEntryPath);
6944
- if (sourceFallbackPath) {
6945
- const resolvedResult = {
6946
- resolvedPath: sourceFallbackPath,
6947
- isExternal: false,
6948
- packageName: void 0
6949
- };
6950
- resolveResultCache.set(cacheKey, resolvedResult);
6951
- return resolvedResult;
6952
- }
6953
- }
6954
- } catch {}
7086
+ const resolvedWorkspacePath = resolveWorkspaceSubpath(workspaceDirectory, cleanedSpecifier.slice(packageName.length + 1));
7087
+ if (resolvedWorkspacePath) {
7088
+ const resolvedResult = {
7089
+ resolvedPath: resolvedWorkspacePath,
7090
+ isExternal: false,
7091
+ packageName: void 0
7092
+ };
7093
+ resolveResultCache.set(cacheKey, resolvedResult);
7094
+ return resolvedResult;
7095
+ }
6955
7096
  }
6956
7097
  }
6957
7098
  const tsconfigForFile = findTsconfigForFile(fromFile);
@@ -6994,10 +7135,30 @@ const createResolver = (config, workspacePackages = [], options = {}) => {
6994
7135
  resolveResultCache.set(cacheKey, resolvedResult);
6995
7136
  return resolvedResult;
6996
7137
  }
6997
- const webpackResolved = tryResolveViaWebpackConfig(cleanedSpecifier, fromFile);
6998
- if (webpackResolved) {
7138
+ const configPathResolved = tryResolveViaConfigPaths(cleanedSpecifier);
7139
+ if (configPathResolved) {
7140
+ const resolvedResult = {
7141
+ resolvedPath: configPathResolved,
7142
+ isExternal: false,
7143
+ packageName: void 0
7144
+ };
7145
+ resolveResultCache.set(cacheKey, resolvedResult);
7146
+ return resolvedResult;
7147
+ }
7148
+ const bundlerAliasResolved = tryResolveViaBundlerAlias(cleanedSpecifier, fromFile);
7149
+ if (bundlerAliasResolved) {
7150
+ const resolvedResult = {
7151
+ resolvedPath: bundlerAliasResolved,
7152
+ isExternal: false,
7153
+ packageName: void 0
7154
+ };
7155
+ resolveResultCache.set(cacheKey, resolvedResult);
7156
+ return resolvedResult;
7157
+ }
7158
+ const structuralResolved = tryResolveViaWorkspaceStructure(cleanedSpecifier);
7159
+ if (structuralResolved) {
6999
7160
  const resolvedResult = {
7000
- resolvedPath: webpackResolved,
7161
+ resolvedPath: structuralResolved,
7001
7162
  isExternal: false,
7002
7163
  packageName: void 0
7003
7164
  };
@@ -12680,6 +12841,7 @@ const defineConfig = (options) => ({
12680
12841
  ignorePatterns: options.ignorePatterns ?? [],
12681
12842
  includeExtensions: options.includeExtensions ?? DEFAULT_EXTENSIONS,
12682
12843
  tsConfigPath: options.tsConfigPath,
12844
+ paths: options.paths,
12683
12845
  reportTypes: options.reportTypes ?? false,
12684
12846
  includeEntryExports: options.includeEntryExports ?? false,
12685
12847
  reportRedundancy: options.reportRedundancy ?? true,
package/dist/index.d.cts CHANGED
@@ -416,6 +416,7 @@ interface DeslopConfig {
416
416
  ignorePatterns: string[];
417
417
  includeExtensions: string[];
418
418
  tsConfigPath: string | undefined;
419
+ paths: Record<string, string[]> | undefined;
419
420
  reportTypes: boolean;
420
421
  includeEntryExports: boolean;
421
422
  reportRedundancy: boolean;
package/dist/index.d.mts CHANGED
@@ -416,6 +416,7 @@ interface DeslopConfig {
416
416
  ignorePatterns: string[];
417
417
  includeExtensions: string[];
418
418
  tsConfigPath: string | undefined;
419
+ paths: Record<string, string[]> | undefined;
419
420
  reportTypes: boolean;
420
421
  includeEntryExports: boolean;
421
422
  reportRedundancy: boolean;
package/dist/index.mjs CHANGED
@@ -4851,7 +4851,7 @@ const extractNextConfigPluginFiles = (directory) => {
4851
4851
  const VITEST_INCLUDE_ITEM_PATTERN = /['"]([^'"]+)['"]/g;
4852
4852
  const COVERAGE_BLOCK_PATTERN = /coverage\s*:\s*\{/g;
4853
4853
  const TEST_MATCH_ARRAY_PATTERN = /testMatch\s*:\s*\[([^\]]*)\]/;
4854
- const STRING_LITERAL_PATTERN = /['"]([^'"]+)['"]/g;
4854
+ const STRING_LITERAL_PATTERN$1 = /['"]([^'"]+)['"]/g;
4855
4855
  const extractJestTestMatchPatterns = (directory) => {
4856
4856
  const configPaths = fg.sync(["jest.config.{ts,js,mjs,cjs}"], {
4857
4857
  cwd: directory,
@@ -4873,9 +4873,9 @@ const extractJestTestMatchPatterns = (directory) => {
4873
4873
  if (!testMatchMatch) continue;
4874
4874
  const arrayContent = testMatchMatch[1];
4875
4875
  const patterns = [];
4876
- STRING_LITERAL_PATTERN.lastIndex = 0;
4876
+ STRING_LITERAL_PATTERN$1.lastIndex = 0;
4877
4877
  let itemMatch;
4878
- while ((itemMatch = STRING_LITERAL_PATTERN.exec(arrayContent)) !== null) patterns.push(itemMatch[1]);
4878
+ while ((itemMatch = STRING_LITERAL_PATTERN$1.exec(arrayContent)) !== null) patterns.push(itemMatch[1]);
4879
4879
  if (patterns.length > 0) return convertJestTestMatchToGlobs(patterns);
4880
4880
  } catch {}
4881
4881
  return [];
@@ -6292,6 +6292,19 @@ const isPlatformBuiltinOrVirtualSpecifier = (specifier) => {
6292
6292
  return BUILTIN_SUBPATH_NODE_MODULES.has(baseName);
6293
6293
  };
6294
6294
 
6295
+ //#endregion
6296
+ //#region src/utils/sanitize-import-specifier.ts
6297
+ const sanitizeImportSpecifier = (specifier) => {
6298
+ if (specifier.startsWith("node:") || specifier.startsWith("data:") || specifier.includes("://")) return specifier;
6299
+ const lastLoaderSeparator = specifier.lastIndexOf("!");
6300
+ let cleaned = lastLoaderSeparator === -1 ? specifier : specifier.slice(lastLoaderSeparator + 1);
6301
+ const queryIndex = cleaned.indexOf("?");
6302
+ if (queryIndex !== -1) cleaned = cleaned.slice(0, queryIndex);
6303
+ const fragmentIndex = cleaned.indexOf("#", 1);
6304
+ if (fragmentIndex !== -1) cleaned = cleaned.slice(0, fragmentIndex);
6305
+ return cleaned || specifier;
6306
+ };
6307
+
6295
6308
  //#endregion
6296
6309
  //#region src/resolver/resolve.ts
6297
6310
  const fileExistsCache = /* @__PURE__ */ new Map();
@@ -6356,6 +6369,50 @@ const resolvePathWithExtensionFallback = (candidatePath) => {
6356
6369
  }
6357
6370
  return candidatePath;
6358
6371
  };
6372
+ const resolveAliasTarget = (target) => {
6373
+ if (existsAsFile(target)) return target;
6374
+ for (const extension of RESOLVER_EXTENSIONS) if (cachedExistsSync(target + extension)) return target + extension;
6375
+ const sourceTarget = target.replace(/\.[cm]?js$/, "");
6376
+ if (sourceTarget !== target) {
6377
+ for (const extension of RESOLVER_EXTENSIONS) if (cachedExistsSync(sourceTarget + extension)) return sourceTarget + extension;
6378
+ }
6379
+ const indexCandidate = join(target, "index");
6380
+ for (const extension of RESOLVER_EXTENSIONS) if (cachedExistsSync(indexCandidate + extension)) return indexCandidate + extension;
6381
+ };
6382
+ const pathMappingSpecificity = (mapping) => mapping.isWildcard ? mapping.prefix.length + mapping.suffix.length : Number.MAX_SAFE_INTEGER;
6383
+ const compilePathMappings = (entries) => {
6384
+ const compiled = [];
6385
+ for (const [pattern, targets] of entries) {
6386
+ const wildcardIndex = pattern.indexOf("*");
6387
+ if (wildcardIndex === -1) compiled.push({
6388
+ prefix: pattern,
6389
+ suffix: "",
6390
+ isWildcard: false,
6391
+ targets
6392
+ });
6393
+ else compiled.push({
6394
+ prefix: pattern.slice(0, wildcardIndex),
6395
+ suffix: pattern.slice(wildcardIndex + 1),
6396
+ isWildcard: true,
6397
+ targets
6398
+ });
6399
+ }
6400
+ compiled.sort((left, right) => pathMappingSpecificity(right) - pathMappingSpecificity(left));
6401
+ return compiled;
6402
+ };
6403
+ const matchCompiledMapping = (specifier, mappings) => {
6404
+ for (const mapping of mappings) {
6405
+ let matchedWildcard = "";
6406
+ if (mapping.isWildcard) {
6407
+ if (!specifier.startsWith(mapping.prefix) || !specifier.endsWith(mapping.suffix)) continue;
6408
+ matchedWildcard = specifier.slice(mapping.prefix.length, specifier.length - mapping.suffix.length);
6409
+ } else if (specifier !== mapping.prefix) continue;
6410
+ for (const target of mapping.targets) {
6411
+ const resolved = resolveAliasTarget(target.replace("*", matchedWildcard));
6412
+ if (resolved) return resolved;
6413
+ }
6414
+ }
6415
+ };
6359
6416
  const COMMON_RESOLVER_OPTIONS = {
6360
6417
  conditionNames: [
6361
6418
  "import",
@@ -6387,11 +6444,26 @@ const WEBPACK_CONFIG_GLOBS = [
6387
6444
  "**/webpack.config*.{js,ts,mjs,cjs}",
6388
6445
  "**/webpack*.config*.babel.{js,ts}"
6389
6446
  ];
6390
- const WEBPACK_ALIAS_BLOCK_PATTERN = /alias\s*:\s*\{([\s\S]*?)\}/g;
6391
- const WEBPACK_ALIAS_ENTRY_PATTERN = /["']?([@\w$./-]+)["']?\s*:\s*(?:path\.(?:resolve|join)\(\s*__dirname\s*,\s*((?:["'][^"']+["']\s*,?\s*)+)\)|["']([^"']+)["'])/g;
6447
+ const VITE_CONFIG_GLOBS = [
6448
+ "vite.config.{js,ts,mjs,cjs,mts,cts}",
6449
+ "vitest.config.{js,ts,mjs,cjs,mts,cts}",
6450
+ "**/vite.config.{js,ts,mjs,cjs,mts,cts}",
6451
+ "**/vitest.config.{js,ts,mjs,cjs,mts,cts}"
6452
+ ];
6453
+ const BABEL_CONFIG_GLOBS = [
6454
+ "babel.config.{js,cjs,mjs,json}",
6455
+ ".babelrc",
6456
+ ".babelrc.{js,cjs,mjs,json}",
6457
+ "**/babel.config.{js,cjs,mjs,json}"
6458
+ ];
6459
+ const JEST_CONFIG_GLOBS = ["jest.config.{js,ts,mjs,cjs,json}", "**/jest.config.{js,ts,mjs,cjs,json}"];
6460
+ const ALIAS_BLOCK_PATTERN = /alias\s*:\s*\{([\s\S]*?)\}/g;
6461
+ const ALIAS_ENTRY_PATTERN = /["']?([@\w$./-]+)["']?\s*:\s*(?:path\.(?:resolve|join)\(\s*__dirname\s*,\s*((?:["'][^"']+["']\s*,?\s*)+)\)|fileURLToPath\(\s*new URL\(\s*["']([^"']+)["']\s*,\s*import\.meta\.url\s*\)\s*\)|["']([^"']+)["'])/g;
6462
+ const JEST_MODULE_NAME_MAPPER_BLOCK_PATTERN = /moduleNameMapper\s*:\s*\{([\s\S]*?)\}/g;
6463
+ const JEST_MODULE_NAME_MAPPER_ENTRY_PATTERN = /["']([^"']+)["']\s*:\s*["']([^"']+)["']/g;
6392
6464
  const WEBPACK_MODULES_BLOCK_PATTERN = /modules\s*:\s*\[([\s\S]*?)\]/g;
6393
6465
  const WEBPACK_PATH_CALL_PATTERN = /path\.(?:resolve|join)\(\s*__dirname\s*,\s*((?:["'][^"']+["']\s*,?\s*)+)\)/g;
6394
- const WEBPACK_STRING_LITERAL_PATTERN = /["']([^"']+)["']/g;
6466
+ const STRING_LITERAL_PATTERN = /["']([^"']+)["']/g;
6395
6467
  const TSCONFIG_FILENAMES = [
6396
6468
  "tsconfig.json",
6397
6469
  "tsconfig.web.json",
@@ -6448,15 +6520,15 @@ const isInsideDirectory = (filePath, directory) => {
6448
6520
  const extractQuotedSegments = (value) => {
6449
6521
  const segments = [];
6450
6522
  let segmentMatch;
6451
- WEBPACK_STRING_LITERAL_PATTERN.lastIndex = 0;
6452
- while ((segmentMatch = WEBPACK_STRING_LITERAL_PATTERN.exec(value)) !== null) segments.push(segmentMatch[1]);
6523
+ STRING_LITERAL_PATTERN.lastIndex = 0;
6524
+ while ((segmentMatch = STRING_LITERAL_PATTERN.exec(value)) !== null) segments.push(segmentMatch[1]);
6453
6525
  return segments;
6454
6526
  };
6455
- const resolveWebpackPathValue = (value, configDirectory) => {
6527
+ const resolveConfigPathValue = (value, configDirectory) => {
6456
6528
  if (isAbsolute(value)) return value;
6457
6529
  return resolve(configDirectory, value);
6458
6530
  };
6459
- const findWebpackConfigScope = (configPath, rootDir) => {
6531
+ const findConfigScope = (configPath, rootDir) => {
6460
6532
  let currentDirectory = dirname(configPath);
6461
6533
  const absoluteRoot = resolve(rootDir);
6462
6534
  while (currentDirectory.length >= absoluteRoot.length) {
@@ -6467,24 +6539,25 @@ const findWebpackConfigScope = (configPath, rootDir) => {
6467
6539
  }
6468
6540
  return absoluteRoot;
6469
6541
  };
6470
- const extractWebpackAliases = (content, configDirectory) => {
6542
+ const extractBundlerAliases = (content, configDirectory) => {
6471
6543
  const aliases = [];
6472
6544
  let aliasBlockMatch;
6473
- WEBPACK_ALIAS_BLOCK_PATTERN.lastIndex = 0;
6474
- while ((aliasBlockMatch = WEBPACK_ALIAS_BLOCK_PATTERN.exec(content)) !== null) {
6545
+ ALIAS_BLOCK_PATTERN.lastIndex = 0;
6546
+ while ((aliasBlockMatch = ALIAS_BLOCK_PATTERN.exec(content)) !== null) {
6475
6547
  const aliasBlock = aliasBlockMatch[1];
6476
6548
  let aliasEntryMatch;
6477
- WEBPACK_ALIAS_ENTRY_PATTERN.lastIndex = 0;
6478
- while ((aliasEntryMatch = WEBPACK_ALIAS_ENTRY_PATTERN.exec(aliasBlock)) !== null) {
6549
+ ALIAS_ENTRY_PATTERN.lastIndex = 0;
6550
+ while ((aliasEntryMatch = ALIAS_ENTRY_PATTERN.exec(aliasBlock)) !== null) {
6479
6551
  const rawName = aliasEntryMatch[1];
6480
6552
  const pathCallSegments = aliasEntryMatch[2];
6481
- const stringTarget = aliasEntryMatch[3];
6482
- if (!pathCallSegments && !stringTarget) continue;
6553
+ const fileUrlTarget = aliasEntryMatch[3];
6554
+ const stringTarget = aliasEntryMatch[4];
6483
6555
  const isExact = rawName.endsWith("$");
6484
6556
  const name = isExact ? rawName.slice(0, -1) : rawName.replace(/\/$/, "");
6485
6557
  let targetDirectory;
6486
6558
  if (pathCallSegments) targetDirectory = resolve(configDirectory, ...extractQuotedSegments(pathCallSegments));
6487
- else if (stringTarget) targetDirectory = resolveWebpackPathValue(stringTarget, configDirectory);
6559
+ else if (fileUrlTarget) targetDirectory = resolve(configDirectory, fileUrlTarget);
6560
+ else if (stringTarget) targetDirectory = resolveConfigPathValue(stringTarget, configDirectory);
6488
6561
  else continue;
6489
6562
  aliases.push({
6490
6563
  name,
@@ -6495,6 +6568,32 @@ const extractWebpackAliases = (content, configDirectory) => {
6495
6568
  }
6496
6569
  return aliases;
6497
6570
  };
6571
+ const compileJestModuleNameMapperAlias = (pattern, target, configDirectory) => {
6572
+ if (!target.includes("<rootDir>")) return void 0;
6573
+ const isWildcard = pattern.includes("(.*)") || pattern.includes("(.+)");
6574
+ const aliasName = pattern.replace(/^\^/, "").replace(/\$$/, "").replace(/\\(.)/g, "$1").replace(/\/?\((?:\.\*|\.\+)\)$/, "").replace(/\/$/, "");
6575
+ if (!aliasName) return void 0;
6576
+ return {
6577
+ name: aliasName,
6578
+ targetDirectory: resolve(target.replace(/<rootDir>/g, configDirectory).replace(/\/?\$\d+$/, "")),
6579
+ isExact: !isWildcard
6580
+ };
6581
+ };
6582
+ const extractJestModuleNameMapperAliases = (content, configDirectory) => {
6583
+ const aliases = [];
6584
+ let blockMatch;
6585
+ JEST_MODULE_NAME_MAPPER_BLOCK_PATTERN.lastIndex = 0;
6586
+ while ((blockMatch = JEST_MODULE_NAME_MAPPER_BLOCK_PATTERN.exec(content)) !== null) {
6587
+ const block = blockMatch[1];
6588
+ let entryMatch;
6589
+ JEST_MODULE_NAME_MAPPER_ENTRY_PATTERN.lastIndex = 0;
6590
+ while ((entryMatch = JEST_MODULE_NAME_MAPPER_ENTRY_PATTERN.exec(block)) !== null) {
6591
+ const alias = compileJestModuleNameMapperAlias(entryMatch[1], entryMatch[2], configDirectory);
6592
+ if (alias) aliases.push(alias);
6593
+ }
6594
+ }
6595
+ return aliases;
6596
+ };
6498
6597
  const extractWebpackModuleDirectories = (content, configDirectory) => {
6499
6598
  const moduleDirectories = [];
6500
6599
  let modulesBlockMatch;
@@ -6505,17 +6604,39 @@ const extractWebpackModuleDirectories = (content, configDirectory) => {
6505
6604
  WEBPACK_PATH_CALL_PATTERN.lastIndex = 0;
6506
6605
  while ((pathCallMatch = WEBPACK_PATH_CALL_PATTERN.exec(modulesBlock)) !== null) moduleDirectories.push(resolve(configDirectory, ...extractQuotedSegments(pathCallMatch[1])));
6507
6606
  let stringMatch;
6508
- WEBPACK_STRING_LITERAL_PATTERN.lastIndex = 0;
6509
- while ((stringMatch = WEBPACK_STRING_LITERAL_PATTERN.exec(modulesBlock)) !== null) {
6607
+ STRING_LITERAL_PATTERN.lastIndex = 0;
6608
+ while ((stringMatch = STRING_LITERAL_PATTERN.exec(modulesBlock)) !== null) {
6510
6609
  const moduleDirectory = stringMatch[1];
6511
6610
  if (moduleDirectory === "node_modules") continue;
6512
- moduleDirectories.push(resolveWebpackPathValue(moduleDirectory, configDirectory));
6611
+ moduleDirectories.push(resolveConfigPathValue(moduleDirectory, configDirectory));
6513
6612
  }
6514
6613
  }
6515
6614
  return [...new Set(moduleDirectories)];
6516
6615
  };
6517
- const loadWebpackResolverConfigs = (rootDir) => {
6518
- const configPaths = fg.sync(WEBPACK_CONFIG_GLOBS, {
6616
+ const isJestConfigPath = (configPath) => /(?:^|[\\/])jest\.config\.[^\\/]+$/.test(configPath);
6617
+ const isWebpackConfigPath = (configPath) => /webpack/.test(configPath);
6618
+ const extractPackageJsonJestAliases = (rootDir) => {
6619
+ try {
6620
+ const moduleNameMapper = JSON.parse(cachedReadFileSync(join(rootDir, "package.json")))?.jest?.moduleNameMapper;
6621
+ if (!moduleNameMapper || typeof moduleNameMapper !== "object") return [];
6622
+ const aliases = [];
6623
+ for (const [pattern, target] of Object.entries(moduleNameMapper)) {
6624
+ if (typeof target !== "string") continue;
6625
+ const alias = compileJestModuleNameMapperAlias(pattern, target, rootDir);
6626
+ if (alias) aliases.push(alias);
6627
+ }
6628
+ return aliases;
6629
+ } catch {
6630
+ return [];
6631
+ }
6632
+ };
6633
+ const loadBundlerAliasConfigs = (rootDir) => {
6634
+ const configPaths = fg.sync([
6635
+ ...WEBPACK_CONFIG_GLOBS,
6636
+ ...VITE_CONFIG_GLOBS,
6637
+ ...BABEL_CONFIG_GLOBS,
6638
+ ...JEST_CONFIG_GLOBS
6639
+ ], {
6519
6640
  cwd: rootDir,
6520
6641
  absolute: true,
6521
6642
  onlyFiles: true,
@@ -6530,17 +6651,24 @@ const loadWebpackResolverConfigs = (rootDir) => {
6530
6651
  for (const configPath of configPaths) try {
6531
6652
  const content = cachedReadFileSync(configPath);
6532
6653
  const configDirectory = dirname(configPath);
6533
- const aliases = extractWebpackAliases(content, configDirectory);
6534
- const moduleDirectories = extractWebpackModuleDirectories(content, configDirectory);
6654
+ const aliases = extractBundlerAliases(content, configDirectory);
6655
+ if (isJestConfigPath(configPath)) aliases.push(...extractJestModuleNameMapperAliases(content, configDirectory));
6656
+ const moduleDirectories = isWebpackConfigPath(configPath) ? extractWebpackModuleDirectories(content, configDirectory) : [];
6535
6657
  if (aliases.length === 0 && moduleDirectories.length === 0) continue;
6536
6658
  configs.push({
6537
- scopeDirectory: findWebpackConfigScope(configPath, rootDir),
6659
+ scopeDirectory: findConfigScope(configPath, rootDir),
6538
6660
  aliases,
6539
6661
  moduleDirectories
6540
6662
  });
6541
6663
  } catch {
6542
6664
  continue;
6543
6665
  }
6666
+ const packageJsonJestAliases = extractPackageJsonJestAliases(rootDir);
6667
+ if (packageJsonJestAliases.length > 0) configs.push({
6668
+ scopeDirectory: resolve(rootDir),
6669
+ aliases: packageJsonJestAliases,
6670
+ moduleDirectories: []
6671
+ });
6544
6672
  return configs;
6545
6673
  };
6546
6674
  const createResolver = (config, workspacePackages = [], options = {}) => {
@@ -6579,7 +6707,36 @@ const createResolver = (config, workspacePackages = [], options = {}) => {
6579
6707
  };
6580
6708
  const workspaceNameToDirectory = /* @__PURE__ */ new Map();
6581
6709
  for (const workspacePackage of workspacePackages) workspaceNameToDirectory.set(workspacePackage.name, workspacePackage.directory);
6582
- const webpackResolverConfigs = (options.monorepoRoot && options.monorepoRoot !== config.rootDir ? [config.rootDir, options.monorepoRoot] : [config.rootDir]).flatMap(loadWebpackResolverConfigs).sort((leftConfig, rightConfig) => rightConfig.scopeDirectory.length - leftConfig.scopeDirectory.length);
6710
+ const structuralAliasToDirectory = /* @__PURE__ */ new Map();
6711
+ const workspaceScopes = /* @__PURE__ */ new Set();
6712
+ for (const workspacePackage of workspacePackages) {
6713
+ if (!workspacePackage.name.startsWith("@")) continue;
6714
+ const slashIndex = workspacePackage.name.indexOf("/");
6715
+ if (slashIndex !== -1) workspaceScopes.add(workspacePackage.name.slice(0, slashIndex));
6716
+ }
6717
+ if (workspaceScopes.size > 0) {
6718
+ const ambiguousStructuralKeys = /* @__PURE__ */ new Set();
6719
+ const registerStructuralAlias = (aliasKey, directory) => {
6720
+ if (workspaceNameToDirectory.has(aliasKey)) return;
6721
+ const existing = structuralAliasToDirectory.get(aliasKey);
6722
+ if (existing !== void 0 && existing !== directory) {
6723
+ ambiguousStructuralKeys.add(aliasKey);
6724
+ return;
6725
+ }
6726
+ structuralAliasToDirectory.set(aliasKey, directory);
6727
+ };
6728
+ for (const workspacePackage of workspacePackages) {
6729
+ const directoryBasename = basename(workspacePackage.directory);
6730
+ const slashIndex = workspacePackage.name.indexOf("/");
6731
+ const unscopedName = workspacePackage.name.startsWith("@") && slashIndex !== -1 ? workspacePackage.name.slice(slashIndex + 1) : workspacePackage.name;
6732
+ for (const scope of workspaceScopes) {
6733
+ registerStructuralAlias(`${scope}/${directoryBasename}`, workspacePackage.directory);
6734
+ if (unscopedName && unscopedName !== directoryBasename) registerStructuralAlias(`${scope}/${unscopedName}`, workspacePackage.directory);
6735
+ }
6736
+ }
6737
+ for (const ambiguousKey of ambiguousStructuralKeys) structuralAliasToDirectory.delete(ambiguousKey);
6738
+ }
6739
+ const bundlerAliasConfigs = (options.monorepoRoot && options.monorepoRoot !== config.rootDir ? [config.rootDir, options.monorepoRoot] : [config.rootDir]).flatMap(loadBundlerAliasConfigs).sort((leftConfig, rightConfig) => rightConfig.scopeDirectory.length - leftConfig.scopeDirectory.length);
6583
6740
  let rootTsconfigPath;
6584
6741
  if (config.tsConfigPath) rootTsconfigPath = resolve(config.rootDir, config.tsConfigPath);
6585
6742
  else {
@@ -6597,6 +6754,7 @@ const createResolver = (config, workspacePackages = [], options = {}) => {
6597
6754
  }
6598
6755
  const tsconfigPathCache = /* @__PURE__ */ new Map();
6599
6756
  const tsconfigPathAliasCache = /* @__PURE__ */ new Map();
6757
+ const tsconfigCompiledAliasCache = /* @__PURE__ */ new Map();
6600
6758
  const findTsconfigForFile = (filePath) => {
6601
6759
  const fileDir = dirname(filePath);
6602
6760
  const cached = tsconfigPathCache.get(fileDir);
@@ -6743,64 +6901,127 @@ const createResolver = (config, workspacePackages = [], options = {}) => {
6743
6901
  tsconfigPathAliasCache.set(tsconfigFile, aliasMap);
6744
6902
  return aliasMap;
6745
6903
  };
6904
+ const getCompiledPathAliases = (tsconfigFile) => {
6905
+ const cached = tsconfigCompiledAliasCache.get(tsconfigFile);
6906
+ if (cached) return cached;
6907
+ const compiled = compilePathMappings(getPathAliases(tsconfigFile));
6908
+ tsconfigCompiledAliasCache.set(tsconfigFile, compiled);
6909
+ return compiled;
6910
+ };
6746
6911
  const tryResolveViaPathAlias = (specifier, fromFile) => {
6747
6912
  const tsconfigFile = findTsconfigForFile(fromFile);
6748
6913
  if (!tsconfigFile) return void 0;
6749
- const aliases = getPathAliases(tsconfigFile);
6750
- for (const [pattern, targetPatterns] of aliases) {
6751
- const wildcardIndex = pattern.indexOf("*");
6752
- if (wildcardIndex === -1) {
6753
- if (specifier === pattern) for (const targetPattern of targetPatterns) {
6754
- const candidate = targetPattern.replace("*", "");
6755
- if (existsAsFile(candidate)) return candidate;
6756
- for (const ext of RESOLVER_EXTENSIONS) if (cachedExistsSync(candidate + ext)) return candidate + ext;
6757
- const indexCandidate = join(candidate, "index");
6758
- for (const ext of RESOLVER_EXTENSIONS) if (cachedExistsSync(indexCandidate + ext)) return indexCandidate + ext;
6759
- }
6760
- continue;
6761
- }
6762
- const prefix = pattern.slice(0, wildcardIndex);
6763
- const suffix = pattern.slice(wildcardIndex + 1);
6764
- if (!specifier.startsWith(prefix) || !specifier.endsWith(suffix)) continue;
6765
- const matchedWildcard = specifier.slice(prefix.length, specifier.length - suffix.length);
6766
- for (const targetPattern of targetPatterns) {
6767
- const resolvedTarget = targetPattern.replace("*", matchedWildcard);
6768
- if (existsAsFile(resolvedTarget)) return resolvedTarget;
6769
- for (const ext of RESOLVER_EXTENSIONS) if (cachedExistsSync(resolvedTarget + ext)) return resolvedTarget + ext;
6770
- const strippedTarget = resolvedTarget.replace(/\.[cm]?js$/, "");
6771
- if (strippedTarget !== resolvedTarget) {
6772
- for (const ext of RESOLVER_EXTENSIONS) if (cachedExistsSync(strippedTarget + ext)) return strippedTarget + ext;
6773
- }
6774
- const indexCandidate = join(resolvedTarget, "index");
6775
- for (const ext of RESOLVER_EXTENSIONS) if (cachedExistsSync(indexCandidate + ext)) return indexCandidate + ext;
6776
- }
6777
- }
6914
+ return matchCompiledMapping(specifier, getCompiledPathAliases(tsconfigFile));
6778
6915
  };
6779
6916
  const tryResolveFromDirectory = (directory, specifier) => {
6780
6917
  const candidatePath = resolvePathWithExtensionFallback(resolve(directory, specifier));
6781
6918
  if (existsAsFile(candidatePath)) return candidatePath;
6782
6919
  };
6783
- const tryResolveViaWebpackConfig = (specifier, fromFile) => {
6784
- if (webpackResolverConfigs.length === 0) return void 0;
6920
+ const tryResolveViaBundlerAlias = (specifier, fromFile) => {
6921
+ if (bundlerAliasConfigs.length === 0) return void 0;
6785
6922
  if (!isBareSpecifier(specifier)) return void 0;
6786
- for (const webpackConfig of webpackResolverConfigs) {
6787
- if (!isInsideDirectory(fromFile, webpackConfig.scopeDirectory)) continue;
6788
- for (const alias of webpackConfig.aliases) {
6923
+ for (const bundlerConfig of bundlerAliasConfigs) {
6924
+ if (!isInsideDirectory(fromFile, bundlerConfig.scopeDirectory)) continue;
6925
+ for (const alias of bundlerConfig.aliases) {
6789
6926
  if (alias.isExact && specifier !== alias.name) continue;
6790
6927
  const suffix = specifier === alias.name ? "" : specifier.startsWith(`${alias.name}/`) ? specifier.slice(alias.name.length + 1) : void 0;
6791
6928
  if (suffix === void 0) continue;
6792
6929
  const aliasCandidate = tryResolveFromDirectory(alias.targetDirectory, suffix);
6793
6930
  if (aliasCandidate) return aliasCandidate;
6794
6931
  }
6795
- for (const moduleDirectory of webpackConfig.moduleDirectories) {
6932
+ for (const moduleDirectory of bundlerConfig.moduleDirectories) {
6796
6933
  const moduleCandidate = tryResolveFromDirectory(moduleDirectory, specifier);
6797
6934
  if (moduleCandidate) return moduleCandidate;
6798
6935
  }
6799
6936
  }
6800
6937
  };
6938
+ const compiledConfigPaths = config.paths ? compilePathMappings(Object.entries(config.paths).map(([pattern, targets]) => [pattern, targets.map((target) => resolve(config.rootDir, target))])) : [];
6939
+ const tryResolveViaConfigPaths = (specifier) => compiledConfigPaths.length === 0 ? void 0 : matchCompiledMapping(specifier, compiledConfigPaths);
6940
+ const resolveWorkspaceSubpath = (workspaceDirectory, subpath) => {
6941
+ const workspacePackageJsonPath = join(workspaceDirectory, "package.json");
6942
+ try {
6943
+ const workspacePackageContent = cachedReadFileSync(workspacePackageJsonPath);
6944
+ const workspacePackageJson = JSON.parse(workspacePackageContent);
6945
+ let resolvedEntryPath;
6946
+ if (subpath && workspacePackageJson.exports) {
6947
+ const exportKey = `./${subpath}`;
6948
+ const exportValue = workspacePackageJson.exports[exportKey];
6949
+ if (typeof exportValue === "string") {
6950
+ const candidatePath = resolvePathWithExtensionFallback(resolve(workspaceDirectory, exportValue));
6951
+ resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6952
+ } else if (typeof exportValue === "object" && exportValue !== null) {
6953
+ const conditionValue = exportValue.import ?? exportValue.require ?? exportValue.default ?? exportValue.types;
6954
+ if (typeof conditionValue === "string") {
6955
+ const candidatePath = resolvePathWithExtensionFallback(resolve(workspaceDirectory, conditionValue));
6956
+ resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6957
+ }
6958
+ }
6959
+ if (!resolvedEntryPath) for (const [wildcardPattern, wildcardTarget] of Object.entries(workspacePackageJson.exports)) {
6960
+ if (typeof wildcardPattern !== "string" || !wildcardPattern.includes("*")) continue;
6961
+ const wildcardTargetRecord = typeof wildcardTarget === "object" && wildcardTarget !== null ? wildcardTarget : void 0;
6962
+ const wildcardTargetValue = typeof wildcardTarget === "string" ? wildcardTarget : wildcardTargetRecord ? String(wildcardTargetRecord["import"] ?? wildcardTargetRecord["require"] ?? wildcardTargetRecord["default"] ?? wildcardTargetRecord["types"] ?? "") : void 0;
6963
+ if (typeof wildcardTargetValue !== "string") continue;
6964
+ const wildcardPrefix = wildcardPattern.slice(0, wildcardPattern.indexOf("*"));
6965
+ const wildcardSuffix = wildcardPattern.slice(wildcardPattern.indexOf("*") + 1);
6966
+ if (exportKey.startsWith(wildcardPrefix) && exportKey.endsWith(wildcardSuffix)) {
6967
+ const matchedSegment = exportKey.slice(wildcardPrefix.length, exportKey.length - wildcardSuffix.length || void 0);
6968
+ const candidatePath = resolvePathWithExtensionFallback(resolve(workspaceDirectory, wildcardTargetValue.replace("*", matchedSegment)));
6969
+ resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6970
+ break;
6971
+ }
6972
+ }
6973
+ }
6974
+ if (subpath && !resolvedEntryPath) {
6975
+ const subpathCandidates = [resolve(workspaceDirectory, subpath), resolve(workspaceDirectory, "src", subpath)];
6976
+ for (const directSubpath of subpathCandidates) {
6977
+ for (const candidateExtension of RESOLVER_EXTENSIONS) {
6978
+ const candidate = directSubpath + candidateExtension;
6979
+ if (cachedExistsSync(candidate)) {
6980
+ resolvedEntryPath = candidate;
6981
+ break;
6982
+ }
6983
+ }
6984
+ if (resolvedEntryPath) break;
6985
+ for (const candidateExtension of RESOLVER_EXTENSIONS) {
6986
+ const indexCandidate = join(directSubpath, `index${candidateExtension}`);
6987
+ if (cachedExistsSync(indexCandidate)) {
6988
+ resolvedEntryPath = indexCandidate;
6989
+ break;
6990
+ }
6991
+ }
6992
+ if (resolvedEntryPath) break;
6993
+ }
6994
+ }
6995
+ if (!subpath) {
6996
+ const mainField = workspacePackageJson.main ?? workspacePackageJson.module;
6997
+ if (typeof mainField === "string") resolvedEntryPath = resolve(workspaceDirectory, mainField);
6998
+ if (!resolvedEntryPath && workspacePackageJson.exports?.["."]) {
6999
+ const dotExport = workspacePackageJson.exports["."];
7000
+ if (typeof dotExport === "string") resolvedEntryPath = resolve(workspaceDirectory, dotExport);
7001
+ else if (typeof dotExport === "object" && dotExport !== null) {
7002
+ const conditionValue = dotExport.import ?? dotExport.require ?? dotExport.default ?? dotExport.types;
7003
+ if (typeof conditionValue === "string") resolvedEntryPath = resolve(workspaceDirectory, conditionValue);
7004
+ }
7005
+ }
7006
+ }
7007
+ if (resolvedEntryPath) {
7008
+ const finalPath = resolveSourcePath(resolvedEntryPath, workspaceDirectory) ?? resolvedEntryPath;
7009
+ if (cachedExistsSync(finalPath)) return finalPath;
7010
+ const sourceFallbackPath = trySourceFallback(resolvedEntryPath);
7011
+ if (sourceFallbackPath) return sourceFallbackPath;
7012
+ }
7013
+ } catch {}
7014
+ };
7015
+ const tryResolveViaWorkspaceStructure = (specifier) => {
7016
+ if (structuralAliasToDirectory.size === 0) return void 0;
7017
+ if (!isBareSpecifier(specifier)) return void 0;
7018
+ const packageKey = extractPackageNameFromSpecifier(specifier);
7019
+ const directory = structuralAliasToDirectory.get(packageKey);
7020
+ if (!directory) return void 0;
7021
+ return resolveWorkspaceSubpath(directory, specifier.length > packageKey.length ? specifier.slice(packageKey.length + 1) : "");
7022
+ };
6801
7023
  const resolveModule = (specifier, fromFile) => {
6802
- const queryIndex = specifier.indexOf("?");
6803
- const cleanedSpecifier = queryIndex !== -1 ? specifier.slice(0, queryIndex) : specifier;
7024
+ const cleanedSpecifier = sanitizeImportSpecifier(specifier);
6804
7025
  const fromDir = dirname(fromFile);
6805
7026
  const cacheKey = `${fromDir}::${cleanedSpecifier}`;
6806
7027
  const cached = resolveResultCache.get(cacheKey);
@@ -6830,96 +7051,16 @@ const createResolver = (config, workspacePackages = [], options = {}) => {
6830
7051
  const packageName = extractPackageNameFromSpecifier(cleanedSpecifier);
6831
7052
  const workspaceDirectory = workspaceNameToDirectory.get(packageName);
6832
7053
  if (workspaceDirectory) {
6833
- const subpath = cleanedSpecifier.slice(packageName.length + 1);
6834
- const workspacePackageJsonPath = join(workspaceDirectory, "package.json");
6835
- try {
6836
- const workspacePackageContent = cachedReadFileSync(workspacePackageJsonPath);
6837
- const workspacePackageJson = JSON.parse(workspacePackageContent);
6838
- let resolvedEntryPath;
6839
- if (subpath && workspacePackageJson.exports) {
6840
- const exportKey = `./${subpath}`;
6841
- const exportValue = workspacePackageJson.exports[exportKey];
6842
- if (typeof exportValue === "string") {
6843
- const candidatePath = resolvePathWithExtensionFallback(resolve(workspaceDirectory, exportValue));
6844
- resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6845
- } else if (typeof exportValue === "object" && exportValue !== null) {
6846
- const conditionValue = exportValue.import ?? exportValue.require ?? exportValue.default ?? exportValue.types;
6847
- if (typeof conditionValue === "string") {
6848
- const candidatePath = resolvePathWithExtensionFallback(resolve(workspaceDirectory, conditionValue));
6849
- resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6850
- }
6851
- }
6852
- if (!resolvedEntryPath) for (const [wildcardPattern, wildcardTarget] of Object.entries(workspacePackageJson.exports)) {
6853
- if (typeof wildcardPattern !== "string" || !wildcardPattern.includes("*")) continue;
6854
- const wildcardTargetRecord = typeof wildcardTarget === "object" && wildcardTarget !== null ? wildcardTarget : void 0;
6855
- const wildcardTargetValue = typeof wildcardTarget === "string" ? wildcardTarget : wildcardTargetRecord ? String(wildcardTargetRecord["import"] ?? wildcardTargetRecord["require"] ?? wildcardTargetRecord["default"] ?? wildcardTargetRecord["types"] ?? "") : void 0;
6856
- if (typeof wildcardTargetValue !== "string") continue;
6857
- const wildcardPrefix = wildcardPattern.slice(0, wildcardPattern.indexOf("*"));
6858
- const wildcardSuffix = wildcardPattern.slice(wildcardPattern.indexOf("*") + 1);
6859
- if (exportKey.startsWith(wildcardPrefix) && exportKey.endsWith(wildcardSuffix)) {
6860
- const matchedSegment = exportKey.slice(wildcardPrefix.length, exportKey.length - wildcardSuffix.length || void 0);
6861
- const candidatePath = resolvePathWithExtensionFallback(resolve(workspaceDirectory, wildcardTargetValue.replace("*", matchedSegment)));
6862
- resolvedEntryPath = existsAsFile(candidatePath) ? candidatePath : trySourceFallback(candidatePath);
6863
- break;
6864
- }
6865
- }
6866
- }
6867
- if (subpath && !resolvedEntryPath) {
6868
- const subpathCandidates = [resolve(workspaceDirectory, subpath), resolve(workspaceDirectory, "src", subpath)];
6869
- for (const directSubpath of subpathCandidates) {
6870
- for (const candidateExtension of RESOLVER_EXTENSIONS) {
6871
- const candidate = directSubpath + candidateExtension;
6872
- if (cachedExistsSync(candidate)) {
6873
- resolvedEntryPath = candidate;
6874
- break;
6875
- }
6876
- }
6877
- if (resolvedEntryPath) break;
6878
- for (const candidateExtension of RESOLVER_EXTENSIONS) {
6879
- const indexCandidate = join(directSubpath, `index${candidateExtension}`);
6880
- if (cachedExistsSync(indexCandidate)) {
6881
- resolvedEntryPath = indexCandidate;
6882
- break;
6883
- }
6884
- }
6885
- if (resolvedEntryPath) break;
6886
- }
6887
- }
6888
- if (!subpath) {
6889
- const mainField = workspacePackageJson.main ?? workspacePackageJson.module;
6890
- if (typeof mainField === "string") resolvedEntryPath = resolve(workspaceDirectory, mainField);
6891
- if (!resolvedEntryPath && workspacePackageJson.exports?.["."]) {
6892
- const dotExport = workspacePackageJson.exports["."];
6893
- if (typeof dotExport === "string") resolvedEntryPath = resolve(workspaceDirectory, dotExport);
6894
- else if (typeof dotExport === "object" && dotExport !== null) {
6895
- const conditionValue = dotExport.import ?? dotExport.require ?? dotExport.default ?? dotExport.types;
6896
- if (typeof conditionValue === "string") resolvedEntryPath = resolve(workspaceDirectory, conditionValue);
6897
- }
6898
- }
6899
- }
6900
- if (resolvedEntryPath) {
6901
- const finalPath = resolveSourcePath(resolvedEntryPath, workspaceDirectory) ?? resolvedEntryPath;
6902
- if (cachedExistsSync(finalPath)) {
6903
- const resolvedResult = {
6904
- resolvedPath: finalPath,
6905
- isExternal: false,
6906
- packageName: void 0
6907
- };
6908
- resolveResultCache.set(cacheKey, resolvedResult);
6909
- return resolvedResult;
6910
- }
6911
- const sourceFallbackPath = trySourceFallback(resolvedEntryPath);
6912
- if (sourceFallbackPath) {
6913
- const resolvedResult = {
6914
- resolvedPath: sourceFallbackPath,
6915
- isExternal: false,
6916
- packageName: void 0
6917
- };
6918
- resolveResultCache.set(cacheKey, resolvedResult);
6919
- return resolvedResult;
6920
- }
6921
- }
6922
- } catch {}
7054
+ const resolvedWorkspacePath = resolveWorkspaceSubpath(workspaceDirectory, cleanedSpecifier.slice(packageName.length + 1));
7055
+ if (resolvedWorkspacePath) {
7056
+ const resolvedResult = {
7057
+ resolvedPath: resolvedWorkspacePath,
7058
+ isExternal: false,
7059
+ packageName: void 0
7060
+ };
7061
+ resolveResultCache.set(cacheKey, resolvedResult);
7062
+ return resolvedResult;
7063
+ }
6923
7064
  }
6924
7065
  }
6925
7066
  const tsconfigForFile = findTsconfigForFile(fromFile);
@@ -6962,10 +7103,30 @@ const createResolver = (config, workspacePackages = [], options = {}) => {
6962
7103
  resolveResultCache.set(cacheKey, resolvedResult);
6963
7104
  return resolvedResult;
6964
7105
  }
6965
- const webpackResolved = tryResolveViaWebpackConfig(cleanedSpecifier, fromFile);
6966
- if (webpackResolved) {
7106
+ const configPathResolved = tryResolveViaConfigPaths(cleanedSpecifier);
7107
+ if (configPathResolved) {
7108
+ const resolvedResult = {
7109
+ resolvedPath: configPathResolved,
7110
+ isExternal: false,
7111
+ packageName: void 0
7112
+ };
7113
+ resolveResultCache.set(cacheKey, resolvedResult);
7114
+ return resolvedResult;
7115
+ }
7116
+ const bundlerAliasResolved = tryResolveViaBundlerAlias(cleanedSpecifier, fromFile);
7117
+ if (bundlerAliasResolved) {
7118
+ const resolvedResult = {
7119
+ resolvedPath: bundlerAliasResolved,
7120
+ isExternal: false,
7121
+ packageName: void 0
7122
+ };
7123
+ resolveResultCache.set(cacheKey, resolvedResult);
7124
+ return resolvedResult;
7125
+ }
7126
+ const structuralResolved = tryResolveViaWorkspaceStructure(cleanedSpecifier);
7127
+ if (structuralResolved) {
6967
7128
  const resolvedResult = {
6968
- resolvedPath: webpackResolved,
7129
+ resolvedPath: structuralResolved,
6969
7130
  isExternal: false,
6970
7131
  packageName: void 0
6971
7132
  };
@@ -12648,6 +12809,7 @@ const defineConfig = (options) => ({
12648
12809
  ignorePatterns: options.ignorePatterns ?? [],
12649
12810
  includeExtensions: options.includeExtensions ?? DEFAULT_EXTENSIONS,
12650
12811
  tsConfigPath: options.tsConfigPath,
12812
+ paths: options.paths,
12651
12813
  reportTypes: options.reportTypes ?? false,
12652
12814
  includeEntryExports: options.includeEntryExports ?? false,
12653
12815
  reportRedundancy: options.reportRedundancy ?? true,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "deslop-js",
3
- "version": "0.0.19-dev.be8757d",
3
+ "version": "0.0.20-dev.867c5c6",
4
4
  "description": "Deslop JavaScript code",
5
5
  "keywords": [
6
6
  "dead-code",