123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- '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);
- }
- if (stylelintOptions.ignoreDisables) {
- postcssResult.stylelint.ignoreDisables = true;
- }
- if (stylelintOptions.reportNeedlessDisables) {
- postcssResult.stylelint.reportNeedlessDisables = true;
- }
- const isFileFixCompatible = isFixCompatible(postcssResult);
- if (!isFileFixCompatible) {
- postcssResult.stylelint.disableWritingFix = true;
- }
- const postcssRoots = (postcssDoc &&
- postcssDoc.constructor.name === 'Document'
- ? postcssDoc.nodes
- : [postcssDoc]);
-
-
-
-
- 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];
-
- 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 &&
-
- isFileFixCompatible &&
- !postcssResult.stylelint.disabledRanges[ruleName],
- newline,
- })(postcssRoot, postcssResult),
- ),
- ),
- );
- });
- return Promise.all(performRules);
- }
- function isFixCompatible({ stylelint }) {
-
- if (stylelint.disabledRanges.all.length) return false;
- return true;
- }
- module.exports = lintPostcssResult;
|