no-import-module-exports.js 12 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. 'use strict';var _minimatch = require('minimatch');var _minimatch2 = _interopRequireDefault(_minimatch);
  2. var _path = require('path');var _path2 = _interopRequireDefault(_path);
  3. var _pkgUp = require('eslint-module-utils/pkgUp');var _pkgUp2 = _interopRequireDefault(_pkgUp);function _interopRequireDefault(obj) {return obj && obj.__esModule ? obj : { 'default': obj };}
  4. function getEntryPoint(context) {
  5. var pkgPath = (0, _pkgUp2['default'])({ cwd: context.getPhysicalFilename ? context.getPhysicalFilename() : context.getFilename() });
  6. try {
  7. return require.resolve(_path2['default'].dirname(pkgPath));
  8. } catch (error) {
  9. // Assume the package has no entrypoint (e.g. CLI packages)
  10. // in which case require.resolve would throw.
  11. return null;
  12. }
  13. }
  14. function findScope(context, identifier) {var _context$getSourceCod =
  15. context.getSourceCode(),scopeManager = _context$getSourceCod.scopeManager;
  16. return scopeManager && scopeManager.scopes.slice().reverse().find(function (scope) {return scope.variables.some(function (variable) {return variable.identifiers.some(function (node) {return node.name === identifier;});});});
  17. }
  18. function findDefinition(objectScope, identifier) {
  19. var variable = objectScope.variables.find(function (variable) {return variable.name === identifier;});
  20. return variable.defs.find(function (def) {return def.name.name === identifier;});
  21. }
  22. module.exports = {
  23. meta: {
  24. type: 'problem',
  25. docs: {
  26. category: 'Module systems',
  27. description: 'Forbid import statements with CommonJS module.exports.',
  28. recommended: true },
  29. fixable: 'code',
  30. schema: [
  31. {
  32. 'type': 'object',
  33. 'properties': {
  34. 'exceptions': { 'type': 'array' } },
  35. 'additionalProperties': false }] },
  36. create: function () {function create(context) {
  37. var importDeclarations = [];
  38. var entryPoint = getEntryPoint(context);
  39. var options = context.options[0] || {};
  40. var alreadyReported = false;
  41. function report(node) {
  42. var fileName = context.getPhysicalFilename ? context.getPhysicalFilename() : context.getFilename();
  43. var isEntryPoint = entryPoint === fileName;
  44. var isIdentifier = node.object.type === 'Identifier';
  45. var hasKeywords = /^(module|exports)$/.test(node.object.name);
  46. var objectScope = hasKeywords && findScope(context, node.object.name);
  47. var variableDefinition = objectScope && findDefinition(objectScope, node.object.name);
  48. var isImportBinding = variableDefinition && variableDefinition.type === 'ImportBinding';
  49. var hasCJSExportReference = hasKeywords && (!objectScope || objectScope.type === 'module');
  50. var isException = !!options.exceptions && options.exceptions.some(function (glob) {return (0, _minimatch2['default'])(fileName, glob);});
  51. if (isIdentifier && hasCJSExportReference && !isEntryPoint && !isException && !isImportBinding) {
  52. importDeclarations.forEach(function (importDeclaration) {
  53. context.report({
  54. node: importDeclaration,
  55. message: 'Cannot use import declarations in modules that export using ' + 'CommonJS (module.exports = \'foo\' or exports.bar = \'hi\')' });
  56. });
  57. alreadyReported = true;
  58. }
  59. }
  60. return {
  61. ImportDeclaration: function () {function ImportDeclaration(node) {
  62. importDeclarations.push(node);
  63. }return ImportDeclaration;}(),
  64. MemberExpression: function () {function MemberExpression(node) {
  65. if (!alreadyReported) {
  66. report(node);
  67. }
  68. }return MemberExpression;}() };
  69. }return create;}() };
  70. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/rules/no-import-module-exports.js"],"names":["getEntryPoint","context","pkgPath","cwd","getPhysicalFilename","getFilename","require","resolve","path","dirname","error","findScope","identifier","getSourceCode","scopeManager","scopes","slice","reverse","find","scope","variables","some","variable","identifiers","node","name","findDefinition","objectScope","defs","def","module","exports","meta","type","docs","category","description","recommended","fixable","schema","create","importDeclarations","entryPoint","options","alreadyReported","report","fileName","isEntryPoint","isIdentifier","object","hasKeywords","test","variableDefinition","isImportBinding","hasCJSExportReference","isException","exceptions","glob","forEach","importDeclaration","message","ImportDeclaration","push","MemberExpression"],"mappings":"aAAA,sC;AACA,4B;AACA,kD;;AAEA,SAASA,aAAT,CAAuBC,OAAvB,EAAgC;AAC9B,MAAMC,UAAU,wBAAM,EAAEC,KAAKF,QAAQG,mBAAR,GAA8BH,QAAQG,mBAAR,EAA9B,GAA8DH,QAAQI,WAAR,EAArE,EAAN,CAAhB;AACA,MAAI;AACF,WAAOC,QAAQC,OAAR,CAAgBC,kBAAKC,OAAL,CAAaP,OAAb,CAAhB,CAAP;AACD,GAFD,CAEE,OAAOQ,KAAP,EAAc;AACd;AACA;AACA,WAAO,IAAP;AACD;AACF;;AAED,SAASC,SAAT,CAAmBV,OAAnB,EAA4BW,UAA5B,EAAwC;AACbX,UAAQY,aAAR,EADa,CAC9BC,YAD8B,yBAC9BA,YAD8B;;AAGtC,SAAOA,gBAAgBA,aAAaC,MAAb,CAAoBC,KAApB,GAA4BC,OAA5B,GAAsCC,IAAtC,CAA2C,UAACC,KAAD,UAAWA,MAAMC,SAAN,CAAgBC,IAAhB,CAAqB,4BAAYC,SAASC,WAAT,CAAqBF,IAArB,CAA0B,UAACG,IAAD,UAAUA,KAAKC,IAAL,KAAcb,UAAxB,EAA1B,CAAZ,EAArB,CAAX,EAA3C,CAAvB;AACD;;AAED,SAASc,cAAT,CAAwBC,WAAxB,EAAqCf,UAArC,EAAiD;AAC/C,MAAMU,WAAWK,YAAYP,SAAZ,CAAsBF,IAAtB,CAA2B,4BAAYI,SAASG,IAAT,KAAkBb,UAA9B,EAA3B,CAAjB;AACA,SAAOU,SAASM,IAAT,CAAcV,IAAd,CAAmB,uBAAOW,IAAIJ,IAAJ,CAASA,IAAT,KAAkBb,UAAzB,EAAnB,CAAP;AACD;;AAEDkB,OAAOC,OAAP,GAAiB;AACfC,QAAM;AACJC,UAAM,SADF;AAEJC,UAAM;AACJC,gBAAU,gBADN;AAEJC,mBAAa,wDAFT;AAGJC,mBAAa,IAHT,EAFF;;AAOJC,aAAS,MAPL;AAQJC,YAAQ;AACN;AACE,cAAQ,QADV;AAEE,oBAAc;AACZ,sBAAc,EAAE,QAAQ,OAAV,EADF,EAFhB;;AAKE,8BAAwB,KAL1B,EADM,CARJ,EADS;;;;AAmBfC,QAnBe,+BAmBRvC,OAnBQ,EAmBC;AACd,UAAMwC,qBAAqB,EAA3B;AACA,UAAMC,aAAa1C,cAAcC,OAAd,CAAnB;AACA,UAAM0C,UAAU1C,QAAQ0C,OAAR,CAAgB,CAAhB,KAAsB,EAAtC;AACA,UAAIC,kBAAkB,KAAtB;;AAEA,eAASC,MAAT,CAAgBrB,IAAhB,EAAsB;AACpB,YAAMsB,WAAW7C,QAAQG,mBAAR,GAA8BH,QAAQG,mBAAR,EAA9B,GAA8DH,QAAQI,WAAR,EAA/E;AACA,YAAM0C,eAAeL,eAAeI,QAApC;AACA,YAAME,eAAexB,KAAKyB,MAAL,CAAYhB,IAAZ,KAAqB,YAA1C;AACA,YAAMiB,cAAe,oBAAD,CAAuBC,IAAvB,CAA4B3B,KAAKyB,MAAL,CAAYxB,IAAxC,CAApB;AACA,YAAME,cAAcuB,eAAevC,UAAUV,OAAV,EAAmBuB,KAAKyB,MAAL,CAAYxB,IAA/B,CAAnC;AACA,YAAM2B,qBAAqBzB,eAAeD,eAAeC,WAAf,EAA4BH,KAAKyB,MAAL,CAAYxB,IAAxC,CAA1C;AACA,YAAM4B,kBAAkBD,sBAAsBA,mBAAmBnB,IAAnB,KAA4B,eAA1E;AACA,YAAMqB,wBAAwBJ,gBAAgB,CAACvB,WAAD,IAAgBA,YAAYM,IAAZ,KAAqB,QAArD,CAA9B;AACA,YAAMsB,cAAc,CAAC,CAACZ,QAAQa,UAAV,IAAwBb,QAAQa,UAAR,CAAmBnC,IAAnB,CAAwB,wBAAQ,4BAAUyB,QAAV,EAAoBW,IAApB,CAAR,EAAxB,CAA5C;;AAEA,YAAIT,gBAAgBM,qBAAhB,IAAyC,CAACP,YAA1C,IAA0D,CAACQ,WAA3D,IAA0E,CAACF,eAA/E,EAAgG;AAC9FZ,6BAAmBiB,OAAnB,CAA2B,6BAAqB;AAC9CzD,oBAAQ4C,MAAR,CAAe;AACbrB,oBAAMmC,iBADO;AAEbC,uBAAS,8HAFI,EAAf;;;AAKD,WAND;AAOAhB,4BAAkB,IAAlB;AACD;AACF;;AAED,aAAO;AACLiB,yBADK,0CACarC,IADb,EACmB;AACtBiB,+BAAmBqB,IAAnB,CAAwBtC,IAAxB;AACD,WAHI;AAILuC,wBAJK,yCAIYvC,IAJZ,EAIkB;AACrB,gBAAI,CAACoB,eAAL,EAAsB;AACpBC,qBAAOrB,IAAP;AACD;AACF,WARI,6BAAP;;AAUD,KA1Dc,mBAAjB","file":"no-import-module-exports.js","sourcesContent":["import minimatch from 'minimatch';\nimport path from 'path';\nimport pkgUp from 'eslint-module-utils/pkgUp';\n\nfunction getEntryPoint(context) {\n  const pkgPath = pkgUp({ cwd: context.getPhysicalFilename ? context.getPhysicalFilename() : context.getFilename() });\n  try {\n    return require.resolve(path.dirname(pkgPath));\n  } catch (error) {\n    // Assume the package has no entrypoint (e.g. CLI packages)\n    // in which case require.resolve would throw.\n    return null;\n  }\n}\n\nfunction findScope(context, identifier) {\n  const { scopeManager } = context.getSourceCode();\n\n  return scopeManager && scopeManager.scopes.slice().reverse().find((scope) => scope.variables.some(variable => variable.identifiers.some((node) => node.name === identifier)));\n}\n\nfunction findDefinition(objectScope, identifier) {\n  const variable = objectScope.variables.find(variable => variable.name === identifier);\n  return variable.defs.find(def => def.name.name === identifier);\n}\n\nmodule.exports = {\n  meta: {\n    type: 'problem',\n    docs: {\n      category: 'Module systems',\n      description: 'Forbid import statements with CommonJS module.exports.',\n      recommended: true,\n    },\n    fixable: 'code',\n    schema: [\n      {\n        'type': 'object',\n        'properties': {\n          'exceptions': { 'type': 'array' },\n        },\n        'additionalProperties': false,\n      },\n    ],\n  },\n  create(context) {\n    const importDeclarations = [];\n    const entryPoint = getEntryPoint(context);\n    const options = context.options[0] || {};\n    let alreadyReported = false;\n\n    function report(node) {\n      const fileName = context.getPhysicalFilename ? context.getPhysicalFilename() : context.getFilename();\n      const isEntryPoint = entryPoint === fileName;\n      const isIdentifier = node.object.type === 'Identifier';\n      const hasKeywords = (/^(module|exports)$/).test(node.object.name);\n      const objectScope = hasKeywords && findScope(context, node.object.name);\n      const variableDefinition = objectScope && findDefinition(objectScope, node.object.name);\n      const isImportBinding = variableDefinition && variableDefinition.type === 'ImportBinding';\n      const hasCJSExportReference = hasKeywords && (!objectScope || objectScope.type === 'module');\n      const isException = !!options.exceptions && options.exceptions.some(glob => minimatch(fileName, glob));\n\n      if (isIdentifier && hasCJSExportReference && !isEntryPoint && !isException && !isImportBinding) {\n        importDeclarations.forEach(importDeclaration => {\n          context.report({\n            node: importDeclaration,\n            message: `Cannot use import declarations in modules that export using ` +\n              `CommonJS (module.exports = 'foo' or exports.bar = 'hi')`,\n          });\n        });\n        alreadyReported = true;\n      }\n    }\n\n    return {\n      ImportDeclaration(node) {\n        importDeclarations.push(node);\n      },\n      MemberExpression(node) {\n        if (!alreadyReported) {\n          report(node);\n        }\n      },\n    };\n  },\n};\n"]}