SourceTermAnalysisSystem_vue/node_modules/@eslint-community/eslint-plugin-eslint-comments/lib/rules/disable-enable-pair.js
2026-05-15 10:22:44 +08:00

74 lines
2.2 KiB
JavaScript

/**
* @author Toru Nagashima <https://github.com/mysticatea>
* See LICENSE file in root directory for full license.
*/
"use strict"
const { getDisabledArea } = require("../internal/disabled-area")
const utils = require("../internal/utils")
module.exports = {
meta: {
docs: {
description:
"require a `eslint-enable` comment for every `eslint-disable` comment",
category: "Best Practices",
recommended: true,
url: "https://eslint-community.github.io/eslint-plugin-eslint-comments/rules/disable-enable-pair.html",
},
fixable: null,
messages: {
missingPair: "Requires 'eslint-enable' directive.",
missingRulePair:
"Requires 'eslint-enable' directive for '{{ruleId}}'.",
},
schema: [
{
type: "object",
properties: {
allowWholeFile: {
type: "boolean",
},
},
additionalProperties: false,
},
],
type: "suggestion",
},
create(context) {
const allowWholeFile =
context.options[0] && context.options[0].allowWholeFile
const disabledArea = getDisabledArea(context)
/** @type {import('@eslint/core').TextSourceCode} */
const sourceCode = context.sourceCode || context.getSourceCode()
const firstToken =
sourceCode.ast && sourceCode.ast.tokens && sourceCode.ast.tokens[0]
if (allowWholeFile && !firstToken) {
return {}
}
for (const area of disabledArea.areas) {
if (area.end != null) {
continue
}
if (
allowWholeFile &&
utils.lte(area.start, utils.getLoc(context, firstToken).start)
) {
continue
}
context.report({
loc: utils.toRuleIdLocation(context, area.comment, area.ruleId),
messageId: area.ruleId ? "missingRulePair" : "missingPair",
data: area,
})
}
return {}
},
}