@alexlit/lint-kit 176.0.1 → 177.0.0

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 (293) hide show
  1. package/package.json +1 -1
  2. package/packages/config-stylelint/package.json +5 -5
  3. package/packages/config-stylelint/plugins/color-format.js +1 -5
  4. package/packages/config-stylelint/plugins/logical-css.js +1 -4
  5. package/packages/config-eslint/node_modules/@eslint/core/LICENSE +0 -201
  6. package/packages/config-eslint/node_modules/@eslint/core/README.md +0 -29
  7. package/packages/config-eslint/node_modules/@eslint/core/dist/cjs/types.d.cts +0 -1179
  8. package/packages/config-eslint/node_modules/@eslint/core/dist/esm/types.d.ts +0 -1179
  9. package/packages/config-eslint/node_modules/@eslint/core/package.json +0 -49
  10. package/packages/config-eslint/node_modules/@eslint/plugin-kit/LICENSE +0 -201
  11. package/packages/config-eslint/node_modules/@eslint/plugin-kit/README.md +0 -273
  12. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/cjs/index.cjs +0 -884
  13. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/cjs/index.d.cts +0 -328
  14. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/cjs/types.cts +0 -7
  15. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/index.d.ts +0 -328
  16. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/index.js +0 -879
  17. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/types.d.ts +0 -6
  18. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/types.ts +0 -7
  19. package/packages/config-eslint/node_modules/@eslint/plugin-kit/package.json +0 -61
  20. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/configs/flat-config-base.js +0 -9
  21. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/index.d.ts +0 -17
  22. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/index.js +0 -91
  23. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/license +0 -9
  24. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/globals.json +0 -3345
  25. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/index.d.ts +0 -3452
  26. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/index.js +0 -2
  27. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/license +0 -9
  28. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/package.json +0 -117
  29. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/readme.md +0 -42
  30. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/package.json +0 -128
  31. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/readme.md +0 -261
  32. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/call-or-new-expression.js +0 -120
  33. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/function-types.js +0 -7
  34. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/index.js +0 -30
  35. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-arrow-function-body.js +0 -3
  36. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-directive.js +0 -4
  37. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-empty-array-expression.js +0 -5
  38. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-empty-node.js +0 -17
  39. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-expression-statement.js +0 -7
  40. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-function.js +0 -5
  41. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-member-expression.js +0 -98
  42. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-method-call.js +0 -62
  43. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-negative-one.js +0 -8
  44. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-reference-identifier.js +0 -159
  45. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-static-require.js +0 -10
  46. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-tagged-template-literal.js +0 -24
  47. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-undefined.js +0 -3
  48. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/literal.js +0 -24
  49. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/better-regex.js +0 -146
  50. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/catch-error-name.js +0 -138
  51. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-assert.js +0 -98
  52. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-date-clone.js +0 -54
  53. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-destructuring.js +0 -168
  54. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-empty-array-spread.js +0 -127
  55. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-existence-index-check.js +0 -137
  56. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-function-scoping.js +0 -265
  57. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/custom-error-definition.js +0 -218
  58. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/empty-brace-spaces.js +0 -62
  59. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/error-message.js +0 -98
  60. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/escape-case.js +0 -86
  61. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/expiring-todo-comments.js +0 -584
  62. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/explicit-length-check.js +0 -236
  63. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/filename-case.js +0 -276
  64. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/add-parenthesizes-to-return-or-throw-expression.js +0 -29
  65. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/append-argument.js +0 -30
  66. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/extend-fix-range.js +0 -11
  67. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/fix-space-around-keywords.js +0 -43
  68. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/index.js +0 -23
  69. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-argument.js +0 -40
  70. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-expression-statement.js +0 -34
  71. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-method-call.js +0 -28
  72. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-object-property.js +0 -21
  73. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-parentheses.js +0 -19
  74. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-spaces-after.js +0 -22
  75. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-specifier.js +0 -59
  76. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/rename-variable.js +0 -8
  77. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-argument.js +0 -17
  78. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-member-expression-property.js +0 -25
  79. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-node-or-token-and-spaces-before.js +0 -31
  80. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-reference-identifier.js +0 -32
  81. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-string-raw.js +0 -12
  82. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-template-element.js +0 -10
  83. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/switch-call-expression-to-new-expression.js +0 -29
  84. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/switch-new-expression-to-call-expression.js +0 -42
  85. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/import-style.js +0 -375
  86. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/index.js +0 -143
  87. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/new-for-builtins.js +0 -112
  88. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-abusive-eslint-disable.js +0 -63
  89. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-accessor-recursion.js +0 -160
  90. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-anonymous-default-export.js +0 -210
  91. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-callback-reference.js +0 -285
  92. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-for-each.js +0 -496
  93. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-method-this-argument.js +0 -223
  94. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-reduce.js +0 -128
  95. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-reverse.js +0 -6
  96. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-sort.js +0 -6
  97. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-await-expression-member.js +0 -85
  98. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-await-in-promise-methods.js +0 -69
  99. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-console-spaces.js +0 -89
  100. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-document-cookie.js +0 -27
  101. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-empty-file.js +0 -58
  102. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-for-loop.js +0 -419
  103. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-hex-escape.js +0 -54
  104. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-immediate-mutation.js +0 -778
  105. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-instanceof-builtins.js +0 -216
  106. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-invalid-fetch-options.js +0 -112
  107. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-invalid-remove-event-listener.js +0 -61
  108. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-keyword-prefix.js +0 -202
  109. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-lonely-if.js +0 -155
  110. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-magic-array-flat-depth.js +0 -55
  111. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-named-default.js +0 -101
  112. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-negated-condition.js +0 -145
  113. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-negation-in-equality-check.js +0 -99
  114. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-nested-ternary.js +0 -60
  115. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-new-array.js +0 -106
  116. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-new-buffer.js +0 -100
  117. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-null.js +0 -153
  118. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-object-as-default-parameter.js +0 -52
  119. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-process-exit.js +0 -106
  120. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-single-promise-in-promise-methods.js +0 -179
  121. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-static-only-class.js +0 -226
  122. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-thenable.js +0 -194
  123. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-this-assignment.js +0 -40
  124. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-typeof-undefined.js +0 -146
  125. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-array-flat-depth.js +0 -49
  126. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-array-splice-count.js +0 -23
  127. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-await.js +0 -110
  128. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-polyfills.js +0 -174
  129. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-slice-end.js +0 -22
  130. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unreadable-array-destructuring.js +0 -85
  131. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unreadable-iife.js +0 -43
  132. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unused-properties.js +0 -240
  133. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-collection-argument.js +0 -101
  134. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-error-capture-stack-trace.js +0 -146
  135. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-fallback-in-spread.js +0 -66
  136. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-length-check.js +0 -150
  137. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-promise-resolve-reject.js +0 -210
  138. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-spread.js +0 -389
  139. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-switch-case.js +0 -59
  140. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-undefined.js +0 -275
  141. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-zero-fractions.js +0 -81
  142. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/number-literal-case.js +0 -82
  143. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/numeric-separators-style.js +0 -189
  144. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-add-event-listener.js +0 -191
  145. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-find.js +0 -458
  146. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-flat-map.js +0 -86
  147. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-flat.js +0 -279
  148. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-index-of.js +0 -34
  149. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-some.js +0 -219
  150. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-at.js +0 -380
  151. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-bigint-literals.js +0 -129
  152. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-blob-reading-methods.js +0 -47
  153. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-class-fields.js +0 -158
  154. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-classlist-toggle.js +0 -255
  155. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-code-point.js +0 -56
  156. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-date-now.js +0 -133
  157. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-default-parameters.js +0 -218
  158. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-append.js +0 -50
  159. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-dataset.js +0 -135
  160. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-remove.js +0 -124
  161. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-text-content.js +0 -77
  162. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-event-target.js +0 -119
  163. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-export-from.js +0 -367
  164. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-global-this.js +0 -222
  165. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-import-meta-properties.js +0 -320
  166. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-includes.js +0 -111
  167. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-json-parse-buffer.js +0 -161
  168. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-keyboard-event-key.js +0 -188
  169. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-logical-operator-over-ternary.js +0 -162
  170. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-math-min-max.js +0 -205
  171. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-math-trunc.js +0 -111
  172. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-modern-dom-apis.js +0 -145
  173. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-modern-math-apis.js +0 -210
  174. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-module.js +0 -377
  175. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-native-coercion-functions.js +0 -187
  176. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-negative-index.js +0 -211
  177. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-node-protocol.js +0 -86
  178. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-number-properties.js +0 -142
  179. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-object-from-entries.js +0 -256
  180. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-optional-catch-binding.js +0 -77
  181. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-prototype-methods.js +0 -162
  182. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-query-selector.js +0 -170
  183. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-reflect-apply.js +0 -99
  184. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-regexp-test.js +0 -155
  185. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-response-static-json.js +0 -85
  186. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-set-has.js +0 -181
  187. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-set-size.js +0 -106
  188. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-single-call.js +0 -188
  189. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-spread.js +0 -521
  190. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-raw.js +0 -149
  191. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-replace-all.js +0 -180
  192. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-slice.js +0 -180
  193. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-starts-ends-with.js +0 -201
  194. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-trim-start-end.js +0 -46
  195. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-structured-clone.js +0 -149
  196. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-switch.js +0 -357
  197. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-ternary.js +0 -288
  198. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-top-level-await.js +0 -154
  199. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-type-error.js +0 -169
  200. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prevent-abbreviations.js +0 -655
  201. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/relative-url-style.js +0 -171
  202. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-array-join-separator.js +0 -65
  203. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-module-attributes.js +0 -120
  204. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-module-specifiers.js +0 -158
  205. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-number-to-fixed-digits-argument.js +0 -55
  206. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-post-message-target-origin.js +0 -74
  207. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/get-documentation-url.js +0 -9
  208. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/index.js +0 -9
  209. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-create.js +0 -51
  210. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-listener.js +0 -40
  211. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-problem.js +0 -38
  212. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-rule-fixer.js +0 -49
  213. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-rule.js +0 -38
  214. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-rules.js +0 -13
  215. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/unicorn-context.js +0 -36
  216. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/unicorn-listeners.js +0 -65
  217. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/utilities.js +0 -27
  218. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/abbreviations.js +0 -270
  219. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/builtin-errors.js +0 -14
  220. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/dom-events.js +0 -275
  221. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/event-keys.js +0 -54
  222. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/negative-index.js +0 -52
  223. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/no-array-mutate-rule.js +0 -139
  224. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/no-unnecessary-length-or-infinity-rule.js +0 -80
  225. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/package-json.js +0 -42
  226. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/simple-array-search-rule.js +0 -126
  227. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/typed-array.js +0 -17
  228. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/string-content.js +0 -192
  229. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/switch-case-braces.js +0 -114
  230. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/template-indent.js +0 -219
  231. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/text-encoding-identifier-case.js +0 -130
  232. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/throw-new-error.js +0 -60
  233. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/array-or-object-prototype-property.js +0 -57
  234. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/assert-token.js +0 -29
  235. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/boolean.js +0 -88
  236. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/builtins.js +0 -30
  237. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/cartesian-product-samples.js +0 -22
  238. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/create-deprecated-rules.js +0 -29
  239. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/escape-string.js +0 -24
  240. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/escape-template-element-raw.js +0 -6
  241. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-ancestor.js +0 -15
  242. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-available-variable-name.js +0 -147
  243. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-builtin-rule.js +0 -5
  244. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-call-expression-arguments-text.js +0 -36
  245. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-call-or-new-expression-tokens.js +0 -67
  246. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-class-head-location.js +0 -22
  247. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-documentation-url.js +0 -9
  248. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-indent-string.js +0 -18
  249. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-references.js +0 -5
  250. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-scopes.js +0 -12
  251. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-sibling-node.js +0 -38
  252. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-switch-case-head-location.js +0 -22
  253. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-token-store.js +0 -24
  254. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-variable-identifiers.js +0 -7
  255. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/global-reference-tracker.js +0 -68
  256. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/has-optional-chain-element.js +0 -17
  257. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/has-same-range.js +0 -7
  258. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/index.js +0 -59
  259. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-function-self-used-inside.js +0 -39
  260. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-left-hand-side.js +0 -20
  261. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-logical-expression.js +0 -14
  262. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-method-named.js +0 -7
  263. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-new-expression-with-parentheses.js +0 -28
  264. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-node-matches.js +0 -58
  265. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-node-value-not-dom-node.js +0 -20
  266. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-node-value-not-function.js +0 -40
  267. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-number.js +0 -224
  268. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-object-method.js +0 -10
  269. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-on-same-line.js +0 -7
  270. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-same-identifier.js +0 -5
  271. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-same-reference.js +0 -170
  272. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-export-local.js +0 -8
  273. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-import-local.js +0 -8
  274. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-property-assignment-pattern-left.js +0 -8
  275. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-property-value.js +0 -6
  276. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-unresolved-variable.js +0 -14
  277. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-value-not-usable.js +0 -5
  278. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/needs-semicolon.js +0 -118
  279. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/numeric.js +0 -49
  280. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/parentheses.js +0 -71
  281. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/resolve-variable-name.js +0 -18
  282. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/rule.js +0 -27
  283. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-await-expression-argument.js +0 -17
  284. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-call-expression-callee.js +0 -18
  285. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-conditional-expression-child.js +0 -13
  286. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-expression-statement-expression.js +0 -22
  287. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-logical-expression-child.js +0 -43
  288. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-member-expression-object.js +0 -47
  289. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-new-expression-callee.js +0 -28
  290. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-unary-expression.js +0 -24
  291. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/singular.js +0 -16
  292. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/string-cases.js +0 -2
  293. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/to-location.js +0 -25
@@ -1,521 +0,0 @@
1
- import {getStaticValue, isCommaToken, hasSideEffect} from '@eslint-community/eslint-utils';
2
- import {
3
- getParenthesizedRange,
4
- getParenthesizedText,
5
- needsSemicolon,
6
- isNodeMatches,
7
- isMethodNamed,
8
- hasOptionalChainElement,
9
- } from './utils/index.js';
10
- import {removeMethodCall} from './fix/index.js';
11
- import {isLiteral, isMethodCall} from './ast/index.js';
12
-
13
- const ERROR_ARRAY_FROM = 'array-from';
14
- const ERROR_ARRAY_CONCAT = 'array-concat';
15
- const ERROR_ARRAY_SLICE = 'array-slice';
16
- const ERROR_ARRAY_TO_SPLICED = 'array-to-spliced';
17
- const ERROR_STRING_SPLIT = 'string-split';
18
- const SUGGESTION_CONCAT_ARGUMENT_IS_SPREADABLE = 'argument-is-spreadable';
19
- const SUGGESTION_CONCAT_ARGUMENT_IS_NOT_SPREADABLE = 'argument-is-not-spreadable';
20
- const SUGGESTION_CONCAT_TEST_ARGUMENT = 'test-argument';
21
- const SUGGESTION_CONCAT_SPREAD_ALL_ARGUMENTS = 'spread-all-arguments';
22
- const SUGGESTION_USE_SPREAD = 'use-spread';
23
- const messages = {
24
- [ERROR_ARRAY_FROM]: 'Prefer the spread operator over `Array.from(…)`.',
25
- [ERROR_ARRAY_CONCAT]: 'Prefer the spread operator over `Array#concat(…)`.',
26
- [ERROR_ARRAY_SLICE]: 'Prefer the spread operator over `Array#slice()`.',
27
- [ERROR_ARRAY_TO_SPLICED]: 'Prefer the spread operator over `Array#toSpliced()`.',
28
- [ERROR_STRING_SPLIT]: 'Prefer the spread operator over `String#split(\'\')`.',
29
- [SUGGESTION_CONCAT_ARGUMENT_IS_SPREADABLE]: 'First argument is an `array`.',
30
- [SUGGESTION_CONCAT_ARGUMENT_IS_NOT_SPREADABLE]: 'First argument is not an `array`.',
31
- [SUGGESTION_CONCAT_TEST_ARGUMENT]: 'Test first argument with `Array.isArray(…)`.',
32
- [SUGGESTION_CONCAT_SPREAD_ALL_ARGUMENTS]: 'Spread all unknown arguments`.',
33
- [SUGGESTION_USE_SPREAD]: 'Use `...` operator.',
34
- };
35
-
36
- const ignoredSliceCallee = [
37
- 'arrayBuffer',
38
- 'blob',
39
- 'buffer',
40
- 'file',
41
- 'this',
42
- ];
43
-
44
- const isArrayLiteral = node => node.type === 'ArrayExpression';
45
- const isArrayLiteralHasTrailingComma = (node, sourceCode) => {
46
- if (node.elements.length === 0) {
47
- return false;
48
- }
49
-
50
- return isCommaToken(sourceCode.getLastToken(node, 1));
51
- };
52
-
53
- function fixConcat(node, context, fixableArguments) {
54
- const {sourceCode} = context;
55
- const array = node.callee.object;
56
- const concatCallArguments = node.arguments;
57
- const arrayParenthesizedRange = getParenthesizedRange(array, context);
58
- const arrayIsArrayLiteral = isArrayLiteral(array);
59
- const arrayHasTrailingComma = arrayIsArrayLiteral && isArrayLiteralHasTrailingComma(array, sourceCode);
60
-
61
- const getArrayLiteralElementsText = (node, keepTrailingComma) => {
62
- if (
63
- !keepTrailingComma
64
- && isArrayLiteralHasTrailingComma(node, sourceCode)
65
- ) {
66
- const start = sourceCode.getRange(node)[0] + 1;
67
- const [end] = sourceCode.getRange(sourceCode.getLastToken(node, 1));
68
- return sourceCode.text.slice(start, end);
69
- }
70
-
71
- return sourceCode.getText(node, -1, -1);
72
- };
73
-
74
- const getFixedText = () => {
75
- const nonEmptyArguments = fixableArguments
76
- .filter(({node, isArrayLiteral}) => (!isArrayLiteral || node.elements.length > 0));
77
- const lastArgument = nonEmptyArguments.at(-1);
78
-
79
- let text = nonEmptyArguments
80
- .map(({node, isArrayLiteral, isSpreadable, testArgument}) => {
81
- if (isArrayLiteral) {
82
- return getArrayLiteralElementsText(node, node === lastArgument.node);
83
- }
84
-
85
- let text = getParenthesizedText(node, context);
86
-
87
- if (testArgument) {
88
- return `...(Array.isArray(${text}) ? ${text} : [${text}])`;
89
- }
90
-
91
- if (isSpreadable) {
92
- text = `...${text}`;
93
- }
94
-
95
- return text || ' ';
96
- })
97
- .join(', ');
98
-
99
- if (!text) {
100
- return '';
101
- }
102
-
103
- if (arrayIsArrayLiteral) {
104
- if (array.elements.length > 0) {
105
- text = ` ${text}`;
106
-
107
- if (!arrayHasTrailingComma) {
108
- text = `,${text}`;
109
- }
110
-
111
- if (
112
- arrayHasTrailingComma
113
- && (!lastArgument.isArrayLiteral || !isArrayLiteralHasTrailingComma(lastArgument.node, sourceCode))
114
- ) {
115
- text = `${text},`;
116
- }
117
- }
118
- } else {
119
- text = `, ${text}`;
120
- }
121
-
122
- return text;
123
- };
124
-
125
- function removeArguments(fixer) {
126
- const [firstArgument] = concatCallArguments;
127
- const lastArgument = concatCallArguments[fixableArguments.length - 1];
128
-
129
- const [start] = getParenthesizedRange(firstArgument, context);
130
- let [, end] = sourceCode.getRange(sourceCode.getTokenAfter(lastArgument, isCommaToken));
131
-
132
- const textAfter = sourceCode.text.slice(end);
133
- const [leadingSpaces] = textAfter.match(/^\s*/);
134
- end += leadingSpaces.length;
135
-
136
- return fixer.removeRange([start, end]);
137
- }
138
-
139
- return function * (fixer) {
140
- // Fixed code always starts with `[`
141
- if (
142
- !arrayIsArrayLiteral
143
- && needsSemicolon(sourceCode.getTokenBefore(node), context, '[')
144
- ) {
145
- yield fixer.insertTextBefore(node, ';');
146
- }
147
-
148
- yield (
149
- concatCallArguments.length - fixableArguments.length === 0
150
- ? removeMethodCall(fixer, node, context)
151
- : removeArguments(fixer)
152
- );
153
-
154
- const text = getFixedText();
155
-
156
- if (arrayIsArrayLiteral) {
157
- const closingBracketToken = sourceCode.getLastToken(array);
158
- yield fixer.insertTextBefore(closingBracketToken, text);
159
- } else {
160
- // The array is already accessing `.concat`, there should not any case need add extra `()`
161
- yield fixer.insertTextBeforeRange(arrayParenthesizedRange, '[...');
162
- yield fixer.insertTextAfterRange(arrayParenthesizedRange, text);
163
- yield fixer.insertTextAfterRange(arrayParenthesizedRange, ']');
164
- }
165
- };
166
- }
167
-
168
- const getConcatArgumentSpreadable = (node, scope) => {
169
- if (node.type === 'SpreadElement') {
170
- return;
171
- }
172
-
173
- if (isArrayLiteral(node)) {
174
- return {node, isArrayLiteral: true};
175
- }
176
-
177
- const result = getStaticValue(node, scope);
178
-
179
- if (!result) {
180
- return;
181
- }
182
-
183
- const isSpreadable = Array.isArray(result.value);
184
-
185
- return {node, isSpreadable};
186
- };
187
-
188
- function getConcatFixableArguments(argumentsList, scope) {
189
- const fixableArguments = [];
190
-
191
- for (const node of argumentsList) {
192
- const result = getConcatArgumentSpreadable(node, scope);
193
-
194
- if (result) {
195
- fixableArguments.push(result);
196
- } else {
197
- break;
198
- }
199
- }
200
-
201
- return fixableArguments;
202
- }
203
-
204
- function fixArrayFrom(node, context) {
205
- const {sourceCode} = context;
206
- const [object] = node.arguments;
207
-
208
- function getObjectText() {
209
- if (isArrayLiteral(object)) {
210
- return sourceCode.getText(object);
211
- }
212
-
213
- const [start, end] = getParenthesizedRange(object, context);
214
- const text = sourceCode.text.slice(start, end);
215
-
216
- return `[...${text}]`;
217
- }
218
-
219
- return function * (fixer) {
220
- // Fixed code always starts with `[`
221
- if (needsSemicolon(sourceCode.getTokenBefore(node), context, '[')) {
222
- yield fixer.insertTextBefore(node, ';');
223
- }
224
-
225
- const objectText = getObjectText();
226
-
227
- yield fixer.replaceText(node, objectText);
228
- };
229
- }
230
-
231
- function methodCallToSpread(node, context) {
232
- return function * (fixer) {
233
- const {sourceCode} = context;
234
- // Fixed code always starts with `[`
235
- if (needsSemicolon(sourceCode.getTokenBefore(node), context, '[')) {
236
- yield fixer.insertTextBefore(node, ';');
237
- }
238
-
239
- yield fixer.insertTextBefore(node, '[...');
240
- yield fixer.insertTextAfter(node, ']');
241
-
242
- // The array is already accessing `.slice` or `.split`, there should not any case need add extra `()`
243
-
244
- yield removeMethodCall(fixer, node, context);
245
- };
246
- }
247
-
248
- function isClassName(node) {
249
- if (node.type === 'MemberExpression') {
250
- node = node.property;
251
- }
252
-
253
- if (node.type !== 'Identifier') {
254
- return false;
255
- }
256
-
257
- const {name} = node;
258
-
259
- return /^[A-Z]./.test(name) && name.toUpperCase() !== name;
260
- }
261
-
262
- function isNotArray(node, scope) {
263
- if (
264
- node.type === 'TemplateLiteral'
265
- || node.type === 'Literal'
266
- || node.type === 'BinaryExpression'
267
- || isClassName(node)
268
- // `foo.join()`
269
- || (isMethodNamed(node, 'join') && node.arguments.length <= 1)
270
- ) {
271
- return true;
272
- }
273
-
274
- const staticValue = getStaticValue(node, scope);
275
- if (staticValue && !Array.isArray(staticValue.value)) {
276
- return true;
277
- }
278
-
279
- return false;
280
- }
281
-
282
- /** @param {import('eslint').Rule.RuleContext} context */
283
- const create = context => {
284
- const {sourceCode} = context;
285
-
286
- // `Array.from()`
287
- context.on('CallExpression', node => {
288
- if (
289
- isMethodCall(node, {
290
- object: 'Array',
291
- method: 'from',
292
- argumentsLength: 1,
293
- optionalCall: false,
294
- optionalMember: false,
295
- })
296
- // Allow `Array.from({length})`
297
- && node.arguments[0].type !== 'ObjectExpression'
298
- ) {
299
- return {
300
- node,
301
- messageId: ERROR_ARRAY_FROM,
302
- fix: fixArrayFrom(node, context),
303
- };
304
- }
305
- });
306
-
307
- // `array.concat()`
308
- context.on('CallExpression', node => {
309
- if (!isMethodCall(node, {
310
- method: 'concat',
311
- optionalCall: false,
312
- optionalMember: false,
313
- })) {
314
- return;
315
- }
316
-
317
- const {object} = node.callee;
318
- const scope = sourceCode.getScope(object);
319
-
320
- if (isNotArray(object, scope)) {
321
- return;
322
- }
323
-
324
- const staticResult = getStaticValue(object, scope);
325
- if (staticResult && !Array.isArray(staticResult.value)) {
326
- return;
327
- }
328
-
329
- const problem = {
330
- node: node.callee.property,
331
- messageId: ERROR_ARRAY_CONCAT,
332
- };
333
-
334
- const fixableArguments = getConcatFixableArguments(node.arguments, scope);
335
-
336
- if (fixableArguments.length > 0 || node.arguments.length === 0) {
337
- problem.fix = fixConcat(node, context, fixableArguments);
338
- return problem;
339
- }
340
-
341
- const [firstArgument, ...restArguments] = node.arguments;
342
- if (firstArgument.type === 'SpreadElement') {
343
- return problem;
344
- }
345
-
346
- const fixableArgumentsAfterFirstArgument = getConcatFixableArguments(restArguments, scope);
347
- const suggestions = [
348
- {
349
- messageId: SUGGESTION_CONCAT_ARGUMENT_IS_SPREADABLE,
350
- isSpreadable: true,
351
- },
352
- {
353
- messageId: SUGGESTION_CONCAT_ARGUMENT_IS_NOT_SPREADABLE,
354
- isSpreadable: false,
355
- },
356
- ];
357
-
358
- if (!hasSideEffect(firstArgument, sourceCode)) {
359
- suggestions.push({
360
- messageId: SUGGESTION_CONCAT_TEST_ARGUMENT,
361
- testArgument: true,
362
- });
363
- }
364
-
365
- problem.suggest = suggestions.map(({messageId, isSpreadable, testArgument}) => ({
366
- messageId,
367
- fix: fixConcat(
368
- node,
369
- context,
370
- // When apply suggestion, we also merge fixable arguments after the first one
371
- [
372
- {
373
- node: firstArgument,
374
- isSpreadable,
375
- testArgument,
376
- },
377
- ...fixableArgumentsAfterFirstArgument,
378
- ],
379
- ),
380
- }));
381
-
382
- if (
383
- fixableArgumentsAfterFirstArgument.length < restArguments.length
384
- && restArguments.every(({type}) => type !== 'SpreadElement')
385
- ) {
386
- problem.suggest.push({
387
- messageId: SUGGESTION_CONCAT_SPREAD_ALL_ARGUMENTS,
388
- fix: fixConcat(
389
- node,
390
- context,
391
- node.arguments.map(node => getConcatArgumentSpreadable(node, scope) || {node, isSpreadable: true}),
392
- ),
393
- });
394
- }
395
-
396
- return problem;
397
- });
398
-
399
- // `array.slice()`
400
- context.on('CallExpression', node => {
401
- if (!(
402
- isMethodCall(node, {
403
- method: 'slice',
404
- minimumArguments: 0,
405
- maximumArguments: 1,
406
- optionalCall: false,
407
- optionalMember: false,
408
- })
409
- && !isArrayLiteral(node.callee.object)
410
- && !hasOptionalChainElement(node.callee.object)
411
- )) {
412
- return;
413
- }
414
-
415
- if (isNodeMatches(node.callee.object, ignoredSliceCallee)) {
416
- return;
417
- }
418
-
419
- const [firstArgument] = node.arguments;
420
- if (firstArgument && !isLiteral(firstArgument, 0)) {
421
- return;
422
- }
423
-
424
- return {
425
- node: node.callee.property,
426
- messageId: ERROR_ARRAY_SLICE,
427
- fix: methodCallToSpread(node, context),
428
- };
429
- });
430
-
431
- // `array.toSpliced()`
432
- context.on('CallExpression', node => {
433
- if (!(
434
- isMethodCall(node, {
435
- method: 'toSpliced',
436
- argumentsLength: 0,
437
- optionalCall: false,
438
- optionalMember: false,
439
- })
440
- && node.callee.object.type !== 'ArrayExpression'
441
- )) {
442
- return;
443
- }
444
-
445
- return {
446
- node: node.callee.property,
447
- messageId: ERROR_ARRAY_TO_SPLICED,
448
- fix: methodCallToSpread(node, context),
449
- };
450
- });
451
-
452
- // `string.split()`
453
- context.on('CallExpression', node => {
454
- if (!isMethodCall(node, {
455
- method: 'split',
456
- argumentsLength: 1,
457
- optionalCall: false,
458
- optionalMember: false,
459
- })) {
460
- return;
461
- }
462
-
463
- const [separator] = node.arguments;
464
- if (!isLiteral(separator, '')) {
465
- return;
466
- }
467
-
468
- const string = node.callee.object;
469
- const staticValue = getStaticValue(string, sourceCode.getScope(string));
470
- let hasSameResult = false;
471
- if (staticValue) {
472
- const {value} = staticValue;
473
-
474
- if (typeof value !== 'string') {
475
- return;
476
- }
477
-
478
- // eslint-disable-next-line unicorn/prefer-spread
479
- const resultBySplit = value.split('');
480
- const resultBySpread = [...value];
481
-
482
- hasSameResult = resultBySplit.length === resultBySpread.length
483
- && resultBySplit.every((character, index) => character === resultBySpread[index]);
484
- }
485
-
486
- const problem = {
487
- node: node.callee.property,
488
- messageId: ERROR_STRING_SPLIT,
489
- };
490
-
491
- if (hasSameResult) {
492
- problem.fix = methodCallToSpread(node, context);
493
- } else {
494
- problem.suggest = [
495
- {
496
- messageId: SUGGESTION_USE_SPREAD,
497
- fix: methodCallToSpread(node, context),
498
- },
499
- ];
500
- }
501
-
502
- return problem;
503
- });
504
- };
505
-
506
- /** @type {import('eslint').Rule.RuleModule} */
507
- const config = {
508
- create,
509
- meta: {
510
- type: 'suggestion',
511
- docs: {
512
- description: 'Prefer the spread operator over `Array.from(…)`, `Array#concat(…)`, `Array#{slice,toSpliced}()` and `String#split(\'\')`.',
513
- recommended: true,
514
- },
515
- fixable: 'code',
516
- hasSuggestions: true,
517
- messages,
518
- },
519
- };
520
-
521
- export default config;
@@ -1,149 +0,0 @@
1
- import {isStringLiteral, isDirective} from './ast/index.js';
2
- import {fixSpaceAroundKeyword, replaceTemplateElement} from './fix/index.js';
3
-
4
- const MESSAGE_ID = 'prefer-string-raw';
5
- const messages = {
6
- [MESSAGE_ID]: '`String.raw` should be used to avoid escaping `\\`.',
7
- };
8
-
9
- const BACKSLASH = '\\';
10
-
11
- function unescapeBackslash(text, quote = '') {
12
- return text.replaceAll(new RegExp(String.raw`\\(?<escapedCharacter>[\\${quote}])`, 'g'), '$<escapedCharacter>');
13
- }
14
-
15
- /**
16
- Check if a string literal is restricted to replace with a `String.raw`
17
- */
18
- // eslint-disable-next-line complexity
19
- function isStringRawRestricted(node) {
20
- const {parent} = node;
21
- const {type} = parent;
22
- return (
23
- // Directive
24
- isDirective(parent)
25
- // Property, method, or accessor key (only non-computed)
26
- || (
27
- (
28
- type === 'Property'
29
- || type === 'PropertyDefinition'
30
- || type === 'MethodDefinition'
31
- || type === 'AccessorProperty'
32
- )
33
- && !parent.computed && parent.key === node
34
- )
35
- // Property, method, or accessor key (always)
36
- || (
37
- (
38
- type === 'TSAbstractPropertyDefinition'
39
- || type === 'TSAbstractMethodDefinition'
40
- || type === 'TSAbstractAccessorProperty'
41
- || type === 'TSPropertySignature'
42
- )
43
- && parent.key === node
44
- )
45
- // Module source
46
- || (
47
- (
48
- type === 'ImportDeclaration'
49
- || type === 'ExportNamedDeclaration'
50
- || type === 'ExportAllDeclaration'
51
- ) && parent.source === node
52
- )
53
- // Import attribute key and value
54
- || (type === 'ImportAttribute' && (parent.key === node || parent.value === node))
55
- // Module specifier
56
- || (type === 'ImportSpecifier' && parent.imported === node)
57
- || (type === 'ExportSpecifier' && (parent.local === node || parent.exported === node))
58
- || (type === 'ExportAllDeclaration' && parent.exported === node)
59
- // JSX attribute value
60
- || (type === 'JSXAttribute' && parent.value === node)
61
- // (TypeScript) Enum member key and value
62
- || (type === 'TSEnumMember' && (parent.initializer === node || parent.id === node))
63
- // (TypeScript) Module declaration
64
- || (type === 'TSModuleDeclaration' && parent.id === node)
65
- // (TypeScript) CommonJS module reference
66
- || (type === 'TSExternalModuleReference' && parent.expression === node)
67
- // (TypeScript) Literal type
68
- || (type === 'TSLiteralType' && parent.literal === node)
69
- );
70
- }
71
-
72
- /** @param {import('eslint').Rule.RuleContext} context */
73
- const create = context => {
74
- context.on('Literal', node => {
75
- if (!isStringLiteral(node) || isStringRawRestricted(node)) {
76
- return;
77
- }
78
-
79
- const {sourceCode} = context;
80
- const {raw} = node;
81
- if (
82
- raw.at(-2) === BACKSLASH
83
- || !raw.includes(BACKSLASH + BACKSLASH)
84
- || raw.includes('`')
85
- || raw.includes('${')
86
- || sourceCode.getLoc(node).start.line !== sourceCode.getLoc(node).end.line
87
- ) {
88
- return;
89
- }
90
-
91
- const unescaped = unescapeBackslash(raw.slice(1, -1), raw.charAt(0));
92
- if (unescaped !== node.value) {
93
- return;
94
- }
95
-
96
- return {
97
- node,
98
- messageId: MESSAGE_ID,
99
- * fix(fixer) {
100
- yield fixSpaceAroundKeyword(fixer, node, context);
101
- yield fixer.replaceText(node, `String.raw\`${unescaped}\``);
102
- },
103
- };
104
- });
105
-
106
- context.on('TemplateLiteral', node => {
107
- if (
108
- (node.parent.type === 'TaggedTemplateExpression' && node.parent.quasi === node)
109
- || node.quasis.every(({value: {cooked, raw}}) => cooked === raw)
110
- || node.quasis.some(({value: {cooked, raw}}) => cooked.at(-1) === BACKSLASH || unescapeBackslash(raw) !== cooked)
111
- ) {
112
- return;
113
- }
114
-
115
- return {
116
- node,
117
- messageId: MESSAGE_ID,
118
- * fix(fixer) {
119
- yield fixSpaceAroundKeyword(fixer, node, context);
120
- yield fixer.insertTextBefore(node, 'String.raw');
121
-
122
- for (const quasis of node.quasis) {
123
- const {cooked, raw} = quasis.value;
124
- if (cooked === raw) {
125
- continue;
126
- }
127
-
128
- yield replaceTemplateElement(quasis, cooked, context, fixer);
129
- }
130
- },
131
- };
132
- });
133
- };
134
-
135
- /** @type {import('eslint').Rule.RuleModule} */
136
- const config = {
137
- create,
138
- meta: {
139
- type: 'suggestion',
140
- docs: {
141
- description: 'Prefer using the `String.raw` tag to avoid escaping `\\`.',
142
- recommended: 'unopinionated',
143
- },
144
- fixable: 'code',
145
- messages,
146
- },
147
- };
148
-
149
- export default config;