@fookiejs/eslint-plugin 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +512 -0
- package/dist/index.d.ts +164 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +167 -0
- package/dist/index.js.map +1 -0
- package/dist/rules/consistent-return.d.ts +7 -0
- package/dist/rules/consistent-return.d.ts.map +1 -0
- package/dist/rules/consistent-return.js +56 -0
- package/dist/rules/consistent-return.js.map +1 -0
- package/dist/rules/exhaustive-switch.d.ts +5 -0
- package/dist/rules/exhaustive-switch.d.ts.map +1 -0
- package/dist/rules/exhaustive-switch.js +83 -0
- package/dist/rules/exhaustive-switch.js.map +1 -0
- package/dist/rules/index.d.ts +50 -0
- package/dist/rules/index.d.ts.map +1 -0
- package/dist/rules/index.js +50 -0
- package/dist/rules/index.js.map +1 -0
- package/dist/rules/no-any.d.ts +5 -0
- package/dist/rules/no-any.d.ts.map +1 -0
- package/dist/rules/no-any.js +20 -0
- package/dist/rules/no-any.js.map +1 -0
- package/dist/rules/no-array-mutating-methods.d.ts +5 -0
- package/dist/rules/no-array-mutating-methods.d.ts.map +1 -0
- package/dist/rules/no-array-mutating-methods.js +65 -0
- package/dist/rules/no-array-mutating-methods.js.map +1 -0
- package/dist/rules/no-async-without-await.d.ts +5 -0
- package/dist/rules/no-async-without-await.d.ts.map +1 -0
- package/dist/rules/no-async-without-await.js +45 -0
- package/dist/rules/no-async-without-await.js.map +1 -0
- package/dist/rules/no-catch-instanceof.d.ts +5 -0
- package/dist/rules/no-catch-instanceof.d.ts.map +1 -0
- package/dist/rules/no-catch-instanceof.js +55 -0
- package/dist/rules/no-catch-instanceof.js.map +1 -0
- package/dist/rules/no-catch-unknown.d.ts +5 -0
- package/dist/rules/no-catch-unknown.d.ts.map +1 -0
- package/dist/rules/no-catch-unknown.js +32 -0
- package/dist/rules/no-catch-unknown.js.map +1 -0
- package/dist/rules/no-class-mutation.d.ts +5 -0
- package/dist/rules/no-class-mutation.d.ts.map +1 -0
- package/dist/rules/no-class-mutation.js +44 -0
- package/dist/rules/no-class-mutation.js.map +1 -0
- package/dist/rules/no-comments.d.ts +5 -0
- package/dist/rules/no-comments.d.ts.map +1 -0
- package/dist/rules/no-comments.js +27 -0
- package/dist/rules/no-comments.js.map +1 -0
- package/dist/rules/no-default-export.d.ts +5 -0
- package/dist/rules/no-default-export.d.ts.map +1 -0
- package/dist/rules/no-default-export.js +22 -0
- package/dist/rules/no-default-export.js.map +1 -0
- package/dist/rules/no-define-property.d.ts +5 -0
- package/dist/rules/no-define-property.d.ts.map +1 -0
- package/dist/rules/no-define-property.js +37 -0
- package/dist/rules/no-define-property.js.map +1 -0
- package/dist/rules/no-delete.d.ts +5 -0
- package/dist/rules/no-delete.d.ts.map +1 -0
- package/dist/rules/no-delete.js +35 -0
- package/dist/rules/no-delete.js.map +1 -0
- package/dist/rules/no-empty-string.d.ts +5 -0
- package/dist/rules/no-empty-string.d.ts.map +1 -0
- package/dist/rules/no-empty-string.js +24 -0
- package/dist/rules/no-empty-string.js.map +1 -0
- package/dist/rules/no-eval.d.ts +5 -0
- package/dist/rules/no-eval.d.ts.map +1 -0
- package/dist/rules/no-eval.js +33 -0
- package/dist/rules/no-eval.js.map +1 -0
- package/dist/rules/no-floating-promise.d.ts +5 -0
- package/dist/rules/no-floating-promise.d.ts.map +1 -0
- package/dist/rules/no-floating-promise.js +74 -0
- package/dist/rules/no-floating-promise.js.map +1 -0
- package/dist/rules/no-for-in.d.ts +5 -0
- package/dist/rules/no-for-in.d.ts.map +1 -0
- package/dist/rules/no-for-in.js +24 -0
- package/dist/rules/no-for-in.js.map +1 -0
- package/dist/rules/no-generic-names.d.ts +12 -0
- package/dist/rules/no-generic-names.d.ts.map +1 -0
- package/dist/rules/no-generic-names.js +104 -0
- package/dist/rules/no-generic-names.js.map +1 -0
- package/dist/rules/no-implicit-coercion.d.ts +7 -0
- package/dist/rules/no-implicit-coercion.d.ts.map +1 -0
- package/dist/rules/no-implicit-coercion.js +33 -0
- package/dist/rules/no-implicit-coercion.js.map +1 -0
- package/dist/rules/no-legacy-globals.d.ts +7 -0
- package/dist/rules/no-legacy-globals.d.ts.map +1 -0
- package/dist/rules/no-legacy-globals.js +58 -0
- package/dist/rules/no-legacy-globals.js.map +1 -0
- package/dist/rules/no-loop-func.d.ts +5 -0
- package/dist/rules/no-loop-func.d.ts.map +1 -0
- package/dist/rules/no-loop-func.js +50 -0
- package/dist/rules/no-loop-func.js.map +1 -0
- package/dist/rules/no-map-set-mutation.d.ts +5 -0
- package/dist/rules/no-map-set-mutation.d.ts.map +1 -0
- package/dist/rules/no-map-set-mutation.js +69 -0
- package/dist/rules/no-map-set-mutation.js.map +1 -0
- package/dist/rules/no-mutable-exports.d.ts +5 -0
- package/dist/rules/no-mutable-exports.d.ts.map +1 -0
- package/dist/rules/no-mutable-exports.js +29 -0
- package/dist/rules/no-mutable-exports.js.map +1 -0
- package/dist/rules/no-nan-array-indexof.d.ts +5 -0
- package/dist/rules/no-nan-array-indexof.d.ts.map +1 -0
- package/dist/rules/no-nan-array-indexof.js +33 -0
- package/dist/rules/no-nan-array-indexof.js.map +1 -0
- package/dist/rules/no-nan-in-math-result.d.ts +5 -0
- package/dist/rules/no-nan-in-math-result.d.ts.map +1 -0
- package/dist/rules/no-nan-in-math-result.js +58 -0
- package/dist/rules/no-nan-in-math-result.js.map +1 -0
- package/dist/rules/no-nan.d.ts +5 -0
- package/dist/rules/no-nan.d.ts.map +1 -0
- package/dist/rules/no-nan.js +26 -0
- package/dist/rules/no-nan.js.map +1 -0
- package/dist/rules/no-new-wrappers.d.ts +5 -0
- package/dist/rules/no-new-wrappers.d.ts.map +1 -0
- package/dist/rules/no-new-wrappers.js +47 -0
- package/dist/rules/no-new-wrappers.js.map +1 -0
- package/dist/rules/no-new.d.ts +5 -0
- package/dist/rules/no-new.d.ts.map +1 -0
- package/dist/rules/no-new.js +111 -0
- package/dist/rules/no-new.js.map +1 -0
- package/dist/rules/no-non-null-assertion.d.ts +5 -0
- package/dist/rules/no-non-null-assertion.d.ts.map +1 -0
- package/dist/rules/no-non-null-assertion.js +22 -0
- package/dist/rules/no-non-null-assertion.js.map +1 -0
- package/dist/rules/no-null-undefined.d.ts +7 -0
- package/dist/rules/no-null-undefined.d.ts.map +1 -0
- package/dist/rules/no-null-undefined.js +34 -0
- package/dist/rules/no-null-undefined.js.map +1 -0
- package/dist/rules/no-nullish-operators.d.ts +7 -0
- package/dist/rules/no-nullish-operators.d.ts.map +1 -0
- package/dist/rules/no-nullish-operators.js +31 -0
- package/dist/rules/no-nullish-operators.js.map +1 -0
- package/dist/rules/no-object-assign-mutation.d.ts +5 -0
- package/dist/rules/no-object-assign-mutation.d.ts.map +1 -0
- package/dist/rules/no-object-assign-mutation.js +36 -0
- package/dist/rules/no-object-assign-mutation.js.map +1 -0
- package/dist/rules/no-param-reassign.d.ts +5 -0
- package/dist/rules/no-param-reassign.d.ts.map +1 -0
- package/dist/rules/no-param-reassign.js +89 -0
- package/dist/rules/no-param-reassign.js.map +1 -0
- package/dist/rules/no-parseint-nan.d.ts +5 -0
- package/dist/rules/no-parseint-nan.d.ts.map +1 -0
- package/dist/rules/no-parseint-nan.js +64 -0
- package/dist/rules/no-parseint-nan.js.map +1 -0
- package/dist/rules/no-placeholder-names.d.ts +12 -0
- package/dist/rules/no-placeholder-names.d.ts.map +1 -0
- package/dist/rules/no-placeholder-names.js +107 -0
- package/dist/rules/no-placeholder-names.js.map +1 -0
- package/dist/rules/no-process-env.d.ts +5 -0
- package/dist/rules/no-process-env.d.ts.map +1 -0
- package/dist/rules/no-process-env.js +31 -0
- package/dist/rules/no-process-env.js.map +1 -0
- package/dist/rules/no-prototype-mutation.d.ts +5 -0
- package/dist/rules/no-prototype-mutation.d.ts.map +1 -0
- package/dist/rules/no-prototype-mutation.js +30 -0
- package/dist/rules/no-prototype-mutation.js.map +1 -0
- package/dist/rules/no-require.d.ts +5 -0
- package/dist/rules/no-require.d.ts.map +1 -0
- package/dist/rules/no-require.js +37 -0
- package/dist/rules/no-require.js.map +1 -0
- package/dist/rules/no-shadow.d.ts +5 -0
- package/dist/rules/no-shadow.d.ts.map +1 -0
- package/dist/rules/no-shadow.js +103 -0
- package/dist/rules/no-shadow.js.map +1 -0
- package/dist/rules/no-string-concat.d.ts +5 -0
- package/dist/rules/no-string-concat.d.ts.map +1 -0
- package/dist/rules/no-string-concat.js +36 -0
- package/dist/rules/no-string-concat.js.map +1 -0
- package/dist/rules/no-throw-literal.d.ts +5 -0
- package/dist/rules/no-throw-literal.d.ts.map +1 -0
- package/dist/rules/no-throw-literal.js +33 -0
- package/dist/rules/no-throw-literal.js.map +1 -0
- package/dist/rules/no-type-assertion.d.ts +5 -0
- package/dist/rules/no-type-assertion.d.ts.map +1 -0
- package/dist/rules/no-type-assertion.js +25 -0
- package/dist/rules/no-type-assertion.js.map +1 -0
- package/dist/rules/no-typeof.d.ts +5 -0
- package/dist/rules/no-typeof.d.ts.map +1 -0
- package/dist/rules/no-typeof.js +24 -0
- package/dist/rules/no-typeof.js.map +1 -0
- package/dist/rules/no-unknown.d.ts +5 -0
- package/dist/rules/no-unknown.d.ts.map +1 -0
- package/dist/rules/no-unknown.js +22 -0
- package/dist/rules/no-unknown.js.map +1 -0
- package/dist/rules/prefer-includes.d.ts +5 -0
- package/dist/rules/prefer-includes.d.ts.map +1 -0
- package/dist/rules/prefer-includes.js +50 -0
- package/dist/rules/prefer-includes.js.map +1 -0
- package/dist/rules/prefer-readonly-params.d.ts +5 -0
- package/dist/rules/prefer-readonly-params.d.ts.map +1 -0
- package/dist/rules/prefer-readonly-params.js +100 -0
- package/dist/rules/prefer-readonly-params.js.map +1 -0
- package/dist/rules/require-boolean-condition.d.ts +5 -0
- package/dist/rules/require-boolean-condition.d.ts.map +1 -0
- package/dist/rules/require-boolean-condition.js +60 -0
- package/dist/rules/require-boolean-condition.js.map +1 -0
- package/dist/rules/require-curly.d.ts +5 -0
- package/dist/rules/require-curly.d.ts.map +1 -0
- package/dist/rules/require-curly.js +55 -0
- package/dist/rules/require-curly.js.map +1 -0
- package/dist/rules/require-explicit-return-type.d.ts +5 -0
- package/dist/rules/require-explicit-return-type.d.ts.map +1 -0
- package/dist/rules/require-explicit-return-type.js +66 -0
- package/dist/rules/require-explicit-return-type.js.map +1 -0
- package/dist/rules/require-private-constructor.d.ts +5 -0
- package/dist/rules/require-private-constructor.d.ts.map +1 -0
- package/dist/rules/require-private-constructor.js +34 -0
- package/dist/rules/require-private-constructor.js.map +1 -0
- package/dist/rules/same-type-comparison.d.ts +5 -0
- package/dist/rules/same-type-comparison.d.ts.map +1 -0
- package/dist/rules/same-type-comparison.js +71 -0
- package/dist/rules/same-type-comparison.js.map +1 -0
- package/package.json +46 -0
package/dist/index.js
ADDED
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import { noAny } from "./rules/no-any.js";
|
|
2
|
+
import { noComments } from "./rules/no-comments.js";
|
|
3
|
+
import { noEmptyString } from "./rules/no-empty-string.js";
|
|
4
|
+
import { noGenericNames } from "./rules/no-generic-names.js";
|
|
5
|
+
import { noImplicitCoercion } from "./rules/no-implicit-coercion.js";
|
|
6
|
+
import { noThrowLiteral } from "./rules/no-throw-literal.js";
|
|
7
|
+
import { noCatchUnknown } from "./rules/no-catch-unknown.js";
|
|
8
|
+
import { noFloatingPromise } from "./rules/no-floating-promise.js";
|
|
9
|
+
import { noParamReassign } from "./rules/no-param-reassign.js";
|
|
10
|
+
import { requireExplicitReturnType } from "./rules/require-explicit-return-type.js";
|
|
11
|
+
import { noArrayMutatingMethods } from "./rules/no-array-mutating-methods.js";
|
|
12
|
+
import { noDelete } from "./rules/no-delete.js";
|
|
13
|
+
import { noMutableExports } from "./rules/no-mutable-exports.js";
|
|
14
|
+
import { preferIncludes } from "./rules/prefer-includes.js";
|
|
15
|
+
import { noLoopFunc } from "./rules/no-loop-func.js";
|
|
16
|
+
import { consistentReturn } from "./rules/consistent-return.js";
|
|
17
|
+
import { noShadow } from "./rules/no-shadow.js";
|
|
18
|
+
import { noCatchInstanceof } from "./rules/no-catch-instanceof.js";
|
|
19
|
+
import { noEval } from "./rules/no-eval.js";
|
|
20
|
+
import { noProcessEnv } from "./rules/no-process-env.js";
|
|
21
|
+
import { preferReadonlyParams } from "./rules/prefer-readonly-params.js";
|
|
22
|
+
import { noForIn } from "./rules/no-for-in.js";
|
|
23
|
+
import { noAsyncWithoutAwait } from "./rules/no-async-without-await.js";
|
|
24
|
+
import { noClassMutation } from "./rules/no-class-mutation.js";
|
|
25
|
+
import { exhaustiveSwitch } from "./rules/exhaustive-switch.js";
|
|
26
|
+
import { noRequire } from "./rules/no-require.js";
|
|
27
|
+
import { noDefaultExport } from "./rules/no-default-export.js";
|
|
28
|
+
import { requirePrivateConstructor } from "./rules/require-private-constructor.js";
|
|
29
|
+
import { noUnknown } from "./rules/no-unknown.js";
|
|
30
|
+
import { requireCurly } from "./rules/require-curly.js";
|
|
31
|
+
import { noNan } from "./rules/no-nan.js";
|
|
32
|
+
import { noNanInMathResult } from "./rules/no-nan-in-math-result.js";
|
|
33
|
+
import { noParseIntNan } from "./rules/no-parseint-nan.js";
|
|
34
|
+
import { noNanArrayIndexOf } from "./rules/no-nan-array-indexof.js";
|
|
35
|
+
import { noObjectAssignMutation } from "./rules/no-object-assign-mutation.js";
|
|
36
|
+
import { noPrototypeMutation } from "./rules/no-prototype-mutation.js";
|
|
37
|
+
import { noDefineProperty } from "./rules/no-define-property.js";
|
|
38
|
+
import { noMapSetMutation } from "./rules/no-map-set-mutation.js";
|
|
39
|
+
import { noLegacyGlobals } from "./rules/no-legacy-globals.js";
|
|
40
|
+
import { noNewWrappers } from "./rules/no-new-wrappers.js";
|
|
41
|
+
import { noNonNullAssertion } from "./rules/no-non-null-assertion.js";
|
|
42
|
+
import { noNullUndefined } from "./rules/no-null-undefined.js";
|
|
43
|
+
import { noNullishOperators } from "./rules/no-nullish-operators.js";
|
|
44
|
+
import { noPlaceholderNames } from "./rules/no-placeholder-names.js";
|
|
45
|
+
import { noStringConcat } from "./rules/no-string-concat.js";
|
|
46
|
+
import { noTypeAssertion } from "./rules/no-type-assertion.js";
|
|
47
|
+
import { noTypeof } from "./rules/no-typeof.js";
|
|
48
|
+
import { requireBooleanCondition } from "./rules/require-boolean-condition.js";
|
|
49
|
+
import { sameTypeComparison } from "./rules/same-type-comparison.js";
|
|
50
|
+
const rules = {
|
|
51
|
+
"no-placeholder-names": noPlaceholderNames,
|
|
52
|
+
"no-generic-names": noGenericNames,
|
|
53
|
+
"no-null-undefined": noNullUndefined,
|
|
54
|
+
"no-comments": noComments,
|
|
55
|
+
"require-boolean-condition": requireBooleanCondition,
|
|
56
|
+
"same-type-comparison": sameTypeComparison,
|
|
57
|
+
"no-any": noAny,
|
|
58
|
+
"no-type-assertion": noTypeAssertion,
|
|
59
|
+
"no-non-null-assertion": noNonNullAssertion,
|
|
60
|
+
"no-nullish-operators": noNullishOperators,
|
|
61
|
+
"no-empty-string": noEmptyString,
|
|
62
|
+
"no-typeof": noTypeof,
|
|
63
|
+
"no-legacy-globals": noLegacyGlobals,
|
|
64
|
+
"no-new-wrappers": noNewWrappers,
|
|
65
|
+
"no-string-concat": noStringConcat,
|
|
66
|
+
"no-implicit-coercion": noImplicitCoercion,
|
|
67
|
+
"no-throw-literal": noThrowLiteral,
|
|
68
|
+
"no-catch-unknown": noCatchUnknown,
|
|
69
|
+
"no-floating-promise": noFloatingPromise,
|
|
70
|
+
"no-param-reassign": noParamReassign,
|
|
71
|
+
"require-explicit-return-type": requireExplicitReturnType,
|
|
72
|
+
"no-array-mutating-methods": noArrayMutatingMethods,
|
|
73
|
+
"no-delete": noDelete,
|
|
74
|
+
"no-mutable-exports": noMutableExports,
|
|
75
|
+
"prefer-includes": preferIncludes,
|
|
76
|
+
"no-loop-func": noLoopFunc,
|
|
77
|
+
"consistent-return": consistentReturn,
|
|
78
|
+
"no-shadow": noShadow,
|
|
79
|
+
"no-catch-instanceof": noCatchInstanceof,
|
|
80
|
+
"no-eval": noEval,
|
|
81
|
+
"no-process-env": noProcessEnv,
|
|
82
|
+
"prefer-readonly-params": preferReadonlyParams,
|
|
83
|
+
"no-for-in": noForIn,
|
|
84
|
+
"no-async-without-await": noAsyncWithoutAwait,
|
|
85
|
+
"no-class-mutation": noClassMutation,
|
|
86
|
+
"exhaustive-switch": exhaustiveSwitch,
|
|
87
|
+
"no-require": noRequire,
|
|
88
|
+
"no-default-export": noDefaultExport,
|
|
89
|
+
"require-private-constructor": requirePrivateConstructor,
|
|
90
|
+
"no-unknown": noUnknown,
|
|
91
|
+
"require-curly": requireCurly,
|
|
92
|
+
"no-nan": noNan,
|
|
93
|
+
"no-nan-in-math-result": noNanInMathResult,
|
|
94
|
+
"no-parseint-nan": noParseIntNan,
|
|
95
|
+
"no-nan-array-indexof": noNanArrayIndexOf,
|
|
96
|
+
"no-object-assign-mutation": noObjectAssignMutation,
|
|
97
|
+
"no-prototype-mutation": noPrototypeMutation,
|
|
98
|
+
"no-define-property": noDefineProperty,
|
|
99
|
+
"no-map-set-mutation": noMapSetMutation,
|
|
100
|
+
};
|
|
101
|
+
const configs = {};
|
|
102
|
+
const plugin = {
|
|
103
|
+
meta: { name: "fookie-eslint-plugin", version: "0.1.0" },
|
|
104
|
+
rules,
|
|
105
|
+
configs,
|
|
106
|
+
};
|
|
107
|
+
const recommendedRules = {
|
|
108
|
+
"fookie/no-placeholder-names": "error",
|
|
109
|
+
"fookie/no-generic-names": "warn",
|
|
110
|
+
"fookie/no-null-undefined": "error",
|
|
111
|
+
"fookie/no-comments": "error",
|
|
112
|
+
"fookie/require-boolean-condition": "error",
|
|
113
|
+
"fookie/same-type-comparison": "error",
|
|
114
|
+
"fookie/no-any": "error",
|
|
115
|
+
"fookie/no-type-assertion": "error",
|
|
116
|
+
"fookie/no-non-null-assertion": "error",
|
|
117
|
+
"fookie/no-nullish-operators": "error",
|
|
118
|
+
"fookie/no-empty-string": "error",
|
|
119
|
+
"fookie/no-typeof": "error",
|
|
120
|
+
"fookie/no-legacy-globals": "error",
|
|
121
|
+
"fookie/no-new-wrappers": "error",
|
|
122
|
+
"fookie/no-string-concat": "error",
|
|
123
|
+
"fookie/no-implicit-coercion": "error",
|
|
124
|
+
"fookie/no-throw-literal": "error",
|
|
125
|
+
"fookie/no-catch-unknown": "error",
|
|
126
|
+
"fookie/no-floating-promise": "error",
|
|
127
|
+
"fookie/no-param-reassign": "error",
|
|
128
|
+
"fookie/require-explicit-return-type": "error",
|
|
129
|
+
"fookie/no-array-mutating-methods": "error",
|
|
130
|
+
"fookie/no-delete": "error",
|
|
131
|
+
"fookie/no-mutable-exports": "error",
|
|
132
|
+
"fookie/prefer-includes": "error",
|
|
133
|
+
"fookie/no-loop-func": "error",
|
|
134
|
+
"fookie/consistent-return": "error",
|
|
135
|
+
"fookie/no-shadow": "error",
|
|
136
|
+
"fookie/no-catch-instanceof": "error",
|
|
137
|
+
"fookie/no-eval": "error",
|
|
138
|
+
"fookie/no-process-env": "error",
|
|
139
|
+
"fookie/prefer-readonly-params": "error",
|
|
140
|
+
"fookie/no-for-in": "error",
|
|
141
|
+
"fookie/no-async-without-await": "error",
|
|
142
|
+
"fookie/no-class-mutation": "error",
|
|
143
|
+
"fookie/exhaustive-switch": "error",
|
|
144
|
+
"fookie/no-require": "error",
|
|
145
|
+
"fookie/no-default-export": "error",
|
|
146
|
+
"fookie/require-private-constructor": "error",
|
|
147
|
+
"fookie/no-unknown": "error",
|
|
148
|
+
"fookie/require-curly": "error",
|
|
149
|
+
"fookie/no-nan": "error",
|
|
150
|
+
"fookie/no-nan-in-math-result": "error",
|
|
151
|
+
"fookie/no-parseint-nan": "error",
|
|
152
|
+
"fookie/no-nan-array-indexof": "error",
|
|
153
|
+
"fookie/no-object-assign-mutation": "error",
|
|
154
|
+
"fookie/no-prototype-mutation": "error",
|
|
155
|
+
"fookie/no-define-property": "error",
|
|
156
|
+
"fookie/no-map-set-mutation": "error",
|
|
157
|
+
};
|
|
158
|
+
configs["recommended"] = {
|
|
159
|
+
plugins: { fookie: plugin },
|
|
160
|
+
rules: recommendedRules,
|
|
161
|
+
};
|
|
162
|
+
configs["recommended-legacy"] = {
|
|
163
|
+
plugins: ["fookie"],
|
|
164
|
+
rules: recommendedRules,
|
|
165
|
+
};
|
|
166
|
+
export default plugin;
|
|
167
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ESLintUtils } from "@typescript-eslint/utils";
|
|
2
|
+
type MessageIds = "missingReturnValue" | "unexpectedReturnValue";
|
|
3
|
+
export declare const consistentReturn: ESLintUtils.RuleModule<MessageIds, [], unknown, ESLintUtils.RuleListener> & {
|
|
4
|
+
name: string;
|
|
5
|
+
};
|
|
6
|
+
export {};
|
|
7
|
+
//# sourceMappingURL=consistent-return.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"consistent-return.d.ts","sourceRoot":"","sources":["../../src/rules/consistent-return.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAQhF,KAAK,UAAU,GAAG,oBAAoB,GAAG,uBAAuB,CAAA;AAahE,eAAO,MAAM,gBAAgB;;CAwD3B,CAAA"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { AST_NODE_TYPES, ESLintUtils, TSESTree } from "@typescript-eslint/utils";
|
|
2
|
+
const createRule = ESLintUtils.RuleCreator((name) => `https://github.com/fookiejs/eslint-plugin-fookie/blob/main/docs/rules/${name}.md`);
|
|
3
|
+
export const consistentReturn = createRule({
|
|
4
|
+
name: "consistent-return",
|
|
5
|
+
meta: {
|
|
6
|
+
type: "problem",
|
|
7
|
+
docs: {
|
|
8
|
+
description: "Require all return statements in a function to either always or never return a value",
|
|
9
|
+
},
|
|
10
|
+
schema: [],
|
|
11
|
+
messages: {
|
|
12
|
+
missingReturnValue: "Expected a return value. All return statements in this function must return a value.",
|
|
13
|
+
unexpectedReturnValue: "Unexpected return value. All return statements in this function must either all return a value or none return a value.",
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
defaultOptions: [],
|
|
17
|
+
create(context) {
|
|
18
|
+
let stack = [];
|
|
19
|
+
function enterFunction(node) {
|
|
20
|
+
if (node.type === AST_NODE_TYPES.ArrowFunctionExpression && node.expression)
|
|
21
|
+
return;
|
|
22
|
+
stack = [...stack, { node, hasValueReturn: false, hasEmptyReturn: false }];
|
|
23
|
+
}
|
|
24
|
+
function exitFunction(node) {
|
|
25
|
+
if (node.type === AST_NODE_TYPES.ArrowFunctionExpression && node.expression)
|
|
26
|
+
return;
|
|
27
|
+
stack = stack.slice(0, -1);
|
|
28
|
+
}
|
|
29
|
+
return {
|
|
30
|
+
FunctionDeclaration: enterFunction,
|
|
31
|
+
FunctionExpression: enterFunction,
|
|
32
|
+
ArrowFunctionExpression: enterFunction,
|
|
33
|
+
"FunctionDeclaration:exit": exitFunction,
|
|
34
|
+
"FunctionExpression:exit": exitFunction,
|
|
35
|
+
"ArrowFunctionExpression:exit": exitFunction,
|
|
36
|
+
ReturnStatement(node) {
|
|
37
|
+
const current = stack[stack.length - 1];
|
|
38
|
+
if (!current)
|
|
39
|
+
return;
|
|
40
|
+
if (node.argument !== null) {
|
|
41
|
+
current.hasValueReturn = true;
|
|
42
|
+
if (current.hasEmptyReturn) {
|
|
43
|
+
context.report({ node, messageId: "unexpectedReturnValue" });
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
current.hasEmptyReturn = true;
|
|
48
|
+
if (current.hasValueReturn) {
|
|
49
|
+
context.report({ node, messageId: "missingReturnValue" });
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
},
|
|
53
|
+
};
|
|
54
|
+
},
|
|
55
|
+
});
|
|
56
|
+
//# sourceMappingURL=consistent-return.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"consistent-return.js","sourceRoot":"","sources":["../../src/rules/consistent-return.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AAEhF,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CACxC,CAAC,IAAI,EAAE,EAAE,CACP,yEAAyE,IAAI,KAAK,CACrF,CAAA;AAgBD,MAAM,CAAC,MAAM,gBAAgB,GAAG,UAAU,CAAsB;IAC9D,IAAI,EAAE,mBAAmB;IACzB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EACT,sFAAsF;SACzF;QACD,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE;YACR,kBAAkB,EAChB,sFAAsF;YACxF,qBAAqB,EACnB,wHAAwH;SAC3H;KACF;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,IAAI,KAAK,GAAgC,EAAE,CAAA;QAE3C,SAAS,aAAa,CAAC,IAAkB;YACvC,IAAI,IAAI,CAAC,IAAI,KAAK,cAAc,CAAC,uBAAuB,IAAI,IAAI,CAAC,UAAU;gBAAE,OAAM;YACnF,KAAK,GAAG,CAAC,GAAG,KAAK,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC,CAAA;QAC5E,CAAC;QAED,SAAS,YAAY,CAAC,IAAkB;YACtC,IAAI,IAAI,CAAC,IAAI,KAAK,cAAc,CAAC,uBAAuB,IAAI,IAAI,CAAC,UAAU;gBAAE,OAAM;YACnF,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;QAC5B,CAAC;QAED,OAAO;YACL,mBAAmB,EAAE,aAAa;YAClC,kBAAkB,EAAE,aAAa;YACjC,uBAAuB,EAAE,aAAa;YACtC,0BAA0B,EAAE,YAAY;YACxC,yBAAyB,EAAE,YAAY;YACvC,8BAA8B,EAAE,YAAY;YAE5C,eAAe,CAAC,IAA8B;gBAC5C,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;gBACvC,IAAI,CAAC,OAAO;oBAAE,OAAM;gBAEpB,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;oBAC3B,OAAO,CAAC,cAAc,GAAG,IAAI,CAAA;oBAC7B,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;wBAC3B,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,uBAAuB,EAAE,CAAC,CAAA;oBAC9D,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,OAAO,CAAC,cAAc,GAAG,IAAI,CAAA;oBAC7B,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;wBAC3B,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,oBAAoB,EAAE,CAAC,CAAA;oBAC3D,CAAC;gBACH,CAAC;YACH,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"exhaustive-switch.d.ts","sourceRoot":"","sources":["../../src/rules/exhaustive-switch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAgDhE,eAAO,MAAM,gBAAgB;;CA2C3B,CAAA"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { ESLintUtils, TSESTree } from "@typescript-eslint/utils";
|
|
2
|
+
import * as ts from "typescript";
|
|
3
|
+
const createRule = ESLintUtils.RuleCreator((name) => `https://github.com/fookiejs/eslint-plugin-fookie/blob/main/docs/rules/${name}.md`);
|
|
4
|
+
function getLiteralValue(type) {
|
|
5
|
+
if (type.flags & ts.TypeFlags.StringLiteral)
|
|
6
|
+
return type.value;
|
|
7
|
+
if (type.flags & ts.TypeFlags.NumberLiteral)
|
|
8
|
+
return type.value;
|
|
9
|
+
if (type.flags & ts.TypeFlags.BooleanLiteral) {
|
|
10
|
+
return type.intrinsicName === "true";
|
|
11
|
+
}
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
function getUnionMembers(type) {
|
|
15
|
+
const members = new Set();
|
|
16
|
+
if (type.isUnion()) {
|
|
17
|
+
for (const t of type.types) {
|
|
18
|
+
const val = getLiteralValue(t);
|
|
19
|
+
if (val !== null)
|
|
20
|
+
members.add(val);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
const val = getLiteralValue(type);
|
|
25
|
+
if (val !== null)
|
|
26
|
+
members.add(val);
|
|
27
|
+
}
|
|
28
|
+
return members;
|
|
29
|
+
}
|
|
30
|
+
function getCaseValues(cases) {
|
|
31
|
+
const values = new Set();
|
|
32
|
+
for (const c of cases) {
|
|
33
|
+
if (!c.test)
|
|
34
|
+
continue;
|
|
35
|
+
const t = c.test;
|
|
36
|
+
if (t.type === "Literal") {
|
|
37
|
+
if (t.value !== null && t.value !== undefined) {
|
|
38
|
+
values.add(t.value);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return values;
|
|
43
|
+
}
|
|
44
|
+
export const exhaustiveSwitch = createRule({
|
|
45
|
+
name: "exhaustive-switch",
|
|
46
|
+
meta: {
|
|
47
|
+
type: "problem",
|
|
48
|
+
docs: {
|
|
49
|
+
description: "Require switch statements over union types to handle all cases without a default fallback",
|
|
50
|
+
},
|
|
51
|
+
schema: [],
|
|
52
|
+
messages: {
|
|
53
|
+
nonExhaustiveSwitch: "Switch is not exhaustive. Missing cases: {{missing}}. Handle all union members explicitly instead of relying on default.",
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
defaultOptions: [],
|
|
57
|
+
create(context) {
|
|
58
|
+
const services = ESLintUtils.getParserServices(context);
|
|
59
|
+
const checker = services.program.getTypeChecker();
|
|
60
|
+
return {
|
|
61
|
+
SwitchStatement(node) {
|
|
62
|
+
const hasDefault = node.cases.some((c) => c.test === null);
|
|
63
|
+
if (hasDefault)
|
|
64
|
+
return;
|
|
65
|
+
const tsNode = services.esTreeNodeToTSNodeMap.get(node.discriminant);
|
|
66
|
+
const type = checker.getTypeAtLocation(tsNode);
|
|
67
|
+
const unionMembers = getUnionMembers(type);
|
|
68
|
+
if (unionMembers.size === 0)
|
|
69
|
+
return;
|
|
70
|
+
const caseValues = getCaseValues(node.cases);
|
|
71
|
+
const missing = [...unionMembers].filter((m) => !caseValues.has(m));
|
|
72
|
+
if (missing.length > 0) {
|
|
73
|
+
context.report({
|
|
74
|
+
node,
|
|
75
|
+
messageId: "nonExhaustiveSwitch",
|
|
76
|
+
data: { missing: missing.map((m) => JSON.stringify(m)).join(", ") },
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
};
|
|
81
|
+
},
|
|
82
|
+
});
|
|
83
|
+
//# sourceMappingURL=exhaustive-switch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"exhaustive-switch.js","sourceRoot":"","sources":["../../src/rules/exhaustive-switch.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
export { noPlaceholderNames } from "./no-placeholder-names.js";
|
|
2
|
+
export { noGenericNames } from "./no-generic-names.js";
|
|
3
|
+
export { noNullUndefined } from "./no-null-undefined.js";
|
|
4
|
+
export { noComments } from "./no-comments.js";
|
|
5
|
+
export { requireBooleanCondition } from "./require-boolean-condition.js";
|
|
6
|
+
export { sameTypeComparison } from "./same-type-comparison.js";
|
|
7
|
+
export { noAny } from "./no-any.js";
|
|
8
|
+
export { noTypeAssertion } from "./no-type-assertion.js";
|
|
9
|
+
export { noNonNullAssertion } from "./no-non-null-assertion.js";
|
|
10
|
+
export { noNullishOperators } from "./no-nullish-operators.js";
|
|
11
|
+
export { noEmptyString } from "./no-empty-string.js";
|
|
12
|
+
export { noTypeof } from "./no-typeof.js";
|
|
13
|
+
export { noLegacyGlobals } from "./no-legacy-globals.js";
|
|
14
|
+
export { noNewWrappers } from "./no-new-wrappers.js";
|
|
15
|
+
export { noStringConcat } from "./no-string-concat.js";
|
|
16
|
+
export { noImplicitCoercion } from "./no-implicit-coercion.js";
|
|
17
|
+
export { noThrowLiteral } from "./no-throw-literal.js";
|
|
18
|
+
export { noCatchUnknown } from "./no-catch-unknown.js";
|
|
19
|
+
export { noFloatingPromise } from "./no-floating-promise.js";
|
|
20
|
+
export { noParamReassign } from "./no-param-reassign.js";
|
|
21
|
+
export { requireExplicitReturnType } from "./require-explicit-return-type.js";
|
|
22
|
+
export { noArrayMutatingMethods } from "./no-array-mutating-methods.js";
|
|
23
|
+
export { noDelete } from "./no-delete.js";
|
|
24
|
+
export { noMutableExports } from "./no-mutable-exports.js";
|
|
25
|
+
export { preferIncludes } from "./prefer-includes.js";
|
|
26
|
+
export { noLoopFunc } from "./no-loop-func.js";
|
|
27
|
+
export { consistentReturn } from "./consistent-return.js";
|
|
28
|
+
export { noShadow } from "./no-shadow.js";
|
|
29
|
+
export { noCatchInstanceof } from "./no-catch-instanceof.js";
|
|
30
|
+
export { noEval } from "./no-eval.js";
|
|
31
|
+
export { noProcessEnv } from "./no-process-env.js";
|
|
32
|
+
export { preferReadonlyParams } from "./prefer-readonly-params.js";
|
|
33
|
+
export { noForIn } from "./no-for-in.js";
|
|
34
|
+
export { noAsyncWithoutAwait } from "./no-async-without-await.js";
|
|
35
|
+
export { noClassMutation } from "./no-class-mutation.js";
|
|
36
|
+
export { exhaustiveSwitch } from "./exhaustive-switch.js";
|
|
37
|
+
export { noRequire } from "./no-require.js";
|
|
38
|
+
export { noDefaultExport } from "./no-default-export.js";
|
|
39
|
+
export { requirePrivateConstructor } from "./require-private-constructor.js";
|
|
40
|
+
export { noUnknown } from "./no-unknown.js";
|
|
41
|
+
export { requireCurly } from "./require-curly.js";
|
|
42
|
+
export { noNan } from "./no-nan.js";
|
|
43
|
+
export { noNanInMathResult } from "./no-nan-in-math-result.js";
|
|
44
|
+
export { noParseIntNan } from "./no-parseint-nan.js";
|
|
45
|
+
export { noNanArrayIndexOf } from "./no-nan-array-indexof.js";
|
|
46
|
+
export { noObjectAssignMutation } from "./no-object-assign-mutation.js";
|
|
47
|
+
export { noPrototypeMutation } from "./no-prototype-mutation.js";
|
|
48
|
+
export { noDefineProperty } from "./no-define-property.js";
|
|
49
|
+
export { noMapSetMutation } from "./no-map-set-mutation.js";
|
|
50
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/rules/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
export { noPlaceholderNames } from "./no-placeholder-names.js";
|
|
2
|
+
export { noGenericNames } from "./no-generic-names.js";
|
|
3
|
+
export { noNullUndefined } from "./no-null-undefined.js";
|
|
4
|
+
export { noComments } from "./no-comments.js";
|
|
5
|
+
export { requireBooleanCondition } from "./require-boolean-condition.js";
|
|
6
|
+
export { sameTypeComparison } from "./same-type-comparison.js";
|
|
7
|
+
export { noAny } from "./no-any.js";
|
|
8
|
+
export { noTypeAssertion } from "./no-type-assertion.js";
|
|
9
|
+
export { noNonNullAssertion } from "./no-non-null-assertion.js";
|
|
10
|
+
export { noNullishOperators } from "./no-nullish-operators.js";
|
|
11
|
+
export { noEmptyString } from "./no-empty-string.js";
|
|
12
|
+
export { noTypeof } from "./no-typeof.js";
|
|
13
|
+
export { noLegacyGlobals } from "./no-legacy-globals.js";
|
|
14
|
+
export { noNewWrappers } from "./no-new-wrappers.js";
|
|
15
|
+
export { noStringConcat } from "./no-string-concat.js";
|
|
16
|
+
export { noImplicitCoercion } from "./no-implicit-coercion.js";
|
|
17
|
+
export { noThrowLiteral } from "./no-throw-literal.js";
|
|
18
|
+
export { noCatchUnknown } from "./no-catch-unknown.js";
|
|
19
|
+
export { noFloatingPromise } from "./no-floating-promise.js";
|
|
20
|
+
export { noParamReassign } from "./no-param-reassign.js";
|
|
21
|
+
export { requireExplicitReturnType } from "./require-explicit-return-type.js";
|
|
22
|
+
export { noArrayMutatingMethods } from "./no-array-mutating-methods.js";
|
|
23
|
+
export { noDelete } from "./no-delete.js";
|
|
24
|
+
export { noMutableExports } from "./no-mutable-exports.js";
|
|
25
|
+
export { preferIncludes } from "./prefer-includes.js";
|
|
26
|
+
export { noLoopFunc } from "./no-loop-func.js";
|
|
27
|
+
export { consistentReturn } from "./consistent-return.js";
|
|
28
|
+
export { noShadow } from "./no-shadow.js";
|
|
29
|
+
export { noCatchInstanceof } from "./no-catch-instanceof.js";
|
|
30
|
+
export { noEval } from "./no-eval.js";
|
|
31
|
+
export { noProcessEnv } from "./no-process-env.js";
|
|
32
|
+
export { preferReadonlyParams } from "./prefer-readonly-params.js";
|
|
33
|
+
export { noForIn } from "./no-for-in.js";
|
|
34
|
+
export { noAsyncWithoutAwait } from "./no-async-without-await.js";
|
|
35
|
+
export { noClassMutation } from "./no-class-mutation.js";
|
|
36
|
+
export { exhaustiveSwitch } from "./exhaustive-switch.js";
|
|
37
|
+
export { noRequire } from "./no-require.js";
|
|
38
|
+
export { noDefaultExport } from "./no-default-export.js";
|
|
39
|
+
export { requirePrivateConstructor } from "./require-private-constructor.js";
|
|
40
|
+
export { noUnknown } from "./no-unknown.js";
|
|
41
|
+
export { requireCurly } from "./require-curly.js";
|
|
42
|
+
export { noNan } from "./no-nan.js";
|
|
43
|
+
export { noNanInMathResult } from "./no-nan-in-math-result.js";
|
|
44
|
+
export { noParseIntNan } from "./no-parseint-nan.js";
|
|
45
|
+
export { noNanArrayIndexOf } from "./no-nan-array-indexof.js";
|
|
46
|
+
export { noObjectAssignMutation } from "./no-object-assign-mutation.js";
|
|
47
|
+
export { noPrototypeMutation } from "./no-prototype-mutation.js";
|
|
48
|
+
export { noDefineProperty } from "./no-define-property.js";
|
|
49
|
+
export { noMapSetMutation } from "./no-map-set-mutation.js";
|
|
50
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/rules/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAA;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,EAAE,uBAAuB,EAAE,MAAM,gCAAgC,CAAA;AACxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAC9D,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AACnC,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAA;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAA;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAA;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAA;AACtD,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAA;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AACxD,OAAO,EAAE,yBAAyB,EAAE,MAAM,mCAAmC,CAAA;AAC7E,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAA;AACvE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAA;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAA;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAClD,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAA;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAA;AACxC,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAA;AACzD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AACxD,OAAO,EAAE,yBAAyB,EAAE,MAAM,kCAAkC,CAAA;AAC5E,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AACnC,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAA;AAC7D,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAA;AACvE,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAA;AAChE,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-any.d.ts","sourceRoot":"","sources":["../../src/rules/no-any.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAUhE,eAAO,MAAM,KAAK;;CAgBhB,CAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ESLintUtils, TSESTree } from "@typescript-eslint/utils";
|
|
2
|
+
const createRule = ESLintUtils.RuleCreator((name) => `https://github.com/fookiejs/eslint-plugin-fookie/blob/main/docs/rules/${name}.md`);
|
|
3
|
+
export const noAny = createRule({
|
|
4
|
+
name: "no-any",
|
|
5
|
+
meta: {
|
|
6
|
+
type: "problem",
|
|
7
|
+
docs: { description: "Disallow the any type" },
|
|
8
|
+
schema: [],
|
|
9
|
+
messages: { noAny: "Do not use 'any'. Use a specific type instead." },
|
|
10
|
+
},
|
|
11
|
+
defaultOptions: [],
|
|
12
|
+
create(context) {
|
|
13
|
+
return {
|
|
14
|
+
TSAnyKeyword(node) {
|
|
15
|
+
context.report({ node, messageId: "noAny" });
|
|
16
|
+
},
|
|
17
|
+
};
|
|
18
|
+
},
|
|
19
|
+
});
|
|
20
|
+
//# sourceMappingURL=no-any.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-any.js","sourceRoot":"","sources":["../../src/rules/no-any.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AAEhE,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CACxC,CAAC,IAAI,EAAE,EAAE,CACP,yEAAyE,IAAI,KAAK,CACrF,CAAA;AAKD,MAAM,CAAC,MAAM,KAAK,GAAG,UAAU,CAAsB;IACnD,IAAI,EAAE,QAAQ;IACd,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,EAAE,WAAW,EAAE,uBAAuB,EAAE;QAC9C,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE,EAAE,KAAK,EAAE,gDAAgD,EAAE;KACtE;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,YAAY,CAAC,IAA2B;gBACtC,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,CAAA;YAC9C,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { ESLintUtils } from "@typescript-eslint/utils";
|
|
2
|
+
export declare const noArrayMutatingMethods: ESLintUtils.RuleModule<"noArrayMutatingMethod", [], unknown, ESLintUtils.RuleListener> & {
|
|
3
|
+
name: string;
|
|
4
|
+
};
|
|
5
|
+
//# sourceMappingURL=no-array-mutating-methods.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-array-mutating-methods.d.ts","sourceRoot":"","sources":["../../src/rules/no-array-mutating-methods.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAiChE,eAAO,MAAM,sBAAsB;;CAwCjC,CAAA"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { ESLintUtils, TSESTree } from "@typescript-eslint/utils";
|
|
2
|
+
import * as ts from "typescript";
|
|
3
|
+
const createRule = ESLintUtils.RuleCreator((name) => `https://github.com/fookiejs/eslint-plugin-fookie/blob/main/docs/rules/${name}.md`);
|
|
4
|
+
const MUTATING_METHODS = new Set([
|
|
5
|
+
"sort",
|
|
6
|
+
"reverse",
|
|
7
|
+
"splice",
|
|
8
|
+
"push",
|
|
9
|
+
"pop",
|
|
10
|
+
"shift",
|
|
11
|
+
"unshift",
|
|
12
|
+
"fill",
|
|
13
|
+
"copyWithin",
|
|
14
|
+
]);
|
|
15
|
+
function isArrayType(type) {
|
|
16
|
+
if (type.isUnion())
|
|
17
|
+
return type.types.some(isArrayType);
|
|
18
|
+
const symbol = type.getSymbol();
|
|
19
|
+
if (symbol) {
|
|
20
|
+
const name = symbol.getName();
|
|
21
|
+
if (name === "Array" || name === "ReadonlyArray")
|
|
22
|
+
return true;
|
|
23
|
+
}
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
export const noArrayMutatingMethods = createRule({
|
|
27
|
+
name: "no-array-mutating-methods",
|
|
28
|
+
meta: {
|
|
29
|
+
type: "problem",
|
|
30
|
+
docs: {
|
|
31
|
+
description: "Disallow in-place array mutation methods. Use spread + method or non-mutating alternatives instead.",
|
|
32
|
+
},
|
|
33
|
+
schema: [],
|
|
34
|
+
messages: {
|
|
35
|
+
noArrayMutatingMethod: "'{{method}}' mutates the array in place. Use '[...arr].{{method}}()' or a non-mutating alternative.",
|
|
36
|
+
},
|
|
37
|
+
},
|
|
38
|
+
defaultOptions: [],
|
|
39
|
+
create(context) {
|
|
40
|
+
const services = ESLintUtils.getParserServices(context);
|
|
41
|
+
const checker = services.program.getTypeChecker();
|
|
42
|
+
return {
|
|
43
|
+
CallExpression(node) {
|
|
44
|
+
const callee = node.callee;
|
|
45
|
+
if (callee.type !== "MemberExpression")
|
|
46
|
+
return;
|
|
47
|
+
const prop = callee.property;
|
|
48
|
+
if (prop.type !== "Identifier")
|
|
49
|
+
return;
|
|
50
|
+
if (!MUTATING_METHODS.has(prop.name))
|
|
51
|
+
return;
|
|
52
|
+
const objTsNode = services.esTreeNodeToTSNodeMap.get(callee.object);
|
|
53
|
+
const objType = checker.getTypeAtLocation(objTsNode);
|
|
54
|
+
if (isArrayType(objType)) {
|
|
55
|
+
context.report({
|
|
56
|
+
node,
|
|
57
|
+
messageId: "noArrayMutatingMethod",
|
|
58
|
+
data: { method: prop.name },
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
};
|
|
63
|
+
},
|
|
64
|
+
});
|
|
65
|
+
//# sourceMappingURL=no-array-mutating-methods.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-array-mutating-methods.js","sourceRoot":"","sources":["../../src/rules/no-array-mutating-methods.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AAChE,OAAO,KAAK,EAAE,MAAM,YAAY,CAAA;AAEhC,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CACxC,CAAC,IAAI,EAAE,EAAE,CACP,yEAAyE,IAAI,KAAK,CACrF,CAAA;AAKD,MAAM,gBAAgB,GAAG,IAAI,GAAG,CAAC;IAC/B,MAAM;IACN,SAAS;IACT,QAAQ;IACR,MAAM;IACN,KAAK;IACL,OAAO;IACP,SAAS;IACT,MAAM;IACN,YAAY;CACb,CAAC,CAAA;AAEF,SAAS,WAAW,CAAC,IAAa;IAChC,IAAI,IAAI,CAAC,OAAO,EAAE;QAAE,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;IACvD,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;IAC/B,IAAI,MAAM,EAAE,CAAC;QACX,MAAM,IAAI,GAAG,MAAM,CAAC,OAAO,EAAE,CAAA;QAC7B,IAAI,IAAI,KAAK,OAAO,IAAI,IAAI,KAAK,eAAe;YAAE,OAAO,IAAI,CAAA;IAC/D,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC;AAED,MAAM,CAAC,MAAM,sBAAsB,GAAG,UAAU,CAAsB;IACpE,IAAI,EAAE,2BAA2B;IACjC,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EACT,qGAAqG;SACxG;QACD,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE;YACR,qBAAqB,EACnB,qGAAqG;SACxG;KACF;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,MAAM,QAAQ,GAAG,WAAW,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAA;QACvD,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,cAAc,EAAE,CAAA;QAEjD,OAAO;YACL,cAAc,CAAC,IAA6B;gBAC1C,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAA;gBAC1B,IAAI,MAAM,CAAC,IAAI,KAAK,kBAAkB;oBAAE,OAAM;gBAC9C,MAAM,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAA;gBAC5B,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY;oBAAE,OAAM;gBACtC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;oBAAE,OAAM;gBAE5C,MAAM,SAAS,GAAG,QAAQ,CAAC,qBAAqB,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;gBACnE,MAAM,OAAO,GAAG,OAAO,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAA;gBAEpD,IAAI,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC;oBACzB,OAAO,CAAC,MAAM,CAAC;wBACb,IAAI;wBACJ,SAAS,EAAE,uBAAuB;wBAClC,IAAI,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE;qBAC5B,CAAC,CAAA;gBACJ,CAAC;YACH,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-async-without-await.d.ts","sourceRoot":"","sources":["../../src/rules/no-async-without-await.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAoBhE,eAAO,MAAM,mBAAmB;;CA4C9B,CAAA"}
|