@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.
Files changed (210) hide show
  1. package/README.md +512 -0
  2. package/dist/index.d.ts +164 -0
  3. package/dist/index.d.ts.map +1 -0
  4. package/dist/index.js +167 -0
  5. package/dist/index.js.map +1 -0
  6. package/dist/rules/consistent-return.d.ts +7 -0
  7. package/dist/rules/consistent-return.d.ts.map +1 -0
  8. package/dist/rules/consistent-return.js +56 -0
  9. package/dist/rules/consistent-return.js.map +1 -0
  10. package/dist/rules/exhaustive-switch.d.ts +5 -0
  11. package/dist/rules/exhaustive-switch.d.ts.map +1 -0
  12. package/dist/rules/exhaustive-switch.js +83 -0
  13. package/dist/rules/exhaustive-switch.js.map +1 -0
  14. package/dist/rules/index.d.ts +50 -0
  15. package/dist/rules/index.d.ts.map +1 -0
  16. package/dist/rules/index.js +50 -0
  17. package/dist/rules/index.js.map +1 -0
  18. package/dist/rules/no-any.d.ts +5 -0
  19. package/dist/rules/no-any.d.ts.map +1 -0
  20. package/dist/rules/no-any.js +20 -0
  21. package/dist/rules/no-any.js.map +1 -0
  22. package/dist/rules/no-array-mutating-methods.d.ts +5 -0
  23. package/dist/rules/no-array-mutating-methods.d.ts.map +1 -0
  24. package/dist/rules/no-array-mutating-methods.js +65 -0
  25. package/dist/rules/no-array-mutating-methods.js.map +1 -0
  26. package/dist/rules/no-async-without-await.d.ts +5 -0
  27. package/dist/rules/no-async-without-await.d.ts.map +1 -0
  28. package/dist/rules/no-async-without-await.js +45 -0
  29. package/dist/rules/no-async-without-await.js.map +1 -0
  30. package/dist/rules/no-catch-instanceof.d.ts +5 -0
  31. package/dist/rules/no-catch-instanceof.d.ts.map +1 -0
  32. package/dist/rules/no-catch-instanceof.js +55 -0
  33. package/dist/rules/no-catch-instanceof.js.map +1 -0
  34. package/dist/rules/no-catch-unknown.d.ts +5 -0
  35. package/dist/rules/no-catch-unknown.d.ts.map +1 -0
  36. package/dist/rules/no-catch-unknown.js +32 -0
  37. package/dist/rules/no-catch-unknown.js.map +1 -0
  38. package/dist/rules/no-class-mutation.d.ts +5 -0
  39. package/dist/rules/no-class-mutation.d.ts.map +1 -0
  40. package/dist/rules/no-class-mutation.js +44 -0
  41. package/dist/rules/no-class-mutation.js.map +1 -0
  42. package/dist/rules/no-comments.d.ts +5 -0
  43. package/dist/rules/no-comments.d.ts.map +1 -0
  44. package/dist/rules/no-comments.js +27 -0
  45. package/dist/rules/no-comments.js.map +1 -0
  46. package/dist/rules/no-default-export.d.ts +5 -0
  47. package/dist/rules/no-default-export.d.ts.map +1 -0
  48. package/dist/rules/no-default-export.js +22 -0
  49. package/dist/rules/no-default-export.js.map +1 -0
  50. package/dist/rules/no-define-property.d.ts +5 -0
  51. package/dist/rules/no-define-property.d.ts.map +1 -0
  52. package/dist/rules/no-define-property.js +37 -0
  53. package/dist/rules/no-define-property.js.map +1 -0
  54. package/dist/rules/no-delete.d.ts +5 -0
  55. package/dist/rules/no-delete.d.ts.map +1 -0
  56. package/dist/rules/no-delete.js +35 -0
  57. package/dist/rules/no-delete.js.map +1 -0
  58. package/dist/rules/no-empty-string.d.ts +5 -0
  59. package/dist/rules/no-empty-string.d.ts.map +1 -0
  60. package/dist/rules/no-empty-string.js +24 -0
  61. package/dist/rules/no-empty-string.js.map +1 -0
  62. package/dist/rules/no-eval.d.ts +5 -0
  63. package/dist/rules/no-eval.d.ts.map +1 -0
  64. package/dist/rules/no-eval.js +33 -0
  65. package/dist/rules/no-eval.js.map +1 -0
  66. package/dist/rules/no-floating-promise.d.ts +5 -0
  67. package/dist/rules/no-floating-promise.d.ts.map +1 -0
  68. package/dist/rules/no-floating-promise.js +74 -0
  69. package/dist/rules/no-floating-promise.js.map +1 -0
  70. package/dist/rules/no-for-in.d.ts +5 -0
  71. package/dist/rules/no-for-in.d.ts.map +1 -0
  72. package/dist/rules/no-for-in.js +24 -0
  73. package/dist/rules/no-for-in.js.map +1 -0
  74. package/dist/rules/no-generic-names.d.ts +12 -0
  75. package/dist/rules/no-generic-names.d.ts.map +1 -0
  76. package/dist/rules/no-generic-names.js +104 -0
  77. package/dist/rules/no-generic-names.js.map +1 -0
  78. package/dist/rules/no-implicit-coercion.d.ts +7 -0
  79. package/dist/rules/no-implicit-coercion.d.ts.map +1 -0
  80. package/dist/rules/no-implicit-coercion.js +33 -0
  81. package/dist/rules/no-implicit-coercion.js.map +1 -0
  82. package/dist/rules/no-legacy-globals.d.ts +7 -0
  83. package/dist/rules/no-legacy-globals.d.ts.map +1 -0
  84. package/dist/rules/no-legacy-globals.js +58 -0
  85. package/dist/rules/no-legacy-globals.js.map +1 -0
  86. package/dist/rules/no-loop-func.d.ts +5 -0
  87. package/dist/rules/no-loop-func.d.ts.map +1 -0
  88. package/dist/rules/no-loop-func.js +50 -0
  89. package/dist/rules/no-loop-func.js.map +1 -0
  90. package/dist/rules/no-map-set-mutation.d.ts +5 -0
  91. package/dist/rules/no-map-set-mutation.d.ts.map +1 -0
  92. package/dist/rules/no-map-set-mutation.js +69 -0
  93. package/dist/rules/no-map-set-mutation.js.map +1 -0
  94. package/dist/rules/no-mutable-exports.d.ts +5 -0
  95. package/dist/rules/no-mutable-exports.d.ts.map +1 -0
  96. package/dist/rules/no-mutable-exports.js +29 -0
  97. package/dist/rules/no-mutable-exports.js.map +1 -0
  98. package/dist/rules/no-nan-array-indexof.d.ts +5 -0
  99. package/dist/rules/no-nan-array-indexof.d.ts.map +1 -0
  100. package/dist/rules/no-nan-array-indexof.js +33 -0
  101. package/dist/rules/no-nan-array-indexof.js.map +1 -0
  102. package/dist/rules/no-nan-in-math-result.d.ts +5 -0
  103. package/dist/rules/no-nan-in-math-result.d.ts.map +1 -0
  104. package/dist/rules/no-nan-in-math-result.js +58 -0
  105. package/dist/rules/no-nan-in-math-result.js.map +1 -0
  106. package/dist/rules/no-nan.d.ts +5 -0
  107. package/dist/rules/no-nan.d.ts.map +1 -0
  108. package/dist/rules/no-nan.js +26 -0
  109. package/dist/rules/no-nan.js.map +1 -0
  110. package/dist/rules/no-new-wrappers.d.ts +5 -0
  111. package/dist/rules/no-new-wrappers.d.ts.map +1 -0
  112. package/dist/rules/no-new-wrappers.js +47 -0
  113. package/dist/rules/no-new-wrappers.js.map +1 -0
  114. package/dist/rules/no-new.d.ts +5 -0
  115. package/dist/rules/no-new.d.ts.map +1 -0
  116. package/dist/rules/no-new.js +111 -0
  117. package/dist/rules/no-new.js.map +1 -0
  118. package/dist/rules/no-non-null-assertion.d.ts +5 -0
  119. package/dist/rules/no-non-null-assertion.d.ts.map +1 -0
  120. package/dist/rules/no-non-null-assertion.js +22 -0
  121. package/dist/rules/no-non-null-assertion.js.map +1 -0
  122. package/dist/rules/no-null-undefined.d.ts +7 -0
  123. package/dist/rules/no-null-undefined.d.ts.map +1 -0
  124. package/dist/rules/no-null-undefined.js +34 -0
  125. package/dist/rules/no-null-undefined.js.map +1 -0
  126. package/dist/rules/no-nullish-operators.d.ts +7 -0
  127. package/dist/rules/no-nullish-operators.d.ts.map +1 -0
  128. package/dist/rules/no-nullish-operators.js +31 -0
  129. package/dist/rules/no-nullish-operators.js.map +1 -0
  130. package/dist/rules/no-object-assign-mutation.d.ts +5 -0
  131. package/dist/rules/no-object-assign-mutation.d.ts.map +1 -0
  132. package/dist/rules/no-object-assign-mutation.js +36 -0
  133. package/dist/rules/no-object-assign-mutation.js.map +1 -0
  134. package/dist/rules/no-param-reassign.d.ts +5 -0
  135. package/dist/rules/no-param-reassign.d.ts.map +1 -0
  136. package/dist/rules/no-param-reassign.js +89 -0
  137. package/dist/rules/no-param-reassign.js.map +1 -0
  138. package/dist/rules/no-parseint-nan.d.ts +5 -0
  139. package/dist/rules/no-parseint-nan.d.ts.map +1 -0
  140. package/dist/rules/no-parseint-nan.js +64 -0
  141. package/dist/rules/no-parseint-nan.js.map +1 -0
  142. package/dist/rules/no-placeholder-names.d.ts +12 -0
  143. package/dist/rules/no-placeholder-names.d.ts.map +1 -0
  144. package/dist/rules/no-placeholder-names.js +107 -0
  145. package/dist/rules/no-placeholder-names.js.map +1 -0
  146. package/dist/rules/no-process-env.d.ts +5 -0
  147. package/dist/rules/no-process-env.d.ts.map +1 -0
  148. package/dist/rules/no-process-env.js +31 -0
  149. package/dist/rules/no-process-env.js.map +1 -0
  150. package/dist/rules/no-prototype-mutation.d.ts +5 -0
  151. package/dist/rules/no-prototype-mutation.d.ts.map +1 -0
  152. package/dist/rules/no-prototype-mutation.js +30 -0
  153. package/dist/rules/no-prototype-mutation.js.map +1 -0
  154. package/dist/rules/no-require.d.ts +5 -0
  155. package/dist/rules/no-require.d.ts.map +1 -0
  156. package/dist/rules/no-require.js +37 -0
  157. package/dist/rules/no-require.js.map +1 -0
  158. package/dist/rules/no-shadow.d.ts +5 -0
  159. package/dist/rules/no-shadow.d.ts.map +1 -0
  160. package/dist/rules/no-shadow.js +103 -0
  161. package/dist/rules/no-shadow.js.map +1 -0
  162. package/dist/rules/no-string-concat.d.ts +5 -0
  163. package/dist/rules/no-string-concat.d.ts.map +1 -0
  164. package/dist/rules/no-string-concat.js +36 -0
  165. package/dist/rules/no-string-concat.js.map +1 -0
  166. package/dist/rules/no-throw-literal.d.ts +5 -0
  167. package/dist/rules/no-throw-literal.d.ts.map +1 -0
  168. package/dist/rules/no-throw-literal.js +33 -0
  169. package/dist/rules/no-throw-literal.js.map +1 -0
  170. package/dist/rules/no-type-assertion.d.ts +5 -0
  171. package/dist/rules/no-type-assertion.d.ts.map +1 -0
  172. package/dist/rules/no-type-assertion.js +25 -0
  173. package/dist/rules/no-type-assertion.js.map +1 -0
  174. package/dist/rules/no-typeof.d.ts +5 -0
  175. package/dist/rules/no-typeof.d.ts.map +1 -0
  176. package/dist/rules/no-typeof.js +24 -0
  177. package/dist/rules/no-typeof.js.map +1 -0
  178. package/dist/rules/no-unknown.d.ts +5 -0
  179. package/dist/rules/no-unknown.d.ts.map +1 -0
  180. package/dist/rules/no-unknown.js +22 -0
  181. package/dist/rules/no-unknown.js.map +1 -0
  182. package/dist/rules/prefer-includes.d.ts +5 -0
  183. package/dist/rules/prefer-includes.d.ts.map +1 -0
  184. package/dist/rules/prefer-includes.js +50 -0
  185. package/dist/rules/prefer-includes.js.map +1 -0
  186. package/dist/rules/prefer-readonly-params.d.ts +5 -0
  187. package/dist/rules/prefer-readonly-params.d.ts.map +1 -0
  188. package/dist/rules/prefer-readonly-params.js +100 -0
  189. package/dist/rules/prefer-readonly-params.js.map +1 -0
  190. package/dist/rules/require-boolean-condition.d.ts +5 -0
  191. package/dist/rules/require-boolean-condition.d.ts.map +1 -0
  192. package/dist/rules/require-boolean-condition.js +60 -0
  193. package/dist/rules/require-boolean-condition.js.map +1 -0
  194. package/dist/rules/require-curly.d.ts +5 -0
  195. package/dist/rules/require-curly.d.ts.map +1 -0
  196. package/dist/rules/require-curly.js +55 -0
  197. package/dist/rules/require-curly.js.map +1 -0
  198. package/dist/rules/require-explicit-return-type.d.ts +5 -0
  199. package/dist/rules/require-explicit-return-type.d.ts.map +1 -0
  200. package/dist/rules/require-explicit-return-type.js +66 -0
  201. package/dist/rules/require-explicit-return-type.js.map +1 -0
  202. package/dist/rules/require-private-constructor.d.ts +5 -0
  203. package/dist/rules/require-private-constructor.d.ts.map +1 -0
  204. package/dist/rules/require-private-constructor.js +34 -0
  205. package/dist/rules/require-private-constructor.js.map +1 -0
  206. package/dist/rules/same-type-comparison.d.ts +5 -0
  207. package/dist/rules/same-type-comparison.d.ts.map +1 -0
  208. package/dist/rules/same-type-comparison.js +71 -0
  209. package/dist/rules/same-type-comparison.js.map +1 -0
  210. package/package.json +46 -0
@@ -0,0 +1,107 @@
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
+ const DEFAULT_BLOCKLIST = [
4
+ "foo", "bar", "baz", "qux", "quux", "foobar", "foobaz", "fooqux",
5
+ "asdf", "qwerty", "aaa", "bbb", "ccc", "ddd", "eee",
6
+ "abc", "abcd", "zzz",
7
+ "temp1", "temp2", "temp3", "test1", "test2",
8
+ "var1", "var2", "val1", "val2",
9
+ "dummy", "placeholder", "lorem",
10
+ ];
11
+ const LOOP_LETTERS = new Set(["i", "j", "k", "n", "m", "l"]);
12
+ const MATH_LETTERS = new Set(["x", "y", "z", "w", "r", "t", "s", "u", "v"]);
13
+ const LOOP_NODE_TYPES = new Set([
14
+ AST_NODE_TYPES.ForStatement,
15
+ AST_NODE_TYPES.ForInStatement,
16
+ AST_NODE_TYPES.ForOfStatement,
17
+ AST_NODE_TYPES.WhileStatement,
18
+ AST_NODE_TYPES.DoWhileStatement,
19
+ ]);
20
+ function isInsideLoop(node) {
21
+ let current = node.parent;
22
+ while (current) {
23
+ if (LOOP_NODE_TYPES.has(current.type))
24
+ return true;
25
+ current = current.parent;
26
+ }
27
+ return false;
28
+ }
29
+ function isDeclarationSite(node) {
30
+ const p = node.parent;
31
+ if (!p)
32
+ return false;
33
+ if (p.type === AST_NODE_TYPES.VariableDeclarator && p.id === node)
34
+ return true;
35
+ if (p.type === AST_NODE_TYPES.FunctionDeclaration && p.id === node)
36
+ return true;
37
+ if (p.type === AST_NODE_TYPES.ClassDeclaration && p.id === node)
38
+ return true;
39
+ if (p.type === AST_NODE_TYPES.FunctionDeclaration ||
40
+ p.type === AST_NODE_TYPES.FunctionExpression ||
41
+ p.type === AST_NODE_TYPES.ArrowFunctionExpression) {
42
+ if (p.params.some((param) => param === node))
43
+ return true;
44
+ }
45
+ if (p.type === AST_NODE_TYPES.Property && p.value === node) {
46
+ if (p.parent.type === AST_NODE_TYPES.ObjectPattern)
47
+ return true;
48
+ }
49
+ return false;
50
+ }
51
+ export const noPlaceholderNames = createRule({
52
+ name: "no-placeholder-names",
53
+ meta: {
54
+ type: "problem",
55
+ docs: {
56
+ description: "Disallow placeholder or meaningless identifier names",
57
+ },
58
+ schema: [
59
+ {
60
+ type: "object",
61
+ properties: {
62
+ blocklist: {
63
+ type: "array",
64
+ items: { type: "string" },
65
+ },
66
+ allowSingleLetterInLoops: {
67
+ type: "boolean",
68
+ },
69
+ },
70
+ additionalProperties: false,
71
+ },
72
+ ],
73
+ messages: {
74
+ placeholderName: "'{{name}}' is a placeholder name. Use a meaningful, descriptive name.",
75
+ },
76
+ },
77
+ defaultOptions: [{}],
78
+ create(context) {
79
+ const [opts = {}] = context.options;
80
+ const { blocklist: extraBlocklist = [], allowSingleLetterInLoops: allowLoops = true } = opts;
81
+ const blocklist = new Set([
82
+ ...DEFAULT_BLOCKLIST.map((n) => n.toLowerCase()),
83
+ ...extraBlocklist.map((n) => n.toLowerCase()),
84
+ ]);
85
+ return {
86
+ Identifier(node) {
87
+ if (!isDeclarationSite(node))
88
+ return;
89
+ const lower = node.name.toLowerCase();
90
+ if (node.name.length === 1) {
91
+ if (MATH_LETTERS.has(lower))
92
+ return;
93
+ if (allowLoops && LOOP_LETTERS.has(lower) && isInsideLoop(node))
94
+ return;
95
+ }
96
+ if (blocklist.has(lower)) {
97
+ context.report({
98
+ node,
99
+ messageId: "placeholderName",
100
+ data: { name: node.name },
101
+ });
102
+ }
103
+ },
104
+ };
105
+ },
106
+ });
107
+ //# sourceMappingURL=no-placeholder-names.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-placeholder-names.js","sourceRoot":"","sources":["../../src/rules/no-placeholder-names.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const noProcessEnv: ESLintUtils.RuleModule<"noProcessEnv", [], unknown, ESLintUtils.RuleListener> & {
3
+ name: string;
4
+ };
5
+ //# sourceMappingURL=no-process-env.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-process-env.d.ts","sourceRoot":"","sources":["../../src/rules/no-process-env.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAUhE,eAAO,MAAM,YAAY;;CA+BvB,CAAA"}
@@ -0,0 +1,31 @@
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 noProcessEnv = createRule({
4
+ name: "no-process-env",
5
+ meta: {
6
+ type: "suggestion",
7
+ docs: {
8
+ description: "Disallow direct process.env access. Use a typed config object instead.",
9
+ },
10
+ schema: [],
11
+ messages: {
12
+ noProcessEnv: "Do not access process.env directly. Centralize environment variables in a typed config module.",
13
+ },
14
+ },
15
+ defaultOptions: [],
16
+ create(context) {
17
+ return {
18
+ MemberExpression(node) {
19
+ const objectNode = node.object;
20
+ const prop = node.property;
21
+ if (objectNode.type === "Identifier" &&
22
+ objectNode.name === "process" &&
23
+ prop.type === "Identifier" &&
24
+ prop.name === "env") {
25
+ context.report({ node, messageId: "noProcessEnv" });
26
+ }
27
+ },
28
+ };
29
+ },
30
+ });
31
+ //# sourceMappingURL=no-process-env.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-process-env.js","sourceRoot":"","sources":["../../src/rules/no-process-env.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,YAAY,GAAG,UAAU,CAAsB;IAC1D,IAAI,EAAE,gBAAgB;IACtB,IAAI,EAAE;QACJ,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE;YACJ,WAAW,EAAE,wEAAwE;SACtF;QACD,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE;YACR,YAAY,EACV,gGAAgG;SACnG;KACF;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,gBAAgB,CAAC,IAA+B;gBAC9C,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAA;gBAC9B,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAA;gBAE1B,IACE,UAAU,CAAC,IAAI,KAAK,YAAY;oBAChC,UAAU,CAAC,IAAI,KAAK,SAAS;oBAC7B,IAAI,CAAC,IAAI,KAAK,YAAY;oBAC1B,IAAI,CAAC,IAAI,KAAK,KAAK,EACnB,CAAC;oBACD,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,cAAc,EAAE,CAAC,CAAA;gBACrD,CAAC;YACH,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const noPrototypeMutation: ESLintUtils.RuleModule<"noPrototypeMutation", [], unknown, ESLintUtils.RuleListener> & {
3
+ name: string;
4
+ };
5
+ //# sourceMappingURL=no-prototype-mutation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-prototype-mutation.d.ts","sourceRoot":"","sources":["../../src/rules/no-prototype-mutation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAUhE,eAAO,MAAM,mBAAmB;;CA8B9B,CAAA"}
@@ -0,0 +1,30 @@
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 noPrototypeMutation = createRule({
4
+ name: "no-prototype-mutation",
5
+ meta: {
6
+ type: "problem",
7
+ docs: {
8
+ description: "Disallow mutating prototypes at runtime. Affects all instances across module boundaries.",
9
+ },
10
+ schema: [],
11
+ messages: {
12
+ noPrototypeMutation: "Do not mutate prototypes at runtime. Use class syntax or composition instead.",
13
+ },
14
+ },
15
+ defaultOptions: [],
16
+ create(context) {
17
+ return {
18
+ AssignmentExpression(node) {
19
+ const left = node.left;
20
+ if (left.type === "MemberExpression" &&
21
+ left.object.type === "MemberExpression" &&
22
+ left.object.property.type === "Identifier" &&
23
+ left.object.property.name === "prototype") {
24
+ context.report({ node, messageId: "noPrototypeMutation" });
25
+ }
26
+ },
27
+ };
28
+ },
29
+ });
30
+ //# sourceMappingURL=no-prototype-mutation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-prototype-mutation.js","sourceRoot":"","sources":["../../src/rules/no-prototype-mutation.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,mBAAmB,GAAG,UAAU,CAAsB;IACjE,IAAI,EAAE,uBAAuB;IAC7B,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EACT,0FAA0F;SAC7F;QACD,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE;YACR,mBAAmB,EACjB,+EAA+E;SAClF;KACF;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,oBAAoB,CAAC,IAAmC;gBACtD,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAA;gBACtB,IACE,IAAI,CAAC,IAAI,KAAK,kBAAkB;oBAChC,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,kBAAkB;oBACvC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,KAAK,YAAY;oBAC1C,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,KAAK,WAAW,EACzC,CAAC;oBACD,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC,CAAA;gBAC5D,CAAC;YACH,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const noRequire: ESLintUtils.RuleModule<"noRequire", [], unknown, ESLintUtils.RuleListener> & {
3
+ name: string;
4
+ };
5
+ //# sourceMappingURL=no-require.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-require.d.ts","sourceRoot":"","sources":["../../src/rules/no-require.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAUhE,eAAO,MAAM,SAAS;;CAqCpB,CAAA"}
@@ -0,0 +1,37 @@
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 noRequire = createRule({
4
+ name: "no-require",
5
+ meta: {
6
+ type: "problem",
7
+ docs: { description: "Disallow require() calls. Use ES module import instead." },
8
+ schema: [],
9
+ messages: {
10
+ noRequire: "Do not use require(). Use 'import' instead.",
11
+ },
12
+ },
13
+ defaultOptions: [],
14
+ create(context) {
15
+ return {
16
+ CallExpression(node) {
17
+ const callee = node.callee;
18
+ if (callee.type === "Identifier" && callee.name === "require") {
19
+ context.report({ node, messageId: "noRequire" });
20
+ }
21
+ if (callee.type === "MemberExpression" &&
22
+ callee.object.type === "Identifier" &&
23
+ callee.object.name === "require") {
24
+ context.report({ node, messageId: "noRequire" });
25
+ }
26
+ },
27
+ MemberExpression(node) {
28
+ if (node.object.type === "Identifier" &&
29
+ node.object.name === "require" &&
30
+ node.parent?.type !== "CallExpression") {
31
+ context.report({ node, messageId: "noRequire" });
32
+ }
33
+ },
34
+ };
35
+ },
36
+ });
37
+ //# sourceMappingURL=no-require.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-require.js","sourceRoot":"","sources":["../../src/rules/no-require.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,SAAS,GAAG,UAAU,CAAsB;IACvD,IAAI,EAAE,YAAY;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,EAAE,WAAW,EAAE,yDAAyD,EAAE;QAChF,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE;YACR,SAAS,EAAE,6CAA6C;SACzD;KACF;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,cAAc,CAAC,IAA6B;gBAC1C,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAA;gBAC1B,IAAI,MAAM,CAAC,IAAI,KAAK,YAAY,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;oBAC9D,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC,CAAA;gBAClD,CAAC;gBACD,IACE,MAAM,CAAC,IAAI,KAAK,kBAAkB;oBAClC,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,YAAY;oBACnC,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS,EAChC,CAAC;oBACD,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC,CAAA;gBAClD,CAAC;YACH,CAAC;YACD,gBAAgB,CAAC,IAA+B;gBAC9C,IACE,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,YAAY;oBACjC,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS;oBAC9B,IAAI,CAAC,MAAM,EAAE,IAAI,KAAK,gBAAgB,EACtC,CAAC;oBACD,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC,CAAA;gBAClD,CAAC;YACH,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const noShadow: ESLintUtils.RuleModule<"noShadow", [], unknown, ESLintUtils.RuleListener> & {
3
+ name: string;
4
+ };
5
+ //# sourceMappingURL=no-shadow.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-shadow.d.ts","sourceRoot":"","sources":["../../src/rules/no-shadow.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAkChF,eAAO,MAAM,QAAQ;;CAwFnB,CAAA"}
@@ -0,0 +1,103 @@
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
+ function getNamesFromPattern(node) {
4
+ if (node.type === AST_NODE_TYPES.Identifier)
5
+ return [node.name];
6
+ if (node.type === AST_NODE_TYPES.ObjectPattern) {
7
+ return node.properties.flatMap((p) => {
8
+ if (p.type === AST_NODE_TYPES.RestElement)
9
+ return getNamesFromPattern(p.argument);
10
+ return getNamesFromPattern(p.value);
11
+ });
12
+ }
13
+ if (node.type === AST_NODE_TYPES.ArrayPattern) {
14
+ return node.elements.flatMap((el) => el !== null ? getNamesFromPattern(el) : []);
15
+ }
16
+ if (node.type === AST_NODE_TYPES.AssignmentPattern) {
17
+ return getNamesFromPattern(node.left);
18
+ }
19
+ if (node.type === AST_NODE_TYPES.RestElement) {
20
+ return getNamesFromPattern(node.argument);
21
+ }
22
+ return [];
23
+ }
24
+ export const noShadow = createRule({
25
+ name: "no-shadow",
26
+ meta: {
27
+ type: "problem",
28
+ docs: {
29
+ description: "Disallow variable declarations that shadow outer scope variables",
30
+ },
31
+ schema: [],
32
+ messages: {
33
+ noShadow: "'{{name}}' shadows a variable declared in an outer scope.",
34
+ },
35
+ },
36
+ defaultOptions: [],
37
+ create(context) {
38
+ let scopeStack = [];
39
+ function currentScope() {
40
+ return scopeStack[scopeStack.length - 1];
41
+ }
42
+ function isDeclaredInOuterScope(name) {
43
+ for (let i = scopeStack.length - 2; i >= 0; i--) {
44
+ if (scopeStack[i].has(name))
45
+ return true;
46
+ }
47
+ return false;
48
+ }
49
+ function declareAndCheck(name, node) {
50
+ if (isDeclaredInOuterScope(name)) {
51
+ context.report({ node, messageId: "noShadow", data: { name } });
52
+ }
53
+ currentScope().add(name);
54
+ }
55
+ function pushScope() {
56
+ scopeStack = [...scopeStack, new Set()];
57
+ }
58
+ function popScope() {
59
+ scopeStack = scopeStack.slice(0, -1);
60
+ }
61
+ return {
62
+ Program: pushScope,
63
+ "Program:exit": popScope,
64
+ BlockStatement: pushScope,
65
+ "BlockStatement:exit": popScope,
66
+ FunctionDeclaration(node) {
67
+ if (node.id !== null)
68
+ declareAndCheck(node.id.name, node.id);
69
+ pushScope();
70
+ for (const param of node.params) {
71
+ for (const name of getNamesFromPattern(param)) {
72
+ currentScope().add(name);
73
+ }
74
+ }
75
+ },
76
+ "FunctionDeclaration:exit": popScope,
77
+ FunctionExpression(node) {
78
+ pushScope();
79
+ for (const param of node.params) {
80
+ for (const name of getNamesFromPattern(param)) {
81
+ currentScope().add(name);
82
+ }
83
+ }
84
+ },
85
+ "FunctionExpression:exit": popScope,
86
+ ArrowFunctionExpression(node) {
87
+ pushScope();
88
+ for (const param of node.params) {
89
+ for (const name of getNamesFromPattern(param)) {
90
+ currentScope().add(name);
91
+ }
92
+ }
93
+ },
94
+ "ArrowFunctionExpression:exit": popScope,
95
+ VariableDeclarator(node) {
96
+ for (const name of getNamesFromPattern(node.id)) {
97
+ declareAndCheck(name, node.id);
98
+ }
99
+ },
100
+ };
101
+ },
102
+ });
103
+ //# sourceMappingURL=no-shadow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-shadow.js","sourceRoot":"","sources":["../../src/rules/no-shadow.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const noStringConcat: ESLintUtils.RuleModule<"noStringConcat", [], unknown, ESLintUtils.RuleListener> & {
3
+ name: string;
4
+ };
5
+ //# sourceMappingURL=no-string-concat.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-string-concat.d.ts","sourceRoot":"","sources":["../../src/rules/no-string-concat.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAehE,eAAO,MAAM,cAAc;;CAoCzB,CAAA"}
@@ -0,0 +1,36 @@
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 isStringType(type) {
5
+ return (type.flags & (ts.TypeFlags.String | ts.TypeFlags.StringLiteral)) !== 0;
6
+ }
7
+ export const noStringConcat = createRule({
8
+ name: "no-string-concat",
9
+ meta: {
10
+ type: "suggestion",
11
+ docs: {
12
+ description: "Disallow string concatenation with +. Use template literals instead.",
13
+ },
14
+ schema: [],
15
+ messages: {
16
+ noStringConcat: "Do not concatenate strings with +. Use a template literal (`${...}`) instead.",
17
+ },
18
+ },
19
+ defaultOptions: [],
20
+ create(context) {
21
+ const services = ESLintUtils.getParserServices(context);
22
+ const checker = services.program.getTypeChecker();
23
+ return {
24
+ BinaryExpression(node) {
25
+ if (node.operator !== "+")
26
+ return;
27
+ const leftType = checker.getTypeAtLocation(services.esTreeNodeToTSNodeMap.get(node.left));
28
+ const rightType = checker.getTypeAtLocation(services.esTreeNodeToTSNodeMap.get(node.right));
29
+ if (isStringType(leftType) || isStringType(rightType)) {
30
+ context.report({ node, messageId: "noStringConcat" });
31
+ }
32
+ },
33
+ };
34
+ },
35
+ });
36
+ //# sourceMappingURL=no-string-concat.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-string-concat.js","sourceRoot":"","sources":["../../src/rules/no-string-concat.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,SAAS,YAAY,CAAC,IAAa;IACjC,OAAO,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,GAAG,EAAE,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,CAAA;AAChF,CAAC;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,UAAU,CAAsB;IAC5D,IAAI,EAAE,kBAAkB;IACxB,IAAI,EAAE;QACJ,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE;YACJ,WAAW,EACT,sEAAsE;SACzE;QACD,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE;YACR,cAAc,EACZ,+EAA+E;SAClF;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,gBAAgB,CAAC,IAA+B;gBAC9C,IAAI,IAAI,CAAC,QAAQ,KAAK,GAAG;oBAAE,OAAM;gBAEjC,MAAM,QAAQ,GAAG,OAAO,CAAC,iBAAiB,CACxC,QAAQ,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAC9C,CAAA;gBACD,MAAM,SAAS,GAAG,OAAO,CAAC,iBAAiB,CACzC,QAAQ,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAC/C,CAAA;gBAED,IAAI,YAAY,CAAC,QAAQ,CAAC,IAAI,YAAY,CAAC,SAAS,CAAC,EAAE,CAAC;oBACtD,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC,CAAA;gBACvD,CAAC;YACH,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const noThrowLiteral: ESLintUtils.RuleModule<"noThrowLiteral", [], unknown, ESLintUtils.RuleListener> & {
3
+ name: string;
4
+ };
5
+ //# sourceMappingURL=no-throw-literal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-throw-literal.d.ts","sourceRoot":"","sources":["../../src/rules/no-throw-literal.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAUhE,eAAO,MAAM,cAAc;;CA8BzB,CAAA"}
@@ -0,0 +1,33 @@
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 noThrowLiteral = createRule({
4
+ name: "no-throw-literal",
5
+ meta: {
6
+ type: "problem",
7
+ docs: { description: "Disallow throwing non-Error values" },
8
+ schema: [],
9
+ messages: {
10
+ noThrowLiteral: "Only throw Error instances. Throwing literals or plain objects loses the stack trace.",
11
+ },
12
+ },
13
+ defaultOptions: [],
14
+ create(context) {
15
+ const BANNED = new Set([
16
+ "Literal",
17
+ "TemplateLiteral",
18
+ "ObjectExpression",
19
+ "ArrayExpression",
20
+ ]);
21
+ return {
22
+ ThrowStatement(node) {
23
+ const arg = node.argument;
24
+ if (!arg)
25
+ return;
26
+ if (BANNED.has(arg.type)) {
27
+ context.report({ node, messageId: "noThrowLiteral" });
28
+ }
29
+ },
30
+ };
31
+ },
32
+ });
33
+ //# sourceMappingURL=no-throw-literal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-throw-literal.js","sourceRoot":"","sources":["../../src/rules/no-throw-literal.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,cAAc,GAAG,UAAU,CAAsB;IAC5D,IAAI,EAAE,kBAAkB;IACxB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,EAAE,WAAW,EAAE,oCAAoC,EAAE;QAC3D,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE;YACR,cAAc,EACZ,uFAAuF;SAC1F;KACF;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC;YACrB,SAAS;YACT,iBAAiB;YACjB,kBAAkB;YAClB,iBAAiB;SAClB,CAAC,CAAA;QAEF,OAAO;YACL,cAAc,CAAC,IAA6B;gBAC1C,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAA;gBACzB,IAAI,CAAC,GAAG;oBAAE,OAAM;gBAChB,IAAI,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;oBACzB,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC,CAAA;gBACvD,CAAC;YACH,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const noTypeAssertion: ESLintUtils.RuleModule<"noTypeAssertion", [], unknown, ESLintUtils.RuleListener> & {
3
+ name: string;
4
+ };
5
+ //# sourceMappingURL=no-type-assertion.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-type-assertion.d.ts","sourceRoot":"","sources":["../../src/rules/no-type-assertion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAUhE,eAAO,MAAM,eAAe;;CAsB1B,CAAA"}
@@ -0,0 +1,25 @@
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 noTypeAssertion = createRule({
4
+ name: "no-type-assertion",
5
+ meta: {
6
+ type: "problem",
7
+ docs: { description: "Disallow type assertions (as X and <X>)" },
8
+ schema: [],
9
+ messages: {
10
+ noTypeAssertion: "Do not use type assertions. Structure your types so assertions are unnecessary.",
11
+ },
12
+ },
13
+ defaultOptions: [],
14
+ create(context) {
15
+ return {
16
+ TSAsExpression(node) {
17
+ context.report({ node, messageId: "noTypeAssertion" });
18
+ },
19
+ TSTypeAssertion(node) {
20
+ context.report({ node, messageId: "noTypeAssertion" });
21
+ },
22
+ };
23
+ },
24
+ });
25
+ //# sourceMappingURL=no-type-assertion.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-type-assertion.js","sourceRoot":"","sources":["../../src/rules/no-type-assertion.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,eAAe,GAAG,UAAU,CAAsB;IAC7D,IAAI,EAAE,mBAAmB;IACzB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,EAAE,WAAW,EAAE,yCAAyC,EAAE;QAChE,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE;YACR,eAAe,EACb,iFAAiF;SACpF;KACF;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,cAAc,CAAC,IAA6B;gBAC1C,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,iBAAiB,EAAE,CAAC,CAAA;YACxD,CAAC;YACD,eAAe,CAAC,IAA8B;gBAC5C,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,iBAAiB,EAAE,CAAC,CAAA;YACxD,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const noTypeof: ESLintUtils.RuleModule<"noTypeof", [], unknown, ESLintUtils.RuleListener> & {
3
+ name: string;
4
+ };
5
+ //# sourceMappingURL=no-typeof.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-typeof.d.ts","sourceRoot":"","sources":["../../src/rules/no-typeof.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAUhE,eAAO,MAAM,QAAQ;;CAqBnB,CAAA"}
@@ -0,0 +1,24 @@
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 noTypeof = createRule({
4
+ name: "no-typeof",
5
+ meta: {
6
+ type: "problem",
7
+ docs: { description: "Disallow the typeof operator" },
8
+ schema: [],
9
+ messages: {
10
+ noTypeof: "Do not use typeof. Use TypeScript types and proper type narrowing instead.",
11
+ },
12
+ },
13
+ defaultOptions: [],
14
+ create(context) {
15
+ return {
16
+ UnaryExpression(node) {
17
+ if (node.operator === "typeof") {
18
+ context.report({ node, messageId: "noTypeof" });
19
+ }
20
+ },
21
+ };
22
+ },
23
+ });
24
+ //# sourceMappingURL=no-typeof.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-typeof.js","sourceRoot":"","sources":["../../src/rules/no-typeof.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,QAAQ,GAAG,UAAU,CAAsB;IACtD,IAAI,EAAE,WAAW;IACjB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,EAAE,WAAW,EAAE,8BAA8B,EAAE;QACrD,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE;YACR,QAAQ,EACN,4EAA4E;SAC/E;KACF;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,eAAe,CAAC,IAA8B;gBAC5C,IAAI,IAAI,CAAC,QAAQ,KAAK,QAAQ,EAAE,CAAC;oBAC/B,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC,CAAA;gBACjD,CAAC;YACH,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const noUnknown: ESLintUtils.RuleModule<"noUnknown", [], unknown, ESLintUtils.RuleListener> & {
3
+ name: string;
4
+ };
5
+ //# sourceMappingURL=no-unknown.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-unknown.d.ts","sourceRoot":"","sources":["../../src/rules/no-unknown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAUhE,eAAO,MAAM,SAAS;;CAkBpB,CAAA"}
@@ -0,0 +1,22 @@
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 noUnknown = createRule({
4
+ name: "no-unknown",
5
+ meta: {
6
+ type: "problem",
7
+ docs: { description: "Disallow the unknown type" },
8
+ schema: [],
9
+ messages: {
10
+ noUnknown: "Do not use 'unknown'. Use a specific type instead.",
11
+ },
12
+ },
13
+ defaultOptions: [],
14
+ create(context) {
15
+ return {
16
+ TSUnknownKeyword(node) {
17
+ context.report({ node, messageId: "noUnknown" });
18
+ },
19
+ };
20
+ },
21
+ });
22
+ //# sourceMappingURL=no-unknown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-unknown.js","sourceRoot":"","sources":["../../src/rules/no-unknown.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,SAAS,GAAG,UAAU,CAAsB;IACvD,IAAI,EAAE,YAAY;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,EAAE,WAAW,EAAE,2BAA2B,EAAE;QAClD,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE;YACR,SAAS,EAAE,oDAAoD;SAChE;KACF;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,gBAAgB,CAAC,IAA+B;gBAC9C,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC,CAAA;YAClD,CAAC;SACF,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const preferIncludes: ESLintUtils.RuleModule<"preferIncludes", [], unknown, ESLintUtils.RuleListener> & {
3
+ name: string;
4
+ };
5
+ //# sourceMappingURL=prefer-includes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prefer-includes.d.ts","sourceRoot":"","sources":["../../src/rules/prefer-includes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,0BAA0B,CAAA;AAgChE,eAAO,MAAM,cAAc;;CAmCzB,CAAA"}