@alexlit/lint-kit 176.0.0 → 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 (295) hide show
  1. package/package.json +1 -1
  2. package/packages/config-eslint/package.json +1 -1
  3. package/packages/config-eslint/plugins/vue.js +6 -0
  4. package/packages/config-stylelint/package.json +5 -5
  5. package/packages/config-stylelint/plugins/color-format.js +1 -5
  6. package/packages/config-stylelint/plugins/logical-css.js +1 -4
  7. package/packages/config-eslint/node_modules/@eslint/core/LICENSE +0 -201
  8. package/packages/config-eslint/node_modules/@eslint/core/README.md +0 -29
  9. package/packages/config-eslint/node_modules/@eslint/core/dist/cjs/types.d.cts +0 -1179
  10. package/packages/config-eslint/node_modules/@eslint/core/dist/esm/types.d.ts +0 -1179
  11. package/packages/config-eslint/node_modules/@eslint/core/package.json +0 -49
  12. package/packages/config-eslint/node_modules/@eslint/plugin-kit/LICENSE +0 -201
  13. package/packages/config-eslint/node_modules/@eslint/plugin-kit/README.md +0 -273
  14. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/cjs/index.cjs +0 -884
  15. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/cjs/index.d.cts +0 -328
  16. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/cjs/types.cts +0 -7
  17. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/index.d.ts +0 -328
  18. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/index.js +0 -879
  19. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/types.d.ts +0 -6
  20. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/types.ts +0 -7
  21. package/packages/config-eslint/node_modules/@eslint/plugin-kit/package.json +0 -61
  22. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/configs/flat-config-base.js +0 -9
  23. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/index.d.ts +0 -17
  24. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/index.js +0 -91
  25. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/license +0 -9
  26. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/globals.json +0 -3345
  27. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/index.d.ts +0 -3452
  28. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/index.js +0 -2
  29. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/license +0 -9
  30. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/package.json +0 -117
  31. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/readme.md +0 -42
  32. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/package.json +0 -128
  33. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/readme.md +0 -261
  34. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/call-or-new-expression.js +0 -120
  35. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/function-types.js +0 -7
  36. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/index.js +0 -30
  37. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-arrow-function-body.js +0 -3
  38. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-directive.js +0 -4
  39. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-empty-array-expression.js +0 -5
  40. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-empty-node.js +0 -17
  41. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-expression-statement.js +0 -7
  42. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-function.js +0 -5
  43. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-member-expression.js +0 -98
  44. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-method-call.js +0 -62
  45. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-negative-one.js +0 -8
  46. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-reference-identifier.js +0 -159
  47. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-static-require.js +0 -10
  48. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-tagged-template-literal.js +0 -24
  49. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-undefined.js +0 -3
  50. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/literal.js +0 -24
  51. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/better-regex.js +0 -146
  52. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/catch-error-name.js +0 -138
  53. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-assert.js +0 -98
  54. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-date-clone.js +0 -54
  55. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-destructuring.js +0 -168
  56. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-empty-array-spread.js +0 -127
  57. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-existence-index-check.js +0 -137
  58. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-function-scoping.js +0 -265
  59. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/custom-error-definition.js +0 -218
  60. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/empty-brace-spaces.js +0 -62
  61. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/error-message.js +0 -98
  62. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/escape-case.js +0 -86
  63. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/expiring-todo-comments.js +0 -584
  64. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/explicit-length-check.js +0 -236
  65. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/filename-case.js +0 -276
  66. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/add-parenthesizes-to-return-or-throw-expression.js +0 -29
  67. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/append-argument.js +0 -30
  68. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/extend-fix-range.js +0 -11
  69. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/fix-space-around-keywords.js +0 -43
  70. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/index.js +0 -23
  71. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-argument.js +0 -40
  72. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-expression-statement.js +0 -34
  73. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-method-call.js +0 -28
  74. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-object-property.js +0 -21
  75. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-parentheses.js +0 -19
  76. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-spaces-after.js +0 -22
  77. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-specifier.js +0 -59
  78. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/rename-variable.js +0 -8
  79. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-argument.js +0 -17
  80. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-member-expression-property.js +0 -25
  81. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-node-or-token-and-spaces-before.js +0 -31
  82. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-reference-identifier.js +0 -32
  83. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-string-raw.js +0 -12
  84. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-template-element.js +0 -10
  85. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/switch-call-expression-to-new-expression.js +0 -29
  86. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/switch-new-expression-to-call-expression.js +0 -42
  87. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/import-style.js +0 -375
  88. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/index.js +0 -143
  89. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/new-for-builtins.js +0 -112
  90. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-abusive-eslint-disable.js +0 -63
  91. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-accessor-recursion.js +0 -160
  92. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-anonymous-default-export.js +0 -210
  93. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-callback-reference.js +0 -285
  94. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-for-each.js +0 -496
  95. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-method-this-argument.js +0 -223
  96. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-reduce.js +0 -128
  97. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-reverse.js +0 -6
  98. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-sort.js +0 -6
  99. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-await-expression-member.js +0 -85
  100. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-await-in-promise-methods.js +0 -69
  101. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-console-spaces.js +0 -89
  102. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-document-cookie.js +0 -27
  103. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-empty-file.js +0 -58
  104. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-for-loop.js +0 -419
  105. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-hex-escape.js +0 -54
  106. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-immediate-mutation.js +0 -778
  107. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-instanceof-builtins.js +0 -216
  108. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-invalid-fetch-options.js +0 -112
  109. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-invalid-remove-event-listener.js +0 -61
  110. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-keyword-prefix.js +0 -202
  111. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-lonely-if.js +0 -155
  112. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-magic-array-flat-depth.js +0 -55
  113. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-named-default.js +0 -101
  114. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-negated-condition.js +0 -145
  115. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-negation-in-equality-check.js +0 -99
  116. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-nested-ternary.js +0 -60
  117. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-new-array.js +0 -106
  118. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-new-buffer.js +0 -100
  119. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-null.js +0 -153
  120. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-object-as-default-parameter.js +0 -52
  121. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-process-exit.js +0 -106
  122. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-single-promise-in-promise-methods.js +0 -179
  123. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-static-only-class.js +0 -226
  124. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-thenable.js +0 -194
  125. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-this-assignment.js +0 -40
  126. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-typeof-undefined.js +0 -146
  127. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-array-flat-depth.js +0 -49
  128. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-array-splice-count.js +0 -23
  129. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-await.js +0 -110
  130. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-polyfills.js +0 -174
  131. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-slice-end.js +0 -22
  132. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unreadable-array-destructuring.js +0 -85
  133. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unreadable-iife.js +0 -43
  134. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unused-properties.js +0 -240
  135. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-collection-argument.js +0 -101
  136. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-error-capture-stack-trace.js +0 -146
  137. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-fallback-in-spread.js +0 -66
  138. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-length-check.js +0 -150
  139. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-promise-resolve-reject.js +0 -210
  140. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-spread.js +0 -389
  141. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-switch-case.js +0 -59
  142. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-undefined.js +0 -275
  143. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-zero-fractions.js +0 -81
  144. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/number-literal-case.js +0 -82
  145. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/numeric-separators-style.js +0 -189
  146. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-add-event-listener.js +0 -191
  147. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-find.js +0 -458
  148. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-flat-map.js +0 -86
  149. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-flat.js +0 -279
  150. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-index-of.js +0 -34
  151. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-some.js +0 -219
  152. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-at.js +0 -380
  153. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-bigint-literals.js +0 -129
  154. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-blob-reading-methods.js +0 -47
  155. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-class-fields.js +0 -158
  156. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-classlist-toggle.js +0 -255
  157. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-code-point.js +0 -56
  158. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-date-now.js +0 -133
  159. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-default-parameters.js +0 -218
  160. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-append.js +0 -50
  161. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-dataset.js +0 -135
  162. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-remove.js +0 -124
  163. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-text-content.js +0 -77
  164. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-event-target.js +0 -119
  165. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-export-from.js +0 -367
  166. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-global-this.js +0 -222
  167. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-import-meta-properties.js +0 -320
  168. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-includes.js +0 -111
  169. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-json-parse-buffer.js +0 -161
  170. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-keyboard-event-key.js +0 -188
  171. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-logical-operator-over-ternary.js +0 -162
  172. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-math-min-max.js +0 -205
  173. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-math-trunc.js +0 -111
  174. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-modern-dom-apis.js +0 -145
  175. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-modern-math-apis.js +0 -210
  176. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-module.js +0 -377
  177. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-native-coercion-functions.js +0 -187
  178. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-negative-index.js +0 -211
  179. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-node-protocol.js +0 -86
  180. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-number-properties.js +0 -142
  181. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-object-from-entries.js +0 -256
  182. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-optional-catch-binding.js +0 -77
  183. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-prototype-methods.js +0 -162
  184. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-query-selector.js +0 -170
  185. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-reflect-apply.js +0 -99
  186. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-regexp-test.js +0 -155
  187. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-response-static-json.js +0 -85
  188. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-set-has.js +0 -181
  189. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-set-size.js +0 -106
  190. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-single-call.js +0 -188
  191. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-spread.js +0 -521
  192. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-raw.js +0 -149
  193. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-replace-all.js +0 -180
  194. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-slice.js +0 -180
  195. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-starts-ends-with.js +0 -201
  196. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-trim-start-end.js +0 -46
  197. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-structured-clone.js +0 -149
  198. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-switch.js +0 -357
  199. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-ternary.js +0 -288
  200. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-top-level-await.js +0 -154
  201. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-type-error.js +0 -169
  202. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prevent-abbreviations.js +0 -655
  203. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/relative-url-style.js +0 -171
  204. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-array-join-separator.js +0 -65
  205. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-module-attributes.js +0 -120
  206. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-module-specifiers.js +0 -158
  207. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-number-to-fixed-digits-argument.js +0 -55
  208. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-post-message-target-origin.js +0 -74
  209. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/get-documentation-url.js +0 -9
  210. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/index.js +0 -9
  211. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-create.js +0 -51
  212. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-listener.js +0 -40
  213. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-problem.js +0 -38
  214. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-rule-fixer.js +0 -49
  215. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-rule.js +0 -38
  216. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-rules.js +0 -13
  217. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/unicorn-context.js +0 -36
  218. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/unicorn-listeners.js +0 -65
  219. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/utilities.js +0 -27
  220. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/abbreviations.js +0 -270
  221. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/builtin-errors.js +0 -14
  222. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/dom-events.js +0 -275
  223. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/event-keys.js +0 -54
  224. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/negative-index.js +0 -52
  225. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/no-array-mutate-rule.js +0 -139
  226. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/no-unnecessary-length-or-infinity-rule.js +0 -80
  227. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/package-json.js +0 -42
  228. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/simple-array-search-rule.js +0 -126
  229. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/typed-array.js +0 -17
  230. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/string-content.js +0 -192
  231. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/switch-case-braces.js +0 -114
  232. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/template-indent.js +0 -219
  233. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/text-encoding-identifier-case.js +0 -130
  234. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/throw-new-error.js +0 -60
  235. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/array-or-object-prototype-property.js +0 -57
  236. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/assert-token.js +0 -29
  237. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/boolean.js +0 -88
  238. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/builtins.js +0 -30
  239. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/cartesian-product-samples.js +0 -22
  240. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/create-deprecated-rules.js +0 -29
  241. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/escape-string.js +0 -24
  242. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/escape-template-element-raw.js +0 -6
  243. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-ancestor.js +0 -15
  244. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-available-variable-name.js +0 -147
  245. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-builtin-rule.js +0 -5
  246. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-call-expression-arguments-text.js +0 -36
  247. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-call-or-new-expression-tokens.js +0 -67
  248. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-class-head-location.js +0 -22
  249. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-documentation-url.js +0 -9
  250. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-indent-string.js +0 -18
  251. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-references.js +0 -5
  252. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-scopes.js +0 -12
  253. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-sibling-node.js +0 -38
  254. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-switch-case-head-location.js +0 -22
  255. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-token-store.js +0 -24
  256. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-variable-identifiers.js +0 -7
  257. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/global-reference-tracker.js +0 -68
  258. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/has-optional-chain-element.js +0 -17
  259. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/has-same-range.js +0 -7
  260. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/index.js +0 -59
  261. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-function-self-used-inside.js +0 -39
  262. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-left-hand-side.js +0 -20
  263. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-logical-expression.js +0 -14
  264. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-method-named.js +0 -7
  265. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-new-expression-with-parentheses.js +0 -28
  266. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-node-matches.js +0 -58
  267. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-node-value-not-dom-node.js +0 -20
  268. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-node-value-not-function.js +0 -40
  269. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-number.js +0 -224
  270. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-object-method.js +0 -10
  271. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-on-same-line.js +0 -7
  272. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-same-identifier.js +0 -5
  273. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-same-reference.js +0 -170
  274. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-export-local.js +0 -8
  275. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-import-local.js +0 -8
  276. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-property-assignment-pattern-left.js +0 -8
  277. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-property-value.js +0 -6
  278. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-unresolved-variable.js +0 -14
  279. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-value-not-usable.js +0 -5
  280. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/needs-semicolon.js +0 -118
  281. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/numeric.js +0 -49
  282. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/parentheses.js +0 -71
  283. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/resolve-variable-name.js +0 -18
  284. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/rule.js +0 -27
  285. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-await-expression-argument.js +0 -17
  286. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-call-expression-callee.js +0 -18
  287. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-conditional-expression-child.js +0 -13
  288. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-expression-statement-expression.js +0 -22
  289. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-logical-expression-child.js +0 -43
  290. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-member-expression-object.js +0 -47
  291. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-new-expression-callee.js +0 -28
  292. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-unary-expression.js +0 -24
  293. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/singular.js +0 -16
  294. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/string-cases.js +0 -2
  295. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/to-location.js +0 -25
@@ -1,106 +0,0 @@
1
- import {isParenthesized, getStaticValue} from '@eslint-community/eslint-utils';
2
- import needsSemicolon from './utils/needs-semicolon.js';
3
- import isNumber from './utils/is-number.js';
4
- import {isNewExpression} from './ast/index.js';
5
-
6
- const MESSAGE_ID_ERROR = 'error';
7
- const MESSAGE_ID_LENGTH = 'array-length';
8
- const MESSAGE_ID_ONLY_ELEMENT = 'only-element';
9
- const MESSAGE_ID_SPREAD = 'spread';
10
- const messages = {
11
- [MESSAGE_ID_ERROR]: '`new Array()` is unclear in intent; use either `[x]` or `Array.from({length: x})`',
12
- [MESSAGE_ID_LENGTH]: 'The argument is the length of array.',
13
- [MESSAGE_ID_ONLY_ELEMENT]: 'The argument is the only element of array.',
14
- [MESSAGE_ID_SPREAD]: 'Spread the argument.',
15
- };
16
-
17
- function getProblem(context, node) {
18
- if (
19
- !isNewExpression(node, {
20
- name: 'Array',
21
- argumentsLength: 1,
22
- allowSpreadElement: true,
23
- })
24
- ) {
25
- return;
26
- }
27
-
28
- const problem = {
29
- node,
30
- messageId: MESSAGE_ID_ERROR,
31
- };
32
-
33
- const [argumentNode] = node.arguments;
34
-
35
- const {sourceCode} = context;
36
- let text = sourceCode.getText(argumentNode);
37
- if (isParenthesized(argumentNode, sourceCode)) {
38
- text = `(${text})`;
39
- }
40
-
41
- const maybeSemiColon = needsSemicolon(sourceCode.getTokenBefore(node), context, '[')
42
- ? ';'
43
- : '';
44
-
45
- // We are not sure how many `arguments` passed
46
- if (argumentNode.type === 'SpreadElement') {
47
- problem.suggest = [
48
- {
49
- messageId: MESSAGE_ID_SPREAD,
50
- fix: fixer => fixer.replaceText(node, `${maybeSemiColon}[${text}]`),
51
- },
52
- ];
53
- return problem;
54
- }
55
-
56
- const fromLengthText = `Array.from(${text === 'length' ? '{length}' : `{length: ${text}}`})`;
57
- const scope = sourceCode.getScope(node);
58
- if (isNumber(argumentNode, scope)) {
59
- problem.fix = fixer => fixer.replaceText(node, fromLengthText);
60
- return problem;
61
- }
62
-
63
- const onlyElementText = `${maybeSemiColon}[${text}]`;
64
- const result = getStaticValue(argumentNode, scope);
65
- if (result !== null && typeof result.value !== 'number') {
66
- problem.fix = fixer => fixer.replaceText(node, onlyElementText);
67
- return problem;
68
- }
69
-
70
- // We don't know the argument is number or not
71
- problem.suggest = [
72
- {
73
- messageId: MESSAGE_ID_LENGTH,
74
- fix: fixer => fixer.replaceText(node, fromLengthText),
75
- },
76
- {
77
- messageId: MESSAGE_ID_ONLY_ELEMENT,
78
- fix: fixer => fixer.replaceText(node, onlyElementText),
79
- },
80
- ];
81
- return problem;
82
- }
83
-
84
- /** @param {import('eslint').Rule.RuleContext} context */
85
- const create = context => ({
86
- NewExpression(node) {
87
- return getProblem(context, node);
88
- },
89
- });
90
-
91
- /** @type {import('eslint').Rule.RuleModule} */
92
- const config = {
93
- create,
94
- meta: {
95
- type: 'suggestion',
96
- docs: {
97
- description: 'Disallow `new Array()`.',
98
- recommended: 'unopinionated',
99
- },
100
- fixable: 'code',
101
- hasSuggestions: true,
102
- messages,
103
- },
104
- };
105
-
106
- export default config;
@@ -1,100 +0,0 @@
1
- import {getStaticValue} from '@eslint-community/eslint-utils';
2
- import {switchNewExpressionToCallExpression} from './fix/index.js';
3
- import isNumber from './utils/is-number.js';
4
- import {isNewExpression} from './ast/index.js';
5
-
6
- const ERROR = 'error';
7
- const ERROR_UNKNOWN = 'error-unknown';
8
- const SUGGESTION = 'suggestion';
9
- const messages = {
10
- [ERROR]: '`new Buffer()` is deprecated, use `Buffer.{{method}}()` instead.',
11
- [ERROR_UNKNOWN]: '`new Buffer()` is deprecated, use `Buffer.alloc()` or `Buffer.from()` instead.',
12
- [SUGGESTION]: 'Switch to `Buffer.{{replacement}}()`.',
13
- };
14
-
15
- const inferMethod = (bufferArguments, scope) => {
16
- if (bufferArguments.length !== 1) {
17
- return 'from';
18
- }
19
-
20
- const [firstArgument] = bufferArguments;
21
- if (firstArgument.type === 'SpreadElement') {
22
- return;
23
- }
24
-
25
- if (firstArgument.type === 'ArrayExpression' || firstArgument.type === 'TemplateLiteral') {
26
- return 'from';
27
- }
28
-
29
- if (isNumber(firstArgument, scope)) {
30
- return 'alloc';
31
- }
32
-
33
- const staticResult = getStaticValue(firstArgument, scope);
34
- if (staticResult) {
35
- const {value} = staticResult;
36
- if (
37
- typeof value === 'string'
38
- || Array.isArray(value)
39
- ) {
40
- return 'from';
41
- }
42
- }
43
- };
44
-
45
- function fix(node, context, method) {
46
- return function * (fixer) {
47
- yield fixer.insertTextAfter(node.callee, `.${method}`);
48
- yield switchNewExpressionToCallExpression(node, context, fixer);
49
- };
50
- }
51
-
52
- /** @param {import('eslint').Rule.RuleContext} context */
53
- const create = context => {
54
- const {sourceCode} = context;
55
- return {
56
- NewExpression(node) {
57
- if (!isNewExpression(node, {name: 'Buffer'})) {
58
- return;
59
- }
60
-
61
- const method = inferMethod(node.arguments, sourceCode.getScope(node));
62
-
63
- if (method) {
64
- return {
65
- node,
66
- messageId: ERROR,
67
- data: {method},
68
- fix: fix(node, context, method),
69
- };
70
- }
71
-
72
- return {
73
- node,
74
- messageId: ERROR_UNKNOWN,
75
- suggest: ['from', 'alloc'].map(replacement => ({
76
- messageId: SUGGESTION,
77
- data: {replacement},
78
- fix: fix(node, context, replacement),
79
- })),
80
- };
81
- },
82
- };
83
- };
84
-
85
- /** @type {import('eslint').Rule.RuleModule} */
86
- const config = {
87
- create,
88
- meta: {
89
- type: 'problem',
90
- docs: {
91
- description: 'Enforce the use of `Buffer.from()` and `Buffer.alloc()` instead of the deprecated `new Buffer()`.',
92
- recommended: 'unopinionated',
93
- },
94
- fixable: 'code',
95
- hasSuggestions: true,
96
- messages,
97
- },
98
- };
99
-
100
- export default config;
@@ -1,153 +0,0 @@
1
- import {isMethodCall, isCallExpression, isLiteral} from './ast/index.js';
2
-
3
- const ERROR_MESSAGE_ID = 'error';
4
- const SUGGESTION_REPLACE_MESSAGE_ID = 'replace';
5
- const SUGGESTION_REMOVE_MESSAGE_ID = 'remove';
6
- const messages = {
7
- [ERROR_MESSAGE_ID]: 'Use `undefined` instead of `null`.',
8
- [SUGGESTION_REPLACE_MESSAGE_ID]: 'Replace `null` with `undefined`.',
9
- [SUGGESTION_REMOVE_MESSAGE_ID]: 'Remove `null`.',
10
- };
11
-
12
- const isLooseEqual = node => node.type === 'BinaryExpression' && ['==', '!='].includes(node.operator);
13
- const isStrictEqual = node => node.type === 'BinaryExpression' && ['===', '!=='].includes(node.operator);
14
-
15
- /** @param {import('eslint').Rule.RuleContext} context */
16
- const create = context => {
17
- const {checkStrictEquality} = {
18
- checkStrictEquality: false,
19
- ...context.options[0],
20
- };
21
-
22
- return {
23
- Literal(node) {
24
- if (
25
- // eslint-disable-next-line unicorn/no-null
26
- !isLiteral(node, null)
27
- || (!checkStrictEquality && isStrictEqual(node.parent))
28
- // `Object.create(null)`, `Object.create(null, foo)`
29
- || (
30
- isMethodCall(node.parent, {
31
- object: 'Object',
32
- method: 'create',
33
- minimumArguments: 1,
34
- maximumArguments: 2,
35
- optionalCall: false,
36
- optionalMember: false,
37
- })
38
- && node.parent.arguments[0] === node
39
- )
40
- // `useRef(null)`
41
- || (
42
- isCallExpression(node.parent, {
43
- name: 'useRef',
44
- argumentsLength: 1,
45
- optionalCall: false,
46
- optionalMember: false,
47
- })
48
- && node.parent.arguments[0] === node
49
- )
50
- // `React.useRef(null)`
51
- || (
52
- isMethodCall(node.parent, {
53
- object: 'React',
54
- method: 'useRef',
55
- argumentsLength: 1,
56
- optionalCall: false,
57
- optionalMember: false,
58
- })
59
- && node.parent.arguments[0] === node
60
- )
61
- // `foo.insertBefore(bar, null)`
62
- || (
63
- isMethodCall(node.parent, {
64
- method: 'insertBefore',
65
- argumentsLength: 2,
66
- optionalCall: false,
67
- })
68
- && node.parent.arguments[1] === node
69
- )
70
- ) {
71
- return;
72
- }
73
-
74
- const {parent} = node;
75
-
76
- const problem = {
77
- node,
78
- messageId: ERROR_MESSAGE_ID,
79
- };
80
-
81
- const useUndefinedFix = fixer => fixer.replaceText(node, 'undefined');
82
-
83
- if (isLooseEqual(parent)) {
84
- problem.fix = useUndefinedFix;
85
- return problem;
86
- }
87
-
88
- const useUndefinedSuggestion = {
89
- messageId: SUGGESTION_REPLACE_MESSAGE_ID,
90
- fix: useUndefinedFix,
91
- };
92
-
93
- if (parent.type === 'ReturnStatement' && parent.argument === node) {
94
- problem.suggest = [
95
- {
96
- messageId: SUGGESTION_REMOVE_MESSAGE_ID,
97
- fix: fixer => fixer.remove(node),
98
- },
99
- useUndefinedSuggestion,
100
- ];
101
- return problem;
102
- }
103
-
104
- if (parent.type === 'VariableDeclarator' && parent.init === node && parent.parent.kind !== 'const') {
105
- const {sourceCode} = context;
106
- const [, start] = sourceCode.getRange(parent.id);
107
- const [, end] = sourceCode.getRange(node);
108
- problem.suggest = [
109
- {
110
- messageId: SUGGESTION_REMOVE_MESSAGE_ID,
111
- fix: fixer => fixer.removeRange([start, end]),
112
- },
113
- useUndefinedSuggestion,
114
- ];
115
- return problem;
116
- }
117
-
118
- problem.suggest = [useUndefinedSuggestion];
119
- return problem;
120
- },
121
- };
122
- };
123
-
124
- const schema = [
125
- {
126
- type: 'object',
127
- additionalProperties: false,
128
- properties: {
129
- checkStrictEquality: {
130
- type: 'boolean',
131
- },
132
- },
133
- },
134
- ];
135
-
136
- /** @type {import('eslint').Rule.RuleModule} */
137
- const config = {
138
- create,
139
- meta: {
140
- type: 'suggestion',
141
- docs: {
142
- description: 'Disallow the use of the `null` literal.',
143
- recommended: true,
144
- },
145
- fixable: 'code',
146
- hasSuggestions: true,
147
- schema,
148
- defaultOptions: [{checkStrictEquality: false}],
149
- messages,
150
- },
151
- };
152
-
153
- export default config;
@@ -1,52 +0,0 @@
1
- import {isFunction} from './ast/index.js';
2
-
3
- const MESSAGE_ID_IDENTIFIER = 'identifier';
4
- const MESSAGE_ID_NON_IDENTIFIER = 'non-identifier';
5
- const messages = {
6
- [MESSAGE_ID_IDENTIFIER]: 'Do not use an object literal as default for parameter `{{parameter}}`.',
7
- [MESSAGE_ID_NON_IDENTIFIER]: 'Do not use an object literal as default.',
8
- };
9
-
10
- /** @param {import('eslint').Rule.RuleContext} context */
11
- const create = () => ({
12
- AssignmentPattern(node) {
13
- if (!(
14
- node.right.type === 'ObjectExpression'
15
- && node.right.properties.length > 0
16
- && isFunction(node.parent)
17
- && node.parent.params.includes(node)
18
- )) {
19
- return;
20
- }
21
-
22
- const {left, right} = node;
23
-
24
- if (left.type === 'Identifier') {
25
- return {
26
- node: left,
27
- messageId: MESSAGE_ID_IDENTIFIER,
28
- data: {parameter: left.name},
29
- };
30
- }
31
-
32
- return {
33
- node: right,
34
- messageId: MESSAGE_ID_NON_IDENTIFIER,
35
- };
36
- },
37
- });
38
-
39
- /** @type {import('eslint').Rule.RuleModule} */
40
- const config = {
41
- create,
42
- meta: {
43
- type: 'problem',
44
- docs: {
45
- description: 'Disallow the use of objects as default parameters.',
46
- recommended: 'unopinionated',
47
- },
48
- messages,
49
- },
50
- };
51
-
52
- export default config;
@@ -1,106 +0,0 @@
1
- import {isStaticRequire, isMethodCall, isLiteral} from './ast/index.js';
2
-
3
- const MESSAGE_ID = 'no-process-exit';
4
- const messages = {
5
- [MESSAGE_ID]: 'Only use `process.exit()` in CLI apps. Throw an error instead.',
6
- };
7
-
8
- const isWorkerThreads = node =>
9
- isLiteral(node, 'node:worker_threads')
10
- || isLiteral(node, 'worker_threads');
11
-
12
- /** @param {import('eslint').Rule.RuleContext} context */
13
- const create = context => {
14
- const startsWithHashBang = context.sourceCode.lines[0].indexOf('#!') === 0;
15
-
16
- if (startsWithHashBang) {
17
- return {};
18
- }
19
-
20
- let processEventHandler;
21
-
22
- // Only report if it's outside an worker thread context. See #328.
23
- let requiredWorkerThreadsModule = false;
24
- const problemNodes = [];
25
-
26
- // `require('worker_threads')`
27
- context.on('CallExpression', callExpression => {
28
- if (
29
- isStaticRequire(callExpression)
30
- && isWorkerThreads(callExpression.arguments[0])
31
- ) {
32
- requiredWorkerThreadsModule = true;
33
- }
34
- });
35
-
36
- // `import workerThreads from 'worker_threads'`
37
- context.on('ImportDeclaration', importDeclaration => {
38
- if (
39
- importDeclaration.source.type === 'Literal'
40
- && isWorkerThreads(importDeclaration.source)
41
- ) {
42
- requiredWorkerThreadsModule = true;
43
- }
44
- });
45
-
46
- // Check `process.on` / `process.once` call
47
- context.on('CallExpression', node => {
48
- if (isMethodCall(node, {
49
- object: 'process',
50
- methods: ['on', 'once'],
51
- minimumArguments: 1,
52
- optionalCall: false,
53
- optionalMember: false,
54
- })) {
55
- processEventHandler = node;
56
- }
57
- });
58
- context.onExit('CallExpression', node => {
59
- if (node === processEventHandler) {
60
- processEventHandler = undefined;
61
- }
62
- });
63
-
64
- // Check `process.exit` call
65
- context.on('CallExpression', node => {
66
- if (
67
- !processEventHandler
68
- && isMethodCall(node, {
69
- object: 'process',
70
- method: 'exit',
71
- optionalCall: false,
72
- optionalMember: false,
73
- })
74
- ) {
75
- problemNodes.push(node);
76
- }
77
- });
78
-
79
- context.onExit('Program', function * () {
80
- if (requiredWorkerThreadsModule) {
81
- return;
82
- }
83
-
84
- for (const node of problemNodes) {
85
- yield {
86
- node,
87
- messageId: MESSAGE_ID,
88
- };
89
- }
90
- });
91
- };
92
-
93
- /** @type {import('eslint').Rule.RuleModule} */
94
- const config = {
95
- create,
96
- meta: {
97
- type: 'suggestion',
98
- docs: {
99
- description: 'Disallow `process.exit()`.',
100
- recommended: 'unopinionated',
101
- },
102
- messages,
103
- },
104
- };
105
-
106
- export default config;
@@ -1,179 +0,0 @@
1
- import {isCommaToken} from '@eslint-community/eslint-utils';
2
- import {isMethodCall, isExpressionStatement} from './ast/index.js';
3
- import {
4
- getParenthesizedText,
5
- isParenthesized,
6
- needsSemicolon,
7
- shouldAddParenthesesToAwaitExpressionArgument,
8
- } from './utils/index.js';
9
-
10
- const MESSAGE_ID_ERROR = 'no-single-promise-in-promise-methods/error';
11
- const MESSAGE_ID_SUGGESTION_UNWRAP = 'no-single-promise-in-promise-methods/unwrap';
12
- const MESSAGE_ID_SUGGESTION_SWITCH_TO_PROMISE_RESOLVE = 'no-single-promise-in-promise-methods/use-promise-resolve';
13
- const messages = {
14
- [MESSAGE_ID_ERROR]: 'Wrapping single-element array with `Promise.{{method}}()` is unnecessary.',
15
- [MESSAGE_ID_SUGGESTION_UNWRAP]: 'Use the value directly.',
16
- [MESSAGE_ID_SUGGESTION_SWITCH_TO_PROMISE_RESOLVE]: 'Switch to `Promise.resolve(…)`.',
17
- };
18
- const METHODS = ['all', 'any', 'race'];
19
-
20
- const isPromiseMethodCallWithSingleElementArray = node =>
21
- isMethodCall(node, {
22
- object: 'Promise',
23
- methods: METHODS,
24
- optionalMember: false,
25
- optionalCall: false,
26
- argumentsLength: 1,
27
- })
28
- && node.arguments[0].type === 'ArrayExpression'
29
- && node.arguments[0].elements.length === 1
30
- && node.arguments[0].elements[0]
31
- && node.arguments[0].elements[0].type !== 'SpreadElement';
32
-
33
- const unwrapAwaitedCallExpression = (callExpression, context) => fixer => {
34
- const {sourceCode} = context;
35
- const [promiseNode] = callExpression.arguments[0].elements;
36
- let text = getParenthesizedText(promiseNode, context);
37
-
38
- if (
39
- !isParenthesized(promiseNode, sourceCode)
40
- && shouldAddParenthesesToAwaitExpressionArgument(promiseNode)
41
- ) {
42
- text = `(${text})`;
43
- }
44
-
45
- // The next node is already behind a `CallExpression`, there should be no ASI problem
46
-
47
- return fixer.replaceText(callExpression, text);
48
- };
49
-
50
- const unwrapNonAwaitedCallExpression = (callExpression, context) => fixer => {
51
- const {sourceCode} = context;
52
- const [promiseNode] = callExpression.arguments[0].elements;
53
- let text = getParenthesizedText(promiseNode, context);
54
-
55
- if (
56
- !isParenthesized(promiseNode, sourceCode)
57
- // Since the original call expression can be anywhere, it's hard to tell if the promise
58
- // need to be parenthesized, but it's safe to add parentheses
59
- && !(
60
- // Known cases that not need parentheses
61
- promiseNode.type === 'Identifier'
62
- || promiseNode.type === 'MemberExpression'
63
- )
64
- ) {
65
- text = `(${text})`;
66
- }
67
-
68
- const previousToken = sourceCode.getTokenBefore(callExpression);
69
- if (needsSemicolon(previousToken, context, text)) {
70
- text = `;${text}`;
71
- }
72
-
73
- return fixer.replaceText(callExpression, text);
74
- };
75
-
76
- const switchToPromiseResolve = (callExpression, sourceCode) => function * (fixer) {
77
- /*
78
- ```
79
- Promise.race([promise,])
80
- // ^^^^ methodNameNode
81
- ```
82
- */
83
- const methodNameNode = callExpression.callee.property;
84
- yield fixer.replaceText(methodNameNode, 'resolve');
85
-
86
- const [arrayExpression] = callExpression.arguments;
87
- /*
88
- ```
89
- Promise.race([promise,])
90
- // ^ openingBracketToken
91
- ```
92
- */
93
- const openingBracketToken = sourceCode.getFirstToken(arrayExpression);
94
- /*
95
- ```
96
- Promise.race([promise,])
97
- // ^ penultimateToken
98
- // ^ closingBracketToken
99
- ```
100
- */
101
- const [
102
- penultimateToken,
103
- closingBracketToken,
104
- ] = sourceCode.getLastTokens(arrayExpression, 2);
105
-
106
- yield fixer.remove(openingBracketToken);
107
- yield fixer.remove(closingBracketToken);
108
-
109
- if (isCommaToken(penultimateToken)) {
110
- yield fixer.remove(penultimateToken);
111
- }
112
- };
113
-
114
- /** @param {import('eslint').Rule.RuleContext} context */
115
- const create = context => ({
116
- CallExpression(callExpression) {
117
- if (!isPromiseMethodCallWithSingleElementArray(callExpression)) {
118
- return;
119
- }
120
-
121
- const methodName = callExpression.callee.property.name;
122
-
123
- const problem = {
124
- node: callExpression.arguments[0],
125
- messageId: MESSAGE_ID_ERROR,
126
- data: {
127
- method: methodName,
128
- },
129
- };
130
-
131
- const {sourceCode} = context;
132
-
133
- if (
134
- callExpression.parent.type === 'AwaitExpression'
135
- && callExpression.parent.argument === callExpression
136
- && (
137
- methodName !== 'all'
138
- || isExpressionStatement(callExpression.parent.parent)
139
- )
140
- ) {
141
- problem.fix = unwrapAwaitedCallExpression(callExpression, context);
142
- return problem;
143
- }
144
-
145
- if (methodName === 'all') {
146
- return problem;
147
- }
148
-
149
- problem.suggest = [
150
- {
151
- messageId: MESSAGE_ID_SUGGESTION_UNWRAP,
152
- fix: unwrapNonAwaitedCallExpression(callExpression, context),
153
- },
154
- {
155
- messageId: MESSAGE_ID_SUGGESTION_SWITCH_TO_PROMISE_RESOLVE,
156
- fix: switchToPromiseResolve(callExpression, sourceCode),
157
- },
158
- ];
159
-
160
- return problem;
161
- },
162
- });
163
-
164
- /** @type {import('eslint').Rule.RuleModule} */
165
- const config = {
166
- create,
167
- meta: {
168
- type: 'suggestion',
169
- docs: {
170
- description: 'Disallow passing single-element arrays to `Promise` methods.',
171
- recommended: 'unopinionated',
172
- },
173
- fixable: 'code',
174
- hasSuggestions: true,
175
- messages,
176
- },
177
- };
178
-
179
- export default config;