@alexlit/lint-kit 166.1.0 → 167.0.0

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