@claude-flow/cli 3.0.0-alpha.6 → 3.0.0-alpha.61

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 (753) hide show
  1. package/.claude/agents/analysis/analyze-code-quality.md +181 -0
  2. package/.claude/agents/analysis/code-analyzer.md +210 -0
  3. package/.claude/agents/architecture/arch-system-design.md +157 -0
  4. package/.claude/agents/consensus/byzantine-coordinator.md +63 -0
  5. package/.claude/agents/consensus/crdt-synchronizer.md +997 -0
  6. package/.claude/agents/consensus/gossip-coordinator.md +63 -0
  7. package/.claude/agents/consensus/performance-benchmarker.md +851 -0
  8. package/.claude/agents/consensus/quorum-manager.md +823 -0
  9. package/.claude/agents/consensus/raft-manager.md +63 -0
  10. package/.claude/agents/consensus/security-manager.md +622 -0
  11. package/.claude/agents/core/coder.md +453 -0
  12. package/.claude/agents/core/planner.md +375 -0
  13. package/.claude/agents/core/researcher.md +369 -0
  14. package/.claude/agents/core/reviewer.md +520 -0
  15. package/.claude/agents/core/tester.md +512 -0
  16. package/.claude/agents/custom/test-long-runner.md +44 -0
  17. package/.claude/agents/data/data-ml-model.md +445 -0
  18. package/.claude/agents/development/dev-backend-api.md +346 -0
  19. package/.claude/agents/devops/ops-cicd-github.md +165 -0
  20. package/.claude/agents/documentation/docs-api-openapi.md +355 -0
  21. package/.claude/agents/flow-nexus/app-store.md +88 -0
  22. package/.claude/agents/flow-nexus/authentication.md +69 -0
  23. package/.claude/agents/flow-nexus/challenges.md +81 -0
  24. package/.claude/agents/flow-nexus/neural-network.md +88 -0
  25. package/.claude/agents/flow-nexus/payments.md +83 -0
  26. package/.claude/agents/flow-nexus/sandbox.md +76 -0
  27. package/.claude/agents/flow-nexus/swarm.md +76 -0
  28. package/.claude/agents/flow-nexus/user-tools.md +96 -0
  29. package/.claude/agents/flow-nexus/workflow.md +84 -0
  30. package/.claude/agents/github/code-review-swarm.md +377 -0
  31. package/.claude/agents/github/github-modes.md +173 -0
  32. package/.claude/agents/github/issue-tracker.md +576 -0
  33. package/.claude/agents/github/multi-repo-swarm.md +553 -0
  34. package/.claude/agents/github/pr-manager.md +438 -0
  35. package/.claude/agents/github/project-board-sync.md +509 -0
  36. package/.claude/agents/github/release-manager.md +605 -0
  37. package/.claude/agents/github/release-swarm.md +583 -0
  38. package/.claude/agents/github/repo-architect.md +398 -0
  39. package/.claude/agents/github/swarm-issue.md +573 -0
  40. package/.claude/agents/github/swarm-pr.md +428 -0
  41. package/.claude/agents/github/sync-coordinator.md +452 -0
  42. package/.claude/agents/github/workflow-automation.md +903 -0
  43. package/.claude/agents/goal/agent.md +816 -0
  44. package/.claude/agents/goal/goal-planner.md +73 -0
  45. package/.claude/agents/optimization/benchmark-suite.md +665 -0
  46. package/.claude/agents/optimization/load-balancer.md +431 -0
  47. package/.claude/agents/optimization/performance-monitor.md +672 -0
  48. package/.claude/agents/optimization/resource-allocator.md +674 -0
  49. package/.claude/agents/optimization/topology-optimizer.md +808 -0
  50. package/.claude/agents/payments/agentic-payments.md +126 -0
  51. package/.claude/agents/sona/sona-learning-optimizer.md +254 -0
  52. package/.claude/agents/sparc/architecture.md +699 -0
  53. package/.claude/agents/sparc/pseudocode.md +520 -0
  54. package/.claude/agents/sparc/refinement.md +802 -0
  55. package/.claude/agents/sparc/specification.md +478 -0
  56. package/.claude/agents/specialized/spec-mobile-react-native.md +227 -0
  57. package/.claude/agents/sublinear/consensus-coordinator.md +338 -0
  58. package/.claude/agents/sublinear/matrix-optimizer.md +185 -0
  59. package/.claude/agents/sublinear/pagerank-analyzer.md +299 -0
  60. package/.claude/agents/sublinear/performance-optimizer.md +368 -0
  61. package/.claude/agents/sublinear/trading-predictor.md +246 -0
  62. package/.claude/agents/swarm/adaptive-coordinator.md +1127 -0
  63. package/.claude/agents/swarm/hierarchical-coordinator.md +710 -0
  64. package/.claude/agents/swarm/mesh-coordinator.md +963 -0
  65. package/.claude/agents/templates/automation-smart-agent.md +205 -0
  66. package/.claude/agents/templates/base-template-generator.md +268 -0
  67. package/.claude/agents/templates/coordinator-swarm-init.md +90 -0
  68. package/.claude/agents/templates/github-pr-manager.md +177 -0
  69. package/.claude/agents/templates/implementer-sparc-coder.md +259 -0
  70. package/.claude/agents/templates/memory-coordinator.md +187 -0
  71. package/.claude/agents/templates/orchestrator-task.md +139 -0
  72. package/.claude/agents/templates/performance-analyzer.md +199 -0
  73. package/.claude/agents/templates/sparc-coordinator.md +514 -0
  74. package/.claude/agents/testing/production-validator.md +395 -0
  75. package/.claude/agents/testing/tdd-london-swarm.md +244 -0
  76. package/.claude/agents/v3/adr-architect.md +184 -0
  77. package/.claude/agents/v3/claims-authorizer.md +208 -0
  78. package/.claude/agents/v3/collective-intelligence-coordinator.md +993 -0
  79. package/.claude/agents/v3/ddd-domain-expert.md +220 -0
  80. package/.claude/agents/v3/memory-specialist.md +995 -0
  81. package/.claude/agents/v3/performance-engineer.md +1233 -0
  82. package/.claude/agents/v3/reasoningbank-learner.md +213 -0
  83. package/.claude/agents/v3/security-architect.md +867 -0
  84. package/.claude/agents/v3/security-auditor.md +771 -0
  85. package/.claude/agents/v3/sparc-orchestrator.md +182 -0
  86. package/.claude/agents/v3/swarm-memory-manager.md +157 -0
  87. package/.claude/agents/v3/v3-integration-architect.md +205 -0
  88. package/.claude/commands/agents/README.md +50 -0
  89. package/.claude/commands/agents/agent-capabilities.md +140 -0
  90. package/.claude/commands/agents/agent-coordination.md +28 -0
  91. package/.claude/commands/agents/agent-spawning.md +28 -0
  92. package/.claude/commands/agents/agent-types.md +216 -0
  93. package/.claude/commands/agents/health.md +139 -0
  94. package/.claude/commands/agents/list.md +100 -0
  95. package/.claude/commands/agents/logs.md +130 -0
  96. package/.claude/commands/agents/metrics.md +122 -0
  97. package/.claude/commands/agents/pool.md +127 -0
  98. package/.claude/commands/agents/spawn.md +140 -0
  99. package/.claude/commands/agents/status.md +115 -0
  100. package/.claude/commands/agents/stop.md +102 -0
  101. package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +54 -0
  102. package/.claude/commands/analysis/README.md +9 -0
  103. package/.claude/commands/analysis/bottleneck-detect.md +162 -0
  104. package/.claude/commands/analysis/performance-bottlenecks.md +59 -0
  105. package/.claude/commands/analysis/performance-report.md +25 -0
  106. package/.claude/commands/analysis/token-efficiency.md +45 -0
  107. package/.claude/commands/analysis/token-usage.md +25 -0
  108. package/.claude/commands/automation/README.md +9 -0
  109. package/.claude/commands/automation/auto-agent.md +122 -0
  110. package/.claude/commands/automation/self-healing.md +106 -0
  111. package/.claude/commands/automation/session-memory.md +90 -0
  112. package/.claude/commands/automation/smart-agents.md +73 -0
  113. package/.claude/commands/automation/smart-spawn.md +25 -0
  114. package/.claude/commands/automation/workflow-select.md +25 -0
  115. package/.claude/commands/claude-flow-help.md +103 -0
  116. package/.claude/commands/claude-flow-memory.md +107 -0
  117. package/.claude/commands/claude-flow-swarm.md +205 -0
  118. package/.claude/commands/coordination/README.md +9 -0
  119. package/.claude/commands/coordination/agent-spawn.md +25 -0
  120. package/.claude/commands/coordination/init.md +44 -0
  121. package/.claude/commands/coordination/orchestrate.md +43 -0
  122. package/.claude/commands/coordination/spawn.md +45 -0
  123. package/.claude/commands/coordination/swarm-init.md +85 -0
  124. package/.claude/commands/coordination/task-orchestrate.md +25 -0
  125. package/.claude/commands/flow-nexus/app-store.md +124 -0
  126. package/.claude/commands/flow-nexus/challenges.md +120 -0
  127. package/.claude/commands/flow-nexus/login-registration.md +65 -0
  128. package/.claude/commands/flow-nexus/neural-network.md +134 -0
  129. package/.claude/commands/flow-nexus/payments.md +116 -0
  130. package/.claude/commands/flow-nexus/sandbox.md +83 -0
  131. package/.claude/commands/flow-nexus/swarm.md +87 -0
  132. package/.claude/commands/flow-nexus/user-tools.md +152 -0
  133. package/.claude/commands/flow-nexus/workflow.md +115 -0
  134. package/.claude/commands/github/README.md +11 -0
  135. package/.claude/commands/github/code-review-swarm.md +514 -0
  136. package/.claude/commands/github/code-review.md +25 -0
  137. package/.claude/commands/github/github-modes.md +147 -0
  138. package/.claude/commands/github/github-swarm.md +121 -0
  139. package/.claude/commands/github/issue-tracker.md +292 -0
  140. package/.claude/commands/github/issue-triage.md +25 -0
  141. package/.claude/commands/github/multi-repo-swarm.md +519 -0
  142. package/.claude/commands/github/pr-enhance.md +26 -0
  143. package/.claude/commands/github/pr-manager.md +170 -0
  144. package/.claude/commands/github/project-board-sync.md +471 -0
  145. package/.claude/commands/github/release-manager.md +338 -0
  146. package/.claude/commands/github/release-swarm.md +544 -0
  147. package/.claude/commands/github/repo-analyze.md +25 -0
  148. package/.claude/commands/github/repo-architect.md +367 -0
  149. package/.claude/commands/github/swarm-issue.md +482 -0
  150. package/.claude/commands/github/swarm-pr.md +285 -0
  151. package/.claude/commands/github/sync-coordinator.md +301 -0
  152. package/.claude/commands/github/workflow-automation.md +442 -0
  153. package/.claude/commands/hive-mind/README.md +17 -0
  154. package/.claude/commands/hive-mind/hive-mind-consensus.md +8 -0
  155. package/.claude/commands/hive-mind/hive-mind-init.md +18 -0
  156. package/.claude/commands/hive-mind/hive-mind-memory.md +8 -0
  157. package/.claude/commands/hive-mind/hive-mind-metrics.md +8 -0
  158. package/.claude/commands/hive-mind/hive-mind-resume.md +8 -0
  159. package/.claude/commands/hive-mind/hive-mind-sessions.md +8 -0
  160. package/.claude/commands/hive-mind/hive-mind-spawn.md +21 -0
  161. package/.claude/commands/hive-mind/hive-mind-status.md +8 -0
  162. package/.claude/commands/hive-mind/hive-mind-stop.md +8 -0
  163. package/.claude/commands/hive-mind/hive-mind-wizard.md +8 -0
  164. package/.claude/commands/hive-mind/hive-mind.md +27 -0
  165. package/.claude/commands/hooks/README.md +11 -0
  166. package/.claude/commands/hooks/overview.md +58 -0
  167. package/.claude/commands/hooks/post-edit.md +117 -0
  168. package/.claude/commands/hooks/post-task.md +112 -0
  169. package/.claude/commands/hooks/pre-edit.md +113 -0
  170. package/.claude/commands/hooks/pre-task.md +111 -0
  171. package/.claude/commands/hooks/session-end.md +118 -0
  172. package/.claude/commands/hooks/setup.md +103 -0
  173. package/.claude/commands/memory/README.md +9 -0
  174. package/.claude/commands/memory/memory-persist.md +25 -0
  175. package/.claude/commands/memory/memory-search.md +25 -0
  176. package/.claude/commands/memory/memory-usage.md +25 -0
  177. package/.claude/commands/memory/neural.md +47 -0
  178. package/.claude/commands/monitoring/README.md +9 -0
  179. package/.claude/commands/monitoring/agent-metrics.md +25 -0
  180. package/.claude/commands/monitoring/agents.md +44 -0
  181. package/.claude/commands/monitoring/real-time-view.md +25 -0
  182. package/.claude/commands/monitoring/status.md +46 -0
  183. package/.claude/commands/monitoring/swarm-monitor.md +25 -0
  184. package/.claude/commands/optimization/README.md +9 -0
  185. package/.claude/commands/optimization/auto-topology.md +62 -0
  186. package/.claude/commands/optimization/cache-manage.md +25 -0
  187. package/.claude/commands/optimization/parallel-execute.md +25 -0
  188. package/.claude/commands/optimization/parallel-execution.md +50 -0
  189. package/.claude/commands/optimization/topology-optimize.md +25 -0
  190. package/.claude/commands/pair/README.md +261 -0
  191. package/.claude/commands/pair/commands.md +546 -0
  192. package/.claude/commands/pair/config.md +510 -0
  193. package/.claude/commands/pair/examples.md +512 -0
  194. package/.claude/commands/pair/modes.md +348 -0
  195. package/.claude/commands/pair/session.md +407 -0
  196. package/.claude/commands/pair/start.md +209 -0
  197. package/.claude/commands/sparc/analyzer.md +52 -0
  198. package/.claude/commands/sparc/architect.md +53 -0
  199. package/.claude/commands/sparc/ask.md +97 -0
  200. package/.claude/commands/sparc/batch-executor.md +54 -0
  201. package/.claude/commands/sparc/code.md +89 -0
  202. package/.claude/commands/sparc/coder.md +54 -0
  203. package/.claude/commands/sparc/debug.md +83 -0
  204. package/.claude/commands/sparc/debugger.md +54 -0
  205. package/.claude/commands/sparc/designer.md +53 -0
  206. package/.claude/commands/sparc/devops.md +109 -0
  207. package/.claude/commands/sparc/docs-writer.md +80 -0
  208. package/.claude/commands/sparc/documenter.md +54 -0
  209. package/.claude/commands/sparc/innovator.md +54 -0
  210. package/.claude/commands/sparc/integration.md +83 -0
  211. package/.claude/commands/sparc/mcp.md +117 -0
  212. package/.claude/commands/sparc/memory-manager.md +54 -0
  213. package/.claude/commands/sparc/optimizer.md +54 -0
  214. package/.claude/commands/sparc/orchestrator.md +132 -0
  215. package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -0
  216. package/.claude/commands/sparc/refinement-optimization-mode.md +83 -0
  217. package/.claude/commands/sparc/researcher.md +54 -0
  218. package/.claude/commands/sparc/reviewer.md +54 -0
  219. package/.claude/commands/sparc/security-review.md +80 -0
  220. package/.claude/commands/sparc/sparc-modes.md +174 -0
  221. package/.claude/commands/sparc/sparc.md +111 -0
  222. package/.claude/commands/sparc/spec-pseudocode.md +80 -0
  223. package/.claude/commands/sparc/supabase-admin.md +348 -0
  224. package/.claude/commands/sparc/swarm-coordinator.md +54 -0
  225. package/.claude/commands/sparc/tdd.md +54 -0
  226. package/.claude/commands/sparc/tester.md +54 -0
  227. package/.claude/commands/sparc/tutorial.md +79 -0
  228. package/.claude/commands/sparc/workflow-manager.md +54 -0
  229. package/.claude/commands/sparc.md +166 -0
  230. package/.claude/commands/stream-chain/pipeline.md +121 -0
  231. package/.claude/commands/stream-chain/run.md +70 -0
  232. package/.claude/commands/swarm/README.md +15 -0
  233. package/.claude/commands/swarm/analysis.md +95 -0
  234. package/.claude/commands/swarm/development.md +96 -0
  235. package/.claude/commands/swarm/examples.md +168 -0
  236. package/.claude/commands/swarm/maintenance.md +102 -0
  237. package/.claude/commands/swarm/optimization.md +117 -0
  238. package/.claude/commands/swarm/research.md +136 -0
  239. package/.claude/commands/swarm/swarm-analysis.md +8 -0
  240. package/.claude/commands/swarm/swarm-background.md +8 -0
  241. package/.claude/commands/swarm/swarm-init.md +19 -0
  242. package/.claude/commands/swarm/swarm-modes.md +8 -0
  243. package/.claude/commands/swarm/swarm-monitor.md +8 -0
  244. package/.claude/commands/swarm/swarm-spawn.md +19 -0
  245. package/.claude/commands/swarm/swarm-status.md +8 -0
  246. package/.claude/commands/swarm/swarm-strategies.md +8 -0
  247. package/.claude/commands/swarm/swarm.md +87 -0
  248. package/.claude/commands/swarm/testing.md +131 -0
  249. package/.claude/commands/training/README.md +9 -0
  250. package/.claude/commands/training/model-update.md +25 -0
  251. package/.claude/commands/training/neural-patterns.md +74 -0
  252. package/.claude/commands/training/neural-train.md +25 -0
  253. package/.claude/commands/training/pattern-learn.md +25 -0
  254. package/.claude/commands/training/specialization.md +63 -0
  255. package/.claude/commands/truth/start.md +143 -0
  256. package/.claude/commands/verify/check.md +50 -0
  257. package/.claude/commands/verify/start.md +128 -0
  258. package/.claude/commands/workflows/README.md +9 -0
  259. package/.claude/commands/workflows/development.md +78 -0
  260. package/.claude/commands/workflows/research.md +63 -0
  261. package/.claude/commands/workflows/workflow-create.md +25 -0
  262. package/.claude/commands/workflows/workflow-execute.md +25 -0
  263. package/.claude/commands/workflows/workflow-export.md +25 -0
  264. package/.claude/helpers/README.md +97 -0
  265. package/.claude/helpers/adr-compliance.sh +186 -0
  266. package/.claude/helpers/auto-commit.sh +178 -0
  267. package/.claude/helpers/checkpoint-manager.sh +251 -0
  268. package/.claude/helpers/daemon-manager.sh +252 -0
  269. package/.claude/helpers/ddd-tracker.sh +144 -0
  270. package/.claude/helpers/github-safe.js +106 -0
  271. package/.claude/helpers/github-setup.sh +28 -0
  272. package/.claude/helpers/guidance-hook.sh +13 -0
  273. package/.claude/helpers/guidance-hooks.sh +102 -0
  274. package/.claude/helpers/health-monitor.sh +108 -0
  275. package/.claude/helpers/learning-hooks.sh +329 -0
  276. package/.claude/helpers/learning-optimizer.sh +127 -0
  277. package/.claude/helpers/learning-service.mjs +1144 -0
  278. package/.claude/helpers/memory.js +83 -0
  279. package/.claude/helpers/metrics-db.mjs +488 -0
  280. package/.claude/helpers/pattern-consolidator.sh +86 -0
  281. package/.claude/helpers/perf-worker.sh +160 -0
  282. package/.claude/helpers/post-commit +16 -0
  283. package/.claude/helpers/pre-commit +26 -0
  284. package/.claude/helpers/quick-start.sh +19 -0
  285. package/.claude/helpers/router.js +66 -0
  286. package/.claude/helpers/security-scanner.sh +127 -0
  287. package/.claude/helpers/session.js +127 -0
  288. package/.claude/helpers/setup-mcp.sh +18 -0
  289. package/.claude/helpers/standard-checkpoint-hooks.sh +189 -0
  290. package/.claude/helpers/statusline-hook.sh +21 -0
  291. package/.claude/helpers/statusline.js +316 -0
  292. package/.claude/helpers/swarm-comms.sh +353 -0
  293. package/.claude/helpers/swarm-hooks.sh +761 -0
  294. package/.claude/helpers/swarm-monitor.sh +211 -0
  295. package/.claude/helpers/sync-v3-metrics.sh +245 -0
  296. package/.claude/helpers/update-v3-progress.sh +166 -0
  297. package/.claude/helpers/v3-quick-status.sh +58 -0
  298. package/.claude/helpers/v3.sh +111 -0
  299. package/.claude/helpers/validate-v3-config.sh +216 -0
  300. package/.claude/helpers/worker-manager.sh +170 -0
  301. package/.claude/settings.json +259 -0
  302. package/.claude/skills/agentdb-advanced/SKILL.md +550 -0
  303. package/.claude/skills/agentdb-learning/SKILL.md +545 -0
  304. package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -0
  305. package/.claude/skills/agentdb-optimization/SKILL.md +509 -0
  306. package/.claude/skills/agentdb-vector-search/SKILL.md +339 -0
  307. package/.claude/skills/agentic-jujutsu/SKILL.md +645 -0
  308. package/.claude/skills/flow-nexus-neural/SKILL.md +738 -0
  309. package/.claude/skills/flow-nexus-platform/SKILL.md +1157 -0
  310. package/.claude/skills/flow-nexus-swarm/SKILL.md +610 -0
  311. package/.claude/skills/github-code-review/SKILL.md +1140 -0
  312. package/.claude/skills/github-multi-repo/SKILL.md +874 -0
  313. package/.claude/skills/github-project-management/SKILL.md +1277 -0
  314. package/.claude/skills/github-release-management/SKILL.md +1081 -0
  315. package/.claude/skills/github-workflow-automation/SKILL.md +1065 -0
  316. package/.claude/skills/hive-mind-advanced/SKILL.md +712 -0
  317. package/.claude/skills/hooks-automation/SKILL.md +1201 -0
  318. package/.claude/skills/pair-programming/SKILL.md +1202 -0
  319. package/.claude/skills/performance-analysis/SKILL.md +563 -0
  320. package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -0
  321. package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -0
  322. package/{.claude-flow → .claude/skills/skill-builder/.claude-flow}/metrics/performance.json +3 -3
  323. package/.claude/skills/skill-builder/.claude-flow/metrics/task-metrics.json +10 -0
  324. package/.claude/skills/skill-builder/SKILL.md +910 -0
  325. package/.claude/skills/sparc-methodology/SKILL.md +1115 -0
  326. package/.claude/skills/stream-chain/SKILL.md +563 -0
  327. package/.claude/skills/swarm-advanced/SKILL.md +973 -0
  328. package/.claude/skills/swarm-orchestration/SKILL.md +179 -0
  329. package/.claude/skills/v3-cli-modernization/SKILL.md +872 -0
  330. package/.claude/skills/v3-core-implementation/SKILL.md +797 -0
  331. package/.claude/skills/v3-ddd-architecture/SKILL.md +442 -0
  332. package/.claude/skills/v3-integration-deep/SKILL.md +241 -0
  333. package/.claude/skills/v3-mcp-optimization/SKILL.md +777 -0
  334. package/.claude/skills/v3-memory-unification/SKILL.md +174 -0
  335. package/.claude/skills/v3-performance-optimization/SKILL.md +390 -0
  336. package/.claude/skills/v3-security-overhaul/SKILL.md +82 -0
  337. package/.claude/skills/v3-swarm-coordination/SKILL.md +340 -0
  338. package/.claude/skills/verification-quality/SKILL.md +649 -0
  339. package/.claude/skills/worker-benchmarks/skill.md +135 -0
  340. package/.claude/skills/worker-integration/skill.md +154 -0
  341. package/README.md +428 -6
  342. package/bin/cli.js +142 -6
  343. package/bin/mcp-server.js +188 -0
  344. package/dist/src/commands/agent.d.ts.map +1 -1
  345. package/dist/src/commands/agent.js +42 -26
  346. package/dist/src/commands/agent.js.map +1 -1
  347. package/dist/src/commands/analyze.d.ts +19 -0
  348. package/dist/src/commands/analyze.d.ts.map +1 -0
  349. package/dist/src/commands/analyze.js +1823 -0
  350. package/dist/src/commands/analyze.js.map +1 -0
  351. package/dist/src/commands/claims.d.ts +10 -0
  352. package/dist/src/commands/claims.d.ts.map +1 -0
  353. package/dist/src/commands/claims.js +288 -0
  354. package/dist/src/commands/claims.js.map +1 -0
  355. package/dist/src/commands/completions.d.ts +10 -0
  356. package/dist/src/commands/completions.d.ts.map +1 -0
  357. package/dist/src/commands/completions.js +539 -0
  358. package/dist/src/commands/completions.js.map +1 -0
  359. package/dist/src/commands/daemon.d.ts +8 -0
  360. package/dist/src/commands/daemon.d.ts.map +1 -0
  361. package/dist/src/commands/daemon.js +593 -0
  362. package/dist/src/commands/daemon.js.map +1 -0
  363. package/dist/src/commands/deployment.d.ts +10 -0
  364. package/dist/src/commands/deployment.d.ts.map +1 -0
  365. package/dist/src/commands/deployment.js +289 -0
  366. package/dist/src/commands/deployment.js.map +1 -0
  367. package/dist/src/commands/doctor.d.ts +10 -0
  368. package/dist/src/commands/doctor.d.ts.map +1 -0
  369. package/dist/src/commands/doctor.js +448 -0
  370. package/dist/src/commands/doctor.js.map +1 -0
  371. package/dist/src/commands/embeddings.d.ts +18 -0
  372. package/dist/src/commands/embeddings.d.ts.map +1 -0
  373. package/dist/src/commands/embeddings.js +616 -0
  374. package/dist/src/commands/embeddings.js.map +1 -0
  375. package/dist/src/commands/hive-mind.d.ts.map +1 -1
  376. package/dist/src/commands/hive-mind.js +252 -35
  377. package/dist/src/commands/hive-mind.js.map +1 -1
  378. package/dist/src/commands/hooks.d.ts.map +1 -1
  379. package/dist/src/commands/hooks.js +800 -6
  380. package/dist/src/commands/hooks.js.map +1 -1
  381. package/dist/src/commands/index.d.ts +52 -14
  382. package/dist/src/commands/index.d.ts.map +1 -1
  383. package/dist/src/commands/index.js +191 -38
  384. package/dist/src/commands/index.js.map +1 -1
  385. package/dist/src/commands/init.d.ts.map +1 -1
  386. package/dist/src/commands/init.js +80 -9
  387. package/dist/src/commands/init.js.map +1 -1
  388. package/dist/src/commands/issues.d.ts +21 -0
  389. package/dist/src/commands/issues.d.ts.map +1 -0
  390. package/dist/src/commands/issues.js +567 -0
  391. package/dist/src/commands/issues.js.map +1 -0
  392. package/dist/src/commands/mcp.js +3 -3
  393. package/dist/src/commands/mcp.js.map +1 -1
  394. package/dist/src/commands/memory.d.ts.map +1 -1
  395. package/dist/src/commands/memory.js +223 -4
  396. package/dist/src/commands/memory.js.map +1 -1
  397. package/dist/src/commands/neural.d.ts +10 -0
  398. package/dist/src/commands/neural.d.ts.map +1 -0
  399. package/dist/src/commands/neural.js +224 -0
  400. package/dist/src/commands/neural.js.map +1 -0
  401. package/dist/src/commands/performance.d.ts +10 -0
  402. package/dist/src/commands/performance.d.ts.map +1 -0
  403. package/dist/src/commands/performance.js +262 -0
  404. package/dist/src/commands/performance.js.map +1 -0
  405. package/dist/src/commands/plugins.d.ts +11 -0
  406. package/dist/src/commands/plugins.d.ts.map +1 -0
  407. package/dist/src/commands/plugins.js +630 -0
  408. package/dist/src/commands/plugins.js.map +1 -0
  409. package/dist/src/commands/progress.d.ts +11 -0
  410. package/dist/src/commands/progress.d.ts.map +1 -0
  411. package/dist/src/commands/progress.js +259 -0
  412. package/dist/src/commands/progress.js.map +1 -0
  413. package/dist/src/commands/providers.d.ts +10 -0
  414. package/dist/src/commands/providers.d.ts.map +1 -0
  415. package/dist/src/commands/providers.js +232 -0
  416. package/dist/src/commands/providers.js.map +1 -0
  417. package/dist/src/commands/route.d.ts +16 -0
  418. package/dist/src/commands/route.d.ts.map +1 -0
  419. package/dist/src/commands/route.js +813 -0
  420. package/dist/src/commands/route.js.map +1 -0
  421. package/dist/src/commands/security.d.ts +10 -0
  422. package/dist/src/commands/security.d.ts.map +1 -0
  423. package/dist/src/commands/security.js +261 -0
  424. package/dist/src/commands/security.js.map +1 -0
  425. package/dist/src/commands/start.d.ts.map +1 -1
  426. package/dist/src/commands/start.js +22 -2
  427. package/dist/src/commands/start.js.map +1 -1
  428. package/dist/src/commands/swarm.d.ts.map +1 -1
  429. package/dist/src/commands/swarm.js +185 -32
  430. package/dist/src/commands/swarm.js.map +1 -1
  431. package/dist/src/commands/transfer-store.d.ts +13 -0
  432. package/dist/src/commands/transfer-store.d.ts.map +1 -0
  433. package/dist/src/commands/transfer-store.js +428 -0
  434. package/dist/src/commands/transfer-store.js.map +1 -0
  435. package/dist/src/index.d.ts +3 -1
  436. package/dist/src/index.d.ts.map +1 -1
  437. package/dist/src/index.js +69 -10
  438. package/dist/src/index.js.map +1 -1
  439. package/dist/src/init/claudemd-generator.d.ts.map +1 -1
  440. package/dist/src/init/claudemd-generator.js +407 -405
  441. package/dist/src/init/claudemd-generator.js.map +1 -1
  442. package/dist/src/init/executor.d.ts.map +1 -1
  443. package/dist/src/init/executor.js +142 -31
  444. package/dist/src/init/executor.js.map +1 -1
  445. package/dist/src/init/helpers-generator.js +1 -1
  446. package/dist/src/init/helpers-generator.js.map +1 -1
  447. package/dist/src/init/mcp-generator.d.ts +9 -0
  448. package/dist/src/init/mcp-generator.d.ts.map +1 -1
  449. package/dist/src/init/mcp-generator.js +57 -28
  450. package/dist/src/init/mcp-generator.js.map +1 -1
  451. package/dist/src/init/settings-generator.d.ts.map +1 -1
  452. package/dist/src/init/settings-generator.js +116 -62
  453. package/dist/src/init/settings-generator.js.map +1 -1
  454. package/dist/src/init/statusline-generator.d.ts +6 -0
  455. package/dist/src/init/statusline-generator.d.ts.map +1 -1
  456. package/dist/src/init/statusline-generator.js +252 -89
  457. package/dist/src/init/statusline-generator.js.map +1 -1
  458. package/dist/src/init/types.d.ts +6 -0
  459. package/dist/src/init/types.d.ts.map +1 -1
  460. package/dist/src/init/types.js +8 -2
  461. package/dist/src/init/types.js.map +1 -1
  462. package/dist/src/mcp-client.d.ts.map +1 -1
  463. package/dist/src/mcp-client.js +17 -1
  464. package/dist/src/mcp-client.js.map +1 -1
  465. package/dist/src/mcp-server.d.ts +6 -1
  466. package/dist/src/mcp-server.d.ts.map +1 -1
  467. package/dist/src/mcp-server.js +169 -38
  468. package/dist/src/mcp-server.js.map +1 -1
  469. package/dist/src/mcp-tools/agent-tools.d.ts +1 -1
  470. package/dist/src/mcp-tools/agent-tools.d.ts.map +1 -1
  471. package/dist/src/mcp-tools/agent-tools.js +350 -14
  472. package/dist/src/mcp-tools/agent-tools.js.map +1 -1
  473. package/dist/src/mcp-tools/analyze-tools.d.ts +38 -0
  474. package/dist/src/mcp-tools/analyze-tools.d.ts.map +1 -0
  475. package/dist/src/mcp-tools/analyze-tools.js +317 -0
  476. package/dist/src/mcp-tools/analyze-tools.js.map +1 -0
  477. package/dist/src/mcp-tools/config-tools.d.ts +1 -1
  478. package/dist/src/mcp-tools/config-tools.d.ts.map +1 -1
  479. package/dist/src/mcp-tools/config-tools.js +262 -15
  480. package/dist/src/mcp-tools/config-tools.js.map +1 -1
  481. package/dist/src/mcp-tools/hive-mind-tools.d.ts +8 -0
  482. package/dist/src/mcp-tools/hive-mind-tools.d.ts.map +1 -0
  483. package/dist/src/mcp-tools/hive-mind-tools.js +447 -0
  484. package/dist/src/mcp-tools/hive-mind-tools.js.map +1 -0
  485. package/dist/src/mcp-tools/hooks-tools.d.ts.map +1 -1
  486. package/dist/src/mcp-tools/hooks-tools.js +195 -31
  487. package/dist/src/mcp-tools/hooks-tools.js.map +1 -1
  488. package/dist/src/mcp-tools/index.d.ts +6 -0
  489. package/dist/src/mcp-tools/index.d.ts.map +1 -1
  490. package/dist/src/mcp-tools/index.js +6 -0
  491. package/dist/src/mcp-tools/index.js.map +1 -1
  492. package/dist/src/mcp-tools/progress-tools.d.ts +14 -0
  493. package/dist/src/mcp-tools/progress-tools.d.ts.map +1 -0
  494. package/dist/src/mcp-tools/progress-tools.js +343 -0
  495. package/dist/src/mcp-tools/progress-tools.js.map +1 -0
  496. package/dist/src/mcp-tools/session-tools.d.ts +1 -1
  497. package/dist/src/mcp-tools/session-tools.d.ts.map +1 -1
  498. package/dist/src/mcp-tools/session-tools.js +237 -22
  499. package/dist/src/mcp-tools/session-tools.js.map +1 -1
  500. package/dist/src/mcp-tools/task-tools.d.ts +1 -1
  501. package/dist/src/mcp-tools/task-tools.d.ts.map +1 -1
  502. package/dist/src/mcp-tools/task-tools.js +219 -17
  503. package/dist/src/mcp-tools/task-tools.js.map +1 -1
  504. package/dist/src/mcp-tools/transfer-tools.d.ts +14 -0
  505. package/dist/src/mcp-tools/transfer-tools.d.ts.map +1 -0
  506. package/dist/src/mcp-tools/transfer-tools.js +396 -0
  507. package/dist/src/mcp-tools/transfer-tools.js.map +1 -0
  508. package/dist/src/mcp-tools/workflow-tools.d.ts +8 -0
  509. package/dist/src/mcp-tools/workflow-tools.d.ts.map +1 -0
  510. package/dist/src/mcp-tools/workflow-tools.js +481 -0
  511. package/dist/src/mcp-tools/workflow-tools.js.map +1 -0
  512. package/dist/src/output.d.ts +16 -0
  513. package/dist/src/output.d.ts.map +1 -1
  514. package/dist/src/output.js +42 -0
  515. package/dist/src/output.js.map +1 -1
  516. package/dist/src/plugins/store/discovery.d.ts +73 -0
  517. package/dist/src/plugins/store/discovery.d.ts.map +1 -0
  518. package/dist/src/plugins/store/discovery.js +568 -0
  519. package/dist/src/plugins/store/discovery.js.map +1 -0
  520. package/dist/src/plugins/store/index.d.ts +76 -0
  521. package/dist/src/plugins/store/index.d.ts.map +1 -0
  522. package/dist/src/plugins/store/index.js +141 -0
  523. package/dist/src/plugins/store/index.js.map +1 -0
  524. package/dist/src/plugins/store/search.d.ts +46 -0
  525. package/dist/src/plugins/store/search.d.ts.map +1 -0
  526. package/dist/src/plugins/store/search.js +230 -0
  527. package/dist/src/plugins/store/search.js.map +1 -0
  528. package/dist/src/plugins/store/types.d.ts +274 -0
  529. package/dist/src/plugins/store/types.d.ts.map +1 -0
  530. package/dist/src/plugins/store/types.js +7 -0
  531. package/dist/src/plugins/store/types.js.map +1 -0
  532. package/dist/src/plugins/tests/demo-plugin-store.d.ts +7 -0
  533. package/dist/src/plugins/tests/demo-plugin-store.d.ts.map +1 -0
  534. package/dist/src/plugins/tests/demo-plugin-store.js +126 -0
  535. package/dist/src/plugins/tests/demo-plugin-store.js.map +1 -0
  536. package/dist/src/plugins/tests/standalone-test.d.ts +12 -0
  537. package/dist/src/plugins/tests/standalone-test.d.ts.map +1 -0
  538. package/dist/src/plugins/tests/standalone-test.js +188 -0
  539. package/dist/src/plugins/tests/standalone-test.js.map +1 -0
  540. package/dist/src/plugins/tests/test-plugin-store.d.ts +7 -0
  541. package/dist/src/plugins/tests/test-plugin-store.d.ts.map +1 -0
  542. package/dist/src/plugins/tests/test-plugin-store.js +206 -0
  543. package/dist/src/plugins/tests/test-plugin-store.js.map +1 -0
  544. package/dist/src/ruvector/ast-analyzer.d.ts +67 -0
  545. package/dist/src/ruvector/ast-analyzer.d.ts.map +1 -0
  546. package/dist/src/ruvector/ast-analyzer.js +277 -0
  547. package/dist/src/ruvector/ast-analyzer.js.map +1 -0
  548. package/dist/src/ruvector/coverage-router.d.ts +160 -0
  549. package/dist/src/ruvector/coverage-router.d.ts.map +1 -0
  550. package/dist/src/ruvector/coverage-router.js +529 -0
  551. package/dist/src/ruvector/coverage-router.js.map +1 -0
  552. package/dist/src/ruvector/coverage-tools.d.ts +33 -0
  553. package/dist/src/ruvector/coverage-tools.d.ts.map +1 -0
  554. package/dist/src/ruvector/coverage-tools.js +157 -0
  555. package/dist/src/ruvector/coverage-tools.js.map +1 -0
  556. package/dist/src/ruvector/diff-classifier.d.ts +175 -0
  557. package/dist/src/ruvector/diff-classifier.d.ts.map +1 -0
  558. package/dist/src/ruvector/diff-classifier.js +698 -0
  559. package/dist/src/ruvector/diff-classifier.js.map +1 -0
  560. package/dist/src/ruvector/graph-analyzer.d.ts +187 -0
  561. package/dist/src/ruvector/graph-analyzer.d.ts.map +1 -0
  562. package/dist/src/ruvector/graph-analyzer.js +929 -0
  563. package/dist/src/ruvector/graph-analyzer.js.map +1 -0
  564. package/dist/src/ruvector/index.d.ts +27 -0
  565. package/dist/src/ruvector/index.d.ts.map +1 -0
  566. package/dist/src/ruvector/index.js +53 -0
  567. package/dist/src/ruvector/index.js.map +1 -0
  568. package/dist/src/ruvector/q-learning-router.d.ts +211 -0
  569. package/dist/src/ruvector/q-learning-router.d.ts.map +1 -0
  570. package/dist/src/ruvector/q-learning-router.js +681 -0
  571. package/dist/src/ruvector/q-learning-router.js.map +1 -0
  572. package/dist/src/ruvector/vector-db.d.ts +69 -0
  573. package/dist/src/ruvector/vector-db.d.ts.map +1 -0
  574. package/dist/src/ruvector/vector-db.js +243 -0
  575. package/dist/src/ruvector/vector-db.js.map +1 -0
  576. package/dist/src/services/claim-service.d.ts +204 -0
  577. package/dist/src/services/claim-service.d.ts.map +1 -0
  578. package/dist/src/services/claim-service.js +818 -0
  579. package/dist/src/services/claim-service.js.map +1 -0
  580. package/dist/src/services/container-worker-pool.d.ts +197 -0
  581. package/dist/src/services/container-worker-pool.d.ts.map +1 -0
  582. package/dist/src/services/container-worker-pool.js +581 -0
  583. package/dist/src/services/container-worker-pool.js.map +1 -0
  584. package/dist/src/services/headless-worker-executor.d.ts +304 -0
  585. package/dist/src/services/headless-worker-executor.d.ts.map +1 -0
  586. package/dist/src/services/headless-worker-executor.js +997 -0
  587. package/dist/src/services/headless-worker-executor.js.map +1 -0
  588. package/dist/src/services/index.d.ts +13 -0
  589. package/dist/src/services/index.d.ts.map +1 -0
  590. package/dist/src/services/index.js +11 -0
  591. package/dist/src/services/index.js.map +1 -0
  592. package/dist/src/services/worker-daemon.d.ts +203 -0
  593. package/dist/src/services/worker-daemon.d.ts.map +1 -0
  594. package/dist/src/services/worker-daemon.js +745 -0
  595. package/dist/src/services/worker-daemon.js.map +1 -0
  596. package/dist/src/services/worker-queue.d.ts +194 -0
  597. package/dist/src/services/worker-queue.d.ts.map +1 -0
  598. package/dist/src/services/worker-queue.js +511 -0
  599. package/dist/src/services/worker-queue.js.map +1 -0
  600. package/dist/src/suggest.d.ts +53 -0
  601. package/dist/src/suggest.d.ts.map +1 -0
  602. package/dist/src/suggest.js +200 -0
  603. package/dist/src/suggest.js.map +1 -0
  604. package/dist/src/transfer/anonymization/index.d.ts +25 -0
  605. package/dist/src/transfer/anonymization/index.d.ts.map +1 -0
  606. package/dist/src/transfer/anonymization/index.js +175 -0
  607. package/dist/src/transfer/anonymization/index.js.map +1 -0
  608. package/dist/src/transfer/deploy-seraphine.d.ts +13 -0
  609. package/dist/src/transfer/deploy-seraphine.d.ts.map +1 -0
  610. package/dist/src/transfer/deploy-seraphine.js +205 -0
  611. package/dist/src/transfer/deploy-seraphine.js.map +1 -0
  612. package/dist/src/transfer/export.d.ts +25 -0
  613. package/dist/src/transfer/export.d.ts.map +1 -0
  614. package/dist/src/transfer/export.js +113 -0
  615. package/dist/src/transfer/export.js.map +1 -0
  616. package/dist/src/transfer/index.d.ts +12 -0
  617. package/dist/src/transfer/index.d.ts.map +1 -0
  618. package/dist/src/transfer/index.js +31 -0
  619. package/dist/src/transfer/index.js.map +1 -0
  620. package/dist/src/transfer/ipfs/client.d.ts +31 -0
  621. package/dist/src/transfer/ipfs/client.d.ts.map +1 -0
  622. package/dist/src/transfer/ipfs/client.js +74 -0
  623. package/dist/src/transfer/ipfs/client.js.map +1 -0
  624. package/dist/src/transfer/ipfs/upload.d.ts +95 -0
  625. package/dist/src/transfer/ipfs/upload.d.ts.map +1 -0
  626. package/dist/src/transfer/ipfs/upload.js +410 -0
  627. package/dist/src/transfer/ipfs/upload.js.map +1 -0
  628. package/dist/src/transfer/models/seraphine.d.ts +72 -0
  629. package/dist/src/transfer/models/seraphine.d.ts.map +1 -0
  630. package/dist/src/transfer/models/seraphine.js +373 -0
  631. package/dist/src/transfer/models/seraphine.js.map +1 -0
  632. package/dist/src/transfer/serialization/cfp.d.ts +49 -0
  633. package/dist/src/transfer/serialization/cfp.d.ts.map +1 -0
  634. package/dist/src/transfer/serialization/cfp.js +180 -0
  635. package/dist/src/transfer/serialization/cfp.js.map +1 -0
  636. package/dist/src/transfer/store/discovery.d.ts +84 -0
  637. package/dist/src/transfer/store/discovery.d.ts.map +1 -0
  638. package/dist/src/transfer/store/discovery.js +275 -0
  639. package/dist/src/transfer/store/discovery.js.map +1 -0
  640. package/dist/src/transfer/store/download.d.ts +70 -0
  641. package/dist/src/transfer/store/download.d.ts.map +1 -0
  642. package/dist/src/transfer/store/download.js +295 -0
  643. package/dist/src/transfer/store/download.js.map +1 -0
  644. package/dist/src/transfer/store/index.d.ts +84 -0
  645. package/dist/src/transfer/store/index.d.ts.map +1 -0
  646. package/dist/src/transfer/store/index.js +153 -0
  647. package/dist/src/transfer/store/index.js.map +1 -0
  648. package/dist/src/transfer/store/publish.d.ts +76 -0
  649. package/dist/src/transfer/store/publish.d.ts.map +1 -0
  650. package/dist/src/transfer/store/publish.js +262 -0
  651. package/dist/src/transfer/store/publish.js.map +1 -0
  652. package/dist/src/transfer/store/registry.d.ts +58 -0
  653. package/dist/src/transfer/store/registry.d.ts.map +1 -0
  654. package/dist/src/transfer/store/registry.js +285 -0
  655. package/dist/src/transfer/store/registry.js.map +1 -0
  656. package/dist/src/transfer/store/search.d.ts +54 -0
  657. package/dist/src/transfer/store/search.d.ts.map +1 -0
  658. package/dist/src/transfer/store/search.js +232 -0
  659. package/dist/src/transfer/store/search.js.map +1 -0
  660. package/dist/src/transfer/store/tests/standalone-test.d.ts +12 -0
  661. package/dist/src/transfer/store/tests/standalone-test.d.ts.map +1 -0
  662. package/dist/src/transfer/store/tests/standalone-test.js +190 -0
  663. package/dist/src/transfer/store/tests/standalone-test.js.map +1 -0
  664. package/dist/src/transfer/store/types.d.ts +193 -0
  665. package/dist/src/transfer/store/types.d.ts.map +1 -0
  666. package/dist/src/transfer/store/types.js +6 -0
  667. package/dist/src/transfer/store/types.js.map +1 -0
  668. package/dist/src/transfer/test-seraphine.d.ts +6 -0
  669. package/dist/src/transfer/test-seraphine.d.ts.map +1 -0
  670. package/dist/src/transfer/test-seraphine.js +105 -0
  671. package/dist/src/transfer/test-seraphine.js.map +1 -0
  672. package/dist/src/transfer/tests/test-store.d.ts +7 -0
  673. package/dist/src/transfer/tests/test-store.d.ts.map +1 -0
  674. package/dist/src/transfer/tests/test-store.js +214 -0
  675. package/dist/src/transfer/tests/test-store.js.map +1 -0
  676. package/dist/src/transfer/types.d.ts +245 -0
  677. package/dist/src/transfer/types.d.ts.map +1 -0
  678. package/dist/src/transfer/types.js +6 -0
  679. package/dist/src/transfer/types.js.map +1 -0
  680. package/dist/tsconfig.tsbuildinfo +1 -1
  681. package/package.json +37 -9
  682. package/.agentic-flow/intelligence.json +0 -17
  683. package/.claude-flow/metrics/task-metrics.json +0 -10
  684. package/__tests__/README.md +0 -140
  685. package/__tests__/TEST_SUMMARY.md +0 -144
  686. package/__tests__/cli.test.ts +0 -558
  687. package/__tests__/commands.test.ts +0 -726
  688. package/__tests__/config-adapter.test.ts +0 -362
  689. package/__tests__/config-loading.test.ts +0 -106
  690. package/__tests__/coverage/.tmp/coverage-0.json +0 -1
  691. package/__tests__/coverage/.tmp/coverage-1.json +0 -1
  692. package/__tests__/coverage/.tmp/coverage-2.json +0 -1
  693. package/__tests__/coverage/.tmp/coverage-3.json +0 -1
  694. package/__tests__/coverage/.tmp/coverage-4.json +0 -1
  695. package/__tests__/coverage/.tmp/coverage-5.json +0 -1
  696. package/__tests__/mcp-client.test.ts +0 -480
  697. package/__tests__/p1-commands.test.ts +0 -1064
  698. package/agents/architect.yaml +0 -11
  699. package/agents/coder.yaml +0 -11
  700. package/agents/reviewer.yaml +0 -10
  701. package/agents/security-architect.yaml +0 -10
  702. package/agents/tester.yaml +0 -10
  703. package/docs/CONFIG_LOADING.md +0 -236
  704. package/docs/IMPLEMENTATION_COMPLETE.md +0 -421
  705. package/docs/MCP_CLIENT_GUIDE.md +0 -620
  706. package/docs/REFACTORING_SUMMARY.md +0 -247
  707. package/src/commands/agent.ts +0 -941
  708. package/src/commands/config.ts +0 -452
  709. package/src/commands/hive-mind.ts +0 -762
  710. package/src/commands/hooks.ts +0 -2603
  711. package/src/commands/index.ts +0 -115
  712. package/src/commands/init.ts +0 -597
  713. package/src/commands/mcp.ts +0 -753
  714. package/src/commands/memory.ts +0 -1161
  715. package/src/commands/migrate.ts +0 -447
  716. package/src/commands/process.ts +0 -695
  717. package/src/commands/session.ts +0 -891
  718. package/src/commands/start.ts +0 -457
  719. package/src/commands/status.ts +0 -736
  720. package/src/commands/swarm.ts +0 -648
  721. package/src/commands/task.ts +0 -792
  722. package/src/commands/workflow.ts +0 -742
  723. package/src/config-adapter.ts +0 -210
  724. package/src/index.ts +0 -400
  725. package/src/infrastructure/in-memory-repositories.ts +0 -310
  726. package/src/init/claudemd-generator.ts +0 -631
  727. package/src/init/executor.ts +0 -762
  728. package/src/init/helpers-generator.ts +0 -628
  729. package/src/init/index.ts +0 -60
  730. package/src/init/mcp-generator.ts +0 -83
  731. package/src/init/settings-generator.ts +0 -274
  732. package/src/init/statusline-generator.ts +0 -211
  733. package/src/init/types.ts +0 -447
  734. package/src/mcp-client.ts +0 -229
  735. package/src/mcp-server.ts +0 -577
  736. package/src/mcp-tools/agent-tools.ts +0 -92
  737. package/src/mcp-tools/config-tools.ts +0 -88
  738. package/src/mcp-tools/hooks-tools.ts +0 -1849
  739. package/src/mcp-tools/index.ts +0 -14
  740. package/src/mcp-tools/memory-tools.ts +0 -270
  741. package/src/mcp-tools/session-tools.ts +0 -102
  742. package/src/mcp-tools/swarm-tools.ts +0 -105
  743. package/src/mcp-tools/task-tools.ts +0 -102
  744. package/src/mcp-tools/types.ts +0 -33
  745. package/src/output.ts +0 -593
  746. package/src/parser.ts +0 -417
  747. package/src/prompt.ts +0 -619
  748. package/src/types.ts +0 -287
  749. package/tsconfig.json +0 -16
  750. package/tsconfig.tsbuildinfo +0 -1
  751. package/vitest.config.ts +0 -13
  752. /package/{tmp.json → .claude/agents/tmp.json} +0 -0
  753. /package/{.claude-flow → .claude/skills/skill-builder/.claude-flow}/metrics/agent-metrics.json +0 -0
@@ -0,0 +1,1823 @@
1
+ /**
2
+ * V3 CLI Analyze Command
3
+ * Code analysis, diff classification, AST analysis, and change risk assessment
4
+ *
5
+ * Features:
6
+ * - AST analysis using ruvector (tree-sitter) with graceful fallback
7
+ * - Symbol extraction (functions, classes, variables, types)
8
+ * - Cyclomatic complexity scoring
9
+ * - Diff classification and risk assessment
10
+ * - Graph boundaries using MinCut algorithm
11
+ * - Module communities using Louvain algorithm
12
+ * - Circular dependency detection
13
+ *
14
+ * Created with ruv.io
15
+ */
16
+ import { output } from '../output.js';
17
+ import { callMCPTool, MCPClientError } from '../mcp-client.js';
18
+ import * as path from 'path';
19
+ import * as fs from 'fs/promises';
20
+ import { writeFile } from 'fs/promises';
21
+ import { resolve } from 'path';
22
+ // Dynamic import for AST analyzer
23
+ async function getASTAnalyzer() {
24
+ try {
25
+ return await import('../ruvector/ast-analyzer.js');
26
+ }
27
+ catch {
28
+ return null;
29
+ }
30
+ }
31
+ // Dynamic import for graph analyzer
32
+ async function getGraphAnalyzer() {
33
+ try {
34
+ return await import('../ruvector/graph-analyzer.js');
35
+ }
36
+ catch {
37
+ return null;
38
+ }
39
+ }
40
+ // Diff subcommand
41
+ const diffCommand = {
42
+ name: 'diff',
43
+ description: 'Analyze git diff for change risk assessment and classification',
44
+ options: [
45
+ {
46
+ name: 'risk',
47
+ short: 'r',
48
+ description: 'Show risk assessment',
49
+ type: 'boolean',
50
+ default: false,
51
+ },
52
+ {
53
+ name: 'classify',
54
+ short: 'c',
55
+ description: 'Classify change type',
56
+ type: 'boolean',
57
+ default: false,
58
+ },
59
+ {
60
+ name: 'reviewers',
61
+ description: 'Show recommended reviewers',
62
+ type: 'boolean',
63
+ default: false,
64
+ },
65
+ {
66
+ name: 'format',
67
+ short: 'f',
68
+ description: 'Output format: text, json, table',
69
+ type: 'string',
70
+ default: 'text',
71
+ choices: ['text', 'json', 'table'],
72
+ },
73
+ {
74
+ name: 'verbose',
75
+ short: 'v',
76
+ description: 'Show detailed file-level analysis',
77
+ type: 'boolean',
78
+ default: false,
79
+ },
80
+ ],
81
+ examples: [
82
+ { command: 'claude-flow analyze diff --risk', description: 'Analyze current diff with risk assessment' },
83
+ { command: 'claude-flow analyze diff HEAD~1 --classify', description: 'Classify changes from last commit' },
84
+ { command: 'claude-flow analyze diff main..feature --format json', description: 'Compare branches with JSON output' },
85
+ { command: 'claude-flow analyze diff --reviewers', description: 'Get recommended reviewers for changes' },
86
+ ],
87
+ action: async (ctx) => {
88
+ const ref = ctx.args[0] || 'HEAD';
89
+ const showRisk = ctx.flags.risk;
90
+ const showClassify = ctx.flags.classify;
91
+ const showReviewers = ctx.flags.reviewers;
92
+ const formatType = ctx.flags.format || 'text';
93
+ const verbose = ctx.flags.verbose;
94
+ // If no specific flag, show all
95
+ const showAll = !showRisk && !showClassify && !showReviewers;
96
+ output.printInfo(`Analyzing diff: ${output.highlight(ref)}`);
97
+ try {
98
+ // Call MCP tool for diff analysis
99
+ const result = await callMCPTool('analyze/diff', {
100
+ ref,
101
+ includeFileRisks: verbose,
102
+ includeReviewers: showReviewers || showAll,
103
+ });
104
+ // JSON output
105
+ if (formatType === 'json') {
106
+ output.printJson(result);
107
+ return { success: true, data: result };
108
+ }
109
+ output.writeln();
110
+ // Summary box
111
+ const files = result.files || [];
112
+ const risk = result.risk || { overall: 'unknown', score: 0, breakdown: { fileCount: 0, totalChanges: 0, highRiskFiles: [], securityConcerns: [], breakingChanges: [], testCoverage: 'unknown' } };
113
+ const classification = result.classification || { category: 'unknown', confidence: 0, reasoning: '' };
114
+ output.printBox([
115
+ `Ref: ${result.ref || 'HEAD'}`,
116
+ `Files: ${files.length}`,
117
+ `Risk: ${getRiskDisplay(risk.overall)} (${risk.score}/100)`,
118
+ `Type: ${classification.category}${classification.subcategory ? ` (${classification.subcategory})` : ''}`,
119
+ ``,
120
+ result.summary || 'No summary available',
121
+ ].join('\n'), 'Diff Analysis');
122
+ // Risk assessment
123
+ if (showRisk || showAll) {
124
+ output.writeln();
125
+ output.writeln(output.bold('Risk Assessment'));
126
+ output.writeln(output.dim('-'.repeat(50)));
127
+ output.printTable({
128
+ columns: [
129
+ { key: 'metric', header: 'Metric', width: 25 },
130
+ { key: 'value', header: 'Value', width: 30 },
131
+ ],
132
+ data: [
133
+ { metric: 'Overall Risk', value: getRiskDisplay(risk.overall) },
134
+ { metric: 'Risk Score', value: `${risk.score}/100` },
135
+ { metric: 'Files Changed', value: risk.breakdown.fileCount },
136
+ { metric: 'Total Lines Changed', value: risk.breakdown.totalChanges },
137
+ { metric: 'Test Coverage', value: risk.breakdown.testCoverage },
138
+ ],
139
+ });
140
+ // Security concerns
141
+ if (risk.breakdown.securityConcerns.length > 0) {
142
+ output.writeln();
143
+ output.writeln(output.bold(output.warning('Security Concerns')));
144
+ output.printList(risk.breakdown.securityConcerns.map(c => output.warning(c)));
145
+ }
146
+ // Breaking changes
147
+ if (risk.breakdown.breakingChanges.length > 0) {
148
+ output.writeln();
149
+ output.writeln(output.bold(output.error('Potential Breaking Changes')));
150
+ output.printList(risk.breakdown.breakingChanges.map(c => output.error(c)));
151
+ }
152
+ // High risk files
153
+ if (risk.breakdown.highRiskFiles.length > 0) {
154
+ output.writeln();
155
+ output.writeln(output.bold('High Risk Files'));
156
+ output.printList(risk.breakdown.highRiskFiles.map(f => output.warning(f)));
157
+ }
158
+ }
159
+ // Classification
160
+ if (showClassify || showAll) {
161
+ output.writeln();
162
+ output.writeln(output.bold('Classification'));
163
+ output.writeln(output.dim('-'.repeat(50)));
164
+ output.printTable({
165
+ columns: [
166
+ { key: 'field', header: 'Field', width: 15 },
167
+ { key: 'value', header: 'Value', width: 40 },
168
+ ],
169
+ data: [
170
+ { field: 'Category', value: classification.category },
171
+ { field: 'Subcategory', value: classification.subcategory || '-' },
172
+ { field: 'Confidence', value: `${(classification.confidence * 100).toFixed(0)}%` },
173
+ ],
174
+ });
175
+ output.writeln();
176
+ output.writeln(output.dim(`Reasoning: ${classification.reasoning}`));
177
+ }
178
+ // Reviewers
179
+ if (showReviewers || showAll) {
180
+ output.writeln();
181
+ output.writeln(output.bold('Recommended Reviewers'));
182
+ output.writeln(output.dim('-'.repeat(50)));
183
+ const reviewers = result.recommendedReviewers || [];
184
+ if (reviewers.length > 0) {
185
+ output.printNumberedList(reviewers.map(r => output.highlight(r)));
186
+ }
187
+ else {
188
+ output.writeln(output.dim('No specific reviewers recommended'));
189
+ }
190
+ }
191
+ // Verbose file-level details
192
+ if (verbose && result.fileRisks) {
193
+ output.writeln();
194
+ output.writeln(output.bold('File-Level Analysis'));
195
+ output.writeln(output.dim('-'.repeat(50)));
196
+ output.printTable({
197
+ columns: [
198
+ { key: 'path', header: 'File', width: 40 },
199
+ { key: 'risk', header: 'Risk', width: 12, format: (v) => getRiskDisplay(String(v)) },
200
+ { key: 'score', header: 'Score', width: 8, align: 'right' },
201
+ { key: 'reasons', header: 'Reasons', width: 30, format: (v) => {
202
+ const reasons = v;
203
+ return reasons.slice(0, 2).join('; ');
204
+ } },
205
+ ],
206
+ data: result.fileRisks,
207
+ });
208
+ }
209
+ // Files changed table
210
+ if (formatType === 'table' || showAll) {
211
+ output.writeln();
212
+ output.writeln(output.bold('Files Changed'));
213
+ output.writeln(output.dim('-'.repeat(50)));
214
+ output.printTable({
215
+ columns: [
216
+ { key: 'status', header: 'Status', width: 10, format: (v) => getStatusDisplay(String(v)) },
217
+ { key: 'path', header: 'File', width: 45 },
218
+ { key: 'additions', header: '+', width: 8, align: 'right', format: (v) => output.success(`+${v}`) },
219
+ { key: 'deletions', header: '-', width: 8, align: 'right', format: (v) => output.error(`-${v}`) },
220
+ ],
221
+ data: files.slice(0, 20),
222
+ });
223
+ if (files.length > 20) {
224
+ output.writeln(output.dim(` ... and ${files.length - 20} more files`));
225
+ }
226
+ }
227
+ return { success: true, data: result };
228
+ }
229
+ catch (error) {
230
+ if (error instanceof MCPClientError) {
231
+ output.printError(`Diff analysis failed: ${error.message}`);
232
+ }
233
+ else {
234
+ output.printError(`Unexpected error: ${String(error)}`);
235
+ }
236
+ return { success: false, exitCode: 1 };
237
+ }
238
+ },
239
+ };
240
+ // Code subcommand (placeholder for future code analysis)
241
+ const codeCommand = {
242
+ name: 'code',
243
+ description: 'Static code analysis and quality assessment',
244
+ options: [
245
+ { name: 'path', short: 'p', type: 'string', description: 'Path to analyze', default: '.' },
246
+ { name: 'type', short: 't', type: 'string', description: 'Analysis type: quality, complexity, security', default: 'quality' },
247
+ { name: 'format', short: 'f', type: 'string', description: 'Output format: text, json', default: 'text' },
248
+ ],
249
+ examples: [
250
+ { command: 'claude-flow analyze code -p ./src', description: 'Analyze source directory' },
251
+ { command: 'claude-flow analyze code --type complexity', description: 'Run complexity analysis' },
252
+ ],
253
+ action: async (ctx) => {
254
+ const path = ctx.flags.path || '.';
255
+ const analysisType = ctx.flags.type || 'quality';
256
+ output.writeln();
257
+ output.writeln(output.bold('Code Analysis'));
258
+ output.writeln(output.dim('-'.repeat(50)));
259
+ output.printInfo(`Analyzing ${path} for ${analysisType}...`);
260
+ output.writeln();
261
+ // Placeholder - would integrate with actual code analysis tools
262
+ output.printBox([
263
+ `Path: ${path}`,
264
+ `Type: ${analysisType}`,
265
+ `Status: Feature in development`,
266
+ ``,
267
+ `Code analysis capabilities coming soon.`,
268
+ `Use 'analyze diff' for change analysis.`,
269
+ ].join('\n'), 'Code Analysis');
270
+ return { success: true };
271
+ },
272
+ };
273
+ // ============================================================================
274
+ // AST Analysis Subcommands (using ruvector tree-sitter with fallback)
275
+ // ============================================================================
276
+ /**
277
+ * Helper: Truncate file path for display
278
+ */
279
+ function truncatePathAst(filePath, maxLen = 45) {
280
+ if (filePath.length <= maxLen)
281
+ return filePath;
282
+ return '...' + filePath.slice(-(maxLen - 3));
283
+ }
284
+ /**
285
+ * Helper: Format complexity value with color coding
286
+ */
287
+ function formatComplexityValueAst(value) {
288
+ if (value <= 5)
289
+ return output.success(String(value));
290
+ if (value <= 10)
291
+ return output.warning(String(value));
292
+ return output.error(String(value));
293
+ }
294
+ /**
295
+ * Helper: Get type marker for symbols
296
+ */
297
+ function getTypeMarkerAst(type) {
298
+ switch (type) {
299
+ case 'function': return output.success('fn');
300
+ case 'class': return output.info('class');
301
+ case 'variable': return output.dim('var');
302
+ case 'type': return output.highlight('type');
303
+ case 'interface': return output.highlight('iface');
304
+ default: return output.dim(type.slice(0, 5));
305
+ }
306
+ }
307
+ /**
308
+ * Helper: Get complexity rating text
309
+ */
310
+ function getComplexityRatingAst(value) {
311
+ if (value <= 5)
312
+ return output.success('Simple');
313
+ if (value <= 10)
314
+ return output.warning('Moderate');
315
+ if (value <= 20)
316
+ return output.error('Complex');
317
+ return output.error(output.bold('Very Complex'));
318
+ }
319
+ /**
320
+ * AST analysis subcommand
321
+ */
322
+ const astCommand = {
323
+ name: 'ast',
324
+ description: 'Analyze code using AST parsing (tree-sitter via ruvector)',
325
+ options: [
326
+ {
327
+ name: 'complexity',
328
+ short: 'c',
329
+ description: 'Include complexity metrics',
330
+ type: 'boolean',
331
+ default: false,
332
+ },
333
+ {
334
+ name: 'symbols',
335
+ short: 's',
336
+ description: 'Include symbol extraction',
337
+ type: 'boolean',
338
+ default: false,
339
+ },
340
+ {
341
+ name: 'format',
342
+ short: 'f',
343
+ description: 'Output format (text, json, table)',
344
+ type: 'string',
345
+ default: 'text',
346
+ choices: ['text', 'json', 'table'],
347
+ },
348
+ {
349
+ name: 'output',
350
+ short: 'o',
351
+ description: 'Output file path',
352
+ type: 'string',
353
+ },
354
+ {
355
+ name: 'verbose',
356
+ short: 'v',
357
+ description: 'Show detailed analysis',
358
+ type: 'boolean',
359
+ default: false,
360
+ },
361
+ ],
362
+ examples: [
363
+ { command: 'claude-flow analyze ast src/', description: 'Analyze all files in src/' },
364
+ { command: 'claude-flow analyze ast src/index.ts --complexity', description: 'Analyze with complexity' },
365
+ { command: 'claude-flow analyze ast . --format json', description: 'JSON output' },
366
+ { command: 'claude-flow analyze ast src/ --symbols', description: 'Extract symbols' },
367
+ ],
368
+ action: async (ctx) => {
369
+ const targetPath = ctx.args[0] || ctx.cwd;
370
+ const showComplexity = ctx.flags.complexity;
371
+ const showSymbols = ctx.flags.symbols;
372
+ const formatType = ctx.flags.format || 'text';
373
+ const outputFile = ctx.flags.output;
374
+ const verbose = ctx.flags.verbose;
375
+ // If no specific flags, show summary
376
+ const showAll = !showComplexity && !showSymbols;
377
+ output.printInfo(`Analyzing: ${output.highlight(targetPath)}`);
378
+ output.writeln();
379
+ const spinner = output.createSpinner({ text: 'Parsing AST...', spinner: 'dots' });
380
+ spinner.start();
381
+ try {
382
+ const astModule = await getASTAnalyzer();
383
+ if (!astModule) {
384
+ spinner.stop();
385
+ output.printWarning('AST analyzer not available, using regex fallback');
386
+ }
387
+ // Resolve path and check if file or directory
388
+ const resolvedPath = resolve(targetPath);
389
+ const stat = await fs.stat(resolvedPath);
390
+ const isDirectory = stat.isDirectory();
391
+ let results = [];
392
+ if (isDirectory) {
393
+ // Scan directory for source files
394
+ const files = await scanSourceFiles(resolvedPath);
395
+ spinner.stop();
396
+ output.printInfo(`Found ${files.length} source files`);
397
+ spinner.start();
398
+ for (const file of files.slice(0, 100)) {
399
+ try {
400
+ const content = await fs.readFile(file, 'utf-8');
401
+ if (astModule) {
402
+ const analyzer = astModule.createASTAnalyzer();
403
+ const analysis = analyzer.analyze(content, file);
404
+ results.push(analysis);
405
+ }
406
+ else {
407
+ // Fallback analysis
408
+ results.push(fallbackAnalyze(content, file));
409
+ }
410
+ }
411
+ catch {
412
+ // Skip files that can't be analyzed
413
+ }
414
+ }
415
+ }
416
+ else {
417
+ // Single file
418
+ const content = await fs.readFile(resolvedPath, 'utf-8');
419
+ if (astModule) {
420
+ const analyzer = astModule.createASTAnalyzer();
421
+ const analysis = analyzer.analyze(content, resolvedPath);
422
+ results.push(analysis);
423
+ }
424
+ else {
425
+ results.push(fallbackAnalyze(content, resolvedPath));
426
+ }
427
+ }
428
+ spinner.stop();
429
+ if (results.length === 0) {
430
+ output.printWarning('No files analyzed');
431
+ return { success: true };
432
+ }
433
+ // Calculate totals
434
+ const totals = {
435
+ files: results.length,
436
+ functions: results.reduce((sum, r) => sum + r.functions.length, 0),
437
+ classes: results.reduce((sum, r) => sum + r.classes.length, 0),
438
+ imports: results.reduce((sum, r) => sum + r.imports.length, 0),
439
+ avgComplexity: results.reduce((sum, r) => sum + r.complexity.cyclomatic, 0) / results.length,
440
+ totalLoc: results.reduce((sum, r) => sum + r.complexity.loc, 0),
441
+ };
442
+ // JSON output
443
+ if (formatType === 'json') {
444
+ const jsonOutput = { files: results, totals };
445
+ if (outputFile) {
446
+ await writeFile(outputFile, JSON.stringify(jsonOutput, null, 2));
447
+ output.printSuccess(`Results written to ${outputFile}`);
448
+ }
449
+ else {
450
+ output.printJson(jsonOutput);
451
+ }
452
+ return { success: true, data: jsonOutput };
453
+ }
454
+ // Summary box
455
+ output.printBox([
456
+ `Files analyzed: ${totals.files}`,
457
+ `Functions: ${totals.functions}`,
458
+ `Classes: ${totals.classes}`,
459
+ `Total LOC: ${totals.totalLoc}`,
460
+ `Avg Complexity: ${formatComplexityValueAst(Math.round(totals.avgComplexity))}`,
461
+ ].join('\n'), 'AST Analysis Summary');
462
+ // Complexity view
463
+ if (showComplexity || showAll) {
464
+ output.writeln();
465
+ output.writeln(output.bold('Complexity by File'));
466
+ output.writeln(output.dim('-'.repeat(60)));
467
+ const complexityData = results
468
+ .map(r => ({
469
+ file: truncatePathAst(r.filePath),
470
+ cyclomatic: r.complexity.cyclomatic,
471
+ cognitive: r.complexity.cognitive,
472
+ loc: r.complexity.loc,
473
+ rating: getComplexityRatingAst(r.complexity.cyclomatic),
474
+ }))
475
+ .sort((a, b) => b.cyclomatic - a.cyclomatic)
476
+ .slice(0, 15);
477
+ output.printTable({
478
+ columns: [
479
+ { key: 'file', header: 'File', width: 40 },
480
+ { key: 'cyclomatic', header: 'Cyclo', width: 8, align: 'right', format: (v) => formatComplexityValueAst(v) },
481
+ { key: 'cognitive', header: 'Cogni', width: 8, align: 'right' },
482
+ { key: 'loc', header: 'LOC', width: 8, align: 'right' },
483
+ { key: 'rating', header: 'Rating', width: 15 },
484
+ ],
485
+ data: complexityData,
486
+ });
487
+ if (results.length > 15) {
488
+ output.writeln(output.dim(` ... and ${results.length - 15} more files`));
489
+ }
490
+ }
491
+ // Symbols view
492
+ if (showSymbols || showAll) {
493
+ output.writeln();
494
+ output.writeln(output.bold('Extracted Symbols'));
495
+ output.writeln(output.dim('-'.repeat(60)));
496
+ const allSymbols = [];
497
+ for (const r of results) {
498
+ for (const fn of r.functions) {
499
+ allSymbols.push({ name: fn.name, type: 'function', file: truncatePathAst(r.filePath, 30), line: fn.startLine });
500
+ }
501
+ for (const cls of r.classes) {
502
+ allSymbols.push({ name: cls.name, type: 'class', file: truncatePathAst(r.filePath, 30), line: cls.startLine });
503
+ }
504
+ }
505
+ const displaySymbols = allSymbols.slice(0, 20);
506
+ output.printTable({
507
+ columns: [
508
+ { key: 'type', header: 'Type', width: 8, format: (v) => getTypeMarkerAst(v) },
509
+ { key: 'name', header: 'Symbol', width: 30 },
510
+ { key: 'file', header: 'File', width: 35 },
511
+ { key: 'line', header: 'Line', width: 8, align: 'right' },
512
+ ],
513
+ data: displaySymbols,
514
+ });
515
+ if (allSymbols.length > 20) {
516
+ output.writeln(output.dim(` ... and ${allSymbols.length - 20} more symbols`));
517
+ }
518
+ }
519
+ // Verbose output
520
+ if (verbose) {
521
+ output.writeln();
522
+ output.writeln(output.bold('Import Analysis'));
523
+ output.writeln(output.dim('-'.repeat(60)));
524
+ const importCounts = new Map();
525
+ for (const r of results) {
526
+ for (const imp of r.imports) {
527
+ importCounts.set(imp, (importCounts.get(imp) || 0) + 1);
528
+ }
529
+ }
530
+ const topImports = Array.from(importCounts.entries())
531
+ .sort((a, b) => b[1] - a[1])
532
+ .slice(0, 10);
533
+ for (const [imp, count] of topImports) {
534
+ output.writeln(` ${output.highlight(count.toString().padStart(3))} ${imp}`);
535
+ }
536
+ }
537
+ if (outputFile) {
538
+ await writeFile(outputFile, JSON.stringify({ files: results, totals }, null, 2));
539
+ output.printSuccess(`Results written to ${outputFile}`);
540
+ }
541
+ return { success: true, data: { files: results, totals } };
542
+ }
543
+ catch (error) {
544
+ spinner.stop();
545
+ const message = error instanceof Error ? error.message : String(error);
546
+ output.printError(`AST analysis failed: ${message}`);
547
+ return { success: false, exitCode: 1 };
548
+ }
549
+ },
550
+ };
551
+ /**
552
+ * Complexity analysis subcommand
553
+ */
554
+ const complexityAstCommand = {
555
+ name: 'complexity',
556
+ aliases: ['cx'],
557
+ description: 'Analyze code complexity metrics',
558
+ options: [
559
+ {
560
+ name: 'threshold',
561
+ short: 't',
562
+ description: 'Complexity threshold to flag (default: 10)',
563
+ type: 'number',
564
+ default: 10,
565
+ },
566
+ {
567
+ name: 'format',
568
+ short: 'f',
569
+ description: 'Output format (text, json)',
570
+ type: 'string',
571
+ default: 'text',
572
+ choices: ['text', 'json'],
573
+ },
574
+ {
575
+ name: 'output',
576
+ short: 'o',
577
+ description: 'Output file path',
578
+ type: 'string',
579
+ },
580
+ ],
581
+ examples: [
582
+ { command: 'claude-flow analyze complexity src/', description: 'Analyze complexity' },
583
+ { command: 'claude-flow analyze complexity src/ --threshold 15', description: 'Flag high complexity' },
584
+ ],
585
+ action: async (ctx) => {
586
+ const targetPath = ctx.args[0] || ctx.cwd;
587
+ const threshold = ctx.flags.threshold || 10;
588
+ const formatType = ctx.flags.format || 'text';
589
+ const outputFile = ctx.flags.output;
590
+ output.printInfo(`Analyzing complexity: ${output.highlight(targetPath)}`);
591
+ output.writeln();
592
+ const spinner = output.createSpinner({ text: 'Calculating complexity...', spinner: 'dots' });
593
+ spinner.start();
594
+ try {
595
+ const astModule = await getASTAnalyzer();
596
+ const resolvedPath = resolve(targetPath);
597
+ const stat = await fs.stat(resolvedPath);
598
+ const files = stat.isDirectory() ? await scanSourceFiles(resolvedPath) : [resolvedPath];
599
+ const results = [];
600
+ for (const file of files.slice(0, 100)) {
601
+ try {
602
+ const content = await fs.readFile(file, 'utf-8');
603
+ let analysis;
604
+ if (astModule) {
605
+ const analyzer = astModule.createASTAnalyzer();
606
+ analysis = analyzer.analyze(content, file);
607
+ }
608
+ else {
609
+ analysis = fallbackAnalyze(content, file);
610
+ }
611
+ const flagged = analysis.complexity.cyclomatic > threshold;
612
+ const rating = analysis.complexity.cyclomatic <= 5 ? 'Simple' :
613
+ analysis.complexity.cyclomatic <= 10 ? 'Moderate' :
614
+ analysis.complexity.cyclomatic <= 20 ? 'Complex' : 'Very Complex';
615
+ results.push({
616
+ file: file,
617
+ cyclomatic: analysis.complexity.cyclomatic,
618
+ cognitive: analysis.complexity.cognitive,
619
+ loc: analysis.complexity.loc,
620
+ commentDensity: analysis.complexity.commentDensity,
621
+ rating,
622
+ flagged,
623
+ });
624
+ }
625
+ catch {
626
+ // Skip files that can't be analyzed
627
+ }
628
+ }
629
+ spinner.stop();
630
+ // Sort by complexity descending
631
+ results.sort((a, b) => b.cyclomatic - a.cyclomatic);
632
+ const flaggedCount = results.filter(r => r.flagged).length;
633
+ const avgComplexity = results.length > 0
634
+ ? results.reduce((sum, r) => sum + r.cyclomatic, 0) / results.length
635
+ : 0;
636
+ if (formatType === 'json') {
637
+ const jsonOutput = { files: results, summary: { total: results.length, flagged: flaggedCount, avgComplexity, threshold } };
638
+ if (outputFile) {
639
+ await writeFile(outputFile, JSON.stringify(jsonOutput, null, 2));
640
+ output.printSuccess(`Results written to ${outputFile}`);
641
+ }
642
+ else {
643
+ output.printJson(jsonOutput);
644
+ }
645
+ return { success: true, data: jsonOutput };
646
+ }
647
+ // Summary
648
+ output.printBox([
649
+ `Files analyzed: ${results.length}`,
650
+ `Threshold: ${threshold}`,
651
+ `Flagged files: ${flaggedCount > 0 ? output.error(String(flaggedCount)) : output.success('0')}`,
652
+ `Average complexity: ${formatComplexityValueAst(Math.round(avgComplexity))}`,
653
+ ].join('\n'), 'Complexity Analysis');
654
+ // Show flagged files first
655
+ if (flaggedCount > 0) {
656
+ output.writeln();
657
+ output.writeln(output.bold(output.warning(`High Complexity Files (>${threshold})`)));
658
+ output.writeln(output.dim('-'.repeat(60)));
659
+ const flaggedFiles = results.filter(r => r.flagged).slice(0, 10);
660
+ output.printTable({
661
+ columns: [
662
+ { key: 'file', header: 'File', width: 40, format: (v) => truncatePathAst(v) },
663
+ { key: 'cyclomatic', header: 'Cyclo', width: 8, align: 'right', format: (v) => output.error(String(v)) },
664
+ { key: 'cognitive', header: 'Cogni', width: 8, align: 'right' },
665
+ { key: 'loc', header: 'LOC', width: 8, align: 'right' },
666
+ { key: 'rating', header: 'Rating', width: 15 },
667
+ ],
668
+ data: flaggedFiles,
669
+ });
670
+ }
671
+ // Show all files in table format
672
+ output.writeln();
673
+ output.writeln(output.bold('All Files'));
674
+ output.writeln(output.dim('-'.repeat(60)));
675
+ const displayFiles = results.slice(0, 15);
676
+ output.printTable({
677
+ columns: [
678
+ { key: 'file', header: 'File', width: 40, format: (v) => truncatePathAst(v) },
679
+ { key: 'cyclomatic', header: 'Cyclo', width: 8, align: 'right', format: (v) => formatComplexityValueAst(v) },
680
+ { key: 'cognitive', header: 'Cogni', width: 8, align: 'right' },
681
+ { key: 'loc', header: 'LOC', width: 8, align: 'right' },
682
+ ],
683
+ data: displayFiles,
684
+ });
685
+ if (results.length > 15) {
686
+ output.writeln(output.dim(` ... and ${results.length - 15} more files`));
687
+ }
688
+ if (outputFile) {
689
+ await writeFile(outputFile, JSON.stringify({ files: results, summary: { total: results.length, flagged: flaggedCount, avgComplexity, threshold } }, null, 2));
690
+ output.printSuccess(`Results written to ${outputFile}`);
691
+ }
692
+ return { success: true, data: { files: results, flaggedCount } };
693
+ }
694
+ catch (error) {
695
+ spinner.stop();
696
+ const message = error instanceof Error ? error.message : String(error);
697
+ output.printError(`Complexity analysis failed: ${message}`);
698
+ return { success: false, exitCode: 1 };
699
+ }
700
+ },
701
+ };
702
+ /**
703
+ * Symbol extraction subcommand
704
+ */
705
+ const symbolsCommand = {
706
+ name: 'symbols',
707
+ aliases: ['sym'],
708
+ description: 'Extract and list code symbols (functions, classes, types)',
709
+ options: [
710
+ {
711
+ name: 'type',
712
+ short: 't',
713
+ description: 'Filter by symbol type (function, class, all)',
714
+ type: 'string',
715
+ default: 'all',
716
+ choices: ['function', 'class', 'all'],
717
+ },
718
+ {
719
+ name: 'format',
720
+ short: 'f',
721
+ description: 'Output format (text, json)',
722
+ type: 'string',
723
+ default: 'text',
724
+ choices: ['text', 'json'],
725
+ },
726
+ {
727
+ name: 'output',
728
+ short: 'o',
729
+ description: 'Output file path',
730
+ type: 'string',
731
+ },
732
+ ],
733
+ examples: [
734
+ { command: 'claude-flow analyze symbols src/', description: 'Extract all symbols' },
735
+ { command: 'claude-flow analyze symbols src/ --type function', description: 'Only functions' },
736
+ { command: 'claude-flow analyze symbols src/ --format json', description: 'JSON output' },
737
+ ],
738
+ action: async (ctx) => {
739
+ const targetPath = ctx.args[0] || ctx.cwd;
740
+ const symbolType = ctx.flags.type || 'all';
741
+ const formatType = ctx.flags.format || 'text';
742
+ const outputFile = ctx.flags.output;
743
+ output.printInfo(`Extracting symbols: ${output.highlight(targetPath)}`);
744
+ output.writeln();
745
+ const spinner = output.createSpinner({ text: 'Parsing code...', spinner: 'dots' });
746
+ spinner.start();
747
+ try {
748
+ const astModule = await getASTAnalyzer();
749
+ const resolvedPath = resolve(targetPath);
750
+ const stat = await fs.stat(resolvedPath);
751
+ const files = stat.isDirectory() ? await scanSourceFiles(resolvedPath) : [resolvedPath];
752
+ const symbols = [];
753
+ for (const file of files.slice(0, 100)) {
754
+ try {
755
+ const content = await fs.readFile(file, 'utf-8');
756
+ let analysis;
757
+ if (astModule) {
758
+ const analyzer = astModule.createASTAnalyzer();
759
+ analysis = analyzer.analyze(content, file);
760
+ }
761
+ else {
762
+ analysis = fallbackAnalyze(content, file);
763
+ }
764
+ if (symbolType === 'all' || symbolType === 'function') {
765
+ for (const fn of analysis.functions) {
766
+ symbols.push({
767
+ name: fn.name,
768
+ type: 'function',
769
+ file,
770
+ startLine: fn.startLine,
771
+ endLine: fn.endLine,
772
+ });
773
+ }
774
+ }
775
+ if (symbolType === 'all' || symbolType === 'class') {
776
+ for (const cls of analysis.classes) {
777
+ symbols.push({
778
+ name: cls.name,
779
+ type: 'class',
780
+ file,
781
+ startLine: cls.startLine,
782
+ endLine: cls.endLine,
783
+ });
784
+ }
785
+ }
786
+ }
787
+ catch {
788
+ // Skip files that can't be parsed
789
+ }
790
+ }
791
+ spinner.stop();
792
+ // Sort by file then name
793
+ symbols.sort((a, b) => a.file.localeCompare(b.file) || a.name.localeCompare(b.name));
794
+ if (formatType === 'json') {
795
+ if (outputFile) {
796
+ await writeFile(outputFile, JSON.stringify(symbols, null, 2));
797
+ output.printSuccess(`Results written to ${outputFile}`);
798
+ }
799
+ else {
800
+ output.printJson(symbols);
801
+ }
802
+ return { success: true, data: symbols };
803
+ }
804
+ // Summary
805
+ const functionCount = symbols.filter(s => s.type === 'function').length;
806
+ const classCount = symbols.filter(s => s.type === 'class').length;
807
+ output.printBox([
808
+ `Total symbols: ${symbols.length}`,
809
+ `Functions: ${functionCount}`,
810
+ `Classes: ${classCount}`,
811
+ `Files: ${files.length}`,
812
+ ].join('\n'), 'Symbol Extraction');
813
+ output.writeln();
814
+ output.writeln(output.bold('Symbols'));
815
+ output.writeln(output.dim('-'.repeat(60)));
816
+ const displaySymbols = symbols.slice(0, 30);
817
+ output.printTable({
818
+ columns: [
819
+ { key: 'type', header: 'Type', width: 10, format: (v) => getTypeMarkerAst(v) },
820
+ { key: 'name', header: 'Name', width: 30 },
821
+ { key: 'file', header: 'File', width: 35, format: (v) => truncatePathAst(v, 33) },
822
+ { key: 'startLine', header: 'Line', width: 8, align: 'right' },
823
+ ],
824
+ data: displaySymbols,
825
+ });
826
+ if (symbols.length > 30) {
827
+ output.writeln(output.dim(` ... and ${symbols.length - 30} more symbols`));
828
+ }
829
+ if (outputFile) {
830
+ await writeFile(outputFile, JSON.stringify(symbols, null, 2));
831
+ output.printSuccess(`Results written to ${outputFile}`);
832
+ }
833
+ return { success: true, data: symbols };
834
+ }
835
+ catch (error) {
836
+ spinner.stop();
837
+ const message = error instanceof Error ? error.message : String(error);
838
+ output.printError(`Symbol extraction failed: ${message}`);
839
+ return { success: false, exitCode: 1 };
840
+ }
841
+ },
842
+ };
843
+ /**
844
+ * Imports analysis subcommand
845
+ */
846
+ const importsCommand = {
847
+ name: 'imports',
848
+ aliases: ['imp'],
849
+ description: 'Analyze import dependencies across files',
850
+ options: [
851
+ {
852
+ name: 'format',
853
+ short: 'f',
854
+ description: 'Output format (text, json)',
855
+ type: 'string',
856
+ default: 'text',
857
+ choices: ['text', 'json'],
858
+ },
859
+ {
860
+ name: 'output',
861
+ short: 'o',
862
+ description: 'Output file path',
863
+ type: 'string',
864
+ },
865
+ {
866
+ name: 'external',
867
+ short: 'e',
868
+ description: 'Show only external (npm) imports',
869
+ type: 'boolean',
870
+ default: false,
871
+ },
872
+ ],
873
+ examples: [
874
+ { command: 'claude-flow analyze imports src/', description: 'Analyze all imports' },
875
+ { command: 'claude-flow analyze imports src/ --external', description: 'Only npm packages' },
876
+ ],
877
+ action: async (ctx) => {
878
+ const targetPath = ctx.args[0] || ctx.cwd;
879
+ const formatType = ctx.flags.format || 'text';
880
+ const outputFile = ctx.flags.output;
881
+ const externalOnly = ctx.flags.external;
882
+ output.printInfo(`Analyzing imports: ${output.highlight(targetPath)}`);
883
+ output.writeln();
884
+ const spinner = output.createSpinner({ text: 'Scanning imports...', spinner: 'dots' });
885
+ spinner.start();
886
+ try {
887
+ const astModule = await getASTAnalyzer();
888
+ const resolvedPath = resolve(targetPath);
889
+ const stat = await fs.stat(resolvedPath);
890
+ const files = stat.isDirectory() ? await scanSourceFiles(resolvedPath) : [resolvedPath];
891
+ const importCounts = new Map();
892
+ const fileImports = new Map();
893
+ for (const file of files.slice(0, 100)) {
894
+ try {
895
+ const content = await fs.readFile(file, 'utf-8');
896
+ let analysis;
897
+ if (astModule) {
898
+ const analyzer = astModule.createASTAnalyzer();
899
+ analysis = analyzer.analyze(content, file);
900
+ }
901
+ else {
902
+ analysis = fallbackAnalyze(content, file);
903
+ }
904
+ const imports = analysis.imports.filter(imp => {
905
+ if (externalOnly) {
906
+ return !imp.startsWith('.') && !imp.startsWith('/');
907
+ }
908
+ return true;
909
+ });
910
+ fileImports.set(file, imports);
911
+ for (const imp of imports) {
912
+ const existing = importCounts.get(imp) || { count: 0, files: [] };
913
+ existing.count++;
914
+ existing.files.push(file);
915
+ importCounts.set(imp, existing);
916
+ }
917
+ }
918
+ catch {
919
+ // Skip files that can't be parsed
920
+ }
921
+ }
922
+ spinner.stop();
923
+ // Sort by count
924
+ const sortedImports = Array.from(importCounts.entries())
925
+ .sort((a, b) => b[1].count - a[1].count);
926
+ if (formatType === 'json') {
927
+ const jsonOutput = {
928
+ imports: Object.fromEntries(sortedImports),
929
+ fileImports: Object.fromEntries(fileImports),
930
+ };
931
+ if (outputFile) {
932
+ await writeFile(outputFile, JSON.stringify(jsonOutput, null, 2));
933
+ output.printSuccess(`Results written to ${outputFile}`);
934
+ }
935
+ else {
936
+ output.printJson(jsonOutput);
937
+ }
938
+ return { success: true, data: jsonOutput };
939
+ }
940
+ // Summary
941
+ const externalImports = sortedImports.filter(([imp]) => !imp.startsWith('.') && !imp.startsWith('/'));
942
+ const localImports = sortedImports.filter(([imp]) => imp.startsWith('.') || imp.startsWith('/'));
943
+ output.printBox([
944
+ `Total unique imports: ${sortedImports.length}`,
945
+ `External (npm): ${externalImports.length}`,
946
+ `Local (relative): ${localImports.length}`,
947
+ `Files scanned: ${files.length}`,
948
+ ].join('\n'), 'Import Analysis');
949
+ // Most used imports
950
+ output.writeln();
951
+ output.writeln(output.bold('Most Used Imports'));
952
+ output.writeln(output.dim('-'.repeat(60)));
953
+ const topImports = sortedImports.slice(0, 20);
954
+ output.printTable({
955
+ columns: [
956
+ { key: 'count', header: 'Uses', width: 8, align: 'right' },
957
+ { key: 'import', header: 'Import', width: 50 },
958
+ { key: 'type', header: 'Type', width: 10 },
959
+ ],
960
+ data: topImports.map(([imp, data]) => ({
961
+ count: data.count,
962
+ import: imp,
963
+ type: imp.startsWith('.') || imp.startsWith('/') ? output.dim('local') : output.highlight('npm'),
964
+ })),
965
+ });
966
+ if (sortedImports.length > 20) {
967
+ output.writeln(output.dim(` ... and ${sortedImports.length - 20} more imports`));
968
+ }
969
+ if (outputFile) {
970
+ await writeFile(outputFile, JSON.stringify({
971
+ imports: Object.fromEntries(sortedImports),
972
+ fileImports: Object.fromEntries(fileImports),
973
+ }, null, 2));
974
+ output.printSuccess(`Results written to ${outputFile}`);
975
+ }
976
+ return { success: true, data: { imports: sortedImports } };
977
+ }
978
+ catch (error) {
979
+ spinner.stop();
980
+ const message = error instanceof Error ? error.message : String(error);
981
+ output.printError(`Import analysis failed: ${message}`);
982
+ return { success: false, exitCode: 1 };
983
+ }
984
+ },
985
+ };
986
+ /**
987
+ * Helper: Scan directory for source files
988
+ */
989
+ async function scanSourceFiles(dir, maxDepth = 10) {
990
+ const files = [];
991
+ const extensions = ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.cjs'];
992
+ const excludeDirs = ['node_modules', 'dist', 'build', '.git', 'coverage', '__pycache__'];
993
+ async function scan(currentDir, depth) {
994
+ if (depth > maxDepth)
995
+ return;
996
+ try {
997
+ const entries = await fs.readdir(currentDir, { withFileTypes: true });
998
+ for (const entry of entries) {
999
+ const fullPath = path.join(currentDir, entry.name);
1000
+ if (entry.isDirectory()) {
1001
+ if (!excludeDirs.includes(entry.name)) {
1002
+ await scan(fullPath, depth + 1);
1003
+ }
1004
+ }
1005
+ else if (entry.isFile()) {
1006
+ const ext = path.extname(entry.name);
1007
+ if (extensions.includes(ext)) {
1008
+ files.push(fullPath);
1009
+ }
1010
+ }
1011
+ }
1012
+ }
1013
+ catch {
1014
+ // Skip directories we can't read
1015
+ }
1016
+ }
1017
+ await scan(dir, 0);
1018
+ return files;
1019
+ }
1020
+ /**
1021
+ * Fallback analysis when ruvector is not available
1022
+ */
1023
+ function fallbackAnalyze(code, filePath) {
1024
+ const lines = code.split('\n');
1025
+ const functions = [];
1026
+ const classes = [];
1027
+ const imports = [];
1028
+ const exports = [];
1029
+ // Extract functions
1030
+ const funcPattern = /(?:export\s+)?(?:async\s+)?function\s+(\w+)|(?:const|let|var)\s+(\w+)\s*=\s*(?:async\s+)?\([^)]*\)\s*=>|^\s*(?:async\s+)?(\w+)\s*\([^)]*\)\s*(?::\s*\w+)?\s*\{/gm;
1031
+ let match;
1032
+ while ((match = funcPattern.exec(code)) !== null) {
1033
+ const name = match[1] || match[2] || match[3];
1034
+ if (name && !['if', 'while', 'for', 'switch'].includes(name)) {
1035
+ const lineNum = code.substring(0, match.index).split('\n').length;
1036
+ functions.push({ name, startLine: lineNum, endLine: lineNum + 10 });
1037
+ }
1038
+ }
1039
+ // Extract classes
1040
+ const classPattern = /(?:export\s+)?class\s+(\w+)/gm;
1041
+ while ((match = classPattern.exec(code)) !== null) {
1042
+ const lineNum = code.substring(0, match.index).split('\n').length;
1043
+ classes.push({ name: match[1], startLine: lineNum, endLine: lineNum + 20 });
1044
+ }
1045
+ // Extract imports
1046
+ const importPattern = /import\s+(?:.*\s+from\s+)?['"]([^'"]+)['"]/gm;
1047
+ while ((match = importPattern.exec(code)) !== null) {
1048
+ imports.push(match[1]);
1049
+ }
1050
+ const requirePattern = /require\s*\(\s*['"]([^'"]+)['"]\s*\)/gm;
1051
+ while ((match = requirePattern.exec(code)) !== null) {
1052
+ imports.push(match[1]);
1053
+ }
1054
+ // Extract exports
1055
+ const exportPattern = /export\s+(?:default\s+)?(?:const|let|var|function|class|interface|type|enum)\s+(\w+)/gm;
1056
+ while ((match = exportPattern.exec(code)) !== null) {
1057
+ exports.push(match[1]);
1058
+ }
1059
+ // Calculate complexity
1060
+ const nonEmptyLines = lines.filter(l => l.trim().length > 0).length;
1061
+ const commentLines = lines.filter(l => /^\s*(\/\/|\/\*|\*|#)/.test(l)).length;
1062
+ const decisionPoints = (code.match(/\b(if|else|for|while|switch|case|catch|&&|\|\||\?)\b/g) || []).length;
1063
+ let cognitive = 0;
1064
+ let nestingLevel = 0;
1065
+ for (const line of lines) {
1066
+ const opens = (line.match(/\{/g) || []).length;
1067
+ const closes = (line.match(/\}/g) || []).length;
1068
+ if (/\b(if|for|while|switch)\b/.test(line)) {
1069
+ cognitive += 1 + nestingLevel;
1070
+ }
1071
+ nestingLevel = Math.max(0, nestingLevel + opens - closes);
1072
+ }
1073
+ // Detect language
1074
+ const ext = path.extname(filePath).toLowerCase();
1075
+ const language = ext === '.ts' || ext === '.tsx' ? 'typescript' :
1076
+ ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs' ? 'javascript' :
1077
+ ext === '.py' ? 'python' : 'unknown';
1078
+ return {
1079
+ filePath,
1080
+ language,
1081
+ functions,
1082
+ classes,
1083
+ imports,
1084
+ exports,
1085
+ complexity: {
1086
+ cyclomatic: decisionPoints + 1,
1087
+ cognitive,
1088
+ loc: nonEmptyLines,
1089
+ commentDensity: lines.length > 0 ? commentLines / lines.length : 0,
1090
+ },
1091
+ };
1092
+ }
1093
+ // Dependencies subcommand
1094
+ const depsCommand = {
1095
+ name: 'deps',
1096
+ description: 'Analyze project dependencies',
1097
+ options: [
1098
+ { name: 'outdated', short: 'o', type: 'boolean', description: 'Show only outdated dependencies' },
1099
+ { name: 'security', short: 's', type: 'boolean', description: 'Check for security vulnerabilities' },
1100
+ { name: 'format', short: 'f', type: 'string', description: 'Output format: text, json', default: 'text' },
1101
+ ],
1102
+ examples: [
1103
+ { command: 'claude-flow analyze deps --outdated', description: 'Show outdated dependencies' },
1104
+ { command: 'claude-flow analyze deps --security', description: 'Check for vulnerabilities' },
1105
+ ],
1106
+ action: async (ctx) => {
1107
+ const showOutdated = ctx.flags.outdated;
1108
+ const checkSecurity = ctx.flags.security;
1109
+ output.writeln();
1110
+ output.writeln(output.bold('Dependency Analysis'));
1111
+ output.writeln(output.dim('-'.repeat(50)));
1112
+ output.printInfo('Analyzing dependencies...');
1113
+ output.writeln();
1114
+ // Placeholder - would integrate with npm/yarn audit
1115
+ output.printBox([
1116
+ `Outdated Check: ${showOutdated ? 'Enabled' : 'Disabled'}`,
1117
+ `Security Check: ${checkSecurity ? 'Enabled' : 'Disabled'}`,
1118
+ `Status: Feature in development`,
1119
+ ``,
1120
+ `Dependency analysis capabilities coming soon.`,
1121
+ `Use 'security scan --type deps' for security scanning.`,
1122
+ ].join('\n'), 'Dependency Analysis');
1123
+ return { success: true };
1124
+ },
1125
+ };
1126
+ // ============================================================================
1127
+ // Graph Analysis Subcommands (MinCut, Louvain, Circular Dependencies)
1128
+ // ============================================================================
1129
+ /**
1130
+ * Analyze code boundaries using MinCut algorithm
1131
+ */
1132
+ const boundariesCommand = {
1133
+ name: 'boundaries',
1134
+ aliases: ['boundary', 'mincut'],
1135
+ description: 'Find natural code boundaries using MinCut algorithm',
1136
+ options: [
1137
+ {
1138
+ name: 'partitions',
1139
+ short: 'p',
1140
+ description: 'Number of partitions to find',
1141
+ type: 'number',
1142
+ default: 2,
1143
+ },
1144
+ {
1145
+ name: 'output',
1146
+ short: 'o',
1147
+ description: 'Output file path',
1148
+ type: 'string',
1149
+ },
1150
+ {
1151
+ name: 'format',
1152
+ short: 'f',
1153
+ description: 'Output format (text, json, dot)',
1154
+ type: 'string',
1155
+ default: 'text',
1156
+ choices: ['text', 'json', 'dot'],
1157
+ },
1158
+ ],
1159
+ examples: [
1160
+ { command: 'claude-flow analyze boundaries src/', description: 'Find code boundaries in src/' },
1161
+ { command: 'claude-flow analyze boundaries -p 3 src/', description: 'Find 3 partitions' },
1162
+ { command: 'claude-flow analyze boundaries -f dot -o graph.dot src/', description: 'Export to DOT format' },
1163
+ ],
1164
+ action: async (ctx) => {
1165
+ const targetDir = ctx.args[0] || ctx.cwd;
1166
+ const numPartitions = ctx.flags.partitions || 2;
1167
+ const outputFile = ctx.flags.output;
1168
+ const format = ctx.flags.format || 'text';
1169
+ output.printInfo(`Analyzing code boundaries in: ${output.highlight(targetDir)}`);
1170
+ output.writeln();
1171
+ const spinner = output.createSpinner({ text: 'Building dependency graph...', spinner: 'dots' });
1172
+ spinner.start();
1173
+ try {
1174
+ const analyzer = await getGraphAnalyzer();
1175
+ if (!analyzer) {
1176
+ spinner.stop();
1177
+ output.printError('Graph analyzer module not available');
1178
+ return { success: false, exitCode: 1 };
1179
+ }
1180
+ const result = await analyzer.analyzeGraph(resolve(targetDir), {
1181
+ includeBoundaries: true,
1182
+ includeModules: false,
1183
+ numPartitions,
1184
+ });
1185
+ spinner.stop();
1186
+ // Handle different output formats
1187
+ if (format === 'json') {
1188
+ const jsonOutput = {
1189
+ boundaries: result.boundaries,
1190
+ statistics: result.statistics,
1191
+ circularDependencies: result.circularDependencies,
1192
+ };
1193
+ if (outputFile) {
1194
+ await writeFile(outputFile, JSON.stringify(jsonOutput, null, 2));
1195
+ output.printSuccess(`Results written to ${outputFile}`);
1196
+ }
1197
+ else {
1198
+ output.printJson(jsonOutput);
1199
+ }
1200
+ return { success: true, data: jsonOutput };
1201
+ }
1202
+ if (format === 'dot') {
1203
+ const dotOutput = analyzer.exportToDot(result, {
1204
+ includeLabels: true,
1205
+ highlightCycles: true,
1206
+ });
1207
+ if (outputFile) {
1208
+ await writeFile(outputFile, dotOutput);
1209
+ output.printSuccess(`DOT graph written to ${outputFile}`);
1210
+ output.writeln(output.dim('Visualize with: dot -Tpng -o graph.png ' + outputFile));
1211
+ }
1212
+ else {
1213
+ output.writeln(dotOutput);
1214
+ }
1215
+ return { success: true };
1216
+ }
1217
+ // Text format (default)
1218
+ output.printBox([
1219
+ `Files analyzed: ${result.statistics.nodeCount}`,
1220
+ `Dependencies: ${result.statistics.edgeCount}`,
1221
+ `Avg degree: ${result.statistics.avgDegree.toFixed(2)}`,
1222
+ `Density: ${(result.statistics.density * 100).toFixed(2)}%`,
1223
+ `Components: ${result.statistics.componentCount}`,
1224
+ ].join('\n'), 'Graph Statistics');
1225
+ if (result.boundaries && result.boundaries.length > 0) {
1226
+ output.writeln();
1227
+ output.writeln(output.bold('MinCut Boundaries'));
1228
+ output.writeln();
1229
+ for (let i = 0; i < result.boundaries.length; i++) {
1230
+ const boundary = result.boundaries[i];
1231
+ output.writeln(output.bold(`Boundary ${i + 1} (cut value: ${boundary.cutValue})`));
1232
+ output.writeln();
1233
+ output.writeln(output.dim('Partition 1:'));
1234
+ const p1Display = boundary.partition1.slice(0, 10);
1235
+ output.printList(p1Display);
1236
+ if (boundary.partition1.length > 10) {
1237
+ output.writeln(output.dim(` ... and ${boundary.partition1.length - 10} more files`));
1238
+ }
1239
+ output.writeln();
1240
+ output.writeln(output.dim('Partition 2:'));
1241
+ const p2Display = boundary.partition2.slice(0, 10);
1242
+ output.printList(p2Display);
1243
+ if (boundary.partition2.length > 10) {
1244
+ output.writeln(output.dim(` ... and ${boundary.partition2.length - 10} more files`));
1245
+ }
1246
+ output.writeln();
1247
+ output.writeln(output.success('Suggestion:'));
1248
+ output.writeln(` ${boundary.suggestion}`);
1249
+ output.writeln();
1250
+ }
1251
+ }
1252
+ // Show circular dependencies
1253
+ if (result.circularDependencies.length > 0) {
1254
+ output.writeln();
1255
+ output.writeln(output.bold(output.warning('Circular Dependencies Detected')));
1256
+ output.writeln();
1257
+ for (const cycle of result.circularDependencies.slice(0, 5)) {
1258
+ const severityColor = cycle.severity === 'high' ? output.error : cycle.severity === 'medium' ? output.warning : output.dim;
1259
+ output.writeln(`${severityColor(`[${cycle.severity.toUpperCase()}]`)} ${cycle.cycle.join(' -> ')}`);
1260
+ output.writeln(output.dim(` ${cycle.suggestion}`));
1261
+ output.writeln();
1262
+ }
1263
+ if (result.circularDependencies.length > 5) {
1264
+ output.writeln(output.dim(`... and ${result.circularDependencies.length - 5} more cycles`));
1265
+ }
1266
+ }
1267
+ if (outputFile) {
1268
+ await writeFile(outputFile, JSON.stringify(result, null, 2));
1269
+ output.printSuccess(`Full results written to ${outputFile}`);
1270
+ }
1271
+ return { success: true, data: result };
1272
+ }
1273
+ catch (error) {
1274
+ spinner.stop();
1275
+ const message = error instanceof Error ? error.message : String(error);
1276
+ output.printError(`Analysis failed: ${message}`);
1277
+ return { success: false, exitCode: 1 };
1278
+ }
1279
+ },
1280
+ };
1281
+ /**
1282
+ * Analyze modules/communities using Louvain algorithm
1283
+ */
1284
+ const modulesCommand = {
1285
+ name: 'modules',
1286
+ aliases: ['communities', 'louvain'],
1287
+ description: 'Detect module communities using Louvain algorithm',
1288
+ options: [
1289
+ {
1290
+ name: 'output',
1291
+ short: 'o',
1292
+ description: 'Output file path',
1293
+ type: 'string',
1294
+ },
1295
+ {
1296
+ name: 'format',
1297
+ short: 'f',
1298
+ description: 'Output format (text, json, dot)',
1299
+ type: 'string',
1300
+ default: 'text',
1301
+ choices: ['text', 'json', 'dot'],
1302
+ },
1303
+ {
1304
+ name: 'min-size',
1305
+ short: 'm',
1306
+ description: 'Minimum community size to display',
1307
+ type: 'number',
1308
+ default: 2,
1309
+ },
1310
+ ],
1311
+ examples: [
1312
+ { command: 'claude-flow analyze modules src/', description: 'Detect module communities' },
1313
+ { command: 'claude-flow analyze modules -f dot -o modules.dot src/', description: 'Export colored DOT graph' },
1314
+ { command: 'claude-flow analyze modules -m 3 src/', description: 'Only show communities with 3+ files' },
1315
+ ],
1316
+ action: async (ctx) => {
1317
+ const targetDir = ctx.args[0] || ctx.cwd;
1318
+ const outputFile = ctx.flags.output;
1319
+ const format = ctx.flags.format || 'text';
1320
+ const minSize = ctx.flags['min-size'] || 2;
1321
+ output.printInfo(`Detecting module communities in: ${output.highlight(targetDir)}`);
1322
+ output.writeln();
1323
+ const spinner = output.createSpinner({ text: 'Building dependency graph...', spinner: 'dots' });
1324
+ spinner.start();
1325
+ try {
1326
+ const analyzer = await getGraphAnalyzer();
1327
+ if (!analyzer) {
1328
+ spinner.stop();
1329
+ output.printError('Graph analyzer module not available');
1330
+ return { success: false, exitCode: 1 };
1331
+ }
1332
+ const result = await analyzer.analyzeGraph(resolve(targetDir), {
1333
+ includeBoundaries: false,
1334
+ includeModules: true,
1335
+ });
1336
+ spinner.stop();
1337
+ // Filter communities by size
1338
+ const communities = result.communities?.filter(c => c.members.length >= minSize) || [];
1339
+ // Handle different output formats
1340
+ if (format === 'json') {
1341
+ const jsonOutput = {
1342
+ communities,
1343
+ statistics: result.statistics,
1344
+ };
1345
+ if (outputFile) {
1346
+ await writeFile(outputFile, JSON.stringify(jsonOutput, null, 2));
1347
+ output.printSuccess(`Results written to ${outputFile}`);
1348
+ }
1349
+ else {
1350
+ output.printJson(jsonOutput);
1351
+ }
1352
+ return { success: true, data: jsonOutput };
1353
+ }
1354
+ if (format === 'dot') {
1355
+ const dotOutput = analyzer.exportToDot(result, {
1356
+ includeLabels: true,
1357
+ colorByCommunity: true,
1358
+ highlightCycles: true,
1359
+ });
1360
+ if (outputFile) {
1361
+ await writeFile(outputFile, dotOutput);
1362
+ output.printSuccess(`DOT graph written to ${outputFile}`);
1363
+ output.writeln(output.dim('Visualize with: dot -Tpng -o modules.png ' + outputFile));
1364
+ }
1365
+ else {
1366
+ output.writeln(dotOutput);
1367
+ }
1368
+ return { success: true };
1369
+ }
1370
+ // Text format (default)
1371
+ output.printBox([
1372
+ `Files analyzed: ${result.statistics.nodeCount}`,
1373
+ `Dependencies: ${result.statistics.edgeCount}`,
1374
+ `Communities found: ${result.communities?.length || 0}`,
1375
+ `Showing: ${communities.length} (min size: ${minSize})`,
1376
+ ].join('\n'), 'Module Detection Results');
1377
+ if (communities.length > 0) {
1378
+ output.writeln();
1379
+ output.writeln(output.bold('Detected Communities'));
1380
+ output.writeln();
1381
+ for (const community of communities.slice(0, 10)) {
1382
+ const cohesionIndicator = community.cohesion > 0.5 ? output.success('High') :
1383
+ community.cohesion > 0.2 ? output.warning('Medium') : output.dim('Low');
1384
+ output.writeln(output.bold(`Community ${community.id}: ${community.suggestedName || 'unnamed'}`));
1385
+ output.writeln(` ${output.dim('Cohesion:')} ${cohesionIndicator} (${(community.cohesion * 100).toFixed(1)}%)`);
1386
+ output.writeln(` ${output.dim('Central node:')} ${community.centralNode || 'none'}`);
1387
+ output.writeln(` ${output.dim('Members:')} ${community.members.length} files`);
1388
+ const displayMembers = community.members.slice(0, 5);
1389
+ for (const member of displayMembers) {
1390
+ output.writeln(` - ${member}`);
1391
+ }
1392
+ if (community.members.length > 5) {
1393
+ output.writeln(output.dim(` ... and ${community.members.length - 5} more`));
1394
+ }
1395
+ output.writeln();
1396
+ }
1397
+ if (communities.length > 10) {
1398
+ output.writeln(output.dim(`... and ${communities.length - 10} more communities`));
1399
+ }
1400
+ }
1401
+ if (outputFile) {
1402
+ await writeFile(outputFile, JSON.stringify(result, null, 2));
1403
+ output.printSuccess(`Full results written to ${outputFile}`);
1404
+ }
1405
+ return { success: true, data: result };
1406
+ }
1407
+ catch (error) {
1408
+ spinner.stop();
1409
+ const message = error instanceof Error ? error.message : String(error);
1410
+ output.printError(`Analysis failed: ${message}`);
1411
+ return { success: false, exitCode: 1 };
1412
+ }
1413
+ },
1414
+ };
1415
+ /**
1416
+ * Build and export dependency graph
1417
+ */
1418
+ const dependenciesCommand = {
1419
+ name: 'dependencies',
1420
+ aliases: ['graph'],
1421
+ description: 'Build and export full dependency graph',
1422
+ options: [
1423
+ {
1424
+ name: 'output',
1425
+ short: 'o',
1426
+ description: 'Output file path',
1427
+ type: 'string',
1428
+ },
1429
+ {
1430
+ name: 'format',
1431
+ short: 'f',
1432
+ description: 'Output format (text, json, dot)',
1433
+ type: 'string',
1434
+ default: 'text',
1435
+ choices: ['text', 'json', 'dot'],
1436
+ },
1437
+ {
1438
+ name: 'include',
1439
+ short: 'i',
1440
+ description: 'File extensions to include (comma-separated)',
1441
+ type: 'string',
1442
+ default: '.ts,.tsx,.js,.jsx,.mjs,.cjs',
1443
+ },
1444
+ {
1445
+ name: 'exclude',
1446
+ short: 'e',
1447
+ description: 'Patterns to exclude (comma-separated)',
1448
+ type: 'string',
1449
+ default: 'node_modules,dist,build,.git',
1450
+ },
1451
+ {
1452
+ name: 'depth',
1453
+ short: 'd',
1454
+ description: 'Maximum directory depth',
1455
+ type: 'number',
1456
+ default: 10,
1457
+ },
1458
+ ],
1459
+ examples: [
1460
+ { command: 'claude-flow analyze dependencies src/', description: 'Build dependency graph' },
1461
+ { command: 'claude-flow analyze dependencies -f dot -o deps.dot src/', description: 'Export to DOT' },
1462
+ { command: 'claude-flow analyze dependencies -i .ts,.tsx src/', description: 'Only TypeScript files' },
1463
+ ],
1464
+ action: async (ctx) => {
1465
+ const targetDir = ctx.args[0] || ctx.cwd;
1466
+ const outputFile = ctx.flags.output;
1467
+ const format = ctx.flags.format || 'text';
1468
+ const include = (ctx.flags.include || '.ts,.tsx,.js,.jsx,.mjs,.cjs').split(',');
1469
+ const exclude = (ctx.flags.exclude || 'node_modules,dist,build,.git').split(',');
1470
+ const maxDepth = ctx.flags.depth || 10;
1471
+ output.printInfo(`Building dependency graph for: ${output.highlight(targetDir)}`);
1472
+ output.writeln();
1473
+ const spinner = output.createSpinner({ text: 'Scanning files...', spinner: 'dots' });
1474
+ spinner.start();
1475
+ try {
1476
+ const analyzer = await getGraphAnalyzer();
1477
+ if (!analyzer) {
1478
+ spinner.stop();
1479
+ output.printError('Graph analyzer module not available');
1480
+ return { success: false, exitCode: 1 };
1481
+ }
1482
+ const graph = await analyzer.buildDependencyGraph(resolve(targetDir), {
1483
+ include,
1484
+ exclude,
1485
+ maxDepth,
1486
+ });
1487
+ spinner.stop();
1488
+ // Detect circular dependencies
1489
+ const circularDeps = analyzer.detectCircularDependencies(graph);
1490
+ // Handle different output formats
1491
+ if (format === 'json') {
1492
+ const jsonOutput = {
1493
+ nodes: Array.from(graph.nodes.values()),
1494
+ edges: graph.edges,
1495
+ metadata: graph.metadata,
1496
+ circularDependencies: circularDeps,
1497
+ };
1498
+ if (outputFile) {
1499
+ await writeFile(outputFile, JSON.stringify(jsonOutput, null, 2));
1500
+ output.printSuccess(`Graph written to ${outputFile}`);
1501
+ }
1502
+ else {
1503
+ output.printJson(jsonOutput);
1504
+ }
1505
+ return { success: true, data: jsonOutput };
1506
+ }
1507
+ if (format === 'dot') {
1508
+ const result = { graph, circularDependencies: circularDeps, statistics: {
1509
+ nodeCount: graph.nodes.size,
1510
+ edgeCount: graph.edges.length,
1511
+ avgDegree: 0,
1512
+ maxDegree: 0,
1513
+ density: 0,
1514
+ componentCount: 0,
1515
+ } };
1516
+ const dotOutput = analyzer.exportToDot(result, {
1517
+ includeLabels: true,
1518
+ highlightCycles: true,
1519
+ });
1520
+ if (outputFile) {
1521
+ await writeFile(outputFile, dotOutput);
1522
+ output.printSuccess(`DOT graph written to ${outputFile}`);
1523
+ output.writeln(output.dim('Visualize with: dot -Tpng -o deps.png ' + outputFile));
1524
+ }
1525
+ else {
1526
+ output.writeln(dotOutput);
1527
+ }
1528
+ return { success: true };
1529
+ }
1530
+ // Text format (default)
1531
+ output.printBox([
1532
+ `Files: ${graph.metadata.totalFiles}`,
1533
+ `Dependencies: ${graph.metadata.totalEdges}`,
1534
+ `Build time: ${graph.metadata.buildTime}ms`,
1535
+ `Root: ${graph.metadata.rootDir}`,
1536
+ ].join('\n'), 'Dependency Graph');
1537
+ // Show top files by imports
1538
+ output.writeln();
1539
+ output.writeln(output.bold('Most Connected Files'));
1540
+ output.writeln();
1541
+ const nodesByDegree = Array.from(graph.nodes.values())
1542
+ .map(n => ({
1543
+ ...n,
1544
+ degree: graph.edges.filter(e => e.source === n.id || e.target === n.id).length,
1545
+ }))
1546
+ .sort((a, b) => b.degree - a.degree)
1547
+ .slice(0, 10);
1548
+ output.printTable({
1549
+ columns: [
1550
+ { key: 'path', header: 'File', width: 50 },
1551
+ { key: 'degree', header: 'Connections', width: 12, align: 'right' },
1552
+ { key: 'complexity', header: 'Complexity', width: 12, align: 'right' },
1553
+ ],
1554
+ data: nodesByDegree.map(n => ({
1555
+ path: n.path.length > 48 ? '...' + n.path.slice(-45) : n.path,
1556
+ degree: n.degree,
1557
+ complexity: n.complexity || 0,
1558
+ })),
1559
+ });
1560
+ // Show circular dependencies
1561
+ if (circularDeps.length > 0) {
1562
+ output.writeln();
1563
+ output.writeln(output.bold(output.warning(`Circular Dependencies: ${circularDeps.length}`)));
1564
+ output.writeln();
1565
+ for (const cycle of circularDeps.slice(0, 3)) {
1566
+ output.writeln(` ${cycle.cycle.join(' -> ')}`);
1567
+ }
1568
+ if (circularDeps.length > 3) {
1569
+ output.writeln(output.dim(` ... and ${circularDeps.length - 3} more`));
1570
+ }
1571
+ }
1572
+ if (outputFile) {
1573
+ const fullOutput = {
1574
+ nodes: Array.from(graph.nodes.values()),
1575
+ edges: graph.edges,
1576
+ metadata: graph.metadata,
1577
+ circularDependencies: circularDeps,
1578
+ };
1579
+ await writeFile(outputFile, JSON.stringify(fullOutput, null, 2));
1580
+ output.printSuccess(`Full results written to ${outputFile}`);
1581
+ }
1582
+ return { success: true };
1583
+ }
1584
+ catch (error) {
1585
+ spinner.stop();
1586
+ const message = error instanceof Error ? error.message : String(error);
1587
+ output.printError(`Analysis failed: ${message}`);
1588
+ return { success: false, exitCode: 1 };
1589
+ }
1590
+ },
1591
+ };
1592
+ /**
1593
+ * Detect circular dependencies
1594
+ */
1595
+ const circularCommand = {
1596
+ name: 'circular',
1597
+ aliases: ['cycles'],
1598
+ description: 'Detect circular dependencies in codebase',
1599
+ options: [
1600
+ {
1601
+ name: 'output',
1602
+ short: 'o',
1603
+ description: 'Output file path',
1604
+ type: 'string',
1605
+ },
1606
+ {
1607
+ name: 'format',
1608
+ short: 'f',
1609
+ description: 'Output format (text, json)',
1610
+ type: 'string',
1611
+ default: 'text',
1612
+ choices: ['text', 'json'],
1613
+ },
1614
+ {
1615
+ name: 'severity',
1616
+ short: 's',
1617
+ description: 'Minimum severity to show (low, medium, high)',
1618
+ type: 'string',
1619
+ default: 'low',
1620
+ choices: ['low', 'medium', 'high'],
1621
+ },
1622
+ ],
1623
+ examples: [
1624
+ { command: 'claude-flow analyze circular src/', description: 'Find circular dependencies' },
1625
+ { command: 'claude-flow analyze circular -s high src/', description: 'Only high severity cycles' },
1626
+ ],
1627
+ action: async (ctx) => {
1628
+ const targetDir = ctx.args[0] || ctx.cwd;
1629
+ const outputFile = ctx.flags.output;
1630
+ const format = ctx.flags.format || 'text';
1631
+ const minSeverity = ctx.flags.severity || 'low';
1632
+ output.printInfo(`Detecting circular dependencies in: ${output.highlight(targetDir)}`);
1633
+ output.writeln();
1634
+ const spinner = output.createSpinner({ text: 'Analyzing dependencies...', spinner: 'dots' });
1635
+ spinner.start();
1636
+ try {
1637
+ const analyzer = await getGraphAnalyzer();
1638
+ if (!analyzer) {
1639
+ spinner.stop();
1640
+ output.printError('Graph analyzer module not available');
1641
+ return { success: false, exitCode: 1 };
1642
+ }
1643
+ const graph = await analyzer.buildDependencyGraph(resolve(targetDir));
1644
+ const cycles = analyzer.detectCircularDependencies(graph);
1645
+ spinner.stop();
1646
+ // Filter by severity
1647
+ const severityOrder = { low: 0, medium: 1, high: 2 };
1648
+ const minLevel = severityOrder[minSeverity] || 0;
1649
+ const filtered = cycles.filter(c => severityOrder[c.severity] >= minLevel);
1650
+ if (format === 'json') {
1651
+ const jsonOutput = { cycles: filtered, total: cycles.length, filtered: filtered.length };
1652
+ if (outputFile) {
1653
+ await writeFile(outputFile, JSON.stringify(jsonOutput, null, 2));
1654
+ output.printSuccess(`Results written to ${outputFile}`);
1655
+ }
1656
+ else {
1657
+ output.printJson(jsonOutput);
1658
+ }
1659
+ return { success: true, data: jsonOutput };
1660
+ }
1661
+ // Text format
1662
+ if (filtered.length === 0) {
1663
+ output.printSuccess('No circular dependencies found!');
1664
+ return { success: true };
1665
+ }
1666
+ output.printBox([
1667
+ `Total cycles: ${cycles.length}`,
1668
+ `Shown (${minSeverity}+): ${filtered.length}`,
1669
+ `High severity: ${cycles.filter(c => c.severity === 'high').length}`,
1670
+ `Medium severity: ${cycles.filter(c => c.severity === 'medium').length}`,
1671
+ `Low severity: ${cycles.filter(c => c.severity === 'low').length}`,
1672
+ ].join('\n'), 'Circular Dependencies');
1673
+ output.writeln();
1674
+ // Group by severity
1675
+ const grouped = {
1676
+ high: filtered.filter(c => c.severity === 'high'),
1677
+ medium: filtered.filter(c => c.severity === 'medium'),
1678
+ low: filtered.filter(c => c.severity === 'low'),
1679
+ };
1680
+ for (const [severity, items] of Object.entries(grouped)) {
1681
+ if (items.length === 0)
1682
+ continue;
1683
+ const color = severity === 'high' ? output.error : severity === 'medium' ? output.warning : output.dim;
1684
+ output.writeln(color(output.bold(`${severity.toUpperCase()} SEVERITY (${items.length})`)));
1685
+ output.writeln();
1686
+ for (const cycle of items.slice(0, 5)) {
1687
+ output.writeln(` ${cycle.cycle.join(' -> ')}`);
1688
+ output.writeln(output.dim(` Fix: ${cycle.suggestion}`));
1689
+ output.writeln();
1690
+ }
1691
+ if (items.length > 5) {
1692
+ output.writeln(output.dim(` ... and ${items.length - 5} more ${severity} cycles`));
1693
+ output.writeln();
1694
+ }
1695
+ }
1696
+ if (outputFile) {
1697
+ await writeFile(outputFile, JSON.stringify({ cycles: filtered }, null, 2));
1698
+ output.printSuccess(`Results written to ${outputFile}`);
1699
+ }
1700
+ return { success: true, data: { cycles: filtered } };
1701
+ }
1702
+ catch (error) {
1703
+ spinner.stop();
1704
+ const message = error instanceof Error ? error.message : String(error);
1705
+ output.printError(`Analysis failed: ${message}`);
1706
+ return { success: false, exitCode: 1 };
1707
+ }
1708
+ },
1709
+ };
1710
+ // Helper functions
1711
+ function getRiskDisplay(risk) {
1712
+ switch (risk) {
1713
+ case 'critical':
1714
+ return output.color(output.bold('CRITICAL'), 'bgRed', 'white');
1715
+ case 'high-risk':
1716
+ return output.error('HIGH');
1717
+ case 'medium-risk':
1718
+ return output.warning('MEDIUM');
1719
+ case 'low-risk':
1720
+ return output.success('LOW');
1721
+ default:
1722
+ return risk;
1723
+ }
1724
+ }
1725
+ function getStatusDisplay(status) {
1726
+ switch (status) {
1727
+ case 'added':
1728
+ return output.success('A');
1729
+ case 'modified':
1730
+ return output.warning('M');
1731
+ case 'deleted':
1732
+ return output.error('D');
1733
+ case 'renamed':
1734
+ return output.info('R');
1735
+ default:
1736
+ return status;
1737
+ }
1738
+ }
1739
+ // Main analyze command
1740
+ export const analyzeCommand = {
1741
+ name: 'analyze',
1742
+ description: 'Code analysis, diff classification, graph boundaries, and change risk assessment',
1743
+ aliases: ['an'],
1744
+ subcommands: [
1745
+ diffCommand,
1746
+ codeCommand,
1747
+ depsCommand,
1748
+ astCommand,
1749
+ complexityAstCommand,
1750
+ symbolsCommand,
1751
+ importsCommand,
1752
+ boundariesCommand,
1753
+ modulesCommand,
1754
+ dependenciesCommand,
1755
+ circularCommand,
1756
+ ],
1757
+ options: [
1758
+ {
1759
+ name: 'format',
1760
+ short: 'f',
1761
+ description: 'Output format: text, json, table',
1762
+ type: 'string',
1763
+ default: 'text',
1764
+ },
1765
+ ],
1766
+ examples: [
1767
+ { command: 'claude-flow analyze ast src/', description: 'Analyze code with AST parsing' },
1768
+ { command: 'claude-flow analyze complexity src/ --threshold 15', description: 'Find high-complexity files' },
1769
+ { command: 'claude-flow analyze symbols src/ --type function', description: 'Extract all functions' },
1770
+ { command: 'claude-flow analyze imports src/ --external', description: 'List npm dependencies' },
1771
+ { command: 'claude-flow analyze diff --risk', description: 'Analyze diff with risk assessment' },
1772
+ { command: 'claude-flow analyze boundaries src/', description: 'Find code boundaries using MinCut' },
1773
+ { command: 'claude-flow analyze modules src/', description: 'Detect module communities with Louvain' },
1774
+ { command: 'claude-flow analyze dependencies src/ --format dot', description: 'Export dependency graph as DOT' },
1775
+ { command: 'claude-flow analyze circular src/', description: 'Find circular dependencies' },
1776
+ { command: 'claude-flow analyze deps --security', description: 'Check dependency vulnerabilities' },
1777
+ ],
1778
+ action: async (ctx) => {
1779
+ // If no subcommand, show help
1780
+ output.writeln();
1781
+ output.writeln(output.bold('Analyze Commands'));
1782
+ output.writeln(output.dim('-'.repeat(50)));
1783
+ output.writeln();
1784
+ output.writeln(output.bold('Available subcommands:'));
1785
+ output.writeln();
1786
+ output.writeln(` ${output.highlight('diff')} Analyze git diff for change risk and classification`);
1787
+ output.writeln(` ${output.highlight('code')} Static code analysis and quality assessment`);
1788
+ output.writeln(` ${output.highlight('deps')} Analyze project dependencies`);
1789
+ output.writeln(` ${output.highlight('ast')} AST analysis with symbol extraction and complexity`);
1790
+ output.writeln(` ${output.highlight('complexity')} Analyze cyclomatic and cognitive complexity`);
1791
+ output.writeln(` ${output.highlight('symbols')} Extract functions, classes, and types`);
1792
+ output.writeln(` ${output.highlight('imports')} Analyze import dependencies`);
1793
+ output.writeln(` ${output.highlight('boundaries')} Find code boundaries using MinCut algorithm`);
1794
+ output.writeln(` ${output.highlight('modules')} Detect module communities using Louvain algorithm`);
1795
+ output.writeln(` ${output.highlight('dependencies')} Build and export full dependency graph`);
1796
+ output.writeln(` ${output.highlight('circular')} Detect circular dependencies in codebase`);
1797
+ output.writeln();
1798
+ output.writeln(output.bold('AST Analysis Examples:'));
1799
+ output.writeln();
1800
+ output.writeln(` ${output.dim('claude-flow analyze ast src/')} # Full AST analysis`);
1801
+ output.writeln(` ${output.dim('claude-flow analyze ast src/index.ts -c')} # Include complexity`);
1802
+ output.writeln(` ${output.dim('claude-flow analyze complexity src/ -t 15')} # Flag high complexity`);
1803
+ output.writeln(` ${output.dim('claude-flow analyze symbols src/ --type fn')} # Extract functions`);
1804
+ output.writeln(` ${output.dim('claude-flow analyze imports src/ --external')} # Only npm imports`);
1805
+ output.writeln();
1806
+ output.writeln(output.bold('Graph Analysis Examples:'));
1807
+ output.writeln();
1808
+ output.writeln(` ${output.dim('claude-flow analyze boundaries src/')} # Find natural code boundaries`);
1809
+ output.writeln(` ${output.dim('claude-flow analyze modules src/')} # Detect module communities`);
1810
+ output.writeln(` ${output.dim('claude-flow analyze dependencies -f dot src/')} # Export to DOT format`);
1811
+ output.writeln(` ${output.dim('claude-flow analyze circular src/')} # Find circular deps`);
1812
+ output.writeln();
1813
+ output.writeln(output.bold('Diff Analysis Examples:'));
1814
+ output.writeln();
1815
+ output.writeln(` ${output.dim('claude-flow analyze diff --risk')} # Risk assessment`);
1816
+ output.writeln(` ${output.dim('claude-flow analyze diff HEAD~1 --classify')} # Classify changes`);
1817
+ output.writeln(` ${output.dim('claude-flow analyze diff main..feature')} # Compare branches`);
1818
+ output.writeln();
1819
+ return { success: true };
1820
+ },
1821
+ };
1822
+ export default analyzeCommand;
1823
+ //# sourceMappingURL=analyze.js.map