@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,813 @@
1
+ /**
2
+ * V3 CLI Route Command
3
+ * Intelligent task-to-agent routing using Q-Learning
4
+ *
5
+ * Features:
6
+ * - Q-Learning based agent selection
7
+ * - Semantic task understanding
8
+ * - Confidence scoring
9
+ * - Learning from feedback
10
+ *
11
+ * Created with love by ruv.io
12
+ */
13
+ import { output } from '../output.js';
14
+ import { createQLearningRouter, isRuvectorAvailable, } from '../ruvector/index.js';
15
+ /**
16
+ * Available agent types for routing
17
+ */
18
+ const AGENT_TYPES = [
19
+ { id: 'coder', name: 'Coder', description: 'Implements features and writes code', capabilities: ['coding', 'implementation', 'refactoring'], priority: 1 },
20
+ { id: 'tester', name: 'Tester', description: 'Creates tests and validates functionality', capabilities: ['testing', 'validation', 'quality'], priority: 2 },
21
+ { id: 'reviewer', name: 'Reviewer', description: 'Reviews code quality and security', capabilities: ['review', 'security', 'best-practices'], priority: 3 },
22
+ { id: 'architect', name: 'Architect', description: 'Designs system architecture', capabilities: ['design', 'architecture', 'planning'], priority: 4 },
23
+ { id: 'researcher', name: 'Researcher', description: 'Researches requirements and patterns', capabilities: ['research', 'analysis', 'documentation'], priority: 5 },
24
+ { id: 'optimizer', name: 'Optimizer', description: 'Optimizes performance and efficiency', capabilities: ['optimization', 'performance', 'profiling'], priority: 6 },
25
+ { id: 'debugger', name: 'Debugger', description: 'Debugs issues and fixes bugs', capabilities: ['debugging', 'troubleshooting', 'fixing'], priority: 7 },
26
+ { id: 'documenter', name: 'Documenter', description: 'Creates and updates documentation', capabilities: ['documentation', 'writing', 'explaining'], priority: 8 },
27
+ ];
28
+ // ============================================================================
29
+ // Router Singleton
30
+ // ============================================================================
31
+ let routerInstance = null;
32
+ let routerInitialized = false;
33
+ /**
34
+ * Get or create the router instance
35
+ */
36
+ async function getRouter() {
37
+ if (!routerInstance) {
38
+ routerInstance = createQLearningRouter();
39
+ }
40
+ if (!routerInitialized) {
41
+ await routerInstance.initialize();
42
+ routerInitialized = true;
43
+ }
44
+ return routerInstance;
45
+ }
46
+ /**
47
+ * Get agent type by route name
48
+ */
49
+ function getAgentType(route) {
50
+ return AGENT_TYPES.find(a => a.id === route);
51
+ }
52
+ // ============================================================================
53
+ // Route Subcommand
54
+ // ============================================================================
55
+ const routeTaskCommand = {
56
+ name: 'task',
57
+ description: 'Route a task to the optimal agent using Q-Learning',
58
+ options: [
59
+ {
60
+ name: 'q-learning',
61
+ short: 'q',
62
+ description: 'Use Q-Learning for agent selection (default: true)',
63
+ type: 'boolean',
64
+ default: true,
65
+ },
66
+ {
67
+ name: 'agent',
68
+ short: 'a',
69
+ description: 'Force specific agent (bypasses Q-Learning)',
70
+ type: 'string',
71
+ },
72
+ {
73
+ name: 'explore',
74
+ short: 'e',
75
+ description: 'Enable exploration (random selection chance)',
76
+ type: 'boolean',
77
+ default: true,
78
+ },
79
+ {
80
+ name: 'json',
81
+ short: 'j',
82
+ description: 'Output in JSON format',
83
+ type: 'boolean',
84
+ default: false,
85
+ },
86
+ ],
87
+ examples: [
88
+ { command: 'claude-flow route task "implement authentication"', description: 'Route task to best agent' },
89
+ { command: 'claude-flow route task "write unit tests" --q-learning', description: 'Use Q-Learning routing' },
90
+ { command: 'claude-flow route task "review code" --agent reviewer', description: 'Force specific agent' },
91
+ ],
92
+ action: async (ctx) => {
93
+ const taskDescription = ctx.args[0];
94
+ const forceAgent = ctx.flags.agent;
95
+ const useExploration = ctx.flags.explore;
96
+ const jsonOutput = ctx.flags.json;
97
+ if (!taskDescription) {
98
+ output.printError('Task description is required');
99
+ output.writeln(output.dim('Usage: claude-flow route task "task description"'));
100
+ return { success: false, exitCode: 1 };
101
+ }
102
+ const spinner = output.createSpinner({ text: 'Analyzing task...', spinner: 'dots' });
103
+ spinner.start();
104
+ try {
105
+ if (forceAgent) {
106
+ // Bypass Q-Learning, use specified agent
107
+ const agent = getAgentType(forceAgent) ||
108
+ AGENT_TYPES.find(a => a.name.toLowerCase() === forceAgent.toLowerCase());
109
+ if (!agent) {
110
+ spinner.fail(`Agent "${forceAgent}" not found`);
111
+ output.writeln();
112
+ output.writeln('Available agents:');
113
+ output.printList(AGENT_TYPES.map(a => `${output.highlight(a.id)} - ${a.description}`));
114
+ return { success: false, exitCode: 1 };
115
+ }
116
+ spinner.succeed(`Routed to ${agent.name}`);
117
+ if (jsonOutput) {
118
+ output.printJson({
119
+ task: taskDescription,
120
+ agentId: agent.id,
121
+ agentName: agent.name,
122
+ confidence: 1.0,
123
+ method: 'forced',
124
+ });
125
+ }
126
+ else {
127
+ output.writeln();
128
+ output.printBox([
129
+ `Task: ${taskDescription}`,
130
+ `Agent: ${output.highlight(agent.name)} (${agent.id})`,
131
+ `Confidence: ${output.success('100%')} (forced)`,
132
+ `Description: ${agent.description}`,
133
+ ].join('\n'), 'Routing Result');
134
+ }
135
+ return { success: true, data: { agentId: agent.id, agentName: agent.name } };
136
+ }
137
+ // Use Q-Learning routing
138
+ const router = await getRouter();
139
+ const result = router.route(taskDescription, useExploration);
140
+ const agent = getAgentType(result.route) || AGENT_TYPES[0];
141
+ spinner.succeed(`Routed to ${agent.name}`);
142
+ if (jsonOutput) {
143
+ output.printJson({
144
+ task: taskDescription,
145
+ agentId: result.route,
146
+ agentName: agent.name,
147
+ confidence: result.confidence,
148
+ qValues: result.qValues,
149
+ explored: result.explored,
150
+ alternatives: result.alternatives.map(a => ({
151
+ agentId: a.route,
152
+ agentName: getAgentType(a.route)?.name || a.route,
153
+ score: a.score,
154
+ })),
155
+ });
156
+ }
157
+ else {
158
+ output.writeln();
159
+ const confidence = result.confidence ?? 0;
160
+ // Use bound methods to preserve `this` context when calling output methods
161
+ const confidenceColor = confidence >= 0.7
162
+ ? (text) => output.success(text)
163
+ : confidence >= 0.4
164
+ ? (text) => output.warning(text)
165
+ : (text) => output.error(text);
166
+ const qValues = result.qValues || [0];
167
+ const maxQValue = Math.max(...qValues);
168
+ const capabilities = agent.capabilities || [];
169
+ const alternatives = result.alternatives || [];
170
+ output.printBox([
171
+ `Task: ${taskDescription}`,
172
+ ``,
173
+ `Agent: ${output.highlight(agent.name)} (${result.route})`,
174
+ `Confidence: ${confidenceColor(`${(confidence * 100).toFixed(1)}%`)}`,
175
+ `Q-Value: ${maxQValue.toFixed(3)}`,
176
+ `Exploration: ${result.explored ? output.warning('Yes') : 'No'}`,
177
+ ``,
178
+ `Description: ${agent.description}`,
179
+ `Capabilities: ${capabilities.join(', ')}`,
180
+ ].join('\n'), 'Q-Learning Routing');
181
+ if (alternatives.length > 0) {
182
+ output.writeln();
183
+ output.writeln(output.bold('Alternatives:'));
184
+ output.printTable({
185
+ columns: [
186
+ { key: 'agent', header: 'Agent', width: 20 },
187
+ { key: 'score', header: 'Score', width: 12, align: 'right' },
188
+ ],
189
+ data: alternatives.map(a => ({
190
+ agent: getAgentType(a.route)?.name || a.route,
191
+ score: (a.score ?? 0).toFixed(3),
192
+ })),
193
+ });
194
+ }
195
+ }
196
+ return { success: true, data: { agentId: result.route, result } };
197
+ }
198
+ catch (error) {
199
+ spinner.fail('Routing failed');
200
+ output.printError(error instanceof Error ? error.message : String(error));
201
+ return { success: false, exitCode: 1 };
202
+ }
203
+ },
204
+ };
205
+ // ============================================================================
206
+ // List Agents Subcommand
207
+ // ============================================================================
208
+ const listAgentsCommand = {
209
+ name: 'list-agents',
210
+ aliases: ['agents', 'ls'],
211
+ description: 'List all available agent types for routing',
212
+ options: [
213
+ {
214
+ name: 'json',
215
+ short: 'j',
216
+ description: 'Output in JSON format',
217
+ type: 'boolean',
218
+ default: false,
219
+ },
220
+ ],
221
+ examples: [
222
+ { command: 'claude-flow route list-agents', description: 'List all agents' },
223
+ { command: 'claude-flow route agents --json', description: 'List agents as JSON' },
224
+ ],
225
+ action: async (ctx) => {
226
+ const jsonOutput = ctx.flags.json;
227
+ try {
228
+ if (jsonOutput) {
229
+ output.printJson(AGENT_TYPES);
230
+ }
231
+ else {
232
+ output.writeln();
233
+ output.writeln(output.bold('Available Agent Types'));
234
+ output.writeln(output.dim('Ordered by priority (highest first)'));
235
+ output.writeln();
236
+ output.printTable({
237
+ columns: [
238
+ { key: 'id', header: 'ID', width: 15 },
239
+ { key: 'name', header: 'Name', width: 15 },
240
+ { key: 'priority', header: 'Priority', width: 10, align: 'right' },
241
+ { key: 'description', header: 'Description', width: 45 },
242
+ ],
243
+ data: AGENT_TYPES.map(a => ({
244
+ id: output.highlight(a.id),
245
+ name: a.name,
246
+ priority: String(a.priority),
247
+ description: a.description,
248
+ })),
249
+ });
250
+ output.writeln();
251
+ output.writeln(output.dim(`Total: ${AGENT_TYPES.length} agent types`));
252
+ }
253
+ return { success: true, data: AGENT_TYPES };
254
+ }
255
+ catch (error) {
256
+ output.printError(error instanceof Error ? error.message : String(error));
257
+ return { success: false, exitCode: 1 };
258
+ }
259
+ },
260
+ };
261
+ // ============================================================================
262
+ // Stats Subcommand
263
+ // ============================================================================
264
+ const statsCommand = {
265
+ name: 'stats',
266
+ description: 'Show Q-Learning router statistics',
267
+ options: [
268
+ {
269
+ name: 'json',
270
+ short: 'j',
271
+ description: 'Output in JSON format',
272
+ type: 'boolean',
273
+ default: false,
274
+ },
275
+ ],
276
+ examples: [
277
+ { command: 'claude-flow route stats', description: 'Show routing statistics' },
278
+ ],
279
+ action: async (ctx) => {
280
+ const jsonOutput = ctx.flags.json;
281
+ try {
282
+ const router = await getRouter();
283
+ const stats = router.getStats();
284
+ const ruvectorAvailable = await isRuvectorAvailable();
285
+ const ruvectorStatus = {
286
+ available: ruvectorAvailable,
287
+ wasmAccelerated: stats.useNative === 1,
288
+ backend: stats.useNative === 1 ? 'ruvector-native' : 'fallback',
289
+ };
290
+ if (jsonOutput) {
291
+ output.printJson({ stats, ruvector: ruvectorStatus });
292
+ }
293
+ else {
294
+ output.writeln();
295
+ output.writeln(output.bold('Q-Learning Router Statistics'));
296
+ output.writeln();
297
+ output.printTable({
298
+ columns: [
299
+ { key: 'metric', header: 'Metric', width: 25 },
300
+ { key: 'value', header: 'Value', width: 20, align: 'right' },
301
+ ],
302
+ data: [
303
+ { metric: 'Update Count', value: String(stats.updateCount) },
304
+ { metric: 'Q-Table Size', value: String(stats.qTableSize) },
305
+ { metric: 'Step Count', value: String(stats.stepCount) },
306
+ { metric: 'Epsilon', value: stats.epsilon.toFixed(4) },
307
+ { metric: 'Avg TD Error', value: stats.avgTDError.toFixed(4) },
308
+ { metric: 'Native Backend', value: stats.useNative === 1 ? 'Yes' : 'No' },
309
+ ],
310
+ });
311
+ output.writeln();
312
+ output.writeln(output.bold('RuVector Status'));
313
+ output.printList([
314
+ `Available: ${ruvectorStatus.available ? output.success('Yes') : output.warning('No (using fallback)')}`,
315
+ `WASM Accelerated: ${ruvectorStatus.wasmAccelerated ? output.success('Yes') : 'No'}`,
316
+ `Backend: ${ruvectorStatus.backend}`,
317
+ ]);
318
+ }
319
+ return { success: true, data: { stats, ruvector: ruvectorStatus } };
320
+ }
321
+ catch (error) {
322
+ output.printError(error instanceof Error ? error.message : String(error));
323
+ return { success: false, exitCode: 1 };
324
+ }
325
+ },
326
+ };
327
+ // ============================================================================
328
+ // Feedback Subcommand
329
+ // ============================================================================
330
+ const feedbackCommand = {
331
+ name: 'feedback',
332
+ description: 'Provide feedback on a routing decision',
333
+ options: [
334
+ {
335
+ name: 'task',
336
+ short: 't',
337
+ description: 'Task description (context for learning)',
338
+ type: 'string',
339
+ required: true,
340
+ },
341
+ {
342
+ name: 'agent',
343
+ short: 'a',
344
+ description: 'Agent that was used',
345
+ type: 'string',
346
+ required: true,
347
+ },
348
+ {
349
+ name: 'reward',
350
+ short: 'r',
351
+ description: 'Reward value (-1 to 1, where 1 is best)',
352
+ type: 'number',
353
+ default: 0.8,
354
+ },
355
+ {
356
+ name: 'next-task',
357
+ short: 'n',
358
+ description: 'Next task description (for multi-step learning)',
359
+ type: 'string',
360
+ },
361
+ ],
362
+ examples: [
363
+ { command: 'claude-flow route feedback -t "implement auth" -a coder -r 0.9', description: 'Positive feedback' },
364
+ { command: 'claude-flow route feedback -t "write tests" -a tester -r -0.5', description: 'Negative feedback' },
365
+ ],
366
+ action: async (ctx) => {
367
+ const taskDescription = ctx.flags.task;
368
+ const agentId = ctx.flags.agent;
369
+ const reward = ctx.flags.reward;
370
+ const nextTask = ctx.flags['next-task'];
371
+ if (!taskDescription || !agentId) {
372
+ output.printError('Task description and agent are required');
373
+ return { success: false, exitCode: 1 };
374
+ }
375
+ // Validate agent
376
+ const agent = getAgentType(agentId);
377
+ if (!agent) {
378
+ output.printError(`Unknown agent: ${agentId}`);
379
+ output.writeln('Available agents:');
380
+ output.printList(AGENT_TYPES.map(a => a.id));
381
+ return { success: false, exitCode: 1 };
382
+ }
383
+ try {
384
+ const router = await getRouter();
385
+ const clampedReward = Math.max(-1, Math.min(1, reward));
386
+ const tdError = router.update(taskDescription, agentId, clampedReward, nextTask);
387
+ output.printSuccess(`Feedback recorded for agent "${agent.name}"`);
388
+ output.writeln();
389
+ output.printBox([
390
+ `Task: ${taskDescription}`,
391
+ `Agent: ${agent.name} (${agentId})`,
392
+ `Reward: ${clampedReward >= 0 ? output.success(clampedReward.toFixed(2)) : output.error(clampedReward.toFixed(2))}`,
393
+ `TD Error: ${Math.abs(tdError).toFixed(4)}`,
394
+ nextTask ? `Next Task: ${nextTask}` : '',
395
+ ].filter(Boolean).join('\n'), 'Feedback Recorded');
396
+ return { success: true, data: { tdError } };
397
+ }
398
+ catch (error) {
399
+ output.printError(error instanceof Error ? error.message : String(error));
400
+ return { success: false, exitCode: 1 };
401
+ }
402
+ },
403
+ };
404
+ // ============================================================================
405
+ // Reset Subcommand
406
+ // ============================================================================
407
+ const resetCommand = {
408
+ name: 'reset',
409
+ description: 'Reset the Q-Learning router state',
410
+ options: [
411
+ {
412
+ name: 'force',
413
+ short: 'f',
414
+ description: 'Force reset without confirmation',
415
+ type: 'boolean',
416
+ default: false,
417
+ },
418
+ ],
419
+ examples: [
420
+ { command: 'claude-flow route reset', description: 'Reset router state' },
421
+ { command: 'claude-flow route reset --force', description: 'Force reset' },
422
+ ],
423
+ action: async (ctx) => {
424
+ const force = ctx.flags.force;
425
+ if (!force && ctx.interactive) {
426
+ output.printWarning('This will reset all learned Q-values and statistics.');
427
+ output.writeln(output.dim('Use --force to skip this confirmation.'));
428
+ return { success: false, exitCode: 1 };
429
+ }
430
+ try {
431
+ const router = await getRouter();
432
+ router.reset();
433
+ output.printSuccess('Q-Learning router state has been reset');
434
+ return { success: true };
435
+ }
436
+ catch (error) {
437
+ output.printError(error instanceof Error ? error.message : String(error));
438
+ return { success: false, exitCode: 1 };
439
+ }
440
+ },
441
+ };
442
+ // ============================================================================
443
+ // Export/Import Subcommands
444
+ // ============================================================================
445
+ const exportCommand = {
446
+ name: 'export',
447
+ description: 'Export Q-table for persistence',
448
+ options: [
449
+ {
450
+ name: 'file',
451
+ short: 'f',
452
+ description: 'Output file path (outputs to stdout if not specified)',
453
+ type: 'string',
454
+ },
455
+ ],
456
+ examples: [
457
+ { command: 'claude-flow route export', description: 'Export Q-table to stdout' },
458
+ { command: 'claude-flow route export -f qtable.json', description: 'Export to file' },
459
+ ],
460
+ action: async (ctx) => {
461
+ const filePath = ctx.flags.file;
462
+ try {
463
+ const router = await getRouter();
464
+ const data = router.export();
465
+ if (filePath) {
466
+ const fs = await import('node:fs/promises');
467
+ await fs.writeFile(filePath, JSON.stringify(data, null, 2));
468
+ output.printSuccess(`Q-table exported to ${filePath}`);
469
+ }
470
+ else {
471
+ output.printJson(data);
472
+ }
473
+ return { success: true, data };
474
+ }
475
+ catch (error) {
476
+ output.printError(error instanceof Error ? error.message : String(error));
477
+ return { success: false, exitCode: 1 };
478
+ }
479
+ },
480
+ };
481
+ const importCommand = {
482
+ name: 'import',
483
+ description: 'Import Q-table from file',
484
+ options: [
485
+ {
486
+ name: 'file',
487
+ short: 'f',
488
+ description: 'Input file path',
489
+ type: 'string',
490
+ required: true,
491
+ },
492
+ ],
493
+ examples: [
494
+ { command: 'claude-flow route import -f qtable.json', description: 'Import Q-table from file' },
495
+ ],
496
+ action: async (ctx) => {
497
+ const filePath = ctx.flags.file;
498
+ if (!filePath) {
499
+ output.printError('File path is required');
500
+ return { success: false, exitCode: 1 };
501
+ }
502
+ try {
503
+ const fs = await import('node:fs/promises');
504
+ const content = await fs.readFile(filePath, 'utf-8');
505
+ const data = JSON.parse(content);
506
+ const router = await getRouter();
507
+ router.import(data);
508
+ output.printSuccess(`Q-table imported from ${filePath}`);
509
+ output.writeln(output.dim(`Loaded ${Object.keys(data).length} state entries`));
510
+ return { success: true };
511
+ }
512
+ catch (error) {
513
+ output.printError(error instanceof Error ? error.message : String(error));
514
+ return { success: false, exitCode: 1 };
515
+ }
516
+ },
517
+ };
518
+ // ============================================================================
519
+ // Coverage-Aware Routing Subcommand
520
+ // ============================================================================
521
+ const coverageRouteCommand = {
522
+ name: 'coverage',
523
+ aliases: ['cov'],
524
+ description: 'Route tasks based on test coverage analysis (ADR-017)',
525
+ options: [
526
+ {
527
+ name: 'path',
528
+ short: 'p',
529
+ description: 'Path to analyze for coverage',
530
+ type: 'string',
531
+ },
532
+ {
533
+ name: 'threshold',
534
+ short: 't',
535
+ description: 'Coverage threshold percentage (default: 80)',
536
+ type: 'number',
537
+ default: 80,
538
+ },
539
+ {
540
+ name: 'suggest',
541
+ short: 's',
542
+ description: 'Get suggestions for improving coverage',
543
+ type: 'boolean',
544
+ default: false,
545
+ },
546
+ {
547
+ name: 'gaps',
548
+ short: 'g',
549
+ description: 'List coverage gaps with agent assignments',
550
+ type: 'boolean',
551
+ default: false,
552
+ },
553
+ {
554
+ name: 'json',
555
+ short: 'j',
556
+ description: 'Output in JSON format',
557
+ type: 'boolean',
558
+ default: false,
559
+ },
560
+ ],
561
+ examples: [
562
+ { command: 'claude-flow route coverage', description: 'Analyze coverage and suggest routing' },
563
+ { command: 'claude-flow route coverage --suggest', description: 'Get improvement suggestions' },
564
+ { command: 'claude-flow route coverage --gaps', description: 'List coverage gaps by agent' },
565
+ { command: 'claude-flow route coverage -p src/auth -t 90', description: 'Analyze specific path with threshold' },
566
+ ],
567
+ action: async (ctx) => {
568
+ const path = ctx.flags.path || '';
569
+ const threshold = ctx.flags.threshold || 80;
570
+ const suggestMode = ctx.flags.suggest;
571
+ const gapsMode = ctx.flags.gaps;
572
+ const jsonOutput = ctx.flags.json;
573
+ const spinner = output.createSpinner({ text: 'Analyzing coverage...', spinner: 'dots' });
574
+ spinner.start();
575
+ try {
576
+ // Lazy load coverage router
577
+ const { coverageRoute, coverageSuggest, coverageGaps } = await import('../ruvector/coverage-router.js');
578
+ if (gapsMode) {
579
+ // List coverage gaps with agent assignments
580
+ const result = await coverageGaps({ threshold, groupByAgent: true });
581
+ spinner.succeed(`Found ${result.totalGaps} coverage gaps`);
582
+ if (jsonOutput) {
583
+ output.printJson(result);
584
+ }
585
+ else {
586
+ output.writeln();
587
+ output.writeln(output.bold('Coverage Gaps by Agent'));
588
+ output.writeln(output.dim(result.summary));
589
+ output.writeln();
590
+ if (Object.keys(result.byAgent).length > 0) {
591
+ for (const [agent, files] of Object.entries(result.byAgent)) {
592
+ output.writeln(`${output.highlight(agent)} (${files.length} files)`);
593
+ for (const file of files.slice(0, 5)) {
594
+ output.writeln(` ${output.dim('•')} ${file}`);
595
+ }
596
+ if (files.length > 5) {
597
+ output.writeln(output.dim(` ... and ${files.length - 5} more`));
598
+ }
599
+ output.writeln();
600
+ }
601
+ }
602
+ else {
603
+ output.printSuccess('No coverage gaps found!');
604
+ }
605
+ output.writeln();
606
+ output.writeln(output.bold('Top Gaps:'));
607
+ output.printTable({
608
+ columns: [
609
+ { key: 'file', header: 'File', width: 50 },
610
+ { key: 'coverage', header: 'Coverage', width: 12, align: 'right' },
611
+ { key: 'gap', header: 'Gap', width: 10, align: 'right' },
612
+ { key: 'agent', header: 'Agent', width: 15 },
613
+ ],
614
+ data: result.gaps.slice(0, 10).map(g => ({
615
+ file: g.file.length > 48 ? '...' + g.file.slice(-45) : g.file,
616
+ coverage: `${g.currentCoverage.toFixed(1)}%`,
617
+ gap: `${g.gap.toFixed(1)}%`,
618
+ agent: g.suggestedAgent,
619
+ })),
620
+ });
621
+ }
622
+ return { success: true, data: result };
623
+ }
624
+ if (suggestMode || path) {
625
+ // Suggest improvements for path
626
+ const result = await coverageSuggest(path || '.', { threshold, limit: 20 });
627
+ spinner.succeed(`Found ${result.suggestions.length} coverage suggestions`);
628
+ if (jsonOutput) {
629
+ output.printJson(result);
630
+ }
631
+ else {
632
+ output.writeln();
633
+ output.writeln(output.bold('Coverage Improvement Suggestions'));
634
+ output.writeln(output.dim(`Path: ${result.path}, Threshold: ${threshold}%`));
635
+ output.writeln();
636
+ if (result.suggestions.length === 0) {
637
+ output.printSuccess('All files meet coverage threshold!');
638
+ }
639
+ else {
640
+ output.writeln(`Total Gap: ${output.warning(`${result.totalGap.toFixed(1)}%`)}`);
641
+ output.writeln(`Estimated Effort: ${output.dim(`${result.estimatedEffort.toFixed(1)} hours`)}`);
642
+ output.writeln();
643
+ output.printTable({
644
+ columns: [
645
+ { key: 'file', header: 'File', width: 45 },
646
+ { key: 'current', header: 'Current', width: 10, align: 'right' },
647
+ { key: 'target', header: 'Target', width: 10, align: 'right' },
648
+ { key: 'priority', header: 'Priority', width: 10, align: 'right' },
649
+ ],
650
+ data: result.suggestions.slice(0, 15).map(s => ({
651
+ file: s.file.length > 43 ? '...' + s.file.slice(-40) : s.file,
652
+ current: `${s.currentCoverage.toFixed(1)}%`,
653
+ target: `${s.targetCoverage.toFixed(1)}%`,
654
+ priority: String(s.priority),
655
+ })),
656
+ });
657
+ // Show test suggestions for top file
658
+ if (result.suggestions.length > 0 && result.suggestions[0].suggestedTests.length > 0) {
659
+ output.writeln();
660
+ output.writeln(output.bold('Suggested Tests for Top Priority File:'));
661
+ output.printList(result.suggestions[0].suggestedTests);
662
+ }
663
+ }
664
+ }
665
+ return { success: true, data: result };
666
+ }
667
+ // Default: Route based on coverage analysis
668
+ const routeResult = await coverageRoute('', { threshold });
669
+ spinner.succeed('Coverage analysis complete');
670
+ if (jsonOutput) {
671
+ output.printJson(routeResult);
672
+ }
673
+ else {
674
+ output.writeln();
675
+ output.writeln(output.bold('Coverage-Aware Routing'));
676
+ output.writeln();
677
+ const actionColors = {
678
+ 'add-tests': (s) => output.error(s),
679
+ 'review-coverage': (s) => output.warning(s),
680
+ 'prioritize': (s) => output.error(s),
681
+ 'skip': (s) => output.success(s),
682
+ };
683
+ const colorFn = actionColors[routeResult.action] || ((s) => s);
684
+ output.printBox([
685
+ `Action: ${colorFn(routeResult.action.toUpperCase())}`,
686
+ `Priority: ${routeResult.priority}/10`,
687
+ `Impact Score: ${routeResult.impactScore}%`,
688
+ `Estimated Effort: ${routeResult.estimatedEffort} hours`,
689
+ ``,
690
+ `Test Types: ${routeResult.testTypes.join(', ')}`,
691
+ `Target Files: ${routeResult.targetFiles.length}`,
692
+ ].join('\n'), 'Coverage Analysis');
693
+ if (routeResult.targetFiles.length > 0) {
694
+ output.writeln();
695
+ output.writeln(output.bold('Target Files:'));
696
+ output.printList(routeResult.targetFiles.slice(0, 5).map(f => f.length > 60 ? '...' + f.slice(-57) : f));
697
+ if (routeResult.targetFiles.length > 5) {
698
+ output.writeln(output.dim(` ... and ${routeResult.targetFiles.length - 5} more`));
699
+ }
700
+ }
701
+ if (routeResult.gaps.length > 0) {
702
+ output.writeln();
703
+ output.writeln(output.bold('Coverage Gaps:'));
704
+ output.printTable({
705
+ columns: [
706
+ { key: 'file', header: 'File', width: 40 },
707
+ { key: 'current', header: 'Current', width: 10, align: 'right' },
708
+ { key: 'gap', header: 'Gap', width: 10, align: 'right' },
709
+ ],
710
+ data: routeResult.gaps.slice(0, 5).map(g => ({
711
+ file: g.file.length > 38 ? '...' + g.file.slice(-35) : g.file,
712
+ current: `${g.currentCoverage.toFixed(1)}%`,
713
+ gap: `${g.gap.toFixed(1)}%`,
714
+ })),
715
+ });
716
+ }
717
+ }
718
+ return { success: true, data: routeResult };
719
+ }
720
+ catch (error) {
721
+ spinner.fail('Coverage analysis failed');
722
+ output.printError(error instanceof Error ? error.message : String(error));
723
+ return { success: false, exitCode: 1 };
724
+ }
725
+ },
726
+ };
727
+ // ============================================================================
728
+ // Main Route Command
729
+ // ============================================================================
730
+ export const routeCommand = {
731
+ name: 'route',
732
+ description: 'Intelligent task-to-agent routing using Q-Learning',
733
+ subcommands: [
734
+ routeTaskCommand,
735
+ listAgentsCommand,
736
+ statsCommand,
737
+ feedbackCommand,
738
+ resetCommand,
739
+ exportCommand,
740
+ importCommand,
741
+ coverageRouteCommand,
742
+ ],
743
+ options: [
744
+ {
745
+ name: 'q-learning',
746
+ short: 'q',
747
+ description: 'Use Q-Learning for agent selection',
748
+ type: 'boolean',
749
+ default: true,
750
+ },
751
+ {
752
+ name: 'agent',
753
+ short: 'a',
754
+ description: 'Force specific agent',
755
+ type: 'string',
756
+ },
757
+ ],
758
+ examples: [
759
+ { command: 'claude-flow route "implement feature"', description: 'Route task to best agent' },
760
+ { command: 'claude-flow route "write tests" --q-learning', description: 'Use Q-Learning routing' },
761
+ { command: 'claude-flow route --agent coder "fix bug"', description: 'Force specific agent' },
762
+ { command: 'claude-flow route list-agents', description: 'List available agents' },
763
+ { command: 'claude-flow route stats', description: 'Show routing statistics' },
764
+ ],
765
+ action: async (ctx) => {
766
+ // If task description provided directly, route it
767
+ if (ctx.args.length > 0 && routeTaskCommand.action) {
768
+ const result = await routeTaskCommand.action(ctx);
769
+ if (result)
770
+ return result;
771
+ return { success: true };
772
+ }
773
+ // Show help
774
+ output.writeln();
775
+ output.writeln(output.bold('Q-Learning Agent Router'));
776
+ output.writeln(output.dim('Intelligent task-to-agent routing using reinforcement learning'));
777
+ output.writeln();
778
+ output.writeln('Usage: claude-flow route <task> [options]');
779
+ output.writeln(' claude-flow route <subcommand>');
780
+ output.writeln();
781
+ output.writeln(output.bold('Subcommands:'));
782
+ output.printList([
783
+ `${output.highlight('task')} - Route a task to optimal agent`,
784
+ `${output.highlight('list-agents')} - List available agent types`,
785
+ `${output.highlight('stats')} - Show router statistics`,
786
+ `${output.highlight('feedback')} - Provide routing feedback`,
787
+ `${output.highlight('reset')} - Reset router state`,
788
+ `${output.highlight('export')} - Export Q-table`,
789
+ `${output.highlight('import')} - Import Q-table`,
790
+ ]);
791
+ output.writeln();
792
+ output.writeln(output.bold('How It Works:'));
793
+ output.printList([
794
+ 'Analyzes task description using hash-based state encoding',
795
+ 'Uses Q-Learning to learn from routing outcomes',
796
+ 'Epsilon-greedy exploration for continuous improvement',
797
+ 'Provides confidence scores and alternatives',
798
+ ]);
799
+ output.writeln();
800
+ // Show quick status
801
+ const ruvectorAvailable = await isRuvectorAvailable();
802
+ output.writeln(output.bold('Backend Status:'));
803
+ output.printList([
804
+ `RuVector: ${ruvectorAvailable ? output.success('Available') : output.warning('Fallback mode')}`,
805
+ `Backend: ${ruvectorAvailable ? 'ruvector-native' : 'JavaScript fallback'}`,
806
+ ]);
807
+ output.writeln();
808
+ output.writeln(output.dim('Run "claude-flow route <subcommand> --help" for more info'));
809
+ return { success: true };
810
+ },
811
+ };
812
+ export default routeCommand;
813
+ //# sourceMappingURL=route.js.map