"use strict"; const hasBlock = require("../../utils/hasBlock"); const isStandardSyntaxAtRule = require("../../utils/isStandardSyntaxAtRule"); const nextNonCommentNode = require("../../utils/nextNonCommentNode"); const rawNodeString = require("../../utils/rawNodeString"); const report = require("../../utils/report"); const ruleMessages = require("../../utils/ruleMessages"); const validateOptions = require("../../utils/validateOptions"); const whitespaceChecker = require("../../utils/whitespaceChecker"); const ruleName = "at-rule-semicolon-newline-after"; const messages = ruleMessages(ruleName, { expectedAfter: () => 'Expected newline after ";"' }); const rule = function(actual, secondary, context) { const checker = whitespaceChecker("newline", actual, messages); return (root, result) => { const validOptions = validateOptions(result, ruleName, { actual, possible: ["always"] }); if (!validOptions) { return; } root.walkAtRules(atRule => { const nextNode = atRule.next(); if (!nextNode) { return; } if (hasBlock(atRule)) { return; } if (!isStandardSyntaxAtRule(atRule)) { return; } // Allow an end-of-line comment const nodeToCheck = nextNonCommentNode(nextNode); if (!nodeToCheck) { return; } checker.afterOneOnly({ source: rawNodeString(nodeToCheck), index: -1, err: msg => { if (context.fix) { nodeToCheck.raws.before = context.newline + nodeToCheck.raws.before; } else { report({ message: msg, node: atRule, index: atRule.toString().length + 1, result, ruleName }); } } }); }); }; }; rule.ruleName = ruleName; rule.messages = messages; module.exports = rule;