UNPKG

stylelint

Version:

A mighty CSS linter that helps you avoid errors and enforce conventions.

50 lines (39 loc) 1.48 kB
import optionsMatches from './utils/optionsMatches.mjs'; import reportCommentProblem from './utils/reportCommentProblem.mjs'; import validateDisableSettings from './validateDisableSettings.mjs'; /** * @param {import('stylelint').PostcssResult} postcssResult * @returns {void} */ export default function descriptionlessDisables(postcssResult) { const [enabled, options] = validateDisableSettings( postcssResult, 'reportDescriptionlessDisables', ); if (!options) return; /** @type {Set<import('postcss').Comment>} */ const alreadyReported = new Set(); for (const [rule, ruleRanges] of Object.entries(postcssResult.stylelint.disabledRanges)) { for (const range of ruleRanges) { if (range.description) continue; const commentNode = range.comment; if (alreadyReported.has(commentNode)) continue; if (enabled === optionsMatches(options, 'except', rule)) { // An 'all' rule will get copied for each individual rule. If the // configuration is `[false, {except: ['specific-rule']}]`, we // don't want to report the copies that match except, so we record // the comment as already reported. if (!enabled && rule === 'all') alreadyReported.add(commentNode); continue; } alreadyReported.add(commentNode); reportCommentProblem({ rule: '--report-descriptionless-disables', message: `Disable for "${rule}" is missing a description`, severity: options.severity, commentNode, postcssResult, }); } } }