index.js 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  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/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,
  39. messageArgs: [matchesWord.pattern],
  40. node: comment,
  41. word: matchesWord.substring,
  42. result,
  43. ruleName,
  44. });
  45. });
  46. };
  47. };
  48. rule.primaryOptionArray = true;
  49. rule.ruleName = ruleName;
  50. rule.messages = messages;
  51. rule.meta = meta;
  52. module.exports = rule;