repoburg 1.1.0 → 1.1.1

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 (1261) hide show
  1. package/backend/dist/tsconfig.build.tsbuildinfo +1 -1
  2. package/backend/node_modules/@typescript-eslint/eslint-plugin/LICENSE +21 -0
  3. package/backend/node_modules/@typescript-eslint/eslint-plugin/README.md +12 -0
  4. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/all.js +156 -0
  5. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/all.js.map +1 -0
  6. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/base.js +13 -0
  7. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/base.js.map +1 -0
  8. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/disable-type-checked.js +64 -0
  9. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/disable-type-checked.js.map +1 -0
  10. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/eslint-recommended.js +31 -0
  11. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/eslint-recommended.js.map +1 -0
  12. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/recommended-type-checked.js +54 -0
  13. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/recommended-type-checked.js.map +1 -0
  14. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/recommended.js +33 -0
  15. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/recommended.js.map +1 -0
  16. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/strict-type-checked.js +79 -0
  17. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/strict-type-checked.js.map +1 -0
  18. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/strict.js +43 -0
  19. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/strict.js.map +1 -0
  20. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/stylistic-type-checked.js +35 -0
  21. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/stylistic-type-checked.js.map +1 -0
  22. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/stylistic.js +29 -0
  23. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/configs/stylistic.js.map +1 -0
  24. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/index.js +39 -0
  25. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/index.js.map +1 -0
  26. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/adjacent-overload-signatures.js +140 -0
  27. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/adjacent-overload-signatures.js.map +1 -0
  28. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/array-type.js +222 -0
  29. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/array-type.js.map +1 -0
  30. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/await-thenable.js +76 -0
  31. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/await-thenable.js.map +1 -0
  32. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/ban-ts-comment.js +156 -0
  33. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/ban-ts-comment.js.map +1 -0
  34. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/ban-tslint-comment.js +56 -0
  35. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/ban-tslint-comment.js.map +1 -0
  36. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/ban-types.js +240 -0
  37. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/ban-types.js.map +1 -0
  38. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/block-spacing.js +140 -0
  39. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/block-spacing.js.map +1 -0
  40. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/brace-style.js +99 -0
  41. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/brace-style.js.map +1 -0
  42. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/class-literal-property-style.js +123 -0
  43. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/class-literal-property-style.js.map +1 -0
  44. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/class-methods-use-this.js +211 -0
  45. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/class-methods-use-this.js.map +1 -0
  46. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/comma-dangle.js +166 -0
  47. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/comma-dangle.js.map +1 -0
  48. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/comma-spacing.js +152 -0
  49. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/comma-spacing.js.map +1 -0
  50. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-generic-constructors.js +109 -0
  51. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-generic-constructors.js.map +1 -0
  52. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-indexed-object-style.js +128 -0
  53. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-indexed-object-style.js.map +1 -0
  54. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-type-assertions.js +222 -0
  55. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-type-assertions.js.map +1 -0
  56. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-type-definitions.js +98 -0
  57. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-type-definitions.js.map +1 -0
  58. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-type-exports.js +245 -0
  59. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-type-exports.js.map +1 -0
  60. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-type-imports.js +635 -0
  61. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/consistent-type-imports.js.map +1 -0
  62. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/default-param-last.js +63 -0
  63. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/default-param-last.js.map +1 -0
  64. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/dot-notation.js +120 -0
  65. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/dot-notation.js.map +1 -0
  66. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/enum-utils/shared.js +112 -0
  67. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/enum-utils/shared.js.map +1 -0
  68. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/explicit-function-return-type.js +164 -0
  69. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/explicit-function-return-type.js.map +1 -0
  70. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/explicit-member-accessibility.js +283 -0
  71. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/explicit-member-accessibility.js.map +1 -0
  72. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/explicit-module-boundary-types.js +366 -0
  73. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/explicit-module-boundary-types.js.map +1 -0
  74. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/func-call-spacing.js +147 -0
  75. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/func-call-spacing.js.map +1 -0
  76. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/indent.js +415 -0
  77. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/indent.js.map +1 -0
  78. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/index.js +288 -0
  79. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/index.js.map +1 -0
  80. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/init-declarations.js +48 -0
  81. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/init-declarations.js.map +1 -0
  82. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/key-spacing.js +322 -0
  83. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/key-spacing.js.map +1 -0
  84. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/keyword-spacing.js +95 -0
  85. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/keyword-spacing.js.map +1 -0
  86. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/lines-around-comment.js +357 -0
  87. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/lines-around-comment.js.map +1 -0
  88. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/lines-between-class-members.js +57 -0
  89. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/lines-between-class-members.js.map +1 -0
  90. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/max-params.js +67 -0
  91. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/max-params.js.map +1 -0
  92. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/member-delimiter-style.js +258 -0
  93. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/member-delimiter-style.js.map +1 -0
  94. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/member-ordering.js +747 -0
  95. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/member-ordering.js.map +1 -0
  96. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/method-signature-style.js +181 -0
  97. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/method-signature-style.js.map +1 -0
  98. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/enums.js +101 -0
  99. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/enums.js.map +1 -0
  100. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/format.js +91 -0
  101. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/format.js.map +1 -0
  102. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/index.js +12 -0
  103. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/index.js.map +1 -0
  104. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/parse-options.js +75 -0
  105. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/parse-options.js.map +1 -0
  106. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/schema.js +291 -0
  107. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/schema.js.map +1 -0
  108. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/shared.js +18 -0
  109. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/shared.js.map +1 -0
  110. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/types.js +3 -0
  111. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/types.js.map +1 -0
  112. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/validator.js +351 -0
  113. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention-utils/validator.js.map +1 -0
  114. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention.js +488 -0
  115. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/naming-convention.js.map +1 -0
  116. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-array-constructor.js +53 -0
  117. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-array-constructor.js.map +1 -0
  118. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-array-delete.js +83 -0
  119. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-array-delete.js.map +1 -0
  120. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-base-to-string.js +164 -0
  121. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-base-to-string.js.map +1 -0
  122. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-confusing-non-null-assertion.js +78 -0
  123. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-confusing-non-null-assertion.js.map +1 -0
  124. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-confusing-void-expression.js +293 -0
  125. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-confusing-void-expression.js.map +1 -0
  126. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-dupe-class-members.js +51 -0
  127. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-dupe-class-members.js.map +1 -0
  128. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-duplicate-enum-values.js +62 -0
  129. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-duplicate-enum-values.js.map +1 -0
  130. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-duplicate-type-constituents.js +139 -0
  131. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-duplicate-type-constituents.js.map +1 -0
  132. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-dynamic-delete.js +95 -0
  133. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-dynamic-delete.js.map +1 -0
  134. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-empty-function.js +132 -0
  135. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-empty-function.js.map +1 -0
  136. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-empty-interface.js +94 -0
  137. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-empty-interface.js.map +1 -0
  138. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-explicit-any.js +170 -0
  139. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-explicit-any.js.map +1 -0
  140. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-extra-non-null-assertion.js +36 -0
  141. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-extra-non-null-assertion.js.map +1 -0
  142. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-extra-parens.js +297 -0
  143. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-extra-parens.js.map +1 -0
  144. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-extra-semi.js +43 -0
  145. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-extra-semi.js.map +1 -0
  146. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-extraneous-class.js +112 -0
  147. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-extraneous-class.js.map +1 -0
  148. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-floating-promises.js +342 -0
  149. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-floating-promises.js.map +1 -0
  150. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-for-in-array.js +60 -0
  151. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-for-in-array.js.map +1 -0
  152. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-implied-eval.js +160 -0
  153. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-implied-eval.js.map +1 -0
  154. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-import-type-side-effects.js +56 -0
  155. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-import-type-side-effects.js.map +1 -0
  156. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-inferrable-types.js +185 -0
  157. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-inferrable-types.js.map +1 -0
  158. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-invalid-this.js +76 -0
  159. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-invalid-this.js.map +1 -0
  160. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-invalid-void-type.js +182 -0
  161. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-invalid-void-type.js.map +1 -0
  162. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-loop-func.js +169 -0
  163. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-loop-func.js.map +1 -0
  164. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-loss-of-precision.js +39 -0
  165. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-loss-of-precision.js.map +1 -0
  166. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-magic-numbers.js +213 -0
  167. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-magic-numbers.js.map +1 -0
  168. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-meaningless-void-operator.js +96 -0
  169. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-meaningless-void-operator.js.map +1 -0
  170. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-misused-new.js +82 -0
  171. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-misused-new.js.map +1 -0
  172. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-misused-promises.js +523 -0
  173. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-misused-promises.js.map +1 -0
  174. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-mixed-enums.js +193 -0
  175. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-mixed-enums.js.map +1 -0
  176. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-namespace.js +63 -0
  177. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-namespace.js.map +1 -0
  178. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-non-null-asserted-nullish-coalescing.js +76 -0
  179. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-non-null-asserted-nullish-coalescing.js.map +1 -0
  180. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-non-null-asserted-optional-chain.js +66 -0
  181. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-non-null-asserted-optional-chain.js.map +1 -0
  182. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-non-null-assertion.js +104 -0
  183. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-non-null-assertion.js.map +1 -0
  184. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-redeclare.js +201 -0
  185. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-redeclare.js.map +1 -0
  186. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-redundant-type-constituents.js +372 -0
  187. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-redundant-type-constituents.js.map +1 -0
  188. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-require-imports.js +90 -0
  189. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-require-imports.js.map +1 -0
  190. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-restricted-imports.js +237 -0
  191. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-restricted-imports.js.map +1 -0
  192. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-shadow.js +482 -0
  193. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-shadow.js.map +1 -0
  194. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-this-alias.js +65 -0
  195. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-this-alias.js.map +1 -0
  196. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-throw-literal.js +96 -0
  197. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-throw-literal.js.map +1 -0
  198. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-type-alias.js +260 -0
  199. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-type-alias.js.map +1 -0
  200. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-boolean-literal-compare.js +234 -0
  201. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-boolean-literal-compare.js.map +1 -0
  202. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-condition.js +540 -0
  203. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-condition.js.map +1 -0
  204. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-qualifier.js +149 -0
  205. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-qualifier.js.map +1 -0
  206. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-type-arguments.js +150 -0
  207. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-type-arguments.js.map +1 -0
  208. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-type-assertion.js +252 -0
  209. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-type-assertion.js.map +1 -0
  210. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-type-constraint.js +112 -0
  211. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unnecessary-type-constraint.js.map +1 -0
  212. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-argument.js +226 -0
  213. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-argument.js.map +1 -0
  214. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-assignment.js +282 -0
  215. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-assignment.js.map +1 -0
  216. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-call.js +83 -0
  217. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-call.js.map +1 -0
  218. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-declaration-merging.js +56 -0
  219. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-declaration-merging.js.map +1 -0
  220. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-enum-comparison.js +168 -0
  221. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-enum-comparison.js.map +1 -0
  222. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-member-access.js +123 -0
  223. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-member-access.js.map +1 -0
  224. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-return.js +161 -0
  225. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-return.js.map +1 -0
  226. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-unary-minus.js +68 -0
  227. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unsafe-unary-minus.js.map +1 -0
  228. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unused-expressions.js +58 -0
  229. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unused-expressions.js.map +1 -0
  230. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unused-vars.js +490 -0
  231. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-unused-vars.js.map +1 -0
  232. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-use-before-define.js +297 -0
  233. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-use-before-define.js.map +1 -0
  234. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-useless-constructor.js +59 -0
  235. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-useless-constructor.js.map +1 -0
  236. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-useless-empty-export.js +72 -0
  237. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-useless-empty-export.js.map +1 -0
  238. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-useless-template-literals.js +138 -0
  239. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-useless-template-literals.js.map +1 -0
  240. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-var-requires.js +67 -0
  241. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/no-var-requires.js.map +1 -0
  242. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/non-nullable-type-assertion-style.js +125 -0
  243. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/non-nullable-type-assertion-style.js.map +1 -0
  244. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/object-curly-spacing.js +226 -0
  245. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/object-curly-spacing.js.map +1 -0
  246. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/padding-line-between-statements.js +634 -0
  247. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/padding-line-between-statements.js.map +1 -0
  248. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/parameter-properties.js +171 -0
  249. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/parameter-properties.js.map +1 -0
  250. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-as-const.js +73 -0
  251. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-as-const.js.map +1 -0
  252. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-destructuring.js +200 -0
  253. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-destructuring.js.map +1 -0
  254. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-enum-initializers.js +65 -0
  255. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-enum-initializers.js.map +1 -0
  256. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-find.js +235 -0
  257. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-find.js.map +1 -0
  258. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-for-of.js +156 -0
  259. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-for-of.js.map +1 -0
  260. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-function-type.js +186 -0
  261. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-function-type.js.map +1 -0
  262. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-includes.js +231 -0
  263. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-includes.js.map +1 -0
  264. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-literal-enum-member.js +72 -0
  265. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-literal-enum-member.js.map +1 -0
  266. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-namespace-keyword.js +46 -0
  267. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-namespace-keyword.js.map +1 -0
  268. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-nullish-coalescing.js +348 -0
  269. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-nullish-coalescing.js.map +1 -0
  270. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-optional-chain-utils/PreferOptionalChainOptions.js +3 -0
  271. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-optional-chain-utils/PreferOptionalChainOptions.js.map +1 -0
  272. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-optional-chain-utils/analyzeChain.js +417 -0
  273. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-optional-chain-utils/analyzeChain.js.map +1 -0
  274. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-optional-chain-utils/compareNodes.js +318 -0
  275. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-optional-chain-utils/compareNodes.js.map +1 -0
  276. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-optional-chain-utils/gatherLogicalOperands.js +279 -0
  277. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-optional-chain-utils/gatherLogicalOperands.js.map +1 -0
  278. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-optional-chain.js +175 -0
  279. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-optional-chain.js.map +1 -0
  280. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-promise-reject-errors.js +107 -0
  281. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-promise-reject-errors.js.map +1 -0
  282. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-readonly-parameter-types.js +82 -0
  283. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-readonly-parameter-types.js.map +1 -0
  284. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-readonly.js +315 -0
  285. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-readonly.js.map +1 -0
  286. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-reduce-type-parameter.js +74 -0
  287. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-reduce-type-parameter.js.map +1 -0
  288. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-regexp-exec.js +159 -0
  289. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-regexp-exec.js.map +1 -0
  290. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-return-this-type.js +137 -0
  291. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-return-this-type.js.map +1 -0
  292. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-string-starts-ends-with.js +508 -0
  293. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-string-starts-ends-with.js.map +1 -0
  294. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-ts-expect-error.js +62 -0
  295. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/prefer-ts-expect-error.js.map +1 -0
  296. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/promise-function-async.js +182 -0
  297. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/promise-function-async.js.map +1 -0
  298. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/quotes.js +63 -0
  299. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/quotes.js.map +1 -0
  300. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/require-array-sort-compare.js +62 -0
  301. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/require-array-sort-compare.js.map +1 -0
  302. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/require-await.js +212 -0
  303. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/require-await.js.map +1 -0
  304. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/restrict-plus-operands.js +211 -0
  305. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/restrict-plus-operands.js.map +1 -0
  306. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/restrict-template-expressions.js +145 -0
  307. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/restrict-template-expressions.js.map +1 -0
  308. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/return-await.js +268 -0
  309. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/return-await.js.map +1 -0
  310. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/semi.js +64 -0
  311. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/semi.js.map +1 -0
  312. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/sort-type-constituents.js +228 -0
  313. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/sort-type-constituents.js.map +1 -0
  314. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/space-before-blocks.js +80 -0
  315. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/space-before-blocks.js.map +1 -0
  316. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/space-before-function-paren.js +143 -0
  317. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/space-before-function-paren.js.map +1 -0
  318. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/space-infix-ops.js +133 -0
  319. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/space-infix-ops.js.map +1 -0
  320. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/strict-boolean-expressions.js +800 -0
  321. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/strict-boolean-expressions.js.map +1 -0
  322. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/switch-exhaustiveness-check.js +242 -0
  323. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/switch-exhaustiveness-check.js.map +1 -0
  324. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/triple-slash-reference.js +110 -0
  325. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/triple-slash-reference.js.map +1 -0
  326. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/type-annotation-spacing.js +228 -0
  327. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/type-annotation-spacing.js.map +1 -0
  328. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/typedef.js +200 -0
  329. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/typedef.js.map +1 -0
  330. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/unbound-method.js +245 -0
  331. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/unbound-method.js.map +1 -0
  332. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/unified-signatures.js +398 -0
  333. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/rules/unified-signatures.js.map +1 -0
  334. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/astUtils.js +89 -0
  335. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/astUtils.js.map +1 -0
  336. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/collectUnusedVariables.js +562 -0
  337. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/collectUnusedVariables.js.map +1 -0
  338. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/createRule.js +6 -0
  339. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/createRule.js.map +1 -0
  340. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/escapeRegExp.js +16 -0
  341. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/escapeRegExp.js.map +1 -0
  342. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/explicitReturnTypeUtils.js +241 -0
  343. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/explicitReturnTypeUtils.js.map +1 -0
  344. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getESLintCoreRule.js +45 -0
  345. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getESLintCoreRule.js.map +1 -0
  346. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getFunctionHeadLoc.js +163 -0
  347. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getFunctionHeadLoc.js.map +1 -0
  348. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getOperatorPrecedence.js +418 -0
  349. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getOperatorPrecedence.js.map +1 -0
  350. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getStaticStringValue.js +46 -0
  351. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getStaticStringValue.js.map +1 -0
  352. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getStringLength.js +20 -0
  353. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getStringLength.js.map +1 -0
  354. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getThisExpression.js +26 -0
  355. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getThisExpression.js.map +1 -0
  356. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getWrappedCode.js +8 -0
  357. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getWrappedCode.js.map +1 -0
  358. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getWrappingFixer.js +155 -0
  359. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/getWrappingFixer.js.map +1 -0
  360. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/index.js +42 -0
  361. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/index.js.map +1 -0
  362. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/isNodeEqual.js +27 -0
  363. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/isNodeEqual.js.map +1 -0
  364. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/isNullLiteral.js +9 -0
  365. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/isNullLiteral.js.map +1 -0
  366. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/isUndefinedIdentifier.js +9 -0
  367. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/isUndefinedIdentifier.js.map +1 -0
  368. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/misc.js +189 -0
  369. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/misc.js.map +1 -0
  370. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/objectIterators.js +27 -0
  371. package/backend/node_modules/@typescript-eslint/eslint-plugin/dist/util/objectIterators.js.map +1 -0
  372. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/README.md +60 -0
  373. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/TEMPLATE.md +30 -0
  374. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/adjacent-overload-signatures.md +99 -0
  375. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/array-type.md +111 -0
  376. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/await-thenable.md +42 -0
  377. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/ban-ts-comment.md +151 -0
  378. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/ban-tslint-comment.md +39 -0
  379. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/ban-types.md +132 -0
  380. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/block-spacing.md +10 -0
  381. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/brace-style.md +10 -0
  382. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/camelcase.md +13 -0
  383. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/class-literal-property-style.md +105 -0
  384. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/class-methods-use-this.md +96 -0
  385. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/comma-dangle.md +20 -0
  386. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/comma-spacing.md +10 -0
  387. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/consistent-generic-constructors.md +76 -0
  388. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/consistent-indexed-object-style.md +80 -0
  389. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/consistent-type-assertions.md +113 -0
  390. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/consistent-type-definitions.md +81 -0
  391. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/consistent-type-exports.md +105 -0
  392. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/consistent-type-imports.md +108 -0
  393. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/default-param-last.md +58 -0
  394. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/dot-notation.md +82 -0
  395. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/explicit-function-return-type.md +320 -0
  396. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/explicit-member-accessibility.md +344 -0
  397. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/explicit-module-boundary-types.md +249 -0
  398. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/func-call-spacing.md +10 -0
  399. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/indent.md +18 -0
  400. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/init-declarations.md +10 -0
  401. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/key-spacing.md +10 -0
  402. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/keyword-spacing.md +10 -0
  403. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/lines-around-comment.md +25 -0
  404. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/lines-between-class-members.md +55 -0
  405. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/max-params.md +10 -0
  406. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/member-delimiter-style.md +164 -0
  407. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/member-ordering.md +1438 -0
  408. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/method-signature-style.md +113 -0
  409. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/naming-convention.md +721 -0
  410. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-array-constructor.md +29 -0
  411. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-array-delete.md +40 -0
  412. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-base-to-string.md +88 -0
  413. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-confusing-non-null-assertion.md +56 -0
  414. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-confusing-void-expression.md +116 -0
  415. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-dupe-class-members.md +14 -0
  416. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-duplicate-enum-values.md +58 -0
  417. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-duplicate-imports.md +13 -0
  418. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-duplicate-type-constituents.md +66 -0
  419. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-dynamic-delete.md +53 -0
  420. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-empty-function.md +92 -0
  421. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-empty-interface.md +59 -0
  422. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-explicit-any.md +168 -0
  423. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-extra-non-null-assertion.md +54 -0
  424. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-extra-parens.md +10 -0
  425. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-extra-semi.md +12 -0
  426. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-extraneous-class.md +295 -0
  427. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-floating-promises.md +124 -0
  428. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-for-in-array.md +61 -0
  429. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-implied-eval.md +102 -0
  430. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-import-type-side-effects.md +74 -0
  431. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-inferrable-types.md +103 -0
  432. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-invalid-this.md +14 -0
  433. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-invalid-void-type.md +112 -0
  434. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-loop-func.md +10 -0
  435. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-loss-of-precision.md +10 -0
  436. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-magic-numbers.md +119 -0
  437. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-meaningless-void-operator.md +53 -0
  438. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-misused-new.md +47 -0
  439. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-misused-promises.md +246 -0
  440. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-mixed-enums.md +88 -0
  441. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-namespace.md +131 -0
  442. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-non-null-asserted-nullish-coalescing.md +54 -0
  443. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-non-null-asserted-optional-chain.md +40 -0
  444. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-non-null-assertion.md +42 -0
  445. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-parameter-properties.md +12 -0
  446. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-redeclare.md +75 -0
  447. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-redundant-type-constituents.md +92 -0
  448. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-require-imports.md +60 -0
  449. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-restricted-imports.md +71 -0
  450. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-shadow.md +105 -0
  451. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-this-alias.md +108 -0
  452. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-throw-literal.md +109 -0
  453. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-type-alias.md +623 -0
  454. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unnecessary-boolean-literal-compare.md +133 -0
  455. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unnecessary-condition.md +119 -0
  456. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unnecessary-qualifier.md +51 -0
  457. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unnecessary-type-arguments.md +79 -0
  458. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unnecessary-type-assertion.md +77 -0
  459. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unnecessary-type-constraint.md +55 -0
  460. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unsafe-argument.md +93 -0
  461. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unsafe-assignment.md +96 -0
  462. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unsafe-call.md +68 -0
  463. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unsafe-declaration-merging.md +59 -0
  464. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unsafe-enum-comparison.md +82 -0
  465. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unsafe-member-access.md +74 -0
  466. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unsafe-return.md +113 -0
  467. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unsafe-unary-minus.md +52 -0
  468. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unused-expressions.md +10 -0
  469. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-unused-vars.md +27 -0
  470. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-use-before-define.md +87 -0
  471. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-useless-constructor.md +19 -0
  472. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-useless-empty-export.md +47 -0
  473. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-useless-template-literals.md +57 -0
  474. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/no-var-requires.md +60 -0
  475. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/non-nullable-type-assertion-style.md +41 -0
  476. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/object-curly-spacing.md +10 -0
  477. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/padding-line-between-statements.md +33 -0
  478. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/parameter-properties.md +488 -0
  479. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-as-const.md +47 -0
  480. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-destructuring.md +91 -0
  481. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-enum-initializers.md +62 -0
  482. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-find.md +39 -0
  483. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-for-of.md +44 -0
  484. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-function-type.md +92 -0
  485. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-includes.md +75 -0
  486. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-literal-enum-member.md +103 -0
  487. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-namespace-keyword.md +47 -0
  488. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-nullish-coalescing.md +187 -0
  489. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-optional-chain.md +263 -0
  490. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-promise-reject-errors.md +50 -0
  491. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-readonly-parameter-types.md +389 -0
  492. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-readonly.md +102 -0
  493. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-reduce-type-parameter.md +60 -0
  494. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-regexp-exec.md +46 -0
  495. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-return-this-type.md +87 -0
  496. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-string-starts-ends-with.md +58 -0
  497. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/prefer-ts-expect-error.md +70 -0
  498. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/promise-function-async.md +132 -0
  499. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/quotes.md +10 -0
  500. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/require-array-sort-compare.md +78 -0
  501. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/require-await.md +22 -0
  502. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/restrict-plus-operands.md +208 -0
  503. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/restrict-template-expressions.md +121 -0
  504. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/return-await.md +216 -0
  505. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/semi.md +12 -0
  506. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/sort-type-constituents.md +163 -0
  507. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/space-before-blocks.md +43 -0
  508. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/space-before-function-paren.md +10 -0
  509. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/space-infix-ops.md +16 -0
  510. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/strict-boolean-expressions.md +190 -0
  511. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/switch-exhaustiveness-check.md +225 -0
  512. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/triple-slash-reference.md +110 -0
  513. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/type-annotation-spacing.md +317 -0
  514. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/typedef.md +320 -0
  515. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/unbound-method.md +105 -0
  516. package/backend/node_modules/@typescript-eslint/eslint-plugin/docs/rules/unified-signatures.md +77 -0
  517. package/backend/node_modules/@typescript-eslint/eslint-plugin/index.d.ts +9 -0
  518. package/backend/node_modules/@typescript-eslint/eslint-plugin/package.json +106 -0
  519. package/backend/node_modules/@typescript-eslint/eslint-plugin/rules.d.ts +45 -0
  520. package/backend/node_modules/@typescript-eslint/parser/LICENSE +22 -0
  521. package/backend/node_modules/@typescript-eslint/parser/README.md +12 -0
  522. package/backend/node_modules/@typescript-eslint/parser/dist/index.d.ts +8 -0
  523. package/backend/node_modules/@typescript-eslint/parser/dist/index.d.ts.map +1 -0
  524. package/backend/node_modules/@typescript-eslint/parser/dist/index.js +17 -0
  525. package/backend/node_modules/@typescript-eslint/parser/dist/index.js.map +1 -0
  526. package/backend/node_modules/@typescript-eslint/parser/dist/parser.d.ts +20 -0
  527. package/backend/node_modules/@typescript-eslint/parser/dist/parser.d.ts.map +1 -0
  528. package/backend/node_modules/@typescript-eslint/parser/dist/parser.js +130 -0
  529. package/backend/node_modules/@typescript-eslint/parser/dist/parser.js.map +1 -0
  530. package/backend/node_modules/@typescript-eslint/parser/package.json +85 -0
  531. package/backend/node_modules/@typescript-eslint/type-utils/LICENSE +21 -0
  532. package/backend/node_modules/@typescript-eslint/type-utils/README.md +14 -0
  533. package/backend/node_modules/@typescript-eslint/type-utils/dist/TypeOrValueSpecifier.d.ts +21 -0
  534. package/backend/node_modules/@typescript-eslint/type-utils/dist/TypeOrValueSpecifier.d.ts.map +1 -0
  535. package/backend/node_modules/@typescript-eslint/type-utils/dist/TypeOrValueSpecifier.js +188 -0
  536. package/backend/node_modules/@typescript-eslint/type-utils/dist/TypeOrValueSpecifier.js.map +1 -0
  537. package/backend/node_modules/@typescript-eslint/type-utils/dist/builtinSymbolLikes.d.ts +39 -0
  538. package/backend/node_modules/@typescript-eslint/type-utils/dist/builtinSymbolLikes.d.ts.map +1 -0
  539. package/backend/node_modules/@typescript-eslint/type-utils/dist/builtinSymbolLikes.js +130 -0
  540. package/backend/node_modules/@typescript-eslint/type-utils/dist/builtinSymbolLikes.js.map +1 -0
  541. package/backend/node_modules/@typescript-eslint/type-utils/dist/containsAllTypesByName.d.ts +10 -0
  542. package/backend/node_modules/@typescript-eslint/type-utils/dist/containsAllTypesByName.d.ts.map +1 -0
  543. package/backend/node_modules/@typescript-eslint/type-utils/dist/containsAllTypesByName.js +61 -0
  544. package/backend/node_modules/@typescript-eslint/type-utils/dist/containsAllTypesByName.js.map +1 -0
  545. package/backend/node_modules/@typescript-eslint/type-utils/dist/getConstrainedTypeAtLocation.d.ts +7 -0
  546. package/backend/node_modules/@typescript-eslint/type-utils/dist/getConstrainedTypeAtLocation.d.ts.map +1 -0
  547. package/backend/node_modules/@typescript-eslint/type-utils/dist/getConstrainedTypeAtLocation.js +15 -0
  548. package/backend/node_modules/@typescript-eslint/type-utils/dist/getConstrainedTypeAtLocation.js.map +1 -0
  549. package/backend/node_modules/@typescript-eslint/type-utils/dist/getContextualType.d.ts +8 -0
  550. package/backend/node_modules/@typescript-eslint/type-utils/dist/getContextualType.d.ts.map +1 -0
  551. package/backend/node_modules/@typescript-eslint/type-utils/dist/getContextualType.js +66 -0
  552. package/backend/node_modules/@typescript-eslint/type-utils/dist/getContextualType.js.map +1 -0
  553. package/backend/node_modules/@typescript-eslint/type-utils/dist/getDeclaration.d.ts +7 -0
  554. package/backend/node_modules/@typescript-eslint/type-utils/dist/getDeclaration.d.ts.map +1 -0
  555. package/backend/node_modules/@typescript-eslint/type-utils/dist/getDeclaration.js +16 -0
  556. package/backend/node_modules/@typescript-eslint/type-utils/dist/getDeclaration.js.map +1 -0
  557. package/backend/node_modules/@typescript-eslint/type-utils/dist/getSourceFileOfNode.d.ts +6 -0
  558. package/backend/node_modules/@typescript-eslint/type-utils/dist/getSourceFileOfNode.d.ts.map +1 -0
  559. package/backend/node_modules/@typescript-eslint/type-utils/dist/getSourceFileOfNode.js +38 -0
  560. package/backend/node_modules/@typescript-eslint/type-utils/dist/getSourceFileOfNode.js.map +1 -0
  561. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTokenAtPosition.d.ts +3 -0
  562. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTokenAtPosition.d.ts.map +1 -0
  563. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTokenAtPosition.js +51 -0
  564. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTokenAtPosition.js.map +1 -0
  565. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTypeArguments.d.ts +6 -0
  566. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTypeArguments.d.ts.map +1 -0
  567. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTypeArguments.js +16 -0
  568. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTypeArguments.js.map +1 -0
  569. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTypeName.d.ts +8 -0
  570. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTypeName.d.ts.map +1 -0
  571. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTypeName.js +74 -0
  572. package/backend/node_modules/@typescript-eslint/type-utils/dist/getTypeName.js.map +1 -0
  573. package/backend/node_modules/@typescript-eslint/type-utils/dist/index.d.ts +19 -0
  574. package/backend/node_modules/@typescript-eslint/type-utils/dist/index.d.ts.map +1 -0
  575. package/backend/node_modules/@typescript-eslint/type-utils/dist/index.js +39 -0
  576. package/backend/node_modules/@typescript-eslint/type-utils/dist/index.js.map +1 -0
  577. package/backend/node_modules/@typescript-eslint/type-utils/dist/isSymbolFromDefaultLibrary.d.ts +3 -0
  578. package/backend/node_modules/@typescript-eslint/type-utils/dist/isSymbolFromDefaultLibrary.d.ts.map +1 -0
  579. package/backend/node_modules/@typescript-eslint/type-utils/dist/isSymbolFromDefaultLibrary.js +18 -0
  580. package/backend/node_modules/@typescript-eslint/type-utils/dist/isSymbolFromDefaultLibrary.js.map +1 -0
  581. package/backend/node_modules/@typescript-eslint/type-utils/dist/isTypeReadonly.d.ts +27 -0
  582. package/backend/node_modules/@typescript-eslint/type-utils/dist/isTypeReadonly.d.ts.map +1 -0
  583. package/backend/node_modules/@typescript-eslint/type-utils/dist/isTypeReadonly.js +226 -0
  584. package/backend/node_modules/@typescript-eslint/type-utils/dist/isTypeReadonly.js.map +1 -0
  585. package/backend/node_modules/@typescript-eslint/type-utils/dist/isUnsafeAssignment.d.ts +17 -0
  586. package/backend/node_modules/@typescript-eslint/type-utils/dist/isUnsafeAssignment.d.ts.map +1 -0
  587. package/backend/node_modules/@typescript-eslint/type-utils/dist/isUnsafeAssignment.js +106 -0
  588. package/backend/node_modules/@typescript-eslint/type-utils/dist/isUnsafeAssignment.js.map +1 -0
  589. package/backend/node_modules/@typescript-eslint/type-utils/dist/predicates.d.ts +58 -0
  590. package/backend/node_modules/@typescript-eslint/type-utils/dist/predicates.d.ts.map +1 -0
  591. package/backend/node_modules/@typescript-eslint/type-utils/dist/predicates.js +169 -0
  592. package/backend/node_modules/@typescript-eslint/type-utils/dist/predicates.js.map +1 -0
  593. package/backend/node_modules/@typescript-eslint/type-utils/dist/propertyTypes.d.ts +4 -0
  594. package/backend/node_modules/@typescript-eslint/type-utils/dist/propertyTypes.d.ts.map +1 -0
  595. package/backend/node_modules/@typescript-eslint/type-utils/dist/propertyTypes.js +37 -0
  596. package/backend/node_modules/@typescript-eslint/type-utils/dist/propertyTypes.js.map +1 -0
  597. package/backend/node_modules/@typescript-eslint/type-utils/dist/requiresQuoting.d.ts +4 -0
  598. package/backend/node_modules/@typescript-eslint/type-utils/dist/requiresQuoting.d.ts.map +1 -0
  599. package/backend/node_modules/@typescript-eslint/type-utils/dist/requiresQuoting.js +43 -0
  600. package/backend/node_modules/@typescript-eslint/type-utils/dist/requiresQuoting.js.map +1 -0
  601. package/backend/node_modules/@typescript-eslint/type-utils/dist/typeFlagUtils.d.ts +16 -0
  602. package/backend/node_modules/@typescript-eslint/type-utils/dist/typeFlagUtils.d.ts.map +1 -0
  603. package/backend/node_modules/@typescript-eslint/type-utils/dist/typeFlagUtils.js +59 -0
  604. package/backend/node_modules/@typescript-eslint/type-utils/dist/typeFlagUtils.js.map +1 -0
  605. package/backend/node_modules/@typescript-eslint/type-utils/package.json +81 -0
  606. package/backend/node_modules/@typescript-eslint/utils/LICENSE +21 -0
  607. package/backend/node_modules/@typescript-eslint/utils/README.md +12 -0
  608. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/PatternMatcher.d.ts +48 -0
  609. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/PatternMatcher.d.ts.map +1 -0
  610. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/PatternMatcher.js +36 -0
  611. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/PatternMatcher.js.map +1 -0
  612. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/ReferenceTracker.d.ts +76 -0
  613. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/ReferenceTracker.d.ts.map +1 -0
  614. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/ReferenceTracker.js +40 -0
  615. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/ReferenceTracker.js.map +1 -0
  616. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/astUtilities.d.ts +76 -0
  617. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/astUtilities.d.ts.map +1 -0
  618. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/astUtilities.js +99 -0
  619. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/astUtilities.js.map +1 -0
  620. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/index.d.ts +6 -0
  621. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/index.d.ts.map +1 -0
  622. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/index.js +22 -0
  623. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/index.js.map +1 -0
  624. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/predicates.d.ts +32 -0
  625. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/predicates.d.ts.map +1 -0
  626. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/predicates.js +72 -0
  627. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/predicates.js.map +1 -0
  628. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/scopeAnalysis.d.ts +18 -0
  629. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/scopeAnalysis.d.ts.map +1 -0
  630. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/scopeAnalysis.js +44 -0
  631. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/eslint-utils/scopeAnalysis.js.map +1 -0
  632. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/helpers.d.ts +1231 -0
  633. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/helpers.d.ts.map +1 -0
  634. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/helpers.js +22 -0
  635. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/helpers.js.map +1 -0
  636. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/index.d.ts +5 -0
  637. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/index.d.ts.map +1 -0
  638. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/index.js +21 -0
  639. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/index.js.map +1 -0
  640. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/misc.d.ts +8 -0
  641. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/misc.d.ts.map +1 -0
  642. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/misc.js +13 -0
  643. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/misc.js.map +1 -0
  644. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/predicates.d.ts +70 -0
  645. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/predicates.d.ts.map +1 -0
  646. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/predicates.js +135 -0
  647. package/backend/node_modules/@typescript-eslint/utils/dist/ast-utils/predicates.js.map +1 -0
  648. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/InferTypesFromRule.d.ts +11 -0
  649. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/InferTypesFromRule.d.ts.map +1 -0
  650. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/InferTypesFromRule.js +3 -0
  651. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/InferTypesFromRule.js.map +1 -0
  652. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/RuleCreator.d.ts +35 -0
  653. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/RuleCreator.d.ts.map +1 -0
  654. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/RuleCreator.js +45 -0
  655. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/RuleCreator.js.map +1 -0
  656. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/applyDefault.d.ts +10 -0
  657. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/applyDefault.d.ts.map +1 -0
  658. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/applyDefault.js +34 -0
  659. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/applyDefault.js.map +1 -0
  660. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/context.d.ts +10 -0
  661. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/context.d.ts.map +1 -0
  662. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/context.js +32 -0
  663. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/context.js.map +1 -0
  664. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/deepMerge.d.ts +17 -0
  665. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/deepMerge.d.ts.map +1 -0
  666. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/deepMerge.js +48 -0
  667. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/deepMerge.js.map +1 -0
  668. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/getParserServices.d.ts +24 -0
  669. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/getParserServices.d.ts.map +1 -0
  670. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/getParserServices.js +46 -0
  671. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/getParserServices.js.map +1 -0
  672. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/index.d.ts +8 -0
  673. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/index.d.ts.map +1 -0
  674. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/index.js +24 -0
  675. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/index.js.map +1 -0
  676. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/nullThrows.d.ts +14 -0
  677. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/nullThrows.d.ts.map +1 -0
  678. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/nullThrows.js +28 -0
  679. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/nullThrows.js.map +1 -0
  680. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/parserPathSeemsToBeTSESLint.d.ts +2 -0
  681. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/parserPathSeemsToBeTSESLint.d.ts.map +1 -0
  682. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/parserPathSeemsToBeTSESLint.js +8 -0
  683. package/backend/node_modules/@typescript-eslint/utils/dist/eslint-utils/parserPathSeemsToBeTSESLint.js.map +1 -0
  684. package/backend/node_modules/@typescript-eslint/utils/dist/index.d.ts +8 -0
  685. package/backend/node_modules/@typescript-eslint/utils/dist/index.d.ts.map +1 -0
  686. package/backend/node_modules/@typescript-eslint/utils/dist/index.js +41 -0
  687. package/backend/node_modules/@typescript-eslint/utils/dist/index.js.map +1 -0
  688. package/backend/node_modules/@typescript-eslint/utils/dist/json-schema.d.ts +388 -0
  689. package/backend/node_modules/@typescript-eslint/utils/dist/json-schema.d.ts.map +1 -0
  690. package/backend/node_modules/@typescript-eslint/utils/dist/json-schema.js +9 -0
  691. package/backend/node_modules/@typescript-eslint/utils/dist/json-schema.js.map +1 -0
  692. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/AST.d.ts +9 -0
  693. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/AST.d.ts.map +1 -0
  694. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/AST.js +4 -0
  695. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/AST.js.map +1 -0
  696. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/CLIEngine.d.ts +131 -0
  697. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/CLIEngine.d.ts.map +1 -0
  698. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/CLIEngine.js +18 -0
  699. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/CLIEngine.js.map +1 -0
  700. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Config.d.ts +260 -0
  701. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Config.d.ts.map +1 -0
  702. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Config.js +4 -0
  703. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Config.js.map +1 -0
  704. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/ESLint.d.ts +374 -0
  705. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/ESLint.d.ts.map +1 -0
  706. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/ESLint.js +24 -0
  707. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/ESLint.js.map +1 -0
  708. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Linter.d.ts +247 -0
  709. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Linter.d.ts.map +1 -0
  710. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Linter.js +14 -0
  711. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Linter.js.map +1 -0
  712. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Parser.d.ts +89 -0
  713. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Parser.d.ts.map +1 -0
  714. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Parser.js +4 -0
  715. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Parser.js.map +1 -0
  716. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/ParserOptions.d.ts +2 -0
  717. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/ParserOptions.d.ts.map +1 -0
  718. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/ParserOptions.js +3 -0
  719. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/ParserOptions.js.map +1 -0
  720. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Processor.d.ts +37 -0
  721. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Processor.d.ts.map +1 -0
  722. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Processor.js +4 -0
  723. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Processor.js.map +1 -0
  724. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Rule.d.ts +514 -0
  725. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Rule.d.ts.map +1 -0
  726. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Rule.js +3 -0
  727. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Rule.js.map +1 -0
  728. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/RuleTester.d.ts +162 -0
  729. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/RuleTester.d.ts.map +1 -0
  730. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/RuleTester.js +8 -0
  731. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/RuleTester.js.map +1 -0
  732. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Scope.d.ts +44 -0
  733. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Scope.d.ts.map +1 -0
  734. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Scope.js +34 -0
  735. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/Scope.js.map +1 -0
  736. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/SourceCode.d.ts +362 -0
  737. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/SourceCode.d.ts.map +1 -0
  738. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/SourceCode.js +9 -0
  739. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/SourceCode.js.map +1 -0
  740. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/index.d.ts +13 -0
  741. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/index.d.ts.map +1 -0
  742. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/index.js +29 -0
  743. package/backend/node_modules/@typescript-eslint/utils/dist/ts-eslint/index.js.map +1 -0
  744. package/backend/node_modules/@typescript-eslint/utils/dist/ts-estree.d.ts +3 -0
  745. package/backend/node_modules/@typescript-eslint/utils/dist/ts-estree.d.ts.map +1 -0
  746. package/backend/node_modules/@typescript-eslint/utils/dist/ts-estree.js +10 -0
  747. package/backend/node_modules/@typescript-eslint/utils/dist/ts-estree.js.map +1 -0
  748. package/backend/node_modules/@typescript-eslint/utils/dist/ts-utils/index.d.ts +2 -0
  749. package/backend/node_modules/@typescript-eslint/utils/dist/ts-utils/index.d.ts.map +1 -0
  750. package/backend/node_modules/@typescript-eslint/utils/dist/ts-utils/index.js +18 -0
  751. package/backend/node_modules/@typescript-eslint/utils/dist/ts-utils/index.js.map +1 -0
  752. package/backend/node_modules/@typescript-eslint/utils/dist/ts-utils/isArray.d.ts +2 -0
  753. package/backend/node_modules/@typescript-eslint/utils/dist/ts-utils/isArray.d.ts.map +1 -0
  754. package/backend/node_modules/@typescript-eslint/utils/dist/ts-utils/isArray.js +9 -0
  755. package/backend/node_modules/@typescript-eslint/utils/dist/ts-utils/isArray.js.map +1 -0
  756. package/backend/node_modules/@typescript-eslint/utils/package.json +98 -0
  757. package/backend/node_modules/chalk/index.d.ts +415 -0
  758. package/backend/node_modules/chalk/license +9 -0
  759. package/backend/node_modules/chalk/package.json +68 -0
  760. package/backend/node_modules/chalk/readme.md +341 -0
  761. package/backend/node_modules/chalk/source/index.js +229 -0
  762. package/backend/node_modules/chalk/source/templates.js +134 -0
  763. package/backend/node_modules/chalk/source/util.js +39 -0
  764. package/backend/node_modules/debug/LICENSE +20 -0
  765. package/backend/node_modules/debug/README.md +481 -0
  766. package/backend/node_modules/debug/package.json +64 -0
  767. package/backend/node_modules/debug/src/browser.js +272 -0
  768. package/backend/node_modules/debug/src/common.js +292 -0
  769. package/backend/node_modules/debug/src/index.js +10 -0
  770. package/backend/node_modules/debug/src/node.js +263 -0
  771. package/backend/node_modules/eslint/LICENSE +19 -0
  772. package/backend/node_modules/eslint/README.md +304 -0
  773. package/backend/node_modules/eslint/bin/eslint.js +173 -0
  774. package/backend/node_modules/eslint/conf/config-schema.js +93 -0
  775. package/backend/node_modules/eslint/conf/default-cli-options.js +32 -0
  776. package/backend/node_modules/eslint/conf/globals.js +154 -0
  777. package/backend/node_modules/eslint/conf/replacements.json +22 -0
  778. package/backend/node_modules/eslint/conf/rule-type-list.json +28 -0
  779. package/backend/node_modules/eslint/lib/api.js +54 -0
  780. package/backend/node_modules/eslint/lib/cli-engine/cli-engine.js +1078 -0
  781. package/backend/node_modules/eslint/lib/cli-engine/file-enumerator.js +547 -0
  782. package/backend/node_modules/eslint/lib/cli-engine/formatters/checkstyle.js +60 -0
  783. package/backend/node_modules/eslint/lib/cli-engine/formatters/compact.js +60 -0
  784. package/backend/node_modules/eslint/lib/cli-engine/formatters/formatters-meta.json +46 -0
  785. package/backend/node_modules/eslint/lib/cli-engine/formatters/html.js +351 -0
  786. package/backend/node_modules/eslint/lib/cli-engine/formatters/jslint-xml.js +41 -0
  787. package/backend/node_modules/eslint/lib/cli-engine/formatters/json-with-metadata.js +16 -0
  788. package/backend/node_modules/eslint/lib/cli-engine/formatters/json.js +13 -0
  789. package/backend/node_modules/eslint/lib/cli-engine/formatters/junit.js +82 -0
  790. package/backend/node_modules/eslint/lib/cli-engine/formatters/stylish.js +101 -0
  791. package/backend/node_modules/eslint/lib/cli-engine/formatters/tap.js +95 -0
  792. package/backend/node_modules/eslint/lib/cli-engine/formatters/unix.js +58 -0
  793. package/backend/node_modules/eslint/lib/cli-engine/formatters/visualstudio.js +63 -0
  794. package/backend/node_modules/eslint/lib/cli-engine/hash.js +35 -0
  795. package/backend/node_modules/eslint/lib/cli-engine/index.js +7 -0
  796. package/backend/node_modules/eslint/lib/cli-engine/lint-result-cache.js +203 -0
  797. package/backend/node_modules/eslint/lib/cli-engine/load-rules.js +46 -0
  798. package/backend/node_modules/eslint/lib/cli-engine/xml-escape.js +34 -0
  799. package/backend/node_modules/eslint/lib/cli.js +471 -0
  800. package/backend/node_modules/eslint/lib/config/default-config.js +67 -0
  801. package/backend/node_modules/eslint/lib/config/flat-config-array.js +380 -0
  802. package/backend/node_modules/eslint/lib/config/flat-config-helpers.js +111 -0
  803. package/backend/node_modules/eslint/lib/config/flat-config-schema.js +598 -0
  804. package/backend/node_modules/eslint/lib/config/rule-validator.js +158 -0
  805. package/backend/node_modules/eslint/lib/eslint/eslint-helpers.js +932 -0
  806. package/backend/node_modules/eslint/lib/eslint/eslint.js +707 -0
  807. package/backend/node_modules/eslint/lib/eslint/flat-eslint.js +1159 -0
  808. package/backend/node_modules/eslint/lib/eslint/index.js +9 -0
  809. package/backend/node_modules/eslint/lib/linter/apply-disable-directives.js +465 -0
  810. package/backend/node_modules/eslint/lib/linter/code-path-analysis/code-path-analyzer.js +852 -0
  811. package/backend/node_modules/eslint/lib/linter/code-path-analysis/code-path-segment.js +263 -0
  812. package/backend/node_modules/eslint/lib/linter/code-path-analysis/code-path-state.js +2348 -0
  813. package/backend/node_modules/eslint/lib/linter/code-path-analysis/code-path.js +342 -0
  814. package/backend/node_modules/eslint/lib/linter/code-path-analysis/debug-helpers.js +203 -0
  815. package/backend/node_modules/eslint/lib/linter/code-path-analysis/fork-context.js +349 -0
  816. package/backend/node_modules/eslint/lib/linter/code-path-analysis/id-generator.js +45 -0
  817. package/backend/node_modules/eslint/lib/linter/config-comment-parser.js +185 -0
  818. package/backend/node_modules/eslint/lib/linter/index.js +13 -0
  819. package/backend/node_modules/eslint/lib/linter/interpolate.js +28 -0
  820. package/backend/node_modules/eslint/lib/linter/linter.js +2119 -0
  821. package/backend/node_modules/eslint/lib/linter/node-event-generator.js +354 -0
  822. package/backend/node_modules/eslint/lib/linter/report-translator.js +369 -0
  823. package/backend/node_modules/eslint/lib/linter/rule-fixer.js +140 -0
  824. package/backend/node_modules/eslint/lib/linter/rules.js +80 -0
  825. package/backend/node_modules/eslint/lib/linter/safe-emitter.js +52 -0
  826. package/backend/node_modules/eslint/lib/linter/source-code-fixer.js +152 -0
  827. package/backend/node_modules/eslint/lib/linter/timing.js +161 -0
  828. package/backend/node_modules/eslint/lib/options.js +398 -0
  829. package/backend/node_modules/eslint/lib/rule-tester/flat-rule-tester.js +1131 -0
  830. package/backend/node_modules/eslint/lib/rule-tester/index.js +5 -0
  831. package/backend/node_modules/eslint/lib/rule-tester/rule-tester.js +1206 -0
  832. package/backend/node_modules/eslint/lib/rules/accessor-pairs.js +346 -0
  833. package/backend/node_modules/eslint/lib/rules/array-bracket-newline.js +261 -0
  834. package/backend/node_modules/eslint/lib/rules/array-bracket-spacing.js +244 -0
  835. package/backend/node_modules/eslint/lib/rules/array-callback-return.js +446 -0
  836. package/backend/node_modules/eslint/lib/rules/array-element-newline.js +311 -0
  837. package/backend/node_modules/eslint/lib/rules/arrow-body-style.js +296 -0
  838. package/backend/node_modules/eslint/lib/rules/arrow-parens.js +186 -0
  839. package/backend/node_modules/eslint/lib/rules/arrow-spacing.js +164 -0
  840. package/backend/node_modules/eslint/lib/rules/block-scoped-var.js +135 -0
  841. package/backend/node_modules/eslint/lib/rules/block-spacing.js +174 -0
  842. package/backend/node_modules/eslint/lib/rules/brace-style.js +197 -0
  843. package/backend/node_modules/eslint/lib/rules/callback-return.js +187 -0
  844. package/backend/node_modules/eslint/lib/rules/camelcase.js +399 -0
  845. package/backend/node_modules/eslint/lib/rules/capitalized-comments.js +300 -0
  846. package/backend/node_modules/eslint/lib/rules/class-methods-use-this.js +187 -0
  847. package/backend/node_modules/eslint/lib/rules/comma-dangle.js +373 -0
  848. package/backend/node_modules/eslint/lib/rules/comma-spacing.js +192 -0
  849. package/backend/node_modules/eslint/lib/rules/comma-style.js +314 -0
  850. package/backend/node_modules/eslint/lib/rules/complexity.js +165 -0
  851. package/backend/node_modules/eslint/lib/rules/computed-property-spacing.js +208 -0
  852. package/backend/node_modules/eslint/lib/rules/consistent-return.js +210 -0
  853. package/backend/node_modules/eslint/lib/rules/consistent-this.js +153 -0
  854. package/backend/node_modules/eslint/lib/rules/constructor-super.js +446 -0
  855. package/backend/node_modules/eslint/lib/rules/curly.js +486 -0
  856. package/backend/node_modules/eslint/lib/rules/default-case-last.js +44 -0
  857. package/backend/node_modules/eslint/lib/rules/default-case.js +97 -0
  858. package/backend/node_modules/eslint/lib/rules/default-param-last.js +62 -0
  859. package/backend/node_modules/eslint/lib/rules/dot-location.js +108 -0
  860. package/backend/node_modules/eslint/lib/rules/dot-notation.js +176 -0
  861. package/backend/node_modules/eslint/lib/rules/eol-last.js +115 -0
  862. package/backend/node_modules/eslint/lib/rules/eqeqeq.js +174 -0
  863. package/backend/node_modules/eslint/lib/rules/for-direction.js +140 -0
  864. package/backend/node_modules/eslint/lib/rules/func-call-spacing.js +233 -0
  865. package/backend/node_modules/eslint/lib/rules/func-name-matching.js +253 -0
  866. package/backend/node_modules/eslint/lib/rules/func-names.js +191 -0
  867. package/backend/node_modules/eslint/lib/rules/func-style.js +98 -0
  868. package/backend/node_modules/eslint/lib/rules/function-call-argument-newline.js +125 -0
  869. package/backend/node_modules/eslint/lib/rules/function-paren-newline.js +292 -0
  870. package/backend/node_modules/eslint/lib/rules/generator-star-spacing.js +209 -0
  871. package/backend/node_modules/eslint/lib/rules/getter-return.js +204 -0
  872. package/backend/node_modules/eslint/lib/rules/global-require.js +90 -0
  873. package/backend/node_modules/eslint/lib/rules/grouped-accessor-pairs.js +215 -0
  874. package/backend/node_modules/eslint/lib/rules/guard-for-in.js +76 -0
  875. package/backend/node_modules/eslint/lib/rules/handle-callback-err.js +101 -0
  876. package/backend/node_modules/eslint/lib/rules/id-blacklist.js +246 -0
  877. package/backend/node_modules/eslint/lib/rules/id-denylist.js +228 -0
  878. package/backend/node_modules/eslint/lib/rules/id-length.js +177 -0
  879. package/backend/node_modules/eslint/lib/rules/id-match.js +299 -0
  880. package/backend/node_modules/eslint/lib/rules/implicit-arrow-linebreak.js +84 -0
  881. package/backend/node_modules/eslint/lib/rules/indent-legacy.js +1126 -0
  882. package/backend/node_modules/eslint/lib/rules/indent.js +1803 -0
  883. package/backend/node_modules/eslint/lib/rules/index.js +306 -0
  884. package/backend/node_modules/eslint/lib/rules/init-declarations.js +139 -0
  885. package/backend/node_modules/eslint/lib/rules/jsx-quotes.js +98 -0
  886. package/backend/node_modules/eslint/lib/rules/key-spacing.js +687 -0
  887. package/backend/node_modules/eslint/lib/rules/keyword-spacing.js +640 -0
  888. package/backend/node_modules/eslint/lib/rules/line-comment-position.js +122 -0
  889. package/backend/node_modules/eslint/lib/rules/linebreak-style.js +108 -0
  890. package/backend/node_modules/eslint/lib/rules/lines-around-comment.js +471 -0
  891. package/backend/node_modules/eslint/lib/rules/lines-around-directive.js +201 -0
  892. package/backend/node_modules/eslint/lib/rules/lines-between-class-members.js +269 -0
  893. package/backend/node_modules/eslint/lib/rules/logical-assignment-operators.js +504 -0
  894. package/backend/node_modules/eslint/lib/rules/max-classes-per-file.js +89 -0
  895. package/backend/node_modules/eslint/lib/rules/max-depth.js +156 -0
  896. package/backend/node_modules/eslint/lib/rules/max-len.js +440 -0
  897. package/backend/node_modules/eslint/lib/rules/max-lines-per-function.js +213 -0
  898. package/backend/node_modules/eslint/lib/rules/max-lines.js +193 -0
  899. package/backend/node_modules/eslint/lib/rules/max-nested-callbacks.js +117 -0
  900. package/backend/node_modules/eslint/lib/rules/max-params.js +102 -0
  901. package/backend/node_modules/eslint/lib/rules/max-statements-per-line.js +199 -0
  902. package/backend/node_modules/eslint/lib/rules/max-statements.js +184 -0
  903. package/backend/node_modules/eslint/lib/rules/multiline-comment-style.js +474 -0
  904. package/backend/node_modules/eslint/lib/rules/multiline-ternary.js +174 -0
  905. package/backend/node_modules/eslint/lib/rules/new-cap.js +276 -0
  906. package/backend/node_modules/eslint/lib/rules/new-parens.js +93 -0
  907. package/backend/node_modules/eslint/lib/rules/newline-after-var.js +253 -0
  908. package/backend/node_modules/eslint/lib/rules/newline-before-return.js +217 -0
  909. package/backend/node_modules/eslint/lib/rules/newline-per-chained-call.js +126 -0
  910. package/backend/node_modules/eslint/lib/rules/no-alert.js +138 -0
  911. package/backend/node_modules/eslint/lib/rules/no-array-constructor.js +133 -0
  912. package/backend/node_modules/eslint/lib/rules/no-async-promise-executor.js +39 -0
  913. package/backend/node_modules/eslint/lib/rules/no-await-in-loop.js +106 -0
  914. package/backend/node_modules/eslint/lib/rules/no-bitwise.js +119 -0
  915. package/backend/node_modules/eslint/lib/rules/no-buffer-constructor.js +50 -0
  916. package/backend/node_modules/eslint/lib/rules/no-caller.js +46 -0
  917. package/backend/node_modules/eslint/lib/rules/no-case-declarations.js +64 -0
  918. package/backend/node_modules/eslint/lib/rules/no-catch-shadow.js +82 -0
  919. package/backend/node_modules/eslint/lib/rules/no-class-assign.js +63 -0
  920. package/backend/node_modules/eslint/lib/rules/no-compare-neg-zero.js +60 -0
  921. package/backend/node_modules/eslint/lib/rules/no-cond-assign.js +159 -0
  922. package/backend/node_modules/eslint/lib/rules/no-confusing-arrow.js +92 -0
  923. package/backend/node_modules/eslint/lib/rules/no-console.js +207 -0
  924. package/backend/node_modules/eslint/lib/rules/no-const-assign.js +56 -0
  925. package/backend/node_modules/eslint/lib/rules/no-constant-binary-expression.js +509 -0
  926. package/backend/node_modules/eslint/lib/rules/no-constant-condition.js +150 -0
  927. package/backend/node_modules/eslint/lib/rules/no-constructor-return.js +62 -0
  928. package/backend/node_modules/eslint/lib/rules/no-continue.js +39 -0
  929. package/backend/node_modules/eslint/lib/rules/no-control-regex.js +138 -0
  930. package/backend/node_modules/eslint/lib/rules/no-debugger.js +43 -0
  931. package/backend/node_modules/eslint/lib/rules/no-delete-var.js +42 -0
  932. package/backend/node_modules/eslint/lib/rules/no-div-regex.js +53 -0
  933. package/backend/node_modules/eslint/lib/rules/no-dupe-args.js +82 -0
  934. package/backend/node_modules/eslint/lib/rules/no-dupe-class-members.js +104 -0
  935. package/backend/node_modules/eslint/lib/rules/no-dupe-else-if.js +122 -0
  936. package/backend/node_modules/eslint/lib/rules/no-dupe-keys.js +142 -0
  937. package/backend/node_modules/eslint/lib/rules/no-duplicate-case.js +71 -0
  938. package/backend/node_modules/eslint/lib/rules/no-duplicate-imports.js +290 -0
  939. package/backend/node_modules/eslint/lib/rules/no-else-return.js +405 -0
  940. package/backend/node_modules/eslint/lib/rules/no-empty-character-class.js +76 -0
  941. package/backend/node_modules/eslint/lib/rules/no-empty-function.js +167 -0
  942. package/backend/node_modules/eslint/lib/rules/no-empty-pattern.js +78 -0
  943. package/backend/node_modules/eslint/lib/rules/no-empty-static-block.js +47 -0
  944. package/backend/node_modules/eslint/lib/rules/no-empty.js +103 -0
  945. package/backend/node_modules/eslint/lib/rules/no-eq-null.js +46 -0
  946. package/backend/node_modules/eslint/lib/rules/no-eval.js +286 -0
  947. package/backend/node_modules/eslint/lib/rules/no-ex-assign.js +54 -0
  948. package/backend/node_modules/eslint/lib/rules/no-extend-native.js +179 -0
  949. package/backend/node_modules/eslint/lib/rules/no-extra-bind.js +213 -0
  950. package/backend/node_modules/eslint/lib/rules/no-extra-boolean-cast.js +317 -0
  951. package/backend/node_modules/eslint/lib/rules/no-extra-label.js +149 -0
  952. package/backend/node_modules/eslint/lib/rules/no-extra-parens.js +1322 -0
  953. package/backend/node_modules/eslint/lib/rules/no-extra-semi.js +147 -0
  954. package/backend/node_modules/eslint/lib/rules/no-fallthrough.js +196 -0
  955. package/backend/node_modules/eslint/lib/rules/no-floating-decimal.js +73 -0
  956. package/backend/node_modules/eslint/lib/rules/no-func-assign.js +78 -0
  957. package/backend/node_modules/eslint/lib/rules/no-global-assign.js +95 -0
  958. package/backend/node_modules/eslint/lib/rules/no-implicit-coercion.js +380 -0
  959. package/backend/node_modules/eslint/lib/rules/no-implicit-globals.js +146 -0
  960. package/backend/node_modules/eslint/lib/rules/no-implied-eval.js +132 -0
  961. package/backend/node_modules/eslint/lib/rules/no-import-assign.js +241 -0
  962. package/backend/node_modules/eslint/lib/rules/no-inline-comments.js +110 -0
  963. package/backend/node_modules/eslint/lib/rules/no-inner-declarations.js +110 -0
  964. package/backend/node_modules/eslint/lib/rules/no-invalid-regexp.js +194 -0
  965. package/backend/node_modules/eslint/lib/rules/no-invalid-this.js +150 -0
  966. package/backend/node_modules/eslint/lib/rules/no-irregular-whitespace.js +276 -0
  967. package/backend/node_modules/eslint/lib/rules/no-iterator.js +52 -0
  968. package/backend/node_modules/eslint/lib/rules/no-label-var.js +80 -0
  969. package/backend/node_modules/eslint/lib/rules/no-labels.js +149 -0
  970. package/backend/node_modules/eslint/lib/rules/no-lone-blocks.js +136 -0
  971. package/backend/node_modules/eslint/lib/rules/no-lonely-if.js +88 -0
  972. package/backend/node_modules/eslint/lib/rules/no-loop-func.js +206 -0
  973. package/backend/node_modules/eslint/lib/rules/no-loss-of-precision.js +214 -0
  974. package/backend/node_modules/eslint/lib/rules/no-magic-numbers.js +243 -0
  975. package/backend/node_modules/eslint/lib/rules/no-misleading-character-class.js +300 -0
  976. package/backend/node_modules/eslint/lib/rules/no-mixed-operators.js +229 -0
  977. package/backend/node_modules/eslint/lib/rules/no-mixed-requires.js +238 -0
  978. package/backend/node_modules/eslint/lib/rules/no-mixed-spaces-and-tabs.js +116 -0
  979. package/backend/node_modules/eslint/lib/rules/no-multi-assign.js +67 -0
  980. package/backend/node_modules/eslint/lib/rules/no-multi-spaces.js +141 -0
  981. package/backend/node_modules/eslint/lib/rules/no-multi-str.js +65 -0
  982. package/backend/node_modules/eslint/lib/rules/no-multiple-empty-lines.js +154 -0
  983. package/backend/node_modules/eslint/lib/rules/no-native-reassign.js +98 -0
  984. package/backend/node_modules/eslint/lib/rules/no-negated-condition.js +95 -0
  985. package/backend/node_modules/eslint/lib/rules/no-negated-in-lhs.js +46 -0
  986. package/backend/node_modules/eslint/lib/rules/no-nested-ternary.js +44 -0
  987. package/backend/node_modules/eslint/lib/rules/no-new-func.js +87 -0
  988. package/backend/node_modules/eslint/lib/rules/no-new-native-nonconstructor.js +66 -0
  989. package/backend/node_modules/eslint/lib/rules/no-new-object.js +67 -0
  990. package/backend/node_modules/eslint/lib/rules/no-new-require.js +50 -0
  991. package/backend/node_modules/eslint/lib/rules/no-new-symbol.js +56 -0
  992. package/backend/node_modules/eslint/lib/rules/no-new-wrappers.js +60 -0
  993. package/backend/node_modules/eslint/lib/rules/no-new.js +43 -0
  994. package/backend/node_modules/eslint/lib/rules/no-nonoctal-decimal-escape.js +148 -0
  995. package/backend/node_modules/eslint/lib/rules/no-obj-calls.js +86 -0
  996. package/backend/node_modules/eslint/lib/rules/no-object-constructor.js +117 -0
  997. package/backend/node_modules/eslint/lib/rules/no-octal-escape.js +56 -0
  998. package/backend/node_modules/eslint/lib/rules/no-octal.js +45 -0
  999. package/backend/node_modules/eslint/lib/rules/no-param-reassign.js +230 -0
  1000. package/backend/node_modules/eslint/lib/rules/no-path-concat.js +64 -0
  1001. package/backend/node_modules/eslint/lib/rules/no-plusplus.js +105 -0
  1002. package/backend/node_modules/eslint/lib/rules/no-process-env.js +51 -0
  1003. package/backend/node_modules/eslint/lib/rules/no-process-exit.js +47 -0
  1004. package/backend/node_modules/eslint/lib/rules/no-promise-executor-return.js +263 -0
  1005. package/backend/node_modules/eslint/lib/rules/no-proto.js +48 -0
  1006. package/backend/node_modules/eslint/lib/rules/no-prototype-builtins.js +159 -0
  1007. package/backend/node_modules/eslint/lib/rules/no-redeclare.js +174 -0
  1008. package/backend/node_modules/eslint/lib/rules/no-regex-spaces.js +197 -0
  1009. package/backend/node_modules/eslint/lib/rules/no-restricted-exports.js +193 -0
  1010. package/backend/node_modules/eslint/lib/rules/no-restricted-globals.js +124 -0
  1011. package/backend/node_modules/eslint/lib/rules/no-restricted-imports.js +410 -0
  1012. package/backend/node_modules/eslint/lib/rules/no-restricted-modules.js +213 -0
  1013. package/backend/node_modules/eslint/lib/rules/no-restricted-properties.js +168 -0
  1014. package/backend/node_modules/eslint/lib/rules/no-restricted-syntax.js +70 -0
  1015. package/backend/node_modules/eslint/lib/rules/no-return-assign.js +80 -0
  1016. package/backend/node_modules/eslint/lib/rules/no-return-await.js +135 -0
  1017. package/backend/node_modules/eslint/lib/rules/no-script-url.js +61 -0
  1018. package/backend/node_modules/eslint/lib/rules/no-self-assign.js +183 -0
  1019. package/backend/node_modules/eslint/lib/rules/no-self-compare.js +60 -0
  1020. package/backend/node_modules/eslint/lib/rules/no-sequences.js +138 -0
  1021. package/backend/node_modules/eslint/lib/rules/no-setter-return.js +226 -0
  1022. package/backend/node_modules/eslint/lib/rules/no-shadow-restricted-names.js +65 -0
  1023. package/backend/node_modules/eslint/lib/rules/no-shadow.js +336 -0
  1024. package/backend/node_modules/eslint/lib/rules/no-spaced-func.js +83 -0
  1025. package/backend/node_modules/eslint/lib/rules/no-sparse-arrays.js +50 -0
  1026. package/backend/node_modules/eslint/lib/rules/no-sync.js +64 -0
  1027. package/backend/node_modules/eslint/lib/rules/no-tabs.js +81 -0
  1028. package/backend/node_modules/eslint/lib/rules/no-template-curly-in-string.js +44 -0
  1029. package/backend/node_modules/eslint/lib/rules/no-ternary.js +41 -0
  1030. package/backend/node_modules/eslint/lib/rules/no-this-before-super.js +331 -0
  1031. package/backend/node_modules/eslint/lib/rules/no-throw-literal.js +51 -0
  1032. package/backend/node_modules/eslint/lib/rules/no-trailing-spaces.js +193 -0
  1033. package/backend/node_modules/eslint/lib/rules/no-undef-init.js +75 -0
  1034. package/backend/node_modules/eslint/lib/rules/no-undef.js +79 -0
  1035. package/backend/node_modules/eslint/lib/rules/no-undefined.js +86 -0
  1036. package/backend/node_modules/eslint/lib/rules/no-underscore-dangle.js +335 -0
  1037. package/backend/node_modules/eslint/lib/rules/no-unexpected-multiline.js +120 -0
  1038. package/backend/node_modules/eslint/lib/rules/no-unmodified-loop-condition.js +360 -0
  1039. package/backend/node_modules/eslint/lib/rules/no-unneeded-ternary.js +166 -0
  1040. package/backend/node_modules/eslint/lib/rules/no-unreachable-loop.js +185 -0
  1041. package/backend/node_modules/eslint/lib/rules/no-unreachable.js +293 -0
  1042. package/backend/node_modules/eslint/lib/rules/no-unsafe-finally.js +111 -0
  1043. package/backend/node_modules/eslint/lib/rules/no-unsafe-negation.js +128 -0
  1044. package/backend/node_modules/eslint/lib/rules/no-unsafe-optional-chaining.js +205 -0
  1045. package/backend/node_modules/eslint/lib/rules/no-unused-expressions.js +186 -0
  1046. package/backend/node_modules/eslint/lib/rules/no-unused-labels.js +143 -0
  1047. package/backend/node_modules/eslint/lib/rules/no-unused-private-class-members.js +195 -0
  1048. package/backend/node_modules/eslint/lib/rules/no-unused-vars.js +718 -0
  1049. package/backend/node_modules/eslint/lib/rules/no-use-before-define.js +348 -0
  1050. package/backend/node_modules/eslint/lib/rules/no-useless-backreference.js +194 -0
  1051. package/backend/node_modules/eslint/lib/rules/no-useless-call.js +90 -0
  1052. package/backend/node_modules/eslint/lib/rules/no-useless-catch.js +57 -0
  1053. package/backend/node_modules/eslint/lib/rules/no-useless-computed-key.js +168 -0
  1054. package/backend/node_modules/eslint/lib/rules/no-useless-concat.js +115 -0
  1055. package/backend/node_modules/eslint/lib/rules/no-useless-constructor.js +189 -0
  1056. package/backend/node_modules/eslint/lib/rules/no-useless-escape.js +333 -0
  1057. package/backend/node_modules/eslint/lib/rules/no-useless-rename.js +172 -0
  1058. package/backend/node_modules/eslint/lib/rules/no-useless-return.js +364 -0
  1059. package/backend/node_modules/eslint/lib/rules/no-var.js +334 -0
  1060. package/backend/node_modules/eslint/lib/rules/no-void.js +64 -0
  1061. package/backend/node_modules/eslint/lib/rules/no-warning-comments.js +201 -0
  1062. package/backend/node_modules/eslint/lib/rules/no-whitespace-before-property.js +116 -0
  1063. package/backend/node_modules/eslint/lib/rules/no-with.js +39 -0
  1064. package/backend/node_modules/eslint/lib/rules/nonblock-statement-body-position.js +127 -0
  1065. package/backend/node_modules/eslint/lib/rules/object-curly-newline.js +324 -0
  1066. package/backend/node_modules/eslint/lib/rules/object-curly-spacing.js +311 -0
  1067. package/backend/node_modules/eslint/lib/rules/object-property-newline.js +102 -0
  1068. package/backend/node_modules/eslint/lib/rules/object-shorthand.js +520 -0
  1069. package/backend/node_modules/eslint/lib/rules/one-var-declaration-per-line.js +95 -0
  1070. package/backend/node_modules/eslint/lib/rules/one-var.js +567 -0
  1071. package/backend/node_modules/eslint/lib/rules/operator-assignment.js +209 -0
  1072. package/backend/node_modules/eslint/lib/rules/operator-linebreak.js +253 -0
  1073. package/backend/node_modules/eslint/lib/rules/padded-blocks.js +310 -0
  1074. package/backend/node_modules/eslint/lib/rules/padding-line-between-statements.js +590 -0
  1075. package/backend/node_modules/eslint/lib/rules/prefer-arrow-callback.js +381 -0
  1076. package/backend/node_modules/eslint/lib/rules/prefer-const.js +501 -0
  1077. package/backend/node_modules/eslint/lib/rules/prefer-destructuring.js +301 -0
  1078. package/backend/node_modules/eslint/lib/rules/prefer-exponentiation-operator.js +191 -0
  1079. package/backend/node_modules/eslint/lib/rules/prefer-named-capture-group.js +178 -0
  1080. package/backend/node_modules/eslint/lib/rules/prefer-numeric-literals.js +148 -0
  1081. package/backend/node_modules/eslint/lib/rules/prefer-object-has-own.js +114 -0
  1082. package/backend/node_modules/eslint/lib/rules/prefer-object-spread.js +298 -0
  1083. package/backend/node_modules/eslint/lib/rules/prefer-promise-reject-errors.js +132 -0
  1084. package/backend/node_modules/eslint/lib/rules/prefer-reflect.js +127 -0
  1085. package/backend/node_modules/eslint/lib/rules/prefer-regex-literals.js +507 -0
  1086. package/backend/node_modules/eslint/lib/rules/prefer-rest-params.js +118 -0
  1087. package/backend/node_modules/eslint/lib/rules/prefer-spread.js +87 -0
  1088. package/backend/node_modules/eslint/lib/rules/prefer-template.js +275 -0
  1089. package/backend/node_modules/eslint/lib/rules/quote-props.js +310 -0
  1090. package/backend/node_modules/eslint/lib/rules/quotes.js +350 -0
  1091. package/backend/node_modules/eslint/lib/rules/radix.js +198 -0
  1092. package/backend/node_modules/eslint/lib/rules/require-atomic-updates.js +331 -0
  1093. package/backend/node_modules/eslint/lib/rules/require-await.js +113 -0
  1094. package/backend/node_modules/eslint/lib/rules/require-jsdoc.js +122 -0
  1095. package/backend/node_modules/eslint/lib/rules/require-unicode-regexp.js +129 -0
  1096. package/backend/node_modules/eslint/lib/rules/require-yield.js +77 -0
  1097. package/backend/node_modules/eslint/lib/rules/rest-spread-spacing.js +123 -0
  1098. package/backend/node_modules/eslint/lib/rules/semi-spacing.js +248 -0
  1099. package/backend/node_modules/eslint/lib/rules/semi-style.js +158 -0
  1100. package/backend/node_modules/eslint/lib/rules/semi.js +438 -0
  1101. package/backend/node_modules/eslint/lib/rules/sort-imports.js +241 -0
  1102. package/backend/node_modules/eslint/lib/rules/sort-keys.js +230 -0
  1103. package/backend/node_modules/eslint/lib/rules/sort-vars.js +104 -0
  1104. package/backend/node_modules/eslint/lib/rules/space-before-blocks.js +204 -0
  1105. package/backend/node_modules/eslint/lib/rules/space-before-function-paren.js +167 -0
  1106. package/backend/node_modules/eslint/lib/rules/space-in-parens.js +285 -0
  1107. package/backend/node_modules/eslint/lib/rules/space-infix-ops.js +198 -0
  1108. package/backend/node_modules/eslint/lib/rules/space-unary-ops.js +324 -0
  1109. package/backend/node_modules/eslint/lib/rules/spaced-comment.js +385 -0
  1110. package/backend/node_modules/eslint/lib/rules/strict.js +277 -0
  1111. package/backend/node_modules/eslint/lib/rules/switch-colon-spacing.js +132 -0
  1112. package/backend/node_modules/eslint/lib/rules/symbol-description.js +73 -0
  1113. package/backend/node_modules/eslint/lib/rules/template-curly-spacing.js +144 -0
  1114. package/backend/node_modules/eslint/lib/rules/template-tag-spacing.js +93 -0
  1115. package/backend/node_modules/eslint/lib/rules/unicode-bom.js +73 -0
  1116. package/backend/node_modules/eslint/lib/rules/use-isnan.js +141 -0
  1117. package/backend/node_modules/eslint/lib/rules/utils/ast-utils.js +2282 -0
  1118. package/backend/node_modules/eslint/lib/rules/utils/fix-tracker.js +114 -0
  1119. package/backend/node_modules/eslint/lib/rules/utils/keywords.js +67 -0
  1120. package/backend/node_modules/eslint/lib/rules/utils/lazy-loading-rule-map.js +115 -0
  1121. package/backend/node_modules/eslint/lib/rules/utils/patterns/letters.js +36 -0
  1122. package/backend/node_modules/eslint/lib/rules/utils/regular-expressions.js +42 -0
  1123. package/backend/node_modules/eslint/lib/rules/utils/unicode/index.js +11 -0
  1124. package/backend/node_modules/eslint/lib/rules/utils/unicode/is-combining-character.js +13 -0
  1125. package/backend/node_modules/eslint/lib/rules/utils/unicode/is-emoji-modifier.js +13 -0
  1126. package/backend/node_modules/eslint/lib/rules/utils/unicode/is-regional-indicator-symbol.js +13 -0
  1127. package/backend/node_modules/eslint/lib/rules/utils/unicode/is-surrogate-pair.js +14 -0
  1128. package/backend/node_modules/eslint/lib/rules/valid-jsdoc.js +516 -0
  1129. package/backend/node_modules/eslint/lib/rules/valid-typeof.js +127 -0
  1130. package/backend/node_modules/eslint/lib/rules/vars-on-top.js +157 -0
  1131. package/backend/node_modules/eslint/lib/rules/wrap-iife.js +207 -0
  1132. package/backend/node_modules/eslint/lib/rules/wrap-regex.js +61 -0
  1133. package/backend/node_modules/eslint/lib/rules/yield-star-spacing.js +130 -0
  1134. package/backend/node_modules/eslint/lib/rules/yoda.js +353 -0
  1135. package/backend/node_modules/eslint/lib/shared/ajv.js +34 -0
  1136. package/backend/node_modules/eslint/lib/shared/ast-utils.js +29 -0
  1137. package/backend/node_modules/eslint/lib/shared/config-validator.js +347 -0
  1138. package/backend/node_modules/eslint/lib/shared/deprecation-warnings.js +58 -0
  1139. package/backend/node_modules/eslint/lib/shared/directives.js +15 -0
  1140. package/backend/node_modules/eslint/lib/shared/logging.js +30 -0
  1141. package/backend/node_modules/eslint/lib/shared/relative-module-resolver.js +50 -0
  1142. package/backend/node_modules/eslint/lib/shared/runtime-info.js +167 -0
  1143. package/backend/node_modules/eslint/lib/shared/severity.js +49 -0
  1144. package/backend/node_modules/eslint/lib/shared/string-utils.js +60 -0
  1145. package/backend/node_modules/eslint/lib/shared/traverser.js +195 -0
  1146. package/backend/node_modules/eslint/lib/shared/types.js +216 -0
  1147. package/backend/node_modules/eslint/lib/source-code/index.js +5 -0
  1148. package/backend/node_modules/eslint/lib/source-code/source-code.js +1055 -0
  1149. package/backend/node_modules/eslint/lib/source-code/token-store/backward-token-comment-cursor.js +57 -0
  1150. package/backend/node_modules/eslint/lib/source-code/token-store/backward-token-cursor.js +58 -0
  1151. package/backend/node_modules/eslint/lib/source-code/token-store/cursor.js +76 -0
  1152. package/backend/node_modules/eslint/lib/source-code/token-store/cursors.js +90 -0
  1153. package/backend/node_modules/eslint/lib/source-code/token-store/decorative-cursor.js +39 -0
  1154. package/backend/node_modules/eslint/lib/source-code/token-store/filter-cursor.js +43 -0
  1155. package/backend/node_modules/eslint/lib/source-code/token-store/forward-token-comment-cursor.js +57 -0
  1156. package/backend/node_modules/eslint/lib/source-code/token-store/forward-token-cursor.js +63 -0
  1157. package/backend/node_modules/eslint/lib/source-code/token-store/index.js +627 -0
  1158. package/backend/node_modules/eslint/lib/source-code/token-store/limit-cursor.js +40 -0
  1159. package/backend/node_modules/eslint/lib/source-code/token-store/padded-token-cursor.js +38 -0
  1160. package/backend/node_modules/eslint/lib/source-code/token-store/skip-cursor.js +42 -0
  1161. package/backend/node_modules/eslint/lib/source-code/token-store/utils.js +107 -0
  1162. package/backend/node_modules/eslint/lib/unsupported-api.js +30 -0
  1163. package/backend/node_modules/eslint/messages/all-files-ignored.js +16 -0
  1164. package/backend/node_modules/eslint/messages/eslintrc-incompat.js +98 -0
  1165. package/backend/node_modules/eslint/messages/eslintrc-plugins.js +24 -0
  1166. package/backend/node_modules/eslint/messages/extend-config-missing.js +13 -0
  1167. package/backend/node_modules/eslint/messages/failed-to-read-json.js +11 -0
  1168. package/backend/node_modules/eslint/messages/file-not-found.js +10 -0
  1169. package/backend/node_modules/eslint/messages/invalid-rule-options.js +17 -0
  1170. package/backend/node_modules/eslint/messages/invalid-rule-severity.js +13 -0
  1171. package/backend/node_modules/eslint/messages/no-config-found.js +15 -0
  1172. package/backend/node_modules/eslint/messages/plugin-conflict.js +22 -0
  1173. package/backend/node_modules/eslint/messages/plugin-invalid.js +16 -0
  1174. package/backend/node_modules/eslint/messages/plugin-missing.js +19 -0
  1175. package/backend/node_modules/eslint/messages/print-config-with-directory-path.js +8 -0
  1176. package/backend/node_modules/eslint/messages/shared.js +18 -0
  1177. package/backend/node_modules/eslint/messages/whitespace-found.js +11 -0
  1178. package/backend/node_modules/eslint/package.json +181 -0
  1179. package/backend/node_modules/undici-types/LICENSE +21 -0
  1180. package/backend/node_modules/undici-types/README.md +6 -0
  1181. package/backend/node_modules/undici-types/agent.d.ts +31 -0
  1182. package/backend/node_modules/undici-types/api.d.ts +43 -0
  1183. package/backend/node_modules/undici-types/balanced-pool.d.ts +29 -0
  1184. package/backend/node_modules/undici-types/cache.d.ts +36 -0
  1185. package/backend/node_modules/undici-types/client.d.ts +108 -0
  1186. package/backend/node_modules/undici-types/connector.d.ts +34 -0
  1187. package/backend/node_modules/undici-types/content-type.d.ts +21 -0
  1188. package/backend/node_modules/undici-types/cookies.d.ts +28 -0
  1189. package/backend/node_modules/undici-types/diagnostics-channel.d.ts +66 -0
  1190. package/backend/node_modules/undici-types/dispatcher.d.ts +256 -0
  1191. package/backend/node_modules/undici-types/env-http-proxy-agent.d.ts +21 -0
  1192. package/backend/node_modules/undici-types/errors.d.ts +149 -0
  1193. package/backend/node_modules/undici-types/eventsource.d.ts +61 -0
  1194. package/backend/node_modules/undici-types/fetch.d.ts +209 -0
  1195. package/backend/node_modules/undici-types/file.d.ts +39 -0
  1196. package/backend/node_modules/undici-types/filereader.d.ts +54 -0
  1197. package/backend/node_modules/undici-types/formdata.d.ts +108 -0
  1198. package/backend/node_modules/undici-types/global-dispatcher.d.ts +9 -0
  1199. package/backend/node_modules/undici-types/global-origin.d.ts +7 -0
  1200. package/backend/node_modules/undici-types/handlers.d.ts +15 -0
  1201. package/backend/node_modules/undici-types/header.d.ts +4 -0
  1202. package/backend/node_modules/undici-types/index.d.ts +71 -0
  1203. package/backend/node_modules/undici-types/interceptors.d.ts +17 -0
  1204. package/backend/node_modules/undici-types/mock-agent.d.ts +50 -0
  1205. package/backend/node_modules/undici-types/mock-client.d.ts +25 -0
  1206. package/backend/node_modules/undici-types/mock-errors.d.ts +12 -0
  1207. package/backend/node_modules/undici-types/mock-interceptor.d.ts +93 -0
  1208. package/backend/node_modules/undici-types/mock-pool.d.ts +25 -0
  1209. package/backend/node_modules/undici-types/package.json +55 -0
  1210. package/backend/node_modules/undici-types/patch.d.ts +33 -0
  1211. package/backend/node_modules/undici-types/pool-stats.d.ts +19 -0
  1212. package/backend/node_modules/undici-types/pool.d.ts +39 -0
  1213. package/backend/node_modules/undici-types/proxy-agent.d.ts +28 -0
  1214. package/backend/node_modules/undici-types/readable.d.ts +65 -0
  1215. package/backend/node_modules/undici-types/retry-agent.d.ts +8 -0
  1216. package/backend/node_modules/undici-types/retry-handler.d.ts +116 -0
  1217. package/backend/node_modules/undici-types/util.d.ts +18 -0
  1218. package/backend/node_modules/undici-types/webidl.d.ts +228 -0
  1219. package/backend/node_modules/undici-types/websocket.d.ts +150 -0
  1220. package/daemon/node_modules/undici-types/LICENSE +21 -0
  1221. package/daemon/node_modules/undici-types/README.md +6 -0
  1222. package/daemon/node_modules/undici-types/agent.d.ts +31 -0
  1223. package/daemon/node_modules/undici-types/api.d.ts +43 -0
  1224. package/daemon/node_modules/undici-types/balanced-pool.d.ts +29 -0
  1225. package/daemon/node_modules/undici-types/cache.d.ts +36 -0
  1226. package/daemon/node_modules/undici-types/client.d.ts +108 -0
  1227. package/daemon/node_modules/undici-types/connector.d.ts +34 -0
  1228. package/daemon/node_modules/undici-types/content-type.d.ts +21 -0
  1229. package/daemon/node_modules/undici-types/cookies.d.ts +28 -0
  1230. package/daemon/node_modules/undici-types/diagnostics-channel.d.ts +66 -0
  1231. package/daemon/node_modules/undici-types/dispatcher.d.ts +256 -0
  1232. package/daemon/node_modules/undici-types/env-http-proxy-agent.d.ts +21 -0
  1233. package/daemon/node_modules/undici-types/errors.d.ts +149 -0
  1234. package/daemon/node_modules/undici-types/eventsource.d.ts +61 -0
  1235. package/daemon/node_modules/undici-types/fetch.d.ts +209 -0
  1236. package/daemon/node_modules/undici-types/file.d.ts +39 -0
  1237. package/daemon/node_modules/undici-types/filereader.d.ts +54 -0
  1238. package/daemon/node_modules/undici-types/formdata.d.ts +108 -0
  1239. package/daemon/node_modules/undici-types/global-dispatcher.d.ts +9 -0
  1240. package/daemon/node_modules/undici-types/global-origin.d.ts +7 -0
  1241. package/daemon/node_modules/undici-types/handlers.d.ts +15 -0
  1242. package/daemon/node_modules/undici-types/header.d.ts +4 -0
  1243. package/daemon/node_modules/undici-types/index.d.ts +71 -0
  1244. package/daemon/node_modules/undici-types/interceptors.d.ts +17 -0
  1245. package/daemon/node_modules/undici-types/mock-agent.d.ts +50 -0
  1246. package/daemon/node_modules/undici-types/mock-client.d.ts +25 -0
  1247. package/daemon/node_modules/undici-types/mock-errors.d.ts +12 -0
  1248. package/daemon/node_modules/undici-types/mock-interceptor.d.ts +93 -0
  1249. package/daemon/node_modules/undici-types/mock-pool.d.ts +25 -0
  1250. package/daemon/node_modules/undici-types/package.json +55 -0
  1251. package/daemon/node_modules/undici-types/patch.d.ts +33 -0
  1252. package/daemon/node_modules/undici-types/pool-stats.d.ts +19 -0
  1253. package/daemon/node_modules/undici-types/pool.d.ts +39 -0
  1254. package/daemon/node_modules/undici-types/proxy-agent.d.ts +28 -0
  1255. package/daemon/node_modules/undici-types/readable.d.ts +65 -0
  1256. package/daemon/node_modules/undici-types/retry-agent.d.ts +8 -0
  1257. package/daemon/node_modules/undici-types/retry-handler.d.ts +116 -0
  1258. package/daemon/node_modules/undici-types/util.d.ts +18 -0
  1259. package/daemon/node_modules/undici-types/webidl.d.ts +228 -0
  1260. package/daemon/node_modules/undici-types/websocket.d.ts +150 -0
  1261. package/package.json +1 -1
@@ -0,0 +1,137 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ const utils_1 = require("@typescript-eslint/utils");
27
+ const ts = __importStar(require("typescript"));
28
+ const util_1 = require("../util");
29
+ exports.default = (0, util_1.createRule)({
30
+ name: 'prefer-return-this-type',
31
+ defaultOptions: [],
32
+ meta: {
33
+ type: 'suggestion',
34
+ docs: {
35
+ description: 'Enforce that `this` is used when only `this` type is returned',
36
+ recommended: 'strict',
37
+ requiresTypeChecking: true,
38
+ },
39
+ messages: {
40
+ useThisType: 'Use `this` type instead.',
41
+ },
42
+ schema: [],
43
+ fixable: 'code',
44
+ },
45
+ create(context) {
46
+ const services = (0, util_1.getParserServices)(context);
47
+ const checker = services.program.getTypeChecker();
48
+ function tryGetNameInType(name, typeNode) {
49
+ if (typeNode.type === utils_1.AST_NODE_TYPES.TSTypeReference &&
50
+ typeNode.typeName.type === utils_1.AST_NODE_TYPES.Identifier &&
51
+ typeNode.typeName.name === name) {
52
+ return typeNode;
53
+ }
54
+ if (typeNode.type === utils_1.AST_NODE_TYPES.TSUnionType) {
55
+ for (const type of typeNode.types) {
56
+ const found = tryGetNameInType(name, type);
57
+ if (found) {
58
+ return found;
59
+ }
60
+ }
61
+ }
62
+ return undefined;
63
+ }
64
+ function isThisSpecifiedInParameters(originalFunc) {
65
+ const firstArg = originalFunc.params.at(0);
66
+ return !!(firstArg?.type === utils_1.AST_NODE_TYPES.Identifier && firstArg.name === 'this');
67
+ }
68
+ function isFunctionReturningThis(originalFunc, originalClass) {
69
+ if (isThisSpecifiedInParameters(originalFunc)) {
70
+ return false;
71
+ }
72
+ const func = services.esTreeNodeToTSNodeMap.get(originalFunc);
73
+ if (!func.body) {
74
+ return false;
75
+ }
76
+ const classType = services.getTypeAtLocation(originalClass);
77
+ if (func.body.kind !== ts.SyntaxKind.Block) {
78
+ const type = checker.getTypeAtLocation(func.body);
79
+ return classType.thisType === type;
80
+ }
81
+ let hasReturnThis = false;
82
+ let hasReturnClassType = false;
83
+ (0, util_1.forEachReturnStatement)(func.body, stmt => {
84
+ const expr = stmt.expression;
85
+ if (!expr) {
86
+ return;
87
+ }
88
+ // fast check
89
+ if (expr.kind === ts.SyntaxKind.ThisKeyword) {
90
+ hasReturnThis = true;
91
+ return;
92
+ }
93
+ const type = checker.getTypeAtLocation(expr);
94
+ if (classType === type) {
95
+ hasReturnClassType = true;
96
+ return true;
97
+ }
98
+ if (classType.thisType === type) {
99
+ hasReturnThis = true;
100
+ return;
101
+ }
102
+ return;
103
+ });
104
+ return !hasReturnClassType && hasReturnThis;
105
+ }
106
+ function checkFunction(originalFunc, originalClass) {
107
+ const className = originalClass.id?.name;
108
+ if (!className || !originalFunc.returnType) {
109
+ return;
110
+ }
111
+ const node = tryGetNameInType(className, originalFunc.returnType.typeAnnotation);
112
+ if (!node) {
113
+ return;
114
+ }
115
+ if (isFunctionReturningThis(originalFunc, originalClass)) {
116
+ context.report({
117
+ node,
118
+ messageId: 'useThisType',
119
+ fix: fixer => fixer.replaceText(node, 'this'),
120
+ });
121
+ }
122
+ }
123
+ return {
124
+ 'ClassBody > MethodDefinition'(node) {
125
+ checkFunction(node.value, node.parent.parent);
126
+ },
127
+ 'ClassBody > PropertyDefinition'(node) {
128
+ if (!(node.value?.type === utils_1.AST_NODE_TYPES.FunctionExpression ||
129
+ node.value?.type === utils_1.AST_NODE_TYPES.ArrowFunctionExpression)) {
130
+ return;
131
+ }
132
+ checkFunction(node.value, node.parent.parent);
133
+ },
134
+ };
135
+ },
136
+ });
137
+ //# sourceMappingURL=prefer-return-this-type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prefer-return-this-type.js","sourceRoot":"","sources":["../../src/rules/prefer-return-this-type.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AACA,oDAA0D;AAC1D,+CAAiC;AAEjC,kCAAgF;AAUhF,kBAAe,IAAA,iBAAU,EAAC;IACxB,IAAI,EAAE,yBAAyB;IAC/B,cAAc,EAAE,EAAE;IAElB,IAAI,EAAE;QACJ,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE;YACJ,WAAW,EACT,+DAA+D;YACjE,WAAW,EAAE,QAAQ;YACrB,oBAAoB,EAAE,IAAI;SAC3B;QACD,QAAQ,EAAE;YACR,WAAW,EAAE,0BAA0B;SACxC;QACD,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,MAAM;KAChB;IAED,MAAM,CAAC,OAAO;QACZ,MAAM,QAAQ,GAAG,IAAA,wBAAiB,EAAC,OAAO,CAAC,CAAC;QAC5C,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;QAElD,SAAS,gBAAgB,CACvB,IAAY,EACZ,QAA2B;YAE3B,IACE,QAAQ,CAAC,IAAI,KAAK,sBAAc,CAAC,eAAe;gBAChD,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,sBAAc,CAAC,UAAU;gBACpD,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,IAAI,EAC/B,CAAC;gBACD,OAAO,QAAQ,CAAC;YAClB,CAAC;YAED,IAAI,QAAQ,CAAC,IAAI,KAAK,sBAAc,CAAC,WAAW,EAAE,CAAC;gBACjD,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;oBAClC,MAAM,KAAK,GAAG,gBAAgB,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;oBAC3C,IAAI,KAAK,EAAE,CAAC;wBACV,OAAO,KAAK,CAAC;oBACf,CAAC;gBACH,CAAC;YACH,CAAC;YAED,OAAO,SAAS,CAAC;QACnB,CAAC;QAED,SAAS,2BAA2B,CAAC,YAA0B;YAC7D,MAAM,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC3C,OAAO,CAAC,CAAC,CACP,QAAQ,EAAE,IAAI,KAAK,sBAAc,CAAC,UAAU,IAAI,QAAQ,CAAC,IAAI,KAAK,MAAM,CACzE,CAAC;QACJ,CAAC;QAED,SAAS,uBAAuB,CAC9B,YAA0B,EAC1B,aAAmC;YAEnC,IAAI,2BAA2B,CAAC,YAAY,CAAC,EAAE,CAAC;gBAC9C,OAAO,KAAK,CAAC;YACf,CAAC;YAED,MAAM,IAAI,GAAG,QAAQ,CAAC,qBAAqB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;YAE9D,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;gBACf,OAAO,KAAK,CAAC;YACf,CAAC;YAED,MAAM,SAAS,GAAG,QAAQ,CAAC,iBAAiB,CAC1C,aAAa,CACM,CAAC;YAEtB,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,KAAK,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;gBAC3C,MAAM,IAAI,GAAG,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAClD,OAAO,SAAS,CAAC,QAAQ,KAAK,IAAI,CAAC;YACrC,CAAC;YAED,IAAI,aAAa,GAAG,KAAK,CAAC;YAC1B,IAAI,kBAAkB,GAAG,KAAgB,CAAC;YAE1C,IAAA,6BAAsB,EAAC,IAAI,CAAC,IAAgB,EAAE,IAAI,CAAC,EAAE;gBACnD,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC;gBAC7B,IAAI,CAAC,IAAI,EAAE,CAAC;oBACV,OAAO;gBACT,CAAC;gBAED,aAAa;gBACb,IAAI,IAAI,CAAC,IAAI,KAAK,EAAE,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;oBAC5C,aAAa,GAAG,IAAI,CAAC;oBACrB,OAAO;gBACT,CAAC;gBAED,MAAM,IAAI,GAAG,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC7C,IAAI,SAAS,KAAK,IAAI,EAAE,CAAC;oBACvB,kBAAkB,GAAG,IAAI,CAAC;oBAC1B,OAAO,IAAI,CAAC;gBACd,CAAC;gBAED,IAAI,SAAS,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;oBAChC,aAAa,GAAG,IAAI,CAAC;oBACrB,OAAO;gBACT,CAAC;gBAED,OAAO;YACT,CAAC,CAAC,CAAC;YAEH,OAAO,CAAC,kBAAkB,IAAI,aAAa,CAAC;QAC9C,CAAC;QAED,SAAS,aAAa,CACpB,YAA0B,EAC1B,aAAmC;YAEnC,MAAM,SAAS,GAAG,aAAa,CAAC,EAAE,EAAE,IAAI,CAAC;YACzC,IAAI,CAAC,SAAS,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;gBAC3C,OAAO;YACT,CAAC;YAED,MAAM,IAAI,GAAG,gBAAgB,CAC3B,SAAS,EACT,YAAY,CAAC,UAAU,CAAC,cAAc,CACvC,CAAC;YACF,IAAI,CAAC,IAAI,EAAE,CAAC;gBACV,OAAO;YACT,CAAC;YAED,IAAI,uBAAuB,CAAC,YAAY,EAAE,aAAa,CAAC,EAAE,CAAC;gBACzD,OAAO,CAAC,MAAM,CAAC;oBACb,IAAI;oBACJ,SAAS,EAAE,aAAa;oBACxB,GAAG,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,EAAE,MAAM,CAAC;iBAC9C,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAED,OAAO;YACL,8BAA8B,CAAC,IAA+B;gBAC5D,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,MAA8B,CAAC,CAAC;YACxE,CAAC;YACD,gCAAgC,CAC9B,IAAiC;gBAEjC,IACE,CAAC,CACC,IAAI,CAAC,KAAK,EAAE,IAAI,KAAK,sBAAc,CAAC,kBAAkB;oBACtD,IAAI,CAAC,KAAK,EAAE,IAAI,KAAK,sBAAc,CAAC,uBAAuB,CAC5D,EACD,CAAC;oBACD,OAAO;gBACT,CAAC;gBAED,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,MAA8B,CAAC,CAAC;YACxE,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
@@ -0,0 +1,508 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const regexpp_1 = require("@eslint-community/regexpp");
4
+ const utils_1 = require("@typescript-eslint/utils");
5
+ const eslint_utils_1 = require("@typescript-eslint/utils/eslint-utils");
6
+ const util_1 = require("../util");
7
+ const EQ_OPERATORS = /^[=!]=/;
8
+ const regexpp = new regexpp_1.RegExpParser();
9
+ exports.default = (0, util_1.createRule)({
10
+ name: 'prefer-string-starts-ends-with',
11
+ defaultOptions: [],
12
+ meta: {
13
+ type: 'suggestion',
14
+ docs: {
15
+ description: 'Enforce using `String#startsWith` and `String#endsWith` over other equivalent methods of checking substrings',
16
+ recommended: 'stylistic',
17
+ requiresTypeChecking: true,
18
+ },
19
+ messages: {
20
+ preferStartsWith: "Use 'String#startsWith' method instead.",
21
+ preferEndsWith: "Use the 'String#endsWith' method instead.",
22
+ },
23
+ schema: [],
24
+ fixable: 'code',
25
+ },
26
+ create(context) {
27
+ const globalScope = (0, eslint_utils_1.getScope)(context);
28
+ const sourceCode = (0, eslint_utils_1.getSourceCode)(context);
29
+ const services = (0, util_1.getParserServices)(context);
30
+ const checker = services.program.getTypeChecker();
31
+ /**
32
+ * Check if a given node is a string.
33
+ * @param node The node to check.
34
+ */
35
+ function isStringType(node) {
36
+ const objectType = services.getTypeAtLocation(node);
37
+ return (0, util_1.getTypeName)(checker, objectType) === 'string';
38
+ }
39
+ /**
40
+ * Check if a given node is a `Literal` node that is null.
41
+ * @param node The node to check.
42
+ */
43
+ function isNull(node) {
44
+ const evaluated = (0, util_1.getStaticValue)(node, globalScope);
45
+ return evaluated != null && evaluated.value == null;
46
+ }
47
+ /**
48
+ * Check if a given node is a `Literal` node that is a given value.
49
+ * @param node The node to check.
50
+ * @param value The expected value of the `Literal` node.
51
+ */
52
+ function isNumber(node, value) {
53
+ const evaluated = (0, util_1.getStaticValue)(node, globalScope);
54
+ return evaluated != null && evaluated.value === value;
55
+ }
56
+ /**
57
+ * Check if a given node is a `Literal` node that is a character.
58
+ * @param node The node to check.
59
+ */
60
+ function isCharacter(node) {
61
+ const evaluated = (0, util_1.getStaticValue)(node, globalScope);
62
+ return (evaluated != null &&
63
+ typeof evaluated.value === 'string' &&
64
+ // checks if the string is a character long
65
+ evaluated.value[0] === evaluated.value);
66
+ }
67
+ /**
68
+ * Check if a given node is `==`, `===`, `!=`, or `!==`.
69
+ * @param node The node to check.
70
+ */
71
+ function isEqualityComparison(node) {
72
+ return (node.type === utils_1.AST_NODE_TYPES.BinaryExpression &&
73
+ EQ_OPERATORS.test(node.operator));
74
+ }
75
+ /**
76
+ * Check if two given nodes are the same meaning.
77
+ * @param node1 A node to compare.
78
+ * @param node2 Another node to compare.
79
+ */
80
+ function isSameTokens(node1, node2) {
81
+ const tokens1 = sourceCode.getTokens(node1);
82
+ const tokens2 = sourceCode.getTokens(node2);
83
+ if (tokens1.length !== tokens2.length) {
84
+ return false;
85
+ }
86
+ for (let i = 0; i < tokens1.length; ++i) {
87
+ const token1 = tokens1[i];
88
+ const token2 = tokens2[i];
89
+ if (token1.type !== token2.type || token1.value !== token2.value) {
90
+ return false;
91
+ }
92
+ }
93
+ return true;
94
+ }
95
+ /**
96
+ * Check if a given node is the expression of the length of a string.
97
+ *
98
+ * - If `length` property access of `expectedObjectNode`, it's `true`.
99
+ * E.g., `foo` → `foo.length` / `"foo"` → `"foo".length`
100
+ * - If `expectedObjectNode` is a string literal, `node` can be a number.
101
+ * E.g., `"foo"` → `3`
102
+ *
103
+ * @param node The node to check.
104
+ * @param expectedObjectNode The node which is expected as the receiver of `length` property.
105
+ */
106
+ function isLengthExpression(node, expectedObjectNode) {
107
+ if (node.type === utils_1.AST_NODE_TYPES.MemberExpression) {
108
+ return ((0, util_1.getPropertyName)(node, globalScope) === 'length' &&
109
+ isSameTokens(node.object, expectedObjectNode));
110
+ }
111
+ const evaluatedLength = (0, util_1.getStaticValue)(node, globalScope);
112
+ const evaluatedString = (0, util_1.getStaticValue)(expectedObjectNode, globalScope);
113
+ return (evaluatedLength != null &&
114
+ evaluatedString != null &&
115
+ typeof evaluatedLength.value === 'number' &&
116
+ typeof evaluatedString.value === 'string' &&
117
+ evaluatedLength.value === evaluatedString.value.length);
118
+ }
119
+ /**
120
+ * Returns true if `node` is `-substring.length` or
121
+ * `parentString.length - substring.length`
122
+ */
123
+ function isLengthAheadOfEnd(node, substring, parentString) {
124
+ return ((node.type === utils_1.AST_NODE_TYPES.UnaryExpression &&
125
+ node.operator === '-' &&
126
+ isLengthExpression(node.argument, substring)) ||
127
+ (node.type === utils_1.AST_NODE_TYPES.BinaryExpression &&
128
+ node.operator === '-' &&
129
+ isLengthExpression(node.left, parentString) &&
130
+ isLengthExpression(node.right, substring)));
131
+ }
132
+ /**
133
+ * Check if a given node is the expression of the last index.
134
+ *
135
+ * E.g. `foo.length - 1`
136
+ *
137
+ * @param node The node to check.
138
+ * @param expectedObjectNode The node which is expected as the receiver of `length` property.
139
+ */
140
+ function isLastIndexExpression(node, expectedObjectNode) {
141
+ return (node.type === utils_1.AST_NODE_TYPES.BinaryExpression &&
142
+ node.operator === '-' &&
143
+ isLengthExpression(node.left, expectedObjectNode) &&
144
+ isNumber(node.right, 1));
145
+ }
146
+ /**
147
+ * Get the range of the property of a given `MemberExpression` node.
148
+ *
149
+ * - `obj[foo]` → the range of `[foo]`
150
+ * - `obf.foo` → the range of `.foo`
151
+ * - `(obj).foo` → the range of `.foo`
152
+ *
153
+ * @param node The member expression node to get.
154
+ */
155
+ function getPropertyRange(node) {
156
+ const dotOrOpenBracket = sourceCode.getTokenAfter(node.object, util_1.isNotClosingParenToken);
157
+ return [dotOrOpenBracket.range[0], node.range[1]];
158
+ }
159
+ /**
160
+ * Parse a given `RegExp` pattern to that string if it's a static string.
161
+ * @param pattern The RegExp pattern text to parse.
162
+ * @param unicode Whether the RegExp is unicode.
163
+ */
164
+ function parseRegExpText(pattern, unicode) {
165
+ // Parse it.
166
+ const ast = regexpp.parsePattern(pattern, undefined, undefined, {
167
+ unicode,
168
+ });
169
+ if (ast.alternatives.length !== 1) {
170
+ return null;
171
+ }
172
+ // Drop `^`/`$` assertion.
173
+ const chars = ast.alternatives[0].elements;
174
+ const first = chars[0];
175
+ if (first.type === 'Assertion' && first.kind === 'start') {
176
+ chars.shift();
177
+ }
178
+ else {
179
+ chars.pop();
180
+ }
181
+ // Check if it can determine a unique string.
182
+ if (!chars.every(c => c.type === 'Character')) {
183
+ return null;
184
+ }
185
+ // To string.
186
+ return String.fromCodePoint(...chars.map(c => c.value));
187
+ }
188
+ /**
189
+ * Parse a given node if it's a `RegExp` instance.
190
+ * @param node The node to parse.
191
+ */
192
+ function parseRegExp(node) {
193
+ const evaluated = (0, util_1.getStaticValue)(node, globalScope);
194
+ if (evaluated == null || !(evaluated.value instanceof RegExp)) {
195
+ return null;
196
+ }
197
+ const { source, flags } = evaluated.value;
198
+ const isStartsWith = source.startsWith('^');
199
+ const isEndsWith = source.endsWith('$');
200
+ if (isStartsWith === isEndsWith ||
201
+ flags.includes('i') ||
202
+ flags.includes('m')) {
203
+ return null;
204
+ }
205
+ const text = parseRegExpText(source, flags.includes('u'));
206
+ if (text == null) {
207
+ return null;
208
+ }
209
+ return { isEndsWith, isStartsWith, text };
210
+ }
211
+ function getLeftNode(node) {
212
+ if (node.type === utils_1.AST_NODE_TYPES.ChainExpression) {
213
+ return getLeftNode(node.expression);
214
+ }
215
+ let leftNode;
216
+ if (node.type === utils_1.AST_NODE_TYPES.CallExpression) {
217
+ leftNode = node.callee;
218
+ }
219
+ else {
220
+ leftNode = node;
221
+ }
222
+ if (leftNode.type !== utils_1.AST_NODE_TYPES.MemberExpression) {
223
+ throw new Error(`Expected a MemberExpression, got ${leftNode.type}`);
224
+ }
225
+ return leftNode;
226
+ }
227
+ /**
228
+ * Fix code with using the right operand as the search string.
229
+ * For example: `foo.slice(0, 3) === 'bar'` → `foo.startsWith('bar')`
230
+ * @param fixer The rule fixer.
231
+ * @param node The node which was reported.
232
+ * @param kind The kind of the report.
233
+ * @param isNegative The flag to fix to negative condition.
234
+ */
235
+ function* fixWithRightOperand(fixer, node, kind, isNegative, isOptional) {
236
+ // left is CallExpression or MemberExpression.
237
+ const leftNode = getLeftNode(node.left);
238
+ const propertyRange = getPropertyRange(leftNode);
239
+ if (isNegative) {
240
+ yield fixer.insertTextBefore(node, '!');
241
+ }
242
+ yield fixer.replaceTextRange([propertyRange[0], node.right.range[0]], `${isOptional ? '?.' : '.'}${kind}sWith(`);
243
+ yield fixer.replaceTextRange([node.right.range[1], node.range[1]], ')');
244
+ }
245
+ /**
246
+ * Fix code with using the first argument as the search string.
247
+ * For example: `foo.indexOf('bar') === 0` → `foo.startsWith('bar')`
248
+ * @param fixer The rule fixer.
249
+ * @param node The node which was reported.
250
+ * @param kind The kind of the report.
251
+ * @param negative The flag to fix to negative condition.
252
+ */
253
+ function* fixWithArgument(fixer, node, callNode, calleeNode, kind, negative, isOptional) {
254
+ if (negative) {
255
+ yield fixer.insertTextBefore(node, '!');
256
+ }
257
+ yield fixer.replaceTextRange(getPropertyRange(calleeNode), `${isOptional ? '?.' : '.'}${kind}sWith`);
258
+ yield fixer.removeRange([callNode.range[1], node.range[1]]);
259
+ }
260
+ function getParent(node) {
261
+ return (0, util_1.nullThrows)(node.parent?.type === utils_1.AST_NODE_TYPES.ChainExpression
262
+ ? node.parent.parent
263
+ : node.parent, util_1.NullThrowsReasons.MissingParent);
264
+ }
265
+ return {
266
+ // foo[0] === "a"
267
+ // foo.charAt(0) === "a"
268
+ // foo[foo.length - 1] === "a"
269
+ // foo.charAt(foo.length - 1) === "a"
270
+ [[
271
+ 'BinaryExpression > MemberExpression.left[computed=true]',
272
+ 'BinaryExpression > CallExpression.left > MemberExpression.callee[property.name="charAt"][computed=false]',
273
+ 'BinaryExpression > ChainExpression.left > MemberExpression[computed=true]',
274
+ 'BinaryExpression > ChainExpression.left > CallExpression > MemberExpression.callee[property.name="charAt"][computed=false]',
275
+ ].join(', ')](node) {
276
+ let parentNode = getParent(node);
277
+ let indexNode = null;
278
+ if (parentNode.type === utils_1.AST_NODE_TYPES.CallExpression) {
279
+ if (parentNode.arguments.length === 1) {
280
+ indexNode = parentNode.arguments[0];
281
+ }
282
+ parentNode = getParent(parentNode);
283
+ }
284
+ else {
285
+ indexNode = node.property;
286
+ }
287
+ if (indexNode == null ||
288
+ !isEqualityComparison(parentNode) ||
289
+ !isStringType(node.object)) {
290
+ return;
291
+ }
292
+ const isEndsWith = isLastIndexExpression(indexNode, node.object);
293
+ const isStartsWith = !isEndsWith && isNumber(indexNode, 0);
294
+ if (!isStartsWith && !isEndsWith) {
295
+ return;
296
+ }
297
+ const eqNode = parentNode;
298
+ context.report({
299
+ node: parentNode,
300
+ messageId: isStartsWith ? 'preferStartsWith' : 'preferEndsWith',
301
+ fix(fixer) {
302
+ // Don't fix if it can change the behavior.
303
+ if (!isCharacter(eqNode.right)) {
304
+ return null;
305
+ }
306
+ return fixWithRightOperand(fixer, eqNode, isStartsWith ? 'start' : 'end', eqNode.operator.startsWith('!'), node.optional);
307
+ },
308
+ });
309
+ },
310
+ // foo.indexOf('bar') === 0
311
+ [[
312
+ 'BinaryExpression > CallExpression.left > MemberExpression.callee[property.name="indexOf"][computed=false]',
313
+ 'BinaryExpression > ChainExpression.left > CallExpression > MemberExpression.callee[property.name="indexOf"][computed=false]',
314
+ ].join(', ')](node) {
315
+ const callNode = getParent(node);
316
+ const parentNode = getParent(callNode);
317
+ if (callNode.arguments.length !== 1 ||
318
+ !isEqualityComparison(parentNode) ||
319
+ !isNumber(parentNode.right, 0) ||
320
+ !isStringType(node.object)) {
321
+ return;
322
+ }
323
+ context.report({
324
+ node: parentNode,
325
+ messageId: 'preferStartsWith',
326
+ fix(fixer) {
327
+ return fixWithArgument(fixer, parentNode, callNode, node, 'start', parentNode.operator.startsWith('!'), node.optional);
328
+ },
329
+ });
330
+ },
331
+ // foo.lastIndexOf('bar') === foo.length - 3
332
+ // foo.lastIndexOf(bar) === foo.length - bar.length
333
+ [[
334
+ 'BinaryExpression > CallExpression.left > MemberExpression.callee[property.name="lastIndexOf"][computed=false]',
335
+ 'BinaryExpression > ChainExpression.left > CallExpression > MemberExpression.callee[property.name="lastIndexOf"][computed=false]',
336
+ ].join(', ')](node) {
337
+ const callNode = getParent(node);
338
+ const parentNode = getParent(callNode);
339
+ if (callNode.arguments.length !== 1 ||
340
+ !isEqualityComparison(parentNode) ||
341
+ parentNode.right.type !== utils_1.AST_NODE_TYPES.BinaryExpression ||
342
+ parentNode.right.operator !== '-' ||
343
+ !isLengthExpression(parentNode.right.left, node.object) ||
344
+ !isLengthExpression(parentNode.right.right, callNode.arguments[0]) ||
345
+ !isStringType(node.object)) {
346
+ return;
347
+ }
348
+ context.report({
349
+ node: parentNode,
350
+ messageId: 'preferEndsWith',
351
+ fix(fixer) {
352
+ return fixWithArgument(fixer, parentNode, callNode, node, 'end', parentNode.operator.startsWith('!'), node.optional);
353
+ },
354
+ });
355
+ },
356
+ // foo.match(/^bar/) === null
357
+ // foo.match(/bar$/) === null
358
+ [[
359
+ 'BinaryExpression > CallExpression.left > MemberExpression.callee[property.name="match"][computed=false]',
360
+ 'BinaryExpression > ChainExpression.left > CallExpression > MemberExpression.callee[property.name="match"][computed=false]',
361
+ ].join(', ')](node) {
362
+ const callNode = getParent(node);
363
+ const parentNode = getParent(callNode);
364
+ if (!isEqualityComparison(parentNode) ||
365
+ !isNull(parentNode.right) ||
366
+ !isStringType(node.object)) {
367
+ return;
368
+ }
369
+ const parsed = callNode.arguments.length === 1
370
+ ? parseRegExp(callNode.arguments[0])
371
+ : null;
372
+ if (parsed == null) {
373
+ return;
374
+ }
375
+ const { isStartsWith, text } = parsed;
376
+ context.report({
377
+ node: callNode,
378
+ messageId: isStartsWith ? 'preferStartsWith' : 'preferEndsWith',
379
+ *fix(fixer) {
380
+ if (!parentNode.operator.startsWith('!')) {
381
+ yield fixer.insertTextBefore(parentNode, '!');
382
+ }
383
+ yield fixer.replaceTextRange(getPropertyRange(node), `${node.optional ? '?.' : '.'}${isStartsWith ? 'start' : 'end'}sWith`);
384
+ yield fixer.replaceText(callNode.arguments[0], JSON.stringify(text));
385
+ yield fixer.removeRange([callNode.range[1], parentNode.range[1]]);
386
+ },
387
+ });
388
+ },
389
+ // foo.slice(0, 3) === 'bar'
390
+ // foo.slice(-3) === 'bar'
391
+ // foo.slice(-3, foo.length) === 'bar'
392
+ // foo.substring(0, 3) === 'bar'
393
+ // foo.substring(foo.length - 3) === 'bar'
394
+ // foo.substring(foo.length - 3, foo.length) === 'bar'
395
+ [[
396
+ 'BinaryExpression > CallExpression.left > MemberExpression.callee[property.name="slice"][computed=false]',
397
+ 'BinaryExpression > CallExpression.left > MemberExpression.callee[property.name="substring"][computed=false]',
398
+ 'BinaryExpression > ChainExpression.left > CallExpression > MemberExpression.callee[property.name="slice"][computed=false]',
399
+ 'BinaryExpression > ChainExpression.left > CallExpression > MemberExpression.callee[property.name="substring"][computed=false]',
400
+ ].join(', ')](node) {
401
+ const callNode = getParent(node);
402
+ const parentNode = getParent(callNode);
403
+ if (!isEqualityComparison(parentNode) || !isStringType(node.object)) {
404
+ return;
405
+ }
406
+ let isEndsWith = false;
407
+ let isStartsWith = false;
408
+ if (callNode.arguments.length === 1) {
409
+ if (
410
+ // foo.slice(-bar.length) === bar
411
+ // foo.slice(foo.length - bar.length) === bar
412
+ isLengthAheadOfEnd(callNode.arguments[0], parentNode.right, node.object)) {
413
+ isEndsWith = true;
414
+ }
415
+ }
416
+ else if (callNode.arguments.length === 2) {
417
+ if (
418
+ // foo.slice(0, bar.length) === bar
419
+ isNumber(callNode.arguments[0], 0) &&
420
+ isLengthExpression(callNode.arguments[1], parentNode.right)) {
421
+ isStartsWith = true;
422
+ }
423
+ else if (
424
+ // foo.slice(foo.length - bar.length, foo.length) === bar
425
+ // foo.slice(foo.length - bar.length, 0) === bar
426
+ // foo.slice(-bar.length, foo.length) === bar
427
+ // foo.slice(-bar.length, 0) === bar
428
+ (isLengthExpression(callNode.arguments[1], node.object) ||
429
+ isNumber(callNode.arguments[1], 0)) &&
430
+ isLengthAheadOfEnd(callNode.arguments[0], parentNode.right, node.object)) {
431
+ isEndsWith = true;
432
+ }
433
+ }
434
+ if (!isStartsWith && !isEndsWith) {
435
+ return;
436
+ }
437
+ const eqNode = parentNode;
438
+ const negativeIndexSupported = node.property.name === 'slice';
439
+ context.report({
440
+ node: parentNode,
441
+ messageId: isStartsWith ? 'preferStartsWith' : 'preferEndsWith',
442
+ fix(fixer) {
443
+ // Don't fix if it can change the behavior.
444
+ if (eqNode.operator.length === 2 &&
445
+ (eqNode.right.type !== utils_1.AST_NODE_TYPES.Literal ||
446
+ typeof eqNode.right.value !== 'string')) {
447
+ return null;
448
+ }
449
+ // code being checked is likely mistake:
450
+ // unequal length of strings being checked for equality
451
+ // or reliant on behavior of substring (negative indices interpreted as 0)
452
+ if (isStartsWith) {
453
+ if (!isLengthExpression(callNode.arguments[1], eqNode.right)) {
454
+ return null;
455
+ }
456
+ }
457
+ else {
458
+ const posNode = callNode.arguments[0];
459
+ const posNodeIsAbsolutelyValid = (posNode.type === utils_1.AST_NODE_TYPES.BinaryExpression &&
460
+ posNode.operator === '-' &&
461
+ isLengthExpression(posNode.left, node.object) &&
462
+ isLengthExpression(posNode.right, eqNode.right)) ||
463
+ (negativeIndexSupported &&
464
+ posNode.type === utils_1.AST_NODE_TYPES.UnaryExpression &&
465
+ posNode.operator === '-' &&
466
+ isLengthExpression(posNode.argument, eqNode.right));
467
+ if (!posNodeIsAbsolutelyValid) {
468
+ return null;
469
+ }
470
+ }
471
+ return fixWithRightOperand(fixer, parentNode, isStartsWith ? 'start' : 'end', parentNode.operator.startsWith('!'), node.optional);
472
+ },
473
+ });
474
+ },
475
+ // /^bar/.test(foo)
476
+ // /bar$/.test(foo)
477
+ 'CallExpression > MemberExpression.callee[property.name="test"][computed=false]'(node) {
478
+ const callNode = getParent(node);
479
+ const parsed = callNode.arguments.length === 1 ? parseRegExp(node.object) : null;
480
+ if (parsed == null) {
481
+ return;
482
+ }
483
+ const { isStartsWith, text } = parsed;
484
+ const messageId = isStartsWith ? 'preferStartsWith' : 'preferEndsWith';
485
+ const methodName = isStartsWith ? 'startsWith' : 'endsWith';
486
+ context.report({
487
+ node: callNode,
488
+ messageId,
489
+ *fix(fixer) {
490
+ const argNode = callNode.arguments[0];
491
+ const needsParen = argNode.type !== utils_1.AST_NODE_TYPES.Literal &&
492
+ argNode.type !== utils_1.AST_NODE_TYPES.TemplateLiteral &&
493
+ argNode.type !== utils_1.AST_NODE_TYPES.Identifier &&
494
+ argNode.type !== utils_1.AST_NODE_TYPES.MemberExpression &&
495
+ argNode.type !== utils_1.AST_NODE_TYPES.CallExpression;
496
+ yield fixer.removeRange([callNode.range[0], argNode.range[0]]);
497
+ if (needsParen) {
498
+ yield fixer.insertTextBefore(argNode, '(');
499
+ yield fixer.insertTextAfter(argNode, ')');
500
+ }
501
+ yield fixer.insertTextAfter(argNode, `${node.optional ? '?.' : '.'}${methodName}(${JSON.stringify(text)}`);
502
+ },
503
+ });
504
+ },
505
+ };
506
+ },
507
+ });
508
+ //# sourceMappingURL=prefer-string-starts-ends-with.js.map