index.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. 'use strict';
  2. const containsString = require('../../utils/containsString');
  3. const matchesStringOrRegExp = require('../../utils/matchesStringOrRegExp');
  4. const report = require('../../utils/report');
  5. const ruleMessages = require('../../utils/ruleMessages');
  6. const validateOptions = require('../../utils/validateOptions');
  7. const { isRegExp, isString } = require('../../utils/validateTypes');
  8. const ruleName = 'comment-word-disallowed-list';
  9. const messages = ruleMessages(ruleName, {
  10. rejected: (pattern) => `Unexpected word matching pattern "${pattern}"`,
  11. });
  12. const meta = {
  13. url: 'https://stylelint.io/user-guide/rules/list/comment-word-disallowed-list',
  14. };
  15. /** @type {import('stylelint').Rule<string | RegExp | Array<string | RegExp>>} */
  16. const rule = (primary) => {
  17. return (root, result) => {
  18. const validOptions = validateOptions(result, ruleName, {
  19. actual: primary,
  20. possible: [isString, isRegExp],
  21. });
  22. if (!validOptions) {
  23. return;
  24. }
  25. root.walkComments((comment) => {
  26. const text = comment.text;
  27. const rawComment = comment.toString();
  28. const firstFourChars = rawComment.slice(0, 4);
  29. // Return early if sourcemap
  30. if (firstFourChars === '/*# ') {
  31. return;
  32. }
  33. const matchesWord = matchesStringOrRegExp(text, primary) || containsString(text, primary);
  34. if (!matchesWord) {
  35. return;
  36. }
  37. report({
  38. message: messages.rejected(matchesWord.pattern),
  39. node: comment,
  40. word: matchesWord.substring,
  41. result,
  42. ruleName,
  43. });
  44. });
  45. };
  46. };
  47. rule.primaryOptionArray = true;
  48. rule.ruleName = ruleName;
  49. rule.messages = messages;
  50. rule.meta = meta;
  51. module.exports = rule;