@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,77 +0,0 @@
1
- import {isOpeningParenToken, isClosingParenToken} from '@eslint-community/eslint-utils';
2
- import assertToken from './utils/assert-token.js';
3
-
4
- const MESSAGE_ID_WITH_NAME = 'with-name';
5
- const MESSAGE_ID_WITHOUT_NAME = 'without-name';
6
- const messages = {
7
- [MESSAGE_ID_WITH_NAME]: 'Remove unused catch binding `{{name}}`.',
8
- [MESSAGE_ID_WITHOUT_NAME]: 'Remove unused catch binding.',
9
- };
10
-
11
- /** @param {import('eslint').Rule.RuleContext} context */
12
- const create = context => ({
13
- CatchClause(catchClause) {
14
- const node = catchClause.param;
15
- if (!node) {
16
- return;
17
- }
18
-
19
- const {sourceCode} = context;
20
- const variables = sourceCode.getDeclaredVariables(node.parent);
21
-
22
- if (variables.some(variable => variable.references.length > 0)) {
23
- return;
24
- }
25
-
26
- const {type, name, parent} = node;
27
-
28
- return {
29
- node,
30
- messageId: type === 'Identifier' ? MESSAGE_ID_WITH_NAME : MESSAGE_ID_WITHOUT_NAME,
31
- data: {name},
32
- * fix(fixer) {
33
- const tokenBefore = sourceCode.getTokenBefore(node);
34
- assertToken(tokenBefore, {
35
- test: isOpeningParenToken,
36
- expected: '(',
37
- ruleId: 'prefer-optional-catch-binding',
38
- });
39
-
40
- const tokenAfter = sourceCode.getTokenAfter(node);
41
- assertToken(tokenAfter, {
42
- test: isClosingParenToken,
43
- expected: ')',
44
- ruleId: 'prefer-optional-catch-binding',
45
- });
46
-
47
- yield fixer.remove(tokenBefore);
48
- yield fixer.remove(node);
49
- yield fixer.remove(tokenAfter);
50
-
51
- const [, endOfClosingParenthesis] = sourceCode.getRange(tokenAfter);
52
- const [startOfCatchClauseBody] = sourceCode.getRange(parent.body);
53
- const text = sourceCode.text.slice(endOfClosingParenthesis, startOfCatchClauseBody);
54
- const leadingSpacesLength = text.length - text.trimStart().length;
55
- if (leadingSpacesLength !== 0) {
56
- yield fixer.removeRange([endOfClosingParenthesis, endOfClosingParenthesis + leadingSpacesLength]);
57
- }
58
- },
59
- };
60
- },
61
- });
62
-
63
- /** @type {import('eslint').Rule.RuleModule} */
64
- const config = {
65
- create,
66
- meta: {
67
- type: 'suggestion',
68
- docs: {
69
- description: 'Prefer omitting the `catch` binding parameter.',
70
- recommended: 'unopinionated',
71
- },
72
- fixable: 'code',
73
- messages,
74
- },
75
- };
76
-
77
- export default config;
@@ -1,162 +0,0 @@
1
- import {getPropertyName, ReferenceTracker} from '@eslint-community/eslint-utils';
2
- import {fixSpaceAroundKeyword} from './fix/index.js';
3
- import {isMemberExpression, isMethodCall} from './ast/index.js';
4
-
5
- const messages = {
6
- 'known-method': 'Prefer using `{{constructorName}}.prototype.{{methodName}}`.',
7
- 'unknown-method': 'Prefer using method from `{{constructorName}}.prototype`.',
8
- };
9
-
10
- const OBJECT_PROTOTYPE_METHODS = [
11
- 'hasOwnProperty',
12
- 'isPrototypeOf',
13
- 'propertyIsEnumerable',
14
- 'toLocaleString',
15
- 'toString',
16
- 'valueOf',
17
- ];
18
-
19
- function getConstructorAndMethodName(methodNode, {context, globalReferences}) {
20
- if (!methodNode) {
21
- return;
22
- }
23
-
24
- const isGlobalReference = globalReferences.has(methodNode);
25
- if (isGlobalReference) {
26
- const path = globalReferences.get(methodNode);
27
- return {
28
- isGlobalReference: true,
29
- constructorName: 'Object',
30
- methodName: path.at(-1),
31
- };
32
- }
33
-
34
- if (!isMemberExpression(methodNode, {optional: false})) {
35
- return;
36
- }
37
-
38
- const objectNode = methodNode.object;
39
-
40
- if (!(
41
- (objectNode.type === 'ArrayExpression' && objectNode.elements.length === 0)
42
- || (objectNode.type === 'ObjectExpression' && objectNode.properties.length === 0)
43
- )) {
44
- return;
45
- }
46
-
47
- const constructorName = objectNode.type === 'ArrayExpression' ? 'Array' : 'Object';
48
- const methodName = getPropertyName(methodNode, context.sourceCode.getScope(methodNode));
49
-
50
- return {
51
- constructorName,
52
- methodName,
53
- };
54
- }
55
-
56
- function getProblem(callExpression, {context, globalReferences}) {
57
- let methodNode;
58
-
59
- if (
60
- // `Reflect.apply([].foo, …)`
61
- // `Reflect.apply({}.foo, …)`
62
- isMethodCall(callExpression, {
63
- object: 'Reflect',
64
- method: 'apply',
65
- minimumArguments: 1,
66
- optionalCall: false,
67
- optionalMember: false,
68
- })
69
- ) {
70
- methodNode = callExpression.arguments[0];
71
- } else if (
72
- // `[].foo.{apply,bind,call}(…)`
73
- // `({}).foo.{apply,bind,call}(…)`
74
- isMethodCall(callExpression, {
75
- methods: ['apply', 'bind', 'call'],
76
- optionalCall: false,
77
- optionalMember: false,
78
- })
79
- ) {
80
- methodNode = callExpression.callee.object;
81
- }
82
-
83
- const {
84
- isGlobalReference,
85
- constructorName,
86
- methodName,
87
- } = getConstructorAndMethodName(methodNode, {context, globalReferences}) ?? {};
88
-
89
- if (!constructorName) {
90
- return;
91
- }
92
-
93
- return {
94
- node: methodNode,
95
- messageId: methodName ? 'known-method' : 'unknown-method',
96
- data: {constructorName, methodName},
97
- * fix(fixer) {
98
- if (isGlobalReference) {
99
- yield fixer.replaceText(methodNode, `${constructorName}.prototype.${methodName}`);
100
- return;
101
- }
102
-
103
- if (isMemberExpression(methodNode)) {
104
- const objectNode = methodNode.object;
105
-
106
- yield fixer.replaceText(objectNode, `${constructorName}.prototype`);
107
-
108
- if (
109
- objectNode.type === 'ArrayExpression'
110
- || objectNode.type === 'ObjectExpression'
111
- ) {
112
- yield fixSpaceAroundKeyword(fixer, callExpression, context);
113
- }
114
- }
115
- },
116
- };
117
- }
118
-
119
- /** @param {import('eslint').Rule.RuleContext} context */
120
- function create(context) {
121
- const {sourceCode} = context;
122
- const callExpressions = [];
123
-
124
- context.on('CallExpression', callExpression => {
125
- callExpressions.push(callExpression);
126
- });
127
-
128
- context.onExit('Program', function * (program) {
129
- const globalReferences = new WeakMap();
130
-
131
- const tracker = new ReferenceTracker(sourceCode.getScope(program));
132
-
133
- for (const {node, path} of tracker.iterateGlobalReferences(
134
- Object.fromEntries(OBJECT_PROTOTYPE_METHODS.map(method => [method, {[ReferenceTracker.READ]: true}])),
135
- )) {
136
- globalReferences.set(node, path);
137
- }
138
-
139
- for (const callExpression of callExpressions) {
140
- yield getProblem(callExpression, {
141
- context,
142
- globalReferences,
143
- });
144
- }
145
- });
146
- }
147
-
148
- /** @type {import('eslint').Rule.RuleModule} */
149
- const config = {
150
- create,
151
- meta: {
152
- type: 'suggestion',
153
- docs: {
154
- description: 'Prefer borrowing methods from the prototype instead of the instance.',
155
- recommended: 'unopinionated',
156
- },
157
- fixable: 'code',
158
- messages,
159
- },
160
- };
161
-
162
- export default config;
@@ -1,170 +0,0 @@
1
- import {isNodeValueNotDomNode} from './utils/index.js';
2
- import {isMethodCall, isStringLiteral, isNullLiteral} from './ast/index.js';
3
-
4
- const MESSAGE_ID = 'prefer-query-selector';
5
- const messages = {
6
- [MESSAGE_ID]: 'Prefer `.{{replacement}}()` over `.{{method}}()`.',
7
- };
8
-
9
- const disallowedIdentifierNames = new Map([
10
- ['getElementById', 'querySelector'],
11
- ['getElementsByClassName', 'querySelectorAll'],
12
- ['getElementsByTagName', 'querySelectorAll'],
13
- ['getElementsByName', 'querySelectorAll'],
14
- ]);
15
-
16
- const getReplacementForId = value => `#${value}`;
17
- const getReplacementForClass = value => value.match(/\S+/g).map(className => `.${className}`).join('');
18
- const getReplacementForName = (value, originQuote) => `[name=${wrapQuoted(value, originQuote)}]`;
19
-
20
- const getQuotedReplacement = (node, value) => {
21
- const leftQuote = node.raw.charAt(0);
22
- const rightQuote = node.raw.at(-1);
23
- return `${leftQuote}${value}${rightQuote}`;
24
- };
25
-
26
- const wrapQuoted = (value, originalQuote) => {
27
- switch (originalQuote) {
28
- case '\'': {
29
- return `"${value}"`;
30
- }
31
-
32
- case '"': {
33
- return `'${value}'`;
34
- }
35
-
36
- case '`': {
37
- return `'${value}'`;
38
- }
39
-
40
- // No default
41
- }
42
- };
43
-
44
- function * getLiteralFix(fixer, node, identifierName) {
45
- let replacement = node.raw;
46
- if (identifierName === 'getElementById') {
47
- replacement = getQuotedReplacement(node, getReplacementForId(node.value));
48
- }
49
-
50
- if (identifierName === 'getElementsByClassName') {
51
- replacement = getQuotedReplacement(node, getReplacementForClass(node.value));
52
- }
53
-
54
- if (identifierName === 'getElementsByName') {
55
- const quoted = node.raw.charAt(0);
56
- replacement = getQuotedReplacement(node, getReplacementForName(node.value, quoted));
57
- }
58
-
59
- yield fixer.replaceText(node, replacement);
60
- }
61
-
62
- function * getTemplateLiteralFix(fixer, node, identifierName) {
63
- yield fixer.insertTextAfter(node, '`');
64
- yield fixer.insertTextBefore(node, '`');
65
-
66
- for (const templateElement of node.quasis) {
67
- if (identifierName === 'getElementById') {
68
- yield fixer.replaceText(
69
- templateElement,
70
- getReplacementForId(templateElement.value.cooked),
71
- );
72
- }
73
-
74
- if (identifierName === 'getElementsByClassName') {
75
- yield fixer.replaceText(
76
- templateElement,
77
- getReplacementForClass(templateElement.value.cooked),
78
- );
79
- }
80
-
81
- if (identifierName === 'getElementsByName') {
82
- const quoted = node.raw ? node.raw.charAt(0) : '"';
83
- yield fixer.replaceText(
84
- templateElement,
85
- getReplacementForName(templateElement.value.cooked, quoted),
86
- );
87
- }
88
- }
89
- }
90
-
91
- const canBeFixed = node =>
92
- isNullLiteral(node)
93
- || (isStringLiteral(node) && Boolean(node.value.trim()))
94
- || (
95
- node.type === 'TemplateLiteral'
96
- && node.expressions.length === 0
97
- && node.quasis.some(templateElement => templateElement.value.cooked.trim())
98
- );
99
-
100
- const hasValue = node => {
101
- if (node.type === 'Literal') {
102
- return node.value;
103
- }
104
-
105
- return true;
106
- };
107
-
108
- const fix = (node, identifierName, preferredSelector) => {
109
- const nodeToBeFixed = node.arguments[0];
110
- if (identifierName === 'getElementsByTagName' || !hasValue(nodeToBeFixed)) {
111
- return fixer => fixer.replaceText(node.callee.property, preferredSelector);
112
- }
113
-
114
- const getArgumentFix = nodeToBeFixed.type === 'Literal' ? getLiteralFix : getTemplateLiteralFix;
115
- return function * (fixer) {
116
- yield getArgumentFix(fixer, nodeToBeFixed, identifierName);
117
- yield fixer.replaceText(node.callee.property, preferredSelector);
118
- };
119
- };
120
-
121
- /** @param {import('eslint').Rule.RuleContext} context */
122
- const create = () => ({
123
- CallExpression(node) {
124
- if (
125
- !isMethodCall(node, {
126
- methods: ['getElementById', 'getElementsByClassName', 'getElementsByTagName', 'getElementsByName'],
127
- argumentsLength: 1,
128
- optionalCall: false,
129
- optionalMember: false,
130
- })
131
- || isNodeValueNotDomNode(node.callee.object)
132
- ) {
133
- return;
134
- }
135
-
136
- const method = node.callee.property.name;
137
- const preferredSelector = disallowedIdentifierNames.get(method);
138
-
139
- const problem = {
140
- node: node.callee.property,
141
- messageId: MESSAGE_ID,
142
- data: {
143
- replacement: preferredSelector,
144
- method,
145
- },
146
- };
147
-
148
- if (canBeFixed(node.arguments[0])) {
149
- problem.fix = fix(node, method, preferredSelector);
150
- }
151
-
152
- return problem;
153
- },
154
- });
155
-
156
- /** @type {import('eslint').Rule.RuleModule} */
157
- const config = {
158
- create,
159
- meta: {
160
- type: 'suggestion',
161
- docs: {
162
- description: 'Prefer `.querySelector()` over `.getElementById()`, `.querySelectorAll()` over `.getElementsByClassName()` and `.getElementsByTagName()` and `.getElementsByName()`.',
163
- recommended: true,
164
- },
165
- fixable: 'code',
166
- messages,
167
- },
168
- };
169
-
170
- export default config;
@@ -1,99 +0,0 @@
1
- import {getPropertyName} from '@eslint-community/eslint-utils';
2
- import {isNullLiteral, isMethodCall} from './ast/index.js';
3
-
4
- const MESSAGE_ID = 'prefer-reflect-apply';
5
- const messages = {
6
- [MESSAGE_ID]: 'Prefer `Reflect.apply()` over `Function#apply()`.',
7
- };
8
-
9
- const isApplySignature = (argument1, argument2) => (
10
- (
11
- isNullLiteral(argument1)
12
- || argument1.type === 'ThisExpression'
13
- )
14
- && (
15
- argument2.type === 'ArrayExpression'
16
- || (argument2.type === 'Identifier' && argument2.name === 'arguments')
17
- )
18
- );
19
-
20
- const getReflectApplyCall = (sourceCode, target, receiver, argumentsList) => (
21
- `Reflect.apply(${sourceCode.getText(target)}, ${sourceCode.getText(receiver)}, ${sourceCode.getText(argumentsList)})`
22
- );
23
-
24
- const fixDirectApplyCall = (node, sourceCode) => {
25
- if (
26
- getPropertyName(node.callee) === 'apply'
27
- && node.arguments.length === 2
28
- && isApplySignature(node.arguments[0], node.arguments[1])
29
- ) {
30
- return fixer => (
31
- fixer.replaceText(
32
- node,
33
- getReflectApplyCall(sourceCode, node.callee.object, node.arguments[0], node.arguments[1]),
34
- )
35
- );
36
- }
37
- };
38
-
39
- const fixFunctionPrototypeCall = (node, sourceCode) => {
40
- if (
41
- getPropertyName(node.callee) === 'call'
42
- && getPropertyName(node.callee.object) === 'apply'
43
- && getPropertyName(node.callee.object.object) === 'prototype'
44
- && node.callee.object.object.object?.type === 'Identifier'
45
- && node.callee.object.object.object.name === 'Function'
46
- && node.arguments.length === 3
47
- && isApplySignature(node.arguments[1], node.arguments[2])
48
- ) {
49
- return fixer => (
50
- fixer.replaceText(
51
- node,
52
- getReflectApplyCall(sourceCode, node.arguments[0], node.arguments[1], node.arguments[2]),
53
- )
54
- );
55
- }
56
- };
57
-
58
- /** @param {import('eslint').Rule.RuleContext} context */
59
- const create = context => ({
60
- CallExpression(node) {
61
- if (
62
- !isMethodCall(node, {
63
- optionalCall: false,
64
- optionalMember: false,
65
- })
66
- || node.callee.object.type === 'Literal'
67
- || node.callee.object.type === 'ArrayExpression'
68
- || node.callee.object.type === 'ObjectExpression'
69
- ) {
70
- return;
71
- }
72
-
73
- const {sourceCode} = context;
74
- const fix = fixDirectApplyCall(node, sourceCode) || fixFunctionPrototypeCall(node, sourceCode);
75
- if (fix) {
76
- return {
77
- node,
78
- messageId: MESSAGE_ID,
79
- fix,
80
- };
81
- }
82
- },
83
- });
84
-
85
- /** @type {import('eslint').Rule.RuleModule} */
86
- const config = {
87
- create,
88
- meta: {
89
- type: 'suggestion',
90
- docs: {
91
- description: 'Prefer `Reflect.apply()` over `Function#apply()`.',
92
- recommended: 'unopinionated',
93
- },
94
- fixable: 'code',
95
- messages,
96
- },
97
- };
98
-
99
- export default config;
@@ -1,155 +0,0 @@
1
- import {isParenthesized, getStaticValue} from '@eslint-community/eslint-utils';
2
- import {checkVueTemplate} from './utils/rule.js';
3
- import {isRegexLiteral, isNewExpression, isMethodCall} from './ast/index.js';
4
- import {isBooleanNode, shouldAddParenthesesToMemberExpressionObject} from './utils/index.js';
5
-
6
- const REGEXP_EXEC = 'regexp-exec';
7
- const STRING_MATCH = 'string-match';
8
- const SUGGESTION = 'suggestion';
9
- const messages = {
10
- [REGEXP_EXEC]: 'Prefer `.test(…)` over `.exec(…)`.',
11
- [STRING_MATCH]: 'Prefer `RegExp#test(…)` over `String#match(…)`.',
12
- [SUGGESTION]: 'Switch to `RegExp#test(…)`.',
13
- };
14
-
15
- const cases = [
16
- {
17
- type: REGEXP_EXEC,
18
- test: node => isMethodCall(node, {
19
- method: 'exec',
20
- argumentsLength: 1,
21
- optionalCall: false,
22
- optionalMember: false,
23
- }),
24
- getNodes: node => ({
25
- stringNode: node.arguments[0],
26
- methodNode: node.callee.property,
27
- regexpNode: node.callee.object,
28
- }),
29
- fix: (fixer, {methodNode}) => fixer.replaceText(methodNode, 'test'),
30
- },
31
- {
32
- type: STRING_MATCH,
33
- test: node => isMethodCall(node, {
34
- method: 'match',
35
- argumentsLength: 1,
36
- optionalCall: false,
37
- optionalMember: false,
38
- }),
39
- getNodes: node => ({
40
- stringNode: node.callee.object,
41
- methodNode: node.callee.property,
42
- regexpNode: node.arguments[0],
43
- }),
44
- * fix(fixer, {stringNode, methodNode, regexpNode}, context) {
45
- const {sourceCode} = context;
46
- yield fixer.replaceText(methodNode, 'test');
47
-
48
- let stringText = sourceCode.getText(stringNode);
49
- if (
50
- !isParenthesized(regexpNode, sourceCode)
51
- // Only `SequenceExpression` need add parentheses
52
- && stringNode.type === 'SequenceExpression'
53
- ) {
54
- stringText = `(${stringText})`;
55
- }
56
-
57
- yield fixer.replaceText(regexpNode, stringText);
58
-
59
- let regexpText = sourceCode.getText(regexpNode);
60
- if (
61
- !isParenthesized(stringNode, sourceCode)
62
- && shouldAddParenthesesToMemberExpressionObject(regexpNode, context)
63
- ) {
64
- regexpText = `(${regexpText})`;
65
- }
66
-
67
- // The nodes that pass `isBooleanNode` cannot have an ASI problem.
68
-
69
- yield fixer.replaceText(stringNode, regexpText);
70
- },
71
- },
72
- ];
73
-
74
- const isRegExpNode = node => isRegexLiteral(node) || isNewExpression(node, {name: 'RegExp'});
75
-
76
- const isRegExpWithoutGlobalFlag = (node, scope) => {
77
- if (isRegexLiteral(node)) {
78
- return !node.regex.flags.includes('g');
79
- }
80
-
81
- const staticResult = getStaticValue(node, scope);
82
-
83
- // Don't know if there is `g` flag
84
- if (!staticResult) {
85
- return false;
86
- }
87
-
88
- const {value} = staticResult;
89
- return (
90
- Object.prototype.toString.call(value) === '[object RegExp]'
91
- && !value.global
92
- );
93
- };
94
-
95
- /** @param {import('eslint').Rule.RuleContext} context */
96
- const create = context => ({
97
- * CallExpression(node) {
98
- if (!isBooleanNode(node)) {
99
- return;
100
- }
101
-
102
- for (const {type, test, getNodes, fix} of cases) {
103
- if (!test(node)) {
104
- continue;
105
- }
106
-
107
- const nodes = getNodes(node);
108
- const {methodNode, regexpNode} = nodes;
109
-
110
- if (regexpNode.type === 'Literal' && !regexpNode.regex) {
111
- continue;
112
- }
113
-
114
- const problem = {
115
- node: type === REGEXP_EXEC ? methodNode : node,
116
- messageId: type,
117
- };
118
-
119
- const fixFunction = fixer => fix(fixer, nodes, context);
120
-
121
- if (
122
- isRegExpNode(regexpNode)
123
- || isRegExpWithoutGlobalFlag(regexpNode, context.sourceCode.getScope(regexpNode))
124
- ) {
125
- problem.fix = fixFunction;
126
- } else {
127
- problem.suggest = [
128
- {
129
- messageId: SUGGESTION,
130
- fix: fixFunction,
131
- },
132
- ];
133
- }
134
-
135
- yield problem;
136
- }
137
- },
138
- });
139
-
140
- /** @type {import('eslint').Rule.RuleModule} */
141
- const config = {
142
- create: checkVueTemplate(create),
143
- meta: {
144
- type: 'suggestion',
145
- docs: {
146
- description: 'Prefer `RegExp#test()` over `String#match()` and `RegExp#exec()`.',
147
- recommended: 'unopinionated',
148
- },
149
- fixable: 'code',
150
- hasSuggestions: true,
151
- messages,
152
- },
153
- };
154
-
155
- export default config;