|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
-
-
- "use strict";
-
-
-
-
-
- module.exports = {
- meta: {
- type: "suggestion",
-
- docs: {
- description: "disallow unused labels",
- category: "Best Practices",
- recommended: true,
- url: "https://eslint.org/docs/rules/no-unused-labels"
- },
-
- schema: [],
- fixable: "code"
- },
-
- create(context) {
- const sourceCode = context.getSourceCode();
- let scopeInfo = null;
-
-
-
- function enterLabeledScope(node) {
- scopeInfo = {
- label: node.label.name,
- used: false,
- upper: scopeInfo
- };
- }
-
-
-
- function exitLabeledScope(node) {
- if (!scopeInfo.used) {
- context.report({
- node: node.label,
- message: "'{{name}}:' is defined but never used.",
- data: node.label,
- fix(fixer) {
-
-
-
- if (sourceCode.getTokenAfter(node.label, { includeComments: true }) ===
- sourceCode.getTokenBefore(node.body, { includeComments: true })) {
- return fixer.removeRange([node.range[0], node.body.range[0]]);
- }
-
- return null;
- }
- });
- }
-
- scopeInfo = scopeInfo.upper;
- }
-
-
-
- function markAsUsed(node) {
- if (!node.label) {
- return;
- }
-
- const label = node.label.name;
- let info = scopeInfo;
-
- while (info) {
- if (info.label === label) {
- info.used = true;
- break;
- }
- info = info.upper;
- }
- }
-
- return {
- LabeledStatement: enterLabeledScope,
- "LabeledStatement:exit": exitLabeledScope,
- BreakStatement: markAsUsed,
- ContinueStatement: markAsUsed
- };
- }
- };
|