@claude-flow/cli 3.6.30 → 3.7.0-alpha.10

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 (492) hide show
  1. package/.claude/agents/analysis/analyze-code-quality.md +178 -178
  2. package/.claude/agents/analysis/code-analyzer.md +209 -209
  3. package/.claude/agents/analysis/code-review/analyze-code-quality.md +178 -178
  4. package/.claude/agents/architecture/arch-system-design.md +156 -156
  5. package/.claude/agents/architecture/system-design/arch-system-design.md +154 -154
  6. package/.claude/agents/browser/browser-agent.yaml +182 -182
  7. package/.claude/agents/consensus/byzantine-coordinator.md +62 -62
  8. package/.claude/agents/consensus/crdt-synchronizer.md +996 -996
  9. package/.claude/agents/consensus/gossip-coordinator.md +62 -62
  10. package/.claude/agents/consensus/performance-benchmarker.md +850 -850
  11. package/.claude/agents/consensus/quorum-manager.md +822 -822
  12. package/.claude/agents/consensus/raft-manager.md +62 -62
  13. package/.claude/agents/consensus/security-manager.md +621 -621
  14. package/.claude/agents/core/coder.md +452 -452
  15. package/.claude/agents/core/planner.md +374 -374
  16. package/.claude/agents/core/researcher.md +368 -368
  17. package/.claude/agents/core/reviewer.md +519 -519
  18. package/.claude/agents/core/tester.md +511 -511
  19. package/.claude/agents/custom/test-long-runner.md +44 -44
  20. package/.claude/agents/data/data-ml-model.md +444 -444
  21. package/.claude/agents/data/ml/data-ml-model.md +192 -192
  22. package/.claude/agents/development/backend/dev-backend-api.md +141 -141
  23. package/.claude/agents/development/dev-backend-api.md +344 -344
  24. package/.claude/agents/devops/ci-cd/ops-cicd-github.md +163 -163
  25. package/.claude/agents/devops/ops-cicd-github.md +164 -164
  26. package/.claude/agents/documentation/api-docs/docs-api-openapi.md +173 -173
  27. package/.claude/agents/documentation/docs-api-openapi.md +354 -354
  28. package/.claude/agents/flow-nexus/app-store.md +87 -87
  29. package/.claude/agents/flow-nexus/authentication.md +68 -68
  30. package/.claude/agents/flow-nexus/challenges.md +80 -80
  31. package/.claude/agents/flow-nexus/neural-network.md +87 -87
  32. package/.claude/agents/flow-nexus/payments.md +82 -82
  33. package/.claude/agents/flow-nexus/sandbox.md +75 -75
  34. package/.claude/agents/flow-nexus/swarm.md +75 -75
  35. package/.claude/agents/flow-nexus/user-tools.md +95 -95
  36. package/.claude/agents/flow-nexus/workflow.md +83 -83
  37. package/.claude/agents/github/code-review-swarm.md +377 -377
  38. package/.claude/agents/github/github-modes.md +172 -172
  39. package/.claude/agents/github/issue-tracker.md +575 -575
  40. package/.claude/agents/github/multi-repo-swarm.md +552 -552
  41. package/.claude/agents/github/pr-manager.md +437 -437
  42. package/.claude/agents/github/project-board-sync.md +508 -508
  43. package/.claude/agents/github/release-manager.md +604 -604
  44. package/.claude/agents/github/release-swarm.md +582 -582
  45. package/.claude/agents/github/repo-architect.md +397 -397
  46. package/.claude/agents/github/swarm-issue.md +572 -572
  47. package/.claude/agents/github/swarm-pr.md +427 -427
  48. package/.claude/agents/github/sync-coordinator.md +451 -451
  49. package/.claude/agents/github/workflow-automation.md +902 -902
  50. package/.claude/agents/goal/agent.md +815 -815
  51. package/.claude/agents/goal/goal-planner.md +72 -72
  52. package/.claude/agents/optimization/benchmark-suite.md +664 -664
  53. package/.claude/agents/optimization/load-balancer.md +430 -430
  54. package/.claude/agents/optimization/performance-monitor.md +671 -671
  55. package/.claude/agents/optimization/resource-allocator.md +673 -673
  56. package/.claude/agents/optimization/topology-optimizer.md +807 -807
  57. package/.claude/agents/payments/agentic-payments.md +126 -126
  58. package/.claude/agents/sona/sona-learning-optimizer.md +74 -74
  59. package/.claude/agents/sparc/architecture.md +698 -698
  60. package/.claude/agents/sparc/pseudocode.md +519 -519
  61. package/.claude/agents/sparc/refinement.md +801 -801
  62. package/.claude/agents/sparc/specification.md +477 -477
  63. package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +224 -224
  64. package/.claude/agents/specialized/spec-mobile-react-native.md +226 -226
  65. package/.claude/agents/sublinear/consensus-coordinator.md +337 -337
  66. package/.claude/agents/sublinear/matrix-optimizer.md +184 -184
  67. package/.claude/agents/sublinear/pagerank-analyzer.md +298 -298
  68. package/.claude/agents/sublinear/performance-optimizer.md +367 -367
  69. package/.claude/agents/sublinear/trading-predictor.md +245 -245
  70. package/.claude/agents/swarm/adaptive-coordinator.md +1126 -1126
  71. package/.claude/agents/swarm/hierarchical-coordinator.md +709 -709
  72. package/.claude/agents/swarm/mesh-coordinator.md +962 -962
  73. package/.claude/agents/templates/automation-smart-agent.md +204 -204
  74. package/.claude/agents/templates/base-template-generator.md +289 -289
  75. package/.claude/agents/templates/coordinator-swarm-init.md +89 -89
  76. package/.claude/agents/templates/github-pr-manager.md +176 -176
  77. package/.claude/agents/templates/implementer-sparc-coder.md +258 -258
  78. package/.claude/agents/templates/memory-coordinator.md +186 -186
  79. package/.claude/agents/templates/orchestrator-task.md +138 -138
  80. package/.claude/agents/templates/performance-analyzer.md +198 -198
  81. package/.claude/agents/templates/sparc-coordinator.md +513 -513
  82. package/.claude/agents/testing/production-validator.md +394 -394
  83. package/.claude/agents/testing/tdd-london-swarm.md +243 -243
  84. package/.claude/agents/v3/adr-architect.md +184 -184
  85. package/.claude/agents/v3/aidefence-guardian.md +282 -282
  86. package/.claude/agents/v3/claims-authorizer.md +208 -208
  87. package/.claude/agents/v3/collective-intelligence-coordinator.md +993 -993
  88. package/.claude/agents/v3/ddd-domain-expert.md +220 -220
  89. package/.claude/agents/v3/injection-analyst.md +236 -236
  90. package/.claude/agents/v3/memory-specialist.md +995 -995
  91. package/.claude/agents/v3/performance-engineer.md +1233 -1233
  92. package/.claude/agents/v3/pii-detector.md +151 -151
  93. package/.claude/agents/v3/reasoningbank-learner.md +213 -213
  94. package/.claude/agents/v3/security-architect-aidefence.md +410 -410
  95. package/.claude/agents/v3/security-architect.md +867 -867
  96. package/.claude/agents/v3/security-auditor.md +771 -771
  97. package/.claude/agents/v3/sparc-orchestrator.md +182 -182
  98. package/.claude/agents/v3/swarm-memory-manager.md +157 -157
  99. package/.claude/agents/v3/v3-integration-architect.md +205 -205
  100. package/.claude/commands/agents/README.md +50 -50
  101. package/.claude/commands/agents/agent-capabilities.md +140 -140
  102. package/.claude/commands/agents/agent-coordination.md +28 -28
  103. package/.claude/commands/agents/agent-spawning.md +28 -28
  104. package/.claude/commands/agents/agent-types.md +216 -216
  105. package/.claude/commands/agents/health.md +139 -139
  106. package/.claude/commands/agents/list.md +100 -100
  107. package/.claude/commands/agents/logs.md +130 -130
  108. package/.claude/commands/agents/metrics.md +122 -122
  109. package/.claude/commands/agents/pool.md +127 -127
  110. package/.claude/commands/agents/spawn.md +140 -140
  111. package/.claude/commands/agents/status.md +115 -115
  112. package/.claude/commands/agents/stop.md +102 -102
  113. package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +53 -53
  114. package/.claude/commands/analysis/README.md +9 -9
  115. package/.claude/commands/analysis/bottleneck-detect.md +162 -162
  116. package/.claude/commands/analysis/performance-bottlenecks.md +58 -58
  117. package/.claude/commands/analysis/performance-report.md +25 -25
  118. package/.claude/commands/analysis/token-efficiency.md +44 -44
  119. package/.claude/commands/analysis/token-usage.md +25 -25
  120. package/.claude/commands/automation/README.md +9 -9
  121. package/.claude/commands/automation/auto-agent.md +122 -122
  122. package/.claude/commands/automation/self-healing.md +105 -105
  123. package/.claude/commands/automation/session-memory.md +89 -89
  124. package/.claude/commands/automation/smart-agents.md +72 -72
  125. package/.claude/commands/automation/smart-spawn.md +25 -25
  126. package/.claude/commands/automation/workflow-select.md +25 -25
  127. package/.claude/commands/claude-flow-help.md +103 -103
  128. package/.claude/commands/claude-flow-memory.md +107 -107
  129. package/.claude/commands/claude-flow-swarm.md +205 -205
  130. package/.claude/commands/coordination/README.md +9 -9
  131. package/.claude/commands/coordination/agent-spawn.md +25 -25
  132. package/.claude/commands/coordination/init.md +44 -44
  133. package/.claude/commands/coordination/orchestrate.md +43 -43
  134. package/.claude/commands/coordination/spawn.md +45 -45
  135. package/.claude/commands/coordination/swarm-init.md +85 -85
  136. package/.claude/commands/coordination/task-orchestrate.md +25 -25
  137. package/.claude/commands/flow-nexus/app-store.md +123 -123
  138. package/.claude/commands/flow-nexus/challenges.md +119 -119
  139. package/.claude/commands/flow-nexus/login-registration.md +64 -64
  140. package/.claude/commands/flow-nexus/neural-network.md +133 -133
  141. package/.claude/commands/flow-nexus/payments.md +115 -115
  142. package/.claude/commands/flow-nexus/sandbox.md +82 -82
  143. package/.claude/commands/flow-nexus/swarm.md +86 -86
  144. package/.claude/commands/flow-nexus/user-tools.md +151 -151
  145. package/.claude/commands/flow-nexus/workflow.md +114 -114
  146. package/.claude/commands/github/README.md +11 -11
  147. package/.claude/commands/github/code-review-swarm.md +513 -513
  148. package/.claude/commands/github/code-review.md +25 -25
  149. package/.claude/commands/github/github-modes.md +146 -146
  150. package/.claude/commands/github/github-swarm.md +121 -121
  151. package/.claude/commands/github/issue-tracker.md +291 -291
  152. package/.claude/commands/github/issue-triage.md +25 -25
  153. package/.claude/commands/github/multi-repo-swarm.md +518 -518
  154. package/.claude/commands/github/pr-enhance.md +26 -26
  155. package/.claude/commands/github/pr-manager.md +169 -169
  156. package/.claude/commands/github/project-board-sync.md +470 -470
  157. package/.claude/commands/github/release-manager.md +337 -337
  158. package/.claude/commands/github/release-swarm.md +543 -543
  159. package/.claude/commands/github/repo-analyze.md +25 -25
  160. package/.claude/commands/github/repo-architect.md +366 -366
  161. package/.claude/commands/github/swarm-issue.md +481 -481
  162. package/.claude/commands/github/swarm-pr.md +284 -284
  163. package/.claude/commands/github/sync-coordinator.md +300 -300
  164. package/.claude/commands/github/workflow-automation.md +441 -441
  165. package/.claude/commands/hive-mind/README.md +17 -17
  166. package/.claude/commands/hive-mind/hive-mind-consensus.md +8 -8
  167. package/.claude/commands/hive-mind/hive-mind-init.md +18 -18
  168. package/.claude/commands/hive-mind/hive-mind-memory.md +8 -8
  169. package/.claude/commands/hive-mind/hive-mind-metrics.md +8 -8
  170. package/.claude/commands/hive-mind/hive-mind-resume.md +8 -8
  171. package/.claude/commands/hive-mind/hive-mind-sessions.md +8 -8
  172. package/.claude/commands/hive-mind/hive-mind-spawn.md +21 -21
  173. package/.claude/commands/hive-mind/hive-mind-status.md +8 -8
  174. package/.claude/commands/hive-mind/hive-mind-stop.md +8 -8
  175. package/.claude/commands/hive-mind/hive-mind-wizard.md +8 -8
  176. package/.claude/commands/hive-mind/hive-mind.md +27 -27
  177. package/.claude/commands/hooks/README.md +11 -11
  178. package/.claude/commands/hooks/overview.md +57 -57
  179. package/.claude/commands/hooks/post-edit.md +117 -117
  180. package/.claude/commands/hooks/post-task.md +112 -112
  181. package/.claude/commands/hooks/pre-edit.md +113 -113
  182. package/.claude/commands/hooks/pre-task.md +111 -111
  183. package/.claude/commands/hooks/session-end.md +118 -118
  184. package/.claude/commands/hooks/setup.md +102 -102
  185. package/.claude/commands/memory/README.md +9 -9
  186. package/.claude/commands/memory/memory-persist.md +25 -25
  187. package/.claude/commands/memory/memory-search.md +25 -25
  188. package/.claude/commands/memory/memory-usage.md +25 -25
  189. package/.claude/commands/memory/neural.md +47 -47
  190. package/.claude/commands/monitoring/README.md +9 -9
  191. package/.claude/commands/monitoring/agent-metrics.md +25 -25
  192. package/.claude/commands/monitoring/agents.md +44 -44
  193. package/.claude/commands/monitoring/real-time-view.md +25 -25
  194. package/.claude/commands/monitoring/status.md +46 -46
  195. package/.claude/commands/monitoring/swarm-monitor.md +25 -25
  196. package/.claude/commands/optimization/README.md +9 -9
  197. package/.claude/commands/optimization/auto-topology.md +61 -61
  198. package/.claude/commands/optimization/cache-manage.md +25 -25
  199. package/.claude/commands/optimization/parallel-execute.md +25 -25
  200. package/.claude/commands/optimization/parallel-execution.md +49 -49
  201. package/.claude/commands/optimization/topology-optimize.md +25 -25
  202. package/.claude/commands/pair/README.md +260 -260
  203. package/.claude/commands/pair/commands.md +545 -545
  204. package/.claude/commands/pair/config.md +509 -509
  205. package/.claude/commands/pair/examples.md +511 -511
  206. package/.claude/commands/pair/modes.md +347 -347
  207. package/.claude/commands/pair/session.md +406 -406
  208. package/.claude/commands/pair/start.md +208 -208
  209. package/.claude/commands/sparc/analyzer.md +51 -51
  210. package/.claude/commands/sparc/architect.md +53 -53
  211. package/.claude/commands/sparc/ask.md +97 -97
  212. package/.claude/commands/sparc/batch-executor.md +54 -54
  213. package/.claude/commands/sparc/code.md +89 -89
  214. package/.claude/commands/sparc/coder.md +54 -54
  215. package/.claude/commands/sparc/debug.md +83 -83
  216. package/.claude/commands/sparc/debugger.md +54 -54
  217. package/.claude/commands/sparc/designer.md +53 -53
  218. package/.claude/commands/sparc/devops.md +109 -109
  219. package/.claude/commands/sparc/docs-writer.md +80 -80
  220. package/.claude/commands/sparc/documenter.md +54 -54
  221. package/.claude/commands/sparc/innovator.md +54 -54
  222. package/.claude/commands/sparc/integration.md +83 -83
  223. package/.claude/commands/sparc/mcp.md +117 -117
  224. package/.claude/commands/sparc/memory-manager.md +54 -54
  225. package/.claude/commands/sparc/optimizer.md +54 -54
  226. package/.claude/commands/sparc/orchestrator.md +131 -131
  227. package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -83
  228. package/.claude/commands/sparc/refinement-optimization-mode.md +83 -83
  229. package/.claude/commands/sparc/researcher.md +54 -54
  230. package/.claude/commands/sparc/reviewer.md +54 -54
  231. package/.claude/commands/sparc/security-review.md +80 -80
  232. package/.claude/commands/sparc/sparc-modes.md +174 -174
  233. package/.claude/commands/sparc/sparc.md +111 -111
  234. package/.claude/commands/sparc/spec-pseudocode.md +80 -80
  235. package/.claude/commands/sparc/supabase-admin.md +348 -348
  236. package/.claude/commands/sparc/swarm-coordinator.md +54 -54
  237. package/.claude/commands/sparc/tdd.md +54 -54
  238. package/.claude/commands/sparc/tester.md +54 -54
  239. package/.claude/commands/sparc/tutorial.md +79 -79
  240. package/.claude/commands/sparc/workflow-manager.md +54 -54
  241. package/.claude/commands/sparc.md +166 -166
  242. package/.claude/commands/stream-chain/pipeline.md +120 -120
  243. package/.claude/commands/stream-chain/run.md +69 -69
  244. package/.claude/commands/swarm/README.md +15 -15
  245. package/.claude/commands/swarm/analysis.md +95 -95
  246. package/.claude/commands/swarm/development.md +96 -96
  247. package/.claude/commands/swarm/examples.md +168 -168
  248. package/.claude/commands/swarm/maintenance.md +102 -102
  249. package/.claude/commands/swarm/optimization.md +117 -117
  250. package/.claude/commands/swarm/research.md +136 -136
  251. package/.claude/commands/swarm/swarm-analysis.md +8 -8
  252. package/.claude/commands/swarm/swarm-background.md +8 -8
  253. package/.claude/commands/swarm/swarm-init.md +19 -19
  254. package/.claude/commands/swarm/swarm-modes.md +8 -8
  255. package/.claude/commands/swarm/swarm-monitor.md +8 -8
  256. package/.claude/commands/swarm/swarm-spawn.md +19 -19
  257. package/.claude/commands/swarm/swarm-status.md +8 -8
  258. package/.claude/commands/swarm/swarm-strategies.md +8 -8
  259. package/.claude/commands/swarm/swarm.md +87 -87
  260. package/.claude/commands/swarm/testing.md +131 -131
  261. package/.claude/commands/training/README.md +9 -9
  262. package/.claude/commands/training/model-update.md +25 -25
  263. package/.claude/commands/training/neural-patterns.md +107 -107
  264. package/.claude/commands/training/neural-train.md +75 -75
  265. package/.claude/commands/training/pattern-learn.md +25 -25
  266. package/.claude/commands/training/specialization.md +62 -62
  267. package/.claude/commands/truth/start.md +142 -142
  268. package/.claude/commands/verify/check.md +49 -49
  269. package/.claude/commands/verify/start.md +127 -127
  270. package/.claude/commands/workflows/README.md +9 -9
  271. package/.claude/commands/workflows/development.md +77 -77
  272. package/.claude/commands/workflows/research.md +62 -62
  273. package/.claude/commands/workflows/workflow-create.md +25 -25
  274. package/.claude/commands/workflows/workflow-execute.md +25 -25
  275. package/.claude/commands/workflows/workflow-export.md +25 -25
  276. package/.claude/helpers/README.md +96 -96
  277. package/.claude/helpers/adr-compliance.sh +186 -186
  278. package/.claude/helpers/auto-commit.sh +178 -178
  279. package/.claude/helpers/auto-memory-hook.mjs +368 -368
  280. package/.claude/helpers/checkpoint-manager.sh +251 -251
  281. package/.claude/helpers/daemon-manager.sh +252 -252
  282. package/.claude/helpers/ddd-tracker.sh +144 -144
  283. package/.claude/helpers/github-safe.js +121 -121
  284. package/.claude/helpers/github-setup.sh +28 -28
  285. package/.claude/helpers/guidance-hook.sh +13 -13
  286. package/.claude/helpers/guidance-hooks.sh +102 -102
  287. package/.claude/helpers/health-monitor.sh +108 -108
  288. package/.claude/helpers/hook-handler.cjs +278 -278
  289. package/.claude/helpers/intelligence.cjs +1031 -1031
  290. package/.claude/helpers/learning-hooks.sh +329 -329
  291. package/.claude/helpers/learning-optimizer.sh +127 -127
  292. package/.claude/helpers/learning-service.mjs +1144 -1144
  293. package/.claude/helpers/memory.js +83 -83
  294. package/.claude/helpers/metrics-db.mjs +488 -488
  295. package/.claude/helpers/pattern-consolidator.sh +86 -86
  296. package/.claude/helpers/perf-worker.sh +160 -160
  297. package/.claude/helpers/post-commit +16 -16
  298. package/.claude/helpers/pre-commit +26 -26
  299. package/.claude/helpers/quick-start.sh +19 -19
  300. package/.claude/helpers/router.js +66 -66
  301. package/.claude/helpers/security-scanner.sh +127 -127
  302. package/.claude/helpers/session.js +135 -135
  303. package/.claude/helpers/setup-mcp.sh +18 -18
  304. package/.claude/helpers/standard-checkpoint-hooks.sh +189 -189
  305. package/.claude/helpers/statusline-hook.sh +21 -21
  306. package/.claude/helpers/statusline.cjs +575 -575
  307. package/.claude/helpers/statusline.js +321 -321
  308. package/.claude/helpers/swarm-comms.sh +353 -353
  309. package/.claude/helpers/swarm-hooks.sh +761 -761
  310. package/.claude/helpers/swarm-monitor.sh +210 -210
  311. package/.claude/helpers/sync-v3-metrics.sh +245 -245
  312. package/.claude/helpers/update-v3-progress.sh +165 -165
  313. package/.claude/helpers/v3-quick-status.sh +57 -57
  314. package/.claude/helpers/v3.sh +110 -110
  315. package/.claude/helpers/validate-v3-config.sh +215 -215
  316. package/.claude/helpers/worker-manager.sh +170 -170
  317. package/.claude/settings.json +182 -182
  318. package/.claude/skills/agentdb-advanced/SKILL.md +550 -550
  319. package/.claude/skills/agentdb-learning/SKILL.md +545 -545
  320. package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -339
  321. package/.claude/skills/agentdb-optimization/SKILL.md +509 -509
  322. package/.claude/skills/agentdb-vector-search/SKILL.md +339 -339
  323. package/.claude/skills/agentic-jujutsu/SKILL.md +645 -645
  324. package/.claude/skills/aidefence-scan.md +151 -151
  325. package/.claude/skills/aidefence.yaml +297 -297
  326. package/.claude/skills/browser/SKILL.md +204 -204
  327. package/.claude/skills/flow-nexus-neural/SKILL.md +738 -738
  328. package/.claude/skills/flow-nexus-platform/SKILL.md +1157 -1157
  329. package/.claude/skills/flow-nexus-swarm/SKILL.md +610 -610
  330. package/.claude/skills/github-code-review/SKILL.md +1140 -1140
  331. package/.claude/skills/github-multi-repo/SKILL.md +874 -874
  332. package/.claude/skills/github-project-management/SKILL.md +1290 -1277
  333. package/.claude/skills/github-release-management/SKILL.md +1081 -1081
  334. package/.claude/skills/github-workflow-automation/SKILL.md +1065 -1065
  335. package/.claude/skills/hive-mind-advanced/SKILL.md +712 -712
  336. package/.claude/skills/hooks-automation/SKILL.md +1201 -1201
  337. package/.claude/skills/pair-programming/SKILL.md +1202 -1202
  338. package/.claude/skills/performance-analysis/SKILL.md +563 -563
  339. package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -446
  340. package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -201
  341. package/.claude/skills/secure-review.md +181 -181
  342. package/.claude/skills/skill-builder/SKILL.md +910 -910
  343. package/.claude/skills/sparc-methodology/SKILL.md +1115 -1115
  344. package/.claude/skills/stream-chain/SKILL.md +563 -563
  345. package/.claude/skills/swarm-advanced/SKILL.md +973 -973
  346. package/.claude/skills/swarm-orchestration/SKILL.md +179 -179
  347. package/.claude/skills/v3-cli-modernization/SKILL.md +871 -871
  348. package/.claude/skills/v3-core-implementation/SKILL.md +796 -796
  349. package/.claude/skills/v3-ddd-architecture/SKILL.md +441 -441
  350. package/.claude/skills/v3-integration-deep/SKILL.md +240 -240
  351. package/.claude/skills/v3-mcp-optimization/SKILL.md +776 -776
  352. package/.claude/skills/v3-memory-unification/SKILL.md +173 -173
  353. package/.claude/skills/v3-performance-optimization/SKILL.md +389 -389
  354. package/.claude/skills/v3-security-overhaul/SKILL.md +81 -81
  355. package/.claude/skills/v3-swarm-coordination/SKILL.md +339 -339
  356. package/.claude/skills/verification-quality/SKILL.md +649 -649
  357. package/.claude/skills/worker-benchmarks/skill.md +135 -135
  358. package/.claude/skills/worker-integration/skill.md +154 -154
  359. package/README.md +393 -391
  360. package/bin/cli.js +220 -220
  361. package/bin/mcp-server.js +224 -224
  362. package/bin/preinstall.cjs +2 -2
  363. package/dist/src/commands/agent-wasm.js +2 -2
  364. package/dist/src/commands/agent-wasm.js.map +1 -1
  365. package/dist/src/commands/completions.js +409 -409
  366. package/dist/src/commands/daemon.d.ts.map +1 -1
  367. package/dist/src/commands/daemon.js +19 -3
  368. package/dist/src/commands/daemon.js.map +1 -1
  369. package/dist/src/commands/doctor.d.ts.map +1 -1
  370. package/dist/src/commands/doctor.js +105 -23
  371. package/dist/src/commands/doctor.js.map +1 -1
  372. package/dist/src/commands/embeddings.js +26 -26
  373. package/dist/src/commands/hive-mind.d.ts.map +1 -1
  374. package/dist/src/commands/hive-mind.js +122 -104
  375. package/dist/src/commands/hive-mind.js.map +1 -1
  376. package/dist/src/commands/hooks.d.ts.map +1 -1
  377. package/dist/src/commands/hooks.js +34 -21
  378. package/dist/src/commands/hooks.js.map +1 -1
  379. package/dist/src/commands/memory.d.ts.map +1 -1
  380. package/dist/src/commands/memory.js +68 -0
  381. package/dist/src/commands/memory.js.map +1 -1
  382. package/dist/src/commands/ruvector/backup.js +23 -23
  383. package/dist/src/commands/ruvector/benchmark.js +31 -31
  384. package/dist/src/commands/ruvector/import.js +14 -14
  385. package/dist/src/commands/ruvector/init.js +115 -115
  386. package/dist/src/commands/ruvector/migrate.js +99 -99
  387. package/dist/src/commands/ruvector/optimize.js +51 -51
  388. package/dist/src/commands/ruvector/setup.js +624 -624
  389. package/dist/src/commands/ruvector/status.js +38 -38
  390. package/dist/src/index.d.ts +5 -1
  391. package/dist/src/index.d.ts.map +1 -1
  392. package/dist/src/index.js +59 -18
  393. package/dist/src/index.js.map +1 -1
  394. package/dist/src/init/claudemd-generator.js +226 -226
  395. package/dist/src/init/executor.d.ts.map +1 -1
  396. package/dist/src/init/executor.js +511 -453
  397. package/dist/src/init/executor.js.map +1 -1
  398. package/dist/src/init/helpers-generator.js +645 -645
  399. package/dist/src/init/settings-generator.d.ts.map +1 -1
  400. package/dist/src/init/settings-generator.js +11 -5
  401. package/dist/src/init/settings-generator.js.map +1 -1
  402. package/dist/src/init/statusline-generator.js +858 -858
  403. package/dist/src/init/types.d.ts +7 -0
  404. package/dist/src/init/types.d.ts.map +1 -1
  405. package/dist/src/init/types.js.map +1 -1
  406. package/dist/src/mcp-tools/agentdb-tools.d.ts +3 -0
  407. package/dist/src/mcp-tools/agentdb-tools.d.ts.map +1 -1
  408. package/dist/src/mcp-tools/agentdb-tools.js +108 -0
  409. package/dist/src/mcp-tools/agentdb-tools.js.map +1 -1
  410. package/dist/src/mcp-tools/hooks-tools.d.ts.map +1 -1
  411. package/dist/src/mcp-tools/hooks-tools.js +4 -2
  412. package/dist/src/mcp-tools/hooks-tools.js.map +1 -1
  413. package/dist/src/mcp-tools/memory-tools.d.ts.map +1 -1
  414. package/dist/src/mcp-tools/memory-tools.js +19 -0
  415. package/dist/src/mcp-tools/memory-tools.js.map +1 -1
  416. package/dist/src/mcp-tools/neural-tools.d.ts.map +1 -1
  417. package/dist/src/mcp-tools/neural-tools.js +14 -1
  418. package/dist/src/mcp-tools/neural-tools.js.map +1 -1
  419. package/dist/src/mcp-tools/security-tools.d.ts.map +1 -1
  420. package/dist/src/mcp-tools/security-tools.js +28 -3
  421. package/dist/src/mcp-tools/security-tools.js.map +1 -1
  422. package/dist/src/mcp-tools/swarm-tools.d.ts.map +1 -1
  423. package/dist/src/mcp-tools/swarm-tools.js +72 -3
  424. package/dist/src/mcp-tools/swarm-tools.js.map +1 -1
  425. package/dist/src/mcp-tools/types.d.ts +4 -33
  426. package/dist/src/mcp-tools/types.d.ts.map +1 -1
  427. package/dist/src/mcp-tools/types.js +4 -14
  428. package/dist/src/mcp-tools/types.js.map +1 -1
  429. package/dist/src/mcp-tools/validate-input.d.ts +5 -57
  430. package/dist/src/mcp-tools/validate-input.d.ts.map +1 -1
  431. package/dist/src/mcp-tools/validate-input.js +5 -233
  432. package/dist/src/mcp-tools/validate-input.js.map +1 -1
  433. package/dist/src/mcp-tools/wasm-agent-tools.js +1 -1
  434. package/dist/src/mcp-tools/wasm-agent-tools.js.map +1 -1
  435. package/dist/src/memory/intelligence.d.ts.map +1 -1
  436. package/dist/src/memory/intelligence.js +28 -3
  437. package/dist/src/memory/intelligence.js.map +1 -1
  438. package/dist/src/memory/memory-bridge.d.ts +69 -0
  439. package/dist/src/memory/memory-bridge.d.ts.map +1 -1
  440. package/dist/src/memory/memory-bridge.js +319 -66
  441. package/dist/src/memory/memory-bridge.js.map +1 -1
  442. package/dist/src/memory/memory-initializer.d.ts +5 -0
  443. package/dist/src/memory/memory-initializer.d.ts.map +1 -1
  444. package/dist/src/memory/memory-initializer.js +369 -363
  445. package/dist/src/memory/memory-initializer.js.map +1 -1
  446. package/dist/src/memory/neural-package-bridge.d.ts +48 -0
  447. package/dist/src/memory/neural-package-bridge.d.ts.map +1 -0
  448. package/dist/src/memory/neural-package-bridge.js +87 -0
  449. package/dist/src/memory/neural-package-bridge.js.map +1 -0
  450. package/dist/src/memory/rabitq-index.js +5 -5
  451. package/dist/src/memory/sona-optimizer.d.ts.map +1 -1
  452. package/dist/src/memory/sona-optimizer.js +1 -0
  453. package/dist/src/memory/sona-optimizer.js.map +1 -1
  454. package/dist/src/output.d.ts +6 -130
  455. package/dist/src/output.d.ts.map +1 -1
  456. package/dist/src/output.js +6 -511
  457. package/dist/src/output.js.map +1 -1
  458. package/dist/src/parser.d.ts +9 -0
  459. package/dist/src/parser.d.ts.map +1 -1
  460. package/dist/src/parser.js +11 -0
  461. package/dist/src/parser.js.map +1 -1
  462. package/dist/src/runtime/headless.js +28 -28
  463. package/dist/src/ruvector/agent-wasm.d.ts.map +1 -1
  464. package/dist/src/ruvector/agent-wasm.js +4 -1
  465. package/dist/src/ruvector/agent-wasm.js.map +1 -1
  466. package/dist/src/ruvector/index.d.ts +0 -2
  467. package/dist/src/ruvector/index.d.ts.map +1 -1
  468. package/dist/src/ruvector/index.js +8 -2
  469. package/dist/src/ruvector/index.js.map +1 -1
  470. package/dist/src/ruvector/model-router.d.ts +22 -1
  471. package/dist/src/ruvector/model-router.d.ts.map +1 -1
  472. package/dist/src/ruvector/model-router.js +125 -5
  473. package/dist/src/ruvector/model-router.js.map +1 -1
  474. package/dist/src/services/headless-worker-executor.js +84 -84
  475. package/dist/src/transfer/deploy-seraphine.js +23 -23
  476. package/dist/src/types.d.ts +10 -195
  477. package/dist/src/types.d.ts.map +1 -1
  478. package/dist/src/types.js +10 -35
  479. package/dist/src/types.js.map +1 -1
  480. package/dist/tsconfig.tsbuildinfo +1 -1
  481. package/package.json +6 -4
  482. package/scripts/deploy-ipfs-node.sh +153 -153
  483. package/scripts/postinstall.cjs +153 -153
  484. package/scripts/publish-registry.ts +345 -345
  485. package/scripts/publish.sh +57 -57
  486. package/scripts/setup-ipfs-registry.md +366 -366
  487. package/dist/src/services/event-stream.d.ts.map +0 -1
  488. package/dist/src/services/event-stream.js.map +0 -1
  489. package/dist/src/services/loop-worker-runner.d.ts.map +0 -1
  490. package/dist/src/services/loop-worker-runner.js.map +0 -1
  491. package/dist/src/services/runtime-capabilities.d.ts.map +0 -1
  492. package/dist/src/services/runtime-capabilities.js.map +0 -1
@@ -21,840 +21,840 @@
21
21
  */
22
22
  export function generateStatuslineScript(options) {
23
23
  const maxAgents = options.runtime.maxAgents;
24
- return `#!/usr/bin/env node
25
- /**
26
- * RuFlo V3 Statusline Generator (Optimized)
27
- * Displays real-time V3 implementation progress and system status
28
- *
29
- * Usage: node statusline.cjs [--json] [--compact]
30
- *
31
- * Performance notes:
32
- * - Single git execSync call (combines branch + status + upstream)
33
- * - No recursive file reading (only stat/readdir, never read test contents)
34
- * - No ps aux calls (uses process.memoryUsage() + file-based metrics)
35
- * - Strict 2s timeout on all execSync calls
36
- * - Shared settings cache across functions
37
- */
38
-
39
- /* eslint-disable @typescript-eslint/no-var-requires */
40
- const fs = require('fs');
41
- const path = require('path');
42
- const { execSync } = require('child_process');
43
- const os = require('os');
44
-
45
- // Configuration
46
- const CONFIG = {
47
- maxAgents: ${maxAgents},
48
- };
49
-
50
- const CWD = process.cwd();
51
-
52
- // ANSI colors
53
- const c = {
54
- reset: '\\x1b[0m',
55
- bold: '\\x1b[1m',
56
- dim: '\\x1b[2m',
57
- red: '\\x1b[0;31m',
58
- green: '\\x1b[0;32m',
59
- yellow: '\\x1b[0;33m',
60
- blue: '\\x1b[0;34m',
61
- purple: '\\x1b[0;35m',
62
- cyan: '\\x1b[0;36m',
63
- brightRed: '\\x1b[1;31m',
64
- brightGreen: '\\x1b[1;32m',
65
- brightYellow: '\\x1b[1;33m',
66
- brightBlue: '\\x1b[1;34m',
67
- brightPurple: '\\x1b[1;35m',
68
- brightCyan: '\\x1b[1;36m',
69
- brightWhite: '\\x1b[1;37m',
70
- };
71
-
72
- // Safe execSync with strict timeout (returns empty string on failure)
73
- function safeExec(cmd, timeoutMs = 2000) {
74
- try {
75
- return execSync(cmd, {
76
- encoding: 'utf-8',
77
- timeout: timeoutMs,
78
- stdio: ['pipe', 'pipe', 'pipe'],
79
- }).trim();
80
- } catch {
81
- return '';
82
- }
83
- }
84
-
85
- // Safe JSON file reader (returns null on failure)
86
- function readJSON(filePath) {
87
- try {
88
- if (fs.existsSync(filePath)) {
89
- return JSON.parse(fs.readFileSync(filePath, 'utf-8'));
90
- }
91
- } catch { /* ignore */ }
92
- return null;
93
- }
94
-
95
- // Safe file stat (returns null on failure)
96
- function safeStat(filePath) {
97
- try {
98
- return fs.statSync(filePath);
99
- } catch { /* ignore */ }
100
- return null;
101
- }
102
-
103
- // Shared settings cache — read once, used by multiple functions
104
- let _settingsCache = undefined;
105
- function getSettings() {
106
- if (_settingsCache !== undefined) return _settingsCache;
107
- _settingsCache = readJSON(path.join(CWD, '.claude', 'settings.json'))
108
- || readJSON(path.join(CWD, '.claude', 'settings.local.json'))
109
- || null;
110
- return _settingsCache;
111
- }
112
-
113
- // ─── Data Collection (all pure-Node.js or single-exec) ──────────
114
-
115
- // Get all git info in ONE shell call
116
- function getGitInfo() {
117
- const result = {
118
- name: 'user', gitBranch: '', modified: 0, untracked: 0,
119
- staged: 0, ahead: 0, behind: 0,
120
- };
121
-
122
- // Single shell: get user.name, branch, porcelain status, and upstream diff
123
- const script = [
124
- 'git config user.name 2>/dev/null || echo user',
125
- 'echo "---SEP---"',
126
- 'git branch --show-current 2>/dev/null',
127
- 'echo "---SEP---"',
128
- 'git status --porcelain 2>/dev/null',
129
- 'echo "---SEP---"',
130
- 'git rev-list --left-right --count HEAD...@{upstream} 2>/dev/null || echo "0 0"',
131
- ].join('; ');
132
-
133
- const raw = safeExec("sh -c '" + script + "'", 3000);
134
- if (!raw) return result;
135
-
136
- const parts = raw.split('---SEP---').map(s => s.trim());
137
- if (parts.length >= 4) {
138
- result.name = parts[0] || 'user';
139
- result.gitBranch = parts[1] || '';
140
-
141
- // Parse porcelain status
142
- if (parts[2]) {
143
- for (const line of parts[2].split('\\n')) {
144
- if (!line || line.length < 2) continue;
145
- const x = line[0], y = line[1];
146
- if (x === '?' && y === '?') { result.untracked++; continue; }
147
- if (x !== ' ' && x !== '?') result.staged++;
148
- if (y !== ' ' && y !== '?') result.modified++;
149
- }
150
- }
151
-
152
- // Parse ahead/behind
153
- const ab = (parts[3] || '0 0').split(/\\s+/);
154
- result.ahead = parseInt(ab[0]) || 0;
155
- result.behind = parseInt(ab[1]) || 0;
156
- }
157
-
158
- return result;
159
- }
160
-
161
- // Detect model name from Claude config (pure file reads, no exec)
162
- function getModelName() {
163
- try {
164
- const claudeConfig = readJSON(path.join(os.homedir(), '.claude.json'));
165
- if (claudeConfig && claudeConfig.projects) {
166
- for (const [projectPath, projectConfig] of Object.entries(claudeConfig.projects)) {
167
- if (CWD === projectPath || CWD.startsWith(projectPath + '/')) {
168
- const usage = projectConfig.lastModelUsage;
169
- if (usage) {
170
- const ids = Object.keys(usage);
171
- if (ids.length > 0) {
172
- let modelId = ids[ids.length - 1];
173
- let latest = 0;
174
- for (const id of ids) {
175
- const ts = usage[id] && usage[id].lastUsedAt ? new Date(usage[id].lastUsedAt).getTime() : 0;
176
- if (ts > latest) { latest = ts; modelId = id; }
177
- }
178
- if (modelId.includes('opus')) return 'Opus 4.7';
179
- if (modelId.includes('sonnet')) return 'Sonnet 4.6';
180
- if (modelId.includes('haiku')) return 'Haiku 4.5';
181
- return modelId.split('-').slice(1, 3).join(' ');
182
- }
183
- }
184
- break;
185
- }
186
- }
187
- }
188
- } catch { /* ignore */ }
189
-
190
- // Fallback: settings.json model field
191
- const settings = getSettings();
192
- if (settings && settings.model) {
193
- const m = settings.model;
194
- if (m.includes('opus')) return 'Opus 4.7';
195
- if (m.includes('sonnet')) return 'Sonnet 4.6';
196
- if (m.includes('haiku')) return 'Haiku 4.5';
197
- }
198
- return 'Claude Code';
199
- }
200
-
201
- // Get learning stats from real data sources (no heuristics)
202
- function getLearningStats() {
203
- let patterns = 0;
204
- let sessions = 0;
205
-
206
- // 1. Count real patterns from intelligence pattern store
207
- const patternStorePath = path.join(CWD, '.claude-flow', 'data', 'patterns.json');
208
- try {
209
- if (fs.existsSync(patternStorePath)) {
210
- const data = JSON.parse(fs.readFileSync(patternStorePath, 'utf-8'));
211
- if (Array.isArray(data)) patterns = data.length;
212
- else if (data && data.patterns) patterns = Array.isArray(data.patterns) ? data.patterns.length : Object.keys(data.patterns).length;
213
- }
214
- } catch { /* ignore */ }
215
-
216
- // 2. Count patterns from auto-memory-store (real entries, not file size)
217
- if (patterns === 0) {
218
- const autoStorePath = path.join(CWD, '.claude-flow', 'data', 'auto-memory-store.json');
219
- try {
220
- if (fs.existsSync(autoStorePath)) {
221
- const data = JSON.parse(fs.readFileSync(autoStorePath, 'utf-8'));
222
- if (Array.isArray(data)) patterns = data.length;
223
- else if (data && data.entries) patterns = data.entries.length;
224
- }
225
- } catch { /* ignore */ }
226
- }
227
-
228
- // 3. Count patterns from memory.db using row count (sqlite header bytes 28-31)
229
- if (patterns === 0) {
230
- const memoryPaths = [
231
- path.join(CWD, '.claude-flow', 'memory.db'),
232
- path.join(CWD, 'data', 'memory.db'),
233
- path.join(CWD, '.swarm', 'memory.db'),
234
- ];
235
- for (const dbPath of memoryPaths) {
236
- try {
237
- if (fs.existsSync(dbPath)) {
238
- // Read SQLite header: page count at offset 28 (4 bytes big-endian)
239
- const fd = fs.openSync(dbPath, 'r');
240
- const buf = Buffer.alloc(4);
241
- fs.readSync(fd, buf, 0, 4, 28);
242
- fs.closeSync(fd);
243
- const pageCount = buf.readUInt32BE(0);
244
- // Each page typically holds ~10-50 rows; use page count as conservative estimate
245
- // But report 0 if DB exists but has only schema pages (< 3)
246
- patterns = pageCount > 2 ? pageCount - 2 : 0;
247
- break;
248
- }
249
- } catch { /* ignore */ }
250
- }
251
- }
252
-
253
- // 4. Count real session files
254
- try {
255
- const sessDir = path.join(CWD, '.claude', 'sessions');
256
- if (fs.existsSync(sessDir)) {
257
- sessions = fs.readdirSync(sessDir).filter(f => f.endsWith('.json')).length;
258
- }
259
- } catch { /* ignore */ }
260
-
261
- // 5. Count session files from claude-flow
262
- if (sessions === 0) {
263
- try {
264
- const cfSessDir = path.join(CWD, '.claude-flow', 'sessions');
265
- if (fs.existsSync(cfSessDir)) {
266
- sessions = fs.readdirSync(cfSessDir).filter(f => f.endsWith('.json')).length;
267
- }
268
- } catch { /* ignore */ }
269
- }
270
-
271
- return { patterns, sessions };
272
- }
273
-
274
- // V3 progress from metrics files (pure file reads)
275
- function getV3Progress() {
276
- const learning = getLearningStats();
277
- const totalDomains = 5;
278
-
279
- const dddData = readJSON(path.join(CWD, '.claude-flow', 'metrics', 'ddd-progress.json'));
280
- let dddProgress = dddData ? (dddData.progress || 0) : 0;
281
- let domainsCompleted = Math.min(5, Math.floor(dddProgress / 20));
282
-
283
- // Only derive DDD progress from real ddd-progress.json or real pattern data
284
- // Don't inflate domains from pattern count — 0 means no DDD work tracked
285
- if (dddProgress === 0 && learning.patterns > 0) {
286
- // Conservative: only count domains if we have substantial real pattern data
287
- // Each domain requires ~100 real stored patterns to claim completion
288
- domainsCompleted = Math.min(5, Math.floor(learning.patterns / 100));
289
- dddProgress = Math.floor((domainsCompleted / totalDomains) * 100);
290
- }
291
-
292
- return {
293
- domainsCompleted, totalDomains, dddProgress,
294
- patternsLearned: learning.patterns,
295
- sessionsCompleted: learning.sessions,
296
- };
297
- }
298
-
299
- // Security status (pure file reads)
300
- function getSecurityStatus() {
301
- const auditData = readJSON(path.join(CWD, '.claude-flow', 'security', 'audit-status.json'));
302
- if (auditData) {
303
- const auditDate = auditData.lastAudit || auditData.lastScan;
304
- if (!auditDate) {
305
- return { status: 'PENDING', cvesFixed: 0, totalCves: 0 };
306
- }
307
- const auditAge = Date.now() - new Date(auditDate).getTime();
308
- const isStale = auditAge > 7 * 24 * 60 * 60 * 1000;
309
- return {
310
- status: isStale ? 'STALE' : (auditData.status || 'PENDING'),
311
- cvesFixed: auditData.cvesFixed || 0,
312
- totalCves: auditData.totalCves || 0,
313
- };
314
- }
315
-
316
- let scanCount = 0;
317
- try {
318
- const scanDir = path.join(CWD, '.claude', 'security-scans');
319
- if (fs.existsSync(scanDir)) {
320
- scanCount = fs.readdirSync(scanDir).filter(f => f.endsWith('.json')).length;
321
- }
322
- } catch { /* ignore */ }
323
-
324
- return {
325
- status: scanCount > 0 ? 'SCANNED' : 'NONE',
326
- cvesFixed: 0,
327
- totalCves: 0,
328
- };
329
- }
330
-
331
- // Swarm status (pure file reads, NO ps aux)
332
- function getSwarmStatus() {
333
- const staleThresholdMs = 5 * 60 * 1000;
334
- const now = Date.now();
335
-
336
- const swarmStatePath = path.join(CWD, '.claude-flow', 'swarm', 'swarm-state.json');
337
- const swarmState = readJSON(swarmStatePath);
338
- if (swarmState) {
339
- const updatedAt = swarmState.updatedAt || swarmState.startedAt;
340
- const age = updatedAt ? now - new Date(updatedAt).getTime() : Infinity;
341
- if (age < staleThresholdMs) {
342
- return {
343
- activeAgents: (swarmState.agents && swarmState.agents.length) || swarmState.agentCount || 0,
344
- maxAgents: swarmState.maxAgents || CONFIG.maxAgents,
345
- coordinationActive: true,
346
- };
347
- }
348
- }
349
-
350
- const activityData = readJSON(path.join(CWD, '.claude-flow', 'metrics', 'swarm-activity.json'));
351
- if (activityData && activityData.swarm) {
352
- const updatedAt = activityData.timestamp || (activityData.swarm && activityData.swarm.timestamp);
353
- const age = updatedAt ? now - new Date(updatedAt).getTime() : Infinity;
354
- if (age < staleThresholdMs) {
355
- return {
356
- activeAgents: activityData.swarm.agent_count || 0,
357
- maxAgents: CONFIG.maxAgents,
358
- coordinationActive: activityData.swarm.coordination_active || activityData.swarm.active || false,
359
- };
360
- }
361
- }
362
-
363
- return { activeAgents: 0, maxAgents: CONFIG.maxAgents, coordinationActive: false };
364
- }
365
-
366
- // System metrics (uses process.memoryUsage() — no shell spawn)
367
- function getSystemMetrics() {
368
- const memoryMB = Math.floor(process.memoryUsage().heapUsed / 1024 / 1024);
369
- const learning = getLearningStats();
370
- const agentdb = getAgentDBStats();
371
-
372
- // Intelligence from learning.json
373
- const learningData = readJSON(path.join(CWD, '.claude-flow', 'metrics', 'learning.json'));
374
- let intelligencePct = 0;
375
- let contextPct = 0;
376
-
377
- if (learningData && learningData.intelligence && learningData.intelligence.score !== undefined) {
378
- intelligencePct = Math.min(100, Math.floor(learningData.intelligence.score));
379
- } else {
380
- // Use real data only — patterns from actual store, vectors from actual DB
381
- const fromPatterns = learning.patterns > 0 ? Math.min(100, Math.floor(learning.patterns / 20)) : 0;
382
- const fromVectors = agentdb.vectorCount > 0 ? Math.min(100, Math.floor(agentdb.vectorCount / 20)) : 0;
383
- intelligencePct = Math.max(fromPatterns, fromVectors);
384
- }
385
- // No fake fallback — 0% means no real learning data exists
386
-
387
- if (learningData && learningData.sessions && learningData.sessions.total !== undefined) {
388
- contextPct = Math.min(100, learningData.sessions.total * 5);
389
- } else {
390
- // Real session count only — no heuristic derivation from patterns
391
- contextPct = learning.sessions > 0 ? Math.min(100, learning.sessions * 5) : 0;
392
- }
393
-
394
- // Sub-agents from file metrics (no ps aux)
395
- let subAgents = 0;
396
- const activityData = readJSON(path.join(CWD, '.claude-flow', 'metrics', 'swarm-activity.json'));
397
- if (activityData && activityData.processes && activityData.processes.estimated_agents) {
398
- subAgents = activityData.processes.estimated_agents;
399
- }
400
-
401
- return { memoryMB, contextPct, intelligencePct, subAgents };
402
- }
403
-
404
- // ADR status (count files only — don't read contents)
405
- function getADRStatus() {
406
- // Count actual ADR files first — compliance JSON may be stale
407
- const adrPaths = [
408
- path.join(CWD, 'v3', 'implementation', 'adrs'),
409
- path.join(CWD, 'docs', 'adrs'),
410
- path.join(CWD, '.claude-flow', 'adrs'),
411
- ];
412
-
413
- for (const adrPath of adrPaths) {
414
- try {
415
- if (fs.existsSync(adrPath)) {
416
- const files = fs.readdirSync(adrPath).filter(f =>
417
- f.endsWith('.md') && (f.startsWith('ADR-') || f.startsWith('adr-') || /^\\d{4}-/.test(f))
418
- );
419
- return { count: files.length, implemented: files.length, compliance: 0 };
420
- }
421
- } catch { /* ignore */ }
422
- }
423
-
424
- return { count: 0, implemented: 0, compliance: 0 };
425
- }
426
-
427
- // Hooks status (shared settings cache)
428
- function getHooksStatus() {
429
- let enabled = 0;
430
- let total = 0;
431
- const settings = getSettings();
432
-
433
- if (settings && settings.hooks) {
434
- for (const category of Object.keys(settings.hooks)) {
435
- const matchers = settings.hooks[category];
436
- if (!Array.isArray(matchers)) continue;
437
- for (const matcher of matchers) {
438
- const hooks = matcher && matcher.hooks;
439
- if (Array.isArray(hooks)) {
440
- total += hooks.length;
441
- enabled += hooks.length;
442
- }
443
- }
444
- }
445
- }
446
-
447
- try {
448
- const hooksDir = path.join(CWD, '.claude', 'hooks');
449
- if (fs.existsSync(hooksDir)) {
450
- const hookFiles = fs.readdirSync(hooksDir).filter(f => f.endsWith('.js') || f.endsWith('.sh')).length;
451
- total = Math.max(total, hookFiles);
452
- enabled = Math.max(enabled, hookFiles);
453
- }
454
- } catch { /* ignore */ }
455
-
456
- return { enabled, total };
457
- }
458
-
459
- // AgentDB stats — count real entries from all data stores
460
- function getAgentDBStats() {
461
- let vectorCount = 0;
462
- let dbSizeKB = 0;
463
- let namespaces = 0;
464
- let hasHnsw = false;
465
-
466
- // 1. Count real entries from auto-memory-store.json
467
- const storePath = path.join(CWD, '.claude-flow', 'data', 'auto-memory-store.json');
468
- const storeStat = safeStat(storePath);
469
- if (storeStat) {
470
- dbSizeKB += storeStat.size / 1024;
471
- try {
472
- const store = JSON.parse(fs.readFileSync(storePath, 'utf-8'));
473
- if (Array.isArray(store)) vectorCount += store.length;
474
- else if (store && store.entries) vectorCount += store.entries.length;
475
- } catch { /* fall back */ }
476
- }
477
-
478
- // 2. Count entries from hooks memory store (.claude-flow/memory/store.json)
479
- const hooksStorePath = path.join(CWD, '.claude-flow', 'memory', 'store.json');
480
- const hooksStoreStat = safeStat(hooksStorePath);
481
- if (hooksStoreStat) {
482
- dbSizeKB += hooksStoreStat.size / 1024;
483
- try {
484
- const store = JSON.parse(fs.readFileSync(hooksStorePath, 'utf-8'));
485
- if (store && store.entries) {
486
- const entryCount = Object.keys(store.entries).length;
487
- vectorCount = Math.max(vectorCount, entryCount);
488
- if (entryCount > 0) namespaces++;
489
- }
490
- } catch { /* fall back */ }
491
- }
492
-
493
- // 3. Count entries from ranked-context.json
494
- try {
495
- const ranked = readJSON(path.join(CWD, '.claude-flow', 'data', 'ranked-context.json'));
496
- if (ranked && ranked.entries && ranked.entries.length > vectorCount) vectorCount = ranked.entries.length;
497
- } catch { /* ignore */ }
498
-
499
- // 3. Add DB file sizes
500
- const dbFiles = [
501
- path.join(CWD, 'data', 'memory.db'),
502
- path.join(CWD, '.claude-flow', 'memory.db'),
503
- path.join(CWD, '.swarm', 'memory.db'),
504
- ];
505
- for (const f of dbFiles) {
506
- const stat = safeStat(f);
507
- if (stat) {
508
- dbSizeKB += stat.size / 1024;
509
- namespaces++;
510
- }
511
- }
512
-
513
- // 4. Graph data size
514
- const graphStat = safeStat(path.join(CWD, 'data', 'memory.graph'));
515
- if (graphStat) dbSizeKB += graphStat.size / 1024;
516
-
517
- // 5. HNSW index or memory package
518
- const hnswPaths = [
519
- path.join(CWD, '.swarm', 'hnsw.index'),
520
- path.join(CWD, '.claude-flow', 'hnsw.index'),
521
- ];
522
- for (const p of hnswPaths) {
523
- if (safeStat(p)) { hasHnsw = true; break; }
524
- }
525
- if (!hasHnsw) {
526
- const memPkgPaths = [
527
- path.join(CWD, 'v3', '@claude-flow', 'memory', 'dist'),
528
- path.join(CWD, 'node_modules', '@claude-flow', 'memory'),
529
- ];
530
- for (const p of memPkgPaths) {
531
- if (fs.existsSync(p)) { hasHnsw = true; break; }
532
- }
533
- }
534
-
535
- return { vectorCount, dbSizeKB: Math.floor(dbSizeKB), namespaces, hasHnsw };
536
- }
537
-
538
- // Test stats (count files only — NO reading file contents)
539
- function getTestStats() {
540
- let testFiles = 0;
541
-
542
- function countTestFiles(dir, depth) {
543
- if (depth === undefined) depth = 0;
544
- if (depth > 6) return;
545
- try {
546
- if (!fs.existsSync(dir)) return;
547
- const entries = fs.readdirSync(dir, { withFileTypes: true });
548
- for (const entry of entries) {
549
- if (entry.isDirectory() && !entry.name.startsWith('.') && entry.name !== 'node_modules') {
550
- countTestFiles(path.join(dir, entry.name), depth + 1);
551
- } else if (entry.isFile()) {
552
- const n = entry.name;
553
- if (n.includes('.test.') || n.includes('.spec.') || n.includes('_test.') || n.includes('_spec.')) {
554
- testFiles++;
555
- }
556
- }
557
- }
558
- } catch { /* ignore */ }
559
- }
560
-
561
- var testDirNames = ['tests', 'test', '__tests__', 'src', 'v3'];
562
- for (var i = 0; i < testDirNames.length; i++) {
563
- countTestFiles(path.join(CWD, testDirNames[i]));
564
- }
565
-
566
- return { testFiles, testCases: testFiles * 4 };
567
- }
568
-
569
- // Integration status (shared settings + file checks)
570
- function getIntegrationStatus() {
571
- const mcpServers = { total: 0, enabled: 0 };
572
- const settings = getSettings();
573
-
574
- if (settings && settings.mcpServers && typeof settings.mcpServers === 'object') {
575
- const servers = Object.keys(settings.mcpServers);
576
- mcpServers.total = servers.length;
577
- mcpServers.enabled = settings.enabledMcpjsonServers
578
- ? settings.enabledMcpjsonServers.filter(s => servers.includes(s)).length
579
- : servers.length;
580
- }
581
-
582
- if (mcpServers.total === 0) {
583
- const mcpConfig = readJSON(path.join(CWD, '.mcp.json'))
584
- || readJSON(path.join(os.homedir(), '.claude', 'mcp.json'));
585
- if (mcpConfig && mcpConfig.mcpServers) {
586
- const s = Object.keys(mcpConfig.mcpServers);
587
- mcpServers.total = s.length;
588
- mcpServers.enabled = s.length;
589
- }
590
- }
591
-
592
- const hasDatabase = ['.swarm/memory.db', '.claude-flow/memory.db', 'data/memory.db']
593
- .some(p => fs.existsSync(path.join(CWD, p)));
594
- const hasApi = !!(process.env.ANTHROPIC_API_KEY || process.env.OPENAI_API_KEY);
595
-
596
- return { mcpServers, hasDatabase, hasApi };
597
- }
598
-
599
- // Session stats (pure file reads)
600
- function getSessionStats() {
601
- var sessionPaths = ['.claude-flow/session.json', '.claude/session.json'];
602
- for (var i = 0; i < sessionPaths.length; i++) {
603
- const data = readJSON(path.join(CWD, sessionPaths[i]));
604
- if (data && data.startTime) {
605
- const diffMs = Date.now() - new Date(data.startTime).getTime();
606
- const mins = Math.floor(diffMs / 60000);
607
- const duration = mins < 60 ? mins + 'm' : Math.floor(mins / 60) + 'h' + (mins % 60) + 'm';
608
- return { duration: duration };
609
- }
610
- }
611
- return { duration: '' };
612
- }
613
-
614
- // ─── Rendering ──────────────────────────────────────────────────
615
-
616
- function progressBar(current, total) {
617
- const width = 5;
618
- const filled = Math.round((current / total) * width);
619
- return '[' + '\\u25CF'.repeat(filled) + '\\u25CB'.repeat(width - filled) + ']';
620
- }
621
-
622
- function generateStatusline() {
623
- const git = getGitInfo();
624
- // Prefer model name from Claude Code stdin data, fallback to file-based detection
625
- const modelName = getModelFromStdin() || getModelName();
626
- const ctxInfo = getContextFromStdin();
627
- const costInfo = getCostFromStdin();
628
- const progress = getV3Progress();
629
- const security = getSecurityStatus();
630
- const swarm = getSwarmStatus();
631
- const system = getSystemMetrics();
632
- const adrs = getADRStatus();
633
- const hooks = getHooksStatus();
634
- const agentdb = getAgentDBStats();
635
- const tests = getTestStats();
636
- const session = getSessionStats();
637
- const integration = getIntegrationStatus();
638
- const lines = [];
639
-
640
- // Header
641
- // Read version from package.json
642
- let pkgVersion = '3.6';
643
- try {
644
- const pkgPath = path.join(CWD, 'node_modules', '@claude-flow', 'cli', 'package.json');
645
- if (fs.existsSync(pkgPath)) {
646
- const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8'));
647
- if (pkg.version) pkgVersion = pkg.version;
648
- } else {
649
- // Try npx-installed location
650
- const npxPkg = path.join(CWD, 'v3', '@claude-flow', 'cli', 'package.json');
651
- if (fs.existsSync(npxPkg)) {
652
- const pkg = JSON.parse(fs.readFileSync(npxPkg, 'utf-8'));
653
- if (pkg.version) pkgVersion = pkg.version;
654
- }
655
- }
656
- } catch { /* use default */ }
657
- let header = c.bold + c.brightPurple + '\\u258A RuFlo V' + pkgVersion + ' ' + c.reset;
658
- header += (swarm.coordinationActive ? c.brightCyan : c.dim) + '\\u25CF ' + c.brightCyan + git.name + c.reset;
659
- if (git.gitBranch) {
660
- header += ' ' + c.dim + '\\u2502' + c.reset + ' ' + c.brightBlue + '\\u23C7 ' + git.gitBranch + c.reset;
661
- const changes = git.modified + git.staged + git.untracked;
662
- if (changes > 0) {
663
- let ind = '';
664
- if (git.staged > 0) ind += c.brightGreen + '+' + git.staged + c.reset;
665
- if (git.modified > 0) ind += c.brightYellow + '~' + git.modified + c.reset;
666
- if (git.untracked > 0) ind += c.dim + '?' + git.untracked + c.reset;
667
- header += ' ' + ind;
668
- }
669
- if (git.ahead > 0) header += ' ' + c.brightGreen + '\\u2191' + git.ahead + c.reset;
670
- if (git.behind > 0) header += ' ' + c.brightRed + '\\u2193' + git.behind + c.reset;
671
- }
672
- header += ' ' + c.dim + '\\u2502' + c.reset + ' ' + c.purple + modelName + c.reset;
673
- // Show session duration from Claude Code stdin if available, else from local files
674
- const duration = costInfo ? costInfo.duration : session.duration;
675
- if (duration) header += ' ' + c.dim + '\\u2502' + c.reset + ' ' + c.cyan + '\\u23F1 ' + duration + c.reset;
676
- // Show context usage from Claude Code stdin if available
677
- if (ctxInfo && ctxInfo.usedPct > 0) {
678
- const ctxColor = ctxInfo.usedPct >= 90 ? c.brightRed : ctxInfo.usedPct >= 70 ? c.brightYellow : c.brightGreen;
679
- header += ' ' + c.dim + '\\u2502' + c.reset + ' ' + ctxColor + '\\u25CF ' + ctxInfo.usedPct + '% ctx' + c.reset;
680
- }
681
- // Show cost from Claude Code stdin if available
682
- if (costInfo && costInfo.costUsd > 0) {
683
- header += ' ' + c.dim + '\\u2502' + c.reset + ' ' + c.brightYellow + '$' + costInfo.costUsd.toFixed(2) + c.reset;
684
- }
685
- lines.push(header);
686
-
687
- // Separator
688
- lines.push(c.dim + '\\u2500'.repeat(53) + c.reset);
689
-
690
- // Line 1: DDD Domains
691
- const domainsColor = progress.domainsCompleted >= 3 ? c.brightGreen : progress.domainsCompleted > 0 ? c.yellow : c.red;
692
- let perfIndicator;
693
- if (agentdb.hasHnsw && agentdb.vectorCount > 0) {
694
- const speedup = agentdb.vectorCount > 10000 ? '12500x' : agentdb.vectorCount > 1000 ? '150x' : '10x';
695
- perfIndicator = c.brightGreen + '\\u26A1 HNSW ' + speedup + c.reset;
696
- } else if (progress.patternsLearned > 0) {
697
- const pk = progress.patternsLearned >= 1000 ? (progress.patternsLearned / 1000).toFixed(1) + 'k' : String(progress.patternsLearned);
698
- perfIndicator = c.brightYellow + '\\uD83D\\uDCDA ' + pk + ' patterns' + c.reset;
699
- } else {
700
- perfIndicator = c.dim + '\\u26A1 target: 150x-12500x' + c.reset;
701
- }
702
- lines.push(
703
- c.brightCyan + '\\uD83C\\uDFD7\\uFE0F DDD Domains' + c.reset + ' ' + progressBar(progress.domainsCompleted, progress.totalDomains) + ' ' +
704
- domainsColor + progress.domainsCompleted + c.reset + '/' + c.brightWhite + progress.totalDomains + c.reset + ' ' + perfIndicator
705
- );
706
-
707
- // Line 2: Swarm + Hooks + CVE + Memory + Intelligence
708
- const swarmInd = swarm.coordinationActive ? c.brightGreen + '\\u25C9' + c.reset : c.dim + '\\u25CB' + c.reset;
709
- const agentsColor = swarm.activeAgents > 0 ? c.brightGreen : c.red;
710
- const secIcon = security.status === 'CLEAN' ? '\\uD83D\\uDFE2' : (security.status === 'IN_PROGRESS' || security.status === 'STALE') ? '\\uD83D\\uDFE1' : (security.status === 'NONE' ? '\\u26AA' : '\\uD83D\\uDD34');
711
- const secColor = security.status === 'CLEAN' ? c.brightGreen : (security.status === 'IN_PROGRESS' || security.status === 'STALE') ? c.brightYellow : (security.status === 'NONE' ? c.dim : c.brightRed);
712
- const hooksColor = hooks.enabled > 0 ? c.brightGreen : c.dim;
713
- const intellColor = system.intelligencePct >= 80 ? c.brightGreen : system.intelligencePct >= 40 ? c.brightYellow : c.dim;
714
-
715
- lines.push(
716
- c.brightYellow + '\\uD83E\\uDD16 Swarm' + c.reset + ' ' + swarmInd + ' [' + agentsColor + String(swarm.activeAgents).padStart(2) + c.reset + '/' + c.brightWhite + swarm.maxAgents + c.reset + '] ' +
717
- c.brightPurple + '\\uD83D\\uDC65 ' + system.subAgents + c.reset + ' ' +
718
- c.brightBlue + '\\uD83E\\uDE9D ' + hooksColor + hooks.enabled + c.reset + '/' + c.brightWhite + hooks.total + c.reset + ' ' +
719
- secIcon + ' ' + secColor + 'CVE ' + security.cvesFixed + c.reset + '/' + c.brightWhite + security.totalCves + c.reset + ' ' +
720
- c.brightCyan + '\\uD83D\\uDCBE ' + system.memoryMB + 'MB' + c.reset + ' ' +
721
- intellColor + '\\uD83E\\uDDE0 ' + String(system.intelligencePct).padStart(3) + '%' + c.reset
722
- );
723
-
724
- // Line 3: Architecture
725
- const dddColor = progress.dddProgress >= 50 ? c.brightGreen : progress.dddProgress > 0 ? c.yellow : c.red;
726
- const adrColor = adrs.count > 0 ? (adrs.implemented === adrs.count ? c.brightGreen : c.yellow) : c.dim;
727
- const adrDisplay = adrs.compliance > 0 ? adrColor + '\\u25CF' + adrs.compliance + '%' + c.reset : adrColor + '\\u25CF' + adrs.implemented + '/' + adrs.count + c.reset;
728
-
729
- lines.push(
730
- c.brightPurple + '\\uD83D\\uDD27 Architecture' + c.reset + ' ' +
731
- c.cyan + 'ADRs' + c.reset + ' ' + adrDisplay + ' ' + c.dim + '\\u2502' + c.reset + ' ' +
732
- c.cyan + 'DDD' + c.reset + ' ' + dddColor + '\\u25CF' + String(progress.dddProgress).padStart(3) + '%' + c.reset + ' ' + c.dim + '\\u2502' + c.reset + ' ' +
733
- c.cyan + 'Security' + c.reset + ' ' + secColor + '\\u25CF' + security.status + c.reset
734
- );
735
-
736
- // Line 4: AgentDB, Tests, Integration
737
- const hnswInd = agentdb.hasHnsw ? c.brightGreen + '\\u26A1' + c.reset : '';
738
- const sizeDisp = agentdb.dbSizeKB >= 1024 ? (agentdb.dbSizeKB / 1024).toFixed(1) + 'MB' : agentdb.dbSizeKB + 'KB';
739
- const vectorColor = agentdb.vectorCount > 0 ? c.brightGreen : c.dim;
740
- const testColor = tests.testFiles > 0 ? c.brightGreen : c.dim;
741
-
742
- let integStr = '';
743
- if (integration.mcpServers.total > 0) {
744
- const mcpCol = integration.mcpServers.enabled === integration.mcpServers.total ? c.brightGreen :
745
- integration.mcpServers.enabled > 0 ? c.brightYellow : c.red;
746
- integStr += c.cyan + 'MCP' + c.reset + ' ' + mcpCol + '\\u25CF' + integration.mcpServers.enabled + '/' + integration.mcpServers.total + c.reset;
747
- }
748
- if (integration.hasDatabase) integStr += (integStr ? ' ' : '') + c.brightGreen + '\\u25C6' + c.reset + 'DB';
749
- if (integration.hasApi) integStr += (integStr ? ' ' : '') + c.brightGreen + '\\u25C6' + c.reset + 'API';
750
- if (!integStr) integStr = c.dim + '\\u25CF none' + c.reset;
751
-
752
- lines.push(
753
- c.brightCyan + '\\uD83D\\uDCCA AgentDB' + c.reset + ' ' +
754
- c.cyan + 'Vectors' + c.reset + ' ' + vectorColor + '\\u25CF' + agentdb.vectorCount + hnswInd + c.reset + ' ' + c.dim + '\\u2502' + c.reset + ' ' +
755
- c.cyan + 'Size' + c.reset + ' ' + c.brightWhite + sizeDisp + c.reset + ' ' + c.dim + '\\u2502' + c.reset + ' ' +
756
- c.cyan + 'Tests' + c.reset + ' ' + testColor + '\\u25CF' + tests.testFiles + c.reset + ' ' + c.dim + '(~' + tests.testCases + ' cases)' + c.reset + ' ' + c.dim + '\\u2502' + c.reset + ' ' +
757
- integStr
758
- );
759
-
760
- return lines.join('\\n');
761
- }
762
-
763
- // JSON output
764
- function generateJSON() {
765
- const git = getGitInfo();
766
- return {
767
- user: { name: git.name, gitBranch: git.gitBranch, modelName: getModelName() },
768
- v3Progress: getV3Progress(),
769
- security: getSecurityStatus(),
770
- swarm: getSwarmStatus(),
771
- system: getSystemMetrics(),
772
- adrs: getADRStatus(),
773
- hooks: getHooksStatus(),
774
- agentdb: getAgentDBStats(),
775
- tests: getTestStats(),
776
- git: { modified: git.modified, untracked: git.untracked, staged: git.staged, ahead: git.ahead, behind: git.behind },
777
- lastUpdated: new Date().toISOString(),
778
- };
779
- }
780
-
781
- // ─── Stdin reader (Claude Code pipes session JSON) ──────────────
782
-
783
- // Claude Code sends session JSON via stdin (model, context, cost, etc.)
784
- // Read it synchronously so the script works both:
785
- // 1. When invoked by Claude Code (stdin has JSON)
786
- // 2. When invoked manually from terminal (stdin is empty/tty)
787
- let _stdinData = null;
788
- function getStdinData() {
789
- if (_stdinData !== undefined && _stdinData !== null) return _stdinData;
790
- try {
791
- // Check if stdin is a TTY (manual run) — skip reading
792
- if (process.stdin.isTTY) { _stdinData = null; return null; }
793
- // Read stdin synchronously via fd 0
794
- const chunks = [];
795
- const buf = Buffer.alloc(4096);
796
- let bytesRead;
797
- try {
798
- while ((bytesRead = fs.readSync(0, buf, 0, buf.length, null)) > 0) {
799
- chunks.push(buf.slice(0, bytesRead));
800
- }
801
- } catch { /* EOF or read error */ }
802
- const raw = Buffer.concat(chunks).toString('utf-8').trim();
803
- if (raw && raw.startsWith('{')) {
804
- _stdinData = JSON.parse(raw);
805
- } else {
806
- _stdinData = null;
807
- }
808
- } catch {
809
- _stdinData = null;
810
- }
811
- return _stdinData;
812
- }
813
-
814
- // Override model detection to prefer stdin data from Claude Code
815
- function getModelFromStdin() {
816
- const data = getStdinData();
817
- if (data && data.model && data.model.display_name) return data.model.display_name;
818
- return null;
819
- }
820
-
821
- // Get context window info from Claude Code session
822
- function getContextFromStdin() {
823
- const data = getStdinData();
824
- if (data && data.context_window) {
825
- return {
826
- usedPct: Math.floor(data.context_window.used_percentage || 0),
827
- remainingPct: Math.floor(data.context_window.remaining_percentage || 100),
828
- };
829
- }
830
- return null;
831
- }
832
-
833
- // Get cost info from Claude Code session
834
- function getCostFromStdin() {
835
- const data = getStdinData();
836
- if (data && data.cost) {
837
- const durationMs = data.cost.total_duration_ms || 0;
838
- const mins = Math.floor(durationMs / 60000);
839
- const secs = Math.floor((durationMs % 60000) / 1000);
840
- return {
841
- costUsd: data.cost.total_cost_usd || 0,
842
- duration: mins > 0 ? mins + 'm' + secs + 's' : secs + 's',
843
- linesAdded: data.cost.total_lines_added || 0,
844
- linesRemoved: data.cost.total_lines_removed || 0,
845
- };
846
- }
847
- return null;
848
- }
849
-
850
- // ─── Main ───────────────────────────────────────────────────────
851
- if (process.argv.includes('--json')) {
852
- console.log(JSON.stringify(generateJSON(), null, 2));
853
- } else if (process.argv.includes('--compact')) {
854
- console.log(JSON.stringify(generateJSON()));
855
- } else {
856
- console.log(generateStatusline());
857
- }
24
+ return `#!/usr/bin/env node
25
+ /**
26
+ * RuFlo V3 Statusline Generator (Optimized)
27
+ * Displays real-time V3 implementation progress and system status
28
+ *
29
+ * Usage: node statusline.cjs [--json] [--compact]
30
+ *
31
+ * Performance notes:
32
+ * - Single git execSync call (combines branch + status + upstream)
33
+ * - No recursive file reading (only stat/readdir, never read test contents)
34
+ * - No ps aux calls (uses process.memoryUsage() + file-based metrics)
35
+ * - Strict 2s timeout on all execSync calls
36
+ * - Shared settings cache across functions
37
+ */
38
+
39
+ /* eslint-disable @typescript-eslint/no-var-requires */
40
+ const fs = require('fs');
41
+ const path = require('path');
42
+ const { execSync } = require('child_process');
43
+ const os = require('os');
44
+
45
+ // Configuration
46
+ const CONFIG = {
47
+ maxAgents: ${maxAgents},
48
+ };
49
+
50
+ const CWD = process.cwd();
51
+
52
+ // ANSI colors
53
+ const c = {
54
+ reset: '\\x1b[0m',
55
+ bold: '\\x1b[1m',
56
+ dim: '\\x1b[2m',
57
+ red: '\\x1b[0;31m',
58
+ green: '\\x1b[0;32m',
59
+ yellow: '\\x1b[0;33m',
60
+ blue: '\\x1b[0;34m',
61
+ purple: '\\x1b[0;35m',
62
+ cyan: '\\x1b[0;36m',
63
+ brightRed: '\\x1b[1;31m',
64
+ brightGreen: '\\x1b[1;32m',
65
+ brightYellow: '\\x1b[1;33m',
66
+ brightBlue: '\\x1b[1;34m',
67
+ brightPurple: '\\x1b[1;35m',
68
+ brightCyan: '\\x1b[1;36m',
69
+ brightWhite: '\\x1b[1;37m',
70
+ };
71
+
72
+ // Safe execSync with strict timeout (returns empty string on failure)
73
+ function safeExec(cmd, timeoutMs = 2000) {
74
+ try {
75
+ return execSync(cmd, {
76
+ encoding: 'utf-8',
77
+ timeout: timeoutMs,
78
+ stdio: ['pipe', 'pipe', 'pipe'],
79
+ }).trim();
80
+ } catch {
81
+ return '';
82
+ }
83
+ }
84
+
85
+ // Safe JSON file reader (returns null on failure)
86
+ function readJSON(filePath) {
87
+ try {
88
+ if (fs.existsSync(filePath)) {
89
+ return JSON.parse(fs.readFileSync(filePath, 'utf-8'));
90
+ }
91
+ } catch { /* ignore */ }
92
+ return null;
93
+ }
94
+
95
+ // Safe file stat (returns null on failure)
96
+ function safeStat(filePath) {
97
+ try {
98
+ return fs.statSync(filePath);
99
+ } catch { /* ignore */ }
100
+ return null;
101
+ }
102
+
103
+ // Shared settings cache — read once, used by multiple functions
104
+ let _settingsCache = undefined;
105
+ function getSettings() {
106
+ if (_settingsCache !== undefined) return _settingsCache;
107
+ _settingsCache = readJSON(path.join(CWD, '.claude', 'settings.json'))
108
+ || readJSON(path.join(CWD, '.claude', 'settings.local.json'))
109
+ || null;
110
+ return _settingsCache;
111
+ }
112
+
113
+ // ─── Data Collection (all pure-Node.js or single-exec) ──────────
114
+
115
+ // Get all git info in ONE shell call
116
+ function getGitInfo() {
117
+ const result = {
118
+ name: 'user', gitBranch: '', modified: 0, untracked: 0,
119
+ staged: 0, ahead: 0, behind: 0,
120
+ };
121
+
122
+ // Single shell: get user.name, branch, porcelain status, and upstream diff
123
+ const script = [
124
+ 'git config user.name 2>/dev/null || echo user',
125
+ 'echo "---SEP---"',
126
+ 'git branch --show-current 2>/dev/null',
127
+ 'echo "---SEP---"',
128
+ 'git status --porcelain 2>/dev/null',
129
+ 'echo "---SEP---"',
130
+ 'git rev-list --left-right --count HEAD...@{upstream} 2>/dev/null || echo "0 0"',
131
+ ].join('; ');
132
+
133
+ const raw = safeExec("sh -c '" + script + "'", 3000);
134
+ if (!raw) return result;
135
+
136
+ const parts = raw.split('---SEP---').map(s => s.trim());
137
+ if (parts.length >= 4) {
138
+ result.name = parts[0] || 'user';
139
+ result.gitBranch = parts[1] || '';
140
+
141
+ // Parse porcelain status
142
+ if (parts[2]) {
143
+ for (const line of parts[2].split('\\n')) {
144
+ if (!line || line.length < 2) continue;
145
+ const x = line[0], y = line[1];
146
+ if (x === '?' && y === '?') { result.untracked++; continue; }
147
+ if (x !== ' ' && x !== '?') result.staged++;
148
+ if (y !== ' ' && y !== '?') result.modified++;
149
+ }
150
+ }
151
+
152
+ // Parse ahead/behind
153
+ const ab = (parts[3] || '0 0').split(/\\s+/);
154
+ result.ahead = parseInt(ab[0]) || 0;
155
+ result.behind = parseInt(ab[1]) || 0;
156
+ }
157
+
158
+ return result;
159
+ }
160
+
161
+ // Detect model name from Claude config (pure file reads, no exec)
162
+ function getModelName() {
163
+ try {
164
+ const claudeConfig = readJSON(path.join(os.homedir(), '.claude.json'));
165
+ if (claudeConfig && claudeConfig.projects) {
166
+ for (const [projectPath, projectConfig] of Object.entries(claudeConfig.projects)) {
167
+ if (CWD === projectPath || CWD.startsWith(projectPath + '/')) {
168
+ const usage = projectConfig.lastModelUsage;
169
+ if (usage) {
170
+ const ids = Object.keys(usage);
171
+ if (ids.length > 0) {
172
+ let modelId = ids[ids.length - 1];
173
+ let latest = 0;
174
+ for (const id of ids) {
175
+ const ts = usage[id] && usage[id].lastUsedAt ? new Date(usage[id].lastUsedAt).getTime() : 0;
176
+ if (ts > latest) { latest = ts; modelId = id; }
177
+ }
178
+ if (modelId.includes('opus')) return 'Opus 4.7';
179
+ if (modelId.includes('sonnet')) return 'Sonnet 4.6';
180
+ if (modelId.includes('haiku')) return 'Haiku 4.5';
181
+ return modelId.split('-').slice(1, 3).join(' ');
182
+ }
183
+ }
184
+ break;
185
+ }
186
+ }
187
+ }
188
+ } catch { /* ignore */ }
189
+
190
+ // Fallback: settings.json model field
191
+ const settings = getSettings();
192
+ if (settings && settings.model) {
193
+ const m = settings.model;
194
+ if (m.includes('opus')) return 'Opus 4.7';
195
+ if (m.includes('sonnet')) return 'Sonnet 4.6';
196
+ if (m.includes('haiku')) return 'Haiku 4.5';
197
+ }
198
+ return 'Claude Code';
199
+ }
200
+
201
+ // Get learning stats from real data sources (no heuristics)
202
+ function getLearningStats() {
203
+ let patterns = 0;
204
+ let sessions = 0;
205
+
206
+ // 1. Count real patterns from intelligence pattern store
207
+ const patternStorePath = path.join(CWD, '.claude-flow', 'data', 'patterns.json');
208
+ try {
209
+ if (fs.existsSync(patternStorePath)) {
210
+ const data = JSON.parse(fs.readFileSync(patternStorePath, 'utf-8'));
211
+ if (Array.isArray(data)) patterns = data.length;
212
+ else if (data && data.patterns) patterns = Array.isArray(data.patterns) ? data.patterns.length : Object.keys(data.patterns).length;
213
+ }
214
+ } catch { /* ignore */ }
215
+
216
+ // 2. Count patterns from auto-memory-store (real entries, not file size)
217
+ if (patterns === 0) {
218
+ const autoStorePath = path.join(CWD, '.claude-flow', 'data', 'auto-memory-store.json');
219
+ try {
220
+ if (fs.existsSync(autoStorePath)) {
221
+ const data = JSON.parse(fs.readFileSync(autoStorePath, 'utf-8'));
222
+ if (Array.isArray(data)) patterns = data.length;
223
+ else if (data && data.entries) patterns = data.entries.length;
224
+ }
225
+ } catch { /* ignore */ }
226
+ }
227
+
228
+ // 3. Count patterns from memory.db using row count (sqlite header bytes 28-31)
229
+ if (patterns === 0) {
230
+ const memoryPaths = [
231
+ path.join(CWD, '.claude-flow', 'memory.db'),
232
+ path.join(CWD, 'data', 'memory.db'),
233
+ path.join(CWD, '.swarm', 'memory.db'),
234
+ ];
235
+ for (const dbPath of memoryPaths) {
236
+ try {
237
+ if (fs.existsSync(dbPath)) {
238
+ // Read SQLite header: page count at offset 28 (4 bytes big-endian)
239
+ const fd = fs.openSync(dbPath, 'r');
240
+ const buf = Buffer.alloc(4);
241
+ fs.readSync(fd, buf, 0, 4, 28);
242
+ fs.closeSync(fd);
243
+ const pageCount = buf.readUInt32BE(0);
244
+ // Each page typically holds ~10-50 rows; use page count as conservative estimate
245
+ // But report 0 if DB exists but has only schema pages (< 3)
246
+ patterns = pageCount > 2 ? pageCount - 2 : 0;
247
+ break;
248
+ }
249
+ } catch { /* ignore */ }
250
+ }
251
+ }
252
+
253
+ // 4. Count real session files
254
+ try {
255
+ const sessDir = path.join(CWD, '.claude', 'sessions');
256
+ if (fs.existsSync(sessDir)) {
257
+ sessions = fs.readdirSync(sessDir).filter(f => f.endsWith('.json')).length;
258
+ }
259
+ } catch { /* ignore */ }
260
+
261
+ // 5. Count session files from claude-flow
262
+ if (sessions === 0) {
263
+ try {
264
+ const cfSessDir = path.join(CWD, '.claude-flow', 'sessions');
265
+ if (fs.existsSync(cfSessDir)) {
266
+ sessions = fs.readdirSync(cfSessDir).filter(f => f.endsWith('.json')).length;
267
+ }
268
+ } catch { /* ignore */ }
269
+ }
270
+
271
+ return { patterns, sessions };
272
+ }
273
+
274
+ // V3 progress from metrics files (pure file reads)
275
+ function getV3Progress() {
276
+ const learning = getLearningStats();
277
+ const totalDomains = 5;
278
+
279
+ const dddData = readJSON(path.join(CWD, '.claude-flow', 'metrics', 'ddd-progress.json'));
280
+ let dddProgress = dddData ? (dddData.progress || 0) : 0;
281
+ let domainsCompleted = Math.min(5, Math.floor(dddProgress / 20));
282
+
283
+ // Only derive DDD progress from real ddd-progress.json or real pattern data
284
+ // Don't inflate domains from pattern count — 0 means no DDD work tracked
285
+ if (dddProgress === 0 && learning.patterns > 0) {
286
+ // Conservative: only count domains if we have substantial real pattern data
287
+ // Each domain requires ~100 real stored patterns to claim completion
288
+ domainsCompleted = Math.min(5, Math.floor(learning.patterns / 100));
289
+ dddProgress = Math.floor((domainsCompleted / totalDomains) * 100);
290
+ }
291
+
292
+ return {
293
+ domainsCompleted, totalDomains, dddProgress,
294
+ patternsLearned: learning.patterns,
295
+ sessionsCompleted: learning.sessions,
296
+ };
297
+ }
298
+
299
+ // Security status (pure file reads)
300
+ function getSecurityStatus() {
301
+ const auditData = readJSON(path.join(CWD, '.claude-flow', 'security', 'audit-status.json'));
302
+ if (auditData) {
303
+ const auditDate = auditData.lastAudit || auditData.lastScan;
304
+ if (!auditDate) {
305
+ return { status: 'PENDING', cvesFixed: 0, totalCves: 0 };
306
+ }
307
+ const auditAge = Date.now() - new Date(auditDate).getTime();
308
+ const isStale = auditAge > 7 * 24 * 60 * 60 * 1000;
309
+ return {
310
+ status: isStale ? 'STALE' : (auditData.status || 'PENDING'),
311
+ cvesFixed: auditData.cvesFixed || 0,
312
+ totalCves: auditData.totalCves || 0,
313
+ };
314
+ }
315
+
316
+ let scanCount = 0;
317
+ try {
318
+ const scanDir = path.join(CWD, '.claude', 'security-scans');
319
+ if (fs.existsSync(scanDir)) {
320
+ scanCount = fs.readdirSync(scanDir).filter(f => f.endsWith('.json')).length;
321
+ }
322
+ } catch { /* ignore */ }
323
+
324
+ return {
325
+ status: scanCount > 0 ? 'SCANNED' : 'NONE',
326
+ cvesFixed: 0,
327
+ totalCves: 0,
328
+ };
329
+ }
330
+
331
+ // Swarm status (pure file reads, NO ps aux)
332
+ function getSwarmStatus() {
333
+ const staleThresholdMs = 5 * 60 * 1000;
334
+ const now = Date.now();
335
+
336
+ const swarmStatePath = path.join(CWD, '.claude-flow', 'swarm', 'swarm-state.json');
337
+ const swarmState = readJSON(swarmStatePath);
338
+ if (swarmState) {
339
+ const updatedAt = swarmState.updatedAt || swarmState.startedAt;
340
+ const age = updatedAt ? now - new Date(updatedAt).getTime() : Infinity;
341
+ if (age < staleThresholdMs) {
342
+ return {
343
+ activeAgents: (swarmState.agents && swarmState.agents.length) || swarmState.agentCount || 0,
344
+ maxAgents: swarmState.maxAgents || CONFIG.maxAgents,
345
+ coordinationActive: true,
346
+ };
347
+ }
348
+ }
349
+
350
+ const activityData = readJSON(path.join(CWD, '.claude-flow', 'metrics', 'swarm-activity.json'));
351
+ if (activityData && activityData.swarm) {
352
+ const updatedAt = activityData.timestamp || (activityData.swarm && activityData.swarm.timestamp);
353
+ const age = updatedAt ? now - new Date(updatedAt).getTime() : Infinity;
354
+ if (age < staleThresholdMs) {
355
+ return {
356
+ activeAgents: activityData.swarm.agent_count || 0,
357
+ maxAgents: CONFIG.maxAgents,
358
+ coordinationActive: activityData.swarm.coordination_active || activityData.swarm.active || false,
359
+ };
360
+ }
361
+ }
362
+
363
+ return { activeAgents: 0, maxAgents: CONFIG.maxAgents, coordinationActive: false };
364
+ }
365
+
366
+ // System metrics (uses process.memoryUsage() — no shell spawn)
367
+ function getSystemMetrics() {
368
+ const memoryMB = Math.floor(process.memoryUsage().heapUsed / 1024 / 1024);
369
+ const learning = getLearningStats();
370
+ const agentdb = getAgentDBStats();
371
+
372
+ // Intelligence from learning.json
373
+ const learningData = readJSON(path.join(CWD, '.claude-flow', 'metrics', 'learning.json'));
374
+ let intelligencePct = 0;
375
+ let contextPct = 0;
376
+
377
+ if (learningData && learningData.intelligence && learningData.intelligence.score !== undefined) {
378
+ intelligencePct = Math.min(100, Math.floor(learningData.intelligence.score));
379
+ } else {
380
+ // Use real data only — patterns from actual store, vectors from actual DB
381
+ const fromPatterns = learning.patterns > 0 ? Math.min(100, Math.floor(learning.patterns / 20)) : 0;
382
+ const fromVectors = agentdb.vectorCount > 0 ? Math.min(100, Math.floor(agentdb.vectorCount / 20)) : 0;
383
+ intelligencePct = Math.max(fromPatterns, fromVectors);
384
+ }
385
+ // No fake fallback — 0% means no real learning data exists
386
+
387
+ if (learningData && learningData.sessions && learningData.sessions.total !== undefined) {
388
+ contextPct = Math.min(100, learningData.sessions.total * 5);
389
+ } else {
390
+ // Real session count only — no heuristic derivation from patterns
391
+ contextPct = learning.sessions > 0 ? Math.min(100, learning.sessions * 5) : 0;
392
+ }
393
+
394
+ // Sub-agents from file metrics (no ps aux)
395
+ let subAgents = 0;
396
+ const activityData = readJSON(path.join(CWD, '.claude-flow', 'metrics', 'swarm-activity.json'));
397
+ if (activityData && activityData.processes && activityData.processes.estimated_agents) {
398
+ subAgents = activityData.processes.estimated_agents;
399
+ }
400
+
401
+ return { memoryMB, contextPct, intelligencePct, subAgents };
402
+ }
403
+
404
+ // ADR status (count files only — don't read contents)
405
+ function getADRStatus() {
406
+ // Count actual ADR files first — compliance JSON may be stale
407
+ const adrPaths = [
408
+ path.join(CWD, 'v3', 'implementation', 'adrs'),
409
+ path.join(CWD, 'docs', 'adrs'),
410
+ path.join(CWD, '.claude-flow', 'adrs'),
411
+ ];
412
+
413
+ for (const adrPath of adrPaths) {
414
+ try {
415
+ if (fs.existsSync(adrPath)) {
416
+ const files = fs.readdirSync(adrPath).filter(f =>
417
+ f.endsWith('.md') && (f.startsWith('ADR-') || f.startsWith('adr-') || /^\\d{4}-/.test(f))
418
+ );
419
+ return { count: files.length, implemented: files.length, compliance: 0 };
420
+ }
421
+ } catch { /* ignore */ }
422
+ }
423
+
424
+ return { count: 0, implemented: 0, compliance: 0 };
425
+ }
426
+
427
+ // Hooks status (shared settings cache)
428
+ function getHooksStatus() {
429
+ let enabled = 0;
430
+ let total = 0;
431
+ const settings = getSettings();
432
+
433
+ if (settings && settings.hooks) {
434
+ for (const category of Object.keys(settings.hooks)) {
435
+ const matchers = settings.hooks[category];
436
+ if (!Array.isArray(matchers)) continue;
437
+ for (const matcher of matchers) {
438
+ const hooks = matcher && matcher.hooks;
439
+ if (Array.isArray(hooks)) {
440
+ total += hooks.length;
441
+ enabled += hooks.length;
442
+ }
443
+ }
444
+ }
445
+ }
446
+
447
+ try {
448
+ const hooksDir = path.join(CWD, '.claude', 'hooks');
449
+ if (fs.existsSync(hooksDir)) {
450
+ const hookFiles = fs.readdirSync(hooksDir).filter(f => f.endsWith('.js') || f.endsWith('.sh')).length;
451
+ total = Math.max(total, hookFiles);
452
+ enabled = Math.max(enabled, hookFiles);
453
+ }
454
+ } catch { /* ignore */ }
455
+
456
+ return { enabled, total };
457
+ }
458
+
459
+ // AgentDB stats — count real entries from all data stores
460
+ function getAgentDBStats() {
461
+ let vectorCount = 0;
462
+ let dbSizeKB = 0;
463
+ let namespaces = 0;
464
+ let hasHnsw = false;
465
+
466
+ // 1. Count real entries from auto-memory-store.json
467
+ const storePath = path.join(CWD, '.claude-flow', 'data', 'auto-memory-store.json');
468
+ const storeStat = safeStat(storePath);
469
+ if (storeStat) {
470
+ dbSizeKB += storeStat.size / 1024;
471
+ try {
472
+ const store = JSON.parse(fs.readFileSync(storePath, 'utf-8'));
473
+ if (Array.isArray(store)) vectorCount += store.length;
474
+ else if (store && store.entries) vectorCount += store.entries.length;
475
+ } catch { /* fall back */ }
476
+ }
477
+
478
+ // 2. Count entries from hooks memory store (.claude-flow/memory/store.json)
479
+ const hooksStorePath = path.join(CWD, '.claude-flow', 'memory', 'store.json');
480
+ const hooksStoreStat = safeStat(hooksStorePath);
481
+ if (hooksStoreStat) {
482
+ dbSizeKB += hooksStoreStat.size / 1024;
483
+ try {
484
+ const store = JSON.parse(fs.readFileSync(hooksStorePath, 'utf-8'));
485
+ if (store && store.entries) {
486
+ const entryCount = Object.keys(store.entries).length;
487
+ vectorCount = Math.max(vectorCount, entryCount);
488
+ if (entryCount > 0) namespaces++;
489
+ }
490
+ } catch { /* fall back */ }
491
+ }
492
+
493
+ // 3. Count entries from ranked-context.json
494
+ try {
495
+ const ranked = readJSON(path.join(CWD, '.claude-flow', 'data', 'ranked-context.json'));
496
+ if (ranked && ranked.entries && ranked.entries.length > vectorCount) vectorCount = ranked.entries.length;
497
+ } catch { /* ignore */ }
498
+
499
+ // 3. Add DB file sizes
500
+ const dbFiles = [
501
+ path.join(CWD, 'data', 'memory.db'),
502
+ path.join(CWD, '.claude-flow', 'memory.db'),
503
+ path.join(CWD, '.swarm', 'memory.db'),
504
+ ];
505
+ for (const f of dbFiles) {
506
+ const stat = safeStat(f);
507
+ if (stat) {
508
+ dbSizeKB += stat.size / 1024;
509
+ namespaces++;
510
+ }
511
+ }
512
+
513
+ // 4. Graph data size
514
+ const graphStat = safeStat(path.join(CWD, 'data', 'memory.graph'));
515
+ if (graphStat) dbSizeKB += graphStat.size / 1024;
516
+
517
+ // 5. HNSW index or memory package
518
+ const hnswPaths = [
519
+ path.join(CWD, '.swarm', 'hnsw.index'),
520
+ path.join(CWD, '.claude-flow', 'hnsw.index'),
521
+ ];
522
+ for (const p of hnswPaths) {
523
+ if (safeStat(p)) { hasHnsw = true; break; }
524
+ }
525
+ if (!hasHnsw) {
526
+ const memPkgPaths = [
527
+ path.join(CWD, 'v3', '@claude-flow', 'memory', 'dist'),
528
+ path.join(CWD, 'node_modules', '@claude-flow', 'memory'),
529
+ ];
530
+ for (const p of memPkgPaths) {
531
+ if (fs.existsSync(p)) { hasHnsw = true; break; }
532
+ }
533
+ }
534
+
535
+ return { vectorCount, dbSizeKB: Math.floor(dbSizeKB), namespaces, hasHnsw };
536
+ }
537
+
538
+ // Test stats (count files only — NO reading file contents)
539
+ function getTestStats() {
540
+ let testFiles = 0;
541
+
542
+ function countTestFiles(dir, depth) {
543
+ if (depth === undefined) depth = 0;
544
+ if (depth > 6) return;
545
+ try {
546
+ if (!fs.existsSync(dir)) return;
547
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
548
+ for (const entry of entries) {
549
+ if (entry.isDirectory() && !entry.name.startsWith('.') && entry.name !== 'node_modules') {
550
+ countTestFiles(path.join(dir, entry.name), depth + 1);
551
+ } else if (entry.isFile()) {
552
+ const n = entry.name;
553
+ if (n.includes('.test.') || n.includes('.spec.') || n.includes('_test.') || n.includes('_spec.')) {
554
+ testFiles++;
555
+ }
556
+ }
557
+ }
558
+ } catch { /* ignore */ }
559
+ }
560
+
561
+ var testDirNames = ['tests', 'test', '__tests__', 'src', 'v3'];
562
+ for (var i = 0; i < testDirNames.length; i++) {
563
+ countTestFiles(path.join(CWD, testDirNames[i]));
564
+ }
565
+
566
+ return { testFiles, testCases: testFiles * 4 };
567
+ }
568
+
569
+ // Integration status (shared settings + file checks)
570
+ function getIntegrationStatus() {
571
+ const mcpServers = { total: 0, enabled: 0 };
572
+ const settings = getSettings();
573
+
574
+ if (settings && settings.mcpServers && typeof settings.mcpServers === 'object') {
575
+ const servers = Object.keys(settings.mcpServers);
576
+ mcpServers.total = servers.length;
577
+ mcpServers.enabled = settings.enabledMcpjsonServers
578
+ ? settings.enabledMcpjsonServers.filter(s => servers.includes(s)).length
579
+ : servers.length;
580
+ }
581
+
582
+ if (mcpServers.total === 0) {
583
+ const mcpConfig = readJSON(path.join(CWD, '.mcp.json'))
584
+ || readJSON(path.join(os.homedir(), '.claude', 'mcp.json'));
585
+ if (mcpConfig && mcpConfig.mcpServers) {
586
+ const s = Object.keys(mcpConfig.mcpServers);
587
+ mcpServers.total = s.length;
588
+ mcpServers.enabled = s.length;
589
+ }
590
+ }
591
+
592
+ const hasDatabase = ['.swarm/memory.db', '.claude-flow/memory.db', 'data/memory.db']
593
+ .some(p => fs.existsSync(path.join(CWD, p)));
594
+ const hasApi = !!(process.env.ANTHROPIC_API_KEY || process.env.OPENAI_API_KEY);
595
+
596
+ return { mcpServers, hasDatabase, hasApi };
597
+ }
598
+
599
+ // Session stats (pure file reads)
600
+ function getSessionStats() {
601
+ var sessionPaths = ['.claude-flow/session.json', '.claude/session.json'];
602
+ for (var i = 0; i < sessionPaths.length; i++) {
603
+ const data = readJSON(path.join(CWD, sessionPaths[i]));
604
+ if (data && data.startTime) {
605
+ const diffMs = Date.now() - new Date(data.startTime).getTime();
606
+ const mins = Math.floor(diffMs / 60000);
607
+ const duration = mins < 60 ? mins + 'm' : Math.floor(mins / 60) + 'h' + (mins % 60) + 'm';
608
+ return { duration: duration };
609
+ }
610
+ }
611
+ return { duration: '' };
612
+ }
613
+
614
+ // ─── Rendering ──────────────────────────────────────────────────
615
+
616
+ function progressBar(current, total) {
617
+ const width = 5;
618
+ const filled = Math.round((current / total) * width);
619
+ return '[' + '\\u25CF'.repeat(filled) + '\\u25CB'.repeat(width - filled) + ']';
620
+ }
621
+
622
+ function generateStatusline() {
623
+ const git = getGitInfo();
624
+ // Prefer model name from Claude Code stdin data, fallback to file-based detection
625
+ const modelName = getModelFromStdin() || getModelName();
626
+ const ctxInfo = getContextFromStdin();
627
+ const costInfo = getCostFromStdin();
628
+ const progress = getV3Progress();
629
+ const security = getSecurityStatus();
630
+ const swarm = getSwarmStatus();
631
+ const system = getSystemMetrics();
632
+ const adrs = getADRStatus();
633
+ const hooks = getHooksStatus();
634
+ const agentdb = getAgentDBStats();
635
+ const tests = getTestStats();
636
+ const session = getSessionStats();
637
+ const integration = getIntegrationStatus();
638
+ const lines = [];
639
+
640
+ // Header
641
+ // Read version from package.json
642
+ let pkgVersion = '3.6';
643
+ try {
644
+ const pkgPath = path.join(CWD, 'node_modules', '@claude-flow', 'cli', 'package.json');
645
+ if (fs.existsSync(pkgPath)) {
646
+ const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8'));
647
+ if (pkg.version) pkgVersion = pkg.version;
648
+ } else {
649
+ // Try npx-installed location
650
+ const npxPkg = path.join(CWD, 'v3', '@claude-flow', 'cli', 'package.json');
651
+ if (fs.existsSync(npxPkg)) {
652
+ const pkg = JSON.parse(fs.readFileSync(npxPkg, 'utf-8'));
653
+ if (pkg.version) pkgVersion = pkg.version;
654
+ }
655
+ }
656
+ } catch { /* use default */ }
657
+ let header = c.bold + c.brightPurple + '\\u258A RuFlo V' + pkgVersion + ' ' + c.reset;
658
+ header += (swarm.coordinationActive ? c.brightCyan : c.dim) + '\\u25CF ' + c.brightCyan + git.name + c.reset;
659
+ if (git.gitBranch) {
660
+ header += ' ' + c.dim + '\\u2502' + c.reset + ' ' + c.brightBlue + '\\u23C7 ' + git.gitBranch + c.reset;
661
+ const changes = git.modified + git.staged + git.untracked;
662
+ if (changes > 0) {
663
+ let ind = '';
664
+ if (git.staged > 0) ind += c.brightGreen + '+' + git.staged + c.reset;
665
+ if (git.modified > 0) ind += c.brightYellow + '~' + git.modified + c.reset;
666
+ if (git.untracked > 0) ind += c.dim + '?' + git.untracked + c.reset;
667
+ header += ' ' + ind;
668
+ }
669
+ if (git.ahead > 0) header += ' ' + c.brightGreen + '\\u2191' + git.ahead + c.reset;
670
+ if (git.behind > 0) header += ' ' + c.brightRed + '\\u2193' + git.behind + c.reset;
671
+ }
672
+ header += ' ' + c.dim + '\\u2502' + c.reset + ' ' + c.purple + modelName + c.reset;
673
+ // Show session duration from Claude Code stdin if available, else from local files
674
+ const duration = costInfo ? costInfo.duration : session.duration;
675
+ if (duration) header += ' ' + c.dim + '\\u2502' + c.reset + ' ' + c.cyan + '\\u23F1 ' + duration + c.reset;
676
+ // Show context usage from Claude Code stdin if available
677
+ if (ctxInfo && ctxInfo.usedPct > 0) {
678
+ const ctxColor = ctxInfo.usedPct >= 90 ? c.brightRed : ctxInfo.usedPct >= 70 ? c.brightYellow : c.brightGreen;
679
+ header += ' ' + c.dim + '\\u2502' + c.reset + ' ' + ctxColor + '\\u25CF ' + ctxInfo.usedPct + '% ctx' + c.reset;
680
+ }
681
+ // Show cost from Claude Code stdin if available
682
+ if (costInfo && costInfo.costUsd > 0) {
683
+ header += ' ' + c.dim + '\\u2502' + c.reset + ' ' + c.brightYellow + '$' + costInfo.costUsd.toFixed(2) + c.reset;
684
+ }
685
+ lines.push(header);
686
+
687
+ // Separator
688
+ lines.push(c.dim + '\\u2500'.repeat(53) + c.reset);
689
+
690
+ // Line 1: DDD Domains
691
+ const domainsColor = progress.domainsCompleted >= 3 ? c.brightGreen : progress.domainsCompleted > 0 ? c.yellow : c.red;
692
+ let perfIndicator;
693
+ if (agentdb.hasHnsw && agentdb.vectorCount > 0) {
694
+ const speedup = agentdb.vectorCount > 10000 ? '12500x' : agentdb.vectorCount > 1000 ? '150x' : '10x';
695
+ perfIndicator = c.brightGreen + '\\u26A1 HNSW ' + speedup + c.reset;
696
+ } else if (progress.patternsLearned > 0) {
697
+ const pk = progress.patternsLearned >= 1000 ? (progress.patternsLearned / 1000).toFixed(1) + 'k' : String(progress.patternsLearned);
698
+ perfIndicator = c.brightYellow + '\\uD83D\\uDCDA ' + pk + ' patterns' + c.reset;
699
+ } else {
700
+ perfIndicator = c.dim + '\\u26A1 target: 150x-12500x' + c.reset;
701
+ }
702
+ lines.push(
703
+ c.brightCyan + '\\uD83C\\uDFD7\\uFE0F DDD Domains' + c.reset + ' ' + progressBar(progress.domainsCompleted, progress.totalDomains) + ' ' +
704
+ domainsColor + progress.domainsCompleted + c.reset + '/' + c.brightWhite + progress.totalDomains + c.reset + ' ' + perfIndicator
705
+ );
706
+
707
+ // Line 2: Swarm + Hooks + CVE + Memory + Intelligence
708
+ const swarmInd = swarm.coordinationActive ? c.brightGreen + '\\u25C9' + c.reset : c.dim + '\\u25CB' + c.reset;
709
+ const agentsColor = swarm.activeAgents > 0 ? c.brightGreen : c.red;
710
+ const secIcon = security.status === 'CLEAN' ? '\\uD83D\\uDFE2' : (security.status === 'IN_PROGRESS' || security.status === 'STALE') ? '\\uD83D\\uDFE1' : (security.status === 'NONE' ? '\\u26AA' : '\\uD83D\\uDD34');
711
+ const secColor = security.status === 'CLEAN' ? c.brightGreen : (security.status === 'IN_PROGRESS' || security.status === 'STALE') ? c.brightYellow : (security.status === 'NONE' ? c.dim : c.brightRed);
712
+ const hooksColor = hooks.enabled > 0 ? c.brightGreen : c.dim;
713
+ const intellColor = system.intelligencePct >= 80 ? c.brightGreen : system.intelligencePct >= 40 ? c.brightYellow : c.dim;
714
+
715
+ lines.push(
716
+ c.brightYellow + '\\uD83E\\uDD16 Swarm' + c.reset + ' ' + swarmInd + ' [' + agentsColor + String(swarm.activeAgents).padStart(2) + c.reset + '/' + c.brightWhite + swarm.maxAgents + c.reset + '] ' +
717
+ c.brightPurple + '\\uD83D\\uDC65 ' + system.subAgents + c.reset + ' ' +
718
+ c.brightBlue + '\\uD83E\\uDE9D ' + hooksColor + hooks.enabled + c.reset + '/' + c.brightWhite + hooks.total + c.reset + ' ' +
719
+ secIcon + ' ' + secColor + 'CVE ' + security.cvesFixed + c.reset + '/' + c.brightWhite + security.totalCves + c.reset + ' ' +
720
+ c.brightCyan + '\\uD83D\\uDCBE ' + system.memoryMB + 'MB' + c.reset + ' ' +
721
+ intellColor + '\\uD83E\\uDDE0 ' + String(system.intelligencePct).padStart(3) + '%' + c.reset
722
+ );
723
+
724
+ // Line 3: Architecture
725
+ const dddColor = progress.dddProgress >= 50 ? c.brightGreen : progress.dddProgress > 0 ? c.yellow : c.red;
726
+ const adrColor = adrs.count > 0 ? (adrs.implemented === adrs.count ? c.brightGreen : c.yellow) : c.dim;
727
+ const adrDisplay = adrs.compliance > 0 ? adrColor + '\\u25CF' + adrs.compliance + '%' + c.reset : adrColor + '\\u25CF' + adrs.implemented + '/' + adrs.count + c.reset;
728
+
729
+ lines.push(
730
+ c.brightPurple + '\\uD83D\\uDD27 Architecture' + c.reset + ' ' +
731
+ c.cyan + 'ADRs' + c.reset + ' ' + adrDisplay + ' ' + c.dim + '\\u2502' + c.reset + ' ' +
732
+ c.cyan + 'DDD' + c.reset + ' ' + dddColor + '\\u25CF' + String(progress.dddProgress).padStart(3) + '%' + c.reset + ' ' + c.dim + '\\u2502' + c.reset + ' ' +
733
+ c.cyan + 'Security' + c.reset + ' ' + secColor + '\\u25CF' + security.status + c.reset
734
+ );
735
+
736
+ // Line 4: AgentDB, Tests, Integration
737
+ const hnswInd = agentdb.hasHnsw ? c.brightGreen + '\\u26A1' + c.reset : '';
738
+ const sizeDisp = agentdb.dbSizeKB >= 1024 ? (agentdb.dbSizeKB / 1024).toFixed(1) + 'MB' : agentdb.dbSizeKB + 'KB';
739
+ const vectorColor = agentdb.vectorCount > 0 ? c.brightGreen : c.dim;
740
+ const testColor = tests.testFiles > 0 ? c.brightGreen : c.dim;
741
+
742
+ let integStr = '';
743
+ if (integration.mcpServers.total > 0) {
744
+ const mcpCol = integration.mcpServers.enabled === integration.mcpServers.total ? c.brightGreen :
745
+ integration.mcpServers.enabled > 0 ? c.brightYellow : c.red;
746
+ integStr += c.cyan + 'MCP' + c.reset + ' ' + mcpCol + '\\u25CF' + integration.mcpServers.enabled + '/' + integration.mcpServers.total + c.reset;
747
+ }
748
+ if (integration.hasDatabase) integStr += (integStr ? ' ' : '') + c.brightGreen + '\\u25C6' + c.reset + 'DB';
749
+ if (integration.hasApi) integStr += (integStr ? ' ' : '') + c.brightGreen + '\\u25C6' + c.reset + 'API';
750
+ if (!integStr) integStr = c.dim + '\\u25CF none' + c.reset;
751
+
752
+ lines.push(
753
+ c.brightCyan + '\\uD83D\\uDCCA AgentDB' + c.reset + ' ' +
754
+ c.cyan + 'Vectors' + c.reset + ' ' + vectorColor + '\\u25CF' + agentdb.vectorCount + hnswInd + c.reset + ' ' + c.dim + '\\u2502' + c.reset + ' ' +
755
+ c.cyan + 'Size' + c.reset + ' ' + c.brightWhite + sizeDisp + c.reset + ' ' + c.dim + '\\u2502' + c.reset + ' ' +
756
+ c.cyan + 'Tests' + c.reset + ' ' + testColor + '\\u25CF' + tests.testFiles + c.reset + ' ' + c.dim + '(~' + tests.testCases + ' cases)' + c.reset + ' ' + c.dim + '\\u2502' + c.reset + ' ' +
757
+ integStr
758
+ );
759
+
760
+ return lines.join('\\n');
761
+ }
762
+
763
+ // JSON output
764
+ function generateJSON() {
765
+ const git = getGitInfo();
766
+ return {
767
+ user: { name: git.name, gitBranch: git.gitBranch, modelName: getModelName() },
768
+ v3Progress: getV3Progress(),
769
+ security: getSecurityStatus(),
770
+ swarm: getSwarmStatus(),
771
+ system: getSystemMetrics(),
772
+ adrs: getADRStatus(),
773
+ hooks: getHooksStatus(),
774
+ agentdb: getAgentDBStats(),
775
+ tests: getTestStats(),
776
+ git: { modified: git.modified, untracked: git.untracked, staged: git.staged, ahead: git.ahead, behind: git.behind },
777
+ lastUpdated: new Date().toISOString(),
778
+ };
779
+ }
780
+
781
+ // ─── Stdin reader (Claude Code pipes session JSON) ──────────────
782
+
783
+ // Claude Code sends session JSON via stdin (model, context, cost, etc.)
784
+ // Read it synchronously so the script works both:
785
+ // 1. When invoked by Claude Code (stdin has JSON)
786
+ // 2. When invoked manually from terminal (stdin is empty/tty)
787
+ let _stdinData = null;
788
+ function getStdinData() {
789
+ if (_stdinData !== undefined && _stdinData !== null) return _stdinData;
790
+ try {
791
+ // Check if stdin is a TTY (manual run) — skip reading
792
+ if (process.stdin.isTTY) { _stdinData = null; return null; }
793
+ // Read stdin synchronously via fd 0
794
+ const chunks = [];
795
+ const buf = Buffer.alloc(4096);
796
+ let bytesRead;
797
+ try {
798
+ while ((bytesRead = fs.readSync(0, buf, 0, buf.length, null)) > 0) {
799
+ chunks.push(buf.slice(0, bytesRead));
800
+ }
801
+ } catch { /* EOF or read error */ }
802
+ const raw = Buffer.concat(chunks).toString('utf-8').trim();
803
+ if (raw && raw.startsWith('{')) {
804
+ _stdinData = JSON.parse(raw);
805
+ } else {
806
+ _stdinData = null;
807
+ }
808
+ } catch {
809
+ _stdinData = null;
810
+ }
811
+ return _stdinData;
812
+ }
813
+
814
+ // Override model detection to prefer stdin data from Claude Code
815
+ function getModelFromStdin() {
816
+ const data = getStdinData();
817
+ if (data && data.model && data.model.display_name) return data.model.display_name;
818
+ return null;
819
+ }
820
+
821
+ // Get context window info from Claude Code session
822
+ function getContextFromStdin() {
823
+ const data = getStdinData();
824
+ if (data && data.context_window) {
825
+ return {
826
+ usedPct: Math.floor(data.context_window.used_percentage || 0),
827
+ remainingPct: Math.floor(data.context_window.remaining_percentage || 100),
828
+ };
829
+ }
830
+ return null;
831
+ }
832
+
833
+ // Get cost info from Claude Code session
834
+ function getCostFromStdin() {
835
+ const data = getStdinData();
836
+ if (data && data.cost) {
837
+ const durationMs = data.cost.total_duration_ms || 0;
838
+ const mins = Math.floor(durationMs / 60000);
839
+ const secs = Math.floor((durationMs % 60000) / 1000);
840
+ return {
841
+ costUsd: data.cost.total_cost_usd || 0,
842
+ duration: mins > 0 ? mins + 'm' + secs + 's' : secs + 's',
843
+ linesAdded: data.cost.total_lines_added || 0,
844
+ linesRemoved: data.cost.total_lines_removed || 0,
845
+ };
846
+ }
847
+ return null;
848
+ }
849
+
850
+ // ─── Main ───────────────────────────────────────────────────────
851
+ if (process.argv.includes('--json')) {
852
+ console.log(JSON.stringify(generateJSON(), null, 2));
853
+ } else if (process.argv.includes('--compact')) {
854
+ console.log(JSON.stringify(generateJSON()));
855
+ } else {
856
+ console.log(generateStatusline());
857
+ }
858
858
  `;
859
859
  }
860
860
  /**
@@ -864,30 +864,30 @@ export function generateStatuslineHook(options) {
864
864
  if (!options.statusline.enabled) {
865
865
  return '#!/bin/bash\n# Statusline disabled\n';
866
866
  }
867
- return `#!/bin/bash
868
- # RuFlo V3 Statusline Hook
869
- # Source this in your .bashrc/.zshrc for terminal statusline
870
-
871
- # Function to get statusline
872
- claude_flow_statusline() {
873
- local statusline_script="\${CLAUDE_FLOW_DIR:-.claude}/helpers/statusline.cjs"
874
- if [ -f "$statusline_script" ]; then
875
- node "$statusline_script" 2>/dev/null || echo ""
876
- fi
877
- }
878
-
879
- # Bash: Add to PS1
880
- # export PS1='$(claude_flow_statusline) \\n\\$ '
881
-
882
- # Zsh: Add to RPROMPT
883
- # export RPROMPT='$(claude_flow_statusline)'
884
-
885
- # Claude Code: Add to .claude/settings.json
886
- # "statusLine": {
887
- # "type": "command",
888
- # "command": "node .claude/helpers/statusline.cjs 2>/dev/null"
889
- # "when": "test -f .claude/helpers/statusline.cjs"
890
- # }
867
+ return `#!/bin/bash
868
+ # RuFlo V3 Statusline Hook
869
+ # Source this in your .bashrc/.zshrc for terminal statusline
870
+
871
+ # Function to get statusline
872
+ claude_flow_statusline() {
873
+ local statusline_script="\${CLAUDE_FLOW_DIR:-.claude}/helpers/statusline.cjs"
874
+ if [ -f "$statusline_script" ]; then
875
+ node "$statusline_script" 2>/dev/null || echo ""
876
+ fi
877
+ }
878
+
879
+ # Bash: Add to PS1
880
+ # export PS1='$(claude_flow_statusline) \\n\\$ '
881
+
882
+ # Zsh: Add to RPROMPT
883
+ # export RPROMPT='$(claude_flow_statusline)'
884
+
885
+ # Claude Code: Add to .claude/settings.json
886
+ # "statusLine": {
887
+ # "type": "command",
888
+ # "command": "node .claude/helpers/statusline.cjs 2>/dev/null"
889
+ # "when": "test -f .claude/helpers/statusline.cjs"
890
+ # }
891
891
  `;
892
892
  }
893
893
  //# sourceMappingURL=statusline-generator.js.map