@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,380 +0,0 @@
1
- import {
2
- isOpeningBracketToken,
3
- isClosingBracketToken,
4
- getStaticValue,
5
- } from '@eslint-community/eslint-utils';
6
- import {
7
- isParenthesized,
8
- getParenthesizedRange,
9
- getParenthesizedText,
10
- isNodeMatchesNameOrPath,
11
- needsSemicolon,
12
- shouldAddParenthesesToMemberExpressionObject,
13
- isLeftHandSide,
14
- } from './utils/index.js';
15
- import {
16
- getNegativeIndexLengthNode,
17
- removeLengthNode,
18
- } from './shared/negative-index.js';
19
- import {removeMemberExpressionProperty, removeMethodCall} from './fix/index.js';
20
- import {
21
- isLiteral,
22
- isCallExpression,
23
- isMethodCall,
24
- isMemberExpression,
25
- } from './ast/index.js';
26
-
27
- const MESSAGE_ID_NEGATIVE_INDEX = 'negative-index';
28
- const MESSAGE_ID_INDEX = 'index';
29
- const MESSAGE_ID_STRING_CHAR_AT_NEGATIVE = 'string-char-at-negative';
30
- const MESSAGE_ID_STRING_CHAR_AT = 'string-char-at';
31
- const MESSAGE_ID_SLICE = 'slice';
32
- const MESSAGE_ID_GET_LAST_FUNCTION = 'get-last-function';
33
- const SUGGESTION_ID = 'use-at';
34
- const messages = {
35
- [MESSAGE_ID_NEGATIVE_INDEX]: 'Prefer `.at(…)` over `[….length - index]`.',
36
- [MESSAGE_ID_INDEX]: 'Prefer `.at(…)` over index access.',
37
- [MESSAGE_ID_STRING_CHAR_AT_NEGATIVE]: 'Prefer `String#at(…)` over `String#charAt(….length - index)`.',
38
- [MESSAGE_ID_STRING_CHAR_AT]: 'Prefer `String#at(…)` over `String#charAt(…)`.',
39
- [MESSAGE_ID_SLICE]: 'Prefer `.at(…)` over the first element from `.slice(…)`.',
40
- [MESSAGE_ID_GET_LAST_FUNCTION]: 'Prefer `.at(-1)` over `{{description}}(…)` to get the last element.',
41
- [SUGGESTION_ID]: 'Use `.at(…)`.',
42
- };
43
-
44
- const isArguments = node => node.type === 'Identifier' && node.name === 'arguments';
45
-
46
- const isLiteralNegativeInteger = node =>
47
- node.type === 'UnaryExpression'
48
- && node.prefix
49
- && node.operator === '-'
50
- && node.argument.type === 'Literal'
51
- && Number.isInteger(node.argument.value)
52
- && node.argument.value > 0;
53
- const isZeroIndexAccess = node =>
54
- isMemberExpression(node.parent, {
55
- optional: false,
56
- computed: true,
57
- })
58
- && node.parent.object === node
59
- && isLiteral(node.parent.property, 0);
60
-
61
- const isArrayPopOrShiftCall = (node, method) =>
62
- isMethodCall(node.parent.parent, {
63
- method,
64
- argumentsLength: 0,
65
- optionalCall: false,
66
- optionalMember: false,
67
- })
68
- && node.parent.object === node;
69
-
70
- const isArrayPopCall = node => isArrayPopOrShiftCall(node, 'pop');
71
- const isArrayShiftCall = node => isArrayPopOrShiftCall(node, 'shift');
72
-
73
- function checkSliceCall(node) {
74
- const sliceArgumentsLength = node.arguments.length;
75
- const [startIndexNode, endIndexNode] = node.arguments;
76
-
77
- if (!isLiteralNegativeInteger(startIndexNode)) {
78
- return;
79
- }
80
-
81
- let firstElementGetMethod = '';
82
- if (isZeroIndexAccess(node)) {
83
- if (isLeftHandSide(node.parent)) {
84
- return;
85
- }
86
-
87
- firstElementGetMethod = 'zero-index';
88
- } else if (isArrayShiftCall(node)) {
89
- firstElementGetMethod = 'shift';
90
- } else if (isArrayPopCall(node)) {
91
- firstElementGetMethod = 'pop';
92
- }
93
-
94
- if (!firstElementGetMethod) {
95
- return;
96
- }
97
-
98
- const startIndex = -startIndexNode.argument.value;
99
- if (sliceArgumentsLength === 1) {
100
- if (
101
- startIndexNode.argument.value === 1
102
- && (
103
- firstElementGetMethod === 'zero-index'
104
- || firstElementGetMethod === 'shift'
105
- || (startIndex === -1 && firstElementGetMethod === 'pop')
106
- )
107
- ) {
108
- return {safeToFix: true, firstElementGetMethod};
109
- }
110
-
111
- return;
112
- }
113
-
114
- if (
115
- isLiteralNegativeInteger(endIndexNode)
116
- && -endIndexNode.argument.value === startIndex + 1
117
- ) {
118
- return {safeToFix: true, firstElementGetMethod};
119
- }
120
-
121
- if (firstElementGetMethod === 'pop') {
122
- return;
123
- }
124
-
125
- return {safeToFix: false, firstElementGetMethod};
126
- }
127
-
128
- const lodashLastFunctions = [
129
- '_.last',
130
- 'lodash.last',
131
- 'underscore.last',
132
- ];
133
-
134
- /** @param {import('eslint').Rule.RuleContext} context */
135
- function create(context) {
136
- const {
137
- getLastElementFunctions,
138
- checkAllIndexAccess,
139
- } = {
140
- getLastElementFunctions: [],
141
- checkAllIndexAccess: false,
142
- ...context.options[0],
143
- };
144
- const getLastFunctions = [...getLastElementFunctions, ...lodashLastFunctions];
145
- const {sourceCode} = context;
146
-
147
- // Index access
148
- context.on('MemberExpression', node => {
149
- if (
150
- !node.computed
151
- || isLeftHandSide(node)
152
- ) {
153
- return;
154
- }
155
-
156
- const indexNode = node.property;
157
- const lengthNode = getNegativeIndexLengthNode(indexNode, node.object);
158
-
159
- if (!lengthNode) {
160
- if (!checkAllIndexAccess) {
161
- return;
162
- }
163
-
164
- // Only if we are sure it's an positive integer
165
- const staticValue = getStaticValue(indexNode, sourceCode.getScope(indexNode));
166
- if (!staticValue || !Number.isInteger(staticValue.value) || staticValue.value < 0) {
167
- return;
168
- }
169
- }
170
-
171
- const problem = {
172
- node: indexNode,
173
- messageId: lengthNode ? MESSAGE_ID_NEGATIVE_INDEX : MESSAGE_ID_INDEX,
174
- };
175
-
176
- if (isArguments(node.object)) {
177
- return problem;
178
- }
179
-
180
- problem.fix = function * (fixer) {
181
- if (lengthNode) {
182
- yield removeLengthNode(lengthNode, fixer, context);
183
- }
184
-
185
- // Only remove space for `foo[foo.length - 1]`
186
- if (
187
- indexNode.type === 'BinaryExpression'
188
- && indexNode.operator === '-'
189
- && indexNode.left === lengthNode
190
- && indexNode.right.type === 'Literal'
191
- && /^\d+$/.test(indexNode.right.raw)
192
- ) {
193
- const numberNode = indexNode.right;
194
- const tokenBefore = sourceCode.getTokenBefore(numberNode);
195
- if (
196
- tokenBefore.type === 'Punctuator'
197
- && tokenBefore.value === '-'
198
- && /^\s+$/.test(sourceCode.text.slice(sourceCode.getRange(tokenBefore)[1], sourceCode.getRange(numberNode)[0]))
199
- ) {
200
- yield fixer.removeRange([sourceCode.getRange(tokenBefore)[1], sourceCode.getRange(numberNode)[0]]);
201
- }
202
- }
203
-
204
- const isOptional = node.optional;
205
- const openingBracketToken = sourceCode.getTokenBefore(indexNode, isOpeningBracketToken);
206
- yield fixer.replaceText(openingBracketToken, `${isOptional ? '' : '.'}at(`);
207
-
208
- const closingBracketToken = sourceCode.getTokenAfter(indexNode, isClosingBracketToken);
209
- yield fixer.replaceText(closingBracketToken, ')');
210
- };
211
-
212
- return problem;
213
- });
214
-
215
- // `string.charAt`
216
- context.on('CallExpression', node => {
217
- if (!isMethodCall(node, {
218
- method: 'charAt',
219
- argumentsLength: 1,
220
- optionalCall: false,
221
- })) {
222
- return;
223
- }
224
-
225
- const [indexNode] = node.arguments;
226
- const lengthNode = getNegativeIndexLengthNode(indexNode, node.callee.object);
227
-
228
- // `String#charAt` don't care about index value, we assume it's always number
229
- if (!lengthNode && !checkAllIndexAccess) {
230
- return;
231
- }
232
-
233
- return {
234
- node: indexNode,
235
- messageId: lengthNode ? MESSAGE_ID_STRING_CHAR_AT_NEGATIVE : MESSAGE_ID_STRING_CHAR_AT,
236
- suggest: [{
237
- messageId: SUGGESTION_ID,
238
- * fix(fixer) {
239
- if (lengthNode) {
240
- yield removeLengthNode(lengthNode, fixer, context);
241
- }
242
-
243
- yield fixer.replaceText(node.callee.property, 'at');
244
- },
245
- }],
246
- };
247
- });
248
-
249
- // `.slice()`
250
- context.on('CallExpression', sliceCall => {
251
- if (!isMethodCall(sliceCall, {
252
- method: 'slice',
253
- minimumArguments: 1,
254
- maximumArguments: 2,
255
- optionalCall: false,
256
- })) {
257
- return;
258
- }
259
-
260
- const result = checkSliceCall(sliceCall);
261
- if (!result) {
262
- return;
263
- }
264
-
265
- const {safeToFix, firstElementGetMethod} = result;
266
-
267
- /** @param {import('eslint').Rule.RuleFixer} fixer */
268
- function * fix(fixer) {
269
- // `.slice` to `.at`
270
- yield fixer.replaceText(sliceCall.callee.property, 'at');
271
-
272
- // Remove extra arguments
273
- if (sliceCall.arguments.length !== 1) {
274
- const [, start] = getParenthesizedRange(sliceCall.arguments[0], context);
275
- const [end] = sourceCode.getRange(sourceCode.getLastToken(sliceCall));
276
- yield fixer.removeRange([start, end]);
277
- }
278
-
279
- yield (
280
- // Remove `[0]`, `.shift()`, or `.pop()`
281
- firstElementGetMethod === 'zero-index'
282
- ? removeMemberExpressionProperty(fixer, sliceCall.parent, context)
283
- : removeMethodCall(fixer, sliceCall.parent.parent, context)
284
- );
285
- }
286
-
287
- const problem = {
288
- node: sliceCall.callee.property,
289
- messageId: MESSAGE_ID_SLICE,
290
- };
291
-
292
- if (safeToFix) {
293
- problem.fix = fix;
294
- } else {
295
- problem.suggest = [{messageId: SUGGESTION_ID, fix}];
296
- }
297
-
298
- return problem;
299
- });
300
-
301
- context.on('CallExpression', node => {
302
- if (!isCallExpression(node, {argumentsLength: 1, optional: false})) {
303
- return;
304
- }
305
-
306
- const matchedFunction = getLastFunctions.find(nameOrPath => isNodeMatchesNameOrPath(node.callee, nameOrPath));
307
- if (!matchedFunction) {
308
- return;
309
- }
310
-
311
- const problem = {
312
- node: node.callee,
313
- messageId: MESSAGE_ID_GET_LAST_FUNCTION,
314
- data: {description: matchedFunction.trim()},
315
- };
316
-
317
- const [array] = node.arguments;
318
-
319
- if (isArguments(array)) {
320
- return problem;
321
- }
322
-
323
- problem.fix = function (fixer) {
324
- let fixed = getParenthesizedText(array, context);
325
-
326
- if (
327
- !isParenthesized(array, sourceCode)
328
- && shouldAddParenthesesToMemberExpressionObject(array, context)
329
- ) {
330
- fixed = `(${fixed})`;
331
- }
332
-
333
- fixed = `${fixed}.at(-1)`;
334
-
335
- const tokenBefore = sourceCode.getTokenBefore(node);
336
- if (needsSemicolon(tokenBefore, context, fixed)) {
337
- fixed = `;${fixed}`;
338
- }
339
-
340
- return fixer.replaceText(node, fixed);
341
- };
342
-
343
- return problem;
344
- });
345
- }
346
-
347
- const schema = [
348
- {
349
- type: 'object',
350
- additionalProperties: false,
351
- properties: {
352
- getLastElementFunctions: {
353
- type: 'array',
354
- uniqueItems: true,
355
- },
356
- checkAllIndexAccess: {
357
- type: 'boolean',
358
- },
359
- },
360
- },
361
- ];
362
-
363
- /** @type {import('eslint').Rule.RuleModule} */
364
- const config = {
365
- create,
366
- meta: {
367
- type: 'suggestion',
368
- docs: {
369
- description: 'Prefer `.at()` method for index access and `String#charAt()`.',
370
- recommended: 'unopinionated',
371
- },
372
- fixable: 'code',
373
- hasSuggestions: true,
374
- schema,
375
- defaultOptions: [{getLastElementFunctions: [], checkAllIndexAccess: false}],
376
- messages,
377
- },
378
- };
379
-
380
- export default config;
@@ -1,129 +0,0 @@
1
- import {
2
- isCallExpression,
3
- isStringLiteral,
4
- } from './ast/index.js';
5
-
6
- const MESSAGE_ID_ERROR = 'prefer-bigint-literals/error';
7
- const MESSAGE_ID_SUGGESTION = 'prefer-bigint-literals/suggestion';
8
- const messages = {
9
- [MESSAGE_ID_ERROR]: 'Prefer using bigint literal over `BigInt(…)`.',
10
- [MESSAGE_ID_SUGGESTION]: 'Replace with {{replacement}}.',
11
- };
12
-
13
- const canUseNumericLiteralRaw = numericLiteral => {
14
- const raw = numericLiteral.raw.replaceAll('_', '').toLowerCase();
15
-
16
- if (raw.includes('.')) {
17
- return false;
18
- }
19
-
20
- const {value} = numericLiteral;
21
-
22
- for (const {prefix, base} of [
23
- {prefix: '0b', base: 2},
24
- {prefix: '0o', base: 8},
25
- {prefix: '0x', base: 16},
26
- ]) {
27
- if (raw.startsWith(prefix)) {
28
- return raw.slice(2) === value.toString(base);
29
- }
30
- }
31
-
32
- if (raw.includes('e')) {
33
- return false;
34
- }
35
-
36
- return raw === String(value);
37
- };
38
-
39
- function getReplacement(valueNode) {
40
- if (isStringLiteral(valueNode)) {
41
- const raw = valueNode.raw.slice(1, -1);
42
- try {
43
- BigInt(raw);
44
- } catch {
45
- return;
46
- }
47
-
48
- return {shouldUseSuggestion: false, text: `${raw.trimEnd()}n`};
49
- }
50
-
51
- const {value, raw} = valueNode;
52
-
53
- if (!Number.isInteger(value)) {
54
- return;
55
- }
56
-
57
- let bigint;
58
- try {
59
- bigint = BigInt(value);
60
- } catch {
61
- return;
62
- }
63
-
64
- const shouldUseSuggestion = !canUseNumericLiteralRaw(valueNode);
65
- const text = shouldUseSuggestion ? `${bigint}n` : `${raw}n`;
66
- return {shouldUseSuggestion, text};
67
- }
68
-
69
- /** @param {import('eslint').Rule.RuleContext} context */
70
- const create = context => ({
71
- CallExpression(callExpression) {
72
- if (!isCallExpression(callExpression, {
73
- name: 'BigInt',
74
- argumentsLength: 1,
75
- optional: false,
76
- })) {
77
- return;
78
- }
79
-
80
- const [valueNode] = callExpression.arguments;
81
- const replacement = getReplacement(valueNode);
82
- if (!replacement) {
83
- return;
84
- }
85
-
86
- const problem = {
87
- node: callExpression,
88
- messageId: MESSAGE_ID_ERROR,
89
- };
90
-
91
- const {shouldUseSuggestion, text} = replacement;
92
-
93
- /** @param {import('eslint').Rule.RuleFixer} fixer */
94
- const fix = fixer => fixer.replaceText(callExpression, text);
95
-
96
- if (shouldUseSuggestion || context.sourceCode.getCommentsInside(callExpression).length > 0) {
97
- problem.suggest = [
98
- {
99
- messageId: MESSAGE_ID_SUGGESTION,
100
- data: {
101
- replacement: text.length < 20 ? `\`${text}\`` : 'a bigint literal',
102
- },
103
- fix,
104
- },
105
- ];
106
- } else {
107
- problem.fix = fix;
108
- }
109
-
110
- return problem;
111
- },
112
- });
113
-
114
- /** @type {import('eslint').Rule.RuleModule} */
115
- const config = {
116
- create,
117
- meta: {
118
- type: 'suggestion',
119
- docs: {
120
- description: 'Prefer `BigInt` literals over the constructor.',
121
- recommended: 'unopinionated',
122
- },
123
- fixable: 'code',
124
- hasSuggestions: true,
125
- messages,
126
- },
127
- };
128
-
129
- export default config;
@@ -1,47 +0,0 @@
1
- import {isMethodCall} from './ast/index.js';
2
-
3
- const MESSAGE_ID = 'error';
4
- const messages = {
5
- [MESSAGE_ID]: 'Prefer `Blob#{{replacement}}()` over `FileReader#{{method}}(blob)`.',
6
- };
7
-
8
- /** @param {import('eslint').Rule.RuleContext} context */
9
- const create = () => ({
10
- CallExpression(node) {
11
- if (!isMethodCall(node, {
12
- methods: ['readAsText', 'readAsArrayBuffer'],
13
- argumentsLength: 1,
14
- optionalCall: false,
15
- optionalMember: false,
16
- })) {
17
- return;
18
- }
19
-
20
- const method = node.callee.property;
21
- const methodName = method.name;
22
-
23
- return {
24
- node: method,
25
- messageId: MESSAGE_ID,
26
- data: {
27
- method: methodName,
28
- replacement: methodName === 'readAsArrayBuffer' ? 'arrayBuffer' : 'text',
29
- },
30
- };
31
- },
32
- });
33
-
34
- /** @type {import('eslint').Rule.RuleModule} */
35
- const config = {
36
- create,
37
- meta: {
38
- type: 'suggestion',
39
- docs: {
40
- description: 'Prefer `Blob#arrayBuffer()` over `FileReader#readAsArrayBuffer(…)` and `Blob#text()` over `FileReader#readAsText(…)`.',
41
- recommended: 'unopinionated',
42
- },
43
- messages,
44
- },
45
- };
46
-
47
- export default config;
@@ -1,158 +0,0 @@
1
- import {isSemicolonToken} from '@eslint-community/eslint-utils';
2
- import getIndentString from './utils/get-indent-string.js';
3
-
4
- const MESSAGE_ID_ERROR = 'prefer-class-fields/error';
5
- const MESSAGE_ID_SUGGESTION = 'prefer-class-fields/suggestion';
6
- const messages = {
7
- [MESSAGE_ID_ERROR]:
8
- 'Prefer class field declaration over `this` assignment in constructor for static values.',
9
- [MESSAGE_ID_SUGGESTION]:
10
- 'Encountered same-named class field declaration and `this` assignment in constructor. Replace the class field declaration with the value from `this` assignment.',
11
- };
12
-
13
- /**
14
- @param {import('eslint').Rule.Node} node
15
- @param {import('eslint').Rule.RuleContext['sourceCode']} sourceCode
16
- @param {import('eslint').Rule.RuleFixer} fixer
17
- */
18
- const removeFieldAssignment = (node, sourceCode, fixer) => {
19
- const {line} = sourceCode.getLoc(node).start;
20
- const nodeText = sourceCode.getText(node);
21
- const lineText = sourceCode.lines[line - 1];
22
- const isOnlyNodeOnLine = lineText.trim() === nodeText;
23
-
24
- return isOnlyNodeOnLine
25
- ? fixer.removeRange([
26
- sourceCode.getIndexFromLoc({line, column: 0}),
27
- sourceCode.getIndexFromLoc({line: line + 1, column: 0}),
28
- ])
29
- : fixer.remove(node);
30
- };
31
-
32
- /**
33
- @type {import('eslint').Rule.RuleModule['create']}
34
- */
35
- const create = context => {
36
- const {sourceCode} = context;
37
-
38
- return {
39
- ClassBody(classBody) {
40
- const constructor = classBody.body.find(node =>
41
- node.kind === 'constructor'
42
- && !node.computed
43
- && !node.static
44
- && node.type === 'MethodDefinition'
45
- && node.value.type === 'FunctionExpression',
46
- );
47
-
48
- if (!constructor) {
49
- return;
50
- }
51
-
52
- const node = constructor.value.body.body.find(node => node.type !== 'EmptyStatement');
53
-
54
- if (!(
55
- node?.type === 'ExpressionStatement'
56
- && node.expression.type === 'AssignmentExpression'
57
- && node.expression.operator === '='
58
- && node.expression.left.type === 'MemberExpression'
59
- && node.expression.left.object.type === 'ThisExpression'
60
- && !node.expression.left.computed
61
- && ['Identifier', 'PrivateIdentifier'].includes(node.expression.left.property.type)
62
- && node.expression.right.type === 'Literal'
63
- )) {
64
- return;
65
- }
66
-
67
- const propertyName = node.expression.left.property.name;
68
- const propertyValue = node.expression.right.raw;
69
- const propertyType = node.expression.left.property.type;
70
- const existingProperty = classBody.body.find(node =>
71
- node.type === 'PropertyDefinition'
72
- && !node.computed
73
- && !node.static
74
- && node.key.type === propertyType
75
- && node.key.name === propertyName,
76
- );
77
-
78
- const problem = {
79
- node,
80
- messageId: MESSAGE_ID_ERROR,
81
- };
82
-
83
- /**
84
- @param {import('eslint').Rule.RuleFixer} fixer
85
- */
86
- function * fix(fixer) {
87
- yield removeFieldAssignment(node, sourceCode, fixer);
88
-
89
- if (existingProperty) {
90
- if (existingProperty.value) {
91
- yield fixer.replaceText(existingProperty.value, propertyValue);
92
- return;
93
- }
94
-
95
- const text = ` = ${propertyValue}`;
96
- const lastToken = sourceCode.getLastToken(existingProperty);
97
- if (isSemicolonToken(lastToken)) {
98
- yield fixer.insertTextBefore(lastToken, text);
99
- return;
100
- }
101
-
102
- yield fixer.insertTextAfter(existingProperty, `${text};`);
103
- return;
104
- }
105
-
106
- const closingBrace = sourceCode.getLastToken(classBody);
107
- const indent = getIndentString(constructor, context);
108
-
109
- let text = `${indent}${propertyName} = ${propertyValue};\n`;
110
-
111
- const characterBefore = sourceCode.getText()[sourceCode.getRange(closingBrace)[0] - 1];
112
- if (characterBefore !== '\n') {
113
- text = `\n${text}`;
114
- }
115
-
116
- const lastProperty = classBody.body.at(-1);
117
- if (
118
- lastProperty.type === 'PropertyDefinition'
119
- && sourceCode.getLastToken(lastProperty).value !== ';'
120
- ) {
121
- text = `;${text}`;
122
- }
123
-
124
- yield fixer.insertTextBefore(closingBrace, text);
125
- }
126
-
127
- if (existingProperty?.value) {
128
- problem.suggest = [
129
- {
130
- messageId: MESSAGE_ID_SUGGESTION,
131
- fix,
132
- },
133
- ];
134
- return problem;
135
- }
136
-
137
- problem.fix = fix;
138
- return problem;
139
- },
140
- };
141
- };
142
-
143
- /** @type {import('eslint').Rule.RuleModule} */
144
- const config = {
145
- create,
146
- meta: {
147
- type: 'suggestion',
148
- docs: {
149
- description: 'Prefer class field declarations over `this` assignments in constructors.',
150
- recommended: 'unopinionated',
151
- },
152
- fixable: 'code',
153
- hasSuggestions: true,
154
- messages,
155
- },
156
- };
157
-
158
- export default config;