no-unused-modules.js 123 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072
  1. 'use strict';var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) {return typeof obj;} : function (obj) {return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;};
  2. var _contextCompat = require('eslint-module-utils/contextCompat');
  3. var _ignore = require('eslint-module-utils/ignore');
  4. var _resolve = require('eslint-module-utils/resolve');var _resolve2 = _interopRequireDefault(_resolve);
  5. var _visit = require('eslint-module-utils/visit');var _visit2 = _interopRequireDefault(_visit);
  6. var _path = require('path');
  7. var _readPkgUp2 = require('eslint-module-utils/readPkgUp');var _readPkgUp3 = _interopRequireDefault(_readPkgUp2);
  8. var _object = require('object.values');var _object2 = _interopRequireDefault(_object);
  9. var _arrayIncludes = require('array-includes');var _arrayIncludes2 = _interopRequireDefault(_arrayIncludes);
  10. var _arrayPrototype = require('array.prototype.flatmap');var _arrayPrototype2 = _interopRequireDefault(_arrayPrototype);
  11. var _builder = require('../exportMap/builder');var _builder2 = _interopRequireDefault(_builder);
  12. var _patternCapture = require('../exportMap/patternCapture');var _patternCapture2 = _interopRequireDefault(_patternCapture);
  13. var _docsUrl = require('../docsUrl');var _docsUrl2 = _interopRequireDefault(_docsUrl);function _interopRequireDefault(obj) {return obj && obj.__esModule ? obj : { 'default': obj };}function _toConsumableArray(arr) {if (Array.isArray(arr)) {for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) {arr2[i] = arr[i];}return arr2;} else {return Array.from(arr);}} /**
  14. * @fileOverview Ensures that modules contain exports and/or all
  15. * modules are consumed within other modules.
  16. * @author René Fermann
  17. */ /**
  18. * Attempt to load the internal `FileEnumerator` class, which has existed in a couple
  19. * of different places, depending on the version of `eslint`. Try requiring it from both
  20. * locations.
  21. * @returns Returns the `FileEnumerator` class if its requirable, otherwise `undefined`.
  22. */function requireFileEnumerator() {var FileEnumerator = void 0;
  23. // Try getting it from the eslint private / deprecated api
  24. try {var _require =
  25. require('eslint/use-at-your-own-risk');FileEnumerator = _require.FileEnumerator;
  26. } catch (e) {
  27. // Absorb this if it's MODULE_NOT_FOUND
  28. if (e.code !== 'MODULE_NOT_FOUND') {
  29. throw e;
  30. }
  31. // If not there, then try getting it from eslint/lib/cli-engine/file-enumerator (moved there in v6)
  32. try {var _require2 =
  33. require('eslint/lib/cli-engine/file-enumerator');FileEnumerator = _require2.FileEnumerator;
  34. } catch (e) {
  35. // Absorb this if it's MODULE_NOT_FOUND
  36. if (e.code !== 'MODULE_NOT_FOUND') {
  37. throw e;
  38. }
  39. }
  40. }
  41. return FileEnumerator;
  42. }
  43. /**
  44. * Given a FileEnumerator class, instantiate and load the list of files.
  45. * @param FileEnumerator the `FileEnumerator` class from `eslint`'s internal api
  46. * @param {string} src path to the src root
  47. * @param {string[]} extensions list of supported extensions
  48. * @returns {{ filename: string, ignored: boolean }[]} list of files to operate on
  49. */
  50. function listFilesUsingFileEnumerator(FileEnumerator, src, extensions) {
  51. // We need to know whether this is being run with flat config in order to
  52. // determine how to report errors if FileEnumerator throws due to a lack of eslintrc.
  53. var
  54. ESLINT_USE_FLAT_CONFIG = process.env.ESLINT_USE_FLAT_CONFIG;
  55. // This condition is sufficient to test in v8, since the environment variable is necessary to turn on flat config
  56. var isUsingFlatConfig = ESLINT_USE_FLAT_CONFIG && process.env.ESLINT_USE_FLAT_CONFIG !== 'false';
  57. // In the case of using v9, we can check the `shouldUseFlatConfig` function
  58. // If this function is present, then we assume it's v9
  59. try {var _require3 =
  60. require('eslint/use-at-your-own-risk'),shouldUseFlatConfig = _require3.shouldUseFlatConfig;
  61. isUsingFlatConfig = shouldUseFlatConfig && ESLINT_USE_FLAT_CONFIG !== 'false';
  62. } catch (_) {
  63. // We don't want to throw here, since we only want to update the
  64. // boolean if the function is available.
  65. }
  66. var enumerator = new FileEnumerator({
  67. extensions: extensions });
  68. try {
  69. return Array.from(
  70. enumerator.iterateFiles(src),
  71. function (_ref) {var filePath = _ref.filePath,ignored = _ref.ignored;return { filename: filePath, ignored: ignored };});
  72. } catch (e) {
  73. // If we're using flat config, and FileEnumerator throws due to a lack of eslintrc,
  74. // then we want to throw an error so that the user knows about this rule's reliance on
  75. // the legacy config.
  76. if (
  77. isUsingFlatConfig &&
  78. e.message.includes('No ESLint configuration found'))
  79. {
  80. throw new Error('\nDue to the exclusion of certain internal ESLint APIs when using flat config,\nthe import/no-unused-modules rule requires an .eslintrc file to know which\nfiles to ignore (even when using flat config).\nThe .eslintrc file only needs to contain "ignorePatterns", or can be empty if\nyou do not want to ignore any files.\n\nSee https://github.com/import-js/eslint-plugin-import/issues/3079\nfor additional context.\n');
  81. }
  82. // If this isn't the case, then we'll just let the error bubble up
  83. throw e;
  84. }
  85. }
  86. /**
  87. * Attempt to require old versions of the file enumeration capability from v6 `eslint` and earlier, and use
  88. * those functions to provide the list of files to operate on
  89. * @param {string} src path to the src root
  90. * @param {string[]} extensions list of supported extensions
  91. * @returns {string[]} list of files to operate on
  92. */
  93. function listFilesWithLegacyFunctions(src, extensions) {
  94. try {
  95. // eslint/lib/util/glob-util has been moved to eslint/lib/util/glob-utils with version 5.3
  96. var _require4 = require('eslint/lib/util/glob-utils'),originalListFilesToProcess = _require4.listFilesToProcess;
  97. // Prevent passing invalid options (extensions array) to old versions of the function.
  98. // https://github.com/eslint/eslint/blob/v5.16.0/lib/util/glob-utils.js#L178-L280
  99. // https://github.com/eslint/eslint/blob/v5.2.0/lib/util/glob-util.js#L174-L269
  100. return originalListFilesToProcess(src, {
  101. extensions: extensions });
  102. } catch (e) {
  103. // Absorb this if it's MODULE_NOT_FOUND
  104. if (e.code !== 'MODULE_NOT_FOUND') {
  105. throw e;
  106. }
  107. // Last place to try (pre v5.3)
  108. var _require5 =
  109. require('eslint/lib/util/glob-util'),_originalListFilesToProcess = _require5.listFilesToProcess;
  110. var patterns = src.concat(
  111. (0, _arrayPrototype2['default'])(
  112. src,
  113. function (pattern) {return extensions.map(function (extension) {return (/\*\*|\*\./.test(pattern) ? pattern : String(pattern) + '/**/*' + String(extension));});}));
  114. return _originalListFilesToProcess(patterns);
  115. }
  116. }
  117. /**
  118. * Given a src pattern and list of supported extensions, return a list of files to process
  119. * with this rule.
  120. * @param {string} src - file, directory, or glob pattern of files to act on
  121. * @param {string[]} extensions - list of supported file extensions
  122. * @returns {string[] | { filename: string, ignored: boolean }[]} the list of files that this rule will evaluate.
  123. */
  124. function listFilesToProcess(src, extensions) {
  125. var FileEnumerator = requireFileEnumerator();
  126. // If we got the FileEnumerator, then let's go with that
  127. if (FileEnumerator) {
  128. return listFilesUsingFileEnumerator(FileEnumerator, src, extensions);
  129. }
  130. // If not, then we can try even older versions of this capability (listFilesToProcess)
  131. return listFilesWithLegacyFunctions(src, extensions);
  132. }
  133. var EXPORT_DEFAULT_DECLARATION = 'ExportDefaultDeclaration';
  134. var EXPORT_NAMED_DECLARATION = 'ExportNamedDeclaration';
  135. var EXPORT_ALL_DECLARATION = 'ExportAllDeclaration';
  136. var IMPORT_DECLARATION = 'ImportDeclaration';
  137. var IMPORT_NAMESPACE_SPECIFIER = 'ImportNamespaceSpecifier';
  138. var IMPORT_DEFAULT_SPECIFIER = 'ImportDefaultSpecifier';
  139. var VARIABLE_DECLARATION = 'VariableDeclaration';
  140. var FUNCTION_DECLARATION = 'FunctionDeclaration';
  141. var CLASS_DECLARATION = 'ClassDeclaration';
  142. var IDENTIFIER = 'Identifier';
  143. var OBJECT_PATTERN = 'ObjectPattern';
  144. var ARRAY_PATTERN = 'ArrayPattern';
  145. var TS_INTERFACE_DECLARATION = 'TSInterfaceDeclaration';
  146. var TS_TYPE_ALIAS_DECLARATION = 'TSTypeAliasDeclaration';
  147. var TS_ENUM_DECLARATION = 'TSEnumDeclaration';
  148. var DEFAULT = 'default';
  149. function forEachDeclarationIdentifier(declaration, cb) {
  150. if (declaration) {
  151. var isTypeDeclaration = declaration.type === TS_INTERFACE_DECLARATION ||
  152. declaration.type === TS_TYPE_ALIAS_DECLARATION ||
  153. declaration.type === TS_ENUM_DECLARATION;
  154. if (
  155. declaration.type === FUNCTION_DECLARATION ||
  156. declaration.type === CLASS_DECLARATION ||
  157. isTypeDeclaration)
  158. {
  159. cb(declaration.id.name, isTypeDeclaration);
  160. } else if (declaration.type === VARIABLE_DECLARATION) {
  161. declaration.declarations.forEach(function (_ref2) {var id = _ref2.id;
  162. if (id.type === OBJECT_PATTERN) {
  163. (0, _patternCapture2['default'])(id, function (pattern) {
  164. if (pattern.type === IDENTIFIER) {
  165. cb(pattern.name, false);
  166. }
  167. });
  168. } else if (id.type === ARRAY_PATTERN) {
  169. id.elements.forEach(function (_ref3) {var name = _ref3.name;
  170. cb(name, false);
  171. });
  172. } else {
  173. cb(id.name, false);
  174. }
  175. });
  176. }
  177. }
  178. }
  179. /**
  180. * List of imports per file.
  181. *
  182. * Represented by a two-level Map to a Set of identifiers. The upper-level Map
  183. * keys are the paths to the modules containing the imports, while the
  184. * lower-level Map keys are the paths to the files which are being imported
  185. * from. Lastly, the Set of identifiers contains either names being imported
  186. * or a special AST node name listed above (e.g ImportDefaultSpecifier).
  187. *
  188. * For example, if we have a file named foo.js containing:
  189. *
  190. * import { o2 } from './bar.js';
  191. *
  192. * Then we will have a structure that looks like:
  193. *
  194. * Map { 'foo.js' => Map { 'bar.js' => Set { 'o2' } } }
  195. *
  196. * @type {Map<string, Map<string, Set<string>>>}
  197. */
  198. var importList = new Map();
  199. /**
  200. * List of exports per file.
  201. *
  202. * Represented by a two-level Map to an object of metadata. The upper-level Map
  203. * keys are the paths to the modules containing the exports, while the
  204. * lower-level Map keys are the specific identifiers or special AST node names
  205. * being exported. The leaf-level metadata object at the moment only contains a
  206. * `whereUsed` property, which contains a Set of paths to modules that import
  207. * the name.
  208. *
  209. * For example, if we have a file named bar.js containing the following exports:
  210. *
  211. * const o2 = 'bar';
  212. * export { o2 };
  213. *
  214. * And a file named foo.js containing the following import:
  215. *
  216. * import { o2 } from './bar.js';
  217. *
  218. * Then we will have a structure that looks like:
  219. *
  220. * Map { 'bar.js' => Map { 'o2' => { whereUsed: Set { 'foo.js' } } } }
  221. *
  222. * @type {Map<string, Map<string, object>>}
  223. */
  224. var exportList = new Map();
  225. var visitorKeyMap = new Map();
  226. /** @type {Set<string>} */
  227. var ignoredFiles = new Set();
  228. var filesOutsideSrc = new Set();
  229. var isNodeModule = function isNodeModule(path) {return (/\/(node_modules)\//.test(path));};
  230. /**
  231. * read all files matching the patterns in src and ignoreExports
  232. *
  233. * return all files matching src pattern, which are not matching the ignoreExports pattern
  234. * @type {(src: string, ignoreExports: string, context: import('eslint').Rule.RuleContext) => Set<string>}
  235. */
  236. function resolveFiles(src, ignoreExports, context) {
  237. var extensions = Array.from((0, _ignore.getFileExtensions)(context.settings));
  238. var srcFileList = listFilesToProcess(src, extensions);
  239. // prepare list of ignored files
  240. var ignoredFilesList = listFilesToProcess(ignoreExports, extensions);
  241. // The modern api will return a list of file paths, rather than an object
  242. if (ignoredFilesList.length && typeof ignoredFilesList[0] === 'string') {
  243. ignoredFilesList.forEach(function (filename) {return ignoredFiles.add(filename);});
  244. } else {
  245. ignoredFilesList.forEach(function (_ref4) {var filename = _ref4.filename;return ignoredFiles.add(filename);});
  246. }
  247. // prepare list of source files, don't consider files from node_modules
  248. var resolvedFiles = srcFileList.length && typeof srcFileList[0] === 'string' ?
  249. srcFileList.filter(function (filePath) {return !isNodeModule(filePath);}) :
  250. (0, _arrayPrototype2['default'])(srcFileList, function (_ref5) {var filename = _ref5.filename;return isNodeModule(filename) ? [] : filename;});
  251. return new Set(resolvedFiles);
  252. }
  253. /**
  254. * parse all source files and build up 2 maps containing the existing imports and exports
  255. */
  256. var prepareImportsAndExports = function prepareImportsAndExports(srcFiles, context) {
  257. var exportAll = new Map();
  258. srcFiles.forEach(function (file) {
  259. var exports = new Map();
  260. var imports = new Map();
  261. var currentExports = _builder2['default'].get(file, context);
  262. if (currentExports) {var
  263. dependencies =
  264. currentExports.dependencies,reexports = currentExports.reexports,localImportList = currentExports.imports,namespace = currentExports.namespace,visitorKeys = currentExports.visitorKeys;
  265. visitorKeyMap.set(file, visitorKeys);
  266. // dependencies === export * from
  267. var currentExportAll = new Set();
  268. dependencies.forEach(function (getDependency) {
  269. var dependency = getDependency();
  270. if (dependency === null) {
  271. return;
  272. }
  273. currentExportAll.add(dependency.path);
  274. });
  275. exportAll.set(file, currentExportAll);
  276. reexports.forEach(function (value, key) {
  277. if (key === DEFAULT) {
  278. exports.set(IMPORT_DEFAULT_SPECIFIER, { whereUsed: new Set() });
  279. } else {
  280. exports.set(key, { whereUsed: new Set() });
  281. }
  282. var reexport = value.getImport();
  283. if (!reexport) {
  284. return;
  285. }
  286. var localImport = imports.get(reexport.path);
  287. var currentValue = void 0;
  288. if (value.local === DEFAULT) {
  289. currentValue = IMPORT_DEFAULT_SPECIFIER;
  290. } else {
  291. currentValue = value.local;
  292. }
  293. if (typeof localImport !== 'undefined') {
  294. localImport = new Set([].concat(_toConsumableArray(localImport), [currentValue]));
  295. } else {
  296. localImport = new Set([currentValue]);
  297. }
  298. imports.set(reexport.path, localImport);
  299. });
  300. localImportList.forEach(function (value, key) {
  301. if (isNodeModule(key)) {
  302. return;
  303. }
  304. var localImport = imports.get(key) || new Set();
  305. value.declarations.forEach(function (_ref6) {var importedSpecifiers = _ref6.importedSpecifiers;
  306. importedSpecifiers.forEach(function (specifier) {
  307. localImport.add(specifier);
  308. });
  309. });
  310. imports.set(key, localImport);
  311. });
  312. importList.set(file, imports);
  313. // build up export list only, if file is not ignored
  314. if (ignoredFiles.has(file)) {
  315. return;
  316. }
  317. namespace.forEach(function (value, key) {
  318. if (key === DEFAULT) {
  319. exports.set(IMPORT_DEFAULT_SPECIFIER, { whereUsed: new Set() });
  320. } else {
  321. exports.set(key, { whereUsed: new Set() });
  322. }
  323. });
  324. }
  325. exports.set(EXPORT_ALL_DECLARATION, { whereUsed: new Set() });
  326. exports.set(IMPORT_NAMESPACE_SPECIFIER, { whereUsed: new Set() });
  327. exportList.set(file, exports);
  328. });
  329. exportAll.forEach(function (value, key) {
  330. value.forEach(function (val) {
  331. var currentExports = exportList.get(val);
  332. if (currentExports) {
  333. var currentExport = currentExports.get(EXPORT_ALL_DECLARATION);
  334. currentExport.whereUsed.add(key);
  335. }
  336. });
  337. });
  338. };
  339. /**
  340. * traverse through all imports and add the respective path to the whereUsed-list
  341. * of the corresponding export
  342. */
  343. var determineUsage = function determineUsage() {
  344. importList.forEach(function (listValue, listKey) {
  345. listValue.forEach(function (value, key) {
  346. var exports = exportList.get(key);
  347. if (typeof exports !== 'undefined') {
  348. value.forEach(function (currentImport) {
  349. var specifier = void 0;
  350. if (currentImport === IMPORT_NAMESPACE_SPECIFIER) {
  351. specifier = IMPORT_NAMESPACE_SPECIFIER;
  352. } else if (currentImport === IMPORT_DEFAULT_SPECIFIER) {
  353. specifier = IMPORT_DEFAULT_SPECIFIER;
  354. } else {
  355. specifier = currentImport;
  356. }
  357. if (typeof specifier !== 'undefined') {
  358. var exportStatement = exports.get(specifier);
  359. if (typeof exportStatement !== 'undefined') {var
  360. whereUsed = exportStatement.whereUsed;
  361. whereUsed.add(listKey);
  362. exports.set(specifier, { whereUsed: whereUsed });
  363. }
  364. }
  365. });
  366. }
  367. });
  368. });
  369. };
  370. var getSrc = function getSrc(src) {
  371. if (src) {
  372. return src;
  373. }
  374. return [process.cwd()];
  375. };
  376. /**
  377. * prepare the lists of existing imports and exports - should only be executed once at
  378. * the start of a new eslint run
  379. */
  380. /** @type {Set<string>} */
  381. var srcFiles = void 0;
  382. var lastPrepareKey = void 0;
  383. var doPreparation = function doPreparation(src, ignoreExports, context) {
  384. var prepareKey = JSON.stringify({
  385. src: (src || []).sort(),
  386. ignoreExports: (ignoreExports || []).sort(),
  387. extensions: Array.from((0, _ignore.getFileExtensions)(context.settings)).sort() });
  388. if (prepareKey === lastPrepareKey) {
  389. return;
  390. }
  391. importList.clear();
  392. exportList.clear();
  393. ignoredFiles.clear();
  394. filesOutsideSrc.clear();
  395. srcFiles = resolveFiles(getSrc(src), ignoreExports, context);
  396. prepareImportsAndExports(srcFiles, context);
  397. determineUsage();
  398. lastPrepareKey = prepareKey;
  399. };
  400. var newNamespaceImportExists = function newNamespaceImportExists(specifiers) {return specifiers.some(function (_ref7) {var type = _ref7.type;return type === IMPORT_NAMESPACE_SPECIFIER;});};
  401. var newDefaultImportExists = function newDefaultImportExists(specifiers) {return specifiers.some(function (_ref8) {var type = _ref8.type;return type === IMPORT_DEFAULT_SPECIFIER;});};
  402. var fileIsInPkg = function fileIsInPkg(file) {var _readPkgUp =
  403. (0, _readPkgUp3['default'])({ cwd: file }),path = _readPkgUp.path,pkg = _readPkgUp.pkg;
  404. var basePath = (0, _path.dirname)(path);
  405. var checkPkgFieldString = function checkPkgFieldString(pkgField) {
  406. if ((0, _path.join)(basePath, pkgField) === file) {
  407. return true;
  408. }
  409. };
  410. var checkPkgFieldObject = function checkPkgFieldObject(pkgField) {
  411. var pkgFieldFiles = (0, _arrayPrototype2['default'])((0, _object2['default'])(pkgField), function (value) {return typeof value === 'boolean' ? [] : (0, _path.join)(basePath, value);});
  412. if ((0, _arrayIncludes2['default'])(pkgFieldFiles, file)) {
  413. return true;
  414. }
  415. };
  416. var checkPkgField = function checkPkgField(pkgField) {
  417. if (typeof pkgField === 'string') {
  418. return checkPkgFieldString(pkgField);
  419. }
  420. if ((typeof pkgField === 'undefined' ? 'undefined' : _typeof(pkgField)) === 'object') {
  421. return checkPkgFieldObject(pkgField);
  422. }
  423. };
  424. if (pkg['private'] === true) {
  425. return false;
  426. }
  427. if (pkg.bin) {
  428. if (checkPkgField(pkg.bin)) {
  429. return true;
  430. }
  431. }
  432. if (pkg.browser) {
  433. if (checkPkgField(pkg.browser)) {
  434. return true;
  435. }
  436. }
  437. if (pkg.main) {
  438. if (checkPkgFieldString(pkg.main)) {
  439. return true;
  440. }
  441. }
  442. return false;
  443. };
  444. module.exports = {
  445. meta: {
  446. type: 'suggestion',
  447. docs: {
  448. category: 'Helpful warnings',
  449. description: 'Forbid modules without exports, or exports without matching import in another module.',
  450. url: (0, _docsUrl2['default'])('no-unused-modules') },
  451. schema: [{
  452. properties: {
  453. src: {
  454. description: 'files/paths to be analyzed (only for unused exports)',
  455. type: 'array',
  456. uniqueItems: true,
  457. items: {
  458. type: 'string',
  459. minLength: 1 } },
  460. ignoreExports: {
  461. description: 'files/paths for which unused exports will not be reported (e.g module entry points)',
  462. type: 'array',
  463. uniqueItems: true,
  464. items: {
  465. type: 'string',
  466. minLength: 1 } },
  467. missingExports: {
  468. description: 'report modules without any exports',
  469. type: 'boolean' },
  470. unusedExports: {
  471. description: 'report exports without any usage',
  472. type: 'boolean' },
  473. ignoreUnusedTypeExports: {
  474. description: 'ignore type exports without any usage',
  475. type: 'boolean' } },
  476. anyOf: [
  477. {
  478. properties: {
  479. unusedExports: { 'enum': [true] },
  480. src: {
  481. minItems: 1 } },
  482. required: ['unusedExports'] },
  483. {
  484. properties: {
  485. missingExports: { 'enum': [true] } },
  486. required: ['missingExports'] }] }] },
  487. create: function () {function create(context) {var _ref9 =
  488. context.options[0] || {},src = _ref9.src,_ref9$ignoreExports = _ref9.ignoreExports,ignoreExports = _ref9$ignoreExports === undefined ? [] : _ref9$ignoreExports,missingExports = _ref9.missingExports,unusedExports = _ref9.unusedExports,ignoreUnusedTypeExports = _ref9.ignoreUnusedTypeExports;
  489. if (unusedExports) {
  490. doPreparation(src, ignoreExports, context);
  491. }
  492. var file = (0, _contextCompat.getPhysicalFilename)(context);
  493. var checkExportPresence = function () {function checkExportPresence(node) {
  494. if (!missingExports) {
  495. return;
  496. }
  497. if (ignoredFiles.has(file)) {
  498. return;
  499. }
  500. var exportCount = exportList.get(file);
  501. var exportAll = exportCount.get(EXPORT_ALL_DECLARATION);
  502. var namespaceImports = exportCount.get(IMPORT_NAMESPACE_SPECIFIER);
  503. exportCount['delete'](EXPORT_ALL_DECLARATION);
  504. exportCount['delete'](IMPORT_NAMESPACE_SPECIFIER);
  505. if (exportCount.size < 1) {
  506. // node.body[0] === 'undefined' only happens, if everything is commented out in the file
  507. // being linted
  508. context.report(node.body[0] ? node.body[0] : node, 'No exports found');
  509. }
  510. exportCount.set(EXPORT_ALL_DECLARATION, exportAll);
  511. exportCount.set(IMPORT_NAMESPACE_SPECIFIER, namespaceImports);
  512. }return checkExportPresence;}();
  513. var checkUsage = function () {function checkUsage(node, exportedValue, isTypeExport) {
  514. if (!unusedExports) {
  515. return;
  516. }
  517. if (isTypeExport && ignoreUnusedTypeExports) {
  518. return;
  519. }
  520. if (ignoredFiles.has(file)) {
  521. return;
  522. }
  523. if (fileIsInPkg(file)) {
  524. return;
  525. }
  526. if (filesOutsideSrc.has(file)) {
  527. return;
  528. }
  529. // make sure file to be linted is included in source files
  530. if (!srcFiles.has(file)) {
  531. srcFiles = resolveFiles(getSrc(src), ignoreExports, context);
  532. if (!srcFiles.has(file)) {
  533. filesOutsideSrc.add(file);
  534. return;
  535. }
  536. }
  537. exports = exportList.get(file);
  538. if (!exports) {
  539. console.error('file `' + String(file) + '` has no exports. Please update to the latest, and if it still happens, report this on https://github.com/import-js/eslint-plugin-import/issues/2866!');
  540. }
  541. // special case: export * from
  542. var exportAll = exports.get(EXPORT_ALL_DECLARATION);
  543. if (typeof exportAll !== 'undefined' && exportedValue !== IMPORT_DEFAULT_SPECIFIER) {
  544. if (exportAll.whereUsed.size > 0) {
  545. return;
  546. }
  547. }
  548. // special case: namespace import
  549. var namespaceImports = exports.get(IMPORT_NAMESPACE_SPECIFIER);
  550. if (typeof namespaceImports !== 'undefined') {
  551. if (namespaceImports.whereUsed.size > 0) {
  552. return;
  553. }
  554. }
  555. // exportsList will always map any imported value of 'default' to 'ImportDefaultSpecifier'
  556. var exportsKey = exportedValue === DEFAULT ? IMPORT_DEFAULT_SPECIFIER : exportedValue;
  557. var exportStatement = exports.get(exportsKey);
  558. var value = exportsKey === IMPORT_DEFAULT_SPECIFIER ? DEFAULT : exportsKey;
  559. if (typeof exportStatement !== 'undefined') {
  560. if (exportStatement.whereUsed.size < 1) {
  561. context.report(
  562. node, 'exported declaration \'' +
  563. value + '\' not used within other modules');
  564. }
  565. } else {
  566. context.report(
  567. node, 'exported declaration \'' +
  568. value + '\' not used within other modules');
  569. }
  570. }return checkUsage;}();
  571. /**
  572. * only useful for tools like vscode-eslint
  573. *
  574. * update lists of existing exports during runtime
  575. */
  576. var updateExportUsage = function () {function updateExportUsage(node) {
  577. if (ignoredFiles.has(file)) {
  578. return;
  579. }
  580. var exports = exportList.get(file);
  581. // new module has been created during runtime
  582. // include it in further processing
  583. if (typeof exports === 'undefined') {
  584. exports = new Map();
  585. }
  586. var newExports = new Map();
  587. var newExportIdentifiers = new Set();
  588. node.body.forEach(function (_ref10) {var type = _ref10.type,declaration = _ref10.declaration,specifiers = _ref10.specifiers;
  589. if (type === EXPORT_DEFAULT_DECLARATION) {
  590. newExportIdentifiers.add(IMPORT_DEFAULT_SPECIFIER);
  591. }
  592. if (type === EXPORT_NAMED_DECLARATION) {
  593. if (specifiers.length > 0) {
  594. specifiers.forEach(function (specifier) {
  595. if (specifier.exported) {
  596. newExportIdentifiers.add(specifier.exported.name || specifier.exported.value);
  597. }
  598. });
  599. }
  600. forEachDeclarationIdentifier(declaration, function (name) {
  601. newExportIdentifiers.add(name);
  602. });
  603. }
  604. });
  605. // old exports exist within list of new exports identifiers: add to map of new exports
  606. exports.forEach(function (value, key) {
  607. if (newExportIdentifiers.has(key)) {
  608. newExports.set(key, value);
  609. }
  610. });
  611. // new export identifiers added: add to map of new exports
  612. newExportIdentifiers.forEach(function (key) {
  613. if (!exports.has(key)) {
  614. newExports.set(key, { whereUsed: new Set() });
  615. }
  616. });
  617. // preserve information about namespace imports
  618. var exportAll = exports.get(EXPORT_ALL_DECLARATION);
  619. var namespaceImports = exports.get(IMPORT_NAMESPACE_SPECIFIER);
  620. if (typeof namespaceImports === 'undefined') {
  621. namespaceImports = { whereUsed: new Set() };
  622. }
  623. newExports.set(EXPORT_ALL_DECLARATION, exportAll);
  624. newExports.set(IMPORT_NAMESPACE_SPECIFIER, namespaceImports);
  625. exportList.set(file, newExports);
  626. }return updateExportUsage;}();
  627. /**
  628. * only useful for tools like vscode-eslint
  629. *
  630. * update lists of existing imports during runtime
  631. */
  632. var updateImportUsage = function () {function updateImportUsage(node) {
  633. if (!unusedExports) {
  634. return;
  635. }
  636. var oldImportPaths = importList.get(file);
  637. if (typeof oldImportPaths === 'undefined') {
  638. oldImportPaths = new Map();
  639. }
  640. var oldNamespaceImports = new Set();
  641. var newNamespaceImports = new Set();
  642. var oldExportAll = new Set();
  643. var newExportAll = new Set();
  644. var oldDefaultImports = new Set();
  645. var newDefaultImports = new Set();
  646. var oldImports = new Map();
  647. var newImports = new Map();
  648. oldImportPaths.forEach(function (value, key) {
  649. if (value.has(EXPORT_ALL_DECLARATION)) {
  650. oldExportAll.add(key);
  651. }
  652. if (value.has(IMPORT_NAMESPACE_SPECIFIER)) {
  653. oldNamespaceImports.add(key);
  654. }
  655. if (value.has(IMPORT_DEFAULT_SPECIFIER)) {
  656. oldDefaultImports.add(key);
  657. }
  658. value.forEach(function (val) {
  659. if (
  660. val !== IMPORT_NAMESPACE_SPECIFIER &&
  661. val !== IMPORT_DEFAULT_SPECIFIER)
  662. {
  663. oldImports.set(val, key);
  664. }
  665. });
  666. });
  667. function processDynamicImport(source) {
  668. if (source.type !== 'Literal') {
  669. return null;
  670. }
  671. var p = (0, _resolve2['default'])(source.value, context);
  672. if (p == null) {
  673. return null;
  674. }
  675. newNamespaceImports.add(p);
  676. }
  677. (0, _visit2['default'])(node, visitorKeyMap.get(file), {
  678. ImportExpression: function () {function ImportExpression(child) {
  679. processDynamicImport(child.source);
  680. }return ImportExpression;}(),
  681. CallExpression: function () {function CallExpression(child) {
  682. if (child.callee.type === 'Import') {
  683. processDynamicImport(child.arguments[0]);
  684. }
  685. }return CallExpression;}() });
  686. node.body.forEach(function (astNode) {
  687. var resolvedPath = void 0;
  688. // support for export { value } from 'module'
  689. if (astNode.type === EXPORT_NAMED_DECLARATION) {
  690. if (astNode.source) {
  691. resolvedPath = (0, _resolve2['default'])(astNode.source.raw.replace(/('|")/g, ''), context);
  692. astNode.specifiers.forEach(function (specifier) {
  693. var name = specifier.local.name || specifier.local.value;
  694. if (name === DEFAULT) {
  695. newDefaultImports.add(resolvedPath);
  696. } else {
  697. newImports.set(name, resolvedPath);
  698. }
  699. });
  700. }
  701. }
  702. if (astNode.type === EXPORT_ALL_DECLARATION) {
  703. resolvedPath = (0, _resolve2['default'])(astNode.source.raw.replace(/('|")/g, ''), context);
  704. newExportAll.add(resolvedPath);
  705. }
  706. if (astNode.type === IMPORT_DECLARATION) {
  707. resolvedPath = (0, _resolve2['default'])(astNode.source.raw.replace(/('|")/g, ''), context);
  708. if (!resolvedPath) {
  709. return;
  710. }
  711. if (isNodeModule(resolvedPath)) {
  712. return;
  713. }
  714. if (newNamespaceImportExists(astNode.specifiers)) {
  715. newNamespaceImports.add(resolvedPath);
  716. }
  717. if (newDefaultImportExists(astNode.specifiers)) {
  718. newDefaultImports.add(resolvedPath);
  719. }
  720. astNode.specifiers.
  721. filter(function (specifier) {return specifier.type !== IMPORT_DEFAULT_SPECIFIER && specifier.type !== IMPORT_NAMESPACE_SPECIFIER;}).
  722. forEach(function (specifier) {
  723. newImports.set(specifier.imported.name || specifier.imported.value, resolvedPath);
  724. });
  725. }
  726. });
  727. newExportAll.forEach(function (value) {
  728. if (!oldExportAll.has(value)) {
  729. var imports = oldImportPaths.get(value);
  730. if (typeof imports === 'undefined') {
  731. imports = new Set();
  732. }
  733. imports.add(EXPORT_ALL_DECLARATION);
  734. oldImportPaths.set(value, imports);
  735. var _exports = exportList.get(value);
  736. var currentExport = void 0;
  737. if (typeof _exports !== 'undefined') {
  738. currentExport = _exports.get(EXPORT_ALL_DECLARATION);
  739. } else {
  740. _exports = new Map();
  741. exportList.set(value, _exports);
  742. }
  743. if (typeof currentExport !== 'undefined') {
  744. currentExport.whereUsed.add(file);
  745. } else {
  746. var whereUsed = new Set();
  747. whereUsed.add(file);
  748. _exports.set(EXPORT_ALL_DECLARATION, { whereUsed: whereUsed });
  749. }
  750. }
  751. });
  752. oldExportAll.forEach(function (value) {
  753. if (!newExportAll.has(value)) {
  754. var imports = oldImportPaths.get(value);
  755. imports['delete'](EXPORT_ALL_DECLARATION);
  756. var _exports2 = exportList.get(value);
  757. if (typeof _exports2 !== 'undefined') {
  758. var currentExport = _exports2.get(EXPORT_ALL_DECLARATION);
  759. if (typeof currentExport !== 'undefined') {
  760. currentExport.whereUsed['delete'](file);
  761. }
  762. }
  763. }
  764. });
  765. newDefaultImports.forEach(function (value) {
  766. if (!oldDefaultImports.has(value)) {
  767. var imports = oldImportPaths.get(value);
  768. if (typeof imports === 'undefined') {
  769. imports = new Set();
  770. }
  771. imports.add(IMPORT_DEFAULT_SPECIFIER);
  772. oldImportPaths.set(value, imports);
  773. var _exports3 = exportList.get(value);
  774. var currentExport = void 0;
  775. if (typeof _exports3 !== 'undefined') {
  776. currentExport = _exports3.get(IMPORT_DEFAULT_SPECIFIER);
  777. } else {
  778. _exports3 = new Map();
  779. exportList.set(value, _exports3);
  780. }
  781. if (typeof currentExport !== 'undefined') {
  782. currentExport.whereUsed.add(file);
  783. } else {
  784. var whereUsed = new Set();
  785. whereUsed.add(file);
  786. _exports3.set(IMPORT_DEFAULT_SPECIFIER, { whereUsed: whereUsed });
  787. }
  788. }
  789. });
  790. oldDefaultImports.forEach(function (value) {
  791. if (!newDefaultImports.has(value)) {
  792. var imports = oldImportPaths.get(value);
  793. imports['delete'](IMPORT_DEFAULT_SPECIFIER);
  794. var _exports4 = exportList.get(value);
  795. if (typeof _exports4 !== 'undefined') {
  796. var currentExport = _exports4.get(IMPORT_DEFAULT_SPECIFIER);
  797. if (typeof currentExport !== 'undefined') {
  798. currentExport.whereUsed['delete'](file);
  799. }
  800. }
  801. }
  802. });
  803. newNamespaceImports.forEach(function (value) {
  804. if (!oldNamespaceImports.has(value)) {
  805. var imports = oldImportPaths.get(value);
  806. if (typeof imports === 'undefined') {
  807. imports = new Set();
  808. }
  809. imports.add(IMPORT_NAMESPACE_SPECIFIER);
  810. oldImportPaths.set(value, imports);
  811. var _exports5 = exportList.get(value);
  812. var currentExport = void 0;
  813. if (typeof _exports5 !== 'undefined') {
  814. currentExport = _exports5.get(IMPORT_NAMESPACE_SPECIFIER);
  815. } else {
  816. _exports5 = new Map();
  817. exportList.set(value, _exports5);
  818. }
  819. if (typeof currentExport !== 'undefined') {
  820. currentExport.whereUsed.add(file);
  821. } else {
  822. var whereUsed = new Set();
  823. whereUsed.add(file);
  824. _exports5.set(IMPORT_NAMESPACE_SPECIFIER, { whereUsed: whereUsed });
  825. }
  826. }
  827. });
  828. oldNamespaceImports.forEach(function (value) {
  829. if (!newNamespaceImports.has(value)) {
  830. var imports = oldImportPaths.get(value);
  831. imports['delete'](IMPORT_NAMESPACE_SPECIFIER);
  832. var _exports6 = exportList.get(value);
  833. if (typeof _exports6 !== 'undefined') {
  834. var currentExport = _exports6.get(IMPORT_NAMESPACE_SPECIFIER);
  835. if (typeof currentExport !== 'undefined') {
  836. currentExport.whereUsed['delete'](file);
  837. }
  838. }
  839. }
  840. });
  841. newImports.forEach(function (value, key) {
  842. if (!oldImports.has(key)) {
  843. var imports = oldImportPaths.get(value);
  844. if (typeof imports === 'undefined') {
  845. imports = new Set();
  846. }
  847. imports.add(key);
  848. oldImportPaths.set(value, imports);
  849. var _exports7 = exportList.get(value);
  850. var currentExport = void 0;
  851. if (typeof _exports7 !== 'undefined') {
  852. currentExport = _exports7.get(key);
  853. } else {
  854. _exports7 = new Map();
  855. exportList.set(value, _exports7);
  856. }
  857. if (typeof currentExport !== 'undefined') {
  858. currentExport.whereUsed.add(file);
  859. } else {
  860. var whereUsed = new Set();
  861. whereUsed.add(file);
  862. _exports7.set(key, { whereUsed: whereUsed });
  863. }
  864. }
  865. });
  866. oldImports.forEach(function (value, key) {
  867. if (!newImports.has(key)) {
  868. var imports = oldImportPaths.get(value);
  869. imports['delete'](key);
  870. var _exports8 = exportList.get(value);
  871. if (typeof _exports8 !== 'undefined') {
  872. var currentExport = _exports8.get(key);
  873. if (typeof currentExport !== 'undefined') {
  874. currentExport.whereUsed['delete'](file);
  875. }
  876. }
  877. }
  878. });
  879. }return updateImportUsage;}();
  880. return {
  881. 'Program:exit': function () {function ProgramExit(node) {
  882. updateExportUsage(node);
  883. updateImportUsage(node);
  884. checkExportPresence(node);
  885. }return ProgramExit;}(),
  886. ExportDefaultDeclaration: function () {function ExportDefaultDeclaration(node) {
  887. checkUsage(node, IMPORT_DEFAULT_SPECIFIER, false);
  888. }return ExportDefaultDeclaration;}(),
  889. ExportNamedDeclaration: function () {function ExportNamedDeclaration(node) {
  890. node.specifiers.forEach(function (specifier) {
  891. checkUsage(specifier, specifier.exported.name || specifier.exported.value, false);
  892. });
  893. forEachDeclarationIdentifier(node.declaration, function (name, isTypeExport) {
  894. checkUsage(node, name, isTypeExport);
  895. });
  896. }return ExportNamedDeclaration;}() };
  897. }return create;}() };
  898. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/rules/no-unused-modules.js"],"names":["requireFileEnumerator","FileEnumerator","require","e","code","listFilesUsingFileEnumerator","src","extensions","ESLINT_USE_FLAT_CONFIG","process","env","isUsingFlatConfig","shouldUseFlatConfig","_","enumerator","Array","from","iterateFiles","filePath","ignored","filename","message","includes","Error","listFilesWithLegacyFunctions","originalListFilesToProcess","listFilesToProcess","patterns","concat","pattern","map","extension","test","EXPORT_DEFAULT_DECLARATION","EXPORT_NAMED_DECLARATION","EXPORT_ALL_DECLARATION","IMPORT_DECLARATION","IMPORT_NAMESPACE_SPECIFIER","IMPORT_DEFAULT_SPECIFIER","VARIABLE_DECLARATION","FUNCTION_DECLARATION","CLASS_DECLARATION","IDENTIFIER","OBJECT_PATTERN","ARRAY_PATTERN","TS_INTERFACE_DECLARATION","TS_TYPE_ALIAS_DECLARATION","TS_ENUM_DECLARATION","DEFAULT","forEachDeclarationIdentifier","declaration","cb","isTypeDeclaration","type","id","name","declarations","forEach","elements","importList","Map","exportList","visitorKeyMap","ignoredFiles","Set","filesOutsideSrc","isNodeModule","path","resolveFiles","ignoreExports","context","settings","srcFileList","ignoredFilesList","length","add","resolvedFiles","filter","prepareImportsAndExports","srcFiles","exportAll","file","exports","imports","currentExports","ExportMapBuilder","get","dependencies","reexports","localImportList","namespace","visitorKeys","set","currentExportAll","getDependency","dependency","value","key","whereUsed","reexport","getImport","localImport","currentValue","local","importedSpecifiers","specifier","has","val","currentExport","determineUsage","listValue","listKey","currentImport","exportStatement","getSrc","cwd","lastPrepareKey","doPreparation","prepareKey","JSON","stringify","sort","clear","newNamespaceImportExists","specifiers","some","newDefaultImportExists","fileIsInPkg","pkg","basePath","checkPkgFieldString","pkgField","checkPkgFieldObject","pkgFieldFiles","checkPkgField","bin","browser","main","module","meta","docs","category","description","url","schema","properties","uniqueItems","items","minLength","missingExports","unusedExports","ignoreUnusedTypeExports","anyOf","minItems","required","create","options","checkExportPresence","node","exportCount","namespaceImports","size","report","body","checkUsage","exportedValue","isTypeExport","console","error","exportsKey","updateExportUsage","newExports","newExportIdentifiers","exported","updateImportUsage","oldImportPaths","oldNamespaceImports","newNamespaceImports","oldExportAll","newExportAll","oldDefaultImports","newDefaultImports","oldImports","newImports","processDynamicImport","source","p","ImportExpression","child","CallExpression","callee","arguments","astNode","resolvedPath","raw","replace","imported","ExportDefaultDeclaration","ExportNamedDeclaration"],"mappings":"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","file":"no-unused-modules.js","sourcesContent":["/**\n * @fileOverview Ensures that modules contain exports and/or all\n * modules are consumed within other modules.\n * @author René Fermann\n */\n\nimport { getPhysicalFilename } from 'eslint-module-utils/contextCompat';\nimport { getFileExtensions } from 'eslint-module-utils/ignore';\nimport resolve from 'eslint-module-utils/resolve';\nimport visit from 'eslint-module-utils/visit';\nimport { dirname, join } from 'path';\nimport readPkgUp from 'eslint-module-utils/readPkgUp';\nimport values from 'object.values';\nimport includes from 'array-includes';\nimport flatMap from 'array.prototype.flatmap';\n\nimport ExportMapBuilder from '../exportMap/builder';\nimport recursivePatternCapture from '../exportMap/patternCapture';\nimport docsUrl from '../docsUrl';\n\n/**\n * Attempt to load the internal `FileEnumerator` class, which has existed in a couple\n * of different places, depending on the version of `eslint`.  Try requiring it from both\n * locations.\n * @returns Returns the `FileEnumerator` class if its requirable, otherwise `undefined`.\n */\nfunction requireFileEnumerator() {\n  let FileEnumerator;\n\n  // Try getting it from the eslint private / deprecated api\n  try {\n    ({ FileEnumerator } = require('eslint/use-at-your-own-risk'));\n  } catch (e) {\n    // Absorb this if it's MODULE_NOT_FOUND\n    if (e.code !== 'MODULE_NOT_FOUND') {\n      throw e;\n    }\n\n    // If not there, then try getting it from eslint/lib/cli-engine/file-enumerator (moved there in v6)\n    try {\n      ({ FileEnumerator } = require('eslint/lib/cli-engine/file-enumerator'));\n    } catch (e) {\n      // Absorb this if it's MODULE_NOT_FOUND\n      if (e.code !== 'MODULE_NOT_FOUND') {\n        throw e;\n      }\n    }\n  }\n  return FileEnumerator;\n}\n\n/**\n * Given a FileEnumerator class, instantiate and load the list of files.\n * @param FileEnumerator the `FileEnumerator` class from `eslint`'s internal api\n * @param {string} src path to the src root\n * @param {string[]} extensions list of supported extensions\n * @returns {{ filename: string, ignored: boolean }[]} list of files to operate on\n */\nfunction listFilesUsingFileEnumerator(FileEnumerator, src, extensions) {\n  // We need to know whether this is being run with flat config in order to\n  // determine how to report errors if FileEnumerator throws due to a lack of eslintrc.\n\n  const { ESLINT_USE_FLAT_CONFIG } = process.env;\n\n  // This condition is sufficient to test in v8, since the environment variable is necessary to turn on flat config\n  let isUsingFlatConfig = ESLINT_USE_FLAT_CONFIG && process.env.ESLINT_USE_FLAT_CONFIG !== 'false';\n\n  // In the case of using v9, we can check the `shouldUseFlatConfig` function\n  // If this function is present, then we assume it's v9\n  try {\n    const { shouldUseFlatConfig } = require('eslint/use-at-your-own-risk');\n    isUsingFlatConfig = shouldUseFlatConfig && ESLINT_USE_FLAT_CONFIG !== 'false';\n  } catch (_) {\n    // We don't want to throw here, since we only want to update the\n    // boolean if the function is available.\n  }\n\n  const enumerator = new FileEnumerator({\n    extensions,\n  });\n\n  try {\n    return Array.from(\n      enumerator.iterateFiles(src),\n      ({ filePath, ignored }) => ({ filename: filePath, ignored }),\n    );\n  } catch (e) {\n    // If we're using flat config, and FileEnumerator throws due to a lack of eslintrc,\n    // then we want to throw an error so that the user knows about this rule's reliance on\n    // the legacy config.\n    if (\n      isUsingFlatConfig\n      && e.message.includes('No ESLint configuration found')\n    ) {\n      throw new Error(`\nDue to the exclusion of certain internal ESLint APIs when using flat config,\nthe import/no-unused-modules rule requires an .eslintrc file to know which\nfiles to ignore (even when using flat config).\nThe .eslintrc file only needs to contain \"ignorePatterns\", or can be empty if\nyou do not want to ignore any files.\n\nSee https://github.com/import-js/eslint-plugin-import/issues/3079\nfor additional context.\n`);\n    }\n    // If this isn't the case, then we'll just let the error bubble up\n    throw e;\n  }\n}\n\n/**\n * Attempt to require old versions of the file enumeration capability from v6 `eslint` and earlier, and use\n * those functions to provide the list of files to operate on\n * @param {string} src path to the src root\n * @param {string[]} extensions list of supported extensions\n * @returns {string[]} list of files to operate on\n */\nfunction listFilesWithLegacyFunctions(src, extensions) {\n  try {\n    // eslint/lib/util/glob-util has been moved to eslint/lib/util/glob-utils with version 5.3\n    const { listFilesToProcess: originalListFilesToProcess } = require('eslint/lib/util/glob-utils');\n    // Prevent passing invalid options (extensions array) to old versions of the function.\n    // https://github.com/eslint/eslint/blob/v5.16.0/lib/util/glob-utils.js#L178-L280\n    // https://github.com/eslint/eslint/blob/v5.2.0/lib/util/glob-util.js#L174-L269\n\n    return originalListFilesToProcess(src, {\n      extensions,\n    });\n  } catch (e) {\n    // Absorb this if it's MODULE_NOT_FOUND\n    if (e.code !== 'MODULE_NOT_FOUND') {\n      throw e;\n    }\n\n    // Last place to try (pre v5.3)\n    const {\n      listFilesToProcess: originalListFilesToProcess,\n    } = require('eslint/lib/util/glob-util');\n    const patterns = src.concat(\n      flatMap(\n        src,\n        (pattern) => extensions.map((extension) => (/\\*\\*|\\*\\./).test(pattern) ? pattern : `${pattern}/**/*${extension}`),\n      ),\n    );\n\n    return originalListFilesToProcess(patterns);\n  }\n}\n\n/**\n * Given a src pattern and list of supported extensions, return a list of files to process\n * with this rule.\n * @param {string} src - file, directory, or glob pattern of files to act on\n * @param {string[]} extensions - list of supported file extensions\n * @returns {string[] | { filename: string, ignored: boolean }[]} the list of files that this rule will evaluate.\n */\nfunction listFilesToProcess(src, extensions) {\n  const FileEnumerator = requireFileEnumerator();\n\n  // If we got the FileEnumerator, then let's go with that\n  if (FileEnumerator) {\n    return listFilesUsingFileEnumerator(FileEnumerator, src, extensions);\n  }\n  // If not, then we can try even older versions of this capability (listFilesToProcess)\n  return listFilesWithLegacyFunctions(src, extensions);\n}\n\nconst EXPORT_DEFAULT_DECLARATION = 'ExportDefaultDeclaration';\nconst EXPORT_NAMED_DECLARATION = 'ExportNamedDeclaration';\nconst EXPORT_ALL_DECLARATION = 'ExportAllDeclaration';\nconst IMPORT_DECLARATION = 'ImportDeclaration';\nconst IMPORT_NAMESPACE_SPECIFIER = 'ImportNamespaceSpecifier';\nconst IMPORT_DEFAULT_SPECIFIER = 'ImportDefaultSpecifier';\nconst VARIABLE_DECLARATION = 'VariableDeclaration';\nconst FUNCTION_DECLARATION = 'FunctionDeclaration';\nconst CLASS_DECLARATION = 'ClassDeclaration';\nconst IDENTIFIER = 'Identifier';\nconst OBJECT_PATTERN = 'ObjectPattern';\nconst ARRAY_PATTERN = 'ArrayPattern';\nconst TS_INTERFACE_DECLARATION = 'TSInterfaceDeclaration';\nconst TS_TYPE_ALIAS_DECLARATION = 'TSTypeAliasDeclaration';\nconst TS_ENUM_DECLARATION = 'TSEnumDeclaration';\nconst DEFAULT = 'default';\n\nfunction forEachDeclarationIdentifier(declaration, cb) {\n  if (declaration) {\n    const isTypeDeclaration = declaration.type === TS_INTERFACE_DECLARATION\n      || declaration.type === TS_TYPE_ALIAS_DECLARATION\n      || declaration.type === TS_ENUM_DECLARATION;\n\n    if (\n      declaration.type === FUNCTION_DECLARATION\n      || declaration.type === CLASS_DECLARATION\n      || isTypeDeclaration\n    ) {\n      cb(declaration.id.name, isTypeDeclaration);\n    } else if (declaration.type === VARIABLE_DECLARATION) {\n      declaration.declarations.forEach(({ id }) => {\n        if (id.type === OBJECT_PATTERN) {\n          recursivePatternCapture(id, (pattern) => {\n            if (pattern.type === IDENTIFIER) {\n              cb(pattern.name, false);\n            }\n          });\n        } else if (id.type === ARRAY_PATTERN) {\n          id.elements.forEach(({ name }) => {\n            cb(name, false);\n          });\n        } else {\n          cb(id.name, false);\n        }\n      });\n    }\n  }\n}\n\n/**\n * List of imports per file.\n *\n * Represented by a two-level Map to a Set of identifiers. The upper-level Map\n * keys are the paths to the modules containing the imports, while the\n * lower-level Map keys are the paths to the files which are being imported\n * from. Lastly, the Set of identifiers contains either names being imported\n * or a special AST node name listed above (e.g ImportDefaultSpecifier).\n *\n * For example, if we have a file named foo.js containing:\n *\n *   import { o2 } from './bar.js';\n *\n * Then we will have a structure that looks like:\n *\n *   Map { 'foo.js' => Map { 'bar.js' => Set { 'o2' } } }\n *\n * @type {Map<string, Map<string, Set<string>>>}\n */\nconst importList = new Map();\n\n/**\n * List of exports per file.\n *\n * Represented by a two-level Map to an object of metadata. The upper-level Map\n * keys are the paths to the modules containing the exports, while the\n * lower-level Map keys are the specific identifiers or special AST node names\n * being exported. The leaf-level metadata object at the moment only contains a\n * `whereUsed` property, which contains a Set of paths to modules that import\n * the name.\n *\n * For example, if we have a file named bar.js containing the following exports:\n *\n *   const o2 = 'bar';\n *   export { o2 };\n *\n * And a file named foo.js containing the following import:\n *\n *   import { o2 } from './bar.js';\n *\n * Then we will have a structure that looks like:\n *\n *   Map { 'bar.js' => Map { 'o2' => { whereUsed: Set { 'foo.js' } } } }\n *\n * @type {Map<string, Map<string, object>>}\n */\nconst exportList = new Map();\n\nconst visitorKeyMap = new Map();\n\n/** @type {Set<string>} */\nconst ignoredFiles = new Set();\nconst filesOutsideSrc = new Set();\n\nconst isNodeModule = (path) => (/\\/(node_modules)\\//).test(path);\n\n/**\n * read all files matching the patterns in src and ignoreExports\n *\n * return all files matching src pattern, which are not matching the ignoreExports pattern\n * @type {(src: string, ignoreExports: string, context: import('eslint').Rule.RuleContext) => Set<string>}\n */\nfunction resolveFiles(src, ignoreExports, context) {\n  const extensions = Array.from(getFileExtensions(context.settings));\n\n  const srcFileList = listFilesToProcess(src, extensions);\n\n  // prepare list of ignored files\n  const ignoredFilesList = listFilesToProcess(ignoreExports, extensions);\n\n  // The modern api will return a list of file paths, rather than an object\n  if (ignoredFilesList.length && typeof ignoredFilesList[0] === 'string') {\n    ignoredFilesList.forEach((filename) => ignoredFiles.add(filename));\n  } else {\n    ignoredFilesList.forEach(({ filename }) => ignoredFiles.add(filename));\n  }\n\n  // prepare list of source files, don't consider files from node_modules\n  const resolvedFiles = srcFileList.length && typeof srcFileList[0] === 'string'\n    ? srcFileList.filter((filePath) => !isNodeModule(filePath))\n    : flatMap(srcFileList, ({ filename }) => isNodeModule(filename) ? [] : filename);\n\n  return new Set(resolvedFiles);\n}\n\n/**\n * parse all source files and build up 2 maps containing the existing imports and exports\n */\nconst prepareImportsAndExports = (srcFiles, context) => {\n  const exportAll = new Map();\n  srcFiles.forEach((file) => {\n    const exports = new Map();\n    const imports = new Map();\n    const currentExports = ExportMapBuilder.get(file, context);\n    if (currentExports) {\n      const {\n        dependencies,\n        reexports,\n        imports: localImportList,\n        namespace,\n        visitorKeys,\n      } = currentExports;\n\n      visitorKeyMap.set(file, visitorKeys);\n      // dependencies === export * from\n      const currentExportAll = new Set();\n      dependencies.forEach((getDependency) => {\n        const dependency = getDependency();\n        if (dependency === null) {\n          return;\n        }\n\n        currentExportAll.add(dependency.path);\n      });\n      exportAll.set(file, currentExportAll);\n\n      reexports.forEach((value, key) => {\n        if (key === DEFAULT) {\n          exports.set(IMPORT_DEFAULT_SPECIFIER, { whereUsed: new Set() });\n        } else {\n          exports.set(key, { whereUsed: new Set() });\n        }\n        const reexport = value.getImport();\n        if (!reexport) {\n          return;\n        }\n        let localImport = imports.get(reexport.path);\n        let currentValue;\n        if (value.local === DEFAULT) {\n          currentValue = IMPORT_DEFAULT_SPECIFIER;\n        } else {\n          currentValue = value.local;\n        }\n        if (typeof localImport !== 'undefined') {\n          localImport = new Set([...localImport, currentValue]);\n        } else {\n          localImport = new Set([currentValue]);\n        }\n        imports.set(reexport.path, localImport);\n      });\n\n      localImportList.forEach((value, key) => {\n        if (isNodeModule(key)) {\n          return;\n        }\n        const localImport = imports.get(key) || new Set();\n        value.declarations.forEach(({ importedSpecifiers }) => {\n          importedSpecifiers.forEach((specifier) => {\n            localImport.add(specifier);\n          });\n        });\n        imports.set(key, localImport);\n      });\n      importList.set(file, imports);\n\n      // build up export list only, if file is not ignored\n      if (ignoredFiles.has(file)) {\n        return;\n      }\n      namespace.forEach((value, key) => {\n        if (key === DEFAULT) {\n          exports.set(IMPORT_DEFAULT_SPECIFIER, { whereUsed: new Set() });\n        } else {\n          exports.set(key, { whereUsed: new Set() });\n        }\n      });\n    }\n    exports.set(EXPORT_ALL_DECLARATION, { whereUsed: new Set() });\n    exports.set(IMPORT_NAMESPACE_SPECIFIER, { whereUsed: new Set() });\n    exportList.set(file, exports);\n  });\n  exportAll.forEach((value, key) => {\n    value.forEach((val) => {\n      const currentExports = exportList.get(val);\n      if (currentExports) {\n        const currentExport = currentExports.get(EXPORT_ALL_DECLARATION);\n        currentExport.whereUsed.add(key);\n      }\n    });\n  });\n};\n\n/**\n * traverse through all imports and add the respective path to the whereUsed-list\n * of the corresponding export\n */\nconst determineUsage = () => {\n  importList.forEach((listValue, listKey) => {\n    listValue.forEach((value, key) => {\n      const exports = exportList.get(key);\n      if (typeof exports !== 'undefined') {\n        value.forEach((currentImport) => {\n          let specifier;\n          if (currentImport === IMPORT_NAMESPACE_SPECIFIER) {\n            specifier = IMPORT_NAMESPACE_SPECIFIER;\n          } else if (currentImport === IMPORT_DEFAULT_SPECIFIER) {\n            specifier = IMPORT_DEFAULT_SPECIFIER;\n          } else {\n            specifier = currentImport;\n          }\n          if (typeof specifier !== 'undefined') {\n            const exportStatement = exports.get(specifier);\n            if (typeof exportStatement !== 'undefined') {\n              const { whereUsed } = exportStatement;\n              whereUsed.add(listKey);\n              exports.set(specifier, { whereUsed });\n            }\n          }\n        });\n      }\n    });\n  });\n};\n\nconst getSrc = (src) => {\n  if (src) {\n    return src;\n  }\n  return [process.cwd()];\n};\n\n/**\n * prepare the lists of existing imports and exports - should only be executed once at\n * the start of a new eslint run\n */\n/** @type {Set<string>} */\nlet srcFiles;\nlet lastPrepareKey;\nconst doPreparation = (src, ignoreExports, context) => {\n  const prepareKey = JSON.stringify({\n    src: (src || []).sort(),\n    ignoreExports: (ignoreExports || []).sort(),\n    extensions: Array.from(getFileExtensions(context.settings)).sort(),\n  });\n  if (prepareKey === lastPrepareKey) {\n    return;\n  }\n\n  importList.clear();\n  exportList.clear();\n  ignoredFiles.clear();\n  filesOutsideSrc.clear();\n\n  srcFiles = resolveFiles(getSrc(src), ignoreExports, context);\n  prepareImportsAndExports(srcFiles, context);\n  determineUsage();\n  lastPrepareKey = prepareKey;\n};\n\nconst newNamespaceImportExists = (specifiers) => specifiers.some(({ type }) => type === IMPORT_NAMESPACE_SPECIFIER);\n\nconst newDefaultImportExists = (specifiers) => specifiers.some(({ type }) => type === IMPORT_DEFAULT_SPECIFIER);\n\nconst fileIsInPkg = (file) => {\n  const { path, pkg } = readPkgUp({ cwd: file });\n  const basePath = dirname(path);\n\n  const checkPkgFieldString = (pkgField) => {\n    if (join(basePath, pkgField) === file) {\n      return true;\n    }\n  };\n\n  const checkPkgFieldObject = (pkgField) => {\n    const pkgFieldFiles = flatMap(values(pkgField), (value) => typeof value === 'boolean' ? [] : join(basePath, value));\n\n    if (includes(pkgFieldFiles, file)) {\n      return true;\n    }\n  };\n\n  const checkPkgField = (pkgField) => {\n    if (typeof pkgField === 'string') {\n      return checkPkgFieldString(pkgField);\n    }\n\n    if (typeof pkgField === 'object') {\n      return checkPkgFieldObject(pkgField);\n    }\n  };\n\n  if (pkg.private === true) {\n    return false;\n  }\n\n  if (pkg.bin) {\n    if (checkPkgField(pkg.bin)) {\n      return true;\n    }\n  }\n\n  if (pkg.browser) {\n    if (checkPkgField(pkg.browser)) {\n      return true;\n    }\n  }\n\n  if (pkg.main) {\n    if (checkPkgFieldString(pkg.main)) {\n      return true;\n    }\n  }\n\n  return false;\n};\n\nmodule.exports = {\n  meta: {\n    type: 'suggestion',\n    docs: {\n      category: 'Helpful warnings',\n      description: 'Forbid modules without exports, or exports without matching import in another module.',\n      url: docsUrl('no-unused-modules'),\n    },\n    schema: [{\n      properties: {\n        src: {\n          description: 'files/paths to be analyzed (only for unused exports)',\n          type: 'array',\n          uniqueItems: true,\n          items: {\n            type: 'string',\n            minLength: 1,\n          },\n        },\n        ignoreExports: {\n          description: 'files/paths for which unused exports will not be reported (e.g module entry points)',\n          type: 'array',\n          uniqueItems: true,\n          items: {\n            type: 'string',\n            minLength: 1,\n          },\n        },\n        missingExports: {\n          description: 'report modules without any exports',\n          type: 'boolean',\n        },\n        unusedExports: {\n          description: 'report exports without any usage',\n          type: 'boolean',\n        },\n        ignoreUnusedTypeExports: {\n          description: 'ignore type exports without any usage',\n          type: 'boolean',\n        },\n      },\n      anyOf: [\n        {\n          properties: {\n            unusedExports: { enum: [true] },\n            src: {\n              minItems: 1,\n            },\n          },\n          required: ['unusedExports'],\n        },\n        {\n          properties: {\n            missingExports: { enum: [true] },\n          },\n          required: ['missingExports'],\n        },\n      ],\n    }],\n  },\n\n  create(context) {\n    const {\n      src,\n      ignoreExports = [],\n      missingExports,\n      unusedExports,\n      ignoreUnusedTypeExports,\n    } = context.options[0] || {};\n\n    if (unusedExports) {\n      doPreparation(src, ignoreExports, context);\n    }\n\n    const file = getPhysicalFilename(context);\n\n    const checkExportPresence = (node) => {\n      if (!missingExports) {\n        return;\n      }\n\n      if (ignoredFiles.has(file)) {\n        return;\n      }\n\n      const exportCount = exportList.get(file);\n      const exportAll = exportCount.get(EXPORT_ALL_DECLARATION);\n      const namespaceImports = exportCount.get(IMPORT_NAMESPACE_SPECIFIER);\n\n      exportCount.delete(EXPORT_ALL_DECLARATION);\n      exportCount.delete(IMPORT_NAMESPACE_SPECIFIER);\n      if (exportCount.size < 1) {\n        // node.body[0] === 'undefined' only happens, if everything is commented out in the file\n        // being linted\n        context.report(node.body[0] ? node.body[0] : node, 'No exports found');\n      }\n      exportCount.set(EXPORT_ALL_DECLARATION, exportAll);\n      exportCount.set(IMPORT_NAMESPACE_SPECIFIER, namespaceImports);\n    };\n\n    const checkUsage = (node, exportedValue, isTypeExport) => {\n      if (!unusedExports) {\n        return;\n      }\n\n      if (isTypeExport && ignoreUnusedTypeExports) {\n        return;\n      }\n\n      if (ignoredFiles.has(file)) {\n        return;\n      }\n\n      if (fileIsInPkg(file)) {\n        return;\n      }\n\n      if (filesOutsideSrc.has(file)) {\n        return;\n      }\n\n      // make sure file to be linted is included in source files\n      if (!srcFiles.has(file)) {\n        srcFiles = resolveFiles(getSrc(src), ignoreExports, context);\n        if (!srcFiles.has(file)) {\n          filesOutsideSrc.add(file);\n          return;\n        }\n      }\n\n      exports = exportList.get(file);\n\n      if (!exports) {\n        console.error(`file \\`${file}\\` has no exports. Please update to the latest, and if it still happens, report this on https://github.com/import-js/eslint-plugin-import/issues/2866!`);\n      }\n\n      // special case: export * from\n      const exportAll = exports.get(EXPORT_ALL_DECLARATION);\n      if (typeof exportAll !== 'undefined' && exportedValue !== IMPORT_DEFAULT_SPECIFIER) {\n        if (exportAll.whereUsed.size > 0) {\n          return;\n        }\n      }\n\n      // special case: namespace import\n      const namespaceImports = exports.get(IMPORT_NAMESPACE_SPECIFIER);\n      if (typeof namespaceImports !== 'undefined') {\n        if (namespaceImports.whereUsed.size > 0) {\n          return;\n        }\n      }\n\n      // exportsList will always map any imported value of 'default' to 'ImportDefaultSpecifier'\n      const exportsKey = exportedValue === DEFAULT ? IMPORT_DEFAULT_SPECIFIER : exportedValue;\n\n      const exportStatement = exports.get(exportsKey);\n\n      const value = exportsKey === IMPORT_DEFAULT_SPECIFIER ? DEFAULT : exportsKey;\n\n      if (typeof exportStatement !== 'undefined') {\n        if (exportStatement.whereUsed.size < 1) {\n          context.report(\n            node,\n            `exported declaration '${value}' not used within other modules`,\n          );\n        }\n      } else {\n        context.report(\n          node,\n          `exported declaration '${value}' not used within other modules`,\n        );\n      }\n    };\n\n    /**\n     * only useful for tools like vscode-eslint\n     *\n     * update lists of existing exports during runtime\n     */\n    const updateExportUsage = (node) => {\n      if (ignoredFiles.has(file)) {\n        return;\n      }\n\n      let exports = exportList.get(file);\n\n      // new module has been created during runtime\n      // include it in further processing\n      if (typeof exports === 'undefined') {\n        exports = new Map();\n      }\n\n      const newExports = new Map();\n      const newExportIdentifiers = new Set();\n\n      node.body.forEach(({ type, declaration, specifiers }) => {\n        if (type === EXPORT_DEFAULT_DECLARATION) {\n          newExportIdentifiers.add(IMPORT_DEFAULT_SPECIFIER);\n        }\n        if (type === EXPORT_NAMED_DECLARATION) {\n          if (specifiers.length > 0) {\n            specifiers.forEach((specifier) => {\n              if (specifier.exported) {\n                newExportIdentifiers.add(specifier.exported.name || specifier.exported.value);\n              }\n            });\n          }\n          forEachDeclarationIdentifier(declaration, (name) => {\n            newExportIdentifiers.add(name);\n          });\n        }\n      });\n\n      // old exports exist within list of new exports identifiers: add to map of new exports\n      exports.forEach((value, key) => {\n        if (newExportIdentifiers.has(key)) {\n          newExports.set(key, value);\n        }\n      });\n\n      // new export identifiers added: add to map of new exports\n      newExportIdentifiers.forEach((key) => {\n        if (!exports.has(key)) {\n          newExports.set(key, { whereUsed: new Set() });\n        }\n      });\n\n      // preserve information about namespace imports\n      const exportAll = exports.get(EXPORT_ALL_DECLARATION);\n      let namespaceImports = exports.get(IMPORT_NAMESPACE_SPECIFIER);\n\n      if (typeof namespaceImports === 'undefined') {\n        namespaceImports = { whereUsed: new Set() };\n      }\n\n      newExports.set(EXPORT_ALL_DECLARATION, exportAll);\n      newExports.set(IMPORT_NAMESPACE_SPECIFIER, namespaceImports);\n      exportList.set(file, newExports);\n    };\n\n    /**\n     * only useful for tools like vscode-eslint\n     *\n     * update lists of existing imports during runtime\n     */\n    const updateImportUsage = (node) => {\n      if (!unusedExports) {\n        return;\n      }\n\n      let oldImportPaths = importList.get(file);\n      if (typeof oldImportPaths === 'undefined') {\n        oldImportPaths = new Map();\n      }\n\n      const oldNamespaceImports = new Set();\n      const newNamespaceImports = new Set();\n\n      const oldExportAll = new Set();\n      const newExportAll = new Set();\n\n      const oldDefaultImports = new Set();\n      const newDefaultImports = new Set();\n\n      const oldImports = new Map();\n      const newImports = new Map();\n      oldImportPaths.forEach((value, key) => {\n        if (value.has(EXPORT_ALL_DECLARATION)) {\n          oldExportAll.add(key);\n        }\n        if (value.has(IMPORT_NAMESPACE_SPECIFIER)) {\n          oldNamespaceImports.add(key);\n        }\n        if (value.has(IMPORT_DEFAULT_SPECIFIER)) {\n          oldDefaultImports.add(key);\n        }\n        value.forEach((val) => {\n          if (\n            val !== IMPORT_NAMESPACE_SPECIFIER\n            && val !== IMPORT_DEFAULT_SPECIFIER\n          ) {\n            oldImports.set(val, key);\n          }\n        });\n      });\n\n      function processDynamicImport(source) {\n        if (source.type !== 'Literal') {\n          return null;\n        }\n        const p = resolve(source.value, context);\n        if (p == null) {\n          return null;\n        }\n        newNamespaceImports.add(p);\n      }\n\n      visit(node, visitorKeyMap.get(file), {\n        ImportExpression(child) {\n          processDynamicImport(child.source);\n        },\n        CallExpression(child) {\n          if (child.callee.type === 'Import') {\n            processDynamicImport(child.arguments[0]);\n          }\n        },\n      });\n\n      node.body.forEach((astNode) => {\n        let resolvedPath;\n\n        // support for export { value } from 'module'\n        if (astNode.type === EXPORT_NAMED_DECLARATION) {\n          if (astNode.source) {\n            resolvedPath = resolve(astNode.source.raw.replace(/('|\")/g, ''), context);\n            astNode.specifiers.forEach((specifier) => {\n              const name = specifier.local.name || specifier.local.value;\n              if (name === DEFAULT) {\n                newDefaultImports.add(resolvedPath);\n              } else {\n                newImports.set(name, resolvedPath);\n              }\n            });\n          }\n        }\n\n        if (astNode.type === EXPORT_ALL_DECLARATION) {\n          resolvedPath = resolve(astNode.source.raw.replace(/('|\")/g, ''), context);\n          newExportAll.add(resolvedPath);\n        }\n\n        if (astNode.type === IMPORT_DECLARATION) {\n          resolvedPath = resolve(astNode.source.raw.replace(/('|\")/g, ''), context);\n          if (!resolvedPath) {\n            return;\n          }\n\n          if (isNodeModule(resolvedPath)) {\n            return;\n          }\n\n          if (newNamespaceImportExists(astNode.specifiers)) {\n            newNamespaceImports.add(resolvedPath);\n          }\n\n          if (newDefaultImportExists(astNode.specifiers)) {\n            newDefaultImports.add(resolvedPath);\n          }\n\n          astNode.specifiers\n            .filter((specifier) => specifier.type !== IMPORT_DEFAULT_SPECIFIER && specifier.type !== IMPORT_NAMESPACE_SPECIFIER)\n            .forEach((specifier) => {\n              newImports.set(specifier.imported.name || specifier.imported.value, resolvedPath);\n            });\n        }\n      });\n\n      newExportAll.forEach((value) => {\n        if (!oldExportAll.has(value)) {\n          let imports = oldImportPaths.get(value);\n          if (typeof imports === 'undefined') {\n            imports = new Set();\n          }\n          imports.add(EXPORT_ALL_DECLARATION);\n          oldImportPaths.set(value, imports);\n\n          let exports = exportList.get(value);\n          let currentExport;\n          if (typeof exports !== 'undefined') {\n            currentExport = exports.get(EXPORT_ALL_DECLARATION);\n          } else {\n            exports = new Map();\n            exportList.set(value, exports);\n          }\n\n          if (typeof currentExport !== 'undefined') {\n            currentExport.whereUsed.add(file);\n          } else {\n            const whereUsed = new Set();\n            whereUsed.add(file);\n            exports.set(EXPORT_ALL_DECLARATION, { whereUsed });\n          }\n        }\n      });\n\n      oldExportAll.forEach((value) => {\n        if (!newExportAll.has(value)) {\n          const imports = oldImportPaths.get(value);\n          imports.delete(EXPORT_ALL_DECLARATION);\n\n          const exports = exportList.get(value);\n          if (typeof exports !== 'undefined') {\n            const currentExport = exports.get(EXPORT_ALL_DECLARATION);\n            if (typeof currentExport !== 'undefined') {\n              currentExport.whereUsed.delete(file);\n            }\n          }\n        }\n      });\n\n      newDefaultImports.forEach((value) => {\n        if (!oldDefaultImports.has(value)) {\n          let imports = oldImportPaths.get(value);\n          if (typeof imports === 'undefined') {\n            imports = new Set();\n          }\n          imports.add(IMPORT_DEFAULT_SPECIFIER);\n          oldImportPaths.set(value, imports);\n\n          let exports = exportList.get(value);\n          let currentExport;\n          if (typeof exports !== 'undefined') {\n            currentExport = exports.get(IMPORT_DEFAULT_SPECIFIER);\n          } else {\n            exports = new Map();\n            exportList.set(value, exports);\n          }\n\n          if (typeof currentExport !== 'undefined') {\n            currentExport.whereUsed.add(file);\n          } else {\n            const whereUsed = new Set();\n            whereUsed.add(file);\n            exports.set(IMPORT_DEFAULT_SPECIFIER, { whereUsed });\n          }\n        }\n      });\n\n      oldDefaultImports.forEach((value) => {\n        if (!newDefaultImports.has(value)) {\n          const imports = oldImportPaths.get(value);\n          imports.delete(IMPORT_DEFAULT_SPECIFIER);\n\n          const exports = exportList.get(value);\n          if (typeof exports !== 'undefined') {\n            const currentExport = exports.get(IMPORT_DEFAULT_SPECIFIER);\n            if (typeof currentExport !== 'undefined') {\n              currentExport.whereUsed.delete(file);\n            }\n          }\n        }\n      });\n\n      newNamespaceImports.forEach((value) => {\n        if (!oldNamespaceImports.has(value)) {\n          let imports = oldImportPaths.get(value);\n          if (typeof imports === 'undefined') {\n            imports = new Set();\n          }\n          imports.add(IMPORT_NAMESPACE_SPECIFIER);\n          oldImportPaths.set(value, imports);\n\n          let exports = exportList.get(value);\n          let currentExport;\n          if (typeof exports !== 'undefined') {\n            currentExport = exports.get(IMPORT_NAMESPACE_SPECIFIER);\n          } else {\n            exports = new Map();\n            exportList.set(value, exports);\n          }\n\n          if (typeof currentExport !== 'undefined') {\n            currentExport.whereUsed.add(file);\n          } else {\n            const whereUsed = new Set();\n            whereUsed.add(file);\n            exports.set(IMPORT_NAMESPACE_SPECIFIER, { whereUsed });\n          }\n        }\n      });\n\n      oldNamespaceImports.forEach((value) => {\n        if (!newNamespaceImports.has(value)) {\n          const imports = oldImportPaths.get(value);\n          imports.delete(IMPORT_NAMESPACE_SPECIFIER);\n\n          const exports = exportList.get(value);\n          if (typeof exports !== 'undefined') {\n            const currentExport = exports.get(IMPORT_NAMESPACE_SPECIFIER);\n            if (typeof currentExport !== 'undefined') {\n              currentExport.whereUsed.delete(file);\n            }\n          }\n        }\n      });\n\n      newImports.forEach((value, key) => {\n        if (!oldImports.has(key)) {\n          let imports = oldImportPaths.get(value);\n          if (typeof imports === 'undefined') {\n            imports = new Set();\n          }\n          imports.add(key);\n          oldImportPaths.set(value, imports);\n\n          let exports = exportList.get(value);\n          let currentExport;\n          if (typeof exports !== 'undefined') {\n            currentExport = exports.get(key);\n          } else {\n            exports = new Map();\n            exportList.set(value, exports);\n          }\n\n          if (typeof currentExport !== 'undefined') {\n            currentExport.whereUsed.add(file);\n          } else {\n            const whereUsed = new Set();\n            whereUsed.add(file);\n            exports.set(key, { whereUsed });\n          }\n        }\n      });\n\n      oldImports.forEach((value, key) => {\n        if (!newImports.has(key)) {\n          const imports = oldImportPaths.get(value);\n          imports.delete(key);\n\n          const exports = exportList.get(value);\n          if (typeof exports !== 'undefined') {\n            const currentExport = exports.get(key);\n            if (typeof currentExport !== 'undefined') {\n              currentExport.whereUsed.delete(file);\n            }\n          }\n        }\n      });\n    };\n\n    return {\n      'Program:exit'(node) {\n        updateExportUsage(node);\n        updateImportUsage(node);\n        checkExportPresence(node);\n      },\n      ExportDefaultDeclaration(node) {\n        checkUsage(node, IMPORT_DEFAULT_SPECIFIER, false);\n      },\n      ExportNamedDeclaration(node) {\n        node.specifiers.forEach((specifier) => {\n          checkUsage(specifier, specifier.exported.name || specifier.exported.value, false);\n        });\n        forEachDeclarationIdentifier(node.declaration, (name, isTypeExport) => {\n          checkUsage(node, name, isTypeExport);\n        });\n      },\n    };\n  },\n};\n"]}