@su-record/vibe 2.7.14 → 2.7.16

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 (234) hide show
  1. package/.env.example +37 -37
  2. package/CLAUDE.md +134 -126
  3. package/LICENSE +21 -21
  4. package/README.md +449 -449
  5. package/agents/architect-low.md +41 -41
  6. package/agents/architect-medium.md +59 -59
  7. package/agents/architect.md +80 -80
  8. package/agents/build-error-resolver.md +115 -115
  9. package/agents/compounder.md +261 -261
  10. package/agents/diagrammer.md +178 -178
  11. package/agents/docs/api-documenter.md +99 -99
  12. package/agents/docs/changelog-writer.md +93 -93
  13. package/agents/e2e-tester.md +294 -294
  14. package/agents/explorer-low.md +42 -42
  15. package/agents/explorer-medium.md +59 -59
  16. package/agents/explorer.md +48 -48
  17. package/agents/implementer-low.md +43 -43
  18. package/agents/implementer-medium.md +52 -52
  19. package/agents/implementer.md +54 -54
  20. package/agents/junior-mentor.md +141 -141
  21. package/agents/planning/requirements-analyst.md +84 -84
  22. package/agents/planning/ux-advisor.md +83 -83
  23. package/agents/qa/acceptance-tester.md +86 -86
  24. package/agents/qa/edge-case-finder.md +93 -93
  25. package/agents/refactor-cleaner.md +143 -143
  26. package/agents/research/best-practices-agent.md +199 -199
  27. package/agents/research/codebase-patterns-agent.md +157 -157
  28. package/agents/research/framework-docs-agent.md +188 -188
  29. package/agents/research/security-advisory-agent.md +213 -213
  30. package/agents/review/architecture-reviewer.md +107 -107
  31. package/agents/review/complexity-reviewer.md +116 -116
  32. package/agents/review/data-integrity-reviewer.md +88 -88
  33. package/agents/review/git-history-reviewer.md +103 -103
  34. package/agents/review/performance-reviewer.md +86 -86
  35. package/agents/review/python-reviewer.md +150 -150
  36. package/agents/review/rails-reviewer.md +139 -139
  37. package/agents/review/react-reviewer.md +144 -144
  38. package/agents/review/security-reviewer.md +80 -80
  39. package/agents/review/simplicity-reviewer.md +140 -140
  40. package/agents/review/test-coverage-reviewer.md +116 -116
  41. package/agents/review/typescript-reviewer.md +127 -127
  42. package/agents/searcher.md +54 -54
  43. package/agents/simplifier.md +120 -120
  44. package/agents/tester.md +49 -49
  45. package/agents/ui/ui-a11y-auditor.md +93 -93
  46. package/agents/ui/ui-antipattern-detector.md +94 -94
  47. package/agents/ui/ui-dataviz-advisor.md +69 -69
  48. package/agents/ui/ui-design-system-gen.md +57 -57
  49. package/agents/ui/ui-industry-analyzer.md +49 -49
  50. package/agents/ui/ui-layout-architect.md +65 -65
  51. package/agents/ui/ui-stack-implementer.md +68 -68
  52. package/agents/ui/ux-compliance-reviewer.md +81 -81
  53. package/agents/ui-previewer.md +258 -258
  54. package/commands/vibe.analyze.md +11 -13
  55. package/commands/vibe.review.md +43 -1
  56. package/commands/vibe.run.md +2124 -2078
  57. package/commands/vibe.spec.md +9 -4
  58. package/commands/vibe.spec.review.md +569 -565
  59. package/commands/vibe.utils.md +413 -413
  60. package/commands/vibe.verify.md +33 -8
  61. package/dist/cli/collaborator.js +52 -52
  62. package/dist/cli/commands/evolution.js +12 -12
  63. package/dist/cli/commands/info.d.ts.map +1 -1
  64. package/dist/cli/commands/info.js +51 -55
  65. package/dist/cli/commands/info.js.map +1 -1
  66. package/dist/cli/commands/init.js +5 -5
  67. package/dist/cli/commands/remove.js +14 -14
  68. package/dist/cli/commands/sentinel.js +27 -27
  69. package/dist/cli/commands/skills.js +5 -5
  70. package/dist/cli/commands/slack.js +10 -10
  71. package/dist/cli/commands/telegram.js +12 -12
  72. package/dist/cli/detect.js +32 -32
  73. package/dist/cli/index.js +51 -51
  74. package/dist/cli/llm/claude-commands.js +16 -16
  75. package/dist/cli/llm/config.js +18 -18
  76. package/dist/cli/llm/gemini-commands.js +16 -16
  77. package/dist/cli/llm/gpt-commands.js +19 -19
  78. package/dist/cli/llm/help.js +21 -21
  79. package/dist/cli/postinstall/constants.d.ts.map +1 -1
  80. package/dist/cli/postinstall/constants.js +7 -8
  81. package/dist/cli/postinstall/constants.js.map +1 -1
  82. package/dist/cli/postinstall/cursor-agents.js +32 -32
  83. package/dist/cli/postinstall/cursor-rules.js +83 -83
  84. package/dist/cli/postinstall/cursor-skills.js +743 -743
  85. package/dist/cli/setup/Provisioner.js +42 -42
  86. package/dist/infra/lib/DeepInit.js +24 -24
  87. package/dist/infra/lib/IterationTracker.js +11 -11
  88. package/dist/infra/lib/PythonParser.js +108 -108
  89. package/dist/infra/lib/ReviewRace.js +96 -96
  90. package/dist/infra/lib/SkillFrontmatter.js +28 -28
  91. package/dist/infra/lib/SkillQualityGate.js +9 -9
  92. package/dist/infra/lib/SkillRepository.js +159 -159
  93. package/dist/infra/lib/UltraQA.js +99 -99
  94. package/dist/infra/lib/autonomy/AuditStore.js +41 -41
  95. package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
  96. package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
  97. package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
  98. package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
  99. package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
  100. package/dist/infra/lib/embedding/VectorStore.js +22 -22
  101. package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
  102. package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
  103. package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
  104. package/dist/infra/lib/evolution/InsightStore.js +90 -90
  105. package/dist/infra/lib/evolution/RollbackManager.js +5 -5
  106. package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
  107. package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
  108. package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
  109. package/dist/infra/lib/evolution/UsageTracker.js +28 -28
  110. package/dist/infra/lib/gemini/orchestration.js +5 -5
  111. package/dist/infra/lib/gpt/orchestration.js +4 -4
  112. package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
  113. package/dist/infra/lib/memory/MemorySearch.js +57 -57
  114. package/dist/infra/lib/memory/MemoryStorage.js +181 -181
  115. package/dist/infra/lib/memory/ObservationStore.js +28 -28
  116. package/dist/infra/lib/memory/ReflectionStore.js +30 -30
  117. package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
  118. package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
  119. package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
  120. package/dist/infra/orchestrator/AgentManager.js +12 -12
  121. package/dist/infra/orchestrator/AgentRegistry.js +65 -65
  122. package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
  123. package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
  124. package/dist/infra/orchestrator/parallelResearch.js +24 -24
  125. package/dist/tools/convention/analyzeComplexity.test.js +115 -115
  126. package/dist/tools/convention/validateCodeQuality.test.js +104 -104
  127. package/dist/tools/memory/createMemoryTimeline.js +10 -10
  128. package/dist/tools/memory/getMemoryGraph.js +12 -12
  129. package/dist/tools/memory/getSessionContext.js +9 -9
  130. package/dist/tools/memory/linkMemories.js +14 -14
  131. package/dist/tools/memory/listMemories.js +4 -4
  132. package/dist/tools/memory/recallMemory.js +4 -4
  133. package/dist/tools/memory/saveMemory.js +4 -4
  134. package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
  135. package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
  136. package/dist/tools/semantic/astGrep.test.js +6 -6
  137. package/dist/tools/spec/prdParser.test.js +171 -171
  138. package/dist/tools/spec/specGenerator.js +169 -169
  139. package/dist/tools/spec/traceabilityMatrix.js +64 -64
  140. package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
  141. package/hooks/gemini-hooks.json +73 -73
  142. package/hooks/hooks.json +137 -137
  143. package/hooks/scripts/code-check.js +77 -70
  144. package/hooks/scripts/context-save.js +212 -212
  145. package/hooks/scripts/hud-status.js +291 -291
  146. package/hooks/scripts/keyword-detector.js +214 -214
  147. package/hooks/scripts/llm-orchestrate.js +475 -475
  148. package/hooks/scripts/post-edit.js +32 -32
  149. package/hooks/scripts/pre-tool-guard.js +125 -125
  150. package/hooks/scripts/prompt-dispatcher.js +185 -185
  151. package/hooks/scripts/sentinel-guard.js +104 -104
  152. package/hooks/scripts/session-start.js +106 -106
  153. package/hooks/scripts/stop-notify.js +209 -209
  154. package/hooks/scripts/utils.js +100 -100
  155. package/languages/csharp-unity.md +515 -515
  156. package/languages/gdscript-godot.md +470 -470
  157. package/languages/ruby-rails.md +489 -489
  158. package/languages/typescript-angular.md +433 -433
  159. package/languages/typescript-astro.md +416 -416
  160. package/languages/typescript-electron.md +406 -406
  161. package/languages/typescript-nestjs.md +524 -524
  162. package/languages/typescript-svelte.md +407 -407
  163. package/languages/typescript-tauri.md +365 -365
  164. package/package.json +121 -121
  165. package/skills/agents-md/SKILL.md +120 -120
  166. package/skills/arch-guard/SKILL.md +180 -180
  167. package/skills/brand-assets/SKILL.md +146 -146
  168. package/skills/capability-loop/SKILL.md +167 -167
  169. package/skills/characterization-test/SKILL.md +206 -206
  170. package/skills/commerce-patterns/SKILL.md +63 -59
  171. package/skills/commit-push-pr/SKILL.md +75 -75
  172. package/skills/context7-usage/SKILL.md +105 -105
  173. package/skills/core-capabilities/SKILL.md +13 -48
  174. package/skills/e2e-commerce/SKILL.md +61 -57
  175. package/skills/exec-plan/SKILL.md +147 -147
  176. package/skills/frontend-design/SKILL.md +12 -73
  177. package/skills/git-worktree/SKILL.md +72 -72
  178. package/skills/handoff/SKILL.md +109 -109
  179. package/skills/parallel-research/SKILL.md +87 -87
  180. package/skills/priority-todos/SKILL.md +63 -63
  181. package/skills/seo-checklist/SKILL.md +57 -57
  182. package/skills/techdebt/SKILL.md +122 -122
  183. package/skills/tool-fallback/SKILL.md +103 -103
  184. package/skills/typescript-advanced-types/SKILL.md +66 -66
  185. package/skills/ui-ux-pro-max/SKILL.md +221 -206
  186. package/skills/vercel-react-best-practices/SKILL.md +59 -59
  187. package/skills/video-production/SKILL.md +51 -51
  188. package/vibe/config.json +29 -29
  189. package/vibe/constitution.md +227 -227
  190. package/vibe/rules/principles/communication-guide.md +98 -98
  191. package/vibe/rules/principles/development-philosophy.md +52 -52
  192. package/vibe/rules/principles/quick-start.md +102 -102
  193. package/vibe/rules/quality/bdd-contract-testing.md +393 -393
  194. package/vibe/rules/quality/checklist.md +276 -276
  195. package/vibe/rules/quality/performance.md +236 -236
  196. package/vibe/rules/quality/testing-strategy.md +440 -440
  197. package/vibe/rules/standards/anti-patterns.md +541 -541
  198. package/vibe/rules/standards/code-structure.md +291 -291
  199. package/vibe/rules/standards/complexity-metrics.md +313 -313
  200. package/vibe/rules/standards/git-workflow.md +237 -237
  201. package/vibe/rules/standards/naming-conventions.md +198 -198
  202. package/vibe/rules/standards/security.md +305 -305
  203. package/vibe/rules/writing/document-style.md +74 -74
  204. package/vibe/setup.sh +31 -31
  205. package/vibe/templates/constitution-template.md +252 -252
  206. package/vibe/templates/contract-backend-template.md +526 -526
  207. package/vibe/templates/contract-frontend-template.md +599 -599
  208. package/vibe/templates/feature-template.md +96 -96
  209. package/vibe/templates/spec-template.md +221 -221
  210. package/vibe/ui-ux-data/charts.csv +26 -26
  211. package/vibe/ui-ux-data/colors.csv +97 -97
  212. package/vibe/ui-ux-data/icons.csv +101 -101
  213. package/vibe/ui-ux-data/landing.csv +31 -31
  214. package/vibe/ui-ux-data/products.csv +96 -96
  215. package/vibe/ui-ux-data/react-performance.csv +45 -45
  216. package/vibe/ui-ux-data/stacks/astro.csv +54 -54
  217. package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
  218. package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
  219. package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
  220. package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
  221. package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
  222. package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
  223. package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
  224. package/vibe/ui-ux-data/stacks/react.csv +54 -54
  225. package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
  226. package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
  227. package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
  228. package/vibe/ui-ux-data/stacks/vue.csv +50 -50
  229. package/vibe/ui-ux-data/styles.csv +68 -68
  230. package/vibe/ui-ux-data/typography.csv +57 -57
  231. package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
  232. package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
  233. package/vibe/ui-ux-data/version.json +31 -31
  234. package/vibe/ui-ux-data/web-interface.csv +31 -31
@@ -153,48 +153,48 @@ export class Provisioner {
153
153
  const stateSection = details.stateManagement.length > 0
154
154
  ? details.stateManagement.join(', ')
155
155
  : 'N/A';
156
- return `# [Feature Name] SPEC
157
-
158
- ## Overview
159
- <!-- Brief description of the feature -->
160
-
161
- ## Tech Stack
162
- ${stackList}
163
-
164
- ### Infrastructure
165
- - **Databases**: ${dbSection}
166
- - **State Management**: ${stateSection}
167
-
168
- ## Problem Statement
169
- <!-- What problem does this solve? -->
170
-
171
- ## Proposed Solution
172
- <!-- High-level approach -->
173
-
174
- ## Requirements
175
-
176
- ### Functional
177
- 1. <!-- Requirement 1 -->
178
-
179
- ### Non-Functional
180
- 1. <!-- Performance, security, accessibility -->
181
-
182
- ## API Design
183
- <!-- Endpoints, request/response schemas -->
184
-
185
- ## Data Model
186
- <!-- Schema changes, migrations -->
187
-
188
- ## Test Strategy
189
- - Unit tests: <!-- scope -->
190
- - Integration tests: <!-- scope -->
191
- - E2E tests: <!-- scope -->
192
-
193
- ## Acceptance Criteria
194
- - [ ] <!-- Criterion 1 -->
195
-
196
- ## References
197
- <!-- Links to relevant docs, designs, PRs -->
156
+ return `# [Feature Name] SPEC
157
+
158
+ ## Overview
159
+ <!-- Brief description of the feature -->
160
+
161
+ ## Tech Stack
162
+ ${stackList}
163
+
164
+ ### Infrastructure
165
+ - **Databases**: ${dbSection}
166
+ - **State Management**: ${stateSection}
167
+
168
+ ## Problem Statement
169
+ <!-- What problem does this solve? -->
170
+
171
+ ## Proposed Solution
172
+ <!-- High-level approach -->
173
+
174
+ ## Requirements
175
+
176
+ ### Functional
177
+ 1. <!-- Requirement 1 -->
178
+
179
+ ### Non-Functional
180
+ 1. <!-- Performance, security, accessibility -->
181
+
182
+ ## API Design
183
+ <!-- Endpoints, request/response schemas -->
184
+
185
+ ## Data Model
186
+ <!-- Schema changes, migrations -->
187
+
188
+ ## Test Strategy
189
+ - Unit tests: <!-- scope -->
190
+ - Integration tests: <!-- scope -->
191
+ - E2E tests: <!-- scope -->
192
+
193
+ ## Acceptance Criteria
194
+ - [ ] <!-- Criterion 1 -->
195
+
196
+ ## References
197
+ <!-- Links to relevant docs, designs, PRs -->
198
198
  `;
199
199
  }
200
200
  }
@@ -216,30 +216,30 @@ export function generateNavigationHeader(dir, rootPath) {
216
216
  * Describe DeepInit workflow
217
217
  */
218
218
  export function describeDeepInitWorkflow() {
219
- return `
220
- ## DeepInit Workflow
221
-
222
- Hierarchical AI-readable documentation generation:
223
-
224
- \`\`\`
225
- project/
226
- ├── AGENTS.md ← Root documentation
227
- ├── src/
228
- │ ├── AGENTS.md ← <!-- Parent: ../AGENTS.md -->
229
- │ ├── components/
230
- │ │ └── AGENTS.md ← <!-- Parent: ../AGENTS.md -->
231
- │ └── services/
232
- │ └── AGENTS.md ← <!-- Parent: ../AGENTS.md -->
233
- └── tests/
234
- └── AGENTS.md ← <!-- Parent: ../AGENTS.md -->
235
- \`\`\`
236
-
237
- Features:
238
- - Parent references for navigation
239
- - Auto-detected purpose and conventions
240
- - Preserved manual notes on regeneration
241
- - Entry point identification
242
- - Child module linking
219
+ return `
220
+ ## DeepInit Workflow
221
+
222
+ Hierarchical AI-readable documentation generation:
223
+
224
+ \`\`\`
225
+ project/
226
+ ├── AGENTS.md ← Root documentation
227
+ ├── src/
228
+ │ ├── AGENTS.md ← <!-- Parent: ../AGENTS.md -->
229
+ │ ├── components/
230
+ │ │ └── AGENTS.md ← <!-- Parent: ../AGENTS.md -->
231
+ │ └── services/
232
+ │ └── AGENTS.md ← <!-- Parent: ../AGENTS.md -->
233
+ └── tests/
234
+ └── AGENTS.md ← <!-- Parent: ../AGENTS.md -->
235
+ \`\`\`
236
+
237
+ Features:
238
+ - Parent references for navigation
239
+ - Auto-detected purpose and conventions
240
+ - Preserved manual notes on regeneration
241
+ - Entry point identification
242
+ - Child module linking
243
243
  `.trim();
244
244
  }
245
245
  //# sourceMappingURL=DeepInit.js.map
@@ -108,10 +108,10 @@ export function formatProgress(state = currentState) {
108
108
  * Phase 시작 배너
109
109
  */
110
110
  export function formatPhaseStart(phaseNumber, phaseName, totalPhases) {
111
- return `
112
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
113
- 🏔️ BOULDER ROLLING... Phase ${phaseNumber}/${totalPhases}
114
- ${phaseName}
111
+ return `
112
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
113
+ 🏔️ BOULDER ROLLING... Phase ${phaseNumber}/${totalPhases}
114
+ ${phaseName}
115
115
  ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━`.trim();
116
116
  }
117
117
  /**
@@ -129,13 +129,13 @@ export function formatIterationComplete(state) {
129
129
  : 0;
130
130
  const totalRetries = state.phases.reduce((sum, p) => sum + p.retryCount, 0);
131
131
  const retryInfo = totalRetries > 0 ? ` (${totalRetries} retries)` : '';
132
- return `
133
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
134
- 🎉 BOULDER REACHED THE TOP!
135
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
136
- Feature: ${state.featureName}
137
- Phases: ${state.totalPhases}/${state.totalPhases} complete${retryInfo}
138
- Time: ${duration}s
132
+ return `
133
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
134
+ 🎉 BOULDER REACHED THE TOP!
135
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
136
+ Feature: ${state.featureName}
137
+ Phases: ${state.totalPhases}/${state.totalPhases} complete${retryInfo}
138
+ Time: ${duration}s
139
139
  ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━`.trim();
140
140
  }
141
141
  /**
@@ -35,114 +35,114 @@ function getPythonCommand() {
35
35
  const PYTHON_CMD = getPythonCommand();
36
36
  export class PythonParser {
37
37
  static cleanupRegistered = false;
38
- static pythonScript = `
39
- import ast
40
- import sys
41
- import json
42
-
43
- def analyze_code(code):
44
- try:
45
- tree = ast.parse(code)
46
- symbols = []
47
-
48
- for node in ast.walk(tree):
49
- if isinstance(node, ast.FunctionDef):
50
- symbols.append({
51
- 'name': node.name,
52
- 'kind': 'function',
53
- 'line': node.lineno,
54
- 'column': node.col_offset,
55
- 'endLine': node.end_lineno,
56
- 'docstring': ast.get_docstring(node)
57
- })
58
- elif isinstance(node, ast.ClassDef):
59
- symbols.append({
60
- 'name': node.name,
61
- 'kind': 'class',
62
- 'line': node.lineno,
63
- 'column': node.col_offset,
64
- 'endLine': node.end_lineno,
65
- 'docstring': ast.get_docstring(node)
66
- })
67
- elif isinstance(node, ast.Assign):
68
- for target in node.targets:
69
- if isinstance(target, ast.Name):
70
- symbols.append({
71
- 'name': target.id,
72
- 'kind': 'variable',
73
- 'line': node.lineno,
74
- 'column': node.col_offset
75
- })
76
- elif isinstance(node, ast.Import) or isinstance(node, ast.ImportFrom):
77
- for alias in node.names:
78
- symbols.append({
79
- 'name': alias.name,
80
- 'kind': 'import',
81
- 'line': node.lineno,
82
- 'column': node.col_offset
83
- })
84
-
85
- return {'success': True, 'symbols': symbols}
86
- except SyntaxError as e:
87
- return {'success': False, 'error': str(e)}
88
- except Exception as e:
89
- return {'success': False, 'error': str(e)}
90
-
91
- def calculate_complexity(code):
92
- try:
93
- tree = ast.parse(code)
94
-
95
- def cyclomatic_complexity(node):
96
- complexity = 1
97
- for child in ast.walk(node):
98
- if isinstance(child, (ast.If, ast.For, ast.While, ast.And, ast.Or, ast.ExceptHandler)):
99
- complexity += 1
100
- elif isinstance(child, ast.BoolOp):
101
- complexity += len(child.values) - 1
102
- return complexity
103
-
104
- functions = []
105
- classes = []
106
- total_complexity = 1
107
-
108
- for node in ast.walk(tree):
109
- if isinstance(node, ast.FunctionDef):
110
- func_complexity = cyclomatic_complexity(node)
111
- functions.append({
112
- 'name': node.name,
113
- 'complexity': func_complexity,
114
- 'line': node.lineno
115
- })
116
- total_complexity += func_complexity
117
- elif isinstance(node, ast.ClassDef):
118
- method_count = sum(1 for n in node.body if isinstance(n, ast.FunctionDef))
119
- classes.append({
120
- 'name': node.name,
121
- 'methods': method_count,
122
- 'line': node.lineno
123
- })
124
-
125
- return {
126
- 'success': True,
127
- 'cyclomaticComplexity': total_complexity,
128
- 'functions': functions,
129
- 'classes': classes
130
- }
131
- except Exception as e:
132
- return {'success': False, 'error': str(e)}
133
-
134
- if __name__ == '__main__':
135
- code = sys.stdin.read()
136
- action = sys.argv[1] if len(sys.argv) > 1 else 'symbols'
137
-
138
- if action == 'symbols':
139
- result = analyze_code(code)
140
- elif action == 'complexity':
141
- result = calculate_complexity(code)
142
- else:
143
- result = {'success': False, 'error': 'Unknown action'}
144
-
145
- print(json.dumps(result))
38
+ static pythonScript = `
39
+ import ast
40
+ import sys
41
+ import json
42
+
43
+ def analyze_code(code):
44
+ try:
45
+ tree = ast.parse(code)
46
+ symbols = []
47
+
48
+ for node in ast.walk(tree):
49
+ if isinstance(node, ast.FunctionDef):
50
+ symbols.append({
51
+ 'name': node.name,
52
+ 'kind': 'function',
53
+ 'line': node.lineno,
54
+ 'column': node.col_offset,
55
+ 'endLine': node.end_lineno,
56
+ 'docstring': ast.get_docstring(node)
57
+ })
58
+ elif isinstance(node, ast.ClassDef):
59
+ symbols.append({
60
+ 'name': node.name,
61
+ 'kind': 'class',
62
+ 'line': node.lineno,
63
+ 'column': node.col_offset,
64
+ 'endLine': node.end_lineno,
65
+ 'docstring': ast.get_docstring(node)
66
+ })
67
+ elif isinstance(node, ast.Assign):
68
+ for target in node.targets:
69
+ if isinstance(target, ast.Name):
70
+ symbols.append({
71
+ 'name': target.id,
72
+ 'kind': 'variable',
73
+ 'line': node.lineno,
74
+ 'column': node.col_offset
75
+ })
76
+ elif isinstance(node, ast.Import) or isinstance(node, ast.ImportFrom):
77
+ for alias in node.names:
78
+ symbols.append({
79
+ 'name': alias.name,
80
+ 'kind': 'import',
81
+ 'line': node.lineno,
82
+ 'column': node.col_offset
83
+ })
84
+
85
+ return {'success': True, 'symbols': symbols}
86
+ except SyntaxError as e:
87
+ return {'success': False, 'error': str(e)}
88
+ except Exception as e:
89
+ return {'success': False, 'error': str(e)}
90
+
91
+ def calculate_complexity(code):
92
+ try:
93
+ tree = ast.parse(code)
94
+
95
+ def cyclomatic_complexity(node):
96
+ complexity = 1
97
+ for child in ast.walk(node):
98
+ if isinstance(child, (ast.If, ast.For, ast.While, ast.And, ast.Or, ast.ExceptHandler)):
99
+ complexity += 1
100
+ elif isinstance(child, ast.BoolOp):
101
+ complexity += len(child.values) - 1
102
+ return complexity
103
+
104
+ functions = []
105
+ classes = []
106
+ total_complexity = 1
107
+
108
+ for node in ast.walk(tree):
109
+ if isinstance(node, ast.FunctionDef):
110
+ func_complexity = cyclomatic_complexity(node)
111
+ functions.append({
112
+ 'name': node.name,
113
+ 'complexity': func_complexity,
114
+ 'line': node.lineno
115
+ })
116
+ total_complexity += func_complexity
117
+ elif isinstance(node, ast.ClassDef):
118
+ method_count = sum(1 for n in node.body if isinstance(n, ast.FunctionDef))
119
+ classes.append({
120
+ 'name': node.name,
121
+ 'methods': method_count,
122
+ 'line': node.lineno
123
+ })
124
+
125
+ return {
126
+ 'success': True,
127
+ 'cyclomaticComplexity': total_complexity,
128
+ 'functions': functions,
129
+ 'classes': classes
130
+ }
131
+ except Exception as e:
132
+ return {'success': False, 'error': str(e)}
133
+
134
+ if __name__ == '__main__':
135
+ code = sys.stdin.read()
136
+ action = sys.argv[1] if len(sys.argv) > 1 else 'symbols'
137
+
138
+ if action == 'symbols':
139
+ result = analyze_code(code)
140
+ elif action == 'complexity':
141
+ result = calculate_complexity(code)
142
+ else:
143
+ result = {'success': False, 'error': 'Unknown action'}
144
+
145
+ print(json.dumps(result))
146
146
  `;
147
147
  // Singleton Python script path to avoid recreating it
148
148
  static scriptPath = null;
@@ -23,90 +23,90 @@ import * as geminiApi from './gemini/index.js';
23
23
  // Constants
24
24
  // ============================================================================
25
25
  const REVIEW_PROMPTS = {
26
- security: `You are a security expert reviewing code changes.
27
- Identify security vulnerabilities including:
28
- - SQL injection, XSS, CSRF
29
- - Authentication/authorization flaws
30
- - Sensitive data exposure
31
- - Insecure dependencies
32
- - OWASP Top 10 issues
33
-
34
- For each issue found, respond in this exact JSON format:
35
- {
36
- "issues": [
37
- {
38
- "id": "SEC-001",
39
- "title": "Brief title",
40
- "description": "Detailed description",
41
- "location": "file.ts:42",
42
- "severity": "critical|high|medium|low",
43
- "suggestion": "How to fix"
44
- }
45
- ]
46
- }
47
-
26
+ security: `You are a security expert reviewing code changes.
27
+ Identify security vulnerabilities including:
28
+ - SQL injection, XSS, CSRF
29
+ - Authentication/authorization flaws
30
+ - Sensitive data exposure
31
+ - Insecure dependencies
32
+ - OWASP Top 10 issues
33
+
34
+ For each issue found, respond in this exact JSON format:
35
+ {
36
+ "issues": [
37
+ {
38
+ "id": "SEC-001",
39
+ "title": "Brief title",
40
+ "description": "Detailed description",
41
+ "location": "file.ts:42",
42
+ "severity": "critical|high|medium|low",
43
+ "suggestion": "How to fix"
44
+ }
45
+ ]
46
+ }
47
+
48
48
  If no issues found, respond: {"issues": []}`,
49
- performance: `You are a performance expert reviewing code changes.
50
- Identify performance issues including:
51
- - N+1 queries
52
- - Memory leaks
53
- - Unnecessary re-renders
54
- - Blocking operations
55
- - Large bundle size impacts
56
- - Missing caching opportunities
57
-
58
- Respond in JSON format:
59
- {
60
- "issues": [
61
- {
62
- "id": "PERF-001",
63
- "title": "Brief title",
64
- "description": "Detailed description",
65
- "location": "file.ts:42",
66
- "severity": "critical|high|medium|low",
67
- "suggestion": "How to fix"
68
- }
69
- ]
49
+ performance: `You are a performance expert reviewing code changes.
50
+ Identify performance issues including:
51
+ - N+1 queries
52
+ - Memory leaks
53
+ - Unnecessary re-renders
54
+ - Blocking operations
55
+ - Large bundle size impacts
56
+ - Missing caching opportunities
57
+
58
+ Respond in JSON format:
59
+ {
60
+ "issues": [
61
+ {
62
+ "id": "PERF-001",
63
+ "title": "Brief title",
64
+ "description": "Detailed description",
65
+ "location": "file.ts:42",
66
+ "severity": "critical|high|medium|low",
67
+ "suggestion": "How to fix"
68
+ }
69
+ ]
70
70
  }`,
71
- architecture: `You are an architecture expert reviewing code changes.
72
- Identify architecture issues including:
73
- - Circular dependencies
74
- - Layer violations (e.g., UI calling DB directly)
75
- - Missing abstractions
76
- - Tight coupling
77
- - Single Responsibility violations
78
- - DRY violations
79
-
71
+ architecture: `You are an architecture expert reviewing code changes.
72
+ Identify architecture issues including:
73
+ - Circular dependencies
74
+ - Layer violations (e.g., UI calling DB directly)
75
+ - Missing abstractions
76
+ - Tight coupling
77
+ - Single Responsibility violations
78
+ - DRY violations
79
+
80
80
  Respond in JSON format with issues array.`,
81
- complexity: `You are a code quality expert reviewing complexity.
82
- Identify complexity issues including:
83
- - Functions > 30 lines
84
- - Nesting depth > 3 levels
85
- - Cyclomatic complexity > 10
86
- - Too many parameters (> 5)
87
- - Long files (> 300 lines)
88
-
81
+ complexity: `You are a code quality expert reviewing complexity.
82
+ Identify complexity issues including:
83
+ - Functions > 30 lines
84
+ - Nesting depth > 3 levels
85
+ - Cyclomatic complexity > 10
86
+ - Too many parameters (> 5)
87
+ - Long files (> 300 lines)
88
+
89
89
  Respond in JSON format with issues array.`,
90
- 'data-integrity': `You are a data integrity expert reviewing code changes.
91
- Identify data integrity issues including:
92
- - Missing validations
93
- - Race conditions
94
- - Inconsistent state handling
95
- - Missing error handling
96
- - Data loss scenarios
97
-
90
+ 'data-integrity': `You are a data integrity expert reviewing code changes.
91
+ Identify data integrity issues including:
92
+ - Missing validations
93
+ - Race conditions
94
+ - Inconsistent state handling
95
+ - Missing error handling
96
+ - Data loss scenarios
97
+
98
98
  Respond in JSON format with issues array.`,
99
- 'test-coverage': `You are a testing expert reviewing code changes.
100
- Identify missing test coverage including:
101
- - Untested edge cases
102
- - Missing error case tests
103
- - Missing integration tests
104
- - Untested business logic
105
-
99
+ 'test-coverage': `You are a testing expert reviewing code changes.
100
+ Identify missing test coverage including:
101
+ - Untested edge cases
102
+ - Missing error case tests
103
+ - Missing integration tests
104
+ - Untested business logic
105
+
106
106
  Respond in JSON format with issues array.`,
107
- general: `You are a senior code reviewer.
108
- Review this code for any issues including security, performance, maintainability, and best practices.
109
-
107
+ general: `You are a senior code reviewer.
108
+ Review this code for any issues including security, performance, maintainability, and best practices.
109
+
110
110
  Respond in JSON format with issues array.`,
111
111
  };
112
112
  // ============================================================================
@@ -202,15 +202,15 @@ function selectBestDescription(issues) {
202
202
  async function reviewWithGPT(reviewType, code, context) {
203
203
  const startTime = Date.now();
204
204
  try {
205
- const prompt = `${REVIEW_PROMPTS[reviewType]}
206
-
207
- Context: ${context || 'Code review'}
208
-
209
- Code to review:
210
- \`\`\`
211
- ${code}
212
- \`\`\`
213
-
205
+ const prompt = `${REVIEW_PROMPTS[reviewType]}
206
+
207
+ Context: ${context || 'Code review'}
208
+
209
+ Code to review:
210
+ \`\`\`
211
+ ${code}
212
+ \`\`\`
213
+
214
214
  Respond with JSON only.`;
215
215
  const response = await gptApi.ask(prompt, {
216
216
  model: 'gpt-5.3-codex',
@@ -238,15 +238,15 @@ Respond with JSON only.`;
238
238
  async function reviewWithGemini(reviewType, code, context) {
239
239
  const startTime = Date.now();
240
240
  try {
241
- const prompt = `${REVIEW_PROMPTS[reviewType]}
242
-
243
- Context: ${context || 'Code review'}
244
-
245
- Code to review:
246
- \`\`\`
247
- ${code}
248
- \`\`\`
249
-
241
+ const prompt = `${REVIEW_PROMPTS[reviewType]}
242
+
243
+ Context: ${context || 'Code review'}
244
+
245
+ Code to review:
246
+ \`\`\`
247
+ ${code}
248
+ \`\`\`
249
+
250
250
  Respond with JSON only.`;
251
251
  const response = await geminiApi.ask(prompt, {
252
252
  model: 'gemini-flash',