no-unused-modules.js 107 KB

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