stylelint
Version:
A mighty CSS linter that helps you avoid errors and enforce conventions.
55 lines (44 loc) • 1.57 kB
JavaScript
// NOTICE: This file is generated by Rollup. To modify it,
// please instead edit the ESM counterpart and rebuild with Rollup (npm run build).
;
const constants = require('./constants.cjs');
const reportCommentProblem = require('./utils/reportCommentProblem.cjs');
/**
* Returns a report describing which `results` (if any) contain disabled ranges
* for rules that disallow disables via `reportDisables: true`.
*
* @param {import('stylelint').PostcssResult} postcssResult
* @returns {void}
*/
function reportDisables(postcssResult) {
const rangeData = postcssResult.stylelint.disabledRanges;
const configRules = postcssResult.stylelint.config?.rules;
if (!configRules) return;
// If no rules actually disallow disables, don't bother looking for ranges
// that correspond to disabled rules.
if (!Object.values(configRules).some((rule) => reportDisablesForRule(rule))) {
return;
}
for (const [rule, ranges] of Object.entries(rangeData)) {
for (const range of ranges) {
if (!configRules[rule]) continue;
if (!reportDisablesForRule(configRules[rule])) continue;
reportCommentProblem({
rule: 'reportDisables',
message: `Rule "${rule}" may not be disabled`,
severity: constants.SEVERITY_ERROR,
node: range.node,
postcssResult,
});
}
}
}
/**
* @param {import('stylelint').ConfigRuleSettings<any, object>} options
* @returns {boolean}
*/
function reportDisablesForRule(options) {
if (!options || !options[1]) return false;
return Boolean(options[1].reportDisables);
}
module.exports = reportDisables;