1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- "use strict";
- function safelyShadowsUndefined(variable) {
- return variable.name === "undefined" &&
- variable.references.every(ref => !ref.isWrite()) &&
- variable.defs.every(def => def.node.type === "VariableDeclarator" && def.node.init === null);
- }
- module.exports = {
- meta: {
- type: "suggestion",
- docs: {
- description: "Disallow identifiers from shadowing restricted names",
- recommended: true,
- url: "https://eslint.org/docs/latest/rules/no-shadow-restricted-names"
- },
- schema: [],
- messages: {
- shadowingRestrictedName: "Shadowing of global property '{{name}}'."
- }
- },
- create(context) {
- const RESTRICTED = new Set(["undefined", "NaN", "Infinity", "arguments", "eval"]);
- const sourceCode = context.sourceCode;
- return {
- "VariableDeclaration, :function, CatchClause"(node) {
- for (const variable of sourceCode.getDeclaredVariables(node)) {
- if (variable.defs.length > 0 && RESTRICTED.has(variable.name) && !safelyShadowsUndefined(variable)) {
- context.report({
- node: variable.defs[0].name,
- messageId: "shadowingRestrictedName",
- data: {
- name: variable.name
- }
- });
- }
- }
- }
- };
- }
- };
|