@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,160 +0,0 @@
1
- const MESSAGE_ID_ERROR = 'no-accessor-recursion/error';
2
- const messages = {
3
- [MESSAGE_ID_ERROR]: 'Disallow recursive access to `this` within {{kind}}ters.',
4
- };
5
-
6
- /**
7
- Get the closest non-arrow function scope.
8
-
9
- @param {import('eslint').SourceCode} sourceCode
10
- @param {import('estree').Node} node
11
- @return {import('eslint').Scope.Scope | undefined}
12
- */
13
- const getClosestFunctionScope = (sourceCode, node) => {
14
- for (let scope = sourceCode.getScope(node); scope; scope = scope.upper) {
15
- if (scope.type === 'class') {
16
- return;
17
- }
18
-
19
- if (scope.type === 'function' && scope.block.type !== 'ArrowFunctionExpression') {
20
- return scope;
21
- }
22
- }
23
- };
24
-
25
- /** @param {import('estree').Identifier | import('estree').PrivateIdentifier} node */
26
- const isIdentifier = node => node.type === 'Identifier' || node.type === 'PrivateIdentifier';
27
-
28
- /** @param {import('estree').ThisExpression} node */
29
- const isDotNotationAccess = node =>
30
- node.parent.type === 'MemberExpression'
31
- && node.parent.object === node
32
- && !node.parent.computed
33
- && isIdentifier(node.parent.property);
34
-
35
- /**
36
- Check if a property is a valid getter or setter.
37
-
38
- @param {import('estree').Property | import('estree').MethodDefinition} property
39
- */
40
- const isValidProperty = property =>
41
- ['Property', 'MethodDefinition'].includes(property?.type)
42
- && !property.computed
43
- && ['set', 'get'].includes(property.kind)
44
- && isIdentifier(property.key);
45
-
46
- /**
47
- Check if two property keys are the same.
48
-
49
- @param {import('estree').Property['key']} keyLeft
50
- @param {import('estree').Property['key']} keyRight
51
- */
52
- const isSameKey = (keyLeft, keyRight) => ['type', 'name'].every(key => keyLeft[key] === keyRight[key]);
53
-
54
- /**
55
- Check if `this` is accessed recursively within a getter or setter.
56
-
57
- @param {import('estree').ThisExpression} node
58
- @param {import('estree').Property | import('estree').MethodDefinition} property
59
- */
60
- const isMemberAccess = (node, property) =>
61
- isDotNotationAccess(node)
62
- && isSameKey(node.parent.property, property.key);
63
-
64
- /**
65
- Check if `this` is accessed recursively within a destructuring assignment.
66
-
67
- @param {import('estree').ThisExpression} node
68
- @param {import('estree').Property | import('estree').MethodDefinition} property
69
- */
70
- const isRecursiveDestructuringAccess = (node, property) =>
71
- node.parent.type === 'VariableDeclarator'
72
- && node.parent.init === node
73
- && node.parent.id.type === 'ObjectPattern'
74
- && node.parent.id.properties.some(declaratorProperty =>
75
- declaratorProperty.type === 'Property'
76
- && !declaratorProperty.computed
77
- && isSameKey(declaratorProperty.key, property.key),
78
- );
79
-
80
- const isPropertyRead = (thisExpression, property) =>
81
- isMemberAccess(thisExpression, property)
82
- || isRecursiveDestructuringAccess(thisExpression, property);
83
-
84
- const isPropertyWrite = (thisExpression, property) => {
85
- if (!isMemberAccess(thisExpression, property)) {
86
- return false;
87
- }
88
-
89
- const memberExpression = thisExpression.parent;
90
- const {parent} = memberExpression;
91
-
92
- // This part is similar to `isLeftHandSide`, try to DRY in future
93
- return (
94
- // `this.foo = …`
95
- // `[this.foo = …] = …`
96
- // `({property: this.foo = …] = …)`
97
- (
98
- (parent.type === 'AssignmentExpression' || parent.type === 'AssignmentPattern')
99
- && parent.left === memberExpression
100
- )
101
- // `++ this.foo`
102
- || (parent.type === 'UpdateExpression' && parent.argument === memberExpression)
103
- // `[this.foo] = …`
104
- || (parent.type === 'ArrayPattern' && parent.elements.includes(memberExpression))
105
- // `({property: this.foo} = …)`
106
- || (
107
- parent.type === 'Property'
108
- && parent.value === memberExpression
109
- && parent.parent.type === 'ObjectPattern'
110
- && parent.parent.properties.includes(memberExpression.parent)
111
- )
112
- );
113
- };
114
-
115
- /** @param {import('eslint').Rule.RuleContext} context */
116
- const create = context => {
117
- const {sourceCode} = context;
118
-
119
- return {
120
- /** @param {import('estree').ThisExpression} thisExpression */
121
- ThisExpression(thisExpression) {
122
- const scope = getClosestFunctionScope(sourceCode, thisExpression);
123
-
124
- if (!scope) {
125
- return;
126
- }
127
-
128
- /** @type {import('estree').Property | import('estree').MethodDefinition} */
129
- const property = scope.block.parent;
130
-
131
- if (!isValidProperty(property)) {
132
- return;
133
- }
134
-
135
- if (property.kind === 'get' && isPropertyRead(thisExpression, property)) {
136
- return {node: thisExpression.parent, messageId: MESSAGE_ID_ERROR, data: {kind: property.kind}};
137
- }
138
-
139
- if (property.kind === 'set' && isPropertyWrite(thisExpression, property)) {
140
- return {node: thisExpression.parent, messageId: MESSAGE_ID_ERROR, data: {kind: property.kind}};
141
- }
142
- },
143
- };
144
- };
145
-
146
- /** @type {import('eslint').Rule.RuleModule} */
147
- const config = {
148
- create,
149
- meta: {
150
- type: 'problem',
151
- docs: {
152
- description: 'Disallow recursive access to `this` within getters and setters.',
153
- recommended: 'unopinionated',
154
- },
155
- defaultOptions: [],
156
- messages,
157
- },
158
- };
159
-
160
- export default config;
@@ -1,210 +0,0 @@
1
- import path from 'node:path';
2
- import {getFunctionHeadLocation, getFunctionNameWithKind, isOpeningParenToken} from '@eslint-community/eslint-utils';
3
- import helperValidatorIdentifier from '@babel/helper-validator-identifier';
4
- import {camelCase} from 'change-case';
5
- import getClassHeadLocation from './utils/get-class-head-location.js';
6
- import {getParenthesizedRange} from './utils/parentheses.js';
7
- import {getScopes, getAvailableVariableName, upperFirst} from './utils/index.js';
8
- import {isMemberExpression} from './ast/index.js';
9
-
10
- const {isIdentifierName} = helperValidatorIdentifier;
11
-
12
- const MESSAGE_ID_ERROR = 'no-anonymous-default-export/error';
13
- const MESSAGE_ID_SUGGESTION = 'no-anonymous-default-export/suggestion';
14
- const messages = {
15
- [MESSAGE_ID_ERROR]: 'The {{description}} should be named.',
16
- [MESSAGE_ID_SUGGESTION]: 'Name it as `{{name}}`.',
17
- };
18
-
19
- const isClassKeywordToken = token => token.type === 'Keyword' && token.value === 'class';
20
- const isAnonymousClassOrFunction = node =>
21
- (
22
- (
23
- node.type === 'FunctionDeclaration'
24
- || node.type === 'FunctionExpression'
25
- || node.type === 'ClassDeclaration'
26
- || node.type === 'ClassExpression'
27
- )
28
- && !node.id
29
- )
30
- || node.type === 'ArrowFunctionExpression';
31
-
32
- function getSuggestionName(node, filename, sourceCode) {
33
- if (filename === '<input>' || filename === '<text>') {
34
- return;
35
- }
36
-
37
- let [name] = path.basename(filename).split('.');
38
- name = camelCase(name);
39
-
40
- if (!isIdentifierName(name)) {
41
- return;
42
- }
43
-
44
- name = node.type === 'ClassDeclaration' || node.type === 'ClassExpression' ? upperFirst(name) : name;
45
- name = getAvailableVariableName(name, getScopes(sourceCode.getScope(node)));
46
-
47
- return name;
48
- }
49
-
50
- function addName(fixer, node, name, context) {
51
- const {sourceCode} = context;
52
- switch (node.type) {
53
- case 'ClassDeclaration':
54
- case 'ClassExpression': {
55
- const lastDecorator = node.decorators?.at(-1);
56
- const classToken = lastDecorator
57
- ? sourceCode.getTokenAfter(lastDecorator, isClassKeywordToken)
58
- : sourceCode.getFirstToken(node, isClassKeywordToken);
59
- return fixer.insertTextAfter(classToken, ` ${name}`);
60
- }
61
-
62
- case 'FunctionDeclaration':
63
- case 'FunctionExpression': {
64
- const openingParenthesisToken = sourceCode.getFirstToken(
65
- node,
66
- isOpeningParenToken,
67
- );
68
- const characterBefore = sourceCode.text.charAt(sourceCode.getRange(openingParenthesisToken)[0] - 1);
69
- return fixer.insertTextBefore(
70
- openingParenthesisToken,
71
- `${characterBefore === ' ' ? '' : ' '}${name} `,
72
- );
73
- }
74
-
75
- case 'ArrowFunctionExpression': {
76
- const [exportDeclarationStart, exportDeclarationEnd]
77
- = sourceCode.getRange(
78
- node.parent.type === 'ExportDefaultDeclaration'
79
- ? node.parent
80
- : node.parent.parent,
81
- );
82
- const [arrowFunctionStart, arrowFunctionEnd] = getParenthesizedRange(node, context);
83
-
84
- let textBefore = sourceCode.text.slice(exportDeclarationStart, arrowFunctionStart);
85
- let textAfter = sourceCode.text.slice(arrowFunctionEnd, exportDeclarationEnd);
86
-
87
- textBefore = `\n${textBefore}`;
88
- if (!/\s$/.test(textBefore)) {
89
- textBefore = `${textBefore} `;
90
- }
91
-
92
- if (!textAfter.endsWith(';')) {
93
- textAfter = `${textAfter};`;
94
- }
95
-
96
- return [
97
- fixer.replaceTextRange(
98
- [exportDeclarationStart, arrowFunctionStart],
99
- `const ${name} = `,
100
- ),
101
- fixer.replaceTextRange(
102
- [arrowFunctionEnd, exportDeclarationEnd],
103
- ';',
104
- ),
105
- fixer.insertTextAfterRange(
106
- [exportDeclarationEnd, exportDeclarationEnd],
107
- `${textBefore}${name}${textAfter}`,
108
- ),
109
- ];
110
- }
111
-
112
- // No default
113
- }
114
- }
115
-
116
- function getProblem(node, context) {
117
- const {sourceCode, physicalFilename} = context;
118
-
119
- const suggestionName = getSuggestionName(node, physicalFilename, sourceCode);
120
-
121
- let loc;
122
- let description;
123
- if (node.type === 'ClassDeclaration' || node.type === 'ClassExpression') {
124
- loc = getClassHeadLocation(node, context);
125
- description = 'class';
126
- } else {
127
- loc = getFunctionHeadLocation(node, sourceCode);
128
- // [TODO: @fisker]: Ask `@eslint-community/eslint-utils` to expose `getFunctionKind`
129
- const nameWithKind = getFunctionNameWithKind(node);
130
- description = nameWithKind.replace(/ '.*?'$/, '');
131
- }
132
-
133
- const problem = {
134
- node,
135
- loc,
136
- messageId: MESSAGE_ID_ERROR,
137
- data: {
138
- description,
139
- },
140
- };
141
-
142
- if (!suggestionName) {
143
- return problem;
144
- }
145
-
146
- problem.suggest = [
147
- {
148
- messageId: MESSAGE_ID_SUGGESTION,
149
- data: {
150
- name: suggestionName,
151
- },
152
- fix: fixer => addName(fixer, node, suggestionName, context),
153
- },
154
- ];
155
-
156
- return problem;
157
- }
158
-
159
- /** @param {import('eslint').Rule.RuleContext} context */
160
- const create = context => {
161
- context.on('ExportDefaultDeclaration', node => {
162
- if (!isAnonymousClassOrFunction(node.declaration)) {
163
- return;
164
- }
165
-
166
- return getProblem(node.declaration, context);
167
- });
168
-
169
- context.on('AssignmentExpression', node => {
170
- if (
171
- !isAnonymousClassOrFunction(node.right)
172
- || !(
173
- node.parent.type === 'ExpressionStatement'
174
- && node.parent.expression === node
175
- )
176
- || !(
177
- isMemberExpression(node.left, {
178
- object: 'module',
179
- property: 'exports',
180
- computed: false,
181
- optional: false,
182
- })
183
- || (
184
- node.left.type === 'Identifier',
185
- node.left.name === 'exports'
186
- )
187
- )
188
- ) {
189
- return;
190
- }
191
-
192
- return getProblem(node.right, context);
193
- });
194
- };
195
-
196
- /** @type {import('eslint').Rule.RuleModule} */
197
- const config = {
198
- create,
199
- meta: {
200
- type: 'suggestion',
201
- docs: {
202
- description: 'Disallow anonymous functions and classes as the default export.',
203
- recommended: 'unopinionated',
204
- },
205
- hasSuggestions: true,
206
- messages,
207
- },
208
- };
209
-
210
- export default config;
@@ -1,285 +0,0 @@
1
- import {isMethodCall} from './ast/index.js';
2
- import {
3
- isNodeMatches,
4
- isNodeValueNotFunction,
5
- isParenthesized,
6
- getParenthesizedRange,
7
- getParenthesizedText,
8
- shouldAddParenthesesToCallExpressionCallee,
9
- } from './utils/index.js';
10
-
11
- const ERROR_WITH_NAME_MESSAGE_ID = 'error-with-name';
12
- const ERROR_WITHOUT_NAME_MESSAGE_ID = 'error-without-name';
13
- const REPLACE_WITH_NAME_MESSAGE_ID = 'replace-with-name';
14
- const REPLACE_WITHOUT_NAME_MESSAGE_ID = 'replace-without-name';
15
- const messages = {
16
- [ERROR_WITH_NAME_MESSAGE_ID]: 'Do not pass function `{{name}}` directly to `.{{method}}(…)`.',
17
- [ERROR_WITHOUT_NAME_MESSAGE_ID]: 'Do not pass function directly to `.{{method}}(…)`.',
18
- [REPLACE_WITH_NAME_MESSAGE_ID]: 'Replace function `{{name}}` with `… => {{name}}({{parameters}})`.',
19
- [REPLACE_WITHOUT_NAME_MESSAGE_ID]: 'Replace function with `… => …({{parameters}})`.',
20
- };
21
-
22
- const isAwaitExpressionArgument = node => node.parent.type === 'AwaitExpression' && node.parent.argument === node;
23
-
24
- const iteratorMethods = new Map([
25
- {
26
- method: 'every',
27
- ignore: [
28
- 'Boolean',
29
- ],
30
- },
31
- {
32
- method: 'filter',
33
- shouldIgnoreCallExpression: node => (node.callee.object.type === 'Identifier' && node.callee.object.name === 'Vue'),
34
- ignore: [
35
- 'Boolean',
36
- ],
37
- },
38
- {
39
- method: 'find',
40
- ignore: [
41
- 'Boolean',
42
- ],
43
- },
44
- {
45
- method: 'findLast',
46
- ignore: [
47
- 'Boolean',
48
- ],
49
- },
50
- {
51
- method: 'findIndex',
52
- ignore: [
53
- 'Boolean',
54
- ],
55
- },
56
- {
57
- method: 'findLastIndex',
58
- ignore: [
59
- 'Boolean',
60
- ],
61
- },
62
- {
63
- method: 'flatMap',
64
- },
65
- {
66
- method: 'forEach',
67
- returnsUndefined: true,
68
- },
69
- {
70
- method: 'map',
71
- shouldIgnoreCallExpression: node => (node.callee.object.type === 'Identifier' && node.callee.object.name === 'types'),
72
- ignore: [
73
- 'String',
74
- 'Number',
75
- 'BigInt',
76
- 'Boolean',
77
- 'Symbol',
78
- ],
79
- },
80
- {
81
- method: 'reduce',
82
- parameters: [
83
- 'accumulator',
84
- 'element',
85
- 'index',
86
- 'array',
87
- ],
88
- minParameters: 2,
89
- },
90
- {
91
- method: 'reduceRight',
92
- parameters: [
93
- 'accumulator',
94
- 'element',
95
- 'index',
96
- 'array',
97
- ],
98
- minParameters: 2,
99
- },
100
- {
101
- method: 'some',
102
- ignore: [
103
- 'Boolean',
104
- ],
105
- },
106
- ].map(({
107
- method,
108
- parameters = ['element', 'index', 'array'],
109
- ignore = [],
110
- minParameters = 1,
111
- returnsUndefined = false,
112
- shouldIgnoreCallExpression,
113
- }) => [method, {
114
- minParameters,
115
- parameters,
116
- returnsUndefined,
117
- shouldIgnoreCallExpression(callExpression) {
118
- if (
119
- method !== 'reduce'
120
- && method !== 'reduceRight'
121
- && isAwaitExpressionArgument(callExpression)
122
- ) {
123
- return true;
124
- }
125
-
126
- if (isNodeMatches(callExpression.callee.object, ignoredCallee)) {
127
- return true;
128
- }
129
-
130
- if (
131
- callExpression.callee.object.type === 'CallExpression'
132
- && isNodeMatches(callExpression.callee.object.callee, ignoredCallee)
133
- ) {
134
- return true;
135
- }
136
-
137
- return shouldIgnoreCallExpression?.(callExpression) ?? false;
138
- },
139
- shouldIgnoreCallback(callback) {
140
- if (callback.type === 'Identifier' && ignore.includes(callback.name)) {
141
- return true;
142
- }
143
-
144
- return false;
145
- },
146
- }]));
147
-
148
- const ignoredCallee = [
149
- // http://bluebirdjs.com/docs/api/promise.map.html
150
- 'Promise',
151
- 'React.Children',
152
- 'Children',
153
- 'lodash',
154
- 'underscore',
155
- '_',
156
- 'Async',
157
- 'async',
158
- 'this',
159
- '$',
160
- 'jQuery',
161
- ];
162
-
163
- function getProblem(context, node, method, options) {
164
- const {type} = node;
165
-
166
- const name = type === 'Identifier' ? node.name : '';
167
-
168
- const problem = {
169
- node,
170
- messageId: name ? ERROR_WITH_NAME_MESSAGE_ID : ERROR_WITHOUT_NAME_MESSAGE_ID,
171
- data: {
172
- name,
173
- method,
174
- },
175
- };
176
-
177
- if (node.type === 'YieldExpression' || node.type === 'AwaitExpression') {
178
- return problem;
179
- }
180
-
181
- problem.suggest = [];
182
-
183
- const {parameters, minParameters, returnsUndefined} = options;
184
- for (let parameterLength = minParameters; parameterLength <= parameters.length; parameterLength++) {
185
- const suggestionParameters = parameters.slice(0, parameterLength).join(', ');
186
-
187
- const suggest = {
188
- messageId: name ? REPLACE_WITH_NAME_MESSAGE_ID : REPLACE_WITHOUT_NAME_MESSAGE_ID,
189
- data: {
190
- name,
191
- parameters: suggestionParameters,
192
- },
193
- fix(fixer) {
194
- let text = getParenthesizedText(node, context);
195
-
196
- if (
197
- !isParenthesized(node, context.sourceCode)
198
- && shouldAddParenthesesToCallExpressionCallee(node)
199
- ) {
200
- text = `(${text})`;
201
- }
202
-
203
- return fixer.replaceTextRange(
204
- getParenthesizedRange(node, context),
205
- returnsUndefined
206
- ? `(${suggestionParameters}) => { ${text}(${suggestionParameters}); }`
207
- : `(${suggestionParameters}) => ${text}(${suggestionParameters})`,
208
- );
209
- },
210
- };
211
-
212
- problem.suggest.push(suggest);
213
- }
214
-
215
- return problem;
216
- }
217
-
218
- function * getTernaryConsequentAndALternate(node) {
219
- if (node.type === 'ConditionalExpression') {
220
- yield * getTernaryConsequentAndALternate(node.consequent);
221
- yield * getTernaryConsequentAndALternate(node.alternate);
222
- return;
223
- }
224
-
225
- yield node;
226
- }
227
-
228
- /** @param {import('eslint').Rule.RuleContext} context */
229
- const create = context => ({
230
- * CallExpression(callExpression) {
231
- if (
232
- !isMethodCall(callExpression, {
233
- minimumArguments: 1,
234
- maximumArguments: 2,
235
- optionalCall: false,
236
- computed: false,
237
- })
238
- || callExpression.callee.property.type !== 'Identifier'
239
- ) {
240
- return;
241
- }
242
-
243
- const methodNode = callExpression.callee.property;
244
- const methodName = methodNode.name;
245
- if (!iteratorMethods.has(methodName)) {
246
- return;
247
- }
248
-
249
- const options = iteratorMethods.get(methodName);
250
- if (options.shouldIgnoreCallExpression(callExpression)) {
251
- return;
252
- }
253
-
254
- for (const callback of getTernaryConsequentAndALternate(callExpression.arguments[0])) {
255
- if (
256
- callback.type === 'FunctionExpression'
257
- || callback.type === 'ArrowFunctionExpression'
258
- // Ignore all `CallExpression`s include `function.bind()`
259
- || callback.type === 'CallExpression'
260
- || options.shouldIgnoreCallback(callback)
261
- || isNodeValueNotFunction(callback)
262
- ) {
263
- continue;
264
- }
265
-
266
- yield getProblem(context, callback, methodName, options);
267
- }
268
- },
269
- });
270
-
271
- /** @type {import('eslint').Rule.RuleModule} */
272
- const config = {
273
- create,
274
- meta: {
275
- type: 'problem',
276
- docs: {
277
- description: 'Prevent passing a function reference directly to iterator methods.',
278
- recommended: true,
279
- },
280
- hasSuggestions: true,
281
- messages,
282
- },
283
- };
284
-
285
- export default config;