.gitignore added
[dotfiles/.git] / .config / coc / extensions / node_modules / coc-prettier / node_modules / stylelint / lib / rules / selector-type-case / index.js
1 "use strict";
2
3 const isKeyframeSelector = require("../../utils/isKeyframeSelector");
4 const isStandardSyntaxRule = require("../../utils/isStandardSyntaxRule");
5 const isStandardSyntaxSelector = require("../../utils/isStandardSyntaxSelector");
6 const isStandardSyntaxTypeSelector = require("../../utils/isStandardSyntaxTypeSelector");
7 const parseSelector = require("../../utils/parseSelector");
8 const report = require("../../utils/report");
9 const ruleMessages = require("../../utils/ruleMessages");
10 const validateOptions = require("../../utils/validateOptions");
11
12 const ruleName = "selector-type-case";
13
14 const messages = ruleMessages(ruleName, {
15   expected: (actual, expected) => `Expected "${actual}" to be "${expected}"`
16 });
17
18 const rule = function(expectation) {
19   return (root, result) => {
20     const validOptions = validateOptions(result, ruleName, {
21       actual: expectation,
22       possible: ["lower", "upper"]
23     });
24     if (!validOptions) {
25       return;
26     }
27
28     root.walkRules(rule => {
29       const selector = rule.selector,
30         selectors = rule.selectors;
31
32       if (!isStandardSyntaxRule(rule)) {
33         return;
34       }
35       if (!isStandardSyntaxSelector(selector)) {
36         return;
37       }
38       if (selectors.some(s => isKeyframeSelector(s))) {
39         return;
40       }
41
42       parseSelector(selector, result, rule, selectorAST => {
43         selectorAST.walkTags(tag => {
44           if (!isStandardSyntaxTypeSelector(tag)) {
45             return;
46           }
47
48           const sourceIndex = tag.sourceIndex,
49             value = tag.value;
50
51           const expectedValue =
52             expectation === "lower" ? value.toLowerCase() : value.toUpperCase();
53
54           if (value === expectedValue) {
55             return;
56           }
57
58           report({
59             message: messages.expected(value, expectedValue),
60             node: rule,
61             index: sourceIndex,
62             ruleName,
63             result
64           });
65         });
66       });
67     });
68   };
69 };
70
71 rule.ruleName = ruleName;
72 rule.messages = messages;
73 module.exports = rule;