@dvukovic/style-guide 0.3.97 → 0.3.99

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 (58) hide show
  1. package/README.md +104 -152
  2. package/package.json +16 -16
  3. package/src/cspell/base.txt +12 -0
  4. package/src/eslint/configs/core.js +42 -30
  5. package/src/eslint/configs/core.test.js +4 -4
  6. package/src/eslint/configs/jest.js +26 -3
  7. package/src/eslint/configs/jest.test.js +3 -3
  8. package/src/eslint/configs/mobx.js +15 -3
  9. package/src/eslint/configs/mobx.test.js +3 -3
  10. package/src/eslint/configs/next.js +15 -3
  11. package/src/eslint/configs/next.test.js +3 -3
  12. package/src/eslint/configs/node.js +16 -4
  13. package/src/eslint/configs/node.test.js +3 -3
  14. package/src/eslint/configs/playwright.js +26 -3
  15. package/src/eslint/configs/playwright.test.js +3 -3
  16. package/src/eslint/configs/react.js +16 -4
  17. package/src/eslint/configs/react.test.js +3 -3
  18. package/src/eslint/configs/storybook.js +15 -3
  19. package/src/eslint/configs/storybook.test.js +3 -3
  20. package/src/eslint/configs/typescript-strict.js +14 -2
  21. package/src/eslint/configs/typescript-strict.test.js +6 -4
  22. package/src/eslint/configs/typescript.js +37 -4
  23. package/src/eslint/configs/typescript.test.js +6 -4
  24. package/src/eslint/configs/vitest.js +26 -3
  25. package/src/eslint/configs/vitest.test.js +3 -3
  26. package/src/eslint/index.js +25 -0
  27. package/src/eslint/plugins/dvukovic.js +15 -0
  28. package/src/eslint/plugins/es-x.js +7 -6
  29. package/src/eslint/plugins/eslint-comments.js +4 -5
  30. package/src/eslint/plugins/eslint.js +9 -3
  31. package/src/eslint/plugins/eslint.test.js +42 -0
  32. package/src/eslint/plugins/import-x.js +4 -5
  33. package/src/eslint/plugins/jest.js +4 -5
  34. package/src/eslint/plugins/mobx.js +4 -5
  35. package/src/eslint/plugins/n.js +4 -5
  36. package/src/eslint/plugins/next.js +4 -5
  37. package/src/eslint/plugins/playwright.js +4 -5
  38. package/src/eslint/plugins/promise.js +4 -5
  39. package/src/eslint/plugins/react-hooks.js +4 -5
  40. package/src/eslint/plugins/react.js +4 -5
  41. package/src/eslint/plugins/rimac.js +4 -5
  42. package/src/eslint/plugins/security-node.js +4 -5
  43. package/src/eslint/plugins/simple-import-sort.js +4 -5
  44. package/src/eslint/plugins/sonarjs.js +261 -37
  45. package/src/eslint/plugins/sort-destructure-keys.js +4 -5
  46. package/src/eslint/plugins/sort-keys-fix.js +4 -5
  47. package/src/eslint/plugins/storybook.js +4 -5
  48. package/src/eslint/plugins/stylistic.js +4 -5
  49. package/src/eslint/plugins/typescript-eslint.js +4 -5
  50. package/src/eslint/plugins/typescript-sort-keys.js +4 -5
  51. package/src/eslint/plugins/unicorn.js +4 -5
  52. package/src/eslint/plugins/unused-imports.js +4 -5
  53. package/src/eslint/plugins/vitest.js +4 -5
  54. package/src/eslint/rules/no-commented-out-code/no-commented-out-code.js +80 -0
  55. package/src/eslint/rules/no-commented-out-code/no-commented-out-code.test.js +89 -0
  56. package/src/eslint/rules/no-commented-out-code/no-commented-out-code.utils.js +119 -0
  57. package/src/eslint/types.js +19 -0
  58. package/src/eslint/plugins/etc.js +0 -3
@@ -1,13 +1,12 @@
1
- import rimac from "@rimac-technology/eslint-plugin"
1
+ import plugin from "@rimac-technology/eslint-plugin"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const rimac = {
4
5
  plugins: {
5
- "@rimac-technology": rimac,
6
+ "@rimac-technology": plugin,
6
7
  },
7
8
  rules: {
8
9
  "@rimac-technology/class-element-sorting": "error",
9
10
  "@rimac-technology/document-todos": ["error", { url: "http" }],
10
11
  },
11
12
  }
12
-
13
- export default plugin
@@ -1,8 +1,9 @@
1
- import securityNode from "eslint-plugin-security-node"
1
+ import plugin from "eslint-plugin-security-node"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const securityNode = {
4
5
  plugins: {
5
- "security-node": securityNode,
6
+ "security-node": plugin,
6
7
  },
7
8
  rules: {
8
9
  "security-node/detect-absence-of-name-option-in-exrpress-session": "error",
@@ -29,5 +30,3 @@ const plugin = {
29
30
  "security-node/non-literal-reg-expr": "error",
30
31
  },
31
32
  }
32
-
33
- export default plugin
@@ -1,13 +1,12 @@
1
- import simpleImportSort from "eslint-plugin-simple-import-sort"
1
+ import plugin from "eslint-plugin-simple-import-sort"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const simpleImportSort = {
4
5
  plugins: {
5
- "simple-import-sort": simpleImportSort,
6
+ "simple-import-sort": plugin,
6
7
  },
7
8
  rules: {
8
9
  "simple-import-sort/exports": "error",
9
10
  "simple-import-sort/imports": "error",
10
11
  },
11
12
  }
12
-
13
- export default plugin
@@ -1,39 +1,263 @@
1
- // sonarjs v3 changed rules significantly - needs manual review
2
- // import sonarjs from "eslint-plugin-sonarjs"
1
+ import plugin from "eslint-plugin-sonarjs"
3
2
 
4
- const plugin = {
5
- // plugins: {
6
- // sonarjs,
7
- // },
8
- // rules: {
9
- // "sonarjs/no-all-duplicated-branches": "error",
10
- // "sonarjs/no-collapsible-if": "error",
11
- // "sonarjs/no-collection-size-mischeck": "error",
12
- // "sonarjs/no-duplicated-branches": "error",
13
- // "sonarjs/no-element-overwrite": "error",
14
- // "sonarjs/no-empty-collection": "error",
15
- // "sonarjs/no-gratuitous-expressions": "error",
16
- // "sonarjs/no-identical-conditions": "error",
17
- // "sonarjs/no-identical-expressions": "error",
18
- // "sonarjs/no-identical-functions": "error",
19
- // "sonarjs/no-ignored-return": "error",
20
- // "sonarjs/no-inverted-boolean-check": "error",
21
- // "sonarjs/no-nested-switch": "error",
22
- // "sonarjs/no-nested-template-literals": "error",
23
- // "sonarjs/no-one-iteration-loop": "error",
24
- // "sonarjs/no-redundant-boolean": "error",
25
- // "sonarjs/no-redundant-jump": "error",
26
- // "sonarjs/no-same-line-conditional": "error",
27
- // "sonarjs/no-small-switch": "error",
28
- // "sonarjs/no-unused-collection": "error",
29
- // "sonarjs/no-use-of-empty-return-value": "error",
30
- // "sonarjs/no-useless-catch": "error",
31
- // "sonarjs/non-existent-operator": "error",
32
- // "sonarjs/prefer-immediate-return": "error",
33
- // "sonarjs/prefer-object-literal": "error",
34
- // "sonarjs/prefer-single-boolean-return": "error",
35
- // "sonarjs/prefer-while": "error",
36
- // },
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const sonarjs = {
5
+ plugins: {
6
+ sonarjs: plugin,
7
+ },
8
+ rules: {
9
+ "sonarjs/anchor-precedence": "error",
10
+ "sonarjs/argument-type": "error",
11
+ "sonarjs/arguments-order": "error",
12
+ "sonarjs/arguments-usage": "error",
13
+ "sonarjs/array-callback-without-return": "error",
14
+ "sonarjs/array-constructor": "error",
15
+ "sonarjs/assertions-in-tests": "error",
16
+ "sonarjs/aws-apigateway-public-api": "error",
17
+ "sonarjs/aws-ec2-rds-dms-public": "error",
18
+ "sonarjs/aws-ec2-unencrypted-ebs-volume": "error",
19
+ "sonarjs/aws-efs-unencrypted": "error",
20
+ "sonarjs/aws-iam-all-privileges": "error",
21
+ "sonarjs/aws-iam-all-resources-accessible": "error",
22
+ "sonarjs/aws-iam-privilege-escalation": "error",
23
+ "sonarjs/aws-iam-public-access": "error",
24
+ "sonarjs/aws-opensearchservice-domain": "error",
25
+ "sonarjs/aws-rds-unencrypted-databases": "error",
26
+ "sonarjs/aws-restricted-ip-admin-access": "error",
27
+ "sonarjs/aws-s3-bucket-granted-access": "error",
28
+ "sonarjs/aws-s3-bucket-insecure-http": "error",
29
+ "sonarjs/aws-s3-bucket-public-access": "error",
30
+ "sonarjs/aws-s3-bucket-server-encryption": "error",
31
+ "sonarjs/aws-s3-bucket-versioning": "error",
32
+ "sonarjs/aws-sagemaker-unencrypted-notebook": "error",
33
+ "sonarjs/aws-sns-unencrypted-topics": "error",
34
+ "sonarjs/aws-sqs-unencrypted-queue": "error",
35
+ "sonarjs/bitwise-operators": "error",
36
+ "sonarjs/block-scoped-var": "error",
37
+ "sonarjs/bool-param-default": "error",
38
+ "sonarjs/call-argument-line": "error",
39
+ "sonarjs/certificate-transparency": "error",
40
+ "sonarjs/chai-determinate-assertion": "error",
41
+ "sonarjs/class-name": "error",
42
+ "sonarjs/class-prototype": "error",
43
+ "sonarjs/code-eval": "error",
44
+ "sonarjs/cognitive-complexity": "error",
45
+ "sonarjs/comma-or-logical-or-case": "error",
46
+ "sonarjs/comment-regex": "error",
47
+ "sonarjs/concise-regex": "error",
48
+ "sonarjs/conditional-indentation": "error",
49
+ "sonarjs/confidential-information-logging": "error",
50
+ "sonarjs/constructor-for-side-effects": "error",
51
+ "sonarjs/content-length": "error",
52
+ "sonarjs/content-security-policy": "error",
53
+ "sonarjs/cookie-no-httponly": "error",
54
+ "sonarjs/cookies": "error",
55
+ "sonarjs/cors": "error",
56
+ "sonarjs/csrf": "error",
57
+ "sonarjs/cyclomatic-complexity": "error",
58
+ "sonarjs/deprecation": "error",
59
+ "sonarjs/destructuring-assignment-syntax": "error",
60
+ "sonarjs/different-types-comparison": "error",
61
+ "sonarjs/disabled-auto-escaping": "error",
62
+ "sonarjs/disabled-resource-integrity": "error",
63
+ "sonarjs/disabled-timeout": "error",
64
+ "sonarjs/dns-prefetching": "error",
65
+ "sonarjs/duplicates-in-character-class": "error",
66
+ "sonarjs/elseif-without-else": "error",
67
+ "sonarjs/empty-string-repetition": "error",
68
+ "sonarjs/encryption": "error",
69
+ "sonarjs/encryption-secure-mode": "error",
70
+ "sonarjs/enforce-trailing-comma": "error",
71
+ "sonarjs/existing-groups": "error",
72
+ "sonarjs/expression-complexity": "error",
73
+ "sonarjs/file-permissions": "error",
74
+ "sonarjs/file-uploads": "error",
75
+ "sonarjs/fixme-tag": "error",
76
+ "sonarjs/for-in": "error",
77
+ "sonarjs/for-loop-increment-sign": "error",
78
+ "sonarjs/frame-ancestors": "error",
79
+ "sonarjs/function-inside-loop": "error",
80
+ "sonarjs/function-return-type": "error",
81
+ "sonarjs/future-reserved-words": "error",
82
+ "sonarjs/generator-without-yield": "error",
83
+ "sonarjs/hashing": "error",
84
+ "sonarjs/hidden-files": "error",
85
+ "sonarjs/in-operator-type-error": "error",
86
+ "sonarjs/inconsistent-function-call": "error",
87
+ "sonarjs/index-of-compare-to-positive-number": "error",
88
+ "sonarjs/insecure-cookie": "error",
89
+ "sonarjs/insecure-jwt-token": "error",
90
+ "sonarjs/inverted-assertion-arguments": "error",
91
+ "sonarjs/jsx-no-leaked-render": "error",
92
+ "sonarjs/label-position": "error",
93
+ "sonarjs/link-with-target-blank": "error",
94
+ "sonarjs/max-lines": "error",
95
+ "sonarjs/max-lines-per-function": "error",
96
+ "sonarjs/max-switch-cases": "error",
97
+ "sonarjs/max-union-size": "error",
98
+ "sonarjs/misplaced-loop-counter": "error",
99
+ "sonarjs/nested-control-flow": "error",
100
+ "sonarjs/new-operator-misuse": "error",
101
+ "sonarjs/no-all-duplicated-branches": "error",
102
+ "sonarjs/no-alphabetical-sort": "error",
103
+ "sonarjs/no-angular-bypass-sanitization": "error",
104
+ "sonarjs/no-array-delete": "error",
105
+ "sonarjs/no-associative-arrays": "error",
106
+ "sonarjs/no-async-constructor": "error",
107
+ "sonarjs/no-built-in-override": "error",
108
+ "sonarjs/no-case-label-in-switch": "error",
109
+ "sonarjs/no-clear-text-protocols": "error",
110
+ "sonarjs/no-code-after-done": "error",
111
+ "sonarjs/no-collapsible-if": "error",
112
+ "sonarjs/no-collection-size-mischeck": "error",
113
+ "sonarjs/no-commented-code": "error",
114
+ "sonarjs/no-control-regex": "error",
115
+ "sonarjs/no-dead-store": "error",
116
+ "sonarjs/no-delete-var": "error",
117
+ "sonarjs/no-duplicate-in-composite": "error",
118
+ "sonarjs/no-duplicated-branches": "error",
119
+ "sonarjs/no-element-overwrite": "error",
120
+ "sonarjs/no-empty-after-reluctant": "error",
121
+ "sonarjs/no-empty-alternatives": "error",
122
+ "sonarjs/no-empty-character-class": "error",
123
+ "sonarjs/no-empty-collection": "error",
124
+ "sonarjs/no-empty-group": "error",
125
+ "sonarjs/no-empty-test-file": "error",
126
+ "sonarjs/no-equals-in-for-termination": "error",
127
+ "sonarjs/no-exclusive-tests": "error",
128
+ "sonarjs/no-extra-arguments": "error",
129
+ "sonarjs/no-fallthrough": "error",
130
+ "sonarjs/no-for-in-iterable": "error",
131
+ "sonarjs/no-function-declaration-in-block": "error",
132
+ "sonarjs/no-global-this": "error",
133
+ "sonarjs/no-globals-shadowing": "error",
134
+ "sonarjs/no-gratuitous-expressions": "error",
135
+ "sonarjs/no-hardcoded-ip": "error",
136
+ "sonarjs/no-hardcoded-secrets": "error",
137
+ "sonarjs/no-hook-setter-in-body": "error",
138
+ "sonarjs/no-identical-conditions": "error",
139
+ "sonarjs/no-identical-expressions": "error",
140
+ "sonarjs/no-identical-functions": "error",
141
+ "sonarjs/no-ignored-exceptions": "error",
142
+ "sonarjs/no-ignored-return": "error",
143
+ "sonarjs/no-implicit-dependencies": "error",
144
+ "sonarjs/no-implicit-global": "error",
145
+ "sonarjs/no-in-misuse": "error",
146
+ "sonarjs/no-incomplete-assertions": "error",
147
+ "sonarjs/no-inconsistent-returns": "error",
148
+ "sonarjs/no-incorrect-string-concat": "error",
149
+ "sonarjs/no-internal-api-use": "error",
150
+ "sonarjs/no-intrusive-permissions": "error",
151
+ "sonarjs/no-invalid-regexp": "error",
152
+ "sonarjs/no-invariant-returns": "error",
153
+ "sonarjs/no-inverted-boolean-check": "error",
154
+ "sonarjs/no-ip-forward": "error",
155
+ "sonarjs/no-labels": "error",
156
+ "sonarjs/no-literal-call": "error",
157
+ "sonarjs/no-mime-sniff": "error",
158
+ "sonarjs/no-misleading-array-reverse": "error",
159
+ "sonarjs/no-misleading-character-class": "error",
160
+ "sonarjs/no-mixed-content": "error",
161
+ "sonarjs/no-nested-assignment": "error",
162
+ "sonarjs/no-nested-conditional": "error",
163
+ "sonarjs/no-nested-functions": "error",
164
+ "sonarjs/no-nested-incdec": "error",
165
+ "sonarjs/no-nested-switch": "error",
166
+ "sonarjs/no-nested-template-literals": "error",
167
+ "sonarjs/no-os-command-from-path": "error",
168
+ "sonarjs/no-parameter-reassignment": "error",
169
+ "sonarjs/no-primitive-wrappers": "error",
170
+ "sonarjs/no-redundant-assignments": "error",
171
+ "sonarjs/no-redundant-boolean": "error",
172
+ "sonarjs/no-redundant-jump": "error",
173
+ "sonarjs/no-redundant-optional": "error",
174
+ "sonarjs/no-redundant-parentheses": "error",
175
+ "sonarjs/no-referrer-policy": "error",
176
+ "sonarjs/no-regex-spaces": "error",
177
+ "sonarjs/no-require-or-define": "error",
178
+ "sonarjs/no-return-type-any": "error",
179
+ "sonarjs/no-same-argument-assert": "error",
180
+ "sonarjs/no-same-line-conditional": "error",
181
+ "sonarjs/no-selector-parameter": "error",
182
+ "sonarjs/no-skipped-tests": "error",
183
+ "sonarjs/no-small-switch": "error",
184
+ "sonarjs/no-sonar-comments": "error",
185
+ "sonarjs/no-tab": "error",
186
+ "sonarjs/no-table-as-layout": "error",
187
+ "sonarjs/no-try-promise": "error",
188
+ "sonarjs/no-undefined-argument": "error",
189
+ "sonarjs/no-unenclosed-multiline-block": "error",
190
+ "sonarjs/no-uniq-key": "error",
191
+ "sonarjs/no-unsafe-unzip": "error",
192
+ "sonarjs/no-unthrown-error": "error",
193
+ "sonarjs/no-unused-collection": "error",
194
+ "sonarjs/no-unused-function-argument": "error",
195
+ "sonarjs/no-unused-vars": "error",
196
+ "sonarjs/no-use-of-empty-return-value": "error",
197
+ "sonarjs/no-useless-catch": "error",
198
+ "sonarjs/no-useless-increment": "error",
199
+ "sonarjs/no-useless-intersection": "error",
200
+ "sonarjs/no-useless-react-setstate": "error",
201
+ "sonarjs/no-variable-usage-before-declaration": "error",
202
+ "sonarjs/no-vue-bypass-sanitization": "error",
203
+ "sonarjs/no-weak-cipher": "error",
204
+ "sonarjs/no-weak-keys": "error",
205
+ "sonarjs/non-existent-operator": "error",
206
+ "sonarjs/non-number-in-arithmetic-expression": "error",
207
+ "sonarjs/null-dereference": "error",
208
+ "sonarjs/object-alt-content": "error",
209
+ "sonarjs/operation-returning-nan": "error",
210
+ "sonarjs/os-command": "error",
211
+ "sonarjs/post-message": "error",
212
+ "sonarjs/prefer-default-last": "error",
213
+ "sonarjs/prefer-immediate-return": "error",
214
+ "sonarjs/prefer-object-literal": "error",
215
+ "sonarjs/prefer-promise-shorthand": "error",
216
+ "sonarjs/prefer-read-only-props": "error",
217
+ "sonarjs/prefer-regexp-exec": "error",
218
+ "sonarjs/prefer-single-boolean-return": "error",
219
+ "sonarjs/prefer-type-guard": "error",
220
+ "sonarjs/prefer-while": "error",
221
+ "sonarjs/process-argv": "error",
222
+ "sonarjs/production-debug": "error",
223
+ "sonarjs/pseudo-random": "error",
224
+ "sonarjs/public-static-readonly": "error",
225
+ "sonarjs/publicly-writable-directories": "error",
226
+ "sonarjs/reduce-initial-value": "error",
227
+ "sonarjs/redundant-type-aliases": "error",
228
+ "sonarjs/regex-complexity": "error",
229
+ "sonarjs/session-regeneration": "error",
230
+ "sonarjs/shorthand-property-grouping": "error",
231
+ "sonarjs/single-char-in-character-classes": "error",
232
+ "sonarjs/single-character-alternation": "error",
233
+ "sonarjs/sockets": "error",
234
+ "sonarjs/sql-queries": "error",
235
+ "sonarjs/stable-tests": "error",
236
+ "sonarjs/standard-input": "error",
237
+ "sonarjs/stateful-regex": "error",
238
+ "sonarjs/strict-transport-security": "error",
239
+ "sonarjs/strings-comparison": "error",
240
+ "sonarjs/super-invocation": "error",
241
+ "sonarjs/table-header": "error",
242
+ "sonarjs/table-header-reference": "error",
243
+ "sonarjs/test-check-exception": "error",
244
+ "sonarjs/todo-tag": "error",
245
+ "sonarjs/unicode-aware-regex": "error",
246
+ "sonarjs/unused-import": "error",
247
+ "sonarjs/unused-named-groups": "error",
248
+ "sonarjs/unverified-certificate": "error",
249
+ "sonarjs/unverified-hostname": "error",
250
+ "sonarjs/updated-const-var": "error",
251
+ "sonarjs/updated-loop-counter": "error",
252
+ "sonarjs/use-type-alias": "error",
253
+ "sonarjs/useless-string-operation": "error",
254
+ "sonarjs/values-not-convertible-to-numbers": "error",
255
+ "sonarjs/variable-name": "error",
256
+ "sonarjs/void-use": "error",
257
+ "sonarjs/weak-ssl": "error",
258
+ "sonarjs/web-sql-database": "error",
259
+ "sonarjs/x-powered-by": "error",
260
+ "sonarjs/xml-parser-xxe": "error",
261
+ "sonarjs/xpath": "error",
262
+ },
37
263
  }
38
-
39
- export default plugin
@@ -1,12 +1,11 @@
1
- import sortDestructureKeys from "eslint-plugin-sort-destructure-keys"
1
+ import plugin from "eslint-plugin-sort-destructure-keys"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const sortDestructureKeys = {
4
5
  plugins: {
5
- "sort-destructure-keys": sortDestructureKeys,
6
+ "sort-destructure-keys": plugin,
6
7
  },
7
8
  rules: {
8
9
  "sort-destructure-keys/sort-destructure-keys": "error",
9
10
  },
10
11
  }
11
-
12
- export default plugin
@@ -1,12 +1,11 @@
1
- import sortKeysFix from "eslint-plugin-sort-keys-fix"
1
+ import plugin from "eslint-plugin-sort-keys-fix"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const sortKeysFix = {
4
5
  plugins: {
5
- "sort-keys-fix": sortKeysFix,
6
+ "sort-keys-fix": plugin,
6
7
  },
7
8
  rules: {
8
9
  "sort-keys-fix/sort-keys-fix": "error",
9
10
  },
10
11
  }
11
-
12
- export default plugin
@@ -1,8 +1,9 @@
1
- import storybook from "eslint-plugin-storybook"
1
+ import plugin from "eslint-plugin-storybook"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const storybook = {
4
5
  plugins: {
5
- storybook,
6
+ storybook: plugin,
6
7
  },
7
8
  rules: {
8
9
  "storybook/await-interactions": "error",
@@ -20,5 +21,3 @@ const plugin = {
20
21
  "storybook/use-storybook-testing-library": "error",
21
22
  },
22
23
  }
23
-
24
- export default plugin
@@ -1,8 +1,9 @@
1
- import stylistic from "@stylistic/eslint-plugin"
1
+ import plugin from "@stylistic/eslint-plugin"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const stylistic = {
4
5
  plugins: {
5
- "@stylistic": stylistic,
6
+ "@stylistic": plugin,
6
7
  },
7
8
  rules: {
8
9
  "@stylistic/lines-between-class-members": ["error", "always"],
@@ -37,5 +38,3 @@ const plugin = {
37
38
  "@stylistic/spaced-comment": ["error", "always", { markers: ["/"] }],
38
39
  },
39
40
  }
40
-
41
- export default plugin
@@ -1,8 +1,9 @@
1
- import typescriptEslint from "typescript-eslint"
1
+ import plugin from "typescript-eslint"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const typescriptEslint = {
4
5
  plugins: {
5
- "@typescript-eslint": typescriptEslint.plugin,
6
+ "@typescript-eslint": plugin.plugin,
6
7
  },
7
8
  rules: {
8
9
  "@typescript-eslint/adjacent-overload-signatures": "error",
@@ -192,5 +193,3 @@ const plugin = {
192
193
  "require-await": "off",
193
194
  },
194
195
  }
195
-
196
- export default plugin
@@ -1,13 +1,12 @@
1
- import typescriptSortKeys from "eslint-plugin-typescript-sort-keys"
1
+ import plugin from "eslint-plugin-typescript-sort-keys"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const typescriptSortKeys = {
4
5
  plugins: {
5
- "typescript-sort-keys": typescriptSortKeys,
6
+ "typescript-sort-keys": plugin,
6
7
  },
7
8
  rules: {
8
9
  "typescript-sort-keys/interface": "error",
9
10
  "typescript-sort-keys/string-enum": "error",
10
11
  },
11
12
  }
12
-
13
- export default plugin
@@ -1,8 +1,9 @@
1
- import unicorn from "eslint-plugin-unicorn"
1
+ import plugin from "eslint-plugin-unicorn"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const unicorn = {
4
5
  plugins: {
5
- unicorn,
6
+ unicorn: plugin,
6
7
  },
7
8
  rules: {
8
9
  "unicorn/better-regex": "error",
@@ -168,5 +169,3 @@ const plugin = {
168
169
  "unicorn/throw-new-error": "error",
169
170
  },
170
171
  }
171
-
172
- export default plugin
@@ -1,12 +1,11 @@
1
- import unusedImports from "eslint-plugin-unused-imports"
1
+ import plugin from "eslint-plugin-unused-imports"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const unusedImports = {
4
5
  plugins: {
5
- "unused-imports": unusedImports,
6
+ "unused-imports": plugin,
6
7
  },
7
8
  rules: {
8
9
  "unused-imports/no-unused-imports": "error",
9
10
  },
10
11
  }
11
-
12
- export default plugin
@@ -1,8 +1,9 @@
1
- import vitest from "@vitest/eslint-plugin"
1
+ import plugin from "@vitest/eslint-plugin"
2
2
 
3
- const plugin = {
3
+ /** @type {import("@eslint/config-helpers").Config} */
4
+ export const vitest = {
4
5
  plugins: {
5
- "@vitest": vitest,
6
+ "@vitest": plugin,
6
7
  },
7
8
  rules: {
8
9
  "@vitest/consistent-each-for": [
@@ -95,5 +96,3 @@ const plugin = {
95
96
  "@vitest/warn-todo": "warn",
96
97
  },
97
98
  }
98
-
99
- export default plugin
@@ -0,0 +1,80 @@
1
+ import tseslint from "typescript-eslint"
2
+
3
+ import {
4
+ hasEmptyBody,
5
+ hasExpressionBody,
6
+ hasLabeledStatementBody,
7
+ isRegionComment,
8
+ toBlocks,
9
+ wrapContent,
10
+ } from "./no-commented-out-code.utils.js"
11
+
12
+ export const noCommentedOutCode = {
13
+ create(context) {
14
+ const sourceCode = context.sourceCode
15
+ const parserOptions = { ...context.parserOptions, project: undefined }
16
+
17
+ function tryParse(content) {
18
+ try {
19
+ const result = tseslint.parser.parseForESLint(content, parserOptions)
20
+
21
+ return result.ast
22
+ } catch {
23
+ return null
24
+ }
25
+ }
26
+
27
+ return {
28
+ Program() {
29
+ const comments = sourceCode.getAllComments()
30
+ const blocks = toBlocks(comments)
31
+
32
+ for (const block of blocks) {
33
+ const { content, loc } = block
34
+
35
+ if (isRegionComment(content)) {
36
+ continue
37
+ }
38
+
39
+ const ast = tryParse(content)
40
+
41
+ if (ast) {
42
+ if (
43
+ !hasEmptyBody(ast) &&
44
+ !hasExpressionBody(ast) &&
45
+ !hasLabeledStatementBody(ast)
46
+ ) {
47
+ context.report({
48
+ loc,
49
+ messageId: "forbidden",
50
+ })
51
+ }
52
+
53
+ continue
54
+ }
55
+
56
+ const index = sourceCode.getIndexFromLoc(loc.start)
57
+ const node = sourceCode.getNodeByRangeIndex(index)
58
+ const wrappedContent = wrapContent(content, node)
59
+
60
+ if (wrappedContent && tryParse(wrappedContent)) {
61
+ context.report({
62
+ loc,
63
+ messageId: "forbidden",
64
+ })
65
+ }
66
+ }
67
+ },
68
+ }
69
+ },
70
+ meta: {
71
+ docs: {
72
+ description: "Forbids commented-out code.",
73
+ },
74
+ messages: {
75
+ forbidden: "Commented-out code is forbidden.",
76
+ },
77
+ schema: [],
78
+ type: "problem",
79
+ },
80
+ }