Save current BZZZ config-ui state before CHORUS branding update
🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
		
							
								
								
									
										65
									
								
								install/config-ui/node_modules/eslint/lib/rules/no-shadow-restricted-names.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								install/config-ui/node_modules/eslint/lib/rules/no-shadow-restricted-names.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | ||||
| /** | ||||
|  * @fileoverview Disallow shadowing of NaN, undefined, and Infinity (ES5 section 15.1.1) | ||||
|  * @author Michael Ficarra | ||||
|  */ | ||||
| "use strict"; | ||||
|  | ||||
| /** | ||||
|  * Determines if a variable safely shadows undefined. | ||||
|  * This is the case when a variable named `undefined` is never assigned to a value (i.e. it always shares the same value | ||||
|  * as the global). | ||||
|  * @param {eslintScope.Variable} variable The variable to check | ||||
|  * @returns {boolean} true if this variable safely shadows `undefined` | ||||
|  */ | ||||
| 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); | ||||
| } | ||||
|  | ||||
| //------------------------------------------------------------------------------ | ||||
| // Rule Definition | ||||
| //------------------------------------------------------------------------------ | ||||
|  | ||||
| /** @type {import('../shared/types').Rule} */ | ||||
| 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 | ||||
|                             } | ||||
|                         }); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         }; | ||||
|  | ||||
|     } | ||||
| }; | ||||
		Reference in New Issue
	
	Block a user
	 anthonyrawlins
					anthonyrawlins