@su-record/vibe 2.9.4 → 2.9.5

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 (479) hide show
  1. package/.env.example +37 -37
  2. package/CLAUDE.md +190 -190
  3. package/LICENSE +21 -21
  4. package/README.ko.md +170 -170
  5. package/README.md +219 -219
  6. package/agents/architect-low.md +41 -41
  7. package/agents/architect-medium.md +59 -59
  8. package/agents/architect.md +80 -80
  9. package/agents/build-error-resolver.md +115 -115
  10. package/agents/compounder.md +261 -261
  11. package/agents/diagrammer.md +178 -178
  12. package/agents/docs/api-documenter.md +99 -99
  13. package/agents/docs/changelog-writer.md +93 -93
  14. package/agents/e2e-tester.md +294 -294
  15. package/agents/event/event-comms.md +78 -78
  16. package/agents/event/event-content.md +68 -68
  17. package/agents/event/event-image.md +95 -95
  18. package/agents/event/event-ops.md +84 -84
  19. package/agents/event/event-scheduler.md +69 -69
  20. package/agents/event/event-speaker.md +86 -86
  21. package/agents/explorer-low.md +42 -42
  22. package/agents/explorer-medium.md +59 -59
  23. package/agents/explorer.md +48 -48
  24. package/agents/implementer-low.md +43 -43
  25. package/agents/implementer-medium.md +52 -52
  26. package/agents/implementer.md +54 -54
  27. package/agents/junior-mentor.md +141 -141
  28. package/agents/planning/requirements-analyst.md +84 -84
  29. package/agents/planning/ux-advisor.md +83 -83
  30. package/agents/qa/acceptance-tester.md +86 -86
  31. package/agents/qa/edge-case-finder.md +93 -93
  32. package/agents/qa/qa-coordinator.md +131 -131
  33. package/agents/refactor-cleaner.md +143 -143
  34. package/agents/research/best-practices-agent.md +199 -199
  35. package/agents/research/codebase-patterns-agent.md +157 -157
  36. package/agents/research/framework-docs-agent.md +188 -188
  37. package/agents/research/security-advisory-agent.md +213 -213
  38. package/agents/review/architecture-reviewer.md +107 -107
  39. package/agents/review/complexity-reviewer.md +116 -116
  40. package/agents/review/data-integrity-reviewer.md +88 -88
  41. package/agents/review/git-history-reviewer.md +103 -103
  42. package/agents/review/performance-reviewer.md +86 -86
  43. package/agents/review/python-reviewer.md +150 -150
  44. package/agents/review/rails-reviewer.md +139 -139
  45. package/agents/review/react-reviewer.md +144 -144
  46. package/agents/review/security-reviewer.md +80 -80
  47. package/agents/review/simplicity-reviewer.md +140 -140
  48. package/agents/review/test-coverage-reviewer.md +116 -116
  49. package/agents/review/typescript-reviewer.md +127 -127
  50. package/agents/searcher.md +54 -54
  51. package/agents/simplifier.md +120 -120
  52. package/agents/teams/debug-team.md +70 -70
  53. package/agents/teams/dev-team.md +88 -88
  54. package/agents/teams/docs-team.md +80 -80
  55. package/agents/teams/figma/figma-analyst.md +52 -52
  56. package/agents/teams/figma/figma-architect.md +112 -112
  57. package/agents/teams/figma/figma-auditor.md +82 -82
  58. package/agents/teams/figma/figma-builder.md +100 -100
  59. package/agents/teams/figma-team.md +85 -85
  60. package/agents/teams/fullstack-team.md +83 -83
  61. package/agents/teams/lite-team.md +69 -69
  62. package/agents/teams/migration-team.md +78 -78
  63. package/agents/teams/refactor-team.md +94 -94
  64. package/agents/teams/research-team.md +86 -86
  65. package/agents/teams/review-debate-team.md +125 -125
  66. package/agents/teams/security-team.md +81 -81
  67. package/agents/tester.md +49 -49
  68. package/agents/ui/ui-a11y-auditor.md +93 -93
  69. package/agents/ui/ui-antipattern-detector.md +102 -102
  70. package/agents/ui/ui-dataviz-advisor.md +69 -69
  71. package/agents/ui/ui-design-system-gen.md +57 -57
  72. package/agents/ui/ui-industry-analyzer.md +49 -49
  73. package/agents/ui/ui-layout-architect.md +65 -65
  74. package/agents/ui/ui-stack-implementer.md +68 -68
  75. package/agents/ui/ux-compliance-reviewer.md +81 -81
  76. package/agents/ui-previewer.md +258 -258
  77. package/commands/vibe.analyze.md +533 -533
  78. package/commands/vibe.docs.md +32 -32
  79. package/commands/vibe.event.md +163 -163
  80. package/commands/vibe.figma.md +584 -584
  81. package/commands/vibe.harness.md +177 -177
  82. package/commands/vibe.review.md +624 -624
  83. package/commands/vibe.run.md +1925 -1925
  84. package/commands/vibe.scaffold.md +195 -195
  85. package/commands/vibe.spec.md +565 -565
  86. package/commands/vibe.trace.md +276 -276
  87. package/commands/vibe.utils.md +413 -413
  88. package/commands/vibe.verify.md +519 -519
  89. package/dist/cli/collaborator.js +52 -52
  90. package/dist/cli/commands/codex-proxy.d.ts +10 -0
  91. package/dist/cli/commands/codex-proxy.d.ts.map +1 -0
  92. package/dist/cli/commands/codex-proxy.js +221 -0
  93. package/dist/cli/commands/codex-proxy.js.map +1 -0
  94. package/dist/cli/commands/config.js +9 -9
  95. package/dist/cli/commands/evolution.js +12 -12
  96. package/dist/cli/commands/figma.js +20 -20
  97. package/dist/cli/commands/index.d.ts +1 -0
  98. package/dist/cli/commands/index.d.ts.map +1 -1
  99. package/dist/cli/commands/index.js +1 -0
  100. package/dist/cli/commands/index.js.map +1 -1
  101. package/dist/cli/commands/info.d.ts.map +1 -1
  102. package/dist/cli/commands/info.js +50 -53
  103. package/dist/cli/commands/info.js.map +1 -1
  104. package/dist/cli/commands/init.js +5 -5
  105. package/dist/cli/commands/remove.js +14 -14
  106. package/dist/cli/commands/sentinel.js +27 -27
  107. package/dist/cli/commands/skills.js +5 -5
  108. package/dist/cli/commands/slack.js +10 -10
  109. package/dist/cli/commands/stats.js +6 -6
  110. package/dist/cli/commands/telegram.js +12 -12
  111. package/dist/cli/detect.js +32 -32
  112. package/dist/cli/index.d.ts.map +1 -1
  113. package/dist/cli/index.js +67 -53
  114. package/dist/cli/index.js.map +1 -1
  115. package/dist/cli/llm/claude-commands.js +16 -16
  116. package/dist/cli/llm/config.js +18 -18
  117. package/dist/cli/llm/gemini-commands.js +16 -16
  118. package/dist/cli/llm/gpt-commands.js +19 -19
  119. package/dist/cli/llm/help.js +21 -21
  120. package/dist/cli/postinstall/constants.d.ts.map +1 -1
  121. package/dist/cli/postinstall/constants.js +17 -13
  122. package/dist/cli/postinstall/constants.js.map +1 -1
  123. package/dist/cli/postinstall/cursor-agents.js +32 -32
  124. package/dist/cli/postinstall/cursor-rules.js +83 -83
  125. package/dist/cli/postinstall/cursor-skills.js +743 -743
  126. package/dist/cli/postinstall/fs-utils.d.ts +6 -0
  127. package/dist/cli/postinstall/fs-utils.d.ts.map +1 -1
  128. package/dist/cli/postinstall/fs-utils.js +15 -0
  129. package/dist/cli/postinstall/fs-utils.js.map +1 -1
  130. package/dist/cli/postinstall/main.d.ts.map +1 -1
  131. package/dist/cli/postinstall/main.js +8 -8
  132. package/dist/cli/postinstall/main.js.map +1 -1
  133. package/dist/cli/setup/Provisioner.js +42 -42
  134. package/dist/cli/types.d.ts +8 -0
  135. package/dist/cli/types.d.ts.map +1 -1
  136. package/dist/infra/lib/DeepInit.js +24 -24
  137. package/dist/infra/lib/IterationTracker.js +11 -11
  138. package/dist/infra/lib/OrchestrateWorkflow.js +1 -1
  139. package/dist/infra/lib/PythonParser.js +108 -108
  140. package/dist/infra/lib/ReviewRace.js +96 -96
  141. package/dist/infra/lib/SkillFrontmatter.js +28 -28
  142. package/dist/infra/lib/SkillQualityGate.js +9 -9
  143. package/dist/infra/lib/SkillRepository.js +159 -159
  144. package/dist/infra/lib/UltraQA.js +99 -99
  145. package/dist/infra/lib/autonomy/AuditStore.js +41 -41
  146. package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
  147. package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
  148. package/dist/infra/lib/autonomy/PolicyEngine.d.ts +3 -3
  149. package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
  150. package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
  151. package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
  152. package/dist/infra/lib/codex-proxy.d.ts +21 -0
  153. package/dist/infra/lib/codex-proxy.d.ts.map +1 -0
  154. package/dist/infra/lib/codex-proxy.js +510 -0
  155. package/dist/infra/lib/codex-proxy.js.map +1 -0
  156. package/dist/infra/lib/embedding/VectorStore.js +22 -22
  157. package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
  158. package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
  159. package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
  160. package/dist/infra/lib/evolution/InsightStore.js +90 -90
  161. package/dist/infra/lib/evolution/ParityTester.js +57 -57
  162. package/dist/infra/lib/evolution/RollbackManager.js +5 -5
  163. package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
  164. package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
  165. package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
  166. package/dist/infra/lib/evolution/UsageTracker.js +28 -28
  167. package/dist/infra/lib/gemini/orchestration.js +5 -5
  168. package/dist/infra/lib/gpt/orchestration.js +4 -4
  169. package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
  170. package/dist/infra/lib/memory/MemorySearch.js +57 -57
  171. package/dist/infra/lib/memory/MemoryStorage.js +181 -181
  172. package/dist/infra/lib/memory/ObservationStore.js +28 -28
  173. package/dist/infra/lib/memory/ReflectionStore.js +30 -30
  174. package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
  175. package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
  176. package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
  177. package/dist/infra/lib/telemetry/SkillTelemetry.test.js +4 -4
  178. package/dist/infra/orchestrator/AgentManager.js +12 -12
  179. package/dist/infra/orchestrator/AgentRegistry.js +65 -65
  180. package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
  181. package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
  182. package/dist/infra/orchestrator/parallelResearch.js +24 -24
  183. package/dist/tools/convention/analyzeComplexity.test.js +115 -115
  184. package/dist/tools/convention/validateCodeQuality.test.js +104 -104
  185. package/dist/tools/memory/createMemoryTimeline.js +10 -10
  186. package/dist/tools/memory/getMemoryGraph.js +12 -12
  187. package/dist/tools/memory/getSessionContext.js +9 -9
  188. package/dist/tools/memory/linkMemories.js +14 -14
  189. package/dist/tools/memory/listMemories.js +4 -4
  190. package/dist/tools/memory/recallMemory.js +4 -4
  191. package/dist/tools/memory/saveMemory.js +4 -4
  192. package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
  193. package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
  194. package/dist/tools/semantic/astGrep.test.js +6 -6
  195. package/dist/tools/spec/prdParser.test.js +171 -171
  196. package/dist/tools/spec/specGenerator.js +169 -169
  197. package/dist/tools/spec/traceabilityMatrix.js +64 -64
  198. package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
  199. package/hooks/gemini-hooks.json +73 -73
  200. package/hooks/hooks.json +174 -174
  201. package/hooks/scripts/__tests__/keyword-detector.test.js +199 -199
  202. package/hooks/scripts/__tests__/pre-tool-guard.test.js +286 -286
  203. package/hooks/scripts/__tests__/sentinel-guard.test.js +210 -210
  204. package/hooks/scripts/auto-commit.js +97 -97
  205. package/hooks/scripts/auto-format.js +64 -64
  206. package/hooks/scripts/auto-test.js +81 -81
  207. package/hooks/scripts/code-check.js +268 -268
  208. package/hooks/scripts/codex-detect.js +46 -46
  209. package/hooks/scripts/codex-review-gate.js +80 -80
  210. package/hooks/scripts/command-log.js +32 -32
  211. package/hooks/scripts/context-save.js +353 -353
  212. package/hooks/scripts/evolution-engine.js +91 -91
  213. package/hooks/scripts/figma-extract.js +635 -635
  214. package/hooks/scripts/figma-guard.js +220 -220
  215. package/hooks/scripts/figma-refine.js +315 -315
  216. package/hooks/scripts/figma-to-scss.js +394 -394
  217. package/hooks/scripts/figma-validate.js +353 -353
  218. package/hooks/scripts/hud-status.js +321 -321
  219. package/hooks/scripts/keyword-detector.js +214 -214
  220. package/hooks/scripts/llm-orchestrate.js +572 -572
  221. package/hooks/scripts/post-edit.js +32 -32
  222. package/hooks/scripts/pr-test-gate.js +52 -52
  223. package/hooks/scripts/pre-tool-guard.js +214 -214
  224. package/hooks/scripts/prompt-dispatcher.js +185 -185
  225. package/hooks/scripts/sentinel-guard.js +131 -131
  226. package/hooks/scripts/session-start.js +177 -177
  227. package/hooks/scripts/skill-injector.js +83 -83
  228. package/hooks/scripts/stop-notify.js +209 -209
  229. package/hooks/scripts/utils.js +243 -243
  230. package/languages/csharp-unity.md +515 -515
  231. package/languages/gdscript-godot.md +470 -470
  232. package/languages/ruby-rails.md +489 -489
  233. package/languages/typescript-angular.md +433 -433
  234. package/languages/typescript-astro.md +416 -416
  235. package/languages/typescript-electron.md +406 -406
  236. package/languages/typescript-nestjs.md +524 -524
  237. package/languages/typescript-svelte.md +407 -407
  238. package/languages/typescript-tauri.md +365 -365
  239. package/package.json +101 -101
  240. package/skills/agents-md/SKILL.md +121 -121
  241. package/skills/agents-md/rubrics/what-to-keep.md +49 -49
  242. package/skills/agents-md/templates/agents-md.md +36 -36
  243. package/skills/arch-guard/SKILL.md +181 -181
  244. package/skills/arch-guard/agents/detector.md +48 -48
  245. package/skills/arch-guard/agents/reporter.md +48 -48
  246. package/skills/arch-guard/agents/rule-generator.md +49 -49
  247. package/skills/arch-guard/agents/violation-checker.md +51 -51
  248. package/skills/arch-guard/frameworks/clean-architecture.md +108 -108
  249. package/skills/arch-guard/frameworks/solid.md +102 -102
  250. package/skills/arch-guard/scripts/check-boundaries.js +90 -90
  251. package/skills/arch-guard/templates/arch-rules.json +47 -47
  252. package/skills/arch-guard/templates/violation-report.md +53 -53
  253. package/skills/brand-assets/SKILL.md +147 -147
  254. package/skills/brand-assets/rubrics/asset-checklist.md +98 -98
  255. package/skills/brand-assets/templates/brand-guide.md +161 -161
  256. package/skills/capability-loop/SKILL.md +272 -272
  257. package/skills/capability-loop/agents/capability-designer.md +61 -61
  258. package/skills/capability-loop/agents/failure-analyst.md +55 -55
  259. package/skills/capability-loop/agents/implementer.md +50 -50
  260. package/skills/capability-loop/agents/tester.md +53 -53
  261. package/skills/capability-loop/templates/capability-spec.md +118 -118
  262. package/skills/capability-loop/templates/failure-analysis.md +118 -118
  263. package/skills/characterization-test/SKILL.md +207 -207
  264. package/skills/characterization-test/agents/behavior-capturer.md +50 -50
  265. package/skills/characterization-test/agents/coverage-checker.md +54 -54
  266. package/skills/characterization-test/agents/reporter.md +50 -50
  267. package/skills/characterization-test/agents/test-writer.md +49 -49
  268. package/skills/characterization-test/rubrics/coverage-criteria.md +53 -53
  269. package/skills/characterization-test/templates/test-template.ts +101 -101
  270. package/skills/chub-usage/SKILL.md +139 -139
  271. package/skills/claude-md-guide/SKILL.md +351 -351
  272. package/skills/claude-md-guide/rubrics/anti-patterns.md +88 -88
  273. package/skills/claude-md-guide/templates/claude-md.md +54 -54
  274. package/skills/commerce-patterns/SKILL.md +64 -64
  275. package/skills/commerce-patterns/rubrics/checkout-flow.md +48 -48
  276. package/skills/commerce-patterns/templates/product-schema.md +85 -85
  277. package/skills/commit-push-pr/SKILL.md +77 -77
  278. package/skills/commit-push-pr/agents/change-analyzer.md +55 -55
  279. package/skills/commit-push-pr/agents/message-writer.md +50 -50
  280. package/skills/commit-push-pr/agents/pr-writer.md +58 -58
  281. package/skills/commit-push-pr/agents/reviewer.md +52 -52
  282. package/skills/commit-push-pr/rubrics/commit-message.md +73 -73
  283. package/skills/commit-push-pr/templates/pr-body.md +63 -63
  284. package/skills/context7-usage/SKILL.md +106 -106
  285. package/skills/context7-usage/rubrics/when-to-use.md +50 -50
  286. package/skills/create-prd/SKILL.md +90 -90
  287. package/skills/create-prd/agents/edge-case-finder.md +48 -48
  288. package/skills/create-prd/agents/prioritizer.md +60 -60
  289. package/skills/create-prd/agents/requirements-writer.md +48 -48
  290. package/skills/create-prd/agents/researcher.md +55 -55
  291. package/skills/create-prd/agents/reviewer.md +54 -54
  292. package/skills/create-prd/frameworks/jobs-to-be-done.md +96 -96
  293. package/skills/create-prd/frameworks/rice-scoring.md +97 -97
  294. package/skills/create-prd/orchestrator.md +70 -70
  295. package/skills/create-prd/rubrics/completeness.md +58 -58
  296. package/skills/create-prd/templates/prd.md +139 -139
  297. package/skills/design-audit/SKILL.md +152 -152
  298. package/skills/design-audit/agents/a11y-auditor.md +43 -43
  299. package/skills/design-audit/agents/performance-auditor.md +46 -46
  300. package/skills/design-audit/agents/responsive-auditor.md +46 -46
  301. package/skills/design-audit/agents/scorer.md +47 -47
  302. package/skills/design-audit/agents/slop-detector.md +47 -47
  303. package/skills/design-audit/frameworks/core-web-vitals.md +107 -107
  304. package/skills/design-audit/frameworks/wcag-checklist.md +64 -64
  305. package/skills/design-audit/orchestrator.md +64 -64
  306. package/skills/design-audit/rubrics/ai-slop-patterns.md +83 -83
  307. package/skills/design-audit/rubrics/scoring.md +63 -63
  308. package/skills/design-audit/templates/report.md +88 -88
  309. package/skills/design-critique/SKILL.md +139 -139
  310. package/skills/design-critique/rubrics/ux-heuristics.md +143 -143
  311. package/skills/design-critique/templates/critique-report.md +86 -86
  312. package/skills/design-distill/SKILL.md +130 -130
  313. package/skills/design-distill/templates/design-system.md +132 -132
  314. package/skills/design-normalize/SKILL.md +133 -133
  315. package/skills/design-normalize/rubrics/token-naming.md +117 -117
  316. package/skills/design-normalize/templates/token-audit.md +89 -89
  317. package/skills/design-polish/SKILL.md +131 -131
  318. package/skills/design-polish/rubrics/polish-checklist.md +68 -68
  319. package/skills/design-polish/templates/polish-report.md +64 -64
  320. package/skills/design-teach/SKILL.md +182 -182
  321. package/skills/design-teach/rubrics/brand-personality.md +73 -73
  322. package/skills/design-teach/templates/design-context.json +36 -36
  323. package/skills/devlog/SKILL.md +143 -143
  324. package/skills/e2e-commerce/SKILL.md +62 -62
  325. package/skills/e2e-commerce/templates/test-scenarios.md +170 -170
  326. package/skills/event-comms/SKILL.md +172 -172
  327. package/skills/event-comms/templates/email-invite.md +99 -99
  328. package/skills/event-comms/templates/sns-post.md +133 -133
  329. package/skills/event-ops/SKILL.md +207 -207
  330. package/skills/event-ops/rubrics/contingency.md +85 -85
  331. package/skills/event-ops/templates/d-day-checklist.md +65 -65
  332. package/skills/event-planning/SKILL.md +144 -144
  333. package/skills/event-planning/rubrics/timeline.md +70 -70
  334. package/skills/event-planning/templates/event-plan.md +91 -91
  335. package/skills/exec-plan/SKILL.md +149 -149
  336. package/skills/exec-plan/agents/decomposer.md +47 -47
  337. package/skills/exec-plan/agents/dependency-mapper.md +44 -44
  338. package/skills/exec-plan/agents/estimator.md +43 -43
  339. package/skills/exec-plan/agents/validator.md +55 -55
  340. package/skills/exec-plan/orchestrator.md +70 -70
  341. package/skills/exec-plan/rubrics/complexity-scoring.md +75 -75
  342. package/skills/exec-plan/templates/plan.md +147 -147
  343. package/skills/git-worktree/SKILL.md +73 -73
  344. package/skills/git-worktree/rubrics/when-to-use.md +55 -55
  345. package/skills/handoff/SKILL.md +110 -110
  346. package/skills/handoff/agents/context-summarizer.md +51 -51
  347. package/skills/handoff/agents/document-writer.md +63 -63
  348. package/skills/handoff/agents/state-collector.md +53 -53
  349. package/skills/handoff/agents/verifier.md +48 -48
  350. package/skills/handoff/rubrics/completeness.md +62 -62
  351. package/skills/handoff/templates/handoff.md +107 -107
  352. package/skills/parallel-research/SKILL.md +89 -89
  353. package/skills/parallel-research/agents/best-practices.md +43 -43
  354. package/skills/parallel-research/agents/codebase-patterns.md +46 -46
  355. package/skills/parallel-research/agents/framework-docs.md +45 -45
  356. package/skills/parallel-research/agents/security-advisory.md +46 -46
  357. package/skills/parallel-research/agents/synthesizer.md +52 -52
  358. package/skills/parallel-research/experts/best-practices.md +50 -50
  359. package/skills/parallel-research/experts/codebase-patterns.md +70 -70
  360. package/skills/parallel-research/experts/framework-docs.md +65 -65
  361. package/skills/parallel-research/experts/security-advisory.md +69 -69
  362. package/skills/parallel-research/orchestrator.md +65 -65
  363. package/skills/parallel-research/templates/synthesis.md +101 -101
  364. package/skills/prioritization-frameworks/SKILL.md +87 -87
  365. package/skills/prioritization-frameworks/rubrics/frameworks.md +79 -79
  366. package/skills/prioritization-frameworks/templates/scoring-matrix.md +69 -69
  367. package/skills/priority-todos/SKILL.md +64 -64
  368. package/skills/priority-todos/rubrics/prioritization.md +70 -70
  369. package/skills/priority-todos/templates/todo-board.md +59 -59
  370. package/skills/seo-checklist/SKILL.md +58 -58
  371. package/skills/seo-checklist/frameworks/structured-data.md +153 -153
  372. package/skills/seo-checklist/rubrics/content-seo.md +42 -42
  373. package/skills/seo-checklist/rubrics/technical-seo.md +48 -48
  374. package/skills/techdebt/SKILL.md +124 -124
  375. package/skills/techdebt/agents/analyzer.md +50 -50
  376. package/skills/techdebt/agents/fixer.md +41 -41
  377. package/skills/techdebt/agents/reviewer.md +47 -47
  378. package/skills/techdebt/agents/scanner.md +44 -44
  379. package/skills/techdebt/orchestrator.md +70 -70
  380. package/skills/techdebt/rubrics/severity.md +51 -51
  381. package/skills/techdebt/scripts/scan.js +90 -90
  382. package/skills/techdebt/templates/report.md +86 -86
  383. package/skills/tool-fallback/SKILL.md +104 -104
  384. package/skills/tool-fallback/rubrics/fallback-chain.md +58 -58
  385. package/skills/typescript-advanced-types/SKILL.md +67 -67
  386. package/skills/typescript-advanced-types/rubrics/type-patterns.md +109 -109
  387. package/skills/ui-ux-pro-max/SKILL.md +236 -236
  388. package/skills/ui-ux-pro-max/reference/color-and-contrast.md +517 -517
  389. package/skills/ui-ux-pro-max/reference/interaction-design.md +544 -544
  390. package/skills/ui-ux-pro-max/reference/motion-design.md +591 -591
  391. package/skills/ui-ux-pro-max/reference/responsive-design.md +463 -463
  392. package/skills/ui-ux-pro-max/reference/spatial-design.md +390 -390
  393. package/skills/ui-ux-pro-max/reference/typography.md +455 -455
  394. package/skills/ui-ux-pro-max/reference/ux-writing.md +469 -469
  395. package/skills/ui-ux-pro-max/rubrics/interaction-states.md +83 -83
  396. package/skills/ui-ux-pro-max/rubrics/responsive-breakpoints.md +99 -99
  397. package/skills/user-personas/SKILL.md +75 -75
  398. package/skills/user-personas/rubrics/research-methods.md +56 -56
  399. package/skills/user-personas/templates/persona.md +89 -89
  400. package/skills/vercel-react-best-practices/SKILL.md +60 -60
  401. package/skills/vercel-react-best-practices/rubrics/performance.md +82 -82
  402. package/skills/vercel-react-best-practices/rubrics/server-components.md +86 -86
  403. package/skills/{vibe.docs → vibe-docs}/SKILL.md +171 -171
  404. package/skills/{vibe.docs → vibe-docs}/templates/architecture.md +80 -80
  405. package/skills/{vibe.docs → vibe-docs}/templates/readme.md +84 -84
  406. package/skills/{vibe.docs → vibe-docs}/templates/release-notes.md +74 -74
  407. package/skills/{vibe.figma → vibe-figma}/SKILL.md +363 -363
  408. package/skills/{vibe.figma → vibe-figma}/rubrics/extraction-checklist.md +51 -51
  409. package/skills/{vibe.figma → vibe-figma}/templates/component-index.md +126 -126
  410. package/skills/{vibe.figma → vibe-figma}/templates/component-spec.md +168 -168
  411. package/skills/{vibe.figma → vibe-figma}/templates/figma-handoff.md +100 -100
  412. package/skills/{vibe.figma → vibe-figma}/templates/remapped-tree.md +277 -277
  413. package/skills/{vibe.figma.convert → vibe-figma-convert}/SKILL.md +235 -235
  414. package/skills/{vibe.figma.convert → vibe-figma-convert}/rubrics/conversion-rules.md +141 -141
  415. package/skills/{vibe.figma.convert → vibe-figma-convert}/templates/component.md +140 -140
  416. package/skills/{vibe.figma.extract → vibe-figma-extract}/SKILL.md +219 -219
  417. package/skills/{vibe.figma.extract → vibe-figma-extract}/rubrics/image-rules.md +157 -157
  418. package/skills/{vibe.interview → vibe-interview}/SKILL.md +358 -358
  419. package/skills/{vibe.interview → vibe-interview}/checklists/api.md +101 -101
  420. package/skills/{vibe.interview → vibe-interview}/checklists/feature.md +88 -88
  421. package/skills/{vibe.interview → vibe-interview}/checklists/library.md +95 -95
  422. package/skills/{vibe.interview → vibe-interview}/checklists/mobile.md +89 -89
  423. package/skills/{vibe.interview → vibe-interview}/checklists/webapp.md +97 -97
  424. package/skills/{vibe.interview → vibe-interview}/checklists/website.md +99 -99
  425. package/skills/{vibe.plan → vibe-plan}/SKILL.md +254 -254
  426. package/skills/{vibe.spec → vibe-spec}/SKILL.md +1155 -1155
  427. package/skills/{vibe.spec.review → vibe-spec-review}/SKILL.md +726 -726
  428. package/skills/video-production/SKILL.md +52 -52
  429. package/skills/video-production/rubrics/quality-checklist.md +58 -58
  430. package/skills/video-production/templates/production-plan.md +104 -104
  431. package/vibe/config.json +29 -29
  432. package/vibe/constitution.md +227 -227
  433. package/vibe/rules/principles/communication-guide.md +98 -98
  434. package/vibe/rules/principles/development-philosophy.md +52 -52
  435. package/vibe/rules/principles/quick-start.md +102 -102
  436. package/vibe/rules/quality/bdd-contract-testing.md +393 -393
  437. package/vibe/rules/quality/checklist.md +276 -276
  438. package/vibe/rules/quality/performance.md +236 -236
  439. package/vibe/rules/quality/testing-strategy.md +440 -440
  440. package/vibe/rules/standards/anti-patterns.md +541 -541
  441. package/vibe/rules/standards/code-structure.md +291 -291
  442. package/vibe/rules/standards/complexity-metrics.md +313 -313
  443. package/vibe/rules/standards/git-workflow.md +237 -237
  444. package/vibe/rules/standards/naming-conventions.md +198 -198
  445. package/vibe/rules/standards/security.md +305 -305
  446. package/vibe/rules/writing/document-style.md +74 -74
  447. package/vibe/setup.sh +31 -31
  448. package/vibe/templates/claudemd-template.md +74 -74
  449. package/vibe/templates/constitution-template.md +267 -267
  450. package/vibe/templates/contract-backend-template.md +526 -526
  451. package/vibe/templates/contract-frontend-template.md +599 -599
  452. package/vibe/templates/feature-template.md +96 -96
  453. package/vibe/templates/plan-template.md +194 -194
  454. package/vibe/templates/spec-template.md +221 -221
  455. package/vibe/ui-ux-data/charts.csv +26 -26
  456. package/vibe/ui-ux-data/colors.csv +97 -97
  457. package/vibe/ui-ux-data/icons.csv +101 -101
  458. package/vibe/ui-ux-data/landing.csv +31 -31
  459. package/vibe/ui-ux-data/products.csv +96 -96
  460. package/vibe/ui-ux-data/react-performance.csv +45 -45
  461. package/vibe/ui-ux-data/stacks/astro.csv +54 -54
  462. package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
  463. package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
  464. package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
  465. package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
  466. package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
  467. package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
  468. package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
  469. package/vibe/ui-ux-data/stacks/react.csv +54 -54
  470. package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
  471. package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
  472. package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
  473. package/vibe/ui-ux-data/stacks/vue.csv +50 -50
  474. package/vibe/ui-ux-data/styles.csv +68 -68
  475. package/vibe/ui-ux-data/typography.csv +57 -57
  476. package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
  477. package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
  478. package/vibe/ui-ux-data/version.json +31 -31
  479. package/vibe/ui-ux-data/web-interface.csv +31 -31
@@ -151,18 +151,18 @@ export class AgentManager {
151
151
  * 리뷰 프롬프트 생성
152
152
  */
153
153
  buildReviewPrompt(agent, filePaths) {
154
- return `You are a ${agent.name}. Review the following files for issues in your domain:
155
-
156
- Files to review:
157
- ${filePaths.map(f => `- ${f}`).join('\n')}
158
-
159
- ${agent.content}
160
-
161
- Provide findings in this format:
162
- - Priority: P1 (Critical), P2 (Important), P3 (Nice-to-have)
163
- - Category: Your specialty area
164
- - Location: file:line
165
- - Issue: Description
154
+ return `You are a ${agent.name}. Review the following files for issues in your domain:
155
+
156
+ Files to review:
157
+ ${filePaths.map(f => `- ${f}`).join('\n')}
158
+
159
+ ${agent.content}
160
+
161
+ Provide findings in this format:
162
+ - Priority: P1 (Critical), P2 (Important), P3 (Nice-to-have)
163
+ - Category: Your specialty area
164
+ - Location: file:line
165
+ - Issue: Description
166
166
  - Fix: Recommendation`;
167
167
  }
168
168
  /**
@@ -57,36 +57,36 @@ export class AgentRegistry {
57
57
  }
58
58
  this.initializeSchema();
59
59
  // Prepare statements
60
- this.insertStmt = this.db.prepare(`
61
- INSERT INTO agent_executions (id, task_id, agent_name, prompt, status, model, started_at, session_id, created_at)
62
- VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
60
+ this.insertStmt = this.db.prepare(`
61
+ INSERT INTO agent_executions (id, task_id, agent_name, prompt, status, model, started_at, session_id, created_at)
62
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
63
63
  `);
64
- this.updateCompleteStmt = this.db.prepare(`
65
- UPDATE agent_executions SET status = 'completed', result = ?, duration = ?, completed_at = ? WHERE id = ?
64
+ this.updateCompleteStmt = this.db.prepare(`
65
+ UPDATE agent_executions SET status = 'completed', result = ?, duration = ?, completed_at = ? WHERE id = ?
66
66
  `);
67
- this.updateFailStmt = this.db.prepare(`
68
- UPDATE agent_executions SET status = 'failed', error = ?, duration = ?, completed_at = ? WHERE id = ?
67
+ this.updateFailStmt = this.db.prepare(`
68
+ UPDATE agent_executions SET status = 'failed', error = ?, duration = ?, completed_at = ? WHERE id = ?
69
69
  `);
70
70
  }
71
71
  initializeSchema() {
72
- this.db.exec(`
73
- CREATE TABLE IF NOT EXISTS agent_executions (
74
- id TEXT PRIMARY KEY,
75
- task_id TEXT NOT NULL,
76
- agent_name TEXT NOT NULL,
77
- prompt TEXT,
78
- result TEXT,
79
- status TEXT NOT NULL DEFAULT 'pending',
80
- duration INTEGER,
81
- model TEXT,
82
- started_at INTEGER NOT NULL,
83
- completed_at INTEGER,
84
- session_id TEXT,
85
- error TEXT,
86
- created_at INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)
87
- );
88
- CREATE INDEX IF NOT EXISTS idx_status ON agent_executions(status);
89
- CREATE INDEX IF NOT EXISTS idx_agent_name ON agent_executions(agent_name);
72
+ this.db.exec(`
73
+ CREATE TABLE IF NOT EXISTS agent_executions (
74
+ id TEXT PRIMARY KEY,
75
+ task_id TEXT NOT NULL,
76
+ agent_name TEXT NOT NULL,
77
+ prompt TEXT,
78
+ result TEXT,
79
+ status TEXT NOT NULL DEFAULT 'pending',
80
+ duration INTEGER,
81
+ model TEXT,
82
+ started_at INTEGER NOT NULL,
83
+ completed_at INTEGER,
84
+ session_id TEXT,
85
+ error TEXT,
86
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)
87
+ );
88
+ CREATE INDEX IF NOT EXISTS idx_status ON agent_executions(status);
89
+ CREATE INDEX IF NOT EXISTS idx_agent_name ON agent_executions(agent_name);
90
90
  `);
91
91
  }
92
92
  recordStart(execution) {
@@ -102,45 +102,45 @@ export class AgentRegistry {
102
102
  this.updateFailStmt.run(maskedError, duration, Date.now(), id);
103
103
  }
104
104
  getIncompleteExecutions() {
105
- const stmt = this.db.prepare(`
106
- SELECT id, task_id as taskId, agent_name as agentName, status, duration, model,
107
- started_at as startedAt, completed_at as completedAt, error, created_at as createdAt
108
- FROM agent_executions WHERE status = 'running' ORDER BY started_at ASC
105
+ const stmt = this.db.prepare(`
106
+ SELECT id, task_id as taskId, agent_name as agentName, status, duration, model,
107
+ started_at as startedAt, completed_at as completedAt, error, created_at as createdAt
108
+ FROM agent_executions WHERE status = 'running' ORDER BY started_at ASC
109
109
  `);
110
110
  return stmt.all();
111
111
  }
112
112
  markOrphaned(olderThanMs) {
113
113
  const cutoff = Date.now() - olderThanMs;
114
- const stmt = this.db.prepare(`
115
- UPDATE agent_executions SET status = 'failed', error = 'Orphaned (process crash)',
116
- completed_at = ? WHERE status = 'running' AND started_at < ?
114
+ const stmt = this.db.prepare(`
115
+ UPDATE agent_executions SET status = 'failed', error = 'Orphaned (process crash)',
116
+ completed_at = ? WHERE status = 'running' AND started_at < ?
117
117
  `);
118
118
  const result = stmt.run(Date.now(), cutoff);
119
119
  return result.changes;
120
120
  }
121
121
  getHistory(limit = 50, agentName) {
122
122
  if (agentName) {
123
- const stmt = this.db.prepare(`
124
- SELECT id, task_id as taskId, agent_name as agentName, status, duration, model,
125
- started_at as startedAt, completed_at as completedAt, error, created_at as createdAt
126
- FROM agent_executions WHERE agent_name = ? ORDER BY created_at DESC LIMIT ?
123
+ const stmt = this.db.prepare(`
124
+ SELECT id, task_id as taskId, agent_name as agentName, status, duration, model,
125
+ started_at as startedAt, completed_at as completedAt, error, created_at as createdAt
126
+ FROM agent_executions WHERE agent_name = ? ORDER BY created_at DESC LIMIT ?
127
127
  `);
128
128
  return stmt.all(agentName, limit);
129
129
  }
130
- const stmt = this.db.prepare(`
131
- SELECT id, task_id as taskId, agent_name as agentName, status, duration, model,
132
- started_at as startedAt, completed_at as completedAt, error, created_at as createdAt
133
- FROM agent_executions ORDER BY created_at DESC LIMIT ?
130
+ const stmt = this.db.prepare(`
131
+ SELECT id, task_id as taskId, agent_name as agentName, status, duration, model,
132
+ started_at as startedAt, completed_at as completedAt, error, created_at as createdAt
133
+ FROM agent_executions ORDER BY created_at DESC LIMIT ?
134
134
  `);
135
135
  return stmt.all(limit);
136
136
  }
137
137
  getAgentStats(agentName) {
138
- const stmt = this.db.prepare(`
139
- SELECT COUNT(*) as total,
140
- SUM(CASE WHEN status = 'completed' THEN 1 ELSE 0 END) as completed,
141
- SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) as failed,
142
- AVG(CASE WHEN duration IS NOT NULL THEN duration END) as avgDuration
143
- FROM agent_executions WHERE agent_name = ?
138
+ const stmt = this.db.prepare(`
139
+ SELECT COUNT(*) as total,
140
+ SUM(CASE WHEN status = 'completed' THEN 1 ELSE 0 END) as completed,
141
+ SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) as failed,
142
+ AVG(CASE WHEN duration IS NOT NULL THEN duration END) as avgDuration
143
+ FROM agent_executions WHERE agent_name = ?
144
144
  `);
145
145
  const row = stmt.get(agentName);
146
146
  return {
@@ -153,21 +153,21 @@ export class AgentRegistry {
153
153
  }
154
154
  getGlobalStats() {
155
155
  // Overall stats
156
- const overallStmt = this.db.prepare(`
157
- SELECT COUNT(*) as total,
158
- SUM(CASE WHEN status = 'completed' THEN 1 ELSE 0 END) as completed,
159
- SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) as failed,
160
- AVG(CASE WHEN duration IS NOT NULL THEN duration END) as avgDuration
161
- FROM agent_executions
156
+ const overallStmt = this.db.prepare(`
157
+ SELECT COUNT(*) as total,
158
+ SUM(CASE WHEN status = 'completed' THEN 1 ELSE 0 END) as completed,
159
+ SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) as failed,
160
+ AVG(CASE WHEN duration IS NOT NULL THEN duration END) as avgDuration
161
+ FROM agent_executions
162
162
  `);
163
163
  const overall = overallStmt.get();
164
164
  // By agent
165
- const byAgentStmt = this.db.prepare(`
166
- SELECT agent_name as agentName, COUNT(*) as total,
167
- SUM(CASE WHEN status = 'completed' THEN 1 ELSE 0 END) as completed,
168
- SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) as failed,
169
- AVG(CASE WHEN duration IS NOT NULL THEN duration END) as avgDuration
170
- FROM agent_executions GROUP BY agent_name
165
+ const byAgentStmt = this.db.prepare(`
166
+ SELECT agent_name as agentName, COUNT(*) as total,
167
+ SUM(CASE WHEN status = 'completed' THEN 1 ELSE 0 END) as completed,
168
+ SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) as failed,
169
+ AVG(CASE WHEN duration IS NOT NULL THEN duration END) as avgDuration
170
+ FROM agent_executions GROUP BY agent_name
171
171
  `);
172
172
  const agentRows = byAgentStmt.all();
173
173
  const byAgent = {};
@@ -181,10 +181,10 @@ export class AgentRegistry {
181
181
  };
182
182
  }
183
183
  // By model
184
- const byModelStmt = this.db.prepare(`
185
- SELECT model, COUNT(*) as count,
186
- AVG(CASE WHEN duration IS NOT NULL THEN duration END) as avgDuration
187
- FROM agent_executions WHERE model IS NOT NULL GROUP BY model
184
+ const byModelStmt = this.db.prepare(`
185
+ SELECT model, COUNT(*) as count,
186
+ AVG(CASE WHEN duration IS NOT NULL THEN duration END) as avgDuration
187
+ FROM agent_executions WHERE model IS NOT NULL GROUP BY model
188
188
  `);
189
189
  const modelRows = byModelStmt.all();
190
190
  const byModel = {};
@@ -203,9 +203,9 @@ export class AgentRegistry {
203
203
  }
204
204
  cleanup(ttlMs = DEFAULT_CLEANUP_TTL_MS) {
205
205
  const cutoff = Date.now() - ttlMs;
206
- const stmt = this.db.prepare(`
207
- DELETE FROM agent_executions
208
- WHERE (status = 'completed' OR status = 'failed') AND completed_at < ?
206
+ const stmt = this.db.prepare(`
207
+ DELETE FROM agent_executions
208
+ WHERE (status = 'completed' OR status = 'failed') AND completed_at < ?
209
209
  `);
210
210
  const result = stmt.run(cutoff);
211
211
  return result.changes;
@@ -12,19 +12,19 @@ export function createMultiLlmPrompts(feature, techStack) {
12
12
  const stackStr = techStack.length > 0 ? techStack.join(', ') : 'the project';
13
13
  return {
14
14
  bestPractices: {
15
- gpt: `Best practices for implementing "${feature}" with ${stackStr}.
16
- Focus on: architecture patterns, code conventions, design patterns.
15
+ gpt: `Best practices for implementing "${feature}" with ${stackStr}.
16
+ Focus on: architecture patterns, code conventions, design patterns.
17
17
  Return JSON: { patterns: string[], antiPatterns: string[], libraries: string[] }`,
18
- gemini: `Best practices for implementing "${feature}" with ${stackStr}.
19
- Focus on: latest trends, framework updates, modern approaches.
18
+ gemini: `Best practices for implementing "${feature}" with ${stackStr}.
19
+ Focus on: latest trends, framework updates, modern approaches.
20
20
  Return JSON: { patterns: string[], antiPatterns: string[], libraries: string[] }`
21
21
  },
22
22
  security: {
23
- gpt: `Security considerations for "${feature}" with ${stackStr}.
24
- Focus on: CVE database, known vulnerabilities, exploit patterns.
23
+ gpt: `Security considerations for "${feature}" with ${stackStr}.
24
+ Focus on: CVE database, known vulnerabilities, exploit patterns.
25
25
  Return JSON: { vulnerabilities: string[], mitigations: string[], checklist: string[] }`,
26
- gemini: `Security advisories for "${feature}" with ${stackStr}.
27
- Focus on: latest patches, recent incidents, security best practices.
26
+ gemini: `Security advisories for "${feature}" with ${stackStr}.
27
+ Focus on: latest patches, recent incidents, security best practices.
28
28
  Return JSON: { advisories: string[], patches: string[], incidents: string[] }`
29
29
  }
30
30
  };
@@ -10,14 +10,14 @@ describe('SwarmOrchestrator', () => {
10
10
  expect(analysis.score).toBeLessThan(10);
11
11
  });
12
12
  it('복잡한 프롬프트는 높은 복잡도', async () => {
13
- const complexPrompt = `
14
- Implement a complete login feature:
15
- 1. Create the login form UI with React
16
- 2. Add form validation with Zod
17
- 3. Implement the API endpoint with authentication
18
- 4. Add error handling and loading states
19
- 5. Write unit tests for all components
20
- 6. Add security measures against CSRF
13
+ const complexPrompt = `
14
+ Implement a complete login feature:
15
+ 1. Create the login form UI with React
16
+ 2. Add form validation with Zod
17
+ 3. Implement the API endpoint with authentication
18
+ 4. Add error handling and loading states
19
+ 5. Write unit tests for all components
20
+ 6. Add security measures against CSRF
21
21
  `;
22
22
  const analysis = await analyzeTaskComplexity(complexPrompt);
23
23
  expect(analysis.score).toBeGreaterThan(15);
@@ -29,10 +29,10 @@ describe('SwarmOrchestrator', () => {
29
29
  expect(analysis.factors).toContain('5-files');
30
30
  });
31
31
  it('숫자 목록은 분할 제안 생성', async () => {
32
- const prompt = `
33
- 1. First do this task
34
- 2. Then do second task
35
- 3. Finally do third task
32
+ const prompt = `
33
+ 1. First do this task
34
+ 2. Then do second task
35
+ 3. Finally do third task
36
36
  `;
37
37
  const analysis = await analyzeTaskComplexity(prompt);
38
38
  expect(analysis.suggestedSplits?.length).toBeGreaterThanOrEqual(2);
@@ -65,10 +65,10 @@ describe('SwarmOrchestrator', () => {
65
65
  it('maxDepth 도달 시 분할 안함', async () => {
66
66
  // maxDepth: 0으로 설정하면 분할하지 않음
67
67
  const orchestrator = new SwarmOrchestrator({
68
- prompt: `
69
- 1. Task one
70
- 2. Task two
71
- 3. Task three
68
+ prompt: `
69
+ 1. Task one
70
+ 2. Task two
71
+ 3. Task three
72
72
  `,
73
73
  maxDepth: 0
74
74
  });
@@ -17,45 +17,45 @@ export function createResearchTasks(feature, techStack = []) {
17
17
  {
18
18
  name: 'best-practices-agent',
19
19
  category: 'best-practices',
20
- prompt: `Research best practices for implementing "${feature}" with ${stackStr}. Focus on:
21
- 1. Industry-standard patterns
22
- 2. Common pitfalls to avoid
23
- 3. Recommended libraries/tools
24
- 4. Testing strategies
25
-
20
+ prompt: `Research best practices for implementing "${feature}" with ${stackStr}. Focus on:
21
+ 1. Industry-standard patterns
22
+ 2. Common pitfalls to avoid
23
+ 3. Recommended libraries/tools
24
+ 4. Testing strategies
25
+
26
26
  Provide actionable recommendations.`
27
27
  },
28
28
  {
29
29
  name: 'framework-docs-agent',
30
30
  category: 'framework-docs',
31
- prompt: `Find the latest documentation for ${stackStr} related to "${feature}". Include:
32
- 1. Official API references
33
- 2. Configuration options
34
- 3. Migration guides if applicable
35
- 4. Code examples from official docs
36
-
31
+ prompt: `Find the latest documentation for ${stackStr} related to "${feature}". Include:
32
+ 1. Official API references
33
+ 2. Configuration options
34
+ 3. Migration guides if applicable
35
+ 4. Code examples from official docs
36
+
37
37
  Use context7 MCP if available for up-to-date documentation.`
38
38
  },
39
39
  {
40
40
  name: 'codebase-patterns-agent',
41
41
  category: 'codebase-patterns',
42
- prompt: `Analyze the current codebase for patterns related to "${feature}". Look for:
43
- 1. Similar existing implementations
44
- 2. Established conventions
45
- 3. Reusable utilities
46
- 4. Potential conflicts or dependencies
47
-
42
+ prompt: `Analyze the current codebase for patterns related to "${feature}". Look for:
43
+ 1. Similar existing implementations
44
+ 2. Established conventions
45
+ 3. Reusable utilities
46
+ 4. Potential conflicts or dependencies
47
+
48
48
  Use Glob and Grep to search the codebase.`
49
49
  },
50
50
  {
51
51
  name: 'security-advisory-agent',
52
52
  category: 'security-advisory',
53
- prompt: `Review security considerations for "${feature}" with ${stackStr}. Check:
54
- 1. OWASP Top 10 relevance
55
- 2. Authentication/authorization requirements
56
- 3. Data validation needs
57
- 4. Known vulnerabilities in dependencies
58
-
53
+ prompt: `Review security considerations for "${feature}" with ${stackStr}. Check:
54
+ 1. OWASP Top 10 relevance
55
+ 2. Authentication/authorization requirements
56
+ 3. Data validation needs
57
+ 4. Known vulnerabilities in dependencies
58
+
59
59
  Provide security recommendations.`
60
60
  }
61
61
  ];
@@ -4,10 +4,10 @@ import { analyzeComplexity } from './analyzeComplexity.js';
4
4
  describe('analyzeComplexity', () => {
5
5
  describe('code analysis', () => {
6
6
  it('should analyze simple code', async () => {
7
- const code = `
8
- function add(a, b) {
9
- return a + b;
10
- }
7
+ const code = `
8
+ function add(a, b) {
9
+ return a + b;
10
+ }
11
11
  `;
12
12
  const result = await analyzeComplexity({ code });
13
13
  expect(result.content).toBeDefined();
@@ -15,70 +15,70 @@ function add(a, b) {
15
15
  expect(result.content[0].text).toContain('Complexity');
16
16
  });
17
17
  it('should detect high cyclomatic complexity', async () => {
18
- const code = `
19
- function complex(a, b, c, d) {
20
- if (a > 0) {
21
- if (b > 0) {
22
- if (c > 0) {
23
- if (d > 0) {
24
- for (let i = 0; i < 10; i++) {
25
- while (true) {
26
- switch (i) {
27
- case 1: break;
28
- case 2: break;
29
- case 3: break;
30
- }
31
- break;
32
- }
33
- }
34
- }
35
- }
36
- }
37
- }
38
- }
18
+ const code = `
19
+ function complex(a, b, c, d) {
20
+ if (a > 0) {
21
+ if (b > 0) {
22
+ if (c > 0) {
23
+ if (d > 0) {
24
+ for (let i = 0; i < 10; i++) {
25
+ while (true) {
26
+ switch (i) {
27
+ case 1: break;
28
+ case 2: break;
29
+ case 3: break;
30
+ }
31
+ break;
32
+ }
33
+ }
34
+ }
35
+ }
36
+ }
37
+ }
38
+ }
39
39
  `;
40
40
  const result = await analyzeComplexity({ code });
41
41
  expect(result.content[0].text).toContain('Complexity');
42
42
  // High complexity code should have lower score or issues
43
43
  });
44
44
  it('should calculate cyclomatic metrics only', async () => {
45
- const code = `
46
- function test() {
47
- if (true) return 1;
48
- return 0;
49
- }
45
+ const code = `
46
+ function test() {
47
+ if (true) return 1;
48
+ return 0;
49
+ }
50
50
  `;
51
51
  const result = await analyzeComplexity({ code, metrics: 'cyclomatic' });
52
52
  expect(result.content[0].text).toContain('Complexity');
53
53
  });
54
54
  it('should calculate cognitive metrics only', async () => {
55
- const code = `
56
- function test() {
57
- if (true) {
58
- for (let i = 0; i < 10; i++) {
59
- console.log(i);
60
- }
61
- }
62
- }
55
+ const code = `
56
+ function test() {
57
+ if (true) {
58
+ for (let i = 0; i < 10; i++) {
59
+ console.log(i);
60
+ }
61
+ }
62
+ }
63
63
  `;
64
64
  const result = await analyzeComplexity({ code, metrics: 'cognitive' });
65
65
  expect(result.content[0].text).toContain('Complexity');
66
66
  });
67
67
  it('should calculate halstead metrics only', async () => {
68
- const code = `
69
- const x = 1 + 2 * 3 - 4 / 5;
68
+ const code = `
69
+ const x = 1 + 2 * 3 - 4 / 5;
70
70
  `;
71
71
  const result = await analyzeComplexity({ code, metrics: 'halstead' });
72
72
  expect(result.content[0].text).toContain('Complexity');
73
73
  });
74
74
  it('should calculate all metrics', async () => {
75
- const code = `
76
- function calculate(a, b) {
77
- if (a > b) {
78
- return a - b;
79
- }
80
- return b - a;
81
- }
75
+ const code = `
76
+ function calculate(a, b) {
77
+ if (a > b) {
78
+ return a - b;
79
+ }
80
+ return b - a;
81
+ }
82
82
  `;
83
83
  const result = await analyzeComplexity({ code, metrics: 'all' });
84
84
  expect(result.content[0].text).toContain('Complexity');
@@ -102,18 +102,18 @@ function calculate(a, b) {
102
102
  });
103
103
  describe('Python code detection', () => {
104
104
  it('should detect and analyze Python code', async () => {
105
- const pythonCode = `
106
- def calculate(a, b):
107
- if a > b:
108
- return a - b
109
- return b - a
110
-
111
- class Calculator:
112
- def __init__(self):
113
- self.value = 0
114
-
115
- def add(self, x):
116
- self.value += x
105
+ const pythonCode = `
106
+ def calculate(a, b):
107
+ if a > b:
108
+ return a - b
109
+ return b - a
110
+
111
+ class Calculator:
112
+ def __init__(self):
113
+ self.value = 0
114
+
115
+ def add(self, x):
116
+ self.value += x
117
117
  `;
118
118
  const result = await analyzeComplexity({ code: pythonCode });
119
119
  expect(result.content[0].text).toContain('Python');
@@ -121,34 +121,34 @@ class Calculator:
121
121
  });
122
122
  describe('score calculation', () => {
123
123
  it('should give high score for simple code', async () => {
124
- const simpleCode = `
125
- function simple() {
126
- return 42;
127
- }
124
+ const simpleCode = `
125
+ function simple() {
126
+ return 42;
127
+ }
128
128
  `;
129
129
  const result = await analyzeComplexity({ code: simpleCode });
130
130
  // Simple code should have good score
131
131
  expect(result.content[0].text).toContain('Score');
132
132
  });
133
133
  it('should give lower score for complex code', async () => {
134
- const complexCode = `
135
- function veryComplex(a, b, c, d, e, f, g, h) {
136
- if (a && b || c && d || e && f || g && h) {
137
- for (let i = 0; i < 10; i++) {
138
- for (let j = 0; j < 10; j++) {
139
- if (i > j) {
140
- switch (i) {
141
- case 1: break;
142
- case 2: break;
143
- case 3: break;
144
- case 4: break;
145
- case 5: break;
146
- }
147
- }
148
- }
149
- }
150
- }
151
- }
134
+ const complexCode = `
135
+ function veryComplex(a, b, c, d, e, f, g, h) {
136
+ if (a && b || c && d || e && f || g && h) {
137
+ for (let i = 0; i < 10; i++) {
138
+ for (let j = 0; j < 10; j++) {
139
+ if (i > j) {
140
+ switch (i) {
141
+ case 1: break;
142
+ case 2: break;
143
+ case 3: break;
144
+ case 4: break;
145
+ case 5: break;
146
+ }
147
+ }
148
+ }
149
+ }
150
+ }
151
+ }
152
152
  `;
153
153
  const result = await analyzeComplexity({ code: complexCode });
154
154
  expect(result.content[0].text).toContain('Score');
@@ -157,46 +157,46 @@ function veryComplex(a, b, c, d, e, f, g, h) {
157
157
  });
158
158
  describe('TypeScript code analysis', () => {
159
159
  it('should analyze TypeScript code', async () => {
160
- const tsCode = `
161
- interface User {
162
- name: string;
163
- age: number;
164
- }
165
-
166
- function greet(user: User): string {
167
- if (user.age > 18) {
168
- return \`Hello, \${user.name}!\`;
169
- }
170
- return 'Hello!';
171
- }
160
+ const tsCode = `
161
+ interface User {
162
+ name: string;
163
+ age: number;
164
+ }
165
+
166
+ function greet(user: User): string {
167
+ if (user.age > 18) {
168
+ return \`Hello, \${user.name}!\`;
169
+ }
170
+ return 'Hello!';
171
+ }
172
172
  `;
173
173
  const result = await analyzeComplexity({ code: tsCode });
174
174
  expect(result.content[0].text).toContain('Complexity');
175
175
  });
176
176
  it('should handle class definitions', async () => {
177
177
  // Use explicit TypeScript syntax that won't be mistaken for Python
178
- const tsCode = `
179
- // TypeScript class
180
- export class Calculator {
181
- private value: number = 0;
182
-
183
- public add(x: number): this {
184
- this.value += x;
185
- return this;
186
- }
187
-
188
- public subtract(x: number): this {
189
- if (x > this.value) {
190
- throw new Error('Cannot be negative');
191
- }
192
- this.value -= x;
193
- return this;
194
- }
195
-
196
- public getValue(): number {
197
- return this.value;
198
- }
199
- }
178
+ const tsCode = `
179
+ // TypeScript class
180
+ export class Calculator {
181
+ private value: number = 0;
182
+
183
+ public add(x: number): this {
184
+ this.value += x;
185
+ return this;
186
+ }
187
+
188
+ public subtract(x: number): this {
189
+ if (x > this.value) {
190
+ throw new Error('Cannot be negative');
191
+ }
192
+ this.value -= x;
193
+ return this;
194
+ }
195
+
196
+ public getValue(): number {
197
+ return this.value;
198
+ }
199
+ }
200
200
  `;
201
201
  const result = await analyzeComplexity({ code: tsCode });
202
202
  // Should analyze as TypeScript, not Python