12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- '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');
- for (const [rule, ruleRanges] of Object.entries(stylelintResult.disabledRanges)) {
- if (usedRules.has(rule)) continue;
- if (enabled === optionsMatches(options, 'except', rule)) continue;
- for (const range of ruleRanges) {
- 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,
- endLine: range.comment.source.end && range.comment.source.end.line,
- endColumn: range.comment.source.end && range.comment.source.end.column,
- severity: options.severity,
- });
- }
- }
- }
- };
|