1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- "use strict";
- const astUtils = require("./utils/ast-utils");
- module.exports = {
- meta: {
- type: "suggestion",
- docs: {
- description: "Disallow labels that share a name with a variable",
- recommended: false,
- url: "https://eslint.org/docs/latest/rules/no-label-var"
- },
- schema: [],
- messages: {
- identifierClashWithLabel: "Found identifier with same name as label."
- }
- },
- create(context) {
- const sourceCode = context.sourceCode;
-
-
-
-
- function findIdentifier(scope, name) {
- return astUtils.getVariableByName(scope, name) !== null;
- }
-
-
-
- return {
- LabeledStatement(node) {
-
- const scope = sourceCode.getScope(node);
-
- if (findIdentifier(scope, node.label.name)) {
- context.report({
- node,
- messageId: "identifierClashWithLabel"
- });
- }
- }
- };
- }
- };
|