@alexlit/lint-kit 183.0.0 → 183.2.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 (631) hide show
  1. package/package.json +1 -1
  2. package/packages/config-eslint/package.json +2 -2
  3. package/packages/config-prettier/package.json +2 -2
  4. package/packages/config-stylelint/index.js +1 -1
  5. package/packages/config-stylelint/package.json +2 -2
  6. package/packages/config-stylelint/plugins/bem.js +1 -5
  7. package/packages/config-eslint/node_modules/ajv/.tonic_example.js +0 -20
  8. package/packages/config-eslint/node_modules/ajv/LICENSE +0 -22
  9. package/packages/config-eslint/node_modules/ajv/README.md +0 -1505
  10. package/packages/config-eslint/node_modules/ajv/dist/ajv.bundle.js +0 -7201
  11. package/packages/config-eslint/node_modules/ajv/dist/ajv.min.js +0 -3
  12. package/packages/config-eslint/node_modules/ajv/dist/ajv.min.js.map +0 -1
  13. package/packages/config-eslint/node_modules/ajv/lib/ajv.d.ts +0 -402
  14. package/packages/config-eslint/node_modules/ajv/lib/ajv.js +0 -506
  15. package/packages/config-eslint/node_modules/ajv/lib/cache.js +0 -26
  16. package/packages/config-eslint/node_modules/ajv/lib/compile/async.js +0 -90
  17. package/packages/config-eslint/node_modules/ajv/lib/compile/equal.js +0 -5
  18. package/packages/config-eslint/node_modules/ajv/lib/compile/error_classes.js +0 -34
  19. package/packages/config-eslint/node_modules/ajv/lib/compile/formats.js +0 -142
  20. package/packages/config-eslint/node_modules/ajv/lib/compile/index.js +0 -389
  21. package/packages/config-eslint/node_modules/ajv/lib/compile/resolve.js +0 -270
  22. package/packages/config-eslint/node_modules/ajv/lib/compile/rules.js +0 -66
  23. package/packages/config-eslint/node_modules/ajv/lib/compile/schema_obj.js +0 -9
  24. package/packages/config-eslint/node_modules/ajv/lib/compile/ucs2length.js +0 -20
  25. package/packages/config-eslint/node_modules/ajv/lib/compile/util.js +0 -239
  26. package/packages/config-eslint/node_modules/ajv/lib/data.js +0 -49
  27. package/packages/config-eslint/node_modules/ajv/lib/definition_schema.js +0 -37
  28. package/packages/config-eslint/node_modules/ajv/lib/dot/_limit.jst +0 -113
  29. package/packages/config-eslint/node_modules/ajv/lib/dot/_limitItems.jst +0 -12
  30. package/packages/config-eslint/node_modules/ajv/lib/dot/_limitLength.jst +0 -12
  31. package/packages/config-eslint/node_modules/ajv/lib/dot/_limitProperties.jst +0 -12
  32. package/packages/config-eslint/node_modules/ajv/lib/dot/allOf.jst +0 -32
  33. package/packages/config-eslint/node_modules/ajv/lib/dot/anyOf.jst +0 -46
  34. package/packages/config-eslint/node_modules/ajv/lib/dot/coerce.def +0 -51
  35. package/packages/config-eslint/node_modules/ajv/lib/dot/comment.jst +0 -9
  36. package/packages/config-eslint/node_modules/ajv/lib/dot/const.jst +0 -11
  37. package/packages/config-eslint/node_modules/ajv/lib/dot/contains.jst +0 -55
  38. package/packages/config-eslint/node_modules/ajv/lib/dot/custom.jst +0 -191
  39. package/packages/config-eslint/node_modules/ajv/lib/dot/defaults.def +0 -47
  40. package/packages/config-eslint/node_modules/ajv/lib/dot/definitions.def +0 -203
  41. package/packages/config-eslint/node_modules/ajv/lib/dot/dependencies.jst +0 -79
  42. package/packages/config-eslint/node_modules/ajv/lib/dot/enum.jst +0 -30
  43. package/packages/config-eslint/node_modules/ajv/lib/dot/errors.def +0 -194
  44. package/packages/config-eslint/node_modules/ajv/lib/dot/format.jst +0 -106
  45. package/packages/config-eslint/node_modules/ajv/lib/dot/if.jst +0 -73
  46. package/packages/config-eslint/node_modules/ajv/lib/dot/items.jst +0 -98
  47. package/packages/config-eslint/node_modules/ajv/lib/dot/missing.def +0 -39
  48. package/packages/config-eslint/node_modules/ajv/lib/dot/multipleOf.jst +0 -22
  49. package/packages/config-eslint/node_modules/ajv/lib/dot/not.jst +0 -43
  50. package/packages/config-eslint/node_modules/ajv/lib/dot/oneOf.jst +0 -54
  51. package/packages/config-eslint/node_modules/ajv/lib/dot/pattern.jst +0 -25
  52. package/packages/config-eslint/node_modules/ajv/lib/dot/properties.jst +0 -245
  53. package/packages/config-eslint/node_modules/ajv/lib/dot/propertyNames.jst +0 -52
  54. package/packages/config-eslint/node_modules/ajv/lib/dot/ref.jst +0 -85
  55. package/packages/config-eslint/node_modules/ajv/lib/dot/required.jst +0 -108
  56. package/packages/config-eslint/node_modules/ajv/lib/dot/uniqueItems.jst +0 -62
  57. package/packages/config-eslint/node_modules/ajv/lib/dot/validate.jst +0 -276
  58. package/packages/config-eslint/node_modules/ajv/lib/dotjs/README.md +0 -3
  59. package/packages/config-eslint/node_modules/ajv/lib/dotjs/_limit.js +0 -163
  60. package/packages/config-eslint/node_modules/ajv/lib/dotjs/_limitItems.js +0 -80
  61. package/packages/config-eslint/node_modules/ajv/lib/dotjs/_limitLength.js +0 -85
  62. package/packages/config-eslint/node_modules/ajv/lib/dotjs/_limitProperties.js +0 -80
  63. package/packages/config-eslint/node_modules/ajv/lib/dotjs/allOf.js +0 -42
  64. package/packages/config-eslint/node_modules/ajv/lib/dotjs/anyOf.js +0 -73
  65. package/packages/config-eslint/node_modules/ajv/lib/dotjs/comment.js +0 -14
  66. package/packages/config-eslint/node_modules/ajv/lib/dotjs/const.js +0 -56
  67. package/packages/config-eslint/node_modules/ajv/lib/dotjs/contains.js +0 -81
  68. package/packages/config-eslint/node_modules/ajv/lib/dotjs/custom.js +0 -228
  69. package/packages/config-eslint/node_modules/ajv/lib/dotjs/dependencies.js +0 -168
  70. package/packages/config-eslint/node_modules/ajv/lib/dotjs/enum.js +0 -66
  71. package/packages/config-eslint/node_modules/ajv/lib/dotjs/format.js +0 -150
  72. package/packages/config-eslint/node_modules/ajv/lib/dotjs/if.js +0 -103
  73. package/packages/config-eslint/node_modules/ajv/lib/dotjs/index.js +0 -33
  74. package/packages/config-eslint/node_modules/ajv/lib/dotjs/items.js +0 -140
  75. package/packages/config-eslint/node_modules/ajv/lib/dotjs/multipleOf.js +0 -80
  76. package/packages/config-eslint/node_modules/ajv/lib/dotjs/not.js +0 -84
  77. package/packages/config-eslint/node_modules/ajv/lib/dotjs/oneOf.js +0 -73
  78. package/packages/config-eslint/node_modules/ajv/lib/dotjs/pattern.js +0 -85
  79. package/packages/config-eslint/node_modules/ajv/lib/dotjs/properties.js +0 -335
  80. package/packages/config-eslint/node_modules/ajv/lib/dotjs/propertyNames.js +0 -81
  81. package/packages/config-eslint/node_modules/ajv/lib/dotjs/ref.js +0 -124
  82. package/packages/config-eslint/node_modules/ajv/lib/dotjs/required.js +0 -270
  83. package/packages/config-eslint/node_modules/ajv/lib/dotjs/uniqueItems.js +0 -86
  84. package/packages/config-eslint/node_modules/ajv/lib/dotjs/validate.js +0 -482
  85. package/packages/config-eslint/node_modules/ajv/lib/keyword.js +0 -146
  86. package/packages/config-eslint/node_modules/ajv/lib/refs/data.json +0 -17
  87. package/packages/config-eslint/node_modules/ajv/lib/refs/json-schema-draft-04.json +0 -149
  88. package/packages/config-eslint/node_modules/ajv/lib/refs/json-schema-draft-06.json +0 -154
  89. package/packages/config-eslint/node_modules/ajv/lib/refs/json-schema-draft-07.json +0 -168
  90. package/packages/config-eslint/node_modules/ajv/lib/refs/json-schema-secure.json +0 -94
  91. package/packages/config-eslint/node_modules/ajv/package.json +0 -107
  92. package/packages/config-eslint/node_modules/ajv/scripts/.eslintrc.yml +0 -3
  93. package/packages/config-eslint/node_modules/ajv/scripts/bundle.js +0 -61
  94. package/packages/config-eslint/node_modules/ajv/scripts/compile-dots.js +0 -73
  95. package/packages/config-eslint/node_modules/ajv/scripts/info +0 -10
  96. package/packages/config-eslint/node_modules/ajv/scripts/prepare-tests +0 -12
  97. package/packages/config-eslint/node_modules/ajv/scripts/publish-built-version +0 -32
  98. package/packages/config-eslint/node_modules/ajv/scripts/travis-gh-pages +0 -23
  99. package/packages/config-eslint/node_modules/balanced-match/LICENSE.md +0 -23
  100. package/packages/config-eslint/node_modules/balanced-match/README.md +0 -57
  101. package/packages/config-eslint/node_modules/balanced-match/dist/commonjs/index.d.ts +0 -9
  102. package/packages/config-eslint/node_modules/balanced-match/dist/commonjs/index.d.ts.map +0 -1
  103. package/packages/config-eslint/node_modules/balanced-match/dist/commonjs/index.js +0 -59
  104. package/packages/config-eslint/node_modules/balanced-match/dist/commonjs/index.js.map +0 -1
  105. package/packages/config-eslint/node_modules/balanced-match/dist/commonjs/package.json +0 -3
  106. package/packages/config-eslint/node_modules/balanced-match/dist/esm/index.d.ts +0 -9
  107. package/packages/config-eslint/node_modules/balanced-match/dist/esm/index.d.ts.map +0 -1
  108. package/packages/config-eslint/node_modules/balanced-match/dist/esm/index.js +0 -54
  109. package/packages/config-eslint/node_modules/balanced-match/dist/esm/index.js.map +0 -1
  110. package/packages/config-eslint/node_modules/balanced-match/dist/esm/package.json +0 -3
  111. package/packages/config-eslint/node_modules/balanced-match/package.json +0 -68
  112. package/packages/config-eslint/node_modules/brace-expansion/LICENSE +0 -23
  113. package/packages/config-eslint/node_modules/brace-expansion/README.md +0 -94
  114. package/packages/config-eslint/node_modules/brace-expansion/dist/commonjs/index.d.ts +0 -6
  115. package/packages/config-eslint/node_modules/brace-expansion/dist/commonjs/index.d.ts.map +0 -1
  116. package/packages/config-eslint/node_modules/brace-expansion/dist/commonjs/index.js +0 -199
  117. package/packages/config-eslint/node_modules/brace-expansion/dist/commonjs/index.js.map +0 -1
  118. package/packages/config-eslint/node_modules/brace-expansion/dist/commonjs/package.json +0 -3
  119. package/packages/config-eslint/node_modules/brace-expansion/dist/esm/index.d.ts +0 -6
  120. package/packages/config-eslint/node_modules/brace-expansion/dist/esm/index.d.ts.map +0 -1
  121. package/packages/config-eslint/node_modules/brace-expansion/dist/esm/index.js +0 -195
  122. package/packages/config-eslint/node_modules/brace-expansion/dist/esm/index.js.map +0 -1
  123. package/packages/config-eslint/node_modules/brace-expansion/dist/esm/package.json +0 -3
  124. package/packages/config-eslint/node_modules/brace-expansion/package.json +0 -64
  125. package/packages/config-eslint/node_modules/eslint/LICENSE +0 -19
  126. package/packages/config-eslint/node_modules/eslint/README.md +0 -369
  127. package/packages/config-eslint/node_modules/eslint/bin/eslint.js +0 -195
  128. package/packages/config-eslint/node_modules/eslint/conf/ecma-version.js +0 -16
  129. package/packages/config-eslint/node_modules/eslint/conf/globals.js +0 -169
  130. package/packages/config-eslint/node_modules/eslint/conf/replacements.json +0 -26
  131. package/packages/config-eslint/node_modules/eslint/conf/rule-type-list.json +0 -91
  132. package/packages/config-eslint/node_modules/eslint/lib/api.js +0 -39
  133. package/packages/config-eslint/node_modules/eslint/lib/cli-engine/formatters/formatters-meta.json +0 -18
  134. package/packages/config-eslint/node_modules/eslint/lib/cli-engine/formatters/html.js +0 -359
  135. package/packages/config-eslint/node_modules/eslint/lib/cli-engine/formatters/json-with-metadata.js +0 -16
  136. package/packages/config-eslint/node_modules/eslint/lib/cli-engine/formatters/json.js +0 -13
  137. package/packages/config-eslint/node_modules/eslint/lib/cli-engine/formatters/stylish.js +0 -153
  138. package/packages/config-eslint/node_modules/eslint/lib/cli-engine/hash.js +0 -35
  139. package/packages/config-eslint/node_modules/eslint/lib/cli-engine/lint-result-cache.js +0 -220
  140. package/packages/config-eslint/node_modules/eslint/lib/cli.js +0 -521
  141. package/packages/config-eslint/node_modules/eslint/lib/config/config-loader.js +0 -668
  142. package/packages/config-eslint/node_modules/eslint/lib/config/config.js +0 -674
  143. package/packages/config-eslint/node_modules/eslint/lib/config/default-config.js +0 -78
  144. package/packages/config-eslint/node_modules/eslint/lib/config/flat-config-array.js +0 -217
  145. package/packages/config-eslint/node_modules/eslint/lib/config/flat-config-schema.js +0 -598
  146. package/packages/config-eslint/node_modules/eslint/lib/config-api.js +0 -12
  147. package/packages/config-eslint/node_modules/eslint/lib/eslint/eslint-helpers.js +0 -1462
  148. package/packages/config-eslint/node_modules/eslint/lib/eslint/eslint.js +0 -1364
  149. package/packages/config-eslint/node_modules/eslint/lib/eslint/index.js +0 -7
  150. package/packages/config-eslint/node_modules/eslint/lib/eslint/worker.js +0 -173
  151. package/packages/config-eslint/node_modules/eslint/lib/languages/js/index.js +0 -336
  152. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/index.js +0 -7
  153. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/source-code.js +0 -1178
  154. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/backward-token-comment-cursor.js +0 -61
  155. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/backward-token-cursor.js +0 -57
  156. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/cursor.js +0 -76
  157. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/cursors.js +0 -120
  158. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/decorative-cursor.js +0 -38
  159. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/filter-cursor.js +0 -42
  160. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/forward-token-comment-cursor.js +0 -65
  161. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/forward-token-cursor.js +0 -62
  162. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/index.js +0 -695
  163. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/limit-cursor.js +0 -39
  164. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/padded-token-cursor.js +0 -45
  165. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/skip-cursor.js +0 -41
  166. package/packages/config-eslint/node_modules/eslint/lib/languages/js/source-code/token-store/utils.js +0 -131
  167. package/packages/config-eslint/node_modules/eslint/lib/languages/js/validate-language-options.js +0 -196
  168. package/packages/config-eslint/node_modules/eslint/lib/linter/apply-disable-directives.js +0 -583
  169. package/packages/config-eslint/node_modules/eslint/lib/linter/code-path-analysis/code-path-analyzer.js +0 -828
  170. package/packages/config-eslint/node_modules/eslint/lib/linter/code-path-analysis/code-path-segment.js +0 -262
  171. package/packages/config-eslint/node_modules/eslint/lib/linter/code-path-analysis/code-path-state.js +0 -2370
  172. package/packages/config-eslint/node_modules/eslint/lib/linter/code-path-analysis/code-path.js +0 -332
  173. package/packages/config-eslint/node_modules/eslint/lib/linter/code-path-analysis/debug-helpers.js +0 -223
  174. package/packages/config-eslint/node_modules/eslint/lib/linter/code-path-analysis/fork-context.js +0 -374
  175. package/packages/config-eslint/node_modules/eslint/lib/linter/code-path-analysis/id-generator.js +0 -44
  176. package/packages/config-eslint/node_modules/eslint/lib/linter/esquery.js +0 -332
  177. package/packages/config-eslint/node_modules/eslint/lib/linter/file-context.js +0 -88
  178. package/packages/config-eslint/node_modules/eslint/lib/linter/file-report.js +0 -604
  179. package/packages/config-eslint/node_modules/eslint/lib/linter/index.js +0 -11
  180. package/packages/config-eslint/node_modules/eslint/lib/linter/interpolate.js +0 -50
  181. package/packages/config-eslint/node_modules/eslint/lib/linter/linter.js +0 -1614
  182. package/packages/config-eslint/node_modules/eslint/lib/linter/rule-fixer.js +0 -199
  183. package/packages/config-eslint/node_modules/eslint/lib/linter/source-code-fixer.js +0 -154
  184. package/packages/config-eslint/node_modules/eslint/lib/linter/source-code-traverser.js +0 -333
  185. package/packages/config-eslint/node_modules/eslint/lib/linter/source-code-visitor.js +0 -81
  186. package/packages/config-eslint/node_modules/eslint/lib/linter/timing.js +0 -209
  187. package/packages/config-eslint/node_modules/eslint/lib/linter/vfile.js +0 -115
  188. package/packages/config-eslint/node_modules/eslint/lib/options.js +0 -416
  189. package/packages/config-eslint/node_modules/eslint/lib/rule-tester/index.js +0 -7
  190. package/packages/config-eslint/node_modules/eslint/lib/rule-tester/rule-tester.js +0 -1996
  191. package/packages/config-eslint/node_modules/eslint/lib/rules/accessor-pairs.js +0 -420
  192. package/packages/config-eslint/node_modules/eslint/lib/rules/array-bracket-newline.js +0 -291
  193. package/packages/config-eslint/node_modules/eslint/lib/rules/array-bracket-spacing.js +0 -301
  194. package/packages/config-eslint/node_modules/eslint/lib/rules/array-callback-return.js +0 -510
  195. package/packages/config-eslint/node_modules/eslint/lib/rules/array-element-newline.js +0 -374
  196. package/packages/config-eslint/node_modules/eslint/lib/rules/arrow-body-style.js +0 -418
  197. package/packages/config-eslint/node_modules/eslint/lib/rules/arrow-parens.js +0 -237
  198. package/packages/config-eslint/node_modules/eslint/lib/rules/arrow-spacing.js +0 -188
  199. package/packages/config-eslint/node_modules/eslint/lib/rules/block-scoped-var.js +0 -144
  200. package/packages/config-eslint/node_modules/eslint/lib/rules/block-spacing.js +0 -202
  201. package/packages/config-eslint/node_modules/eslint/lib/rules/brace-style.js +0 -278
  202. package/packages/config-eslint/node_modules/eslint/lib/rules/callback-return.js +0 -216
  203. package/packages/config-eslint/node_modules/eslint/lib/rules/camelcase.js +0 -422
  204. package/packages/config-eslint/node_modules/eslint/lib/rules/capitalized-comments.js +0 -325
  205. package/packages/config-eslint/node_modules/eslint/lib/rules/class-methods-use-this.js +0 -250
  206. package/packages/config-eslint/node_modules/eslint/lib/rules/comma-dangle.js +0 -424
  207. package/packages/config-eslint/node_modules/eslint/lib/rules/comma-spacing.js +0 -205
  208. package/packages/config-eslint/node_modules/eslint/lib/rules/comma-style.js +0 -391
  209. package/packages/config-eslint/node_modules/eslint/lib/rules/complexity.js +0 -201
  210. package/packages/config-eslint/node_modules/eslint/lib/rules/computed-property-spacing.js +0 -251
  211. package/packages/config-eslint/node_modules/eslint/lib/rules/consistent-return.js +0 -221
  212. package/packages/config-eslint/node_modules/eslint/lib/rules/consistent-this.js +0 -179
  213. package/packages/config-eslint/node_modules/eslint/lib/rules/constructor-super.js +0 -453
  214. package/packages/config-eslint/node_modules/eslint/lib/rules/curly.js +0 -425
  215. package/packages/config-eslint/node_modules/eslint/lib/rules/default-case-last.js +0 -51
  216. package/packages/config-eslint/node_modules/eslint/lib/rules/default-case.js +0 -103
  217. package/packages/config-eslint/node_modules/eslint/lib/rules/default-param-last.js +0 -78
  218. package/packages/config-eslint/node_modules/eslint/lib/rules/dot-location.js +0 -138
  219. package/packages/config-eslint/node_modules/eslint/lib/rules/dot-notation.js +0 -216
  220. package/packages/config-eslint/node_modules/eslint/lib/rules/eol-last.js +0 -135
  221. package/packages/config-eslint/node_modules/eslint/lib/rules/eqeqeq.js +0 -210
  222. package/packages/config-eslint/node_modules/eslint/lib/rules/for-direction.js +0 -168
  223. package/packages/config-eslint/node_modules/eslint/lib/rules/func-call-spacing.js +0 -281
  224. package/packages/config-eslint/node_modules/eslint/lib/rules/func-name-matching.js +0 -338
  225. package/packages/config-eslint/node_modules/eslint/lib/rules/func-names.js +0 -204
  226. package/packages/config-eslint/node_modules/eslint/lib/rules/func-style.js +0 -221
  227. package/packages/config-eslint/node_modules/eslint/lib/rules/function-call-argument-newline.js +0 -166
  228. package/packages/config-eslint/node_modules/eslint/lib/rules/function-paren-newline.js +0 -368
  229. package/packages/config-eslint/node_modules/eslint/lib/rules/generator-star-spacing.js +0 -246
  230. package/packages/config-eslint/node_modules/eslint/lib/rules/getter-return.js +0 -242
  231. package/packages/config-eslint/node_modules/eslint/lib/rules/global-require.js +0 -117
  232. package/packages/config-eslint/node_modules/eslint/lib/rules/grouped-accessor-pairs.js +0 -268
  233. package/packages/config-eslint/node_modules/eslint/lib/rules/guard-for-in.js +0 -85
  234. package/packages/config-eslint/node_modules/eslint/lib/rules/handle-callback-err.js +0 -122
  235. package/packages/config-eslint/node_modules/eslint/lib/rules/id-blacklist.js +0 -241
  236. package/packages/config-eslint/node_modules/eslint/lib/rules/id-denylist.js +0 -223
  237. package/packages/config-eslint/node_modules/eslint/lib/rules/id-length.js +0 -217
  238. package/packages/config-eslint/node_modules/eslint/lib/rules/id-match.js +0 -363
  239. package/packages/config-eslint/node_modules/eslint/lib/rules/implicit-arrow-linebreak.js +0 -125
  240. package/packages/config-eslint/node_modules/eslint/lib/rules/indent-legacy.js +0 -1369
  241. package/packages/config-eslint/node_modules/eslint/lib/rules/indent.js +0 -2334
  242. package/packages/config-eslint/node_modules/eslint/lib/rules/index.js +0 -332
  243. package/packages/config-eslint/node_modules/eslint/lib/rules/init-declarations.js +0 -172
  244. package/packages/config-eslint/node_modules/eslint/lib/rules/jsx-quotes.js +0 -128
  245. package/packages/config-eslint/node_modules/eslint/lib/rules/key-spacing.js +0 -822
  246. package/packages/config-eslint/node_modules/eslint/lib/rules/keyword-spacing.js +0 -701
  247. package/packages/config-eslint/node_modules/eslint/lib/rules/line-comment-position.js +0 -157
  248. package/packages/config-eslint/node_modules/eslint/lib/rules/linebreak-style.js +0 -135
  249. package/packages/config-eslint/node_modules/eslint/lib/rules/lines-around-comment.js +0 -581
  250. package/packages/config-eslint/node_modules/eslint/lib/rules/lines-around-directive.js +0 -249
  251. package/packages/config-eslint/node_modules/eslint/lib/rules/lines-between-class-members.js +0 -358
  252. package/packages/config-eslint/node_modules/eslint/lib/rules/logical-assignment-operators.js +0 -688
  253. package/packages/config-eslint/node_modules/eslint/lib/rules/max-classes-per-file.js +0 -90
  254. package/packages/config-eslint/node_modules/eslint/lib/rules/max-depth.js +0 -159
  255. package/packages/config-eslint/node_modules/eslint/lib/rules/max-len.js +0 -497
  256. package/packages/config-eslint/node_modules/eslint/lib/rules/max-lines-per-function.js +0 -238
  257. package/packages/config-eslint/node_modules/eslint/lib/rules/max-lines.js +0 -189
  258. package/packages/config-eslint/node_modules/eslint/lib/rules/max-nested-callbacks.js +0 -115
  259. package/packages/config-eslint/node_modules/eslint/lib/rules/max-params.js +0 -148
  260. package/packages/config-eslint/node_modules/eslint/lib/rules/max-statements-per-line.js +0 -224
  261. package/packages/config-eslint/node_modules/eslint/lib/rules/max-statements.js +0 -188
  262. package/packages/config-eslint/node_modules/eslint/lib/rules/multiline-comment-style.js +0 -652
  263. package/packages/config-eslint/node_modules/eslint/lib/rules/multiline-ternary.js +0 -257
  264. package/packages/config-eslint/node_modules/eslint/lib/rules/new-cap.js +0 -277
  265. package/packages/config-eslint/node_modules/eslint/lib/rules/new-parens.js +0 -120
  266. package/packages/config-eslint/node_modules/eslint/lib/rules/newline-after-var.js +0 -307
  267. package/packages/config-eslint/node_modules/eslint/lib/rules/newline-before-return.js +0 -242
  268. package/packages/config-eslint/node_modules/eslint/lib/rules/newline-per-chained-call.js +0 -159
  269. package/packages/config-eslint/node_modules/eslint/lib/rules/no-alert.js +0 -149
  270. package/packages/config-eslint/node_modules/eslint/lib/rules/no-array-constructor.js +0 -195
  271. package/packages/config-eslint/node_modules/eslint/lib/rules/no-async-promise-executor.js +0 -45
  272. package/packages/config-eslint/node_modules/eslint/lib/rules/no-await-in-loop.js +0 -115
  273. package/packages/config-eslint/node_modules/eslint/lib/rules/no-bitwise.js +0 -145
  274. package/packages/config-eslint/node_modules/eslint/lib/rules/no-buffer-constructor.js +0 -74
  275. package/packages/config-eslint/node_modules/eslint/lib/rules/no-caller.js +0 -52
  276. package/packages/config-eslint/node_modules/eslint/lib/rules/no-case-declarations.js +0 -80
  277. package/packages/config-eslint/node_modules/eslint/lib/rules/no-catch-shadow.js +0 -96
  278. package/packages/config-eslint/node_modules/eslint/lib/rules/no-class-assign.js +0 -66
  279. package/packages/config-eslint/node_modules/eslint/lib/rules/no-compare-neg-zero.js +0 -74
  280. package/packages/config-eslint/node_modules/eslint/lib/rules/no-cond-assign.js +0 -175
  281. package/packages/config-eslint/node_modules/eslint/lib/rules/no-confusing-arrow.js +0 -127
  282. package/packages/config-eslint/node_modules/eslint/lib/rules/no-console.js +0 -227
  283. package/packages/config-eslint/node_modules/eslint/lib/rules/no-const-assign.js +0 -73
  284. package/packages/config-eslint/node_modules/eslint/lib/rules/no-constant-binary-expression.js +0 -603
  285. package/packages/config-eslint/node_modules/eslint/lib/rules/no-constant-condition.js +0 -177
  286. package/packages/config-eslint/node_modules/eslint/lib/rules/no-constructor-return.js +0 -62
  287. package/packages/config-eslint/node_modules/eslint/lib/rules/no-continue.js +0 -38
  288. package/packages/config-eslint/node_modules/eslint/lib/rules/no-control-regex.js +0 -142
  289. package/packages/config-eslint/node_modules/eslint/lib/rules/no-debugger.js +0 -41
  290. package/packages/config-eslint/node_modules/eslint/lib/rules/no-delete-var.js +0 -42
  291. package/packages/config-eslint/node_modules/eslint/lib/rules/no-div-regex.js +0 -60
  292. package/packages/config-eslint/node_modules/eslint/lib/rules/no-dupe-args.js +0 -98
  293. package/packages/config-eslint/node_modules/eslint/lib/rules/no-dupe-class-members.js +0 -117
  294. package/packages/config-eslint/node_modules/eslint/lib/rules/no-dupe-else-if.js +0 -145
  295. package/packages/config-eslint/node_modules/eslint/lib/rules/no-dupe-keys.js +0 -165
  296. package/packages/config-eslint/node_modules/eslint/lib/rules/no-duplicate-case.js +0 -78
  297. package/packages/config-eslint/node_modules/eslint/lib/rules/no-duplicate-imports.js +0 -368
  298. package/packages/config-eslint/node_modules/eslint/lib/rules/no-else-return.js +0 -456
  299. package/packages/config-eslint/node_modules/eslint/lib/rules/no-empty-character-class.js +0 -83
  300. package/packages/config-eslint/node_modules/eslint/lib/rules/no-empty-function.js +0 -236
  301. package/packages/config-eslint/node_modules/eslint/lib/rules/no-empty-pattern.js +0 -85
  302. package/packages/config-eslint/node_modules/eslint/lib/rules/no-empty-static-block.js +0 -73
  303. package/packages/config-eslint/node_modules/eslint/lib/rules/no-empty.js +0 -153
  304. package/packages/config-eslint/node_modules/eslint/lib/rules/no-eq-null.js +0 -51
  305. package/packages/config-eslint/node_modules/eslint/lib/rules/no-eval.js +0 -301
  306. package/packages/config-eslint/node_modules/eslint/lib/rules/no-ex-assign.js +0 -57
  307. package/packages/config-eslint/node_modules/eslint/lib/rules/no-extend-native.js +0 -180
  308. package/packages/config-eslint/node_modules/eslint/lib/rules/no-extra-bind.js +0 -224
  309. package/packages/config-eslint/node_modules/eslint/lib/rules/no-extra-boolean-cast.js +0 -420
  310. package/packages/config-eslint/node_modules/eslint/lib/rules/no-extra-label.js +0 -169
  311. package/packages/config-eslint/node_modules/eslint/lib/rules/no-extra-parens.js +0 -1669
  312. package/packages/config-eslint/node_modules/eslint/lib/rules/no-extra-semi.js +0 -167
  313. package/packages/config-eslint/node_modules/eslint/lib/rules/no-fallthrough.js +0 -260
  314. package/packages/config-eslint/node_modules/eslint/lib/rules/no-floating-decimal.js +0 -99
  315. package/packages/config-eslint/node_modules/eslint/lib/rules/no-func-assign.js +0 -77
  316. package/packages/config-eslint/node_modules/eslint/lib/rules/no-global-assign.js +0 -101
  317. package/packages/config-eslint/node_modules/eslint/lib/rules/no-implicit-coercion.js +0 -468
  318. package/packages/config-eslint/node_modules/eslint/lib/rules/no-implicit-globals.js +0 -187
  319. package/packages/config-eslint/node_modules/eslint/lib/rules/no-implied-eval.js +0 -171
  320. package/packages/config-eslint/node_modules/eslint/lib/rules/no-import-assign.js +0 -227
  321. package/packages/config-eslint/node_modules/eslint/lib/rules/no-inline-comments.js +0 -115
  322. package/packages/config-eslint/node_modules/eslint/lib/rules/no-inner-declarations.js +0 -147
  323. package/packages/config-eslint/node_modules/eslint/lib/rules/no-invalid-regexp.js +0 -244
  324. package/packages/config-eslint/node_modules/eslint/lib/rules/no-invalid-this.js +0 -178
  325. package/packages/config-eslint/node_modules/eslint/lib/rules/no-irregular-whitespace.js +0 -292
  326. package/packages/config-eslint/node_modules/eslint/lib/rules/no-iterator.js +0 -48
  327. package/packages/config-eslint/node_modules/eslint/lib/rules/no-label-var.js +0 -78
  328. package/packages/config-eslint/node_modules/eslint/lib/rules/no-labels.js +0 -156
  329. package/packages/config-eslint/node_modules/eslint/lib/rules/no-lone-blocks.js +0 -140
  330. package/packages/config-eslint/node_modules/eslint/lib/rules/no-lonely-if.js +0 -126
  331. package/packages/config-eslint/node_modules/eslint/lib/rules/no-loop-func.js +0 -273
  332. package/packages/config-eslint/node_modules/eslint/lib/rules/no-loss-of-precision.js +0 -249
  333. package/packages/config-eslint/node_modules/eslint/lib/rules/no-magic-numbers.js +0 -365
  334. package/packages/config-eslint/node_modules/eslint/lib/rules/no-misleading-character-class.js +0 -595
  335. package/packages/config-eslint/node_modules/eslint/lib/rules/no-mixed-operators.js +0 -253
  336. package/packages/config-eslint/node_modules/eslint/lib/rules/no-mixed-requires.js +0 -267
  337. package/packages/config-eslint/node_modules/eslint/lib/rules/no-mixed-spaces-and-tabs.js +0 -148
  338. package/packages/config-eslint/node_modules/eslint/lib/rules/no-multi-assign.js +0 -66
  339. package/packages/config-eslint/node_modules/eslint/lib/rules/no-multi-spaces.js +0 -179
  340. package/packages/config-eslint/node_modules/eslint/lib/rules/no-multi-str.js +0 -67
  341. package/packages/config-eslint/node_modules/eslint/lib/rules/no-multiple-empty-lines.js +0 -210
  342. package/packages/config-eslint/node_modules/eslint/lib/rules/no-native-reassign.js +0 -114
  343. package/packages/config-eslint/node_modules/eslint/lib/rules/no-negated-condition.js +0 -100
  344. package/packages/config-eslint/node_modules/eslint/lib/rules/no-negated-in-lhs.js +0 -59
  345. package/packages/config-eslint/node_modules/eslint/lib/rules/no-nested-ternary.js +0 -46
  346. package/packages/config-eslint/node_modules/eslint/lib/rules/no-new-func.js +0 -96
  347. package/packages/config-eslint/node_modules/eslint/lib/rules/no-new-native-nonconstructor.js +0 -70
  348. package/packages/config-eslint/node_modules/eslint/lib/rules/no-new-object.js +0 -76
  349. package/packages/config-eslint/node_modules/eslint/lib/rules/no-new-require.js +0 -67
  350. package/packages/config-eslint/node_modules/eslint/lib/rules/no-new-symbol.js +0 -74
  351. package/packages/config-eslint/node_modules/eslint/lib/rules/no-new-wrappers.js +0 -62
  352. package/packages/config-eslint/node_modules/eslint/lib/rules/no-new.js +0 -42
  353. package/packages/config-eslint/node_modules/eslint/lib/rules/no-nonoctal-decimal-escape.js +0 -176
  354. package/packages/config-eslint/node_modules/eslint/lib/rules/no-obj-calls.js +0 -99
  355. package/packages/config-eslint/node_modules/eslint/lib/rules/no-object-constructor.js +0 -124
  356. package/packages/config-eslint/node_modules/eslint/lib/rules/no-octal-escape.js +0 -53
  357. package/packages/config-eslint/node_modules/eslint/lib/rules/no-octal.js +0 -42
  358. package/packages/config-eslint/node_modules/eslint/lib/rules/no-param-reassign.js +0 -248
  359. package/packages/config-eslint/node_modules/eslint/lib/rules/no-path-concat.js +0 -79
  360. package/packages/config-eslint/node_modules/eslint/lib/rules/no-plusplus.js +0 -102
  361. package/packages/config-eslint/node_modules/eslint/lib/rules/no-process-env.js +0 -68
  362. package/packages/config-eslint/node_modules/eslint/lib/rules/no-process-exit.js +0 -67
  363. package/packages/config-eslint/node_modules/eslint/lib/rules/no-promise-executor-return.js +0 -264
  364. package/packages/config-eslint/node_modules/eslint/lib/rules/no-proto.js +0 -45
  365. package/packages/config-eslint/node_modules/eslint/lib/rules/no-prototype-builtins.js +0 -181
  366. package/packages/config-eslint/node_modules/eslint/lib/rules/no-redeclare.js +0 -173
  367. package/packages/config-eslint/node_modules/eslint/lib/rules/no-regex-spaces.js +0 -219
  368. package/packages/config-eslint/node_modules/eslint/lib/rules/no-restricted-exports.js +0 -227
  369. package/packages/config-eslint/node_modules/eslint/lib/rules/no-restricted-globals.js +0 -266
  370. package/packages/config-eslint/node_modules/eslint/lib/rules/no-restricted-imports.js +0 -892
  371. package/packages/config-eslint/node_modules/eslint/lib/rules/no-restricted-modules.js +0 -249
  372. package/packages/config-eslint/node_modules/eslint/lib/rules/no-restricted-properties.js +0 -233
  373. package/packages/config-eslint/node_modules/eslint/lib/rules/no-restricted-syntax.js +0 -74
  374. package/packages/config-eslint/node_modules/eslint/lib/rules/no-return-assign.js +0 -87
  375. package/packages/config-eslint/node_modules/eslint/lib/rules/no-return-await.js +0 -162
  376. package/packages/config-eslint/node_modules/eslint/lib/rules/no-script-url.js +0 -68
  377. package/packages/config-eslint/node_modules/eslint/lib/rules/no-self-assign.js +0 -186
  378. package/packages/config-eslint/node_modules/eslint/lib/rules/no-self-compare.js +0 -77
  379. package/packages/config-eslint/node_modules/eslint/lib/rules/no-sequences.js +0 -158
  380. package/packages/config-eslint/node_modules/eslint/lib/rules/no-setter-return.js +0 -224
  381. package/packages/config-eslint/node_modules/eslint/lib/rules/no-shadow-restricted-names.js +0 -113
  382. package/packages/config-eslint/node_modules/eslint/lib/rules/no-shadow.js +0 -695
  383. package/packages/config-eslint/node_modules/eslint/lib/rules/no-spaced-func.js +0 -105
  384. package/packages/config-eslint/node_modules/eslint/lib/rules/no-sparse-arrays.js +0 -68
  385. package/packages/config-eslint/node_modules/eslint/lib/rules/no-sync.js +0 -81
  386. package/packages/config-eslint/node_modules/eslint/lib/rules/no-tabs.js +0 -110
  387. package/packages/config-eslint/node_modules/eslint/lib/rules/no-template-curly-in-string.js +0 -45
  388. package/packages/config-eslint/node_modules/eslint/lib/rules/no-ternary.js +0 -38
  389. package/packages/config-eslint/node_modules/eslint/lib/rules/no-this-before-super.js +0 -365
  390. package/packages/config-eslint/node_modules/eslint/lib/rules/no-throw-literal.js +0 -46
  391. package/packages/config-eslint/node_modules/eslint/lib/rules/no-trailing-spaces.js +0 -227
  392. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unassigned-vars.js +0 -80
  393. package/packages/config-eslint/node_modules/eslint/lib/rules/no-undef-init.js +0 -101
  394. package/packages/config-eslint/node_modules/eslint/lib/rules/no-undef.js +0 -84
  395. package/packages/config-eslint/node_modules/eslint/lib/rules/no-undefined.js +0 -91
  396. package/packages/config-eslint/node_modules/eslint/lib/rules/no-underscore-dangle.js +0 -383
  397. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unexpected-multiline.js +0 -130
  398. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unmodified-loop-condition.js +0 -367
  399. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unneeded-ternary.js +0 -232
  400. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unreachable-loop.js +0 -190
  401. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unreachable.js +0 -300
  402. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unsafe-finally.js +0 -119
  403. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unsafe-negation.js +0 -152
  404. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unsafe-optional-chaining.js +0 -221
  405. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unused-expressions.js +0 -227
  406. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unused-labels.js +0 -158
  407. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unused-private-class-members.js +0 -219
  408. package/packages/config-eslint/node_modules/eslint/lib/rules/no-unused-vars.js +0 -1746
  409. package/packages/config-eslint/node_modules/eslint/lib/rules/no-use-before-define.js +0 -453
  410. package/packages/config-eslint/node_modules/eslint/lib/rules/no-useless-assignment.js +0 -658
  411. package/packages/config-eslint/node_modules/eslint/lib/rules/no-useless-backreference.js +0 -263
  412. package/packages/config-eslint/node_modules/eslint/lib/rules/no-useless-call.js +0 -95
  413. package/packages/config-eslint/node_modules/eslint/lib/rules/no-useless-catch.js +0 -57
  414. package/packages/config-eslint/node_modules/eslint/lib/rules/no-useless-computed-key.js +0 -204
  415. package/packages/config-eslint/node_modules/eslint/lib/rules/no-useless-concat.js +0 -121
  416. package/packages/config-eslint/node_modules/eslint/lib/rules/no-useless-constructor.js +0 -262
  417. package/packages/config-eslint/node_modules/eslint/lib/rules/no-useless-escape.js +0 -406
  418. package/packages/config-eslint/node_modules/eslint/lib/rules/no-useless-rename.js +0 -202
  419. package/packages/config-eslint/node_modules/eslint/lib/rules/no-useless-return.js +0 -401
  420. package/packages/config-eslint/node_modules/eslint/lib/rules/no-var.js +0 -375
  421. package/packages/config-eslint/node_modules/eslint/lib/rules/no-void.js +0 -69
  422. package/packages/config-eslint/node_modules/eslint/lib/rules/no-warning-comments.js +0 -209
  423. package/packages/config-eslint/node_modules/eslint/lib/rules/no-whitespace-before-property.js +0 -150
  424. package/packages/config-eslint/node_modules/eslint/lib/rules/no-with.js +0 -37
  425. package/packages/config-eslint/node_modules/eslint/lib/rules/nonblock-statement-body-position.js +0 -164
  426. package/packages/config-eslint/node_modules/eslint/lib/rules/object-curly-newline.js +0 -383
  427. package/packages/config-eslint/node_modules/eslint/lib/rules/object-curly-spacing.js +0 -369
  428. package/packages/config-eslint/node_modules/eslint/lib/rules/object-property-newline.js +0 -151
  429. package/packages/config-eslint/node_modules/eslint/lib/rules/object-shorthand.js +0 -652
  430. package/packages/config-eslint/node_modules/eslint/lib/rules/one-var-declaration-per-line.js +0 -117
  431. package/packages/config-eslint/node_modules/eslint/lib/rules/one-var.js +0 -717
  432. package/packages/config-eslint/node_modules/eslint/lib/rules/operator-assignment.js +0 -270
  433. package/packages/config-eslint/node_modules/eslint/lib/rules/operator-linebreak.js +0 -315
  434. package/packages/config-eslint/node_modules/eslint/lib/rules/padded-blocks.js +0 -366
  435. package/packages/config-eslint/node_modules/eslint/lib/rules/padding-line-between-statements.js +0 -612
  436. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-arrow-callback.js +0 -444
  437. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-const.js +0 -554
  438. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-destructuring.js +0 -332
  439. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-exponentiation-operator.js +0 -235
  440. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-named-capture-group.js +0 -197
  441. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-numeric-literals.js +0 -157
  442. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-object-has-own.js +0 -148
  443. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-object-spread.js +0 -319
  444. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-promise-reject-errors.js +0 -154
  445. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-reflect.js +0 -150
  446. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-regex-literals.js +0 -605
  447. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-rest-params.js +0 -125
  448. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-spread.js +0 -91
  449. package/packages/config-eslint/node_modules/eslint/lib/rules/prefer-template.js +0 -347
  450. package/packages/config-eslint/node_modules/eslint/lib/rules/preserve-caught-error.js +0 -535
  451. package/packages/config-eslint/node_modules/eslint/lib/rules/quote-props.js +0 -394
  452. package/packages/config-eslint/node_modules/eslint/lib/rules/quotes.js +0 -416
  453. package/packages/config-eslint/node_modules/eslint/lib/rules/radix.js +0 -199
  454. package/packages/config-eslint/node_modules/eslint/lib/rules/require-atomic-updates.js +0 -365
  455. package/packages/config-eslint/node_modules/eslint/lib/rules/require-await.js +0 -184
  456. package/packages/config-eslint/node_modules/eslint/lib/rules/require-unicode-regexp.js +0 -317
  457. package/packages/config-eslint/node_modules/eslint/lib/rules/require-yield.js +0 -86
  458. package/packages/config-eslint/node_modules/eslint/lib/rules/rest-spread-spacing.js +0 -150
  459. package/packages/config-eslint/node_modules/eslint/lib/rules/semi-spacing.js +0 -297
  460. package/packages/config-eslint/node_modules/eslint/lib/rules/semi-style.js +0 -218
  461. package/packages/config-eslint/node_modules/eslint/lib/rules/semi.js +0 -476
  462. package/packages/config-eslint/node_modules/eslint/lib/rules/sort-imports.js +0 -319
  463. package/packages/config-eslint/node_modules/eslint/lib/rules/sort-keys.js +0 -268
  464. package/packages/config-eslint/node_modules/eslint/lib/rules/sort-vars.js +0 -140
  465. package/packages/config-eslint/node_modules/eslint/lib/rules/space-before-blocks.js +0 -232
  466. package/packages/config-eslint/node_modules/eslint/lib/rules/space-before-function-paren.js +0 -202
  467. package/packages/config-eslint/node_modules/eslint/lib/rules/space-in-parens.js +0 -374
  468. package/packages/config-eslint/node_modules/eslint/lib/rules/space-infix-ops.js +0 -249
  469. package/packages/config-eslint/node_modules/eslint/lib/rules/space-unary-ops.js +0 -400
  470. package/packages/config-eslint/node_modules/eslint/lib/rules/spaced-comment.js +0 -447
  471. package/packages/config-eslint/node_modules/eslint/lib/rules/strict.js +0 -324
  472. package/packages/config-eslint/node_modules/eslint/lib/rules/switch-colon-spacing.js +0 -158
  473. package/packages/config-eslint/node_modules/eslint/lib/rules/symbol-description.js +0 -70
  474. package/packages/config-eslint/node_modules/eslint/lib/rules/template-curly-spacing.js +0 -168
  475. package/packages/config-eslint/node_modules/eslint/lib/rules/template-tag-spacing.js +0 -121
  476. package/packages/config-eslint/node_modules/eslint/lib/rules/unicode-bom.js +0 -73
  477. package/packages/config-eslint/node_modules/eslint/lib/rules/use-isnan.js +0 -268
  478. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/ast-utils.js +0 -2848
  479. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/char-source.js +0 -247
  480. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/fix-tracker.js +0 -125
  481. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/keywords.js +0 -67
  482. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/lazy-loading-rule-map.js +0 -118
  483. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/regular-expressions.js +0 -58
  484. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/unicode/index.js +0 -16
  485. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/unicode/is-combining-character.js +0 -13
  486. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/unicode/is-emoji-modifier.js +0 -13
  487. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/unicode/is-regional-indicator-symbol.js +0 -13
  488. package/packages/config-eslint/node_modules/eslint/lib/rules/utils/unicode/is-surrogate-pair.js +0 -14
  489. package/packages/config-eslint/node_modules/eslint/lib/rules/valid-typeof.js +0 -171
  490. package/packages/config-eslint/node_modules/eslint/lib/rules/vars-on-top.js +0 -165
  491. package/packages/config-eslint/node_modules/eslint/lib/rules/wrap-iife.js +0 -238
  492. package/packages/config-eslint/node_modules/eslint/lib/rules/wrap-regex.js +0 -91
  493. package/packages/config-eslint/node_modules/eslint/lib/rules/yield-star-spacing.js +0 -158
  494. package/packages/config-eslint/node_modules/eslint/lib/rules/yoda.js +0 -362
  495. package/packages/config-eslint/node_modules/eslint/lib/services/parser-service.js +0 -64
  496. package/packages/config-eslint/node_modules/eslint/lib/services/processor-service.js +0 -100
  497. package/packages/config-eslint/node_modules/eslint/lib/services/suppressions-service.js +0 -302
  498. package/packages/config-eslint/node_modules/eslint/lib/services/warning-service.js +0 -87
  499. package/packages/config-eslint/node_modules/eslint/lib/shared/ajv.js +0 -34
  500. package/packages/config-eslint/node_modules/eslint/lib/shared/assert.js +0 -21
  501. package/packages/config-eslint/node_modules/eslint/lib/shared/ast-utils.js +0 -30
  502. package/packages/config-eslint/node_modules/eslint/lib/shared/deep-merge-arrays.js +0 -62
  503. package/packages/config-eslint/node_modules/eslint/lib/shared/directives.js +0 -16
  504. package/packages/config-eslint/node_modules/eslint/lib/shared/flags.js +0 -89
  505. package/packages/config-eslint/node_modules/eslint/lib/shared/logging.js +0 -38
  506. package/packages/config-eslint/node_modules/eslint/lib/shared/naming.js +0 -109
  507. package/packages/config-eslint/node_modules/eslint/lib/shared/option-utils.js +0 -63
  508. package/packages/config-eslint/node_modules/eslint/lib/shared/relative-module-resolver.js +0 -28
  509. package/packages/config-eslint/node_modules/eslint/lib/shared/runtime-info.js +0 -177
  510. package/packages/config-eslint/node_modules/eslint/lib/shared/serialization.js +0 -78
  511. package/packages/config-eslint/node_modules/eslint/lib/shared/severity.js +0 -49
  512. package/packages/config-eslint/node_modules/eslint/lib/shared/stats.js +0 -30
  513. package/packages/config-eslint/node_modules/eslint/lib/shared/string-utils.js +0 -58
  514. package/packages/config-eslint/node_modules/eslint/lib/shared/text-table.js +0 -68
  515. package/packages/config-eslint/node_modules/eslint/lib/shared/translate-cli-options.js +0 -223
  516. package/packages/config-eslint/node_modules/eslint/lib/shared/traverser.js +0 -202
  517. package/packages/config-eslint/node_modules/eslint/lib/types/config-api.d.ts +0 -12
  518. package/packages/config-eslint/node_modules/eslint/lib/types/index.d.ts +0 -1475
  519. package/packages/config-eslint/node_modules/eslint/lib/types/rules.d.ts +0 -5603
  520. package/packages/config-eslint/node_modules/eslint/lib/types/universal.d.ts +0 -6
  521. package/packages/config-eslint/node_modules/eslint/lib/types/use-at-your-own-risk.d.ts +0 -34
  522. package/packages/config-eslint/node_modules/eslint/lib/universal.js +0 -10
  523. package/packages/config-eslint/node_modules/eslint/lib/unsupported-api.js +0 -21
  524. package/packages/config-eslint/node_modules/eslint/messages/all-matched-files-ignored.js +0 -21
  525. package/packages/config-eslint/node_modules/eslint/messages/config-file-missing.js +0 -16
  526. package/packages/config-eslint/node_modules/eslint/messages/config-plugin-missing.js +0 -14
  527. package/packages/config-eslint/node_modules/eslint/messages/config-serialize-function.js +0 -30
  528. package/packages/config-eslint/node_modules/eslint/messages/eslintrc-incompat.js +0 -117
  529. package/packages/config-eslint/node_modules/eslint/messages/eslintrc-plugins.js +0 -27
  530. package/packages/config-eslint/node_modules/eslint/messages/extend-config-missing.js +0 -13
  531. package/packages/config-eslint/node_modules/eslint/messages/failed-to-read-json.js +0 -11
  532. package/packages/config-eslint/node_modules/eslint/messages/file-not-found.js +0 -10
  533. package/packages/config-eslint/node_modules/eslint/messages/invalid-rule-options.js +0 -17
  534. package/packages/config-eslint/node_modules/eslint/messages/invalid-rule-severity.js +0 -13
  535. package/packages/config-eslint/node_modules/eslint/messages/no-config-found.js +0 -15
  536. package/packages/config-eslint/node_modules/eslint/messages/plugin-conflict.js +0 -22
  537. package/packages/config-eslint/node_modules/eslint/messages/plugin-invalid.js +0 -16
  538. package/packages/config-eslint/node_modules/eslint/messages/plugin-missing.js +0 -19
  539. package/packages/config-eslint/node_modules/eslint/messages/shared.js +0 -23
  540. package/packages/config-eslint/node_modules/eslint/messages/whitespace-found.js +0 -11
  541. package/packages/config-eslint/node_modules/eslint/package.json +0 -220
  542. package/packages/config-eslint/node_modules/eslint-visitor-keys/LICENSE +0 -201
  543. package/packages/config-eslint/node_modules/eslint-visitor-keys/README.md +0 -123
  544. package/packages/config-eslint/node_modules/eslint-visitor-keys/dist/eslint-visitor-keys.cjs +0 -187
  545. package/packages/config-eslint/node_modules/eslint-visitor-keys/dist/eslint-visitor-keys.d.cts +0 -28
  546. package/packages/config-eslint/node_modules/eslint-visitor-keys/dist/index.d.ts +0 -16
  547. package/packages/config-eslint/node_modules/eslint-visitor-keys/dist/visitor-keys.d.ts +0 -12
  548. package/packages/config-eslint/node_modules/eslint-visitor-keys/lib/index.js +0 -67
  549. package/packages/config-eslint/node_modules/eslint-visitor-keys/lib/visitor-keys.js +0 -118
  550. package/packages/config-eslint/node_modules/eslint-visitor-keys/package.json +0 -57
  551. package/packages/config-eslint/node_modules/espree/LICENSE +0 -25
  552. package/packages/config-eslint/node_modules/espree/README.md +0 -261
  553. package/packages/config-eslint/node_modules/espree/dist/espree.cjs +0 -1284
  554. package/packages/config-eslint/node_modules/espree/dist/espree.d.cts +0 -3
  555. package/packages/config-eslint/node_modules/espree/dist/espree.d.cts.map +0 -1
  556. package/packages/config-eslint/node_modules/espree/dist/espree.d.ts +0 -67
  557. package/packages/config-eslint/node_modules/espree/dist/espree.d.ts.map +0 -1
  558. package/packages/config-eslint/node_modules/espree/espree.js +0 -287
  559. package/packages/config-eslint/node_modules/espree/lib/espree.js +0 -493
  560. package/packages/config-eslint/node_modules/espree/lib/options.js +0 -176
  561. package/packages/config-eslint/node_modules/espree/lib/token-translator.js +0 -306
  562. package/packages/config-eslint/node_modules/espree/lib/types.js +0 -118
  563. package/packages/config-eslint/node_modules/espree/package.json +0 -70
  564. package/packages/config-eslint/node_modules/ignore/LICENSE-MIT +0 -21
  565. package/packages/config-eslint/node_modules/ignore/README.md +0 -412
  566. package/packages/config-eslint/node_modules/ignore/index.d.ts +0 -61
  567. package/packages/config-eslint/node_modules/ignore/index.js +0 -636
  568. package/packages/config-eslint/node_modules/ignore/legacy.js +0 -559
  569. package/packages/config-eslint/node_modules/ignore/package.json +0 -74
  570. package/packages/config-eslint/node_modules/json-schema-traverse/.eslintrc.yml +0 -27
  571. package/packages/config-eslint/node_modules/json-schema-traverse/.travis.yml +0 -8
  572. package/packages/config-eslint/node_modules/json-schema-traverse/LICENSE +0 -21
  573. package/packages/config-eslint/node_modules/json-schema-traverse/README.md +0 -83
  574. package/packages/config-eslint/node_modules/json-schema-traverse/index.js +0 -89
  575. package/packages/config-eslint/node_modules/json-schema-traverse/package.json +0 -43
  576. package/packages/config-eslint/node_modules/json-schema-traverse/spec/.eslintrc.yml +0 -6
  577. package/packages/config-eslint/node_modules/json-schema-traverse/spec/fixtures/schema.js +0 -125
  578. package/packages/config-eslint/node_modules/json-schema-traverse/spec/index.spec.js +0 -171
  579. package/packages/config-eslint/node_modules/minimatch/LICENSE.md +0 -55
  580. package/packages/config-eslint/node_modules/minimatch/README.md +0 -528
  581. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts +0 -2
  582. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts.map +0 -1
  583. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js +0 -14
  584. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js.map +0 -1
  585. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/ast.d.ts +0 -22
  586. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/ast.d.ts.map +0 -1
  587. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/ast.js +0 -846
  588. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/ast.js.map +0 -1
  589. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts +0 -8
  590. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts.map +0 -1
  591. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/brace-expressions.js +0 -150
  592. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/brace-expressions.js.map +0 -1
  593. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/escape.d.ts +0 -15
  594. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/escape.d.ts.map +0 -1
  595. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/escape.js +0 -30
  596. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/escape.js.map +0 -1
  597. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/index.d.ts +0 -174
  598. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/index.d.ts.map +0 -1
  599. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/index.js +0 -1121
  600. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/index.js.map +0 -1
  601. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/package.json +0 -3
  602. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/unescape.d.ts +0 -22
  603. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/unescape.d.ts.map +0 -1
  604. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/unescape.js +0 -38
  605. package/packages/config-eslint/node_modules/minimatch/dist/commonjs/unescape.js.map +0 -1
  606. package/packages/config-eslint/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts +0 -2
  607. package/packages/config-eslint/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts.map +0 -1
  608. package/packages/config-eslint/node_modules/minimatch/dist/esm/assert-valid-pattern.js +0 -10
  609. package/packages/config-eslint/node_modules/minimatch/dist/esm/assert-valid-pattern.js.map +0 -1
  610. package/packages/config-eslint/node_modules/minimatch/dist/esm/ast.d.ts +0 -22
  611. package/packages/config-eslint/node_modules/minimatch/dist/esm/ast.d.ts.map +0 -1
  612. package/packages/config-eslint/node_modules/minimatch/dist/esm/ast.js +0 -842
  613. package/packages/config-eslint/node_modules/minimatch/dist/esm/ast.js.map +0 -1
  614. package/packages/config-eslint/node_modules/minimatch/dist/esm/brace-expressions.d.ts +0 -8
  615. package/packages/config-eslint/node_modules/minimatch/dist/esm/brace-expressions.d.ts.map +0 -1
  616. package/packages/config-eslint/node_modules/minimatch/dist/esm/brace-expressions.js +0 -146
  617. package/packages/config-eslint/node_modules/minimatch/dist/esm/brace-expressions.js.map +0 -1
  618. package/packages/config-eslint/node_modules/minimatch/dist/esm/escape.d.ts +0 -15
  619. package/packages/config-eslint/node_modules/minimatch/dist/esm/escape.d.ts.map +0 -1
  620. package/packages/config-eslint/node_modules/minimatch/dist/esm/escape.js +0 -26
  621. package/packages/config-eslint/node_modules/minimatch/dist/esm/escape.js.map +0 -1
  622. package/packages/config-eslint/node_modules/minimatch/dist/esm/index.d.ts +0 -174
  623. package/packages/config-eslint/node_modules/minimatch/dist/esm/index.d.ts.map +0 -1
  624. package/packages/config-eslint/node_modules/minimatch/dist/esm/index.js +0 -1108
  625. package/packages/config-eslint/node_modules/minimatch/dist/esm/index.js.map +0 -1
  626. package/packages/config-eslint/node_modules/minimatch/dist/esm/package.json +0 -3
  627. package/packages/config-eslint/node_modules/minimatch/dist/esm/unescape.d.ts +0 -22
  628. package/packages/config-eslint/node_modules/minimatch/dist/esm/unescape.d.ts.map +0 -1
  629. package/packages/config-eslint/node_modules/minimatch/dist/esm/unescape.js +0 -34
  630. package/packages/config-eslint/node_modules/minimatch/dist/esm/unescape.js.map +0 -1
  631. package/packages/config-eslint/node_modules/minimatch/package.json +0 -67
@@ -1,1178 +0,0 @@
1
- /**
2
- * @fileoverview Abstraction of JavaScript source code.
3
- * @author Nicholas C. Zakas
4
- */
5
- "use strict";
6
-
7
- //------------------------------------------------------------------------------
8
- // Requirements
9
- //------------------------------------------------------------------------------
10
-
11
- const TokenStore = require("./token-store"),
12
- astUtils = require("../../../shared/ast-utils"),
13
- Traverser = require("../../../shared/traverser"),
14
- globals = require("../../../../conf/globals"),
15
- { directivesPattern } = require("../../../shared/directives"),
16
- CodePathAnalyzer = require("../../../linter/code-path-analysis/code-path-analyzer"),
17
- {
18
- ConfigCommentParser,
19
- VisitNodeStep,
20
- CallMethodStep,
21
- Directive,
22
- } = require("@eslint/plugin-kit");
23
-
24
- //------------------------------------------------------------------------------
25
- // Type Definitions
26
- //------------------------------------------------------------------------------
27
-
28
- /** @typedef {import("eslint-scope").Variable} Variable */
29
- /** @typedef {import("eslint-scope").Scope} Scope */
30
- /** @typedef {import("eslint-scope").ScopeManager} ScopeManager */
31
- /** @typedef {import("@eslint/core").SourceCode} ISourceCode */
32
- /** @typedef {import("@eslint/core").Directive} IDirective */
33
- /** @typedef {import("@eslint/core").TraversalStep} ITraversalStep */
34
-
35
- //------------------------------------------------------------------------------
36
- // Private
37
- //------------------------------------------------------------------------------
38
-
39
- const commentParser = new ConfigCommentParser();
40
-
41
- /**
42
- * Validates that the given AST has the required information.
43
- * @param {ASTNode} ast The Program node of the AST to check.
44
- * @throws {TypeError} If the AST doesn't contain the correct information.
45
- * @returns {void}
46
- * @private
47
- */
48
- function validate(ast) {
49
- if (!ast) {
50
- throw new TypeError(`Unexpected empty AST. (${ast})`);
51
- }
52
-
53
- if (!ast.tokens) {
54
- throw new TypeError("AST is missing the tokens array.");
55
- }
56
-
57
- if (!ast.comments) {
58
- throw new TypeError("AST is missing the comments array.");
59
- }
60
-
61
- if (!ast.loc) {
62
- throw new TypeError("AST is missing location information.");
63
- }
64
-
65
- if (!ast.range) {
66
- throw new TypeError("AST is missing range information");
67
- }
68
- }
69
-
70
- /**
71
- * Retrieves globals for the given ecmaVersion.
72
- * @param {number} ecmaVersion The version to retrieve globals for.
73
- * @returns {Object} The globals for the given ecmaVersion.
74
- */
75
- function getGlobalsForEcmaVersion(ecmaVersion) {
76
- switch (ecmaVersion) {
77
- case 3:
78
- return globals.es3;
79
-
80
- case 5:
81
- return globals.es5;
82
-
83
- default:
84
- if (ecmaVersion < 2015) {
85
- return globals[`es${ecmaVersion + 2009}`];
86
- }
87
-
88
- return globals[`es${ecmaVersion}`];
89
- }
90
- }
91
-
92
- /**
93
- * Merges two sorted lists into a larger sorted list in O(n) time.
94
- * @param {Token[]} tokens The list of tokens.
95
- * @param {Token[]} comments The list of comments.
96
- * @returns {Token[]} A sorted list of tokens and comments.
97
- * @private
98
- */
99
- function sortedMerge(tokens, comments) {
100
- const result = [];
101
- let tokenIndex = 0;
102
- let commentIndex = 0;
103
-
104
- while (tokenIndex < tokens.length || commentIndex < comments.length) {
105
- if (
106
- commentIndex >= comments.length ||
107
- (tokenIndex < tokens.length &&
108
- tokens[tokenIndex].range[0] < comments[commentIndex].range[0])
109
- ) {
110
- result.push(tokens[tokenIndex++]);
111
- } else {
112
- result.push(comments[commentIndex++]);
113
- }
114
- }
115
-
116
- return result;
117
- }
118
-
119
- /**
120
- * Normalizes a value for a global in a config
121
- * @param {(boolean|string|null)} configuredValue The value given for a global in configuration or in
122
- * a global directive comment
123
- * @returns {("readonly"|"writable"|"off")} The value normalized as a string
124
- * @throws {Error} if global value is invalid
125
- */
126
- function normalizeConfigGlobal(configuredValue) {
127
- switch (configuredValue) {
128
- case "off":
129
- return "off";
130
-
131
- case true:
132
- case "true":
133
- case "writeable":
134
- case "writable":
135
- return "writable";
136
-
137
- case null:
138
- case false:
139
- case "false":
140
- case "readable":
141
- case "readonly":
142
- return "readonly";
143
-
144
- default:
145
- throw new Error(
146
- `'${configuredValue}' is not a valid configuration for a global (use 'readonly', 'writable', or 'off')`,
147
- );
148
- }
149
- }
150
-
151
- /**
152
- * Determines if two nodes or tokens overlap.
153
- * @param {ASTNode|Token} first The first node or token to check.
154
- * @param {ASTNode|Token} second The second node or token to check.
155
- * @returns {boolean} True if the two nodes or tokens overlap.
156
- * @private
157
- */
158
- function nodesOrTokensOverlap(first, second) {
159
- return (
160
- (first.range[0] <= second.range[0] &&
161
- first.range[1] >= second.range[0]) ||
162
- (second.range[0] <= first.range[0] && second.range[1] >= first.range[0])
163
- );
164
- }
165
-
166
- /**
167
- * Performs binary search to find the line number containing a given character index.
168
- * Returns the lower bound - the index of the first element greater than the target.
169
- * **Please note that the `lineStartIndices` should be sorted in ascending order**.
170
- * - Time Complexity: O(log n) - Significantly faster than linear search for large files.
171
- * @param {number[]} lineStartIndices Sorted array of line start indices.
172
- * @param {number} target The character index to find the line number for.
173
- * @returns {number} The 1-based line number for the target index.
174
- * @private
175
- */
176
- function findLineNumberBinarySearch(lineStartIndices, target) {
177
- let low = 0;
178
- let high = lineStartIndices.length;
179
-
180
- while (low < high) {
181
- const mid = ((low + high) / 2) | 0; // Use bitwise OR to floor the division
182
-
183
- if (target < lineStartIndices[mid]) {
184
- high = mid;
185
- } else {
186
- low = mid + 1;
187
- }
188
- }
189
-
190
- return low;
191
- }
192
-
193
- //-----------------------------------------------------------------------------
194
- // Directive Comments
195
- //-----------------------------------------------------------------------------
196
-
197
- /**
198
- * Ensures that variables representing built-in properties of the Global Object,
199
- * and any globals declared by special block comments, are present in the global
200
- * scope.
201
- * @param {ScopeManager} scopeManager Scope manager.
202
- * @param {Object|undefined} configGlobals The globals declared in configuration
203
- * @param {Object|undefined} inlineGlobals The globals declared in the source code
204
- * @returns {void}
205
- */
206
- function addDeclaredGlobals(
207
- scopeManager,
208
- configGlobals = Object.create(null),
209
- inlineGlobals = Object.create(null),
210
- ) {
211
- const finalGlobals = { __proto__: null, ...configGlobals };
212
-
213
- for (const [name, data] of Object.entries(inlineGlobals)) {
214
- finalGlobals[name] = data.value;
215
- }
216
-
217
- const names = Object.keys(finalGlobals).filter(
218
- name => finalGlobals[name] !== "off",
219
- );
220
-
221
- scopeManager.addGlobals(names);
222
-
223
- const globalScope = scopeManager.scopes[0];
224
-
225
- for (const name of names) {
226
- const variable = globalScope.set.get(name);
227
-
228
- variable.eslintImplicitGlobalSetting = configGlobals[name];
229
- variable.eslintExplicitGlobal = !!inlineGlobals[name];
230
- variable.eslintExplicitGlobalComments = inlineGlobals[name]?.comments;
231
- variable.writeable = finalGlobals[name] === "writable";
232
- }
233
- }
234
-
235
- /**
236
- * Sets the given variable names as exported so they won't be triggered by
237
- * the `no-unused-vars` rule.
238
- * @param {eslint.Scope} globalScope The global scope to define exports in.
239
- * @param {Record<string,string>} variables An object whose keys are the variable
240
- * names to export.
241
- * @returns {void}
242
- */
243
- function markExportedVariables(globalScope, variables) {
244
- Object.keys(variables).forEach(name => {
245
- const variable = globalScope.set.get(name);
246
-
247
- if (variable) {
248
- variable.eslintUsed = true;
249
- variable.eslintExported = true;
250
- }
251
- });
252
- }
253
-
254
- //------------------------------------------------------------------------------
255
- // Public Interface
256
- //------------------------------------------------------------------------------
257
-
258
- const caches = Symbol("caches");
259
-
260
- /**
261
- * Represents parsed source code.
262
- * @implements {ISourceCode}
263
- */
264
- class SourceCode extends TokenStore {
265
- /**
266
- * The cache of steps that were taken while traversing the source code.
267
- * @type {Array<ITraversalStep>}
268
- */
269
- #steps;
270
-
271
- /**
272
- * Creates a new instance.
273
- * @param {string|Object} textOrConfig The source code text or config object.
274
- * @param {string} textOrConfig.text The source code text.
275
- * @param {ASTNode} textOrConfig.ast The Program node of the AST representing the code. This AST should be created from the text that BOM was stripped.
276
- * @param {boolean} textOrConfig.hasBOM Indicates if the text has a Unicode BOM.
277
- * @param {Object|null} textOrConfig.parserServices The parser services.
278
- * @param {ScopeManager|null} textOrConfig.scopeManager The scope of this source code.
279
- * @param {Object|null} textOrConfig.visitorKeys The visitor keys to traverse AST.
280
- * @param {ASTNode} [astIfNoConfig] The Program node of the AST representing the code. This AST should be created from the text that BOM was stripped.
281
- */
282
- constructor(textOrConfig, astIfNoConfig) {
283
- let text, hasBOM, ast, parserServices, scopeManager, visitorKeys;
284
-
285
- // Process overloading of arguments
286
- if (typeof textOrConfig === "string") {
287
- text = textOrConfig;
288
- ast = astIfNoConfig;
289
- hasBOM = false;
290
- } else if (typeof textOrConfig === "object" && textOrConfig !== null) {
291
- text = textOrConfig.text;
292
- ast = textOrConfig.ast;
293
- hasBOM = textOrConfig.hasBOM;
294
- parserServices = textOrConfig.parserServices;
295
- scopeManager = textOrConfig.scopeManager;
296
- visitorKeys = textOrConfig.visitorKeys;
297
- }
298
-
299
- validate(ast);
300
- super(ast.tokens, ast.comments);
301
-
302
- /**
303
- * General purpose caching for the class.
304
- */
305
- this[caches] = new Map([
306
- ["scopes", new WeakMap()],
307
- ["vars", new Map()],
308
- ["configNodes", void 0],
309
- ["isGlobalReference", new WeakMap()],
310
- ]);
311
-
312
- /**
313
- * Indicates if the AST is ESTree compatible.
314
- * @type {boolean}
315
- */
316
- this.isESTree = ast.type === "Program";
317
-
318
- /*
319
- * Backwards compatibility for BOM handling.
320
- *
321
- * The `hasBOM` property has been available on the `SourceCode` object
322
- * for a long time and is used to indicate if the source contains a BOM.
323
- * The linter strips the BOM and just passes the `hasBOM` property to the
324
- * `SourceCode` constructor to make it easier for languages to not deal with
325
- * the BOM.
326
- *
327
- * However, the text passed in to the `SourceCode` constructor might still
328
- * have a BOM if the constructor is called outside of the linter, so we still
329
- * need to check for the BOM in the text.
330
- */
331
- const textHasBOM = text.charCodeAt(0) === 0xfeff;
332
-
333
- /**
334
- * The flag to indicate that the source code has Unicode BOM.
335
- * @type {boolean}
336
- */
337
- this.hasBOM = textHasBOM || !!hasBOM;
338
-
339
- /**
340
- * The original text source code.
341
- * BOM was stripped from this text.
342
- * @type {string}
343
- */
344
- this.text = textHasBOM ? text.slice(1) : text;
345
-
346
- /**
347
- * The parsed AST for the source code.
348
- * @type {ASTNode}
349
- */
350
- this.ast = ast;
351
-
352
- /**
353
- * The parser services of this source code.
354
- * @type {Object}
355
- */
356
- this.parserServices = parserServices || {};
357
-
358
- /**
359
- * The scope of this source code.
360
- * @type {ScopeManager|null}
361
- */
362
- this.scopeManager = scopeManager || null;
363
-
364
- /**
365
- * The visitor keys to traverse AST.
366
- * @type {Object}
367
- */
368
- this.visitorKeys = visitorKeys || Traverser.DEFAULT_VISITOR_KEYS;
369
-
370
- // Check the source text for the presence of a shebang since it is parsed as a standard line comment.
371
- const shebangMatched = this.text.match(astUtils.shebangPattern);
372
- const hasShebang =
373
- shebangMatched &&
374
- ast.comments.length &&
375
- ast.comments[0].value === shebangMatched[1];
376
-
377
- if (hasShebang) {
378
- ast.comments[0].type = "Shebang";
379
- }
380
-
381
- this.tokensAndComments = sortedMerge(ast.tokens, ast.comments);
382
-
383
- /**
384
- * The source code split into lines according to ECMA-262 specification.
385
- * This is done to avoid each rule needing to do so separately.
386
- * @type {string[]}
387
- */
388
- this.lines = [];
389
-
390
- /**
391
- * @type {number[]}
392
- */
393
- this.lineStartIndices = [0];
394
-
395
- const lineEndingPattern = astUtils.createGlobalLinebreakMatcher();
396
- let match;
397
-
398
- /*
399
- * Previously, this was implemented using a regex that
400
- * matched a sequence of non-linebreak characters followed by a
401
- * linebreak, then adding the lengths of the matches. However,
402
- * this caused a catastrophic backtracking issue when the end
403
- * of a file contained a large number of non-newline characters.
404
- * To avoid this, the current implementation just matches newlines
405
- * and uses match.index to get the correct line start indices.
406
- */
407
- while ((match = lineEndingPattern.exec(this.text))) {
408
- this.lines.push(
409
- this.text.slice(this.lineStartIndices.at(-1), match.index),
410
- );
411
- this.lineStartIndices.push(match.index + match[0].length);
412
- }
413
- this.lines.push(this.text.slice(this.lineStartIndices.at(-1)));
414
-
415
- // don't allow further modification of this object
416
- Object.freeze(this);
417
- Object.freeze(this.lines);
418
- }
419
-
420
- /**
421
- * Split the source code into multiple lines based on the line delimiters.
422
- * @param {string} text Source code as a string.
423
- * @returns {string[]} Array of source code lines.
424
- * @public
425
- */
426
- static splitLines(text) {
427
- return text.split(astUtils.createGlobalLinebreakMatcher());
428
- }
429
-
430
- /**
431
- * Gets the source code for the given node.
432
- * @param {ASTNode} [node] The AST node to get the text for.
433
- * @param {number} [beforeCount] The number of characters before the node to retrieve.
434
- * @param {number} [afterCount] The number of characters after the node to retrieve.
435
- * @returns {string} The text representing the AST node.
436
- * @public
437
- */
438
- getText(node, beforeCount, afterCount) {
439
- if (node) {
440
- return this.text.slice(
441
- Math.max(node.range[0] - (beforeCount || 0), 0),
442
- node.range[1] + (afterCount || 0),
443
- );
444
- }
445
- return this.text;
446
- }
447
-
448
- /**
449
- * Gets the entire source text split into an array of lines.
450
- * @returns {string[]} The source text as an array of lines.
451
- * @public
452
- */
453
- getLines() {
454
- return this.lines;
455
- }
456
-
457
- /**
458
- * Retrieves an array containing all comments in the source code.
459
- * @returns {ASTNode[]} An array of comment nodes.
460
- * @public
461
- */
462
- getAllComments() {
463
- return this.ast.comments;
464
- }
465
-
466
- /**
467
- * Gets the deepest node containing a range index.
468
- * @param {number} index Range index of the desired node.
469
- * @returns {ASTNode} The node if found or null if not found.
470
- * @public
471
- */
472
- getNodeByRangeIndex(index) {
473
- let result = null;
474
-
475
- Traverser.traverse(this.ast, {
476
- visitorKeys: this.visitorKeys,
477
- enter(node) {
478
- if (node.range[0] <= index && index < node.range[1]) {
479
- result = node;
480
- } else {
481
- this.skip();
482
- }
483
- },
484
- leave(node) {
485
- if (node === result) {
486
- this.break();
487
- }
488
- },
489
- });
490
-
491
- return result;
492
- }
493
-
494
- /**
495
- * Determines if two nodes or tokens have at least one whitespace character
496
- * between them. Order does not matter. Returns false if the given nodes or
497
- * tokens overlap.
498
- * @param {ASTNode|Token} first The first node or token to check between.
499
- * @param {ASTNode|Token} second The second node or token to check between.
500
- * @returns {boolean} True if there is a whitespace character between
501
- * any of the tokens found between the two given nodes or tokens.
502
- * @public
503
- */
504
- isSpaceBetween(first, second) {
505
- if (nodesOrTokensOverlap(first, second)) {
506
- return false;
507
- }
508
-
509
- const [startingNodeOrToken, endingNodeOrToken] =
510
- first.range[1] <= second.range[0]
511
- ? [first, second]
512
- : [second, first];
513
- const firstToken =
514
- this.getLastToken(startingNodeOrToken) || startingNodeOrToken;
515
- const finalToken =
516
- this.getFirstToken(endingNodeOrToken) || endingNodeOrToken;
517
- let currentToken = firstToken;
518
-
519
- while (currentToken !== finalToken) {
520
- const nextToken = this.getTokenAfter(currentToken, {
521
- includeComments: true,
522
- });
523
-
524
- if (currentToken.range[1] !== nextToken.range[0]) {
525
- return true;
526
- }
527
-
528
- currentToken = nextToken;
529
- }
530
-
531
- return false;
532
- }
533
-
534
- /**
535
- * Converts a source text index into a (line, column) pair.
536
- * @param {number} index The index of a character in a file.
537
- * @throws {TypeError|RangeError} If non-numeric index or index out of range.
538
- * @returns {{line: number, column: number}} A {line, column} location object with 1-indexed line and 0-indexed column.
539
- * @public
540
- */
541
- getLocFromIndex(index) {
542
- if (typeof index !== "number") {
543
- throw new TypeError("Expected `index` to be a number.");
544
- }
545
-
546
- if (index < 0 || index > this.text.length) {
547
- throw new RangeError(
548
- `Index out of range (requested index ${index}, but source text has length ${this.text.length}).`,
549
- );
550
- }
551
-
552
- /*
553
- * For an argument of this.text.length, return the location one "spot" past the last character
554
- * of the file. If the last character is a linebreak, the location will be column 0 of the next
555
- * line; otherwise, the location will be in the next column on the same line.
556
- *
557
- * See getIndexFromLoc for the motivation for this special case.
558
- */
559
- if (index === this.text.length) {
560
- return {
561
- line: this.lines.length,
562
- column: this.lines.at(-1).length,
563
- };
564
- }
565
-
566
- /*
567
- * To figure out which line index is on, determine the last place at which index could
568
- * be inserted into lineStartIndices to keep the list sorted.
569
- */
570
- const lineNumber =
571
- index >= this.lineStartIndices.at(-1)
572
- ? this.lineStartIndices.length
573
- : findLineNumberBinarySearch(this.lineStartIndices, index);
574
-
575
- return {
576
- line: lineNumber,
577
- column: index - this.lineStartIndices[lineNumber - 1],
578
- };
579
- }
580
-
581
- /**
582
- * Converts a (line, column) pair into a range index.
583
- * @param {Object} loc A line/column location
584
- * @param {number} loc.line The line number of the location (1-indexed)
585
- * @param {number} loc.column The column number of the location (0-indexed)
586
- * @throws {TypeError|RangeError} If `loc` is not an object with a numeric
587
- * `line` and `column`, if the `line` is less than or equal to zero or
588
- * the line or column is out of the expected range.
589
- * @returns {number} The range index of the location in the file.
590
- * @public
591
- */
592
- getIndexFromLoc(loc) {
593
- if (
594
- loc === null ||
595
- typeof loc !== "object" ||
596
- typeof loc.line !== "number" ||
597
- typeof loc.column !== "number"
598
- ) {
599
- throw new TypeError(
600
- "Expected `loc` to be an object with numeric `line` and `column` properties.",
601
- );
602
- }
603
-
604
- if (loc.line <= 0) {
605
- throw new RangeError(
606
- `Line number out of range (line ${loc.line} requested). Line numbers should be 1-based.`,
607
- );
608
- }
609
-
610
- if (loc.line > this.lineStartIndices.length) {
611
- throw new RangeError(
612
- `Line number out of range (line ${loc.line} requested, but only ${this.lineStartIndices.length} lines present).`,
613
- );
614
- }
615
-
616
- if (loc.column < 0) {
617
- throw new RangeError(
618
- `Invalid column number (column ${loc.column} requested).`,
619
- );
620
- }
621
-
622
- const lineStartIndex = this.lineStartIndices[loc.line - 1];
623
- const lineEndIndex =
624
- loc.line === this.lineStartIndices.length
625
- ? this.text.length
626
- : this.lineStartIndices[loc.line];
627
- const positionIndex = lineStartIndex + loc.column;
628
-
629
- /*
630
- * By design, getIndexFromLoc({ line: lineNum, column: 0 }) should return the start index of
631
- * the given line, provided that the line number is valid element of this.lines. Since the
632
- * last element of this.lines is an empty string for files with trailing newlines, add a
633
- * special case where getting the index for the first location after the end of the file
634
- * will return the length of the file, rather than throwing an error. This allows rules to
635
- * use getIndexFromLoc consistently without worrying about edge cases at the end of a file.
636
- */
637
- if (
638
- (loc.line === this.lineStartIndices.length &&
639
- positionIndex > lineEndIndex) ||
640
- (loc.line < this.lineStartIndices.length &&
641
- positionIndex >= lineEndIndex)
642
- ) {
643
- throw new RangeError(
644
- `Column number out of range (column ${loc.column} requested, but the length of line ${loc.line} is ${lineEndIndex - lineStartIndex}).`,
645
- );
646
- }
647
-
648
- return positionIndex;
649
- }
650
-
651
- /**
652
- * Gets the scope for the given node
653
- * @param {ASTNode} currentNode The node to get the scope of
654
- * @returns {Scope} The scope information for this node
655
- * @throws {TypeError} If the `currentNode` argument is missing.
656
- */
657
- getScope(currentNode) {
658
- if (!currentNode) {
659
- throw new TypeError("Missing required argument: node.");
660
- }
661
-
662
- // check cache first
663
- const cache = this[caches].get("scopes");
664
- const cachedScope = cache.get(currentNode);
665
-
666
- if (cachedScope) {
667
- return cachedScope;
668
- }
669
-
670
- // On Program node, get the outermost scope to avoid return Node.js special function scope or ES modules scope.
671
- const inner = currentNode.type !== "Program";
672
-
673
- for (let node = currentNode; node; node = node.parent) {
674
- const scope = this.scopeManager.acquire(node, inner);
675
-
676
- if (scope) {
677
- if (scope.type === "function-expression-name") {
678
- cache.set(currentNode, scope.childScopes[0]);
679
- return scope.childScopes[0];
680
- }
681
-
682
- cache.set(currentNode, scope);
683
- return scope;
684
- }
685
- }
686
-
687
- cache.set(currentNode, this.scopeManager.scopes[0]);
688
- return this.scopeManager.scopes[0];
689
- }
690
-
691
- /**
692
- * Get the variables that `node` defines.
693
- * This is a convenience method that passes through
694
- * to the same method on the `scopeManager`.
695
- * @param {ASTNode} node The node for which the variables are obtained.
696
- * @returns {Array<Variable>} An array of variable nodes representing
697
- * the variables that `node` defines.
698
- */
699
- getDeclaredVariables(node) {
700
- return this.scopeManager.getDeclaredVariables(node);
701
- }
702
-
703
- /* eslint-disable class-methods-use-this -- node is owned by SourceCode */
704
- /**
705
- * Gets all the ancestors of a given node
706
- * @param {ASTNode} node The node
707
- * @returns {Array<ASTNode>} All the ancestor nodes in the AST, not including the provided node, starting
708
- * from the root node at index 0 and going inwards to the parent node.
709
- * @throws {TypeError} When `node` is missing.
710
- */
711
- getAncestors(node) {
712
- if (!node) {
713
- throw new TypeError("Missing required argument: node.");
714
- }
715
-
716
- const ancestorsStartingAtParent = [];
717
-
718
- for (let ancestor = node.parent; ancestor; ancestor = ancestor.parent) {
719
- ancestorsStartingAtParent.push(ancestor);
720
- }
721
-
722
- return ancestorsStartingAtParent.reverse();
723
- }
724
-
725
- /**
726
- * Determines whether the given identifier node is a reference to a global variable.
727
- * @param {ASTNode} node `Identifier` node to check.
728
- * @returns {boolean} True if the identifier is a reference to a global variable.
729
- */
730
- isGlobalReference(node) {
731
- if (!node) {
732
- throw new TypeError("Missing required argument: node.");
733
- }
734
-
735
- const cache = this[caches].get("isGlobalReference");
736
-
737
- if (cache.has(node)) {
738
- return cache.get(node);
739
- }
740
-
741
- if (node.type !== "Identifier") {
742
- cache.set(node, false);
743
- return false;
744
- }
745
-
746
- const variable = this.scopeManager.scopes[0].set.get(node.name);
747
-
748
- if (!variable || variable.defs.length > 0) {
749
- cache.set(node, false);
750
- return false;
751
- }
752
-
753
- const result = variable.references.some(
754
- ({ identifier }) => identifier === node,
755
- );
756
- cache.set(node, result);
757
- return result;
758
- }
759
-
760
- /**
761
- * Returns the location of the given node or token.
762
- * @param {ASTNode|Token} nodeOrToken The node or token to get the location of.
763
- * @returns {SourceLocation} The location of the node or token.
764
- */
765
- getLoc(nodeOrToken) {
766
- return nodeOrToken.loc;
767
- }
768
-
769
- /**
770
- * Returns the range of the given node or token.
771
- * @param {ASTNode|Token} nodeOrToken The node or token to get the range of.
772
- * @returns {[number, number]} The range of the node or token.
773
- */
774
- getRange(nodeOrToken) {
775
- return nodeOrToken.range;
776
- }
777
-
778
- /* eslint-enable class-methods-use-this -- node is owned by SourceCode */
779
-
780
- /**
781
- * Marks a variable as used in the current scope
782
- * @param {string} name The name of the variable to mark as used.
783
- * @param {ASTNode} [refNode] The closest node to the variable reference.
784
- * @returns {boolean} True if the variable was found and marked as used, false if not.
785
- */
786
- markVariableAsUsed(name, refNode = this.ast) {
787
- const currentScope = this.getScope(refNode);
788
- let initialScope = currentScope;
789
-
790
- /*
791
- * When we are in an ESM or CommonJS module, we need to start searching
792
- * from the top-level scope, not the global scope. For ESM the top-level
793
- * scope is the module scope; for CommonJS the top-level scope is the
794
- * outer function scope.
795
- *
796
- * Without this check, we might miss a variable declared with `var` at
797
- * the top-level because it won't exist in the global scope.
798
- */
799
- if (
800
- currentScope.type === "global" &&
801
- currentScope.childScopes.length > 0 &&
802
- // top-level scopes refer to a `Program` node
803
- currentScope.childScopes[0].block === this.ast
804
- ) {
805
- initialScope = currentScope.childScopes[0];
806
- }
807
-
808
- for (let scope = initialScope; scope; scope = scope.upper) {
809
- const variable = scope.variables.find(
810
- scopeVar => scopeVar.name === name,
811
- );
812
-
813
- if (variable) {
814
- variable.eslintUsed = true;
815
- return true;
816
- }
817
- }
818
-
819
- return false;
820
- }
821
-
822
- /**
823
- * Returns an array of all inline configuration nodes found in the
824
- * source code.
825
- * @returns {Array<Token>} An array of all inline configuration nodes.
826
- */
827
- getInlineConfigNodes() {
828
- // check the cache first
829
- let configNodes = this[caches].get("configNodes");
830
-
831
- if (configNodes) {
832
- return configNodes;
833
- }
834
-
835
- // calculate fresh config nodes
836
- configNodes = this.ast.comments.filter(comment => {
837
- // shebang comments are never directives
838
- if (comment.type === "Shebang") {
839
- return false;
840
- }
841
-
842
- const directive = commentParser.parseDirective(comment.value);
843
-
844
- if (!directive) {
845
- return false;
846
- }
847
-
848
- if (!directivesPattern.test(directive.label)) {
849
- return false;
850
- }
851
-
852
- // only certain comment types are supported as line comments
853
- return (
854
- comment.type !== "Line" ||
855
- !!/^eslint-disable-(?:next-)?line$/u.test(directive.label)
856
- );
857
- });
858
-
859
- this[caches].set("configNodes", configNodes);
860
-
861
- return configNodes;
862
- }
863
-
864
- /**
865
- * Returns an all directive nodes that enable or disable rules along with any problems
866
- * encountered while parsing the directives.
867
- * @returns {{problems:Array<Problem>,directives:Array<Directive>}} Information
868
- * that ESLint needs to further process the directives.
869
- */
870
- getDisableDirectives() {
871
- // check the cache first
872
- const cachedDirectives = this[caches].get("disableDirectives");
873
-
874
- if (cachedDirectives) {
875
- return cachedDirectives;
876
- }
877
-
878
- const problems = [];
879
- const directives = [];
880
-
881
- this.getInlineConfigNodes().forEach(comment => {
882
- // Step 1: Parse the directive
883
- const {
884
- label,
885
- value,
886
- justification: justificationPart,
887
- } = commentParser.parseDirective(comment.value);
888
-
889
- // Step 2: Extract the directive value
890
- const lineCommentSupported =
891
- /^eslint-disable-(?:next-)?line$/u.test(label);
892
-
893
- if (comment.type === "Line" && !lineCommentSupported) {
894
- return;
895
- }
896
-
897
- // Step 3: Validate the directive does not span multiple lines
898
- if (
899
- label === "eslint-disable-line" &&
900
- comment.loc.start.line !== comment.loc.end.line
901
- ) {
902
- const message = `${label} comment should not span multiple lines.`;
903
-
904
- problems.push({
905
- ruleId: null,
906
- message,
907
- loc: comment.loc,
908
- });
909
- return;
910
- }
911
-
912
- // Step 4: Extract the directive value and create the Directive object
913
- switch (label) {
914
- case "eslint-disable":
915
- case "eslint-enable":
916
- case "eslint-disable-next-line":
917
- case "eslint-disable-line": {
918
- const directiveType = label.slice("eslint-".length);
919
-
920
- directives.push(
921
- new Directive({
922
- type: directiveType,
923
- node: comment,
924
- value,
925
- justification: justificationPart,
926
- }),
927
- );
928
- }
929
-
930
- // no default
931
- }
932
- });
933
-
934
- const result = { problems, directives };
935
-
936
- this[caches].set("disableDirectives", result);
937
-
938
- return result;
939
- }
940
-
941
- /**
942
- * Applies language options sent in from the core.
943
- * @param {Object} languageOptions The language options for this run.
944
- * @returns {void}
945
- */
946
- applyLanguageOptions(languageOptions) {
947
- /*
948
- * Add configured globals and language globals
949
- *
950
- * Using Object.assign instead of object spread for performance reasons
951
- * https://github.com/eslint/eslint/issues/16302
952
- */
953
- const configGlobals = Object.assign(
954
- Object.create(null), // https://github.com/eslint/eslint/issues/18363
955
- getGlobalsForEcmaVersion(languageOptions.ecmaVersion),
956
- languageOptions.sourceType === "commonjs"
957
- ? globals.commonjs
958
- : void 0,
959
- languageOptions.globals,
960
- );
961
-
962
- /*
963
- * `normalizeConfigGlobal` will throw an error if a configured global value is invalid. However, these errors would
964
- * typically be caught when validating a config anyway (validity for inline global comments is checked separately).
965
- */
966
- for (const [name, value] of Object.entries(configGlobals)) {
967
- configGlobals[name] = normalizeConfigGlobal(value);
968
- }
969
-
970
- const varsCache = this[caches].get("vars");
971
-
972
- varsCache.set("configGlobals", configGlobals);
973
- }
974
-
975
- /**
976
- * Applies configuration found inside of the source code. This method is only
977
- * called when ESLint is running with inline configuration allowed.
978
- * @returns {{problems:Array<Problem>,configs:{config:FlatConfigArray,loc:Location}}} Information
979
- * that ESLint needs to further process the inline configuration.
980
- */
981
- applyInlineConfig() {
982
- const problems = [];
983
- const configs = [];
984
- const exportedVariables = {};
985
- const inlineGlobals = Object.create(null);
986
-
987
- this.getInlineConfigNodes().forEach(comment => {
988
- const { label, value } = commentParser.parseDirective(
989
- comment.value,
990
- );
991
-
992
- switch (label) {
993
- case "exported":
994
- Object.assign(
995
- exportedVariables,
996
- commentParser.parseListConfig(value),
997
- );
998
- break;
999
-
1000
- case "globals":
1001
- case "global":
1002
- for (const [id, idSetting] of Object.entries(
1003
- commentParser.parseStringConfig(value),
1004
- )) {
1005
- let normalizedValue;
1006
-
1007
- try {
1008
- normalizedValue = normalizeConfigGlobal(idSetting);
1009
- } catch (err) {
1010
- problems.push({
1011
- ruleId: null,
1012
- loc: comment.loc,
1013
- message: err.message,
1014
- });
1015
- continue;
1016
- }
1017
-
1018
- if (inlineGlobals[id]) {
1019
- inlineGlobals[id].comments.push(comment);
1020
- inlineGlobals[id].value = normalizedValue;
1021
- } else {
1022
- inlineGlobals[id] = {
1023
- comments: [comment],
1024
- value: normalizedValue,
1025
- };
1026
- }
1027
- }
1028
- break;
1029
-
1030
- case "eslint": {
1031
- const parseResult =
1032
- commentParser.parseJSONLikeConfig(value);
1033
-
1034
- if (parseResult.ok) {
1035
- configs.push({
1036
- config: {
1037
- rules: parseResult.config,
1038
- },
1039
- loc: comment.loc,
1040
- });
1041
- } else {
1042
- problems.push({
1043
- ruleId: null,
1044
- loc: comment.loc,
1045
- message: parseResult.error.message,
1046
- });
1047
- }
1048
-
1049
- break;
1050
- }
1051
- case "eslint-env": {
1052
- problems.push({
1053
- ruleId: null,
1054
- loc: comment.loc,
1055
- message:
1056
- "/* eslint-env */ comments are no longer supported.",
1057
- });
1058
- break;
1059
- }
1060
-
1061
- // no default
1062
- }
1063
- });
1064
-
1065
- // save all the new variables for later
1066
- const varsCache = this[caches].get("vars");
1067
-
1068
- varsCache.set("inlineGlobals", inlineGlobals);
1069
- varsCache.set("exportedVariables", exportedVariables);
1070
-
1071
- return {
1072
- configs,
1073
- problems,
1074
- };
1075
- }
1076
-
1077
- /**
1078
- * Called by ESLint core to indicate that it has finished providing
1079
- * information. We now add in all the missing variables and ensure that
1080
- * state-changing methods cannot be called by rules.
1081
- * @returns {void}
1082
- */
1083
- finalize() {
1084
- const varsCache = this[caches].get("vars");
1085
- const configGlobals = varsCache.get("configGlobals");
1086
- const inlineGlobals = varsCache.get("inlineGlobals");
1087
- const exportedVariables = varsCache.get("exportedVariables");
1088
- const globalScope = this.scopeManager.scopes[0];
1089
-
1090
- addDeclaredGlobals(this.scopeManager, configGlobals, inlineGlobals);
1091
-
1092
- if (exportedVariables) {
1093
- markExportedVariables(globalScope, exportedVariables);
1094
- }
1095
- }
1096
-
1097
- /**
1098
- * Traverse the source code and return the steps that were taken.
1099
- * @returns {Array<TraversalStep>} The steps that were taken while traversing the source code.
1100
- */
1101
- traverse() {
1102
- // Because the AST doesn't mutate, we can cache the steps
1103
- if (this.#steps) {
1104
- return this.#steps;
1105
- }
1106
-
1107
- const steps = (this.#steps = []);
1108
-
1109
- /*
1110
- * This logic works for any AST, not just ESTree. Because ESLint has allowed
1111
- * custom parsers to return any AST, we need to ensure that the traversal
1112
- * logic works for any AST.
1113
- */
1114
- let analyzer = {
1115
- enterNode(node) {
1116
- steps.push(
1117
- new VisitNodeStep({
1118
- target: node,
1119
- phase: 1,
1120
- args: [node],
1121
- }),
1122
- );
1123
- },
1124
- leaveNode(node) {
1125
- steps.push(
1126
- new VisitNodeStep({
1127
- target: node,
1128
- phase: 2,
1129
- args: [node],
1130
- }),
1131
- );
1132
- },
1133
- emit(eventName, args) {
1134
- steps.push(
1135
- new CallMethodStep({
1136
- target: eventName,
1137
- args,
1138
- }),
1139
- );
1140
- },
1141
- };
1142
-
1143
- /*
1144
- * We do code path analysis for ESTree only. Code path analysis is not
1145
- * necessary for other ASTs, and it's also not possible to do for other
1146
- * ASTs because the necessary information is not available.
1147
- *
1148
- * Generally speaking, we can tell that the AST is an ESTree if it has a
1149
- * Program node at the top level. This is not a perfect heuristic, but it
1150
- * is good enough for now.
1151
- */
1152
- if (this.isESTree) {
1153
- analyzer = new CodePathAnalyzer(analyzer);
1154
- }
1155
-
1156
- /*
1157
- * The actual AST traversal is done by the `Traverser` class. This class
1158
- * is responsible for walking the AST and calling the appropriate methods
1159
- * on the `analyzer` object, which is appropriate for the given AST.
1160
- */
1161
- Traverser.traverse(this.ast, {
1162
- enter(node, parent) {
1163
- // save the parent node on a property for backwards compatibility
1164
- node.parent = parent;
1165
-
1166
- analyzer.enterNode(node);
1167
- },
1168
- leave(node) {
1169
- analyzer.leaveNode(node);
1170
- },
1171
- visitorKeys: this.visitorKeys,
1172
- });
1173
-
1174
- return steps;
1175
- }
1176
- }
1177
-
1178
- module.exports = SourceCode;