You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
134 lines
3.8 KiB
134 lines
3.8 KiB
'use strict'; |
|
|
|
const assignDisabledRanges = require('./assignDisabledRanges'); |
|
const get = require('lodash/get'); |
|
const getOsEol = require('./utils/getOsEol'); |
|
const reportUnknownRuleNames = require('./reportUnknownRuleNames'); |
|
const rulesOrder = require('./rules'); |
|
|
|
/** @typedef {import('stylelint').StylelintStandaloneOptions} StylelintStandaloneOptions */ |
|
/** @typedef {import('stylelint').PostcssResult} PostcssResult */ |
|
/** @typedef {import('stylelint').StylelintConfig} StylelintConfig */ |
|
|
|
/** |
|
* @param {StylelintStandaloneOptions} stylelintOptions |
|
* @param {PostcssResult} postcssResult |
|
* @param {StylelintConfig} config |
|
* @returns {Promise<any>} |
|
*/ |
|
function lintPostcssResult(stylelintOptions, postcssResult, config) { |
|
postcssResult.stylelint.ruleSeverities = {}; |
|
postcssResult.stylelint.customMessages = {}; |
|
postcssResult.stylelint.stylelintError = false; |
|
postcssResult.stylelint.quiet = config.quiet; |
|
postcssResult.stylelint.config = config; |
|
|
|
/** @type {string} */ |
|
let newline; |
|
const postcssDoc = postcssResult.root; |
|
|
|
if (postcssDoc) { |
|
if (!('type' in postcssDoc)) { |
|
throw new Error('Unexpected Postcss root object!'); |
|
} |
|
|
|
// @ts-ignore TODO TYPES property css does not exists |
|
const newlineMatch = postcssDoc.source && postcssDoc.source.input.css.match(/\r?\n/); |
|
|
|
newline = newlineMatch ? newlineMatch[0] : getOsEol(); |
|
|
|
assignDisabledRanges(postcssDoc, postcssResult); |
|
} |
|
|
|
const isFileFixCompatible = isFixCompatible(postcssResult); |
|
|
|
if (!isFileFixCompatible) { |
|
postcssResult.stylelint.disableWritingFix = true; |
|
} |
|
|
|
const postcssRoots = /** @type {import('postcss').Root[]} */ (postcssDoc && |
|
postcssDoc.constructor.name === 'Document' |
|
? postcssDoc.nodes |
|
: [postcssDoc]); |
|
|
|
// Promises for the rules. Although the rule code runs synchronously now, |
|
// the use of Promises makes it compatible with the possibility of async |
|
// rules down the line. |
|
/** @type {Array<Promise<any>>} */ |
|
const performRules = []; |
|
|
|
const rules = config.rules |
|
? Object.keys(config.rules).sort( |
|
(a, b) => Object.keys(rulesOrder).indexOf(a) - Object.keys(rulesOrder).indexOf(b), |
|
) |
|
: []; |
|
|
|
rules.forEach((ruleName) => { |
|
const ruleFunction = rulesOrder[ruleName] || get(config, ['pluginFunctions', ruleName]); |
|
|
|
if (ruleFunction === undefined) { |
|
performRules.push( |
|
Promise.all( |
|
postcssRoots.map((postcssRoot) => |
|
reportUnknownRuleNames(ruleName, postcssRoot, postcssResult), |
|
), |
|
), |
|
); |
|
|
|
return; |
|
} |
|
|
|
const ruleSettings = get(config, ['rules', ruleName]); |
|
|
|
if (ruleSettings === null || ruleSettings[0] === null) { |
|
return; |
|
} |
|
|
|
const primaryOption = ruleSettings[0]; |
|
const secondaryOptions = ruleSettings[1]; |
|
|
|
// Log the rule's severity in the PostCSS result |
|
const defaultSeverity = config.defaultSeverity || 'error'; |
|
|
|
postcssResult.stylelint.ruleSeverities[ruleName] = get( |
|
secondaryOptions, |
|
'severity', |
|
defaultSeverity, |
|
); |
|
postcssResult.stylelint.customMessages[ruleName] = get(secondaryOptions, 'message'); |
|
|
|
performRules.push( |
|
Promise.all( |
|
postcssRoots.map((postcssRoot) => |
|
ruleFunction(primaryOption, secondaryOptions, { |
|
fix: |
|
stylelintOptions.fix && |
|
// Next two conditionals are temporary measures until #2643 is resolved |
|
isFileFixCompatible && |
|
!postcssResult.stylelint.disabledRanges[ruleName], |
|
newline, |
|
})(postcssRoot, postcssResult), |
|
), |
|
), |
|
); |
|
}); |
|
|
|
return Promise.all(performRules); |
|
} |
|
|
|
/** |
|
* There are currently some bugs in the autofixer of Stylelint. |
|
* The autofixer does not yet adhere to stylelint-disable comments, so if there are disabled |
|
* ranges we can not autofix this document. More info in issue #2643. |
|
* |
|
* @param {PostcssResult} postcssResult |
|
* @returns {boolean} |
|
*/ |
|
function isFixCompatible({ stylelint }) { |
|
// Check for issue #2643 |
|
if (stylelint.disabledRanges.all.length) return false; |
|
|
|
return true; |
|
} |
|
|
|
module.exports = lintPostcssResult;
|
|
|