eslint-plugin-stylelint-2 1.0.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (268) hide show
  1. package/CHANGELOG.md +329 -0
  2. package/LICENSE +21 -0
  3. package/README.md +174 -0
  4. package/dist/_internal/rule-docs-url.d.ts +15 -0
  5. package/dist/_internal/rule-docs-url.d.ts.map +1 -0
  6. package/dist/_internal/rule-docs-url.js +15 -0
  7. package/dist/_internal/rule-docs-url.js.map +1 -0
  8. package/dist/_internal/rules-registry.d.ts +88 -0
  9. package/dist/_internal/rules-registry.d.ts.map +1 -0
  10. package/dist/_internal/rules-registry.js +85 -0
  11. package/dist/_internal/rules-registry.js.map +1 -0
  12. package/dist/_internal/stylelint-config-boolean-option-rule.d.ts +17 -0
  13. package/dist/_internal/stylelint-config-boolean-option-rule.d.ts.map +1 -0
  14. package/dist/_internal/stylelint-config-boolean-option-rule.js +90 -0
  15. package/dist/_internal/stylelint-config-boolean-option-rule.js.map +1 -0
  16. package/dist/_internal/stylelint-config-disallowed-option-rule.d.ts +16 -0
  17. package/dist/_internal/stylelint-config-disallowed-option-rule.d.ts.map +1 -0
  18. package/dist/_internal/stylelint-config-disallowed-option-rule.js +48 -0
  19. package/dist/_internal/stylelint-config-disallowed-option-rule.js.map +1 -0
  20. package/dist/_internal/stylelint-config-object.d.ts +62 -0
  21. package/dist/_internal/stylelint-config-object.d.ts.map +1 -0
  22. package/dist/_internal/stylelint-config-object.js +114 -0
  23. package/dist/_internal/stylelint-config-object.js.map +1 -0
  24. package/dist/_internal/stylelint-config-package-option-rule.d.ts +12 -0
  25. package/dist/_internal/stylelint-config-package-option-rule.d.ts.map +1 -0
  26. package/dist/_internal/stylelint-config-package-option-rule.js +66 -0
  27. package/dist/_internal/stylelint-config-package-option-rule.js.map +1 -0
  28. package/dist/_internal/stylelint-config-rules-object.d.ts +23 -0
  29. package/dist/_internal/stylelint-config-rules-object.d.ts.map +1 -0
  30. package/dist/_internal/stylelint-config-rules-object.js +47 -0
  31. package/dist/_internal/stylelint-config-rules-object.js.map +1 -0
  32. package/dist/_internal/stylelint-config-string-array-option-rule.d.ts +27 -0
  33. package/dist/_internal/stylelint-config-string-array-option-rule.d.ts.map +1 -0
  34. package/dist/_internal/stylelint-config-string-array-option-rule.js +234 -0
  35. package/dist/_internal/stylelint-config-string-array-option-rule.js.map +1 -0
  36. package/dist/_internal/stylelint-config-string-array-option.d.ts +32 -0
  37. package/dist/_internal/stylelint-config-string-array-option.d.ts.map +1 -0
  38. package/dist/_internal/stylelint-config-string-array-option.js +55 -0
  39. package/dist/_internal/stylelint-config-string-array-option.js.map +1 -0
  40. package/dist/_internal/stylelint-package-dependencies.d.ts +18 -0
  41. package/dist/_internal/stylelint-package-dependencies.d.ts.map +1 -0
  42. package/dist/_internal/stylelint-package-dependencies.js +107 -0
  43. package/dist/_internal/stylelint-package-dependencies.js.map +1 -0
  44. package/dist/_internal/stylelint-runner.d.ts +4 -0
  45. package/dist/_internal/stylelint-runner.d.ts.map +1 -0
  46. package/dist/_internal/stylelint-runner.js +93 -0
  47. package/dist/_internal/stylelint-runner.js.map +1 -0
  48. package/dist/_internal/stylelint-worker-types.d.ts +70 -0
  49. package/dist/_internal/stylelint-worker-types.d.ts.map +1 -0
  50. package/dist/_internal/stylelint-worker-types.js +2 -0
  51. package/dist/_internal/stylelint-worker-types.js.map +1 -0
  52. package/dist/_internal/stylelint-worker.d.ts +2 -0
  53. package/dist/_internal/stylelint-worker.d.ts.map +1 -0
  54. package/dist/_internal/stylelint-worker.js +113 -0
  55. package/dist/_internal/stylelint-worker.js.map +1 -0
  56. package/dist/_internal/stylelint2-config-references.d.ts +32 -0
  57. package/dist/_internal/stylelint2-config-references.d.ts.map +1 -0
  58. package/dist/_internal/stylelint2-config-references.js +65 -0
  59. package/dist/_internal/stylelint2-config-references.js.map +1 -0
  60. package/dist/_internal/typed-rule.d.ts +42 -0
  61. package/dist/_internal/typed-rule.d.ts.map +1 -0
  62. package/dist/_internal/typed-rule.js +53 -0
  63. package/dist/_internal/typed-rule.js.map +1 -0
  64. package/dist/plugin.cjs +1 -0
  65. package/dist/plugin.d.cts +10 -0
  66. package/dist/plugin.d.ts +36 -0
  67. package/dist/plugin.d.ts.map +1 -0
  68. package/dist/plugin.js +183 -0
  69. package/dist/plugin.js.map +1 -0
  70. package/dist/rules/disallow-stylelint-allow-empty-input.d.ts +9 -0
  71. package/dist/rules/disallow-stylelint-allow-empty-input.d.ts.map +1 -0
  72. package/dist/rules/disallow-stylelint-allow-empty-input.js +29 -0
  73. package/dist/rules/disallow-stylelint-allow-empty-input.js.map +1 -0
  74. package/dist/rules/disallow-stylelint-configuration-comment.d.ts +9 -0
  75. package/dist/rules/disallow-stylelint-configuration-comment.d.ts.map +1 -0
  76. package/dist/rules/disallow-stylelint-configuration-comment.js +29 -0
  77. package/dist/rules/disallow-stylelint-configuration-comment.js.map +1 -0
  78. package/dist/rules/disallow-stylelint-custom-syntax.d.ts +12 -0
  79. package/dist/rules/disallow-stylelint-custom-syntax.d.ts.map +1 -0
  80. package/dist/rules/disallow-stylelint-custom-syntax.js +32 -0
  81. package/dist/rules/disallow-stylelint-custom-syntax.js.map +1 -0
  82. package/dist/rules/disallow-stylelint-default-severity.d.ts +9 -0
  83. package/dist/rules/disallow-stylelint-default-severity.d.ts.map +1 -0
  84. package/dist/rules/disallow-stylelint-default-severity.js +28 -0
  85. package/dist/rules/disallow-stylelint-default-severity.js.map +1 -0
  86. package/dist/rules/disallow-stylelint-duplicate-extends.d.ts +9 -0
  87. package/dist/rules/disallow-stylelint-duplicate-extends.d.ts.map +1 -0
  88. package/dist/rules/disallow-stylelint-duplicate-extends.js +29 -0
  89. package/dist/rules/disallow-stylelint-duplicate-extends.js.map +1 -0
  90. package/dist/rules/disallow-stylelint-duplicate-plugins.d.ts +9 -0
  91. package/dist/rules/disallow-stylelint-duplicate-plugins.d.ts.map +1 -0
  92. package/dist/rules/disallow-stylelint-duplicate-plugins.js +29 -0
  93. package/dist/rules/disallow-stylelint-duplicate-plugins.js.map +1 -0
  94. package/dist/rules/disallow-stylelint-duplicate-rule-option-values.d.ts +10 -0
  95. package/dist/rules/disallow-stylelint-duplicate-rule-option-values.d.ts.map +1 -0
  96. package/dist/rules/disallow-stylelint-duplicate-rule-option-values.js +171 -0
  97. package/dist/rules/disallow-stylelint-duplicate-rule-option-values.js.map +1 -0
  98. package/dist/rules/disallow-stylelint-empty-rules-object.d.ts +7 -0
  99. package/dist/rules/disallow-stylelint-empty-rules-object.d.ts.map +1 -0
  100. package/dist/rules/disallow-stylelint-empty-rules-object.js +65 -0
  101. package/dist/rules/disallow-stylelint-empty-rules-object.js.map +1 -0
  102. package/dist/rules/disallow-stylelint-ignore-disables.d.ts +9 -0
  103. package/dist/rules/disallow-stylelint-ignore-disables.d.ts.map +1 -0
  104. package/dist/rules/disallow-stylelint-ignore-disables.js +28 -0
  105. package/dist/rules/disallow-stylelint-ignore-disables.js.map +1 -0
  106. package/dist/rules/disallow-stylelint-ignore-files.d.ts +9 -0
  107. package/dist/rules/disallow-stylelint-ignore-files.d.ts.map +1 -0
  108. package/dist/rules/disallow-stylelint-ignore-files.js +28 -0
  109. package/dist/rules/disallow-stylelint-ignore-files.js.map +1 -0
  110. package/dist/rules/disallow-stylelint-null-rule-config.d.ts +7 -0
  111. package/dist/rules/disallow-stylelint-null-rule-config.d.ts.map +1 -0
  112. package/dist/rules/disallow-stylelint-null-rule-config.js +86 -0
  113. package/dist/rules/disallow-stylelint-null-rule-config.js.map +1 -0
  114. package/dist/rules/disallow-stylelint-overrides-runtime-options.d.ts +7 -0
  115. package/dist/rules/disallow-stylelint-overrides-runtime-options.d.ts.map +1 -0
  116. package/dist/rules/disallow-stylelint-overrides-runtime-options.js +124 -0
  117. package/dist/rules/disallow-stylelint-overrides-runtime-options.js.map +1 -0
  118. package/dist/rules/disallow-stylelint-processors.d.ts +9 -0
  119. package/dist/rules/disallow-stylelint-processors.d.ts.map +1 -0
  120. package/dist/rules/disallow-stylelint-processors.js +29 -0
  121. package/dist/rules/disallow-stylelint-processors.js.map +1 -0
  122. package/dist/rules/disallow-stylelint-relative-extends-paths.d.ts +9 -0
  123. package/dist/rules/disallow-stylelint-relative-extends-paths.d.ts.map +1 -0
  124. package/dist/rules/disallow-stylelint-relative-extends-paths.js +28 -0
  125. package/dist/rules/disallow-stylelint-relative-extends-paths.js.map +1 -0
  126. package/dist/rules/disallow-stylelint-relative-plugin-paths.d.ts +9 -0
  127. package/dist/rules/disallow-stylelint-relative-plugin-paths.d.ts.map +1 -0
  128. package/dist/rules/disallow-stylelint-relative-plugin-paths.js +28 -0
  129. package/dist/rules/disallow-stylelint-relative-plugin-paths.js.map +1 -0
  130. package/dist/rules/prefer-stylelint-cache.d.ts +9 -0
  131. package/dist/rules/prefer-stylelint-cache.d.ts.map +1 -0
  132. package/dist/rules/prefer-stylelint-cache.js +28 -0
  133. package/dist/rules/prefer-stylelint-cache.js.map +1 -0
  134. package/dist/rules/prefer-stylelint-define-config.d.ts +7 -0
  135. package/dist/rules/prefer-stylelint-define-config.d.ts.map +1 -0
  136. package/dist/rules/prefer-stylelint-define-config.js +82 -0
  137. package/dist/rules/prefer-stylelint-define-config.js.map +1 -0
  138. package/dist/rules/prefer-stylelint-extends-array.d.ts +9 -0
  139. package/dist/rules/prefer-stylelint-extends-array.d.ts.map +1 -0
  140. package/dist/rules/prefer-stylelint-extends-array.js +29 -0
  141. package/dist/rules/prefer-stylelint-extends-array.js.map +1 -0
  142. package/dist/rules/prefer-stylelint-fix.d.ts +7 -0
  143. package/dist/rules/prefer-stylelint-fix.d.ts.map +1 -0
  144. package/dist/rules/prefer-stylelint-fix.js +90 -0
  145. package/dist/rules/prefer-stylelint-fix.js.map +1 -0
  146. package/dist/rules/prefer-stylelint-formatter.d.ts +10 -0
  147. package/dist/rules/prefer-stylelint-formatter.d.ts.map +1 -0
  148. package/dist/rules/prefer-stylelint-formatter.js +77 -0
  149. package/dist/rules/prefer-stylelint-formatter.js.map +1 -0
  150. package/dist/rules/prefer-stylelint-plugins-array.d.ts +9 -0
  151. package/dist/rules/prefer-stylelint-plugins-array.d.ts.map +1 -0
  152. package/dist/rules/prefer-stylelint-plugins-array.js +29 -0
  153. package/dist/rules/prefer-stylelint-plugins-array.js.map +1 -0
  154. package/dist/rules/prefer-stylelint-report-descriptionless-disables.d.ts +12 -0
  155. package/dist/rules/prefer-stylelint-report-descriptionless-disables.d.ts.map +1 -0
  156. package/dist/rules/prefer-stylelint-report-descriptionless-disables.js +32 -0
  157. package/dist/rules/prefer-stylelint-report-descriptionless-disables.js.map +1 -0
  158. package/dist/rules/prefer-stylelint-report-invalid-scope-disables.d.ts +12 -0
  159. package/dist/rules/prefer-stylelint-report-invalid-scope-disables.d.ts.map +1 -0
  160. package/dist/rules/prefer-stylelint-report-invalid-scope-disables.js +32 -0
  161. package/dist/rules/prefer-stylelint-report-invalid-scope-disables.js.map +1 -0
  162. package/dist/rules/prefer-stylelint-report-needless-disables.d.ts +9 -0
  163. package/dist/rules/prefer-stylelint-report-needless-disables.d.ts.map +1 -0
  164. package/dist/rules/prefer-stylelint-report-needless-disables.js +29 -0
  165. package/dist/rules/prefer-stylelint-report-needless-disables.js.map +1 -0
  166. package/dist/rules/prefer-stylelint-report-unscoped-disables.d.ts +9 -0
  167. package/dist/rules/prefer-stylelint-report-unscoped-disables.d.ts.map +1 -0
  168. package/dist/rules/prefer-stylelint-report-unscoped-disables.js +29 -0
  169. package/dist/rules/prefer-stylelint-report-unscoped-disables.js.map +1 -0
  170. package/dist/rules/require-stylelint-config-file-naming-convention.d.ts +13 -0
  171. package/dist/rules/require-stylelint-config-file-naming-convention.d.ts.map +1 -0
  172. package/dist/rules/require-stylelint-config-file-naming-convention.js +58 -0
  173. package/dist/rules/require-stylelint-config-file-naming-convention.js.map +1 -0
  174. package/dist/rules/require-stylelint-custom-syntax-in-overrides.d.ts +7 -0
  175. package/dist/rules/require-stylelint-custom-syntax-in-overrides.d.ts.map +1 -0
  176. package/dist/rules/require-stylelint-custom-syntax-in-overrides.js +100 -0
  177. package/dist/rules/require-stylelint-custom-syntax-in-overrides.js.map +1 -0
  178. package/dist/rules/require-stylelint-extends-packages-installed.d.ts +12 -0
  179. package/dist/rules/require-stylelint-extends-packages-installed.d.ts.map +1 -0
  180. package/dist/rules/require-stylelint-extends-packages-installed.js +31 -0
  181. package/dist/rules/require-stylelint-extends-packages-installed.js.map +1 -0
  182. package/dist/rules/require-stylelint-overrides-configuration.d.ts +7 -0
  183. package/dist/rules/require-stylelint-overrides-configuration.d.ts.map +1 -0
  184. package/dist/rules/require-stylelint-overrides-configuration.js +100 -0
  185. package/dist/rules/require-stylelint-overrides-configuration.js.map +1 -0
  186. package/dist/rules/require-stylelint-overrides-files-array.d.ts +7 -0
  187. package/dist/rules/require-stylelint-overrides-files-array.d.ts.map +1 -0
  188. package/dist/rules/require-stylelint-overrides-files-array.js +99 -0
  189. package/dist/rules/require-stylelint-overrides-files-array.js.map +1 -0
  190. package/dist/rules/require-stylelint-overrides-files.d.ts +7 -0
  191. package/dist/rules/require-stylelint-overrides-files.d.ts.map +1 -0
  192. package/dist/rules/require-stylelint-overrides-files.js +104 -0
  193. package/dist/rules/require-stylelint-overrides-files.js.map +1 -0
  194. package/dist/rules/require-stylelint-plugins-packages-installed.d.ts +12 -0
  195. package/dist/rules/require-stylelint-plugins-packages-installed.d.ts.map +1 -0
  196. package/dist/rules/require-stylelint-plugins-packages-installed.js +31 -0
  197. package/dist/rules/require-stylelint-plugins-packages-installed.js.map +1 -0
  198. package/dist/rules/require-stylelint-report-disables.d.ts +9 -0
  199. package/dist/rules/require-stylelint-report-disables.d.ts.map +1 -0
  200. package/dist/rules/require-stylelint-report-disables.js +29 -0
  201. package/dist/rules/require-stylelint-report-disables.js.map +1 -0
  202. package/dist/rules/require-stylelint-rules-object.d.ts +7 -0
  203. package/dist/rules/require-stylelint-rules-object.d.ts.map +1 -0
  204. package/dist/rules/require-stylelint-rules-object.js +65 -0
  205. package/dist/rules/require-stylelint-rules-object.js.map +1 -0
  206. package/dist/rules/sort-stylelint-extends.d.ts +9 -0
  207. package/dist/rules/sort-stylelint-extends.d.ts.map +1 -0
  208. package/dist/rules/sort-stylelint-extends.js +28 -0
  209. package/dist/rules/sort-stylelint-extends.js.map +1 -0
  210. package/dist/rules/sort-stylelint-plugins.d.ts +9 -0
  211. package/dist/rules/sort-stylelint-plugins.d.ts.map +1 -0
  212. package/dist/rules/sort-stylelint-plugins.js +28 -0
  213. package/dist/rules/sort-stylelint-plugins.js.map +1 -0
  214. package/dist/rules/sort-stylelint-rule-keys.d.ts +7 -0
  215. package/dist/rules/sort-stylelint-rule-keys.d.ts.map +1 -0
  216. package/dist/rules/sort-stylelint-rule-keys.js +129 -0
  217. package/dist/rules/sort-stylelint-rule-keys.js.map +1 -0
  218. package/dist/rules/stylelint.d.ts +15 -0
  219. package/dist/rules/stylelint.d.ts.map +1 -0
  220. package/dist/rules/stylelint.js +157 -0
  221. package/dist/rules/stylelint.js.map +1 -0
  222. package/docs/rules/disallow-stylelint-allow-empty-input.md +62 -0
  223. package/docs/rules/disallow-stylelint-configuration-comment.md +62 -0
  224. package/docs/rules/disallow-stylelint-custom-syntax.md +70 -0
  225. package/docs/rules/disallow-stylelint-default-severity.md +77 -0
  226. package/docs/rules/disallow-stylelint-duplicate-extends.md +61 -0
  227. package/docs/rules/disallow-stylelint-duplicate-plugins.md +61 -0
  228. package/docs/rules/disallow-stylelint-duplicate-rule-option-values.md +73 -0
  229. package/docs/rules/disallow-stylelint-empty-rules-object.md +62 -0
  230. package/docs/rules/disallow-stylelint-ignore-disables.md +78 -0
  231. package/docs/rules/disallow-stylelint-ignore-files.md +78 -0
  232. package/docs/rules/disallow-stylelint-null-rule-config.md +63 -0
  233. package/docs/rules/disallow-stylelint-overrides-runtime-options.md +82 -0
  234. package/docs/rules/disallow-stylelint-processors.md +62 -0
  235. package/docs/rules/disallow-stylelint-relative-extends-paths.md +61 -0
  236. package/docs/rules/disallow-stylelint-relative-plugin-paths.md +61 -0
  237. package/docs/rules/getting-started.md +130 -0
  238. package/docs/rules/overview.md +99 -0
  239. package/docs/rules/prefer-stylelint-cache.md +79 -0
  240. package/docs/rules/prefer-stylelint-define-config.md +90 -0
  241. package/docs/rules/prefer-stylelint-extends-array.md +61 -0
  242. package/docs/rules/prefer-stylelint-fix.md +79 -0
  243. package/docs/rules/prefer-stylelint-formatter.md +80 -0
  244. package/docs/rules/prefer-stylelint-plugins-array.md +61 -0
  245. package/docs/rules/prefer-stylelint-report-descriptionless-disables.md +85 -0
  246. package/docs/rules/prefer-stylelint-report-invalid-scope-disables.md +83 -0
  247. package/docs/rules/prefer-stylelint-report-needless-disables.md +83 -0
  248. package/docs/rules/prefer-stylelint-report-unscoped-disables.md +83 -0
  249. package/docs/rules/presets/all.md +39 -0
  250. package/docs/rules/presets/configs.md +40 -0
  251. package/docs/rules/presets/configuration.md +64 -0
  252. package/docs/rules/presets/index.md +82 -0
  253. package/docs/rules/presets/recommended.md +40 -0
  254. package/docs/rules/presets/stylelint-only.md +42 -0
  255. package/docs/rules/require-stylelint-config-file-naming-convention.md +61 -0
  256. package/docs/rules/require-stylelint-custom-syntax-in-overrides.md +77 -0
  257. package/docs/rules/require-stylelint-extends-packages-installed.md +61 -0
  258. package/docs/rules/require-stylelint-overrides-configuration.md +80 -0
  259. package/docs/rules/require-stylelint-overrides-files-array.md +78 -0
  260. package/docs/rules/require-stylelint-overrides-files.md +83 -0
  261. package/docs/rules/require-stylelint-plugins-packages-installed.md +61 -0
  262. package/docs/rules/require-stylelint-report-disables.md +67 -0
  263. package/docs/rules/require-stylelint-rules-object.md +61 -0
  264. package/docs/rules/sort-stylelint-extends.md +61 -0
  265. package/docs/rules/sort-stylelint-plugins.md +61 -0
  266. package/docs/rules/sort-stylelint-rule-keys.md +65 -0
  267. package/docs/rules/stylelint.md +100 -0
  268. package/package.json +577 -0
@@ -0,0 +1,99 @@
1
+ import { getExportedStylelintConfigObject, getObjectPropertyByName, isStylelintConfigFile, } from "../_internal/stylelint-config-object.js";
2
+ import { createTypedRule, toRuleListener } from "../_internal/typed-rule.js";
3
+ const isPropertyExpressionValue = (value) => value.type !== "ArrayPattern" &&
4
+ value.type !== "AssignmentPattern" &&
5
+ value.type !== "ObjectPattern" &&
6
+ value.type !== "TSEmptyBodyFunctionExpression";
7
+ const isNonEmptyStringLiteralElement = (element) => element !== null &&
8
+ element.type === "Literal" &&
9
+ typeof element.value === "string" &&
10
+ element.value.trim().length > 0;
11
+ const hasStrictFilesArrayShape = (expression) => {
12
+ if (expression.type !== "ArrayExpression") {
13
+ return false;
14
+ }
15
+ if (expression.elements.length === 0) {
16
+ return false;
17
+ }
18
+ for (const element of expression.elements) {
19
+ if (isNonEmptyStringLiteralElement(element)) {
20
+ continue;
21
+ }
22
+ return false;
23
+ }
24
+ return true;
25
+ };
26
+ /** Rule module enforcing array-only override file globs with explicit strings. */
27
+ const requireStylelintOverridesFilesArrayRule = createTypedRule({
28
+ create(context) {
29
+ if (!isStylelintConfigFile(context.physicalFilename)) {
30
+ return {};
31
+ }
32
+ return toRuleListener({
33
+ ExportDefaultDeclaration(node) {
34
+ if (node === null || typeof node !== "object") {
35
+ return;
36
+ }
37
+ const exportDefaultNode = node;
38
+ const configObject = getExportedStylelintConfigObject(exportDefaultNode.declaration);
39
+ if (configObject === undefined) {
40
+ return;
41
+ }
42
+ const overridesProperty = getObjectPropertyByName(configObject, "overrides");
43
+ if (overridesProperty === undefined) {
44
+ return;
45
+ }
46
+ const overridesPropertyValue = overridesProperty.value;
47
+ if (!isPropertyExpressionValue(overridesPropertyValue)) {
48
+ return;
49
+ }
50
+ if (overridesPropertyValue.type !== "ArrayExpression") {
51
+ return;
52
+ }
53
+ for (const overrideEntry of overridesPropertyValue.elements) {
54
+ if (overrideEntry?.type !== "ObjectExpression") {
55
+ continue;
56
+ }
57
+ const filesProperty = getObjectPropertyByName(overrideEntry, "files");
58
+ if (filesProperty === undefined) {
59
+ continue;
60
+ }
61
+ const filesPropertyValue = filesProperty.value;
62
+ if (!isPropertyExpressionValue(filesPropertyValue)) {
63
+ continue;
64
+ }
65
+ if (hasStrictFilesArrayShape(filesPropertyValue)) {
66
+ continue;
67
+ }
68
+ context.report({
69
+ messageId: "requireOverrideFilesArray",
70
+ node: filesProperty,
71
+ });
72
+ }
73
+ },
74
+ });
75
+ },
76
+ meta: {
77
+ deprecated: false,
78
+ docs: {
79
+ configs: [
80
+ "stylelint2.configs.recommended",
81
+ "stylelint2.configs.configuration",
82
+ "stylelint2.configs.all",
83
+ ],
84
+ description: "require Stylelint override `files` declarations to be explicit non-empty arrays of glob strings.",
85
+ frozen: false,
86
+ recommended: true,
87
+ requiresTypeChecking: false,
88
+ url: "https://nick2bad4u.github.io/eslint-plugin-stylelint-2/docs/rules/require-stylelint-overrides-files-array",
89
+ },
90
+ messages: {
91
+ requireOverrideFilesArray: 'Stylelint override `files` must be a non-empty array of non-empty glob strings (for example `["**/*.scss"]`).',
92
+ },
93
+ schema: [],
94
+ type: "suggestion",
95
+ },
96
+ name: "require-stylelint-overrides-files-array",
97
+ });
98
+ export default requireStylelintOverridesFilesArrayRule;
99
+ //# sourceMappingURL=require-stylelint-overrides-files-array.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-stylelint-overrides-files-array.js","sourceRoot":"","sources":["../../src/rules/require-stylelint-overrides-files-array.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import type { RuleModuleWithDocs } from "../_internal/typed-rule.js";
2
+ type MessageIds = "requireOverrideFiles";
3
+ type Options = readonly [];
4
+ /** Rule module that requires non-empty `files` in each Stylelint override. */
5
+ declare const requireStylelintOverridesFilesRule: RuleModuleWithDocs<MessageIds, Options>;
6
+ export default requireStylelintOverridesFilesRule;
7
+ //# sourceMappingURL=require-stylelint-overrides-files.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-stylelint-overrides-files.d.ts","sourceRoot":"","sources":["../../src/rules/require-stylelint-overrides-files.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AASrE,KAAK,UAAU,GAAG,sBAAsB,CAAC;AACzC,KAAK,OAAO,GAAG,SAAS,EAAE,CAAC;AA0C3B,8EAA8E;AAC9E,QAAA,MAAM,kCAAkC,EAAE,kBAAkB,CACxD,UAAU,EACV,OAAO,CAqGT,CAAC;AAEH,eAAe,kCAAkC,CAAC"}
@@ -0,0 +1,104 @@
1
+ import { getExportedStylelintConfigObject, getObjectPropertyByName, isStylelintConfigFile, } from "../_internal/stylelint-config-object.js";
2
+ import { createTypedRule, toRuleListener } from "../_internal/typed-rule.js";
3
+ const isPropertyExpressionValue = (value) => value.type !== "ArrayPattern" &&
4
+ value.type !== "AssignmentPattern" &&
5
+ value.type !== "ObjectPattern" &&
6
+ value.type !== "TSEmptyBodyFunctionExpression";
7
+ const isNonEmptyStringLiteral = (expression) => expression.type === "Literal" &&
8
+ typeof expression.value === "string" &&
9
+ expression.value.trim().length > 0;
10
+ const hasNonEmptyFilesMatcher = (expression) => {
11
+ if (isNonEmptyStringLiteral(expression)) {
12
+ return true;
13
+ }
14
+ if (expression.type !== "ArrayExpression") {
15
+ return false;
16
+ }
17
+ for (const element of expression.elements) {
18
+ if (element !== null &&
19
+ element.type === "Literal" &&
20
+ typeof element.value === "string" &&
21
+ element.value.trim().length > 0) {
22
+ return true;
23
+ }
24
+ }
25
+ return false;
26
+ };
27
+ /** Rule module that requires non-empty `files` in each Stylelint override. */
28
+ const requireStylelintOverridesFilesRule = createTypedRule({
29
+ create(context) {
30
+ if (!isStylelintConfigFile(context.physicalFilename)) {
31
+ return {};
32
+ }
33
+ return toRuleListener({
34
+ ExportDefaultDeclaration(node) {
35
+ if (node === null || typeof node !== "object") {
36
+ return;
37
+ }
38
+ const exportDefaultNode = node;
39
+ const configObject = getExportedStylelintConfigObject(exportDefaultNode.declaration);
40
+ if (configObject === undefined) {
41
+ return;
42
+ }
43
+ const overridesProperty = getObjectPropertyByName(configObject, "overrides");
44
+ if (overridesProperty === undefined) {
45
+ return;
46
+ }
47
+ const overridesPropertyValue = overridesProperty.value;
48
+ if (!isPropertyExpressionValue(overridesPropertyValue)) {
49
+ return;
50
+ }
51
+ if (overridesPropertyValue.type !== "ArrayExpression") {
52
+ return;
53
+ }
54
+ for (const element of overridesPropertyValue.elements) {
55
+ if (element?.type !== "ObjectExpression") {
56
+ continue;
57
+ }
58
+ const filesProperty = getObjectPropertyByName(element, "files");
59
+ if (filesProperty === undefined) {
60
+ context.report({
61
+ messageId: "requireOverrideFiles",
62
+ node: element,
63
+ });
64
+ continue;
65
+ }
66
+ const filesPropertyValue = filesProperty.value;
67
+ if (!isPropertyExpressionValue(filesPropertyValue)) {
68
+ continue;
69
+ }
70
+ if (hasNonEmptyFilesMatcher(filesPropertyValue)) {
71
+ continue;
72
+ }
73
+ context.report({
74
+ messageId: "requireOverrideFiles",
75
+ node: filesProperty,
76
+ });
77
+ }
78
+ },
79
+ });
80
+ },
81
+ meta: {
82
+ deprecated: false,
83
+ docs: {
84
+ configs: [
85
+ "stylelint2.configs.recommended",
86
+ "stylelint2.configs.configuration",
87
+ "stylelint2.configs.all",
88
+ ],
89
+ description: "require every Stylelint override entry to declare non-empty `files` matchers.",
90
+ frozen: false,
91
+ recommended: true,
92
+ requiresTypeChecking: false,
93
+ url: "https://nick2bad4u.github.io/eslint-plugin-stylelint-2/docs/rules/require-stylelint-overrides-files",
94
+ },
95
+ messages: {
96
+ requireOverrideFiles: "Each Stylelint `overrides` entry must define a non-empty `files` matcher so override scope is explicit.",
97
+ },
98
+ schema: [],
99
+ type: "suggestion",
100
+ },
101
+ name: "require-stylelint-overrides-files",
102
+ });
103
+ export default requireStylelintOverridesFilesRule;
104
+ //# sourceMappingURL=require-stylelint-overrides-files.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-stylelint-overrides-files.js","sourceRoot":"","sources":["../../src/rules/require-stylelint-overrides-files.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * @packageDocumentation
3
+ * Require Stylelint plugins package specifiers to resolve from dependencies.
4
+ */
5
+ import type { RuleModuleWithDocs } from "../_internal/typed-rule.js";
6
+ /**
7
+ * Rule module that requires package-backed `plugins` entries to exist in
8
+ * workspace dependencies.
9
+ */
10
+ declare const requireStylelintPluginsPackagesInstalledRule: RuleModuleWithDocs<"requireInstalledPackage", readonly []>;
11
+ export default requireStylelintPluginsPackagesInstalledRule;
12
+ //# sourceMappingURL=require-stylelint-plugins-packages-installed.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-stylelint-plugins-packages-installed.d.ts","sourceRoot":"","sources":["../../src/rules/require-stylelint-plugins-packages-installed.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAIrE;;;GAGG;AACH,QAAA,MAAM,4CAA4C,EAAE,kBAAkB,CAClE,yBAAyB,EACzB,SAAS,EAAE,CA0Bb,CAAC;AAEH,eAAe,4CAA4C,CAAC"}
@@ -0,0 +1,31 @@
1
+ import { createStylelintConfigRequireInstalledPackageOptionRule } from "../_internal/stylelint-config-package-option-rule.js";
2
+ /**
3
+ * Rule module that requires package-backed `plugins` entries to exist in
4
+ * workspace dependencies.
5
+ */
6
+ const requireStylelintPluginsPackagesInstalledRule = createStylelintConfigRequireInstalledPackageOptionRule({
7
+ meta: {
8
+ deprecated: false,
9
+ docs: {
10
+ configs: [
11
+ "stylelint2.configs.recommended",
12
+ "stylelint2.configs.configuration",
13
+ "stylelint2.configs.all",
14
+ ],
15
+ description: "require top-level Stylelint `plugins` package specifiers to be listed in workspace dependencies.",
16
+ frozen: false,
17
+ recommended: true,
18
+ requiresTypeChecking: false,
19
+ url: "https://nick2bad4u.github.io/eslint-plugin-stylelint-2/docs/rules/require-stylelint-plugins-packages-installed",
20
+ },
21
+ messages: {
22
+ requireInstalledPackage: "Add `{{packageName}}` to dependencies for this shared config, or remove the unresolved `plugins` reference.",
23
+ },
24
+ schema: [],
25
+ type: "problem",
26
+ },
27
+ name: "require-stylelint-plugins-packages-installed",
28
+ optionName: "plugins",
29
+ });
30
+ export default requireStylelintPluginsPackagesInstalledRule;
31
+ //# sourceMappingURL=require-stylelint-plugins-packages-installed.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-stylelint-plugins-packages-installed.js","sourceRoot":"","sources":["../../src/rules/require-stylelint-plugins-packages-installed.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,sDAAsD,EAAE,MAAM,sDAAsD,CAAC;AAE9H;;;GAGG;AACH,MAAM,4CAA4C,GAG9C,sDAAsD,CAAC;IACvD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,OAAO,EAAE;gBACL,gCAAgC;gBAChC,kCAAkC;gBAClC,wBAAwB;aAC3B;YACD,WAAW,EACP,kGAAkG;YACtG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,gHAAgH;SACxH;QACD,QAAQ,EAAE;YACN,uBAAuB,EACnB,6GAA6G;SACpH;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,8CAA8C;IACpD,UAAU,EAAE,SAAS;CACxB,CAAC,CAAC;AAEH,eAAe,4CAA4C,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * @packageDocumentation
3
+ * Require top-level Stylelint reportDisables configuration in authored config files.
4
+ */
5
+ import type { RuleModuleWithDocs } from "../_internal/typed-rule.js";
6
+ /** Rule module that requires `reportDisables: true` in Stylelint config files. */
7
+ declare const requireStylelintReportDisablesRule: RuleModuleWithDocs<"requireConfigOption", readonly []>;
8
+ export default requireStylelintReportDisablesRule;
9
+ //# sourceMappingURL=require-stylelint-report-disables.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-stylelint-report-disables.d.ts","sourceRoot":"","sources":["../../src/rules/require-stylelint-report-disables.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAIrE,kFAAkF;AAClF,QAAA,MAAM,kCAAkC,EAAE,kBAAkB,CACxD,qBAAqB,EACrB,SAAS,EAAE,CA2Bb,CAAC;AAEH,eAAe,kCAAkC,CAAC"}
@@ -0,0 +1,29 @@
1
+ import { createStylelintConfigBooleanOptionRule } from "../_internal/stylelint-config-boolean-option-rule.js";
2
+ /** Rule module that requires `reportDisables: true` in Stylelint config files. */
3
+ const requireStylelintReportDisablesRule = createStylelintConfigBooleanOptionRule({
4
+ meta: {
5
+ deprecated: false,
6
+ docs: {
7
+ configs: [
8
+ "stylelint2.configs.recommended",
9
+ "stylelint2.configs.configuration",
10
+ "stylelint2.configs.all",
11
+ ],
12
+ description: "require `reportDisables: true` in authored Stylelint config files.",
13
+ frozen: false,
14
+ recommended: true,
15
+ requiresTypeChecking: false,
16
+ url: "https://nick2bad4u.github.io/eslint-plugin-stylelint-2/docs/rules/require-stylelint-report-disables",
17
+ },
18
+ fixable: "code",
19
+ messages: {
20
+ requireConfigOption: "Enable `reportDisables: true` so disable-comment usage remains visible and reviewable.",
21
+ },
22
+ schema: [],
23
+ type: "suggestion",
24
+ },
25
+ name: "require-stylelint-report-disables",
26
+ optionName: "reportDisables",
27
+ });
28
+ export default requireStylelintReportDisablesRule;
29
+ //# sourceMappingURL=require-stylelint-report-disables.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-stylelint-report-disables.js","sourceRoot":"","sources":["../../src/rules/require-stylelint-report-disables.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,sCAAsC,EAAE,MAAM,sDAAsD,CAAC;AAE9G,kFAAkF;AAClF,MAAM,kCAAkC,GAGpC,sCAAsC,CAAC;IACvC,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,OAAO,EAAE;gBACL,gCAAgC;gBAChC,kCAAkC;gBAClC,wBAAwB;aAC3B;YACD,WAAW,EACP,oEAAoE;YACxE,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,qGAAqG;SAC7G;QACD,OAAO,EAAE,MAAM;QACf,QAAQ,EAAE;YACN,mBAAmB,EACf,wFAAwF;SAC/F;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,YAAY;KACrB;IACD,IAAI,EAAE,mCAAmC;IACzC,UAAU,EAAE,gBAAgB;CAC/B,CAAC,CAAC;AAEH,eAAe,kCAAkC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { RuleModuleWithDocs } from "../_internal/typed-rule.js";
2
+ type MessageIds = "requireRulesObject";
3
+ type Options = readonly [];
4
+ /** Rule module that requires top-level `rules` in Stylelint config files. */
5
+ declare const requireStylelintRulesObjectRule: RuleModuleWithDocs<MessageIds, Options>;
6
+ export default requireStylelintRulesObjectRule;
7
+ //# sourceMappingURL=require-stylelint-rules-object.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-stylelint-rules-object.d.ts","sourceRoot":"","sources":["../../src/rules/require-stylelint-rules-object.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AASrE,KAAK,UAAU,GAAG,oBAAoB,CAAC;AACvC,KAAK,OAAO,GAAG,SAAS,EAAE,CAAC;AAQ3B,6EAA6E;AAC7E,QAAA,MAAM,+BAA+B,EAAE,kBAAkB,CAAC,UAAU,EAAE,OAAO,CAkFvE,CAAC;AAEP,eAAe,+BAA+B,CAAC"}
@@ -0,0 +1,65 @@
1
+ import { getExportedStylelintConfigObject, getObjectPropertyByName, isStylelintConfigFile, } from "../_internal/stylelint-config-object.js";
2
+ import { createTypedRule, toRuleListener } from "../_internal/typed-rule.js";
3
+ const getLineEnding = (text) => text.includes("\r\n") ? "\r\n" : "\n";
4
+ const getIndentation = (node) => node === undefined ? " " : " ".repeat(node.loc.start.column);
5
+ /** Rule module that requires top-level `rules` in Stylelint config files. */
6
+ const requireStylelintRulesObjectRule = createTypedRule({
7
+ create(context) {
8
+ if (!isStylelintConfigFile(context.physicalFilename)) {
9
+ return {};
10
+ }
11
+ const sourceCode = context.sourceCode;
12
+ const lineEnding = getLineEnding(sourceCode.text);
13
+ return toRuleListener({
14
+ ExportDefaultDeclaration(node) {
15
+ if (node === null || typeof node !== "object") {
16
+ return;
17
+ }
18
+ const exportDefaultNode = node;
19
+ const configObject = getExportedStylelintConfigObject(exportDefaultNode.declaration);
20
+ if (configObject === undefined) {
21
+ return;
22
+ }
23
+ const rulesProperty = getObjectPropertyByName(configObject, "rules");
24
+ if (rulesProperty !== undefined) {
25
+ return;
26
+ }
27
+ context.report({
28
+ fix(fixer) {
29
+ const firstProperty = configObject.properties[0];
30
+ if (firstProperty === undefined) {
31
+ return fixer.replaceText(configObject, `{${lineEnding} rules: {},${lineEnding}}`);
32
+ }
33
+ const indentation = getIndentation(firstProperty);
34
+ return fixer.insertTextBefore(firstProperty, `rules: {},${lineEnding}${indentation}`);
35
+ },
36
+ messageId: "requireRulesObject",
37
+ node: configObject,
38
+ });
39
+ },
40
+ });
41
+ },
42
+ meta: {
43
+ deprecated: false,
44
+ docs: {
45
+ configs: [
46
+ "stylelint2.configs.recommended",
47
+ "stylelint2.configs.configuration",
48
+ "stylelint2.configs.all",
49
+ ],
50
+ description: "require a top-level `rules` object in authored Stylelint config files.",
51
+ recommended: true,
52
+ requiresTypeChecking: false,
53
+ url: "https://nick2bad4u.github.io/eslint-plugin-stylelint-2/docs/rules/require-stylelint-rules-object",
54
+ },
55
+ fixable: "code",
56
+ messages: {
57
+ requireRulesObject: "Add a top-level `rules` object so Stylelint rule configuration stays explicit and reviewable.",
58
+ },
59
+ schema: [],
60
+ type: "suggestion",
61
+ },
62
+ name: "require-stylelint-rules-object",
63
+ });
64
+ export default requireStylelintRulesObjectRule;
65
+ //# sourceMappingURL=require-stylelint-rules-object.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-stylelint-rules-object.js","sourceRoot":"","sources":["../../src/rules/require-stylelint-rules-object.ts"],"names":[],"mappings":"AAQA,OAAO,EACH,gCAAgC,EAChC,uBAAuB,EACvB,qBAAqB,GACxB,MAAM,yCAAyC,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAK7E,MAAM,aAAa,GAAG,CAAC,IAAY,EAAiB,EAAE,CAClD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC;AAE1C,MAAM,cAAc,GAAG,CAAC,IAAyC,EAAU,EAAE,CACzE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AAEpE,6EAA6E;AAC7E,MAAM,+BAA+B,GACjC,eAAe,CAAC;IACZ,MAAM,CAAC,OAAO;QACV,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,CAAC;YACnD,OAAO,EAAE,CAAC;QACd,CAAC;QAED,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QACtC,MAAM,UAAU,GAAG,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAElD,OAAO,cAAc,CAAC;YAClB,wBAAwB,CAAC,IAAa;gBAClC,IAAI,IAAI,KAAK,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;oBAC5C,OAAO;gBACX,CAAC;gBAED,MAAM,iBAAiB,GACnB,IAAyC,CAAC;gBAC9C,MAAM,YAAY,GAAG,gCAAgC,CACjD,iBAAiB,CAAC,WAAW,CAChC,CAAC;gBAEF,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;oBAC7B,OAAO;gBACX,CAAC;gBAED,MAAM,aAAa,GAAG,uBAAuB,CACzC,YAAY,EACZ,OAAO,CACV,CAAC;gBAEF,IAAI,aAAa,KAAK,SAAS,EAAE,CAAC;oBAC9B,OAAO;gBACX,CAAC;gBAED,OAAO,CAAC,MAAM,CAAC;oBACX,GAAG,CAAC,KAAK;wBACL,MAAM,aAAa,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;wBAEjD,IAAI,aAAa,KAAK,SAAS,EAAE,CAAC;4BAC9B,OAAO,KAAK,CAAC,WAAW,CACpB,YAAY,EACZ,IAAI,UAAU,iBAAiB,UAAU,GAAG,CAC/C,CAAC;wBACN,CAAC;wBAED,MAAM,WAAW,GAAG,cAAc,CAAC,aAAa,CAAC,CAAC;wBAElD,OAAO,KAAK,CAAC,gBAAgB,CACzB,aAAa,EACb,aAAa,UAAU,GAAG,WAAW,EAAE,CAC1C,CAAC;oBACN,CAAC;oBACD,SAAS,EAAE,oBAAoB;oBAC/B,IAAI,EAAE,YAAY;iBACrB,CAAC,CAAC;YACP,CAAC;SACJ,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,OAAO,EAAE;gBACL,gCAAgC;gBAChC,kCAAkC;gBAClC,wBAAwB;aAC3B;YACD,WAAW,EACP,wEAAwE;YAC5E,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,kGAAkG;SAC1G;QACD,OAAO,EAAE,MAAM;QACf,QAAQ,EAAE;YACN,kBAAkB,EACd,+FAA+F;SACtG;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,YAAY;KACrB;IACD,IAAI,EAAE,gCAAgC;CACzC,CAAC,CAAC;AAEP,eAAe,+BAA+B,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * @packageDocumentation
3
+ * Enforce sorted entries in Stylelint top-level extends option.
4
+ */
5
+ import type { RuleModuleWithDocs } from "../_internal/typed-rule.js";
6
+ /** Rule module that enforces sorted top-level Stylelint `extends` entries. */
7
+ declare const sortStylelintExtendsRule: RuleModuleWithDocs<"sortArray", readonly []>;
8
+ export default sortStylelintExtendsRule;
9
+ //# sourceMappingURL=sort-stylelint-extends.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sort-stylelint-extends.d.ts","sourceRoot":"","sources":["../../src/rules/sort-stylelint-extends.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAIrE,8EAA8E;AAC9E,QAAA,MAAM,wBAAwB,EAAE,kBAAkB,CAAC,WAAW,EAAE,SAAS,EAAE,CA0BrE,CAAC;AAEP,eAAe,wBAAwB,CAAC"}
@@ -0,0 +1,28 @@
1
+ import { createStylelintConfigSortArrayEntriesRule } from "../_internal/stylelint-config-string-array-option-rule.js";
2
+ /** Rule module that enforces sorted top-level Stylelint `extends` entries. */
3
+ const sortStylelintExtendsRule = createStylelintConfigSortArrayEntriesRule({
4
+ meta: {
5
+ deprecated: false,
6
+ docs: {
7
+ configs: [
8
+ "stylelint2.configs.recommended",
9
+ "stylelint2.configs.configuration",
10
+ "stylelint2.configs.all",
11
+ ],
12
+ description: "enforce sorted entries in top-level Stylelint `extends` declarations.",
13
+ recommended: true,
14
+ requiresTypeChecking: false,
15
+ url: "https://nick2bad4u.github.io/eslint-plugin-stylelint-2/docs/rules/sort-stylelint-extends",
16
+ },
17
+ fixable: "code",
18
+ messages: {
19
+ sortArray: "Sort top-level `extends` entries for deterministic config diffs and simpler reviews.",
20
+ },
21
+ schema: [],
22
+ type: "suggestion",
23
+ },
24
+ name: "sort-stylelint-extends",
25
+ optionName: "extends",
26
+ });
27
+ export default sortStylelintExtendsRule;
28
+ //# sourceMappingURL=sort-stylelint-extends.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sort-stylelint-extends.js","sourceRoot":"","sources":["../../src/rules/sort-stylelint-extends.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,yCAAyC,EAAE,MAAM,2DAA2D,CAAC;AAEtH,8EAA8E;AAC9E,MAAM,wBAAwB,GAC1B,yCAAyC,CAAC;IACtC,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,OAAO,EAAE;gBACL,gCAAgC;gBAChC,kCAAkC;gBAClC,wBAAwB;aAC3B;YACD,WAAW,EACP,uEAAuE;YAC3E,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,0FAA0F;SAClG;QACD,OAAO,EAAE,MAAM;QACf,QAAQ,EAAE;YACN,SAAS,EACL,sFAAsF;SAC7F;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,YAAY;KACrB;IACD,IAAI,EAAE,wBAAwB;IAC9B,UAAU,EAAE,SAAS;CACxB,CAAC,CAAC;AAEP,eAAe,wBAAwB,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * @packageDocumentation
3
+ * Enforce sorted entries in Stylelint top-level plugins option.
4
+ */
5
+ import type { RuleModuleWithDocs } from "../_internal/typed-rule.js";
6
+ /** Rule module that enforces sorted top-level Stylelint `plugins` entries. */
7
+ declare const sortStylelintPluginsRule: RuleModuleWithDocs<"sortArray", readonly []>;
8
+ export default sortStylelintPluginsRule;
9
+ //# sourceMappingURL=sort-stylelint-plugins.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sort-stylelint-plugins.d.ts","sourceRoot":"","sources":["../../src/rules/sort-stylelint-plugins.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAIrE,8EAA8E;AAC9E,QAAA,MAAM,wBAAwB,EAAE,kBAAkB,CAAC,WAAW,EAAE,SAAS,EAAE,CA0BrE,CAAC;AAEP,eAAe,wBAAwB,CAAC"}
@@ -0,0 +1,28 @@
1
+ import { createStylelintConfigSortArrayEntriesRule } from "../_internal/stylelint-config-string-array-option-rule.js";
2
+ /** Rule module that enforces sorted top-level Stylelint `plugins` entries. */
3
+ const sortStylelintPluginsRule = createStylelintConfigSortArrayEntriesRule({
4
+ meta: {
5
+ deprecated: false,
6
+ docs: {
7
+ configs: [
8
+ "stylelint2.configs.recommended",
9
+ "stylelint2.configs.configuration",
10
+ "stylelint2.configs.all",
11
+ ],
12
+ description: "enforce sorted entries in top-level Stylelint `plugins` declarations.",
13
+ recommended: true,
14
+ requiresTypeChecking: false,
15
+ url: "https://nick2bad4u.github.io/eslint-plugin-stylelint-2/docs/rules/sort-stylelint-plugins",
16
+ },
17
+ fixable: "code",
18
+ messages: {
19
+ sortArray: "Sort top-level `plugins` entries for deterministic plugin ordering and cleaner diffs.",
20
+ },
21
+ schema: [],
22
+ type: "suggestion",
23
+ },
24
+ name: "sort-stylelint-plugins",
25
+ optionName: "plugins",
26
+ });
27
+ export default sortStylelintPluginsRule;
28
+ //# sourceMappingURL=sort-stylelint-plugins.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sort-stylelint-plugins.js","sourceRoot":"","sources":["../../src/rules/sort-stylelint-plugins.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,yCAAyC,EAAE,MAAM,2DAA2D,CAAC;AAEtH,8EAA8E;AAC9E,MAAM,wBAAwB,GAC1B,yCAAyC,CAAC;IACtC,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,OAAO,EAAE;gBACL,gCAAgC;gBAChC,kCAAkC;gBAClC,wBAAwB;aAC3B;YACD,WAAW,EACP,uEAAuE;YAC3E,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,0FAA0F;SAClG;QACD,OAAO,EAAE,MAAM;QACf,QAAQ,EAAE;YACN,SAAS,EACL,uFAAuF;SAC9F;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,YAAY;KACrB;IACD,IAAI,EAAE,wBAAwB;IAC9B,UAAU,EAAE,SAAS;CACxB,CAAC,CAAC;AAEP,eAAe,wBAAwB,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { RuleModuleWithDocs } from "../_internal/typed-rule.js";
2
+ type MessageIds = "sortRuleKeys";
3
+ type Options = readonly [];
4
+ /** Rule module that enforces lexical ordering of top-level Stylelint rule keys. */
5
+ declare const sortStylelintRuleKeysRule: RuleModuleWithDocs<MessageIds, Options>;
6
+ export default sortStylelintRuleKeysRule;
7
+ //# sourceMappingURL=sort-stylelint-rule-keys.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sort-stylelint-rule-keys.d.ts","sourceRoot":"","sources":["../../src/rules/sort-stylelint-rule-keys.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAYrE,KAAK,UAAU,GAAG,cAAc,CAAC;AACjC,KAAK,OAAO,GAAG,SAAS,EAAE,CAAC;AAwF3B,mFAAmF;AACnF,QAAA,MAAM,yBAAyB,EAAE,kBAAkB,CAAC,UAAU,EAAE,OAAO,CA6FjE,CAAC;AAEP,eAAe,yBAAyB,CAAC"}