Versions

no-shadow-restricted-names

Disallow identifiers from shadowing restricted names

Recommended

Using the recommended config from @eslint/js in a configuration file enables this rule

ES5 §15.1.1 Value Properties of the Global Object (NaN, Infinity, undefined) as well as strict mode restricted identifiers eval and arguments are considered to be restricted names in JavaScript. Defining them to mean something else can have unintended consequences and confuse others reading the code. For example, there’s nothing preventing you from writing:

var undefined = "foo";

Then any code used within the same scope would not get the global undefined, but rather the local version with a very different meaning.

Rule Details

Examples of incorrect code for this rule:

Open in Playground
/*eslint no-shadow-restricted-names: "error"*/

function NaN(){}

!function(Infinity){};

var undefined = 5;

try {} catch(eval){}
Open in Playground
/*eslint no-shadow-restricted-names: "error"*/

import NaN from "foo";

import { undefined } from "bar";

class Infinity {}

Examples of correct code for this rule:

Open in Playground
/*eslint no-shadow-restricted-names: "error"*/

var Object;

function f(a, b){}

// Exception: `undefined` may be shadowed if the variable is never assigned a value.
var undefined;
Open in Playground
/*eslint no-shadow-restricted-names: "error"*/

import { undefined as undef } from "bar";

Version

This rule was introduced in ESLint v0.1.4.

Further Reading

Resources

Change Language