moflo 4.8.24 → 4.8.26

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 (260) hide show
  1. package/.claude/agents/browser/browser-agent.yaml +182 -182
  2. package/.claude/agents/core/coder.md +265 -265
  3. package/.claude/agents/core/planner.md +167 -167
  4. package/.claude/agents/core/researcher.md +189 -189
  5. package/.claude/agents/core/reviewer.md +325 -325
  6. package/.claude/agents/core/tester.md +318 -318
  7. package/.claude/agents/database-specialist.yaml +21 -21
  8. package/.claude/agents/dual-mode/codex-coordinator.md +224 -224
  9. package/.claude/agents/dual-mode/codex-worker.md +211 -211
  10. package/.claude/agents/dual-mode/dual-orchestrator.md +291 -291
  11. package/.claude/agents/github/code-review-swarm.md +537 -537
  12. package/.claude/agents/github/github-modes.md +172 -172
  13. package/.claude/agents/github/issue-tracker.md +318 -318
  14. package/.claude/agents/github/multi-repo-swarm.md +552 -552
  15. package/.claude/agents/github/pr-manager.md +190 -190
  16. package/.claude/agents/github/project-board-sync.md +508 -508
  17. package/.claude/agents/github/release-manager.md +366 -366
  18. package/.claude/agents/github/release-swarm.md +582 -582
  19. package/.claude/agents/github/repo-architect.md +397 -397
  20. package/.claude/agents/github/swarm-issue.md +572 -572
  21. package/.claude/agents/github/swarm-pr.md +427 -427
  22. package/.claude/agents/github/sync-coordinator.md +451 -451
  23. package/.claude/agents/github/workflow-automation.md +634 -634
  24. package/.claude/agents/goal/code-goal-planner.md +445 -445
  25. package/.claude/agents/hive-mind/collective-intelligence-coordinator.md +129 -129
  26. package/.claude/agents/hive-mind/queen-coordinator.md +202 -202
  27. package/.claude/agents/hive-mind/scout-explorer.md +241 -241
  28. package/.claude/agents/hive-mind/swarm-memory-manager.md +192 -192
  29. package/.claude/agents/hive-mind/worker-specialist.md +216 -216
  30. package/.claude/agents/index.yaml +17 -17
  31. package/.claude/agents/neural/safla-neural.md +73 -73
  32. package/.claude/agents/project-coordinator.yaml +15 -15
  33. package/.claude/agents/python-specialist.yaml +21 -21
  34. package/.claude/agents/reasoning/goal-planner.md +72 -72
  35. package/.claude/agents/security-auditor.yaml +20 -20
  36. package/.claude/agents/swarm/adaptive-coordinator.md +395 -395
  37. package/.claude/agents/swarm/hierarchical-coordinator.md +326 -326
  38. package/.claude/agents/swarm/mesh-coordinator.md +391 -391
  39. package/.claude/agents/templates/migration-plan.md +745 -745
  40. package/.claude/agents/typescript-specialist.yaml +21 -21
  41. package/.claude/checkpoints/1767754460.json +8 -8
  42. package/.claude/commands/agents/agent-spawning.md +28 -28
  43. package/.claude/commands/github/github-modes.md +146 -146
  44. package/.claude/commands/github/github-swarm.md +121 -121
  45. package/.claude/commands/github/issue-tracker.md +291 -291
  46. package/.claude/commands/github/pr-manager.md +169 -169
  47. package/.claude/commands/github/release-manager.md +337 -337
  48. package/.claude/commands/github/repo-architect.md +366 -366
  49. package/.claude/commands/github/sync-coordinator.md +300 -300
  50. package/.claude/commands/memory/neural.md +47 -47
  51. package/.claude/commands/sparc/analyzer.md +51 -51
  52. package/.claude/commands/sparc/architect.md +53 -53
  53. package/.claude/commands/sparc/ask.md +97 -97
  54. package/.claude/commands/sparc/batch-executor.md +54 -54
  55. package/.claude/commands/sparc/code.md +89 -89
  56. package/.claude/commands/sparc/coder.md +54 -54
  57. package/.claude/commands/sparc/debug.md +83 -83
  58. package/.claude/commands/sparc/debugger.md +54 -54
  59. package/.claude/commands/sparc/designer.md +53 -53
  60. package/.claude/commands/sparc/devops.md +109 -109
  61. package/.claude/commands/sparc/docs-writer.md +80 -80
  62. package/.claude/commands/sparc/documenter.md +54 -54
  63. package/.claude/commands/sparc/innovator.md +54 -54
  64. package/.claude/commands/sparc/integration.md +83 -83
  65. package/.claude/commands/sparc/mcp.md +117 -117
  66. package/.claude/commands/sparc/memory-manager.md +54 -54
  67. package/.claude/commands/sparc/optimizer.md +54 -54
  68. package/.claude/commands/sparc/orchestrator.md +131 -131
  69. package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -83
  70. package/.claude/commands/sparc/refinement-optimization-mode.md +83 -83
  71. package/.claude/commands/sparc/researcher.md +54 -54
  72. package/.claude/commands/sparc/reviewer.md +54 -54
  73. package/.claude/commands/sparc/security-review.md +80 -80
  74. package/.claude/commands/sparc/sparc-modes.md +174 -174
  75. package/.claude/commands/sparc/sparc.md +111 -111
  76. package/.claude/commands/sparc/spec-pseudocode.md +80 -80
  77. package/.claude/commands/sparc/supabase-admin.md +348 -348
  78. package/.claude/commands/sparc/swarm-coordinator.md +54 -54
  79. package/.claude/commands/sparc/tdd.md +54 -54
  80. package/.claude/commands/sparc/tester.md +54 -54
  81. package/.claude/commands/sparc/tutorial.md +79 -79
  82. package/.claude/commands/sparc/workflow-manager.md +54 -54
  83. package/.claude/commands/sparc.md +166 -166
  84. package/.claude/commands/swarm/analysis.md +95 -95
  85. package/.claude/commands/swarm/development.md +96 -96
  86. package/.claude/commands/swarm/examples.md +168 -168
  87. package/.claude/commands/swarm/maintenance.md +102 -102
  88. package/.claude/commands/swarm/optimization.md +117 -117
  89. package/.claude/commands/swarm/research.md +136 -136
  90. package/.claude/commands/swarm/testing.md +131 -131
  91. package/.claude/commands/workflows/development.md +77 -77
  92. package/.claude/commands/workflows/research.md +62 -62
  93. package/.claude/guidance/moflo-bootstrap.md +126 -126
  94. package/.claude/guidance/shipped/agent-bootstrap.md +143 -131
  95. package/.claude/guidance/shipped/guidance-memory-strategy.md +262 -262
  96. package/.claude/guidance/shipped/memory-strategy.md +204 -204
  97. package/.claude/guidance/shipped/moflo.md +675 -668
  98. package/.claude/guidance/shipped/task-swarm-integration.md +441 -441
  99. package/.claude/helpers/intelligence.cjs +207 -207
  100. package/.claude/helpers/statusline.cjs +851 -851
  101. package/.claude/skills/fl/SKILL.md +583 -583
  102. package/.claude/skills/flo/SKILL.md +583 -583
  103. package/.claude/skills/github-code-review/SKILL.md +1140 -1140
  104. package/.claude/skills/github-multi-repo/SKILL.md +874 -874
  105. package/.claude/skills/github-project-management/SKILL.md +1277 -1277
  106. package/.claude/skills/github-release-management/SKILL.md +1081 -1081
  107. package/.claude/skills/github-workflow-automation/SKILL.md +1065 -1065
  108. package/.claude/skills/hive-mind-advanced/SKILL.md +712 -712
  109. package/.claude/skills/hooks-automation/SKILL.md +1201 -1201
  110. package/.claude/skills/performance-analysis/SKILL.md +563 -563
  111. package/.claude/skills/sparc-methodology/SKILL.md +1115 -1115
  112. package/.claude/skills/swarm-advanced/SKILL.md +973 -973
  113. package/.claude/workflow-state.json +5 -5
  114. package/LICENSE +21 -21
  115. package/README.md +685 -698
  116. package/bin/cli.js +0 -0
  117. package/bin/gate-hook.mjs +50 -50
  118. package/bin/gate.cjs +138 -138
  119. package/bin/generate-code-map.mjs +937 -775
  120. package/bin/hook-handler.cjs +83 -83
  121. package/bin/hooks.mjs +696 -656
  122. package/bin/index-guidance.mjs +892 -892
  123. package/bin/index-tests.mjs +709 -709
  124. package/bin/lib/process-manager.mjs +256 -243
  125. package/bin/lib/registry-cleanup.cjs +41 -41
  126. package/bin/prompt-hook.mjs +72 -72
  127. package/bin/semantic-search.mjs +472 -472
  128. package/bin/session-start-launcher.mjs +238 -238
  129. package/bin/setup-project.mjs +250 -252
  130. package/package.json +123 -123
  131. package/src/@claude-flow/cli/README.md +452 -452
  132. package/src/@claude-flow/cli/bin/cli.js +180 -180
  133. package/src/@claude-flow/cli/bin/preinstall.cjs +2 -2
  134. package/src/@claude-flow/cli/dist/src/commands/completions.js +409 -409
  135. package/src/@claude-flow/cli/dist/src/commands/doctor.js +2 -18
  136. package/src/@claude-flow/cli/dist/src/commands/embeddings.js +25 -25
  137. package/src/@claude-flow/cli/dist/src/commands/github.js +61 -61
  138. package/src/@claude-flow/cli/dist/src/commands/hive-mind.js +90 -90
  139. package/src/@claude-flow/cli/dist/src/commands/hooks.js +9 -9
  140. package/src/@claude-flow/cli/dist/src/commands/init.js +8 -3
  141. package/src/@claude-flow/cli/dist/src/commands/ruvector/import.js +14 -14
  142. package/src/@claude-flow/cli/dist/src/commands/ruvector/setup.js +624 -624
  143. package/src/@claude-flow/cli/dist/src/config/moflo-config.d.ts +0 -3
  144. package/src/@claude-flow/cli/dist/src/config/moflo-config.js +91 -101
  145. package/src/@claude-flow/cli/dist/src/index.d.ts +0 -5
  146. package/src/@claude-flow/cli/dist/src/index.js +0 -44
  147. package/src/@claude-flow/cli/dist/src/init/claudemd-generator.d.ts +29 -29
  148. package/src/@claude-flow/cli/dist/src/init/claudemd-generator.js +43 -45
  149. package/src/@claude-flow/cli/dist/src/init/executor.js +453 -453
  150. package/src/@claude-flow/cli/dist/src/init/helpers-generator.js +482 -482
  151. package/src/@claude-flow/cli/dist/src/init/moflo-init.d.ts +30 -30
  152. package/src/@claude-flow/cli/dist/src/init/moflo-init.js +144 -200
  153. package/src/@claude-flow/cli/dist/src/init/statusline-generator.js +876 -876
  154. package/src/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.js +11 -5
  155. package/src/@claude-flow/cli/dist/src/memory/memory-initializer.js +371 -371
  156. package/src/@claude-flow/cli/dist/src/runtime/headless.js +28 -28
  157. package/src/@claude-flow/cli/dist/src/services/daemon-lock.d.ts +0 -14
  158. package/src/@claude-flow/cli/dist/src/services/daemon-lock.js +1 -1
  159. package/src/@claude-flow/cli/dist/src/services/headless-worker-executor.js +84 -84
  160. package/src/@claude-flow/cli/package.json +1 -1
  161. package/src/@claude-flow/guidance/README.md +1195 -1195
  162. package/src/@claude-flow/guidance/package.json +198 -198
  163. package/src/@claude-flow/memory/README.md +587 -587
  164. package/src/@claude-flow/memory/dist/agentdb-backend.js +26 -26
  165. package/src/@claude-flow/memory/dist/auto-memory-bridge.test.js +27 -27
  166. package/src/@claude-flow/memory/dist/sqljs-backend.js +26 -26
  167. package/src/@claude-flow/memory/package.json +44 -44
  168. package/src/@claude-flow/shared/README.md +323 -323
  169. package/src/@claude-flow/shared/dist/events/event-store.js +31 -31
  170. package/src/README.md +493 -493
  171. package/.claude/agents/flow-nexus/app-store.md +0 -88
  172. package/.claude/agents/flow-nexus/authentication.md +0 -69
  173. package/.claude/agents/flow-nexus/challenges.md +0 -81
  174. package/.claude/agents/flow-nexus/neural-network.md +0 -88
  175. package/.claude/agents/flow-nexus/payments.md +0 -83
  176. package/.claude/agents/flow-nexus/sandbox.md +0 -76
  177. package/.claude/agents/flow-nexus/swarm.md +0 -76
  178. package/.claude/agents/flow-nexus/user-tools.md +0 -96
  179. package/.claude/agents/flow-nexus/workflow.md +0 -84
  180. package/.claude/agents/payments/agentic-payments.md +0 -126
  181. package/.claude/agents/sona/sona-learning-optimizer.md +0 -74
  182. package/.claude/agents/sublinear/consensus-coordinator.md +0 -338
  183. package/.claude/agents/sublinear/matrix-optimizer.md +0 -185
  184. package/.claude/agents/sublinear/pagerank-analyzer.md +0 -299
  185. package/.claude/agents/sublinear/performance-optimizer.md +0 -368
  186. package/.claude/agents/sublinear/trading-predictor.md +0 -246
  187. package/.claude/agents/v3/adr-architect.md +0 -184
  188. package/.claude/agents/v3/aidefence-guardian.md +0 -282
  189. package/.claude/agents/v3/claims-authorizer.md +0 -208
  190. package/.claude/agents/v3/collective-intelligence-coordinator.md +0 -993
  191. package/.claude/agents/v3/ddd-domain-expert.md +0 -220
  192. package/.claude/agents/v3/injection-analyst.md +0 -236
  193. package/.claude/agents/v3/memory-specialist.md +0 -995
  194. package/.claude/agents/v3/performance-engineer.md +0 -1233
  195. package/.claude/agents/v3/pii-detector.md +0 -151
  196. package/.claude/agents/v3/reasoningbank-learner.md +0 -213
  197. package/.claude/agents/v3/security-architect-aidefence.md +0 -410
  198. package/.claude/agents/v3/security-architect.md +0 -867
  199. package/.claude/agents/v3/security-auditor.md +0 -771
  200. package/.claude/agents/v3/sparc-orchestrator.md +0 -182
  201. package/.claude/agents/v3/swarm-memory-manager.md +0 -157
  202. package/.claude/agents/v3/v3-integration-architect.md +0 -205
  203. package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +0 -54
  204. package/.claude/commands/analysis/README.md +0 -9
  205. package/.claude/commands/analysis/bottleneck-detect.md +0 -162
  206. package/.claude/commands/analysis/performance-bottlenecks.md +0 -59
  207. package/.claude/commands/analysis/performance-report.md +0 -25
  208. package/.claude/commands/analysis/token-efficiency.md +0 -45
  209. package/.claude/commands/analysis/token-usage.md +0 -25
  210. package/.claude/commands/automation/README.md +0 -9
  211. package/.claude/commands/automation/auto-agent.md +0 -122
  212. package/.claude/commands/automation/self-healing.md +0 -106
  213. package/.claude/commands/automation/session-memory.md +0 -90
  214. package/.claude/commands/automation/smart-agents.md +0 -73
  215. package/.claude/commands/automation/smart-spawn.md +0 -25
  216. package/.claude/commands/automation/workflow-select.md +0 -25
  217. package/.claude/commands/monitoring/README.md +0 -9
  218. package/.claude/commands/monitoring/agent-metrics.md +0 -25
  219. package/.claude/commands/monitoring/agents.md +0 -44
  220. package/.claude/commands/monitoring/real-time-view.md +0 -25
  221. package/.claude/commands/monitoring/status.md +0 -46
  222. package/.claude/commands/monitoring/swarm-monitor.md +0 -25
  223. package/.claude/commands/optimization/README.md +0 -9
  224. package/.claude/commands/optimization/auto-topology.md +0 -62
  225. package/.claude/commands/optimization/cache-manage.md +0 -25
  226. package/.claude/commands/optimization/parallel-execute.md +0 -25
  227. package/.claude/commands/optimization/parallel-execution.md +0 -50
  228. package/.claude/commands/optimization/topology-optimize.md +0 -25
  229. package/.claude/guidance/shipped/task-icons.md +0 -42
  230. package/.claude/helpers/gate-hook.mjs +0 -50
  231. package/.claude/helpers/gate.cjs +0 -138
  232. package/.claude/helpers/hook-handler.cjs +0 -76
  233. package/.claude/helpers/prompt-hook.mjs +0 -72
  234. package/.claude/scripts/build-embeddings.mjs +0 -549
  235. package/.claude/scripts/generate-code-map.mjs +0 -776
  236. package/.claude/scripts/hooks.mjs +0 -656
  237. package/.claude/scripts/index-guidance.mjs +0 -893
  238. package/.claude/scripts/index-tests.mjs +0 -710
  239. package/.claude/scripts/semantic-search.mjs +0 -473
  240. package/.claude/scripts/session-start-launcher.mjs +0 -238
  241. package/.claude/settings.local.json +0 -18
  242. package/.claude/skills/pair-programming/SKILL.md +0 -1202
  243. package/.claude/skills/stream-chain/SKILL.md +0 -563
  244. package/.claude/skills/v3-cli-modernization/SKILL.md +0 -872
  245. package/.claude/skills/v3-core-implementation/SKILL.md +0 -797
  246. package/.claude/skills/v3-ddd-architecture/SKILL.md +0 -442
  247. package/.claude/skills/v3-integration-deep/SKILL.md +0 -241
  248. package/.claude/skills/v3-mcp-optimization/SKILL.md +0 -777
  249. package/.claude/skills/v3-memory-unification/SKILL.md +0 -174
  250. package/.claude/skills/v3-performance-optimization/SKILL.md +0 -390
  251. package/.claude/skills/v3-security-overhaul/SKILL.md +0 -82
  252. package/.claude/skills/v3-swarm-coordination/SKILL.md +0 -340
  253. package/src/@claude-flow/cli/dist/src/services/container-worker-pool.d.ts +0 -197
  254. package/src/@claude-flow/cli/dist/src/services/container-worker-pool.js +0 -584
  255. package/src/@claude-flow/memory/dist/hybrid-backend.d.ts +0 -245
  256. package/src/@claude-flow/memory/dist/hybrid-backend.js +0 -569
  257. package/src/@claude-flow/memory/dist/hybrid-backend.test.d.ts +0 -8
  258. package/src/@claude-flow/memory/dist/hybrid-backend.test.js +0 -320
  259. package/src/@claude-flow/memory/dist/sqlite-backend.d.ts +0 -121
  260. package/src/@claude-flow/memory/dist/sqlite-backend.js +0 -572
@@ -1,872 +0,0 @@
1
- ---
2
- name: "V3 CLI Modernization"
3
- description: "CLI modernization and hooks system enhancement for claude-flow v3. Implements interactive prompts, command decomposition, enhanced hooks integration, and intelligent workflow automation."
4
- ---
5
-
6
- # V3 CLI Modernization
7
-
8
- ## What This Skill Does
9
-
10
- Modernizes claude-flow v3 CLI with interactive prompts, intelligent command decomposition, enhanced hooks integration, performance optimization, and comprehensive workflow automation capabilities.
11
-
12
- ## Quick Start
13
-
14
- ```bash
15
- # Initialize CLI modernization analysis
16
- Task("CLI architecture", "Analyze current CLI structure and identify optimization opportunities", "cli-hooks-developer")
17
-
18
- # Modernization implementation (parallel)
19
- Task("Command decomposition", "Break down large CLI files into focused modules", "cli-hooks-developer")
20
- Task("Interactive prompts", "Implement intelligent interactive CLI experience", "cli-hooks-developer")
21
- Task("Hooks enhancement", "Deep integrate hooks with CLI lifecycle", "cli-hooks-developer")
22
- ```
23
-
24
- ## CLI Architecture Modernization
25
-
26
- ### Current State Analysis
27
- ```
28
- Current CLI Issues:
29
- ├── index.ts: 108KB monolithic file
30
- ├── enterprise.ts: 68KB feature module
31
- ├── Limited interactivity: Basic command parsing
32
- ├── Hooks integration: Basic pre/post execution
33
- └── No intelligent workflows: Manual command chaining
34
-
35
- Target Architecture:
36
- ├── Modular Commands: <500 lines per command
37
- ├── Interactive Prompts: Smart context-aware UX
38
- ├── Enhanced Hooks: Deep lifecycle integration
39
- ├── Workflow Automation: Intelligent command orchestration
40
- └── Performance: <200ms command response time
41
- ```
42
-
43
- ### Modular Command Architecture
44
- ```typescript
45
- // src/cli/core/command-registry.ts
46
- interface CommandModule {
47
- name: string;
48
- description: string;
49
- category: CommandCategory;
50
- handler: CommandHandler;
51
- middleware: MiddlewareStack;
52
- permissions: Permission[];
53
- examples: CommandExample[];
54
- }
55
-
56
- export class ModularCommandRegistry {
57
- private commands = new Map<string, CommandModule>();
58
- private categories = new Map<CommandCategory, CommandModule[]>();
59
- private aliases = new Map<string, string>();
60
-
61
- registerCommand(command: CommandModule): void {
62
- this.commands.set(command.name, command);
63
-
64
- // Register in category index
65
- if (!this.categories.has(command.category)) {
66
- this.categories.set(command.category, []);
67
- }
68
- this.categories.get(command.category)!.push(command);
69
- }
70
-
71
- async executeCommand(name: string, args: string[]): Promise<CommandResult> {
72
- const command = this.resolveCommand(name);
73
- if (!command) {
74
- throw new CommandNotFoundError(name, this.getSuggestions(name));
75
- }
76
-
77
- // Execute middleware stack
78
- const context = await this.buildExecutionContext(command, args);
79
- const result = await command.middleware.execute(context);
80
-
81
- return result;
82
- }
83
-
84
- private resolveCommand(name: string): CommandModule | undefined {
85
- // Try exact match first
86
- if (this.commands.has(name)) {
87
- return this.commands.get(name);
88
- }
89
-
90
- // Try alias
91
- const aliasTarget = this.aliases.get(name);
92
- if (aliasTarget) {
93
- return this.commands.get(aliasTarget);
94
- }
95
-
96
- // Try fuzzy match
97
- return this.findFuzzyMatch(name);
98
- }
99
- }
100
- ```
101
-
102
- ## Command Decomposition Strategy
103
-
104
- ### Swarm Commands Module
105
- ```typescript
106
- // src/cli/commands/swarm/swarm.command.ts
107
- @Command({
108
- name: 'swarm',
109
- description: 'Swarm coordination and management',
110
- category: 'orchestration'
111
- })
112
- export class SwarmCommand {
113
- constructor(
114
- private swarmCoordinator: UnifiedSwarmCoordinator,
115
- private promptService: InteractivePromptService
116
- ) {}
117
-
118
- @SubCommand('init')
119
- @Option('--topology', 'Swarm topology (mesh|hierarchical|adaptive)', 'hierarchical')
120
- @Option('--agents', 'Number of agents to spawn', 5)
121
- @Option('--interactive', 'Interactive agent configuration', false)
122
- async init(
123
- @Arg('projectName') projectName: string,
124
- options: SwarmInitOptions
125
- ): Promise<CommandResult> {
126
-
127
- if (options.interactive) {
128
- return this.interactiveSwarmInit(projectName);
129
- }
130
-
131
- return this.quickSwarmInit(projectName, options);
132
- }
133
-
134
- private async interactiveSwarmInit(projectName: string): Promise<CommandResult> {
135
- console.log(`🚀 Initializing Swarm for ${projectName}`);
136
-
137
- // Interactive topology selection
138
- const topology = await this.promptService.select({
139
- message: 'Select swarm topology:',
140
- choices: [
141
- { name: 'Hierarchical (Queen-led coordination)', value: 'hierarchical' },
142
- { name: 'Mesh (Peer-to-peer collaboration)', value: 'mesh' },
143
- { name: 'Adaptive (Dynamic topology switching)', value: 'adaptive' }
144
- ]
145
- });
146
-
147
- // Agent configuration
148
- const agents = await this.promptAgentConfiguration();
149
-
150
- // Initialize with configuration
151
- const swarm = await this.swarmCoordinator.initialize({
152
- name: projectName,
153
- topology,
154
- agents,
155
- hooks: {
156
- onAgentSpawn: this.handleAgentSpawn.bind(this),
157
- onTaskComplete: this.handleTaskComplete.bind(this),
158
- onSwarmComplete: this.handleSwarmComplete.bind(this)
159
- }
160
- });
161
-
162
- return CommandResult.success({
163
- message: `✅ Swarm ${projectName} initialized with ${agents.length} agents`,
164
- data: { swarmId: swarm.id, topology, agentCount: agents.length }
165
- });
166
- }
167
-
168
- @SubCommand('status')
169
- async status(): Promise<CommandResult> {
170
- const swarms = await this.swarmCoordinator.listActiveSwarms();
171
-
172
- if (swarms.length === 0) {
173
- return CommandResult.info('No active swarms found');
174
- }
175
-
176
- // Interactive swarm selection if multiple
177
- const selectedSwarm = swarms.length === 1
178
- ? swarms[0]
179
- : await this.promptService.select({
180
- message: 'Select swarm to inspect:',
181
- choices: swarms.map(s => ({
182
- name: `${s.name} (${s.agents.length} agents, ${s.topology})`,
183
- value: s
184
- }))
185
- });
186
-
187
- return this.displaySwarmStatus(selectedSwarm);
188
- }
189
- }
190
- ```
191
-
192
- ### Learning Commands Module
193
- ```typescript
194
- // src/cli/commands/learning/learning.command.ts
195
- @Command({
196
- name: 'learning',
197
- description: 'Learning system management and optimization',
198
- category: 'intelligence'
199
- })
200
- export class LearningCommand {
201
- constructor(
202
- private learningService: IntegratedLearningService,
203
- private promptService: InteractivePromptService
204
- ) {}
205
-
206
- @SubCommand('start')
207
- @Option('--algorithm', 'RL algorithm to use', 'auto')
208
- @Option('--tier', 'Learning tier (basic|standard|advanced)', 'standard')
209
- async start(options: LearningStartOptions): Promise<CommandResult> {
210
- // Auto-detect optimal algorithm if not specified
211
- if (options.algorithm === 'auto') {
212
- const taskContext = await this.analyzeCurrentContext();
213
- options.algorithm = this.learningService.selectOptimalAlgorithm(taskContext);
214
-
215
- console.log(`🧠 Auto-selected ${options.algorithm} algorithm based on context`);
216
- }
217
-
218
- const session = await this.learningService.startSession({
219
- algorithm: options.algorithm,
220
- tier: options.tier,
221
- userId: await this.getCurrentUser()
222
- });
223
-
224
- return CommandResult.success({
225
- message: `🚀 Learning session started with ${options.algorithm}`,
226
- data: { sessionId: session.id, algorithm: options.algorithm, tier: options.tier }
227
- });
228
- }
229
-
230
- @SubCommand('feedback')
231
- @Arg('reward', 'Reward value (0-1)', 'number')
232
- async feedback(
233
- @Arg('reward') reward: number,
234
- @Option('--context', 'Additional context for learning')
235
- context?: string
236
- ): Promise<CommandResult> {
237
- const activeSession = await this.learningService.getActiveSession();
238
- if (!activeSession) {
239
- return CommandResult.error('No active learning session found. Start one with `learning start`');
240
- }
241
-
242
- await this.learningService.submitFeedback({
243
- sessionId: activeSession.id,
244
- reward,
245
- context,
246
- timestamp: new Date()
247
- });
248
-
249
- return CommandResult.success({
250
- message: `📊 Feedback recorded (reward: ${reward})`,
251
- data: { reward, sessionId: activeSession.id }
252
- });
253
- }
254
-
255
- @SubCommand('metrics')
256
- async metrics(): Promise<CommandResult> {
257
- const metrics = await this.learningService.getMetrics();
258
-
259
- // Interactive metrics display
260
- await this.displayInteractiveMetrics(metrics);
261
-
262
- return CommandResult.success('Metrics displayed');
263
- }
264
- }
265
- ```
266
-
267
- ## Interactive Prompt System
268
-
269
- ### Advanced Prompt Service
270
- ```typescript
271
- // src/cli/services/interactive-prompt.service.ts
272
- interface PromptOptions {
273
- message: string;
274
- type: 'select' | 'multiselect' | 'input' | 'confirm' | 'progress';
275
- choices?: PromptChoice[];
276
- default?: any;
277
- validate?: (input: any) => boolean | string;
278
- transform?: (input: any) => any;
279
- }
280
-
281
- export class InteractivePromptService {
282
- private inquirer: any; // Dynamic import for tree-shaking
283
-
284
- async select<T>(options: SelectPromptOptions<T>): Promise<T> {
285
- const { default: inquirer } = await import('inquirer');
286
-
287
- const result = await inquirer.prompt([{
288
- type: 'list',
289
- name: 'selection',
290
- message: options.message,
291
- choices: options.choices,
292
- default: options.default
293
- }]);
294
-
295
- return result.selection;
296
- }
297
-
298
- async multiSelect<T>(options: MultiSelectPromptOptions<T>): Promise<T[]> {
299
- const { default: inquirer } = await import('inquirer');
300
-
301
- const result = await inquirer.prompt([{
302
- type: 'checkbox',
303
- name: 'selections',
304
- message: options.message,
305
- choices: options.choices,
306
- validate: (input: T[]) => {
307
- if (options.minSelections && input.length < options.minSelections) {
308
- return `Please select at least ${options.minSelections} options`;
309
- }
310
- if (options.maxSelections && input.length > options.maxSelections) {
311
- return `Please select at most ${options.maxSelections} options`;
312
- }
313
- return true;
314
- }
315
- }]);
316
-
317
- return result.selections;
318
- }
319
-
320
- async input(options: InputPromptOptions): Promise<string> {
321
- const { default: inquirer } = await import('inquirer');
322
-
323
- const result = await inquirer.prompt([{
324
- type: 'input',
325
- name: 'input',
326
- message: options.message,
327
- default: options.default,
328
- validate: options.validate,
329
- transformer: options.transform
330
- }]);
331
-
332
- return result.input;
333
- }
334
-
335
- async progressTask<T>(
336
- task: ProgressTask<T>,
337
- options: ProgressOptions
338
- ): Promise<T> {
339
- const { default: cliProgress } = await import('cli-progress');
340
-
341
- const progressBar = new cliProgress.SingleBar({
342
- format: `${options.title} |{bar}| {percentage}% | {status}`,
343
- barCompleteChar: '█',
344
- barIncompleteChar: '░',
345
- hideCursor: true
346
- });
347
-
348
- progressBar.start(100, 0, { status: 'Starting...' });
349
-
350
- try {
351
- const result = await task({
352
- updateProgress: (percent: number, status?: string) => {
353
- progressBar.update(percent, { status: status || 'Processing...' });
354
- }
355
- });
356
-
357
- progressBar.update(100, { status: 'Complete!' });
358
- progressBar.stop();
359
-
360
- return result;
361
- } catch (error) {
362
- progressBar.stop();
363
- throw error;
364
- }
365
- }
366
-
367
- async confirmWithDetails(
368
- message: string,
369
- details: ConfirmationDetails
370
- ): Promise<boolean> {
371
- console.log('\n' + chalk.bold(message));
372
- console.log(chalk.gray('Details:'));
373
-
374
- for (const [key, value] of Object.entries(details)) {
375
- console.log(chalk.gray(` ${key}: ${value}`));
376
- }
377
-
378
- return this.confirm('\nProceed?');
379
- }
380
- }
381
- ```
382
-
383
- ## Enhanced Hooks Integration
384
-
385
- ### Deep CLI Hooks Integration
386
- ```typescript
387
- // src/cli/hooks/cli-hooks-manager.ts
388
- interface CLIHookEvent {
389
- type: 'command_start' | 'command_end' | 'command_error' | 'agent_spawn' | 'task_complete';
390
- command: string;
391
- args: string[];
392
- context: ExecutionContext;
393
- timestamp: Date;
394
- }
395
-
396
- export class CLIHooksManager {
397
- private hooks: Map<string, HookHandler[]> = new Map();
398
- private learningIntegration: LearningHooksIntegration;
399
-
400
- constructor() {
401
- this.learningIntegration = new LearningHooksIntegration();
402
- this.setupDefaultHooks();
403
- }
404
-
405
- private setupDefaultHooks(): void {
406
- // Learning integration hooks
407
- this.registerHook('command_start', async (event: CLIHookEvent) => {
408
- await this.learningIntegration.recordCommandStart(event);
409
- });
410
-
411
- this.registerHook('command_end', async (event: CLIHookEvent) => {
412
- await this.learningIntegration.recordCommandSuccess(event);
413
- });
414
-
415
- this.registerHook('command_error', async (event: CLIHookEvent) => {
416
- await this.learningIntegration.recordCommandError(event);
417
- });
418
-
419
- // Intelligent suggestions
420
- this.registerHook('command_start', async (event: CLIHookEvent) => {
421
- const suggestions = await this.generateIntelligentSuggestions(event);
422
- if (suggestions.length > 0) {
423
- this.displaySuggestions(suggestions);
424
- }
425
- });
426
-
427
- // Performance monitoring
428
- this.registerHook('command_end', async (event: CLIHookEvent) => {
429
- await this.recordPerformanceMetrics(event);
430
- });
431
- }
432
-
433
- async executeHooks(type: string, event: CLIHookEvent): Promise<void> {
434
- const handlers = this.hooks.get(type) || [];
435
-
436
- await Promise.all(handlers.map(handler =>
437
- this.executeHookSafely(handler, event)
438
- ));
439
- }
440
-
441
- private async generateIntelligentSuggestions(event: CLIHookEvent): Promise<Suggestion[]> {
442
- const context = await this.learningIntegration.getExecutionContext(event);
443
- const patterns = await this.learningIntegration.findSimilarPatterns(context);
444
-
445
- return patterns.map(pattern => ({
446
- type: 'optimization',
447
- message: `Based on similar executions, consider: ${pattern.suggestion}`,
448
- confidence: pattern.confidence
449
- }));
450
- }
451
- }
452
- ```
453
-
454
- ### Learning Integration
455
- ```typescript
456
- // src/cli/hooks/learning-hooks-integration.ts
457
- export class LearningHooksIntegration {
458
- constructor(
459
- private agenticFlowHooks: AgenticFlowHooksClient,
460
- private agentDBLearning: AgentDBLearningClient
461
- ) {}
462
-
463
- async recordCommandStart(event: CLIHookEvent): Promise<void> {
464
- // Start trajectory tracking
465
- await this.agenticFlowHooks.trajectoryStart({
466
- sessionId: event.context.sessionId,
467
- command: event.command,
468
- args: event.args,
469
- context: event.context
470
- });
471
-
472
- // Record experience in AgentDB
473
- await this.agentDBLearning.recordExperience({
474
- type: 'command_execution',
475
- state: this.encodeCommandState(event),
476
- action: event.command,
477
- timestamp: event.timestamp
478
- });
479
- }
480
-
481
- async recordCommandSuccess(event: CLIHookEvent): Promise<void> {
482
- const executionTime = Date.now() - event.timestamp.getTime();
483
- const reward = this.calculateReward(event, executionTime, true);
484
-
485
- // Complete trajectory
486
- await this.agenticFlowHooks.trajectoryEnd({
487
- sessionId: event.context.sessionId,
488
- success: true,
489
- reward,
490
- verdict: 'positive'
491
- });
492
-
493
- // Submit feedback to learning system
494
- await this.agentDBLearning.submitFeedback({
495
- sessionId: event.context.learningSessionId,
496
- reward,
497
- success: true,
498
- latencyMs: executionTime
499
- });
500
-
501
- // Store successful pattern
502
- if (reward > 0.8) {
503
- await this.agenticFlowHooks.storePattern({
504
- pattern: event.command,
505
- solution: event.context.result,
506
- confidence: reward
507
- });
508
- }
509
- }
510
-
511
- async recordCommandError(event: CLIHookEvent): Promise<void> {
512
- const executionTime = Date.now() - event.timestamp.getTime();
513
- const reward = this.calculateReward(event, executionTime, false);
514
-
515
- // Complete trajectory with error
516
- await this.agenticFlowHooks.trajectoryEnd({
517
- sessionId: event.context.sessionId,
518
- success: false,
519
- reward,
520
- verdict: 'negative',
521
- error: event.context.error
522
- });
523
-
524
- // Learn from failure
525
- await this.agentDBLearning.submitFeedback({
526
- sessionId: event.context.learningSessionId,
527
- reward,
528
- success: false,
529
- latencyMs: executionTime,
530
- error: event.context.error
531
- });
532
- }
533
-
534
- private calculateReward(event: CLIHookEvent, executionTime: number, success: boolean): number {
535
- if (!success) return 0;
536
-
537
- // Base reward for success
538
- let reward = 0.5;
539
-
540
- // Performance bonus (faster execution)
541
- const expectedTime = this.getExpectedExecutionTime(event.command);
542
- if (executionTime < expectedTime) {
543
- reward += 0.3 * (1 - executionTime / expectedTime);
544
- }
545
-
546
- // Complexity bonus
547
- const complexity = this.calculateCommandComplexity(event);
548
- reward += complexity * 0.2;
549
-
550
- return Math.min(reward, 1.0);
551
- }
552
- }
553
- ```
554
-
555
- ## Intelligent Workflow Automation
556
-
557
- ### Workflow Orchestrator
558
- ```typescript
559
- // src/cli/workflows/workflow-orchestrator.ts
560
- interface WorkflowStep {
561
- id: string;
562
- command: string;
563
- args: string[];
564
- dependsOn: string[];
565
- condition?: WorkflowCondition;
566
- retryPolicy?: RetryPolicy;
567
- }
568
-
569
- export class WorkflowOrchestrator {
570
- constructor(
571
- private commandRegistry: ModularCommandRegistry,
572
- private promptService: InteractivePromptService
573
- ) {}
574
-
575
- async executeWorkflow(workflow: Workflow): Promise<WorkflowResult> {
576
- const context = new WorkflowExecutionContext(workflow);
577
-
578
- // Display workflow overview
579
- await this.displayWorkflowOverview(workflow);
580
-
581
- const confirmed = await this.promptService.confirm(
582
- 'Execute this workflow?'
583
- );
584
-
585
- if (!confirmed) {
586
- return WorkflowResult.cancelled();
587
- }
588
-
589
- // Execute steps
590
- return this.promptService.progressTask(
591
- async ({ updateProgress }) => {
592
- const steps = this.sortStepsByDependencies(workflow.steps);
593
-
594
- for (let i = 0; i < steps.length; i++) {
595
- const step = steps[i];
596
- updateProgress((i / steps.length) * 100, `Executing ${step.command}`);
597
-
598
- await this.executeStep(step, context);
599
- }
600
-
601
- return WorkflowResult.success(context.getResults());
602
- },
603
- { title: `Workflow: ${workflow.name}` }
604
- );
605
- }
606
-
607
- async generateWorkflowFromIntent(intent: string): Promise<Workflow> {
608
- // Use learning system to generate workflow
609
- const patterns = await this.findWorkflowPatterns(intent);
610
-
611
- if (patterns.length === 0) {
612
- throw new Error('Could not generate workflow for intent');
613
- }
614
-
615
- // Select best pattern or let user choose
616
- const selectedPattern = patterns.length === 1
617
- ? patterns[0]
618
- : await this.promptService.select({
619
- message: 'Select workflow template:',
620
- choices: patterns.map(p => ({
621
- name: `${p.name} (${p.confidence}% match)`,
622
- value: p
623
- }))
624
- });
625
-
626
- return this.customizeWorkflow(selectedPattern, intent);
627
- }
628
-
629
- private async executeStep(step: WorkflowStep, context: WorkflowExecutionContext): Promise<void> {
630
- // Check conditions
631
- if (step.condition && !this.evaluateCondition(step.condition, context)) {
632
- context.skipStep(step.id, 'Condition not met');
633
- return;
634
- }
635
-
636
- // Check dependencies
637
- const missingDeps = step.dependsOn.filter(dep => !context.isStepCompleted(dep));
638
- if (missingDeps.length > 0) {
639
- throw new WorkflowError(`Step ${step.id} has unmet dependencies: ${missingDeps.join(', ')}`);
640
- }
641
-
642
- // Execute with retry policy
643
- const retryPolicy = step.retryPolicy || { maxAttempts: 1 };
644
- let lastError: Error | null = null;
645
-
646
- for (let attempt = 1; attempt <= retryPolicy.maxAttempts; attempt++) {
647
- try {
648
- const result = await this.commandRegistry.executeCommand(step.command, step.args);
649
- context.completeStep(step.id, result);
650
- return;
651
- } catch (error) {
652
- lastError = error as Error;
653
-
654
- if (attempt < retryPolicy.maxAttempts) {
655
- await this.delay(retryPolicy.backoffMs || 1000);
656
- }
657
- }
658
- }
659
-
660
- throw new WorkflowError(`Step ${step.id} failed after ${retryPolicy.maxAttempts} attempts: ${lastError?.message}`);
661
- }
662
- }
663
- ```
664
-
665
- ## Performance Optimization
666
-
667
- ### Command Performance Monitoring
668
- ```typescript
669
- // src/cli/performance/command-performance.ts
670
- export class CommandPerformanceMonitor {
671
- private metrics = new Map<string, CommandMetrics>();
672
-
673
- async measureCommand<T>(
674
- commandName: string,
675
- executor: () => Promise<T>
676
- ): Promise<T> {
677
- const start = performance.now();
678
- const memBefore = process.memoryUsage();
679
-
680
- try {
681
- const result = await executor();
682
- const end = performance.now();
683
- const memAfter = process.memoryUsage();
684
-
685
- this.recordMetrics(commandName, {
686
- executionTime: end - start,
687
- memoryDelta: memAfter.heapUsed - memBefore.heapUsed,
688
- success: true
689
- });
690
-
691
- return result;
692
- } catch (error) {
693
- const end = performance.now();
694
-
695
- this.recordMetrics(commandName, {
696
- executionTime: end - start,
697
- memoryDelta: 0,
698
- success: false,
699
- error: error as Error
700
- });
701
-
702
- throw error;
703
- }
704
- }
705
-
706
- private recordMetrics(command: string, measurement: PerformanceMeasurement): void {
707
- if (!this.metrics.has(command)) {
708
- this.metrics.set(command, new CommandMetrics(command));
709
- }
710
-
711
- const metrics = this.metrics.get(command)!;
712
- metrics.addMeasurement(measurement);
713
-
714
- // Alert if performance degrades
715
- if (metrics.getP95ExecutionTime() > 5000) { // 5 seconds
716
- console.warn(`⚠️ Command '${command}' is performing slowly (P95: ${metrics.getP95ExecutionTime()}ms)`);
717
- }
718
- }
719
-
720
- getCommandReport(command: string): PerformanceReport {
721
- const metrics = this.metrics.get(command);
722
- if (!metrics) {
723
- throw new Error(`No metrics found for command: ${command}`);
724
- }
725
-
726
- return {
727
- command,
728
- totalExecutions: metrics.getTotalExecutions(),
729
- successRate: metrics.getSuccessRate(),
730
- avgExecutionTime: metrics.getAverageExecutionTime(),
731
- p95ExecutionTime: metrics.getP95ExecutionTime(),
732
- avgMemoryUsage: metrics.getAverageMemoryUsage(),
733
- recommendations: this.generateRecommendations(metrics)
734
- };
735
- }
736
- }
737
- ```
738
-
739
- ## Smart Auto-completion
740
-
741
- ### Intelligent Command Completion
742
- ```typescript
743
- // src/cli/completion/intelligent-completion.ts
744
- export class IntelligentCompletion {
745
- constructor(
746
- private learningService: LearningService,
747
- private commandRegistry: ModularCommandRegistry
748
- ) {}
749
-
750
- async generateCompletions(
751
- partial: string,
752
- context: CompletionContext
753
- ): Promise<Completion[]> {
754
- const completions: Completion[] = [];
755
-
756
- // 1. Exact command matches
757
- const exactMatches = this.commandRegistry.findCommandsByPrefix(partial);
758
- completions.push(...exactMatches.map(cmd => ({
759
- value: cmd.name,
760
- description: cmd.description,
761
- type: 'command',
762
- confidence: 1.0
763
- })));
764
-
765
- // 2. Learning-based suggestions
766
- const learnedSuggestions = await this.learningService.suggestCommands(
767
- partial,
768
- context
769
- );
770
- completions.push(...learnedSuggestions);
771
-
772
- // 3. Context-aware suggestions
773
- const contextualSuggestions = await this.generateContextualSuggestions(
774
- partial,
775
- context
776
- );
777
- completions.push(...contextualSuggestions);
778
-
779
- // Sort by confidence and relevance
780
- return completions
781
- .sort((a, b) => b.confidence - a.confidence)
782
- .slice(0, 10); // Top 10 suggestions
783
- }
784
-
785
- private async generateContextualSuggestions(
786
- partial: string,
787
- context: CompletionContext
788
- ): Promise<Completion[]> {
789
- const suggestions: Completion[] = [];
790
-
791
- // If in git repository, suggest git-related commands
792
- if (context.isGitRepository) {
793
- if (partial.startsWith('git')) {
794
- suggestions.push({
795
- value: 'git commit',
796
- description: 'Create git commit with generated message',
797
- type: 'workflow',
798
- confidence: 0.8
799
- });
800
- }
801
- }
802
-
803
- // If package.json exists, suggest npm commands
804
- if (context.hasPackageJson) {
805
- if (partial.startsWith('npm') || partial.startsWith('swarm')) {
806
- suggestions.push({
807
- value: 'swarm init',
808
- description: 'Initialize swarm for this project',
809
- type: 'workflow',
810
- confidence: 0.9
811
- });
812
- }
813
- }
814
-
815
- return suggestions;
816
- }
817
- }
818
- ```
819
-
820
- ## Success Metrics
821
-
822
- ### CLI Performance Targets
823
- - [ ] **Command Response**: <200ms average command execution time
824
- - [ ] **File Decomposition**: index.ts (108KB) → <10KB per command module
825
- - [ ] **Interactive UX**: Smart prompts with context awareness
826
- - [ ] **Hook Integration**: Deep lifecycle integration with learning
827
- - [ ] **Workflow Automation**: Intelligent multi-step command orchestration
828
- - [ ] **Auto-completion**: >90% accuracy for command suggestions
829
-
830
- ### User Experience Improvements
831
- ```typescript
832
- const cliImprovements = {
833
- before: {
834
- commandResponse: '~500ms',
835
- interactivity: 'Basic command parsing',
836
- workflows: 'Manual command chaining',
837
- suggestions: 'Static help text'
838
- },
839
-
840
- after: {
841
- commandResponse: '<200ms with caching',
842
- interactivity: 'Smart context-aware prompts',
843
- workflows: 'Automated multi-step execution',
844
- suggestions: 'Learning-based intelligent completion'
845
- }
846
- };
847
- ```
848
-
849
- ## Related V3 Skills
850
-
851
- - `v3-core-implementation` - Core domain integration
852
- - `v3-memory-unification` - Memory-backed command caching
853
- - `v3-swarm-coordination` - CLI swarm management integration
854
- - `v3-performance-optimization` - CLI performance monitoring
855
-
856
- ## Usage Examples
857
-
858
- ### Complete CLI Modernization
859
- ```bash
860
- # Full CLI modernization implementation
861
- Task("CLI modernization implementation",
862
- "Implement modular commands, interactive prompts, and intelligent workflows",
863
- "cli-hooks-developer")
864
- ```
865
-
866
- ### Interactive Command Enhancement
867
- ```bash
868
- # Enhanced interactive commands
869
- claude-flow swarm init --interactive
870
- claude-flow learning start --guided
871
- claude-flow workflow create --from-intent "setup new project"
872
- ```