UNPKG

11.6 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6exports.default = void 0;
7
8var _Lint = _interopRequireWildcard(require("../Lint"));
9
10var _Versioning = _interopRequireWildcard(require("../Versioning"));
11
12function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
13
14function getName(node) {
15 switch (node.type) {
16 case 'NewExpression':
17 {
18 return node.callee.name;
19 }
20
21 case 'MemberExpression':
22 {
23 return node.object.name;
24 }
25
26 case 'CallExpression':
27 {
28 return node.callee.name;
29 }
30
31 default:
32 throw new Error('not found');
33 }
34}
35
36var _default = {
37 meta: {
38 docs: {
39 description: 'Ensure cross-browser API compatibility',
40 category: 'Compatibility',
41 recommended: true
42 },
43 fixable: 'code',
44 schema: []
45 },
46
47 create(context) {
48 // Determine lowest targets from browserslist config, which reads user's
49 const browserslistConfig = context.settings.browsers || context.settings.targets || context.options[0];
50 const browserslistTargets = (0, _Versioning.Versioning)((0, _Versioning.default)(context.getFilename(), browserslistConfig));
51 const errors = [];
52
53 function lint(node) {
54 const {
55 isValid,
56 rule,
57 unsupportedTargets
58 } = (0, _Lint.default)(node, browserslistTargets, new Set(context.settings.polyfills || []));
59
60 if (!isValid) {
61 errors.push({
62 node,
63 message: [(0, _Lint.generateErrorName)(rule), 'is not supported in', unsupportedTargets.join(', ')].join(' ')
64 });
65 }
66 }
67
68 const identifiers = new Set();
69 return {
70 CallExpression: lint,
71 MemberExpression: lint,
72 NewExpression: lint,
73
74 // Keep track of all the defined variables. Do not report errors for nodes that are not defined
75 Identifier(node) {
76 if (node.parent) {
77 const {
78 type
79 } = node.parent;
80
81 if ( // ex. const { Set } = require('immutable');
82 type === 'Property' || // ex. function Set() {}
83 type === 'FunctionDeclaration' || // ex. const Set = () => {}
84 type === 'VariableDeclarator' || // ex. class Set {}
85 type === 'ClassDeclaration' || // ex. import Set from 'set';
86 type === 'ImportDefaultSpecifier' || // ex. import {Set} from 'set';
87 type === 'ImportSpecifier' || // ex. import {Set} from 'set';
88 type === 'ImportDeclaration') {
89 identifiers.add(node.name);
90 }
91 }
92 },
93
94 'Program:exit': () => {
95 // Get a map of all the variables defined in the root scope (not the global scope)
96 // const variablesMap = context.getScope().childScopes.map(e => e.set)[0];
97 errors.filter(error => !identifiers.has(getName(error.node))).forEach(node => context.report(node));
98 }
99 };
100 }
101
102};
103exports.default = _default;
104//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/rules/compat.js"],"names":["getName","node","type","callee","name","object","Error","meta","docs","description","category","recommended","fixable","schema","create","context","browserslistConfig","settings","browsers","targets","options","browserslistTargets","getFilename","errors","lint","isValid","rule","unsupportedTargets","Set","polyfills","push","message","join","identifiers","CallExpression","MemberExpression","NewExpression","Identifier","parent","add","filter","error","has","forEach","report"],"mappings":"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","sourcesContent":["// @flow\nimport Lint, { generateErrorName } from '../Lint';\nimport DetermineTargetsFromConfig, { Versioning } from '../Versioning';\nimport type { ESLintNode } from '../LintTypes';\n\ntype ESLint = {\n  [astNodeTypeName: string]: (node: ESLintNode) => void\n};\n\ntype Context = {\n  node: ESLintNode,\n  settings: {\n    browsers: Array<string>,\n    polyfills: Array<string>\n  },\n  getFilename: () => string,\n  report: () => void\n};\n\nfunction getName(node) {\n  switch (node.type) {\n    case 'NewExpression': {\n      return node.callee.name;\n    }\n    case 'MemberExpression': {\n      return node.object.name;\n    }\n    case 'CallExpression': {\n      return node.callee.name;\n    }\n    default:\n      throw new Error('not found');\n  }\n}\n\nexport type BrowserListConfig =\n  | Array<string>\n  | {\n      production?: Array<string>,\n      development?: Array<string>\n    }\n  | null;\n\nexport default {\n  meta: {\n    docs: {\n      description: 'Ensure cross-browser API compatibility',\n      category: 'Compatibility',\n      recommended: true\n    },\n    fixable: 'code',\n    schema: []\n  },\n  create(context: Context): ESLint {\n    // Determine lowest targets from browserslist config, which reads user's\n    // package.json config section. Use config from eslintrc for testing purposes\n    const browserslistConfig: BrowserListConfig =\n      context.settings.browsers ||\n      context.settings.targets ||\n      context.options[0];\n\n    const browserslistTargets = Versioning(\n      DetermineTargetsFromConfig(context.getFilename(), browserslistConfig)\n    );\n\n    const errors = [];\n\n    function lint(node: ESLintNode) {\n      const { isValid, rule, unsupportedTargets } = Lint(\n        node,\n        browserslistTargets,\n        new Set(context.settings.polyfills || [])\n      );\n\n      if (!isValid) {\n        errors.push({\n          node,\n          message: [\n            generateErrorName(rule),\n            'is not supported in',\n            unsupportedTargets.join(', ')\n          ].join(' ')\n        });\n      }\n    }\n\n    const identifiers = new Set();\n\n    return {\n      CallExpression: lint,\n      MemberExpression: lint,\n      NewExpression: lint,\n      // Keep track of all the defined variables. Do not report errors for nodes that are not defined\n      Identifier(node) {\n        if (node.parent) {\n          const { type } = node.parent;\n          if (\n            // ex. const { Set } = require('immutable');\n            type === 'Property' ||\n            // ex. function Set() {}\n            type === 'FunctionDeclaration' ||\n            // ex. const Set = () => {}\n            type === 'VariableDeclarator' ||\n            // ex. class Set {}\n            type === 'ClassDeclaration' ||\n            // ex. import Set from 'set';\n            type === 'ImportDefaultSpecifier' ||\n            // ex. import {Set} from 'set';\n            type === 'ImportSpecifier' ||\n            // ex. import {Set} from 'set';\n            type === 'ImportDeclaration'\n          ) {\n            identifiers.add(node.name);\n          }\n        }\n      },\n      'Program:exit': () => {\n        // Get a map of all the variables defined in the root scope (not the global scope)\n        // const variablesMap = context.getScope().childScopes.map(e => e.set)[0];\n        errors\n          .filter(error => !identifiers.has(getName(error.node)))\n          .forEach(node => context.report(node));\n      }\n    };\n  }\n};\n"]}
\No newline at end of file