| 'use strict'; |
| |
| const optionsMatches = require('./utils/optionsMatches'); |
| const validateDisableSettings = require('./validateDisableSettings'); |
| |
| /** @typedef {import('stylelint').RangeType} RangeType */ |
| |
| /** |
| * @param {import('stylelint').LintResult[]} results |
| */ |
| module.exports = function invalidScopeDisables(results) { |
| for (const result of results) { |
| const settings = validateDisableSettings(result._postcssResult, 'reportInvalidScopeDisables'); |
| |
| if (!settings) continue; |
| |
| const [enabled, options, stylelintResult] = settings; |
| |
| const configRules = (stylelintResult.config || {}).rules || {}; |
| |
| const usedRules = new Set(Object.keys(configRules)); |
| |
| usedRules.add('all'); |
| |
| const rangeData = stylelintResult.disabledRanges; |
| const disabledRules = Object.keys(rangeData); |
| |
| for (const rule of disabledRules) { |
| if (usedRules.has(rule)) continue; |
| |
| if (enabled === optionsMatches(options, 'except', rule)) continue; |
| |
| for (const range of rangeData[rule]) { |
| if (!range.strictStart && !range.strictEnd) continue; |
| |
| // If the comment doesn't have a location, we can't report a useful error. |
| // In practice we expect all comments to have locations, though. |
| if (!range.comment.source || !range.comment.source.start) continue; |
| |
| result.warnings.push({ |
| text: `Rule "${rule}" isn't enabled`, |
| rule: '--report-invalid-scope-disables', |
| line: range.comment.source.start.line, |
| column: range.comment.source.start.column, |
| severity: options.severity, |
| }); |
| } |
| } |
| } |
| }; |