vibe-and-thrive 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (145) hide show
  1. package/.claude/commands/add-tests.md +240 -0
  2. package/.claude/commands/e2e-scaffold.md +212 -0
  3. package/.claude/commands/explain.md +110 -0
  4. package/.claude/commands/fix-types.md +238 -0
  5. package/.claude/commands/refactor.md +184 -0
  6. package/.claude/commands/review.md +136 -0
  7. package/.claude/commands/security-check.md +223 -0
  8. package/.claude/commands/styleguide.md +446 -0
  9. package/.claude/commands/tdd-feature.md +227 -0
  10. package/.claude/commands/vibe-check.md +112 -0
  11. package/.pre-commit-hooks.yaml +77 -0
  12. package/LICENSE +21 -0
  13. package/README.md +167 -0
  14. package/bin/vibe-check.js +19 -0
  15. package/dist/cli.d.ts +13 -0
  16. package/dist/cli.d.ts.map +1 -0
  17. package/dist/cli.js +206 -0
  18. package/dist/cli.js.map +1 -0
  19. package/dist/eslint-plugin/index.d.ts +66 -0
  20. package/dist/eslint-plugin/index.d.ts.map +1 -0
  21. package/dist/eslint-plugin/index.js +67 -0
  22. package/dist/eslint-plugin/index.js.map +1 -0
  23. package/dist/eslint-plugin/rules/max-function-length.d.ts +8 -0
  24. package/dist/eslint-plugin/rules/max-function-length.d.ts.map +1 -0
  25. package/dist/eslint-plugin/rules/max-function-length.js +69 -0
  26. package/dist/eslint-plugin/rules/max-function-length.js.map +1 -0
  27. package/dist/eslint-plugin/rules/no-any-type.d.ts +8 -0
  28. package/dist/eslint-plugin/rules/no-any-type.d.ts.map +1 -0
  29. package/dist/eslint-plugin/rules/no-any-type.js +29 -0
  30. package/dist/eslint-plugin/rules/no-any-type.js.map +1 -0
  31. package/dist/eslint-plugin/rules/no-debug-statements.d.ts +8 -0
  32. package/dist/eslint-plugin/rules/no-debug-statements.d.ts.map +1 -0
  33. package/dist/eslint-plugin/rules/no-debug-statements.js +59 -0
  34. package/dist/eslint-plugin/rules/no-debug-statements.js.map +1 -0
  35. package/dist/eslint-plugin/rules/no-deep-nesting.d.ts +8 -0
  36. package/dist/eslint-plugin/rules/no-deep-nesting.d.ts.map +1 -0
  37. package/dist/eslint-plugin/rules/no-deep-nesting.js +56 -0
  38. package/dist/eslint-plugin/rules/no-deep-nesting.js.map +1 -0
  39. package/dist/eslint-plugin/rules/no-empty-catch.d.ts +8 -0
  40. package/dist/eslint-plugin/rules/no-empty-catch.d.ts.map +1 -0
  41. package/dist/eslint-plugin/rules/no-empty-catch.js +31 -0
  42. package/dist/eslint-plugin/rules/no-empty-catch.js.map +1 -0
  43. package/dist/eslint-plugin/rules/no-magic-numbers.d.ts +8 -0
  44. package/dist/eslint-plugin/rules/no-magic-numbers.d.ts.map +1 -0
  45. package/dist/eslint-plugin/rules/no-magic-numbers.js +58 -0
  46. package/dist/eslint-plugin/rules/no-magic-numbers.js.map +1 -0
  47. package/dist/eslint-plugin/rules/no-snake-case-props.d.ts +8 -0
  48. package/dist/eslint-plugin/rules/no-snake-case-props.d.ts.map +1 -0
  49. package/dist/eslint-plugin/rules/no-snake-case-props.js +48 -0
  50. package/dist/eslint-plugin/rules/no-snake-case-props.js.map +1 -0
  51. package/dist/hooks/check-any-types.d.ts +6 -0
  52. package/dist/hooks/check-any-types.d.ts.map +1 -0
  53. package/dist/hooks/check-any-types.js +73 -0
  54. package/dist/hooks/check-any-types.js.map +1 -0
  55. package/dist/hooks/check-commented-code.d.ts +6 -0
  56. package/dist/hooks/check-commented-code.d.ts.map +1 -0
  57. package/dist/hooks/check-commented-code.js +81 -0
  58. package/dist/hooks/check-commented-code.js.map +1 -0
  59. package/dist/hooks/check-console-error.d.ts +6 -0
  60. package/dist/hooks/check-console-error.d.ts.map +1 -0
  61. package/dist/hooks/check-console-error.js +41 -0
  62. package/dist/hooks/check-console-error.js.map +1 -0
  63. package/dist/hooks/check-debug-statements.d.ts +6 -0
  64. package/dist/hooks/check-debug-statements.d.ts.map +1 -0
  65. package/dist/hooks/check-debug-statements.js +120 -0
  66. package/dist/hooks/check-debug-statements.js.map +1 -0
  67. package/dist/hooks/check-deep-nesting.d.ts +6 -0
  68. package/dist/hooks/check-deep-nesting.d.ts.map +1 -0
  69. package/dist/hooks/check-deep-nesting.js +116 -0
  70. package/dist/hooks/check-deep-nesting.js.map +1 -0
  71. package/dist/hooks/check-docker-platform.d.ts +6 -0
  72. package/dist/hooks/check-docker-platform.d.ts.map +1 -0
  73. package/dist/hooks/check-docker-platform.js +42 -0
  74. package/dist/hooks/check-docker-platform.js.map +1 -0
  75. package/dist/hooks/check-dry-violations.d.ts +6 -0
  76. package/dist/hooks/check-dry-violations.d.ts.map +1 -0
  77. package/dist/hooks/check-dry-violations.js +124 -0
  78. package/dist/hooks/check-dry-violations.js.map +1 -0
  79. package/dist/hooks/check-empty-catch.d.ts +6 -0
  80. package/dist/hooks/check-empty-catch.d.ts.map +1 -0
  81. package/dist/hooks/check-empty-catch.js +111 -0
  82. package/dist/hooks/check-empty-catch.js.map +1 -0
  83. package/dist/hooks/check-function-length.d.ts +6 -0
  84. package/dist/hooks/check-function-length.d.ts.map +1 -0
  85. package/dist/hooks/check-function-length.js +152 -0
  86. package/dist/hooks/check-function-length.js.map +1 -0
  87. package/dist/hooks/check-hardcoded-urls.d.ts +6 -0
  88. package/dist/hooks/check-hardcoded-urls.d.ts.map +1 -0
  89. package/dist/hooks/check-hardcoded-urls.js +124 -0
  90. package/dist/hooks/check-hardcoded-urls.js.map +1 -0
  91. package/dist/hooks/check-magic-numbers.d.ts +6 -0
  92. package/dist/hooks/check-magic-numbers.d.ts.map +1 -0
  93. package/dist/hooks/check-magic-numbers.js +116 -0
  94. package/dist/hooks/check-magic-numbers.js.map +1 -0
  95. package/dist/hooks/check-secrets.d.ts +6 -0
  96. package/dist/hooks/check-secrets.d.ts.map +1 -0
  97. package/dist/hooks/check-secrets.js +138 -0
  98. package/dist/hooks/check-secrets.js.map +1 -0
  99. package/dist/hooks/check-snake-case-ts.d.ts +6 -0
  100. package/dist/hooks/check-snake-case-ts.d.ts.map +1 -0
  101. package/dist/hooks/check-snake-case-ts.js +78 -0
  102. package/dist/hooks/check-snake-case-ts.js.map +1 -0
  103. package/dist/hooks/check-todo-fixme.d.ts +6 -0
  104. package/dist/hooks/check-todo-fixme.d.ts.map +1 -0
  105. package/dist/hooks/check-todo-fixme.js +41 -0
  106. package/dist/hooks/check-todo-fixme.js.map +1 -0
  107. package/dist/hooks/check-unsafe-html.d.ts +6 -0
  108. package/dist/hooks/check-unsafe-html.d.ts.map +1 -0
  109. package/dist/hooks/check-unsafe-html.js +101 -0
  110. package/dist/hooks/check-unsafe-html.js.map +1 -0
  111. package/dist/hooks/index.d.ts +29 -0
  112. package/dist/hooks/index.d.ts.map +1 -0
  113. package/dist/hooks/index.js +54 -0
  114. package/dist/hooks/index.js.map +1 -0
  115. package/dist/index.d.ts +9 -0
  116. package/dist/index.d.ts.map +1 -0
  117. package/dist/index.js +10 -0
  118. package/dist/index.js.map +1 -0
  119. package/dist/lint-staged/config.d.ts +20 -0
  120. package/dist/lint-staged/config.d.ts.map +1 -0
  121. package/dist/lint-staged/config.js +27 -0
  122. package/dist/lint-staged/config.js.map +1 -0
  123. package/dist/utils/file-reader.d.ts +24 -0
  124. package/dist/utils/file-reader.d.ts.map +1 -0
  125. package/dist/utils/file-reader.js +140 -0
  126. package/dist/utils/file-reader.js.map +1 -0
  127. package/dist/utils/patterns.d.ts +27 -0
  128. package/dist/utils/patterns.d.ts.map +1 -0
  129. package/dist/utils/patterns.js +84 -0
  130. package/dist/utils/patterns.js.map +1 -0
  131. package/dist/utils/reporters.d.ts +21 -0
  132. package/dist/utils/reporters.d.ts.map +1 -0
  133. package/dist/utils/reporters.js +115 -0
  134. package/dist/utils/reporters.js.map +1 -0
  135. package/dist/utils/types.d.ts +71 -0
  136. package/dist/utils/types.d.ts.map +1 -0
  137. package/dist/utils/types.js +5 -0
  138. package/dist/utils/types.js.map +1 -0
  139. package/integrations/cursorrules.template +147 -0
  140. package/integrations/eslint.config.js +34 -0
  141. package/integrations/lint-staged.config.js +34 -0
  142. package/integrations/ruff.toml +125 -0
  143. package/integrations/vibe-check.yml +116 -0
  144. package/integrations/vscode-settings.json +127 -0
  145. package/package.json +81 -0
package/dist/cli.js ADDED
@@ -0,0 +1,206 @@
1
+ /**
2
+ * CLI entry point for vibe-check
3
+ */
4
+ import * as path from 'node:path';
5
+ import { resolveFiles, readFile, getExtension } from './utils/file-reader.js';
6
+ import { formatResults } from './utils/reporters.js';
7
+ import { hooks, getHooksForFile } from './hooks/index.js';
8
+ /**
9
+ * Parse command line arguments
10
+ */
11
+ function parseArgs(args) {
12
+ const files = [];
13
+ const options = {
14
+ format: 'pretty',
15
+ failOn: 'error',
16
+ };
17
+ let i = 0;
18
+ while (i < args.length) {
19
+ const arg = args[i];
20
+ if (arg === '--only' && args[i + 1]) {
21
+ options.only = args[i + 1].split(',').map((s) => s.trim());
22
+ i += 2;
23
+ }
24
+ else if (arg === '--skip' && args[i + 1]) {
25
+ options.skip = args[i + 1].split(',').map((s) => s.trim());
26
+ i += 2;
27
+ }
28
+ else if (arg === '--format' && args[i + 1]) {
29
+ const format = args[i + 1];
30
+ if (['pretty', 'json', 'compact'].includes(format)) {
31
+ options.format = format;
32
+ }
33
+ i += 2;
34
+ }
35
+ else if (arg === '--fail-on' && args[i + 1]) {
36
+ const failOn = args[i + 1];
37
+ if (['error', 'warning', 'info', 'none'].includes(failOn)) {
38
+ options.failOn = failOn === 'none' ? undefined : failOn;
39
+ }
40
+ i += 2;
41
+ }
42
+ else if (arg === '--fix') {
43
+ options.fix = true;
44
+ i += 1;
45
+ }
46
+ else if (arg === '--help' || arg === '-h') {
47
+ printHelp();
48
+ process.exit(0);
49
+ }
50
+ else if (arg === '--version' || arg === '-v') {
51
+ console.log('vibe-check 1.0.0');
52
+ process.exit(0);
53
+ }
54
+ else if (!arg.startsWith('-')) {
55
+ files.push(arg);
56
+ i += 1;
57
+ }
58
+ else {
59
+ console.error(`Unknown option: ${arg}`);
60
+ process.exit(2);
61
+ }
62
+ }
63
+ return { files, options };
64
+ }
65
+ /**
66
+ * Print help message
67
+ */
68
+ function printHelp() {
69
+ console.log(`
70
+ vibe-check - Catch common AI-generated code issues
71
+
72
+ Usage:
73
+ vibe-check [options] <files...>
74
+
75
+ Options:
76
+ --only <hooks> Only run specified hooks (comma-separated)
77
+ --skip <hooks> Skip specified hooks (comma-separated)
78
+ --format <format> Output format: pretty, json, compact (default: pretty)
79
+ --fail-on <level> Fail on severity level: error, warning, info, none (default: error)
80
+ --fix Auto-fix issues where possible
81
+ -h, --help Show this help message
82
+ -v, --version Show version
83
+
84
+ Examples:
85
+ vibe-check .
86
+ vibe-check src/
87
+ vibe-check --only secrets,urls .
88
+ vibe-check --skip any-types,snake-case .
89
+ vibe-check --format json .
90
+
91
+ Available hooks:
92
+ ${hooks.map((h) => ` ${h.id.padEnd(20)} ${h.description}`).join('\n')}
93
+ `);
94
+ }
95
+ /**
96
+ * Check a single file with applicable hooks
97
+ */
98
+ function checkFile(filePath, options) {
99
+ const extension = getExtension(filePath);
100
+ const content = readFile(filePath);
101
+ const context = {
102
+ filePath,
103
+ content,
104
+ extension,
105
+ };
106
+ // Get hooks for this file type
107
+ let applicableHooks = getHooksForFile(extension);
108
+ // Filter by --only
109
+ if (options.only && options.only.length > 0) {
110
+ applicableHooks = applicableHooks.filter((h) => options.only.includes(h.id));
111
+ }
112
+ // Filter by --skip
113
+ if (options.skip && options.skip.length > 0) {
114
+ applicableHooks = applicableHooks.filter((h) => !options.skip.includes(h.id));
115
+ }
116
+ // Run all applicable hooks
117
+ const issues = [];
118
+ for (const hook of applicableHooks) {
119
+ try {
120
+ const hookIssues = hook.check(context);
121
+ issues.push(...hookIssues);
122
+ }
123
+ catch (error) {
124
+ // Skip hooks that fail - don't crash the whole check
125
+ console.error(`Warning: Hook "${hook.id}" failed on ${filePath}: ${error}`);
126
+ }
127
+ }
128
+ // Sort issues by line number
129
+ issues.sort((a, b) => a.line - b.line);
130
+ return {
131
+ filePath: path.relative(process.cwd(), filePath),
132
+ issues,
133
+ };
134
+ }
135
+ /**
136
+ * Main vibe-check function
137
+ */
138
+ export function vibeCheck(files, options = {}) {
139
+ const resolvedFiles = resolveFiles(files);
140
+ const results = [];
141
+ for (const file of resolvedFiles) {
142
+ const result = checkFile(file, options);
143
+ results.push(result);
144
+ }
145
+ // Calculate summary
146
+ let errorCount = 0;
147
+ let warningCount = 0;
148
+ let infoCount = 0;
149
+ let filesWithIssues = 0;
150
+ for (const result of results) {
151
+ if (result.issues.length > 0) {
152
+ filesWithIssues++;
153
+ }
154
+ for (const issue of result.issues) {
155
+ switch (issue.severity) {
156
+ case 'error':
157
+ errorCount++;
158
+ break;
159
+ case 'warning':
160
+ warningCount++;
161
+ break;
162
+ case 'info':
163
+ infoCount++;
164
+ break;
165
+ }
166
+ }
167
+ }
168
+ return {
169
+ filesChecked: resolvedFiles.length,
170
+ filesWithIssues,
171
+ errorCount,
172
+ warningCount,
173
+ infoCount,
174
+ results,
175
+ };
176
+ }
177
+ /**
178
+ * CLI main function
179
+ */
180
+ export async function main(args) {
181
+ const { files, options } = parseArgs(args);
182
+ if (files.length === 0) {
183
+ console.error('Error: No files specified. Use "vibe-check ." to check current directory.');
184
+ process.exit(2);
185
+ }
186
+ const summary = vibeCheck(files, options);
187
+ const output = formatResults(summary, options.format || 'pretty');
188
+ console.log(output);
189
+ // Determine exit code based on --fail-on
190
+ if (options.failOn) {
191
+ const severityOrder = ['error', 'warning', 'info'];
192
+ const failIndex = severityOrder.indexOf(options.failOn);
193
+ let shouldFail = false;
194
+ if (failIndex <= 0 && summary.errorCount > 0)
195
+ shouldFail = true;
196
+ if (failIndex <= 1 && summary.warningCount > 0)
197
+ shouldFail = true;
198
+ if (failIndex <= 2 && summary.infoCount > 0)
199
+ shouldFail = true;
200
+ if (shouldFail) {
201
+ process.exit(1);
202
+ }
203
+ }
204
+ process.exit(0);
205
+ }
206
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,66 @@
1
+ /**
2
+ * vibe-and-thrive ESLint plugin
3
+ *
4
+ * Usage:
5
+ * import vibe from 'vibe-and-thrive/eslint-plugin';
6
+ * export default [vibe.configs.recommended];
7
+ */
8
+ declare const rules: {
9
+ 'no-any-type': import("eslint").Rule.RuleModule;
10
+ 'no-snake-case-props': import("eslint").Rule.RuleModule;
11
+ 'no-debug-statements': import("eslint").Rule.RuleModule;
12
+ 'no-empty-catch': import("eslint").Rule.RuleModule;
13
+ 'no-magic-numbers': import("eslint").Rule.RuleModule;
14
+ 'no-deep-nesting': import("eslint").Rule.RuleModule;
15
+ 'max-function-length': import("eslint").Rule.RuleModule;
16
+ };
17
+ declare const plugin: {
18
+ meta: {
19
+ name: string;
20
+ version: string;
21
+ };
22
+ rules: {
23
+ 'no-any-type': import("eslint").Rule.RuleModule;
24
+ 'no-snake-case-props': import("eslint").Rule.RuleModule;
25
+ 'no-debug-statements': import("eslint").Rule.RuleModule;
26
+ 'no-empty-catch': import("eslint").Rule.RuleModule;
27
+ 'no-magic-numbers': import("eslint").Rule.RuleModule;
28
+ 'no-deep-nesting': import("eslint").Rule.RuleModule;
29
+ 'max-function-length': import("eslint").Rule.RuleModule;
30
+ };
31
+ configs: {
32
+ recommended: {
33
+ plugins: {
34
+ readonly vibe: /*elided*/ any;
35
+ };
36
+ rules: {
37
+ 'vibe/no-any-type': string;
38
+ 'vibe/no-snake-case-props': string;
39
+ 'vibe/no-debug-statements': string;
40
+ 'vibe/no-empty-catch': string;
41
+ 'vibe/no-magic-numbers': string;
42
+ 'vibe/no-deep-nesting': string;
43
+ 'vibe/max-function-length': string;
44
+ };
45
+ };
46
+ strict: {
47
+ plugins: {
48
+ readonly vibe: /*elided*/ any;
49
+ };
50
+ rules: {
51
+ 'vibe/no-any-type': string;
52
+ 'vibe/no-snake-case-props': string;
53
+ 'vibe/no-debug-statements': string;
54
+ 'vibe/no-empty-catch': string;
55
+ 'vibe/no-magic-numbers': string;
56
+ 'vibe/no-deep-nesting': string;
57
+ 'vibe/max-function-length': (string | {
58
+ max: number;
59
+ })[];
60
+ };
61
+ };
62
+ };
63
+ };
64
+ export default plugin;
65
+ export { rules };
66
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/eslint-plugin/index.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAUH,QAAA,MAAM,KAAK;;;;;;;;CAQV,CAAC;AAEF,QAAA,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAwCX,CAAC;AAEF,eAAe,MAAM,CAAC;AACtB,OAAO,EAAE,KAAK,EAAE,CAAC"}
@@ -0,0 +1,67 @@
1
+ /**
2
+ * vibe-and-thrive ESLint plugin
3
+ *
4
+ * Usage:
5
+ * import vibe from 'vibe-and-thrive/eslint-plugin';
6
+ * export default [vibe.configs.recommended];
7
+ */
8
+ import noAnyType from './rules/no-any-type.js';
9
+ import noSnakeCaseProps from './rules/no-snake-case-props.js';
10
+ import noDebugStatements from './rules/no-debug-statements.js';
11
+ import noEmptyCatch from './rules/no-empty-catch.js';
12
+ import noMagicNumbers from './rules/no-magic-numbers.js';
13
+ import noDeepNesting from './rules/no-deep-nesting.js';
14
+ import maxFunctionLength from './rules/max-function-length.js';
15
+ const rules = {
16
+ 'no-any-type': noAnyType,
17
+ 'no-snake-case-props': noSnakeCaseProps,
18
+ 'no-debug-statements': noDebugStatements,
19
+ 'no-empty-catch': noEmptyCatch,
20
+ 'no-magic-numbers': noMagicNumbers,
21
+ 'no-deep-nesting': noDeepNesting,
22
+ 'max-function-length': maxFunctionLength,
23
+ };
24
+ const plugin = {
25
+ meta: {
26
+ name: 'vibe-and-thrive',
27
+ version: '1.0.0',
28
+ },
29
+ rules,
30
+ configs: {
31
+ recommended: {
32
+ plugins: {
33
+ get vibe() {
34
+ return plugin;
35
+ },
36
+ },
37
+ rules: {
38
+ 'vibe/no-any-type': 'warn',
39
+ 'vibe/no-snake-case-props': 'warn',
40
+ 'vibe/no-debug-statements': 'warn',
41
+ 'vibe/no-empty-catch': 'warn',
42
+ 'vibe/no-magic-numbers': 'off', // Often noisy
43
+ 'vibe/no-deep-nesting': 'warn',
44
+ 'vibe/max-function-length': 'warn',
45
+ },
46
+ },
47
+ strict: {
48
+ plugins: {
49
+ get vibe() {
50
+ return plugin;
51
+ },
52
+ },
53
+ rules: {
54
+ 'vibe/no-any-type': 'error',
55
+ 'vibe/no-snake-case-props': 'error',
56
+ 'vibe/no-debug-statements': 'error',
57
+ 'vibe/no-empty-catch': 'error',
58
+ 'vibe/no-magic-numbers': 'warn',
59
+ 'vibe/no-deep-nesting': 'error',
60
+ 'vibe/max-function-length': ['error', { max: 40 }],
61
+ },
62
+ },
63
+ },
64
+ };
65
+ export default plugin;
66
+ export { rules };
67
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/eslint-plugin/index.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAC/C,OAAO,gBAAgB,MAAM,gCAAgC,CAAC;AAC9D,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,YAAY,MAAM,2BAA2B,CAAC;AACrD,OAAO,cAAc,MAAM,6BAA6B,CAAC;AACzD,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAE/D,MAAM,KAAK,GAAG;IACZ,aAAa,EAAE,SAAS;IACxB,qBAAqB,EAAE,gBAAgB;IACvC,qBAAqB,EAAE,iBAAiB;IACxC,gBAAgB,EAAE,YAAY;IAC9B,kBAAkB,EAAE,cAAc;IAClC,iBAAiB,EAAE,aAAa;IAChC,qBAAqB,EAAE,iBAAiB;CACzC,CAAC;AAEF,MAAM,MAAM,GAAG;IACb,IAAI,EAAE;QACJ,IAAI,EAAE,iBAAiB;QACvB,OAAO,EAAE,OAAO;KACjB;IACD,KAAK;IACL,OAAO,EAAE;QACP,WAAW,EAAE;YACX,OAAO,EAAE;gBACP,IAAI,IAAI;oBACN,OAAO,MAAM,CAAC;gBAChB,CAAC;aACF;YACD,KAAK,EAAE;gBACL,kBAAkB,EAAE,MAAM;gBAC1B,0BAA0B,EAAE,MAAM;gBAClC,0BAA0B,EAAE,MAAM;gBAClC,qBAAqB,EAAE,MAAM;gBAC7B,uBAAuB,EAAE,KAAK,EAAE,cAAc;gBAC9C,sBAAsB,EAAE,MAAM;gBAC9B,0BAA0B,EAAE,MAAM;aACnC;SACF;QACD,MAAM,EAAE;YACN,OAAO,EAAE;gBACP,IAAI,IAAI;oBACN,OAAO,MAAM,CAAC;gBAChB,CAAC;aACF;YACD,KAAK,EAAE;gBACL,kBAAkB,EAAE,OAAO;gBAC3B,0BAA0B,EAAE,OAAO;gBACnC,0BAA0B,EAAE,OAAO;gBACnC,qBAAqB,EAAE,OAAO;gBAC9B,uBAAuB,EAAE,MAAM;gBAC/B,sBAAsB,EAAE,OAAO;gBAC/B,0BAA0B,EAAE,CAAC,OAAO,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC;aACnD;SACF;KACF;CACF,CAAC;AAEF,eAAe,MAAM,CAAC;AACtB,OAAO,EAAE,KAAK,EAAE,CAAC"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * ESLint rule: max-function-length
3
+ * Enforce a maximum function length
4
+ */
5
+ import type { Rule } from 'eslint';
6
+ declare const rule: Rule.RuleModule;
7
+ export default rule;
8
+ //# sourceMappingURL=max-function-length.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"max-function-length.d.ts","sourceRoot":"","sources":["../../../src/eslint-plugin/rules/max-function-length.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAInC,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,UAgEhB,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,69 @@
1
+ /**
2
+ * ESLint rule: max-function-length
3
+ * Enforce a maximum function length
4
+ */
5
+ const DEFAULT_MAX_LINES = 50;
6
+ const rule = {
7
+ meta: {
8
+ type: 'suggestion',
9
+ docs: {
10
+ description: 'Enforce a maximum function length',
11
+ recommended: true,
12
+ },
13
+ messages: {
14
+ tooLong: 'Function "{{ name }}" is {{ lines }} lines (max: {{ max }}) - consider refactoring',
15
+ },
16
+ schema: [
17
+ {
18
+ type: 'object',
19
+ properties: {
20
+ max: {
21
+ type: 'number',
22
+ minimum: 1,
23
+ },
24
+ },
25
+ additionalProperties: false,
26
+ },
27
+ ],
28
+ },
29
+ create(context) {
30
+ const options = context.options[0] || {};
31
+ const maxLines = options.max || DEFAULT_MAX_LINES;
32
+ function checkFunction(node) {
33
+ const loc = node.loc;
34
+ if (!loc)
35
+ return;
36
+ const lines = loc.end.line - loc.start.line + 1;
37
+ if (lines <= maxLines)
38
+ return;
39
+ // Get function name
40
+ let name = 'anonymous';
41
+ const nodeAny = node;
42
+ if (nodeAny.id?.name) {
43
+ name = nodeAny.id.name;
44
+ }
45
+ else if (nodeAny.parent?.type === 'VariableDeclarator' && nodeAny.parent.id?.name) {
46
+ name = nodeAny.parent.id.name;
47
+ }
48
+ else if (nodeAny.parent?.type === 'MethodDefinition' && nodeAny.parent.key?.name) {
49
+ name = nodeAny.parent.key.name;
50
+ }
51
+ context.report({
52
+ node,
53
+ messageId: 'tooLong',
54
+ data: {
55
+ name,
56
+ lines: String(lines),
57
+ max: String(maxLines),
58
+ },
59
+ });
60
+ }
61
+ return {
62
+ FunctionDeclaration: checkFunction,
63
+ FunctionExpression: checkFunction,
64
+ ArrowFunctionExpression: checkFunction,
65
+ };
66
+ },
67
+ };
68
+ export default rule;
69
+ //# sourceMappingURL=max-function-length.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"max-function-length.js","sourceRoot":"","sources":["../../../src/eslint-plugin/rules/max-function-length.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,MAAM,iBAAiB,GAAG,EAAE,CAAC;AAE7B,MAAM,IAAI,GAAoB;IAC5B,IAAI,EAAE;QACJ,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE;YACJ,WAAW,EAAE,mCAAmC;YAChD,WAAW,EAAE,IAAI;SAClB;QACD,QAAQ,EAAE;YACR,OAAO,EAAE,oFAAoF;SAC9F;QACD,MAAM,EAAE;YACN;gBACE,IAAI,EAAE,QAAQ;gBACd,UAAU,EAAE;oBACV,GAAG,EAAE;wBACH,IAAI,EAAE,QAAQ;wBACd,OAAO,EAAE,CAAC;qBACX;iBACF;gBACD,oBAAoB,EAAE,KAAK;aAC5B;SACF;KACF;IAED,MAAM,CAAC,OAAO;QACZ,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QACzC,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,IAAI,iBAAiB,CAAC;QAElD,SAAS,aAAa,CAAC,IAAe;YACpC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;YACrB,IAAI,CAAC,GAAG;gBAAE,OAAO;YAEjB,MAAM,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC;YAChD,IAAI,KAAK,IAAI,QAAQ;gBAAE,OAAO;YAE9B,oBAAoB;YACpB,IAAI,IAAI,GAAG,WAAW,CAAC;YACvB,MAAM,OAAO,GAAG,IAA+G,CAAC;YAEhI,IAAI,OAAO,CAAC,EAAE,EAAE,IAAI,EAAE,CAAC;gBACrB,IAAI,GAAG,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC;YACzB,CAAC;iBAAM,IAAI,OAAO,CAAC,MAAM,EAAE,IAAI,KAAK,oBAAoB,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,EAAE,CAAC;gBACpF,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC;YAChC,CAAC;iBAAM,IAAI,OAAO,CAAC,MAAM,EAAE,IAAI,KAAK,kBAAkB,IAAI,OAAO,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,EAAE,CAAC;gBACnF,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;YACjC,CAAC;YAED,OAAO,CAAC,MAAM,CAAC;gBACb,IAAI;gBACJ,SAAS,EAAE,SAAS;gBACpB,IAAI,EAAE;oBACJ,IAAI;oBACJ,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC;oBACpB,GAAG,EAAE,MAAM,CAAC,QAAQ,CAAC;iBACtB;aACF,CAAC,CAAC;QACL,CAAC;QAED,OAAO;YACL,mBAAmB,EAAE,aAAa;YAClC,kBAAkB,EAAE,aAAa;YACjC,uBAAuB,EAAE,aAAa;SACvC,CAAC;IACJ,CAAC;CACF,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * ESLint rule: no-any-type
3
+ * Disallow usage of 'any' type in TypeScript
4
+ */
5
+ import type { Rule } from 'eslint';
6
+ declare const rule: Rule.RuleModule;
7
+ export default rule;
8
+ //# sourceMappingURL=no-any-type.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-any-type.d.ts","sourceRoot":"","sources":["../../../src/eslint-plugin/rules/no-any-type.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAEnC,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,UAuBhB,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,29 @@
1
+ /**
2
+ * ESLint rule: no-any-type
3
+ * Disallow usage of 'any' type in TypeScript
4
+ */
5
+ const rule = {
6
+ meta: {
7
+ type: 'suggestion',
8
+ docs: {
9
+ description: 'Disallow usage of "any" type',
10
+ recommended: true,
11
+ },
12
+ messages: {
13
+ noAny: 'Avoid using "any" type - use "unknown" or a specific type instead',
14
+ },
15
+ schema: [],
16
+ },
17
+ create(context) {
18
+ return {
19
+ TSAnyKeyword(node) {
20
+ context.report({
21
+ node,
22
+ messageId: 'noAny',
23
+ });
24
+ },
25
+ };
26
+ },
27
+ };
28
+ export default rule;
29
+ //# sourceMappingURL=no-any-type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-any-type.js","sourceRoot":"","sources":["../../../src/eslint-plugin/rules/no-any-type.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,MAAM,IAAI,GAAoB;IAC5B,IAAI,EAAE;QACJ,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE;YACJ,WAAW,EAAE,8BAA8B;YAC3C,WAAW,EAAE,IAAI;SAClB;QACD,QAAQ,EAAE;YACR,KAAK,EAAE,mEAAmE;SAC3E;QACD,MAAM,EAAE,EAAE;KACX;IAED,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,YAAY,CAAC,IAAe;gBAC1B,OAAO,CAAC,MAAM,CAAC;oBACb,IAAI;oBACJ,SAAS,EAAE,OAAO;iBACnB,CAAC,CAAC;YACL,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * ESLint rule: no-debug-statements
3
+ * Disallow console.log, debugger, and other debug statements
4
+ */
5
+ import type { Rule } from 'eslint';
6
+ declare const rule: Rule.RuleModule;
7
+ export default rule;
8
+ //# sourceMappingURL=no-debug-statements.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-debug-statements.d.ts","sourceRoot":"","sources":["../../../src/eslint-plugin/rules/no-debug-statements.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAEnC,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,UA+DhB,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,59 @@
1
+ /**
2
+ * ESLint rule: no-debug-statements
3
+ * Disallow console.log, debugger, and other debug statements
4
+ */
5
+ const rule = {
6
+ meta: {
7
+ type: 'problem',
8
+ docs: {
9
+ description: 'Disallow debug statements (console.log, debugger)',
10
+ recommended: true,
11
+ },
12
+ fixable: 'code',
13
+ messages: {
14
+ consoleLog: 'Unexpected console.log statement - remove before commit',
15
+ consoleDebug: 'Unexpected console.debug statement - remove before commit',
16
+ debugger: 'Unexpected debugger statement - remove before commit',
17
+ alert: 'Unexpected alert statement - remove before commit',
18
+ },
19
+ schema: [],
20
+ },
21
+ create(context) {
22
+ return {
23
+ CallExpression(node) {
24
+ // Check for console.log, console.debug
25
+ if (node.callee?.type === 'MemberExpression' &&
26
+ node.callee.object?.name === 'console') {
27
+ const method = node.callee.property?.name;
28
+ if (method === 'log') {
29
+ context.report({
30
+ node,
31
+ messageId: 'consoleLog',
32
+ });
33
+ }
34
+ else if (method === 'debug') {
35
+ context.report({
36
+ node,
37
+ messageId: 'consoleDebug',
38
+ });
39
+ }
40
+ }
41
+ // Check for alert()
42
+ if (node.callee?.type === 'Identifier' && node.callee.name === 'alert') {
43
+ context.report({
44
+ node,
45
+ messageId: 'alert',
46
+ });
47
+ }
48
+ },
49
+ DebuggerStatement(node) {
50
+ context.report({
51
+ node,
52
+ messageId: 'debugger',
53
+ });
54
+ },
55
+ };
56
+ },
57
+ };
58
+ export default rule;
59
+ //# sourceMappingURL=no-debug-statements.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-debug-statements.js","sourceRoot":"","sources":["../../../src/eslint-plugin/rules/no-debug-statements.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,MAAM,IAAI,GAAoB;IAC5B,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EAAE,mDAAmD;YAChE,WAAW,EAAE,IAAI;SAClB;QACD,OAAO,EAAE,MAAM;QACf,QAAQ,EAAE;YACR,UAAU,EAAE,yDAAyD;YACrE,YAAY,EAAE,2DAA2D;YACzE,QAAQ,EAAE,sDAAsD;YAChE,KAAK,EAAE,mDAAmD;SAC3D;QACD,MAAM,EAAE,EAAE;KACX;IAED,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,cAAc,CAAC,IAOd;gBACC,uCAAuC;gBACvC,IACE,IAAI,CAAC,MAAM,EAAE,IAAI,KAAK,kBAAkB;oBACxC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,KAAK,SAAS,EACtC,CAAC;oBACD,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC;oBAC1C,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;wBACrB,OAAO,CAAC,MAAM,CAAC;4BACb,IAAI;4BACJ,SAAS,EAAE,YAAY;yBACxB,CAAC,CAAC;oBACL,CAAC;yBAAM,IAAI,MAAM,KAAK,OAAO,EAAE,CAAC;wBAC9B,OAAO,CAAC,MAAM,CAAC;4BACb,IAAI;4BACJ,SAAS,EAAE,cAAc;yBAC1B,CAAC,CAAC;oBACL,CAAC;gBACH,CAAC;gBAED,oBAAoB;gBACpB,IAAI,IAAI,CAAC,MAAM,EAAE,IAAI,KAAK,YAAY,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;oBACvE,OAAO,CAAC,MAAM,CAAC;wBACb,IAAI;wBACJ,SAAS,EAAE,OAAO;qBACnB,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YAED,iBAAiB,CAAC,IAAe;gBAC/B,OAAO,CAAC,MAAM,CAAC;oBACb,IAAI;oBACJ,SAAS,EAAE,UAAU;iBACtB,CAAC,CAAC;YACL,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * ESLint rule: no-deep-nesting
3
+ * Disallow deeply nested code blocks
4
+ */
5
+ import type { Rule } from 'eslint';
6
+ declare const rule: Rule.RuleModule;
7
+ export default rule;
8
+ //# sourceMappingURL=no-deep-nesting.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-deep-nesting.d.ts","sourceRoot":"","sources":["../../../src/eslint-plugin/rules/no-deep-nesting.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAInC,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,UAoDhB,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,56 @@
1
+ /**
2
+ * ESLint rule: no-deep-nesting
3
+ * Disallow deeply nested code blocks
4
+ */
5
+ const DEFAULT_MAX_DEPTH = 4;
6
+ const rule = {
7
+ meta: {
8
+ type: 'suggestion',
9
+ docs: {
10
+ description: 'Disallow deeply nested code blocks',
11
+ recommended: true,
12
+ },
13
+ messages: {
14
+ tooDeep: 'Nesting depth {{ depth }} exceeds maximum of {{ max }} - consider refactoring',
15
+ },
16
+ schema: [
17
+ {
18
+ type: 'object',
19
+ properties: {
20
+ max: {
21
+ type: 'number',
22
+ minimum: 1,
23
+ },
24
+ },
25
+ additionalProperties: false,
26
+ },
27
+ ],
28
+ },
29
+ create(context) {
30
+ const options = context.options[0] || {};
31
+ const maxDepth = options.max || DEFAULT_MAX_DEPTH;
32
+ let currentDepth = 0;
33
+ function enterBlock(node) {
34
+ currentDepth++;
35
+ if (currentDepth > maxDepth) {
36
+ context.report({
37
+ node,
38
+ messageId: 'tooDeep',
39
+ data: {
40
+ depth: String(currentDepth),
41
+ max: String(maxDepth),
42
+ },
43
+ });
44
+ }
45
+ }
46
+ function exitBlock() {
47
+ currentDepth--;
48
+ }
49
+ return {
50
+ BlockStatement: enterBlock,
51
+ 'BlockStatement:exit': exitBlock,
52
+ };
53
+ },
54
+ };
55
+ export default rule;
56
+ //# sourceMappingURL=no-deep-nesting.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-deep-nesting.js","sourceRoot":"","sources":["../../../src/eslint-plugin/rules/no-deep-nesting.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAE5B,MAAM,IAAI,GAAoB;IAC5B,IAAI,EAAE;QACJ,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE;YACJ,WAAW,EAAE,oCAAoC;YACjD,WAAW,EAAE,IAAI;SAClB;QACD,QAAQ,EAAE;YACR,OAAO,EAAE,+EAA+E;SACzF;QACD,MAAM,EAAE;YACN;gBACE,IAAI,EAAE,QAAQ;gBACd,UAAU,EAAE;oBACV,GAAG,EAAE;wBACH,IAAI,EAAE,QAAQ;wBACd,OAAO,EAAE,CAAC;qBACX;iBACF;gBACD,oBAAoB,EAAE,KAAK;aAC5B;SACF;KACF;IAED,MAAM,CAAC,OAAO;QACZ,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QACzC,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,IAAI,iBAAiB,CAAC;QAClD,IAAI,YAAY,GAAG,CAAC,CAAC;QAErB,SAAS,UAAU,CAAC,IAAe;YACjC,YAAY,EAAE,CAAC;YACf,IAAI,YAAY,GAAG,QAAQ,EAAE,CAAC;gBAC5B,OAAO,CAAC,MAAM,CAAC;oBACb,IAAI;oBACJ,SAAS,EAAE,SAAS;oBACpB,IAAI,EAAE;wBACJ,KAAK,EAAE,MAAM,CAAC,YAAY,CAAC;wBAC3B,GAAG,EAAE,MAAM,CAAC,QAAQ,CAAC;qBACtB;iBACF,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAED,SAAS,SAAS;YAChB,YAAY,EAAE,CAAC;QACjB,CAAC;QAED,OAAO;YACL,cAAc,EAAE,UAAU;YAC1B,qBAAqB,EAAE,SAAS;SACjC,CAAC;IACJ,CAAC;CACF,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * ESLint rule: no-empty-catch
3
+ * Disallow empty catch blocks
4
+ */
5
+ import type { Rule } from 'eslint';
6
+ declare const rule: Rule.RuleModule;
7
+ export default rule;
8
+ //# sourceMappingURL=no-empty-catch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-empty-catch.d.ts","sourceRoot":"","sources":["../../../src/eslint-plugin/rules/no-empty-catch.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAEnC,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,UAyBhB,CAAC;AAEF,eAAe,IAAI,CAAC"}