UNPKG

@stylistic/stylelint-plugin

Version:
75 lines (59 loc) 2.07 kB
import stylelint from "stylelint" import { addNamespace } from "../../utils/addNamespace/index.js" import { getRuleDocUrl } from "../../utils/getRuleDocUrl/index.js" import { isNumber } from "../../utils/validateTypes/index.js" let { utils: { report, ruleMessages, validateOptions } } = stylelint let shortName = `selector-max-empty-lines` export let ruleName = addNamespace(shortName) export let messages = ruleMessages(ruleName, { expected: (max) => `Expected no more than ${max} empty ${max === 1 ? `line` : `lines`}`, }) export let meta = { url: getRuleDocUrl(shortName), fixable: true, } /** @type {import('stylelint').Rule} */ function rule (primary) { let maxAdjacentNewlines = primary + 1 return (root, result) => { let validOptions = validateOptions(result, ruleName, { actual: primary, possible: isNumber, }) if (!validOptions) { return } let violatedCRLFNewLinesRegex = new RegExp(`(?:\r\n){${maxAdjacentNewlines + 1},}`) let violatedLFNewLinesRegex = new RegExp(`\n{${maxAdjacentNewlines + 1},}`) let allowedLFNewLinesString = `\n`.repeat(maxAdjacentNewlines) let allowedCRLFNewLinesString = `\r\n`.repeat(maxAdjacentNewlines) root.walkRules((ruleNode) => { let selector = ruleNode.raws.selector ? ruleNode.raws.selector.raw : ruleNode.selector if (violatedLFNewLinesRegex.test(selector) || violatedCRLFNewLinesRegex.test(selector)) { report({ message: messages.expected, messageArgs: [primary], node: ruleNode, index: 0, endIndex: selector.length, result, ruleName, fix () { let newSelectorString = selector .replace(new RegExp(violatedLFNewLinesRegex, `gm`), allowedLFNewLinesString) .replace(new RegExp(violatedCRLFNewLinesRegex, `gm`), allowedCRLFNewLinesString) if (ruleNode.raws.selector) { ruleNode.raws.selector.raw = newSelectorString } else { ruleNode.selector = newSelectorString } }, }) } }) } } rule.ruleName = ruleName rule.messages = messages rule.meta = meta export default rule