claude-flow 3.0.0-alpha.16 → 3.0.0-alpha.19
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.
- package/README.md +39 -1093
- package/bin/cli.js +36 -0
- package/dist/index.d.ts +40 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +43 -0
- package/dist/index.js.map +1 -0
- package/package.json +53 -54
- package/.claude/.claude-flow/metrics/system-metrics.json +0 -2606
- package/.claude/agents/MIGRATION_SUMMARY.md +0 -222
- package/.claude/agents/README.md +0 -89
- package/.claude/agents/analysis/analyze-code-quality.md +0 -180
- package/.claude/agents/analysis/code-analyzer.md +0 -209
- package/.claude/agents/analysis/code-review/analyze-code-quality.md +0 -180
- package/.claude/agents/architecture/system-design/arch-system-design.md +0 -156
- package/.claude/agents/base-template-generator.md +0 -42
- package/.claude/agents/consensus/README.md +0 -253
- package/.claude/agents/consensus/byzantine-coordinator.md +0 -63
- package/.claude/agents/consensus/crdt-synchronizer.md +0 -997
- package/.claude/agents/consensus/gossip-coordinator.md +0 -63
- package/.claude/agents/consensus/performance-benchmarker.md +0 -851
- package/.claude/agents/consensus/quorum-manager.md +0 -823
- package/.claude/agents/consensus/raft-manager.md +0 -63
- package/.claude/agents/consensus/security-manager.md +0 -622
- package/.claude/agents/core/coder.md +0 -266
- package/.claude/agents/core/planner.md +0 -168
- package/.claude/agents/core/researcher.md +0 -190
- package/.claude/agents/core/reviewer.md +0 -326
- package/.claude/agents/core/tester.md +0 -319
- package/.claude/agents/custom/test-long-runner.md +0 -44
- package/.claude/agents/data/ml/data-ml-model.md +0 -193
- package/.claude/agents/database-specialist.yaml +0 -21
- package/.claude/agents/development/backend/dev-backend-api.md +0 -142
- package/.claude/agents/development/dev-backend-api.md +0 -345
- package/.claude/agents/devops/ci-cd/ops-cicd-github.md +0 -164
- package/.claude/agents/documentation/api-docs/docs-api-openapi.md +0 -174
- package/.claude/agents/flow-nexus/app-store.md +0 -88
- package/.claude/agents/flow-nexus/authentication.md +0 -69
- package/.claude/agents/flow-nexus/challenges.md +0 -81
- package/.claude/agents/flow-nexus/neural-network.md +0 -88
- package/.claude/agents/flow-nexus/payments.md +0 -83
- package/.claude/agents/flow-nexus/sandbox.md +0 -76
- package/.claude/agents/flow-nexus/swarm.md +0 -76
- package/.claude/agents/flow-nexus/user-tools.md +0 -96
- package/.claude/agents/flow-nexus/workflow.md +0 -84
- package/.claude/agents/github/code-review-swarm.md +0 -538
- package/.claude/agents/github/github-modes.md +0 -173
- package/.claude/agents/github/issue-tracker.md +0 -319
- package/.claude/agents/github/multi-repo-swarm.md +0 -553
- package/.claude/agents/github/pr-manager.md +0 -191
- package/.claude/agents/github/project-board-sync.md +0 -509
- package/.claude/agents/github/release-manager.md +0 -367
- package/.claude/agents/github/release-swarm.md +0 -583
- package/.claude/agents/github/repo-architect.md +0 -398
- package/.claude/agents/github/swarm-issue.md +0 -573
- package/.claude/agents/github/swarm-pr.md +0 -428
- package/.claude/agents/github/sync-coordinator.md +0 -452
- package/.claude/agents/github/workflow-automation.md +0 -635
- package/.claude/agents/goal/agent.md +0 -816
- package/.claude/agents/goal/code-goal-planner.md +0 -446
- package/.claude/agents/goal/goal-planner.md +0 -168
- package/.claude/agents/hive-mind/collective-intelligence-coordinator.md +0 -130
- package/.claude/agents/hive-mind/queen-coordinator.md +0 -203
- package/.claude/agents/hive-mind/scout-explorer.md +0 -242
- package/.claude/agents/hive-mind/swarm-memory-manager.md +0 -193
- package/.claude/agents/hive-mind/worker-specialist.md +0 -217
- package/.claude/agents/index.yaml +0 -17
- package/.claude/agents/neural/safla-neural.md +0 -74
- package/.claude/agents/optimization/README.md +0 -250
- package/.claude/agents/optimization/benchmark-suite.md +0 -665
- package/.claude/agents/optimization/load-balancer.md +0 -431
- package/.claude/agents/optimization/performance-monitor.md +0 -672
- package/.claude/agents/optimization/resource-allocator.md +0 -674
- package/.claude/agents/optimization/topology-optimizer.md +0 -808
- package/.claude/agents/payments/agentic-payments.md +0 -126
- package/.claude/agents/project-coordinator.yaml +0 -15
- package/.claude/agents/python-specialist.yaml +0 -21
- package/.claude/agents/reasoning/agent.md +0 -816
- package/.claude/agents/reasoning/goal-planner.md +0 -73
- package/.claude/agents/security-auditor.yaml +0 -20
- package/.claude/agents/sona/sona-learning-optimizer.md +0 -496
- package/.claude/agents/sparc/architecture.md +0 -472
- package/.claude/agents/sparc/pseudocode.md +0 -318
- package/.claude/agents/sparc/refinement.md +0 -525
- package/.claude/agents/sparc/specification.md +0 -276
- package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +0 -226
- package/.claude/agents/sublinear/consensus-coordinator.md +0 -338
- package/.claude/agents/sublinear/matrix-optimizer.md +0 -185
- package/.claude/agents/sublinear/pagerank-analyzer.md +0 -299
- package/.claude/agents/sublinear/performance-optimizer.md +0 -368
- package/.claude/agents/sublinear/trading-predictor.md +0 -246
- package/.claude/agents/swarm/README.md +0 -190
- package/.claude/agents/swarm/adaptive-coordinator.md +0 -396
- package/.claude/agents/swarm/hierarchical-coordinator.md +0 -327
- package/.claude/agents/swarm/mesh-coordinator.md +0 -392
- package/.claude/agents/templates/automation-smart-agent.md +0 -205
- package/.claude/agents/templates/coordinator-swarm-init.md +0 -105
- package/.claude/agents/templates/github-pr-manager.md +0 -177
- package/.claude/agents/templates/implementer-sparc-coder.md +0 -259
- package/.claude/agents/templates/memory-coordinator.md +0 -187
- package/.claude/agents/templates/migration-plan.md +0 -746
- package/.claude/agents/templates/orchestrator-task.md +0 -139
- package/.claude/agents/templates/performance-analyzer.md +0 -199
- package/.claude/agents/templates/sparc-coordinator.md +0 -183
- package/.claude/agents/testing/production-validator.md +0 -395
- package/.claude/agents/testing/tdd-london-swarm.md +0 -244
- package/.claude/agents/testing/unit/tdd-london-swarm.md +0 -244
- package/.claude/agents/testing/validation/production-validator.md +0 -395
- package/.claude/agents/typescript-specialist.yaml +0 -21
- package/.claude/agents/v3/database-specialist.yaml +0 -21
- package/.claude/agents/v3/index.yaml +0 -17
- package/.claude/agents/v3/project-coordinator.yaml +0 -15
- package/.claude/agents/v3/python-specialist.yaml +0 -21
- package/.claude/agents/v3/test-architect.yaml +0 -20
- package/.claude/agents/v3/typescript-specialist.yaml +0 -21
- package/.claude/agents/v3/v3-integration-architect.md +0 -346
- package/.claude/agents/v3/v3-memory-specialist.md +0 -318
- package/.claude/agents/v3/v3-performance-engineer.md +0 -397
- package/.claude/agents/v3/v3-queen-coordinator.md +0 -98
- package/.claude/agents/v3/v3-security-architect.md +0 -174
- package/.claude/checkpoints/1767754460.json +0 -8
- package/.claude/commands/agents/README.md +0 -10
- package/.claude/commands/agents/agent-capabilities.md +0 -21
- package/.claude/commands/agents/agent-coordination.md +0 -28
- package/.claude/commands/agents/agent-spawning.md +0 -28
- package/.claude/commands/agents/agent-types.md +0 -26
- package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +0 -54
- package/.claude/commands/analysis/README.md +0 -9
- package/.claude/commands/analysis/bottleneck-detect.md +0 -162
- package/.claude/commands/analysis/performance-bottlenecks.md +0 -59
- package/.claude/commands/analysis/performance-report.md +0 -25
- package/.claude/commands/analysis/token-efficiency.md +0 -45
- package/.claude/commands/analysis/token-usage.md +0 -25
- package/.claude/commands/automation/README.md +0 -9
- package/.claude/commands/automation/auto-agent.md +0 -122
- package/.claude/commands/automation/self-healing.md +0 -106
- package/.claude/commands/automation/session-memory.md +0 -90
- package/.claude/commands/automation/smart-agents.md +0 -73
- package/.claude/commands/automation/smart-spawn.md +0 -25
- package/.claude/commands/automation/workflow-select.md +0 -25
- package/.claude/commands/claude-flow-help.md +0 -103
- package/.claude/commands/claude-flow-memory.md +0 -107
- package/.claude/commands/claude-flow-swarm.md +0 -205
- package/.claude/commands/coordination/README.md +0 -9
- package/.claude/commands/coordination/agent-spawn.md +0 -25
- package/.claude/commands/coordination/init.md +0 -44
- package/.claude/commands/coordination/orchestrate.md +0 -43
- package/.claude/commands/coordination/spawn.md +0 -45
- package/.claude/commands/coordination/swarm-init.md +0 -85
- package/.claude/commands/coordination/task-orchestrate.md +0 -25
- package/.claude/commands/flow-nexus/app-store.md +0 -124
- package/.claude/commands/flow-nexus/challenges.md +0 -120
- package/.claude/commands/flow-nexus/login-registration.md +0 -65
- package/.claude/commands/flow-nexus/neural-network.md +0 -134
- package/.claude/commands/flow-nexus/payments.md +0 -116
- package/.claude/commands/flow-nexus/sandbox.md +0 -83
- package/.claude/commands/flow-nexus/swarm.md +0 -87
- package/.claude/commands/flow-nexus/user-tools.md +0 -152
- package/.claude/commands/flow-nexus/workflow.md +0 -115
- package/.claude/commands/github/README.md +0 -11
- package/.claude/commands/github/code-review-swarm.md +0 -514
- package/.claude/commands/github/code-review.md +0 -25
- package/.claude/commands/github/github-modes.md +0 -147
- package/.claude/commands/github/github-swarm.md +0 -121
- package/.claude/commands/github/issue-tracker.md +0 -292
- package/.claude/commands/github/issue-triage.md +0 -25
- package/.claude/commands/github/multi-repo-swarm.md +0 -519
- package/.claude/commands/github/pr-enhance.md +0 -26
- package/.claude/commands/github/pr-manager.md +0 -170
- package/.claude/commands/github/project-board-sync.md +0 -471
- package/.claude/commands/github/release-manager.md +0 -338
- package/.claude/commands/github/release-swarm.md +0 -544
- package/.claude/commands/github/repo-analyze.md +0 -25
- package/.claude/commands/github/repo-architect.md +0 -367
- package/.claude/commands/github/swarm-issue.md +0 -482
- package/.claude/commands/github/swarm-pr.md +0 -285
- package/.claude/commands/github/sync-coordinator.md +0 -301
- package/.claude/commands/github/workflow-automation.md +0 -442
- package/.claude/commands/hive-mind/README.md +0 -17
- package/.claude/commands/hive-mind/hive-mind-consensus.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-init.md +0 -18
- package/.claude/commands/hive-mind/hive-mind-memory.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-metrics.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-resume.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-sessions.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-spawn.md +0 -21
- package/.claude/commands/hive-mind/hive-mind-status.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-stop.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-wizard.md +0 -8
- package/.claude/commands/hive-mind/hive-mind.md +0 -27
- package/.claude/commands/hooks/README.md +0 -11
- package/.claude/commands/hooks/overview.md +0 -58
- package/.claude/commands/hooks/post-edit.md +0 -117
- package/.claude/commands/hooks/post-task.md +0 -112
- package/.claude/commands/hooks/pre-edit.md +0 -113
- package/.claude/commands/hooks/pre-task.md +0 -111
- package/.claude/commands/hooks/session-end.md +0 -118
- package/.claude/commands/hooks/setup.md +0 -103
- package/.claude/commands/memory/README.md +0 -9
- package/.claude/commands/memory/memory-persist.md +0 -25
- package/.claude/commands/memory/memory-search.md +0 -25
- package/.claude/commands/memory/memory-usage.md +0 -25
- package/.claude/commands/memory/neural.md +0 -47
- package/.claude/commands/monitoring/README.md +0 -9
- package/.claude/commands/monitoring/agent-metrics.md +0 -25
- package/.claude/commands/monitoring/agents.md +0 -44
- package/.claude/commands/monitoring/real-time-view.md +0 -25
- package/.claude/commands/monitoring/status.md +0 -46
- package/.claude/commands/monitoring/swarm-monitor.md +0 -25
- package/.claude/commands/optimization/README.md +0 -9
- package/.claude/commands/optimization/auto-topology.md +0 -62
- package/.claude/commands/optimization/cache-manage.md +0 -25
- package/.claude/commands/optimization/parallel-execute.md +0 -25
- package/.claude/commands/optimization/parallel-execution.md +0 -50
- package/.claude/commands/optimization/topology-optimize.md +0 -25
- package/.claude/commands/pair/README.md +0 -261
- package/.claude/commands/pair/commands.md +0 -546
- package/.claude/commands/pair/config.md +0 -510
- package/.claude/commands/pair/examples.md +0 -512
- package/.claude/commands/pair/modes.md +0 -348
- package/.claude/commands/pair/session.md +0 -407
- package/.claude/commands/pair/start.md +0 -209
- package/.claude/commands/sparc/analyzer.md +0 -52
- package/.claude/commands/sparc/architect.md +0 -53
- package/.claude/commands/sparc/ask.md +0 -97
- package/.claude/commands/sparc/batch-executor.md +0 -54
- package/.claude/commands/sparc/code.md +0 -89
- package/.claude/commands/sparc/coder.md +0 -54
- package/.claude/commands/sparc/debug.md +0 -83
- package/.claude/commands/sparc/debugger.md +0 -54
- package/.claude/commands/sparc/designer.md +0 -53
- package/.claude/commands/sparc/devops.md +0 -109
- package/.claude/commands/sparc/docs-writer.md +0 -80
- package/.claude/commands/sparc/documenter.md +0 -54
- package/.claude/commands/sparc/innovator.md +0 -54
- package/.claude/commands/sparc/integration.md +0 -83
- package/.claude/commands/sparc/mcp.md +0 -117
- package/.claude/commands/sparc/memory-manager.md +0 -54
- package/.claude/commands/sparc/optimizer.md +0 -54
- package/.claude/commands/sparc/orchestrator.md +0 -132
- package/.claude/commands/sparc/post-deployment-monitoring-mode.md +0 -83
- package/.claude/commands/sparc/refinement-optimization-mode.md +0 -83
- package/.claude/commands/sparc/researcher.md +0 -54
- package/.claude/commands/sparc/reviewer.md +0 -54
- package/.claude/commands/sparc/security-review.md +0 -80
- package/.claude/commands/sparc/sparc-modes.md +0 -174
- package/.claude/commands/sparc/sparc.md +0 -111
- package/.claude/commands/sparc/spec-pseudocode.md +0 -80
- package/.claude/commands/sparc/supabase-admin.md +0 -348
- package/.claude/commands/sparc/swarm-coordinator.md +0 -54
- package/.claude/commands/sparc/tdd.md +0 -54
- package/.claude/commands/sparc/tester.md +0 -54
- package/.claude/commands/sparc/tutorial.md +0 -79
- package/.claude/commands/sparc/workflow-manager.md +0 -54
- package/.claude/commands/sparc.md +0 -166
- package/.claude/commands/stream-chain/pipeline.md +0 -121
- package/.claude/commands/stream-chain/run.md +0 -70
- package/.claude/commands/swarm/README.md +0 -15
- package/.claude/commands/swarm/analysis.md +0 -95
- package/.claude/commands/swarm/development.md +0 -96
- package/.claude/commands/swarm/examples.md +0 -168
- package/.claude/commands/swarm/maintenance.md +0 -102
- package/.claude/commands/swarm/optimization.md +0 -117
- package/.claude/commands/swarm/research.md +0 -136
- package/.claude/commands/swarm/swarm-analysis.md +0 -8
- package/.claude/commands/swarm/swarm-background.md +0 -8
- package/.claude/commands/swarm/swarm-init.md +0 -19
- package/.claude/commands/swarm/swarm-modes.md +0 -8
- package/.claude/commands/swarm/swarm-monitor.md +0 -8
- package/.claude/commands/swarm/swarm-spawn.md +0 -19
- package/.claude/commands/swarm/swarm-status.md +0 -8
- package/.claude/commands/swarm/swarm-strategies.md +0 -8
- package/.claude/commands/swarm/swarm.md +0 -27
- package/.claude/commands/swarm/testing.md +0 -131
- package/.claude/commands/training/README.md +0 -9
- package/.claude/commands/training/model-update.md +0 -25
- package/.claude/commands/training/neural-patterns.md +0 -74
- package/.claude/commands/training/neural-train.md +0 -25
- package/.claude/commands/training/pattern-learn.md +0 -25
- package/.claude/commands/training/specialization.md +0 -63
- package/.claude/commands/truth/start.md +0 -143
- package/.claude/commands/verify/check.md +0 -50
- package/.claude/commands/verify/start.md +0 -128
- package/.claude/commands/workflows/README.md +0 -9
- package/.claude/commands/workflows/development.md +0 -78
- package/.claude/commands/workflows/research.md +0 -63
- package/.claude/commands/workflows/workflow-create.md +0 -25
- package/.claude/commands/workflows/workflow-execute.md +0 -25
- package/.claude/commands/workflows/workflow-export.md +0 -25
- package/.claude/config/v3-dependency-optimization.json +0 -266
- package/.claude/config/v3-performance-targets.json +0 -251
- package/.claude/helpers/README.md +0 -97
- package/.claude/helpers/adr-compliance.sh +0 -186
- package/.claude/helpers/auto-commit.sh +0 -178
- package/.claude/helpers/checkpoint-manager.sh +0 -251
- package/.claude/helpers/daemon-manager.sh +0 -252
- package/.claude/helpers/ddd-tracker.sh +0 -144
- package/.claude/helpers/github-safe.js +0 -106
- package/.claude/helpers/github-setup.sh +0 -28
- package/.claude/helpers/guidance-hook.sh +0 -13
- package/.claude/helpers/guidance-hooks.sh +0 -102
- package/.claude/helpers/health-monitor.sh +0 -108
- package/.claude/helpers/learning-hooks.sh +0 -329
- package/.claude/helpers/learning-optimizer.sh +0 -127
- package/.claude/helpers/learning-service.mjs +0 -1144
- package/.claude/helpers/metrics-db.mjs +0 -488
- package/.claude/helpers/pattern-consolidator.sh +0 -86
- package/.claude/helpers/perf-worker.sh +0 -160
- package/.claude/helpers/quick-start.sh +0 -19
- package/.claude/helpers/security-scanner.sh +0 -127
- package/.claude/helpers/setup-mcp.sh +0 -18
- package/.claude/helpers/standard-checkpoint-hooks.sh +0 -189
- package/.claude/helpers/swarm-comms.sh +0 -353
- package/.claude/helpers/swarm-hooks.sh +0 -761
- package/.claude/helpers/swarm-monitor.sh +0 -211
- package/.claude/helpers/sync-v3-metrics.sh +0 -245
- package/.claude/helpers/update-v3-progress.sh +0 -166
- package/.claude/helpers/v3-quick-status.sh +0 -58
- package/.claude/helpers/v3.sh +0 -111
- package/.claude/helpers/validate-v3-config.sh +0 -216
- package/.claude/helpers/worker-manager.sh +0 -170
- package/.claude/mcp.json +0 -13
- package/.claude/settings.json +0 -526
- package/.claude/settings.local.json +0 -10
- package/.claude/skills/.claude-flow/metrics/agent-metrics.json +0 -1
- package/.claude/skills/.claude-flow/metrics/performance.json +0 -87
- package/.claude/skills/.claude-flow/metrics/task-metrics.json +0 -10
- package/.claude/skills/agentdb-advanced/SKILL.md +0 -550
- package/.claude/skills/agentdb-learning/SKILL.md +0 -545
- package/.claude/skills/agentdb-memory-patterns/SKILL.md +0 -339
- package/.claude/skills/agentdb-optimization/SKILL.md +0 -509
- package/.claude/skills/agentdb-vector-search/SKILL.md +0 -339
- package/.claude/skills/agentic-jujutsu/SKILL.md +0 -645
- package/.claude/skills/flow-nexus-neural/SKILL.md +0 -738
- package/.claude/skills/flow-nexus-platform/SKILL.md +0 -1157
- package/.claude/skills/flow-nexus-swarm/SKILL.md +0 -610
- package/.claude/skills/github-code-review/SKILL.md +0 -1140
- package/.claude/skills/github-multi-repo/SKILL.md +0 -874
- package/.claude/skills/github-project-management/SKILL.md +0 -1277
- package/.claude/skills/github-release-management/SKILL.md +0 -1081
- package/.claude/skills/github-workflow-automation/SKILL.md +0 -1065
- package/.claude/skills/hive-mind-advanced/SKILL.md +0 -712
- package/.claude/skills/hooks-automation/SKILL.md +0 -1201
- package/.claude/skills/pair-programming/SKILL.md +0 -1202
- package/.claude/skills/performance-analysis/SKILL.md +0 -563
- package/.claude/skills/reasoningbank-agentdb/SKILL.md +0 -446
- package/.claude/skills/reasoningbank-intelligence/SKILL.md +0 -201
- package/.claude/skills/skill-builder/.claude-flow/metrics/agent-metrics.json +0 -1
- package/.claude/skills/skill-builder/.claude-flow/metrics/performance.json +0 -87
- package/.claude/skills/skill-builder/.claude-flow/metrics/task-metrics.json +0 -10
- package/.claude/skills/skill-builder/SKILL.md +0 -910
- package/.claude/skills/sparc-methodology/SKILL.md +0 -1115
- package/.claude/skills/stream-chain/SKILL.md +0 -563
- package/.claude/skills/swarm-advanced/SKILL.md +0 -973
- package/.claude/skills/swarm-orchestration/SKILL.md +0 -179
- package/.claude/skills/v3-cli-modernization/SKILL.md +0 -872
- package/.claude/skills/v3-core-implementation/SKILL.md +0 -797
- package/.claude/skills/v3-ddd-architecture/SKILL.md +0 -442
- package/.claude/skills/v3-integration-deep/SKILL.md +0 -241
- package/.claude/skills/v3-mcp-optimization/SKILL.md +0 -777
- package/.claude/skills/v3-memory-unification/SKILL.md +0 -174
- package/.claude/skills/v3-performance-optimization/SKILL.md +0 -390
- package/.claude/skills/v3-security-overhaul/SKILL.md +0 -82
- package/.claude/skills/v3-swarm-coordination/SKILL.md +0 -340
- package/.claude/skills/verification-quality/SKILL.md +0 -649
- package/.claude/skills/worker-benchmarks/skill.md +0 -135
- package/.claude/skills/worker-integration/skill.md +0 -154
- package/.claude/statusline-command.sh +0 -176
- package/.claude/statusline.mjs +0 -109
- package/.claude/statusline.sh +0 -375
- package/.claude-plugin/README.md +0 -720
- package/.claude-plugin/docs/INSTALLATION.md +0 -261
- package/.claude-plugin/docs/PLUGIN_SUMMARY.md +0 -361
- package/.claude-plugin/docs/QUICKSTART.md +0 -361
- package/.claude-plugin/docs/STRUCTURE.md +0 -128
- package/.claude-plugin/hooks/hooks.json +0 -74
- package/.claude-plugin/marketplace.json +0 -96
- package/.claude-plugin/plugin.json +0 -71
- package/.claude-plugin/scripts/install.sh +0 -234
- package/.claude-plugin/scripts/uninstall.sh +0 -36
- package/.claude-plugin/scripts/verify.sh +0 -108
- package/v3/@claude-flow/cli/README.md +0 -1352
- package/v3/@claude-flow/cli/bin/cli.js +0 -14
- package/v3/@claude-flow/cli/dist/src/commands/agent.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/agent.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/agent.js +0 -819
- package/v3/@claude-flow/cli/dist/src/commands/agent.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/analyze.d.ts +0 -19
- package/v3/@claude-flow/cli/dist/src/commands/analyze.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/analyze.js +0 -1823
- package/v3/@claude-flow/cli/dist/src/commands/analyze.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/claims.d.ts +0 -10
- package/v3/@claude-flow/cli/dist/src/commands/claims.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/claims.js +0 -288
- package/v3/@claude-flow/cli/dist/src/commands/claims.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/completions.d.ts +0 -10
- package/v3/@claude-flow/cli/dist/src/commands/completions.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/completions.js +0 -539
- package/v3/@claude-flow/cli/dist/src/commands/completions.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/config.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/config.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/config.js +0 -406
- package/v3/@claude-flow/cli/dist/src/commands/config.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/daemon.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/daemon.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/daemon.js +0 -545
- package/v3/@claude-flow/cli/dist/src/commands/daemon.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/deployment.d.ts +0 -10
- package/v3/@claude-flow/cli/dist/src/commands/deployment.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/deployment.js +0 -289
- package/v3/@claude-flow/cli/dist/src/commands/deployment.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/doctor.d.ts +0 -10
- package/v3/@claude-flow/cli/dist/src/commands/doctor.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/doctor.js +0 -448
- package/v3/@claude-flow/cli/dist/src/commands/doctor.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/embeddings.d.ts +0 -18
- package/v3/@claude-flow/cli/dist/src/commands/embeddings.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/embeddings.js +0 -616
- package/v3/@claude-flow/cli/dist/src/commands/embeddings.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/hive-mind.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/hive-mind.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/hive-mind.js +0 -844
- package/v3/@claude-flow/cli/dist/src/commands/hive-mind.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/hooks.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/hooks.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/hooks.js +0 -2542
- package/v3/@claude-flow/cli/dist/src/commands/hooks.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/index.d.ts +0 -65
- package/v3/@claude-flow/cli/dist/src/commands/index.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/index.js +0 -162
- package/v3/@claude-flow/cli/dist/src/commands/index.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/init.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/init.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/init.js +0 -532
- package/v3/@claude-flow/cli/dist/src/commands/init.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/mcp.d.ts +0 -11
- package/v3/@claude-flow/cli/dist/src/commands/mcp.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/mcp.js +0 -662
- package/v3/@claude-flow/cli/dist/src/commands/mcp.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/memory.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/memory.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/memory.js +0 -977
- package/v3/@claude-flow/cli/dist/src/commands/memory.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/migrate.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/migrate.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/migrate.js +0 -398
- package/v3/@claude-flow/cli/dist/src/commands/migrate.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/neural.d.ts +0 -10
- package/v3/@claude-flow/cli/dist/src/commands/neural.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/neural.js +0 -224
- package/v3/@claude-flow/cli/dist/src/commands/neural.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/performance.d.ts +0 -10
- package/v3/@claude-flow/cli/dist/src/commands/performance.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/performance.js +0 -262
- package/v3/@claude-flow/cli/dist/src/commands/performance.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/plugins.d.ts +0 -10
- package/v3/@claude-flow/cli/dist/src/commands/plugins.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/plugins.js +0 -280
- package/v3/@claude-flow/cli/dist/src/commands/plugins.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/process.d.ts +0 -10
- package/v3/@claude-flow/cli/dist/src/commands/process.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/process.js +0 -641
- package/v3/@claude-flow/cli/dist/src/commands/process.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/progress.d.ts +0 -11
- package/v3/@claude-flow/cli/dist/src/commands/progress.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/progress.js +0 -259
- package/v3/@claude-flow/cli/dist/src/commands/progress.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/providers.d.ts +0 -10
- package/v3/@claude-flow/cli/dist/src/commands/providers.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/providers.js +0 -232
- package/v3/@claude-flow/cli/dist/src/commands/providers.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/route.d.ts +0 -16
- package/v3/@claude-flow/cli/dist/src/commands/route.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/route.js +0 -603
- package/v3/@claude-flow/cli/dist/src/commands/route.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/security.d.ts +0 -10
- package/v3/@claude-flow/cli/dist/src/commands/security.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/security.js +0 -261
- package/v3/@claude-flow/cli/dist/src/commands/security.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/session.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/session.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/session.js +0 -750
- package/v3/@claude-flow/cli/dist/src/commands/session.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/start.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/start.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/start.js +0 -398
- package/v3/@claude-flow/cli/dist/src/commands/start.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/status.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/status.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/status.js +0 -584
- package/v3/@claude-flow/cli/dist/src/commands/status.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/swarm.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/swarm.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/swarm.js +0 -573
- package/v3/@claude-flow/cli/dist/src/commands/swarm.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/task.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/task.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/task.js +0 -671
- package/v3/@claude-flow/cli/dist/src/commands/task.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/workflow.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/commands/workflow.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/commands/workflow.js +0 -617
- package/v3/@claude-flow/cli/dist/src/commands/workflow.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/config-adapter.d.ts +0 -15
- package/v3/@claude-flow/cli/dist/src/config-adapter.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/config-adapter.js +0 -185
- package/v3/@claude-flow/cli/dist/src/config-adapter.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/index.d.ts +0 -57
- package/v3/@claude-flow/cli/dist/src/index.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/index.js +0 -370
- package/v3/@claude-flow/cli/dist/src/index.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.d.ts +0 -68
- package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.js +0 -264
- package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.d.ts +0 -15
- package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.js +0 -482
- package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/executor.d.ts +0 -11
- package/v3/@claude-flow/cli/dist/src/init/executor.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/executor.js +0 -652
- package/v3/@claude-flow/cli/dist/src/init/executor.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/helpers-generator.d.ts +0 -42
- package/v3/@claude-flow/cli/dist/src/init/helpers-generator.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/helpers-generator.js +0 -613
- package/v3/@claude-flow/cli/dist/src/init/helpers-generator.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/index.d.ts +0 -12
- package/v3/@claude-flow/cli/dist/src/init/index.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/index.js +0 -15
- package/v3/@claude-flow/cli/dist/src/init/index.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/mcp-generator.d.ts +0 -18
- package/v3/@claude-flow/cli/dist/src/init/mcp-generator.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/mcp-generator.js +0 -71
- package/v3/@claude-flow/cli/dist/src/init/mcp-generator.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/settings-generator.d.ts +0 -14
- package/v3/@claude-flow/cli/dist/src/init/settings-generator.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/settings-generator.js +0 -267
- package/v3/@claude-flow/cli/dist/src/init/settings-generator.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/statusline-generator.d.ts +0 -14
- package/v3/@claude-flow/cli/dist/src/init/statusline-generator.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/statusline-generator.js +0 -206
- package/v3/@claude-flow/cli/dist/src/init/statusline-generator.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/types.d.ts +0 -240
- package/v3/@claude-flow/cli/dist/src/init/types.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/init/types.js +0 -210
- package/v3/@claude-flow/cli/dist/src/init/types.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-client.d.ts +0 -92
- package/v3/@claude-flow/cli/dist/src/mcp-client.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-client.js +0 -207
- package/v3/@claude-flow/cli/dist/src/mcp-client.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-server.d.ts +0 -153
- package/v3/@claude-flow/cli/dist/src/mcp-server.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-server.js +0 -453
- package/v3/@claude-flow/cli/dist/src/mcp-server.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.js +0 -426
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.d.ts +0 -38
- package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.js +0 -317
- package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.js +0 -333
- package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.js +0 -447
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.d.ts +0 -41
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.js +0 -1711
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/index.d.ts +0 -19
- package/v3/@claude-flow/cli/dist/src/mcp-tools/index.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/index.js +0 -18
- package/v3/@claude-flow/cli/dist/src/mcp-tools/index.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.js +0 -235
- package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.d.ts +0 -14
- package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.js +0 -343
- package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.js +0 -315
- package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.js +0 -102
- package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.js +0 -302
- package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/types.d.ts +0 -31
- package/v3/@claude-flow/cli/dist/src/mcp-tools/types.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/types.js +0 -7
- package/v3/@claude-flow/cli/dist/src/mcp-tools/types.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.d.ts +0 -8
- package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.js +0 -481
- package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/output.d.ts +0 -133
- package/v3/@claude-flow/cli/dist/src/output.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/output.js +0 -513
- package/v3/@claude-flow/cli/dist/src/output.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/parser.d.ts +0 -41
- package/v3/@claude-flow/cli/dist/src/parser.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/parser.js +0 -353
- package/v3/@claude-flow/cli/dist/src/parser.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/prompt.d.ts +0 -44
- package/v3/@claude-flow/cli/dist/src/prompt.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/prompt.js +0 -501
- package/v3/@claude-flow/cli/dist/src/prompt.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.d.ts +0 -67
- package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.js +0 -277
- package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.d.ts +0 -160
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.js +0 -491
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.d.ts +0 -33
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.js +0 -157
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.d.ts +0 -175
- package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.js +0 -662
- package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.d.ts +0 -187
- package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.js +0 -929
- package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/index.d.ts +0 -27
- package/v3/@claude-flow/cli/dist/src/ruvector/index.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/index.js +0 -53
- package/v3/@claude-flow/cli/dist/src/ruvector/index.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.d.ts +0 -211
- package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.js +0 -681
- package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.d.ts +0 -69
- package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.js +0 -243
- package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/services/index.d.ts +0 -7
- package/v3/@claude-flow/cli/dist/src/services/index.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/services/index.js +0 -6
- package/v3/@claude-flow/cli/dist/src/services/index.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/services/worker-daemon.d.ts +0 -153
- package/v3/@claude-flow/cli/dist/src/services/worker-daemon.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/services/worker-daemon.js +0 -567
- package/v3/@claude-flow/cli/dist/src/services/worker-daemon.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/suggest.d.ts +0 -53
- package/v3/@claude-flow/cli/dist/src/suggest.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/suggest.js +0 -200
- package/v3/@claude-flow/cli/dist/src/suggest.js.map +0 -1
- package/v3/@claude-flow/cli/dist/src/types.d.ts +0 -198
- package/v3/@claude-flow/cli/dist/src/types.d.ts.map +0 -1
- package/v3/@claude-flow/cli/dist/src/types.js +0 -38
- package/v3/@claude-flow/cli/dist/src/types.js.map +0 -1
- package/v3/@claude-flow/cli/dist/tsconfig.tsbuildinfo +0 -1
- package/v3/@claude-flow/cli/package.json +0 -51
- package/v3/@claude-flow/shared/README.md +0 -323
- package/v3/@claude-flow/shared/dist/core/config/defaults.d.ts +0 -41
- package/v3/@claude-flow/shared/dist/core/config/defaults.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/config/defaults.js +0 -186
- package/v3/@claude-flow/shared/dist/core/config/defaults.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/config/index.d.ts +0 -8
- package/v3/@claude-flow/shared/dist/core/config/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/config/index.js +0 -12
- package/v3/@claude-flow/shared/dist/core/config/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/config/loader.d.ts +0 -45
- package/v3/@claude-flow/shared/dist/core/config/loader.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/config/loader.js +0 -222
- package/v3/@claude-flow/shared/dist/core/config/loader.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/config/schema.d.ts +0 -1134
- package/v3/@claude-flow/shared/dist/core/config/schema.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/config/schema.js +0 -158
- package/v3/@claude-flow/shared/dist/core/config/schema.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/config/validator.d.ts +0 -92
- package/v3/@claude-flow/shared/dist/core/config/validator.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/config/validator.js +0 -147
- package/v3/@claude-flow/shared/dist/core/config/validator.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/event-bus.d.ts +0 -31
- package/v3/@claude-flow/shared/dist/core/event-bus.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/event-bus.js +0 -197
- package/v3/@claude-flow/shared/dist/core/event-bus.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/index.d.ts +0 -15
- package/v3/@claude-flow/shared/dist/core/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/index.js +0 -19
- package/v3/@claude-flow/shared/dist/core/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/agent.interface.d.ts +0 -200
- package/v3/@claude-flow/shared/dist/core/interfaces/agent.interface.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/agent.interface.js +0 -6
- package/v3/@claude-flow/shared/dist/core/interfaces/agent.interface.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/coordinator.interface.d.ts +0 -310
- package/v3/@claude-flow/shared/dist/core/interfaces/coordinator.interface.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/coordinator.interface.js +0 -7
- package/v3/@claude-flow/shared/dist/core/interfaces/coordinator.interface.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/event.interface.d.ts +0 -224
- package/v3/@claude-flow/shared/dist/core/interfaces/event.interface.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/event.interface.js +0 -46
- package/v3/@claude-flow/shared/dist/core/interfaces/event.interface.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/index.d.ts +0 -10
- package/v3/@claude-flow/shared/dist/core/interfaces/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/index.js +0 -15
- package/v3/@claude-flow/shared/dist/core/interfaces/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/memory.interface.d.ts +0 -298
- package/v3/@claude-flow/shared/dist/core/interfaces/memory.interface.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/memory.interface.js +0 -7
- package/v3/@claude-flow/shared/dist/core/interfaces/memory.interface.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/task.interface.d.ts +0 -185
- package/v3/@claude-flow/shared/dist/core/interfaces/task.interface.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/interfaces/task.interface.js +0 -6
- package/v3/@claude-flow/shared/dist/core/interfaces/task.interface.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/event-coordinator.d.ts +0 -35
- package/v3/@claude-flow/shared/dist/core/orchestrator/event-coordinator.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/event-coordinator.js +0 -101
- package/v3/@claude-flow/shared/dist/core/orchestrator/event-coordinator.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/health-monitor.d.ts +0 -60
- package/v3/@claude-flow/shared/dist/core/orchestrator/health-monitor.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/health-monitor.js +0 -166
- package/v3/@claude-flow/shared/dist/core/orchestrator/health-monitor.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/index.d.ts +0 -46
- package/v3/@claude-flow/shared/dist/core/orchestrator/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/index.js +0 -64
- package/v3/@claude-flow/shared/dist/core/orchestrator/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.d.ts +0 -56
- package/v3/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.js +0 -195
- package/v3/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/session-manager.d.ts +0 -83
- package/v3/@claude-flow/shared/dist/core/orchestrator/session-manager.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/session-manager.js +0 -193
- package/v3/@claude-flow/shared/dist/core/orchestrator/session-manager.js.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/task-manager.d.ts +0 -49
- package/v3/@claude-flow/shared/dist/core/orchestrator/task-manager.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/core/orchestrator/task-manager.js +0 -253
- package/v3/@claude-flow/shared/dist/core/orchestrator/task-manager.js.map +0 -1
- package/v3/@claude-flow/shared/dist/events/domain-events.d.ts +0 -282
- package/v3/@claude-flow/shared/dist/events/domain-events.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/events/domain-events.js +0 -165
- package/v3/@claude-flow/shared/dist/events/domain-events.js.map +0 -1
- package/v3/@claude-flow/shared/dist/events/event-store.d.ts +0 -126
- package/v3/@claude-flow/shared/dist/events/event-store.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/events/event-store.js +0 -416
- package/v3/@claude-flow/shared/dist/events/event-store.js.map +0 -1
- package/v3/@claude-flow/shared/dist/events/event-store.test.d.ts +0 -8
- package/v3/@claude-flow/shared/dist/events/event-store.test.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/events/event-store.test.js +0 -293
- package/v3/@claude-flow/shared/dist/events/event-store.test.js.map +0 -1
- package/v3/@claude-flow/shared/dist/events/example-usage.d.ts +0 -10
- package/v3/@claude-flow/shared/dist/events/example-usage.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/events/example-usage.js +0 -193
- package/v3/@claude-flow/shared/dist/events/example-usage.js.map +0 -1
- package/v3/@claude-flow/shared/dist/events/index.d.ts +0 -19
- package/v3/@claude-flow/shared/dist/events/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/events/index.js +0 -20
- package/v3/@claude-flow/shared/dist/events/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/events/projections.d.ts +0 -177
- package/v3/@claude-flow/shared/dist/events/projections.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/events/projections.js +0 -421
- package/v3/@claude-flow/shared/dist/events/projections.js.map +0 -1
- package/v3/@claude-flow/shared/dist/events/state-reconstructor.d.ts +0 -101
- package/v3/@claude-flow/shared/dist/events/state-reconstructor.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/events/state-reconstructor.js +0 -263
- package/v3/@claude-flow/shared/dist/events/state-reconstructor.js.map +0 -1
- package/v3/@claude-flow/shared/dist/events.d.ts +0 -80
- package/v3/@claude-flow/shared/dist/events.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/events.js +0 -249
- package/v3/@claude-flow/shared/dist/events.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/example-usage.d.ts +0 -42
- package/v3/@claude-flow/shared/dist/hooks/example-usage.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/example-usage.js +0 -351
- package/v3/@claude-flow/shared/dist/hooks/example-usage.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/executor.d.ts +0 -100
- package/v3/@claude-flow/shared/dist/hooks/executor.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/executor.js +0 -264
- package/v3/@claude-flow/shared/dist/hooks/executor.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/hooks.test.d.ts +0 -9
- package/v3/@claude-flow/shared/dist/hooks/hooks.test.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/hooks.test.js +0 -322
- package/v3/@claude-flow/shared/dist/hooks/hooks.test.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/index.d.ts +0 -52
- package/v3/@claude-flow/shared/dist/hooks/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/index.js +0 -51
- package/v3/@claude-flow/shared/dist/hooks/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/registry.d.ts +0 -133
- package/v3/@claude-flow/shared/dist/hooks/registry.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/registry.js +0 -277
- package/v3/@claude-flow/shared/dist/hooks/registry.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/safety/bash-safety.d.ts +0 -105
- package/v3/@claude-flow/shared/dist/hooks/safety/bash-safety.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/safety/bash-safety.js +0 -481
- package/v3/@claude-flow/shared/dist/hooks/safety/bash-safety.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/safety/file-organization.d.ts +0 -144
- package/v3/@claude-flow/shared/dist/hooks/safety/file-organization.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/safety/file-organization.js +0 -328
- package/v3/@claude-flow/shared/dist/hooks/safety/file-organization.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/safety/git-commit.d.ts +0 -158
- package/v3/@claude-flow/shared/dist/hooks/safety/git-commit.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/safety/git-commit.js +0 -450
- package/v3/@claude-flow/shared/dist/hooks/safety/git-commit.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/safety/index.d.ts +0 -17
- package/v3/@claude-flow/shared/dist/hooks/safety/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/safety/index.js +0 -17
- package/v3/@claude-flow/shared/dist/hooks/safety/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/session-hooks.d.ts +0 -234
- package/v3/@claude-flow/shared/dist/hooks/session-hooks.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/session-hooks.js +0 -334
- package/v3/@claude-flow/shared/dist/hooks/session-hooks.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/task-hooks.d.ts +0 -163
- package/v3/@claude-flow/shared/dist/hooks/task-hooks.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/task-hooks.js +0 -326
- package/v3/@claude-flow/shared/dist/hooks/task-hooks.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/types.d.ts +0 -267
- package/v3/@claude-flow/shared/dist/hooks/types.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/types.js +0 -62
- package/v3/@claude-flow/shared/dist/hooks/types.js.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/verify-exports.test.d.ts +0 -9
- package/v3/@claude-flow/shared/dist/hooks/verify-exports.test.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/hooks/verify-exports.test.js +0 -93
- package/v3/@claude-flow/shared/dist/hooks/verify-exports.test.js.map +0 -1
- package/v3/@claude-flow/shared/dist/index.d.ts +0 -19
- package/v3/@claude-flow/shared/dist/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/index.js +0 -46
- package/v3/@claude-flow/shared/dist/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/connection-pool.d.ts +0 -98
- package/v3/@claude-flow/shared/dist/mcp/connection-pool.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/connection-pool.js +0 -364
- package/v3/@claude-flow/shared/dist/mcp/connection-pool.js.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/index.d.ts +0 -69
- package/v3/@claude-flow/shared/dist/mcp/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/index.js +0 -84
- package/v3/@claude-flow/shared/dist/mcp/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/server.d.ts +0 -166
- package/v3/@claude-flow/shared/dist/mcp/server.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/server.js +0 -593
- package/v3/@claude-flow/shared/dist/mcp/server.js.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/session-manager.d.ts +0 -136
- package/v3/@claude-flow/shared/dist/mcp/session-manager.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/session-manager.js +0 -335
- package/v3/@claude-flow/shared/dist/mcp/session-manager.js.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/tool-registry.d.ts +0 -178
- package/v3/@claude-flow/shared/dist/mcp/tool-registry.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/tool-registry.js +0 -439
- package/v3/@claude-flow/shared/dist/mcp/tool-registry.js.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/transport/http.d.ts +0 -104
- package/v3/@claude-flow/shared/dist/mcp/transport/http.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/transport/http.js +0 -476
- package/v3/@claude-flow/shared/dist/mcp/transport/http.js.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/transport/index.d.ts +0 -102
- package/v3/@claude-flow/shared/dist/mcp/transport/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/transport/index.js +0 -238
- package/v3/@claude-flow/shared/dist/mcp/transport/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/transport/stdio.d.ts +0 -104
- package/v3/@claude-flow/shared/dist/mcp/transport/stdio.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/transport/stdio.js +0 -263
- package/v3/@claude-flow/shared/dist/mcp/transport/stdio.js.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/transport/websocket.d.ts +0 -133
- package/v3/@claude-flow/shared/dist/mcp/transport/websocket.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/transport/websocket.js +0 -396
- package/v3/@claude-flow/shared/dist/mcp/transport/websocket.js.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/types.d.ts +0 -438
- package/v3/@claude-flow/shared/dist/mcp/types.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/mcp/types.js +0 -54
- package/v3/@claude-flow/shared/dist/mcp/types.js.map +0 -1
- package/v3/@claude-flow/shared/dist/plugin-interface.d.ts +0 -544
- package/v3/@claude-flow/shared/dist/plugin-interface.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/plugin-interface.js +0 -23
- package/v3/@claude-flow/shared/dist/plugin-interface.js.map +0 -1
- package/v3/@claude-flow/shared/dist/plugin-loader.d.ts +0 -139
- package/v3/@claude-flow/shared/dist/plugin-loader.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/plugin-loader.js +0 -434
- package/v3/@claude-flow/shared/dist/plugin-loader.js.map +0 -1
- package/v3/@claude-flow/shared/dist/plugin-registry.d.ts +0 -183
- package/v3/@claude-flow/shared/dist/plugin-registry.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/plugin-registry.js +0 -457
- package/v3/@claude-flow/shared/dist/plugin-registry.js.map +0 -1
- package/v3/@claude-flow/shared/dist/plugins/index.d.ts +0 -10
- package/v3/@claude-flow/shared/dist/plugins/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/plugins/index.js +0 -10
- package/v3/@claude-flow/shared/dist/plugins/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.d.ts +0 -106
- package/v3/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.js +0 -241
- package/v3/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.js.map +0 -1
- package/v3/@claude-flow/shared/dist/plugins/official/index.d.ts +0 -10
- package/v3/@claude-flow/shared/dist/plugins/official/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/plugins/official/index.js +0 -10
- package/v3/@claude-flow/shared/dist/plugins/official/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/plugins/official/maestro-plugin.d.ts +0 -121
- package/v3/@claude-flow/shared/dist/plugins/official/maestro-plugin.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/plugins/official/maestro-plugin.js +0 -355
- package/v3/@claude-flow/shared/dist/plugins/official/maestro-plugin.js.map +0 -1
- package/v3/@claude-flow/shared/dist/plugins/types.d.ts +0 -93
- package/v3/@claude-flow/shared/dist/plugins/types.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/plugins/types.js +0 -9
- package/v3/@claude-flow/shared/dist/plugins/types.js.map +0 -1
- package/v3/@claude-flow/shared/dist/resilience/bulkhead.d.ts +0 -105
- package/v3/@claude-flow/shared/dist/resilience/bulkhead.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/resilience/bulkhead.js +0 -206
- package/v3/@claude-flow/shared/dist/resilience/bulkhead.js.map +0 -1
- package/v3/@claude-flow/shared/dist/resilience/circuit-breaker.d.ts +0 -132
- package/v3/@claude-flow/shared/dist/resilience/circuit-breaker.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/resilience/circuit-breaker.js +0 -233
- package/v3/@claude-flow/shared/dist/resilience/circuit-breaker.js.map +0 -1
- package/v3/@claude-flow/shared/dist/resilience/index.d.ts +0 -19
- package/v3/@claude-flow/shared/dist/resilience/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/resilience/index.js +0 -19
- package/v3/@claude-flow/shared/dist/resilience/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/resilience/rate-limiter.d.ts +0 -168
- package/v3/@claude-flow/shared/dist/resilience/rate-limiter.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/resilience/rate-limiter.js +0 -314
- package/v3/@claude-flow/shared/dist/resilience/rate-limiter.js.map +0 -1
- package/v3/@claude-flow/shared/dist/resilience/retry.d.ts +0 -91
- package/v3/@claude-flow/shared/dist/resilience/retry.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/resilience/retry.js +0 -159
- package/v3/@claude-flow/shared/dist/resilience/retry.js.map +0 -1
- package/v3/@claude-flow/shared/dist/security/index.d.ts +0 -10
- package/v3/@claude-flow/shared/dist/security/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/security/index.js +0 -12
- package/v3/@claude-flow/shared/dist/security/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/security/input-validation.d.ts +0 -73
- package/v3/@claude-flow/shared/dist/security/input-validation.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/security/input-validation.js +0 -201
- package/v3/@claude-flow/shared/dist/security/input-validation.js.map +0 -1
- package/v3/@claude-flow/shared/dist/security/secure-random.d.ts +0 -92
- package/v3/@claude-flow/shared/dist/security/secure-random.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/security/secure-random.js +0 -142
- package/v3/@claude-flow/shared/dist/security/secure-random.js.map +0 -1
- package/v3/@claude-flow/shared/dist/types/agent.types.d.ts +0 -137
- package/v3/@claude-flow/shared/dist/types/agent.types.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/types/agent.types.js +0 -6
- package/v3/@claude-flow/shared/dist/types/agent.types.js.map +0 -1
- package/v3/@claude-flow/shared/dist/types/index.d.ts +0 -11
- package/v3/@claude-flow/shared/dist/types/index.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/types/index.js +0 -17
- package/v3/@claude-flow/shared/dist/types/index.js.map +0 -1
- package/v3/@claude-flow/shared/dist/types/mcp.types.d.ts +0 -266
- package/v3/@claude-flow/shared/dist/types/mcp.types.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/types/mcp.types.js +0 -7
- package/v3/@claude-flow/shared/dist/types/mcp.types.js.map +0 -1
- package/v3/@claude-flow/shared/dist/types/memory.types.d.ts +0 -236
- package/v3/@claude-flow/shared/dist/types/memory.types.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/types/memory.types.js +0 -7
- package/v3/@claude-flow/shared/dist/types/memory.types.js.map +0 -1
- package/v3/@claude-flow/shared/dist/types/swarm.types.d.ts +0 -186
- package/v3/@claude-flow/shared/dist/types/swarm.types.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/types/swarm.types.js +0 -65
- package/v3/@claude-flow/shared/dist/types/swarm.types.js.map +0 -1
- package/v3/@claude-flow/shared/dist/types/task.types.d.ts +0 -178
- package/v3/@claude-flow/shared/dist/types/task.types.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/types/task.types.js +0 -32
- package/v3/@claude-flow/shared/dist/types/task.types.js.map +0 -1
- package/v3/@claude-flow/shared/dist/types.d.ts +0 -197
- package/v3/@claude-flow/shared/dist/types.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/types.js +0 -21
- package/v3/@claude-flow/shared/dist/types.js.map +0 -1
- package/v3/@claude-flow/shared/dist/utils/secure-logger.d.ts +0 -69
- package/v3/@claude-flow/shared/dist/utils/secure-logger.d.ts.map +0 -1
- package/v3/@claude-flow/shared/dist/utils/secure-logger.js +0 -208
- package/v3/@claude-flow/shared/dist/utils/secure-logger.js.map +0 -1
- package/v3/@claude-flow/shared/package.json +0 -34
- package/v3/README.md +0 -493
|
@@ -1,929 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Graph Analyzer Module
|
|
3
|
-
*
|
|
4
|
-
* Provides code dependency graph analysis using ruvector's graph algorithms:
|
|
5
|
-
* - MinCut for code boundary detection (refactoring suggestions)
|
|
6
|
-
* - Louvain for module/community detection
|
|
7
|
-
* - Circular dependency detection
|
|
8
|
-
* - DOT format export for visualization
|
|
9
|
-
*
|
|
10
|
-
* Falls back to built-in implementations when @ruvector/wasm is not available.
|
|
11
|
-
*
|
|
12
|
-
* @module @claude-flow/cli/ruvector/graph-analyzer
|
|
13
|
-
*/
|
|
14
|
-
import { readFile, readdir, stat } from 'fs/promises';
|
|
15
|
-
import { join, relative, extname, dirname, basename } from 'path';
|
|
16
|
-
// ============================================================================
|
|
17
|
-
// Caching for Performance
|
|
18
|
-
// ============================================================================
|
|
19
|
-
/**
|
|
20
|
-
* Cache for dependency graphs (5 minute TTL)
|
|
21
|
-
*/
|
|
22
|
-
const graphCache = new Map();
|
|
23
|
-
const GRAPH_CACHE_TTL_MS = 5 * 60 * 1000; // 5 minutes
|
|
24
|
-
/**
|
|
25
|
-
* Cache for analysis results (2 minute TTL)
|
|
26
|
-
*/
|
|
27
|
-
const analysisResultCache = new Map();
|
|
28
|
-
const ANALYSIS_CACHE_TTL_MS = 2 * 60 * 1000; // 2 minutes
|
|
29
|
-
/**
|
|
30
|
-
* Clear all graph caches
|
|
31
|
-
*/
|
|
32
|
-
export function clearGraphCaches() {
|
|
33
|
-
graphCache.clear();
|
|
34
|
-
analysisResultCache.clear();
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Get cache statistics
|
|
38
|
-
*/
|
|
39
|
-
export function getGraphCacheStats() {
|
|
40
|
-
return {
|
|
41
|
-
graphCacheSize: graphCache.size,
|
|
42
|
-
analysisCacheSize: analysisResultCache.size,
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
let ruVectorGraph = null;
|
|
46
|
-
let ruVectorLoadAttempted = false;
|
|
47
|
-
/**
|
|
48
|
-
* Attempt to load ruvector graph algorithms
|
|
49
|
-
*/
|
|
50
|
-
async function loadRuVector() {
|
|
51
|
-
if (ruVectorLoadAttempted)
|
|
52
|
-
return ruVectorGraph;
|
|
53
|
-
ruVectorLoadAttempted = true;
|
|
54
|
-
// Use dynamic module names to bypass TypeScript static analysis
|
|
55
|
-
// These modules are optional and may not be installed
|
|
56
|
-
const ruvectorModule = 'ruvector';
|
|
57
|
-
const wasmModule = '@ruvector/wasm';
|
|
58
|
-
try {
|
|
59
|
-
// Try to load ruvector's graph module
|
|
60
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
61
|
-
const ruvector = await import(/* webpackIgnore: true */ ruvectorModule).catch(() => null);
|
|
62
|
-
if (ruvector && typeof ruvector.hooks_graph_mincut === 'function' && typeof ruvector.hooks_graph_cluster === 'function') {
|
|
63
|
-
ruVectorGraph = {
|
|
64
|
-
mincut: (nodes, edges) => ruvector.hooks_graph_mincut(nodes, edges),
|
|
65
|
-
louvain: (nodes, edges) => ruvector.hooks_graph_cluster(nodes, edges),
|
|
66
|
-
};
|
|
67
|
-
return ruVectorGraph;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
catch {
|
|
71
|
-
// Try alternative import paths
|
|
72
|
-
try {
|
|
73
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
74
|
-
const wasm = await import(/* webpackIgnore: true */ wasmModule).catch(() => null);
|
|
75
|
-
if (wasm && wasm.GraphAnalyzer) {
|
|
76
|
-
const analyzer = new wasm.GraphAnalyzer();
|
|
77
|
-
ruVectorGraph = {
|
|
78
|
-
mincut: (nodes, edges) => analyzer.mincut(nodes, edges),
|
|
79
|
-
louvain: (nodes, edges) => analyzer.louvain(nodes, edges),
|
|
80
|
-
};
|
|
81
|
-
return ruVectorGraph;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
catch {
|
|
85
|
-
// Fallback will be used
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
return null;
|
|
89
|
-
}
|
|
90
|
-
// ============================================================================
|
|
91
|
-
// Import/Require Parser
|
|
92
|
-
// ============================================================================
|
|
93
|
-
/**
|
|
94
|
-
* Extract imports from TypeScript/JavaScript file
|
|
95
|
-
*/
|
|
96
|
-
function extractImports(content, _filePath) {
|
|
97
|
-
const imports = [];
|
|
98
|
-
// ES6 import statements
|
|
99
|
-
const esImportRegex = /import\s+(?:(?:\{[^}]*\}|\*\s+as\s+\w+|\w+)\s*,?\s*)*\s*from\s*['"]([^'"]+)['"]/g;
|
|
100
|
-
let match;
|
|
101
|
-
while ((match = esImportRegex.exec(content)) !== null) {
|
|
102
|
-
imports.push({ path: match[1], type: 'import' });
|
|
103
|
-
}
|
|
104
|
-
// Side-effect imports: import 'module'
|
|
105
|
-
const sideEffectRegex = /import\s+['"]([^'"]+)['"]/g;
|
|
106
|
-
while ((match = sideEffectRegex.exec(content)) !== null) {
|
|
107
|
-
imports.push({ path: match[1], type: 'import' });
|
|
108
|
-
}
|
|
109
|
-
// CommonJS require
|
|
110
|
-
const requireRegex = /require\s*\(\s*['"]([^'"]+)['"]\s*\)/g;
|
|
111
|
-
while ((match = requireRegex.exec(content)) !== null) {
|
|
112
|
-
imports.push({ path: match[1], type: 'require' });
|
|
113
|
-
}
|
|
114
|
-
// Dynamic imports
|
|
115
|
-
const dynamicImportRegex = /import\s*\(\s*['"]([^'"]+)['"]\s*\)/g;
|
|
116
|
-
while ((match = dynamicImportRegex.exec(content)) !== null) {
|
|
117
|
-
imports.push({ path: match[1], type: 'dynamic' });
|
|
118
|
-
}
|
|
119
|
-
// Re-exports: export * from 'module'
|
|
120
|
-
const reExportRegex = /export\s+(?:\*|\{[^}]*\})\s+from\s*['"]([^'"]+)['"]/g;
|
|
121
|
-
while ((match = reExportRegex.exec(content)) !== null) {
|
|
122
|
-
imports.push({ path: match[1], type: 're-export' });
|
|
123
|
-
}
|
|
124
|
-
return imports;
|
|
125
|
-
}
|
|
126
|
-
/**
|
|
127
|
-
* Extract exports from TypeScript/JavaScript file
|
|
128
|
-
*/
|
|
129
|
-
function extractExports(content) {
|
|
130
|
-
const exports = [];
|
|
131
|
-
// Named exports
|
|
132
|
-
const namedExportRegex = /export\s+(?:const|let|var|function|class|interface|type|enum)\s+(\w+)/g;
|
|
133
|
-
let match;
|
|
134
|
-
while ((match = namedExportRegex.exec(content)) !== null) {
|
|
135
|
-
exports.push(match[1]);
|
|
136
|
-
}
|
|
137
|
-
// Export list: export { a, b, c }
|
|
138
|
-
const exportListRegex = /export\s+\{([^}]+)\}/g;
|
|
139
|
-
while ((match = exportListRegex.exec(content)) !== null) {
|
|
140
|
-
const names = match[1].split(',').map(n => n.trim().split(/\s+as\s+/)[0].trim());
|
|
141
|
-
exports.push(...names.filter(n => n));
|
|
142
|
-
}
|
|
143
|
-
// Default export
|
|
144
|
-
if (/export\s+default/.test(content)) {
|
|
145
|
-
exports.push('default');
|
|
146
|
-
}
|
|
147
|
-
return exports;
|
|
148
|
-
}
|
|
149
|
-
/**
|
|
150
|
-
* Resolve import path to absolute file path
|
|
151
|
-
*/
|
|
152
|
-
function resolveImportPath(importPath, fromFile, rootDir) {
|
|
153
|
-
// Skip external packages
|
|
154
|
-
if (!importPath.startsWith('.') && !importPath.startsWith('/')) {
|
|
155
|
-
return null;
|
|
156
|
-
}
|
|
157
|
-
const fromDir = dirname(fromFile);
|
|
158
|
-
let resolved;
|
|
159
|
-
if (importPath.startsWith('/')) {
|
|
160
|
-
resolved = join(rootDir, importPath);
|
|
161
|
-
}
|
|
162
|
-
else {
|
|
163
|
-
resolved = join(fromDir, importPath);
|
|
164
|
-
}
|
|
165
|
-
// Handle extension-less imports
|
|
166
|
-
const ext = extname(resolved);
|
|
167
|
-
if (!ext) {
|
|
168
|
-
// Try common extensions
|
|
169
|
-
const extensions = ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.cjs'];
|
|
170
|
-
for (const tryExt of extensions) {
|
|
171
|
-
const tryPath = resolved + tryExt;
|
|
172
|
-
return tryPath; // Return normalized, existence check done later
|
|
173
|
-
}
|
|
174
|
-
// Could be index file
|
|
175
|
-
return join(resolved, 'index');
|
|
176
|
-
}
|
|
177
|
-
return resolved;
|
|
178
|
-
}
|
|
179
|
-
// ============================================================================
|
|
180
|
-
// Graph Builder
|
|
181
|
-
// ============================================================================
|
|
182
|
-
/**
|
|
183
|
-
* Build dependency graph from source directory (with caching)
|
|
184
|
-
*/
|
|
185
|
-
export async function buildDependencyGraph(rootDir, options = {}) {
|
|
186
|
-
// Check cache first
|
|
187
|
-
const cacheKey = `${rootDir}:${JSON.stringify(options)}`;
|
|
188
|
-
if (!options.skipCache) {
|
|
189
|
-
const cached = graphCache.get(cacheKey);
|
|
190
|
-
if (cached && Date.now() - cached.timestamp < GRAPH_CACHE_TTL_MS) {
|
|
191
|
-
return cached.graph;
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
const startTime = Date.now();
|
|
195
|
-
const nodes = new Map();
|
|
196
|
-
const edges = [];
|
|
197
|
-
const include = options.include || ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.cjs'];
|
|
198
|
-
const exclude = options.exclude || ['node_modules', 'dist', 'build', '.git', '__tests__', '*.test.*', '*.spec.*'];
|
|
199
|
-
const maxDepth = options.maxDepth ?? 10;
|
|
200
|
-
/**
|
|
201
|
-
* Check if path should be excluded
|
|
202
|
-
*/
|
|
203
|
-
function shouldExclude(path) {
|
|
204
|
-
const name = basename(path);
|
|
205
|
-
return exclude.some(pattern => {
|
|
206
|
-
if (pattern.includes('*')) {
|
|
207
|
-
const regex = new RegExp('^' + pattern.replace(/\*/g, '.*') + '$');
|
|
208
|
-
return regex.test(name);
|
|
209
|
-
}
|
|
210
|
-
return name === pattern || path.includes(`/${pattern}/`);
|
|
211
|
-
});
|
|
212
|
-
}
|
|
213
|
-
/**
|
|
214
|
-
* Recursively scan directory for source files
|
|
215
|
-
*/
|
|
216
|
-
async function scanDir(dir, depth) {
|
|
217
|
-
if (depth > maxDepth)
|
|
218
|
-
return;
|
|
219
|
-
try {
|
|
220
|
-
const entries = await readdir(dir, { withFileTypes: true });
|
|
221
|
-
for (const entry of entries) {
|
|
222
|
-
const fullPath = join(dir, entry.name);
|
|
223
|
-
const relPath = relative(rootDir, fullPath);
|
|
224
|
-
if (shouldExclude(fullPath))
|
|
225
|
-
continue;
|
|
226
|
-
if (entry.isDirectory()) {
|
|
227
|
-
await scanDir(fullPath, depth + 1);
|
|
228
|
-
}
|
|
229
|
-
else if (entry.isFile()) {
|
|
230
|
-
const ext = extname(entry.name);
|
|
231
|
-
if (include.includes(ext)) {
|
|
232
|
-
await processFile(fullPath, relPath);
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
catch {
|
|
238
|
-
// Directory not readable, skip
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
/**
|
|
242
|
-
* Process a single source file
|
|
243
|
-
*/
|
|
244
|
-
async function processFile(fullPath, relPath) {
|
|
245
|
-
try {
|
|
246
|
-
const content = await readFile(fullPath, 'utf-8');
|
|
247
|
-
const fileStats = await stat(fullPath);
|
|
248
|
-
const imports = extractImports(content, fullPath);
|
|
249
|
-
const exportsList = extractExports(content);
|
|
250
|
-
// Create node
|
|
251
|
-
const node = {
|
|
252
|
-
id: relPath,
|
|
253
|
-
path: relPath,
|
|
254
|
-
name: basename(relPath, extname(relPath)),
|
|
255
|
-
type: 'file',
|
|
256
|
-
imports: imports.map(i => i.path),
|
|
257
|
-
exports: exportsList,
|
|
258
|
-
size: fileStats.size,
|
|
259
|
-
complexity: estimateComplexity(content),
|
|
260
|
-
};
|
|
261
|
-
nodes.set(relPath, node);
|
|
262
|
-
// Create edges for imports
|
|
263
|
-
for (const imp of imports) {
|
|
264
|
-
const resolved = resolveImportPath(imp.path, fullPath, rootDir);
|
|
265
|
-
if (resolved) {
|
|
266
|
-
const targetRel = relative(rootDir, resolved);
|
|
267
|
-
edges.push({
|
|
268
|
-
source: relPath,
|
|
269
|
-
target: targetRel,
|
|
270
|
-
type: imp.type,
|
|
271
|
-
weight: imp.type === 're-export' ? 2 : 1,
|
|
272
|
-
});
|
|
273
|
-
}
|
|
274
|
-
}
|
|
275
|
-
}
|
|
276
|
-
catch {
|
|
277
|
-
// File not readable, skip
|
|
278
|
-
}
|
|
279
|
-
}
|
|
280
|
-
// Build the graph
|
|
281
|
-
await scanDir(rootDir, 0);
|
|
282
|
-
// Normalize edges - ensure targets exist (with extension variations)
|
|
283
|
-
const normalizedEdges = [];
|
|
284
|
-
for (const edge of edges) {
|
|
285
|
-
// Try to find matching node
|
|
286
|
-
let targetKey = edge.target;
|
|
287
|
-
if (!nodes.has(targetKey)) {
|
|
288
|
-
// Try with different extensions
|
|
289
|
-
const extensions = ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.cjs'];
|
|
290
|
-
const baseTarget = targetKey.replace(/\.[^.]+$/, '');
|
|
291
|
-
for (const ext of extensions) {
|
|
292
|
-
if (nodes.has(baseTarget + ext)) {
|
|
293
|
-
targetKey = baseTarget + ext;
|
|
294
|
-
break;
|
|
295
|
-
}
|
|
296
|
-
// Try index files
|
|
297
|
-
if (nodes.has(join(baseTarget, 'index' + ext))) {
|
|
298
|
-
targetKey = join(baseTarget, 'index' + ext);
|
|
299
|
-
break;
|
|
300
|
-
}
|
|
301
|
-
}
|
|
302
|
-
}
|
|
303
|
-
if (nodes.has(targetKey)) {
|
|
304
|
-
normalizedEdges.push({ ...edge, target: targetKey });
|
|
305
|
-
}
|
|
306
|
-
}
|
|
307
|
-
const graph = {
|
|
308
|
-
nodes,
|
|
309
|
-
edges: normalizedEdges,
|
|
310
|
-
metadata: {
|
|
311
|
-
rootDir,
|
|
312
|
-
totalFiles: nodes.size,
|
|
313
|
-
totalEdges: normalizedEdges.length,
|
|
314
|
-
buildTime: Date.now() - startTime,
|
|
315
|
-
},
|
|
316
|
-
};
|
|
317
|
-
// Cache the result
|
|
318
|
-
graphCache.set(cacheKey, { graph, timestamp: Date.now() });
|
|
319
|
-
return graph;
|
|
320
|
-
}
|
|
321
|
-
/**
|
|
322
|
-
* Estimate cyclomatic complexity from code
|
|
323
|
-
*/
|
|
324
|
-
function estimateComplexity(content) {
|
|
325
|
-
let complexity = 1;
|
|
326
|
-
// Count branching statements
|
|
327
|
-
const patterns = [
|
|
328
|
-
/\bif\s*\(/g,
|
|
329
|
-
/\belse\s+if\s*\(/g,
|
|
330
|
-
/\bfor\s*\(/g,
|
|
331
|
-
/\bwhile\s*\(/g,
|
|
332
|
-
/\bcase\s+/g,
|
|
333
|
-
/\bcatch\s*\(/g,
|
|
334
|
-
/\?\s*[^:]+:/g, // Ternary operator
|
|
335
|
-
/&&/g,
|
|
336
|
-
/\|\|/g,
|
|
337
|
-
];
|
|
338
|
-
for (const pattern of patterns) {
|
|
339
|
-
const matches = content.match(pattern);
|
|
340
|
-
if (matches)
|
|
341
|
-
complexity += matches.length;
|
|
342
|
-
}
|
|
343
|
-
return complexity;
|
|
344
|
-
}
|
|
345
|
-
// ============================================================================
|
|
346
|
-
// MinCut Algorithm (Fallback Implementation)
|
|
347
|
-
// ============================================================================
|
|
348
|
-
/**
|
|
349
|
-
* Stoer-Wagner MinCut algorithm (fallback when ruvector not available)
|
|
350
|
-
* Finds minimum cut with deterministic result
|
|
351
|
-
*/
|
|
352
|
-
function fallbackMinCut(nodes, edges) {
|
|
353
|
-
if (nodes.length < 2) {
|
|
354
|
-
return {
|
|
355
|
-
cutValue: 0,
|
|
356
|
-
partition1: nodes,
|
|
357
|
-
partition2: [],
|
|
358
|
-
cutEdges: [],
|
|
359
|
-
};
|
|
360
|
-
}
|
|
361
|
-
// Build adjacency map with weights
|
|
362
|
-
const adj = new Map();
|
|
363
|
-
for (const node of nodes) {
|
|
364
|
-
adj.set(node, new Map());
|
|
365
|
-
}
|
|
366
|
-
for (const [u, v, w] of edges) {
|
|
367
|
-
if (adj.has(u) && adj.has(v)) {
|
|
368
|
-
adj.get(u).set(v, (adj.get(u).get(v) || 0) + w);
|
|
369
|
-
adj.get(v).set(u, (adj.get(v).get(u) || 0) + w);
|
|
370
|
-
}
|
|
371
|
-
}
|
|
372
|
-
let bestCut = Infinity;
|
|
373
|
-
let bestPartition1 = [];
|
|
374
|
-
let bestPartition2 = [];
|
|
375
|
-
let bestCutEdges = [];
|
|
376
|
-
// Run multiple iterations for better results
|
|
377
|
-
const iterations = Math.min(nodes.length * 2, 20);
|
|
378
|
-
for (let iter = 0; iter < iterations; iter++) {
|
|
379
|
-
// Start from different nodes
|
|
380
|
-
const startNode = nodes[iter % nodes.length];
|
|
381
|
-
const inSet = new Set([startNode]);
|
|
382
|
-
const remaining = new Set(nodes.filter(n => n !== startNode));
|
|
383
|
-
while (remaining.size > 1) {
|
|
384
|
-
// Find node with maximum connectivity to current set
|
|
385
|
-
let maxNode = '';
|
|
386
|
-
let maxConn = -1;
|
|
387
|
-
for (const node of Array.from(remaining)) {
|
|
388
|
-
let conn = 0;
|
|
389
|
-
for (const inNode of Array.from(inSet)) {
|
|
390
|
-
conn += adj.get(node)?.get(inNode) || 0;
|
|
391
|
-
}
|
|
392
|
-
if (conn > maxConn) {
|
|
393
|
-
maxConn = conn;
|
|
394
|
-
maxNode = node;
|
|
395
|
-
}
|
|
396
|
-
}
|
|
397
|
-
if (!maxNode)
|
|
398
|
-
break;
|
|
399
|
-
remaining.delete(maxNode);
|
|
400
|
-
inSet.add(maxNode);
|
|
401
|
-
}
|
|
402
|
-
if (remaining.size === 1) {
|
|
403
|
-
const lastNode = Array.from(remaining)[0];
|
|
404
|
-
let cutValue = 0;
|
|
405
|
-
const cutEdges = [];
|
|
406
|
-
for (const inNode of Array.from(inSet)) {
|
|
407
|
-
const weight = adj.get(lastNode)?.get(inNode) || 0;
|
|
408
|
-
if (weight > 0) {
|
|
409
|
-
cutValue += weight;
|
|
410
|
-
cutEdges.push([lastNode, inNode]);
|
|
411
|
-
}
|
|
412
|
-
}
|
|
413
|
-
if (cutValue < bestCut) {
|
|
414
|
-
bestCut = cutValue;
|
|
415
|
-
bestPartition1 = Array.from(inSet);
|
|
416
|
-
bestPartition2 = [lastNode];
|
|
417
|
-
bestCutEdges = cutEdges;
|
|
418
|
-
}
|
|
419
|
-
}
|
|
420
|
-
}
|
|
421
|
-
// If we didn't find a good cut, split roughly in half
|
|
422
|
-
if (bestCut === Infinity) {
|
|
423
|
-
const mid = Math.floor(nodes.length / 2);
|
|
424
|
-
bestPartition1 = nodes.slice(0, mid);
|
|
425
|
-
bestPartition2 = nodes.slice(mid);
|
|
426
|
-
bestCut = 0;
|
|
427
|
-
bestCutEdges = [];
|
|
428
|
-
for (const [u, v, w] of edges) {
|
|
429
|
-
const uIn1 = bestPartition1.includes(u);
|
|
430
|
-
const vIn1 = bestPartition1.includes(v);
|
|
431
|
-
if (uIn1 !== vIn1) {
|
|
432
|
-
bestCut += w;
|
|
433
|
-
bestCutEdges.push([u, v]);
|
|
434
|
-
}
|
|
435
|
-
}
|
|
436
|
-
}
|
|
437
|
-
return {
|
|
438
|
-
cutValue: bestCut,
|
|
439
|
-
partition1: bestPartition1,
|
|
440
|
-
partition2: bestPartition2,
|
|
441
|
-
cutEdges: bestCutEdges,
|
|
442
|
-
};
|
|
443
|
-
}
|
|
444
|
-
// ============================================================================
|
|
445
|
-
// Louvain Algorithm (Fallback Implementation)
|
|
446
|
-
// ============================================================================
|
|
447
|
-
/**
|
|
448
|
-
* Louvain community detection algorithm (fallback when ruvector not available)
|
|
449
|
-
* Greedy modularity optimization
|
|
450
|
-
*/
|
|
451
|
-
function fallbackLouvain(nodes, edges) {
|
|
452
|
-
if (nodes.length === 0) {
|
|
453
|
-
return { communities: [], modularity: 0 };
|
|
454
|
-
}
|
|
455
|
-
// Build adjacency map
|
|
456
|
-
const adj = new Map();
|
|
457
|
-
for (const node of nodes) {
|
|
458
|
-
adj.set(node, new Map());
|
|
459
|
-
}
|
|
460
|
-
let totalWeight = 0;
|
|
461
|
-
for (const [u, v, w] of edges) {
|
|
462
|
-
if (adj.has(u) && adj.has(v)) {
|
|
463
|
-
adj.get(u).set(v, (adj.get(u).get(v) || 0) + w);
|
|
464
|
-
adj.get(v).set(u, (adj.get(v).get(u) || 0) + w);
|
|
465
|
-
totalWeight += w * 2;
|
|
466
|
-
}
|
|
467
|
-
}
|
|
468
|
-
if (totalWeight === 0) {
|
|
469
|
-
// No edges, each node is its own community
|
|
470
|
-
return {
|
|
471
|
-
communities: nodes.map((n, i) => ({ id: i, members: [n] })),
|
|
472
|
-
modularity: 0,
|
|
473
|
-
};
|
|
474
|
-
}
|
|
475
|
-
// Initialize: each node in its own community
|
|
476
|
-
const community = new Map();
|
|
477
|
-
let nextCommunityId = 0;
|
|
478
|
-
for (const node of nodes) {
|
|
479
|
-
community.set(node, nextCommunityId++);
|
|
480
|
-
}
|
|
481
|
-
// Calculate node degree
|
|
482
|
-
const degree = new Map();
|
|
483
|
-
for (const node of nodes) {
|
|
484
|
-
let d = 0;
|
|
485
|
-
for (const [, w] of Array.from(adj.get(node).entries())) {
|
|
486
|
-
d += w;
|
|
487
|
-
}
|
|
488
|
-
degree.set(node, d);
|
|
489
|
-
}
|
|
490
|
-
// Louvain phase 1: local moving
|
|
491
|
-
let improved = true;
|
|
492
|
-
const maxIterations = 10;
|
|
493
|
-
let iteration = 0;
|
|
494
|
-
while (improved && iteration < maxIterations) {
|
|
495
|
-
improved = false;
|
|
496
|
-
iteration++;
|
|
497
|
-
for (const node of nodes) {
|
|
498
|
-
const currentCommunity = community.get(node);
|
|
499
|
-
const nodeAdj = adj.get(node);
|
|
500
|
-
const nodeDegree = degree.get(node);
|
|
501
|
-
// Calculate modularity gain for moving to each neighbor's community
|
|
502
|
-
const communityWeights = new Map();
|
|
503
|
-
for (const [neighbor, weight] of Array.from(nodeAdj.entries())) {
|
|
504
|
-
const neighborCommunity = community.get(neighbor);
|
|
505
|
-
communityWeights.set(neighborCommunity, (communityWeights.get(neighborCommunity) || 0) + weight);
|
|
506
|
-
}
|
|
507
|
-
// Calculate community totals
|
|
508
|
-
const communityTotal = new Map();
|
|
509
|
-
for (const [n, c] of Array.from(community.entries())) {
|
|
510
|
-
communityTotal.set(c, (communityTotal.get(c) || 0) + (degree.get(n) || 0));
|
|
511
|
-
}
|
|
512
|
-
let bestCommunity = currentCommunity;
|
|
513
|
-
let bestGain = 0;
|
|
514
|
-
for (const [targetCommunity, edgeWeight] of Array.from(communityWeights.entries())) {
|
|
515
|
-
if (targetCommunity === currentCommunity)
|
|
516
|
-
continue;
|
|
517
|
-
// Calculate modularity gain
|
|
518
|
-
const currentTotal = communityTotal.get(currentCommunity) || 0;
|
|
519
|
-
const targetTotal = communityTotal.get(targetCommunity) || 0;
|
|
520
|
-
const currentEdges = communityWeights.get(currentCommunity) || 0;
|
|
521
|
-
const gain = (edgeWeight - currentEdges) / totalWeight -
|
|
522
|
-
(nodeDegree * (targetTotal - currentTotal + nodeDegree)) / (totalWeight * totalWeight);
|
|
523
|
-
if (gain > bestGain) {
|
|
524
|
-
bestGain = gain;
|
|
525
|
-
bestCommunity = targetCommunity;
|
|
526
|
-
}
|
|
527
|
-
}
|
|
528
|
-
if (bestCommunity !== currentCommunity) {
|
|
529
|
-
community.set(node, bestCommunity);
|
|
530
|
-
improved = true;
|
|
531
|
-
}
|
|
532
|
-
}
|
|
533
|
-
}
|
|
534
|
-
// Collect communities
|
|
535
|
-
const communityMembers = new Map();
|
|
536
|
-
for (const [node, comm] of Array.from(community.entries())) {
|
|
537
|
-
if (!communityMembers.has(comm)) {
|
|
538
|
-
communityMembers.set(comm, []);
|
|
539
|
-
}
|
|
540
|
-
communityMembers.get(comm).push(node);
|
|
541
|
-
}
|
|
542
|
-
// Renumber communities
|
|
543
|
-
const communities = [];
|
|
544
|
-
let id = 0;
|
|
545
|
-
for (const members of Array.from(communityMembers.values())) {
|
|
546
|
-
communities.push({ id: id++, members });
|
|
547
|
-
}
|
|
548
|
-
// Calculate modularity
|
|
549
|
-
let modularity = 0;
|
|
550
|
-
for (const [u, v, w] of edges) {
|
|
551
|
-
const cu = community.get(u);
|
|
552
|
-
const cv = community.get(v);
|
|
553
|
-
if (cu === cv) {
|
|
554
|
-
const du = degree.get(u);
|
|
555
|
-
const dv = degree.get(v);
|
|
556
|
-
modularity += w - (du * dv) / totalWeight;
|
|
557
|
-
}
|
|
558
|
-
}
|
|
559
|
-
modularity /= totalWeight;
|
|
560
|
-
return { communities, modularity };
|
|
561
|
-
}
|
|
562
|
-
// ============================================================================
|
|
563
|
-
// Circular Dependency Detection
|
|
564
|
-
// ============================================================================
|
|
565
|
-
/**
|
|
566
|
-
* Detect circular dependencies using DFS
|
|
567
|
-
*/
|
|
568
|
-
export function detectCircularDependencies(graph) {
|
|
569
|
-
const cycles = [];
|
|
570
|
-
const visited = new Set();
|
|
571
|
-
const recursionStack = new Set();
|
|
572
|
-
const path = [];
|
|
573
|
-
// Build adjacency list
|
|
574
|
-
const adjList = new Map();
|
|
575
|
-
for (const node of Array.from(graph.nodes.keys())) {
|
|
576
|
-
adjList.set(node, []);
|
|
577
|
-
}
|
|
578
|
-
for (const edge of graph.edges) {
|
|
579
|
-
const list = adjList.get(edge.source);
|
|
580
|
-
if (list) {
|
|
581
|
-
list.push(edge.target);
|
|
582
|
-
}
|
|
583
|
-
}
|
|
584
|
-
function dfs(node) {
|
|
585
|
-
visited.add(node);
|
|
586
|
-
recursionStack.add(node);
|
|
587
|
-
path.push(node);
|
|
588
|
-
const neighbors = adjList.get(node) || [];
|
|
589
|
-
for (const neighbor of neighbors) {
|
|
590
|
-
if (!visited.has(neighbor)) {
|
|
591
|
-
dfs(neighbor);
|
|
592
|
-
}
|
|
593
|
-
else if (recursionStack.has(neighbor)) {
|
|
594
|
-
// Found cycle
|
|
595
|
-
const cycleStart = path.indexOf(neighbor);
|
|
596
|
-
const cycle = path.slice(cycleStart);
|
|
597
|
-
cycle.push(neighbor); // Complete the cycle
|
|
598
|
-
const severity = getCycleSeverity(cycle, graph);
|
|
599
|
-
cycles.push({
|
|
600
|
-
cycle,
|
|
601
|
-
severity,
|
|
602
|
-
suggestion: getCycleSuggestion(cycle, graph),
|
|
603
|
-
});
|
|
604
|
-
}
|
|
605
|
-
}
|
|
606
|
-
recursionStack.delete(node);
|
|
607
|
-
path.pop();
|
|
608
|
-
}
|
|
609
|
-
for (const node of Array.from(graph.nodes.keys())) {
|
|
610
|
-
if (!visited.has(node)) {
|
|
611
|
-
dfs(node);
|
|
612
|
-
}
|
|
613
|
-
}
|
|
614
|
-
return cycles;
|
|
615
|
-
}
|
|
616
|
-
function getCycleSeverity(cycle, _graph) {
|
|
617
|
-
// High severity if cycle involves many files or core modules
|
|
618
|
-
if (cycle.length > 5)
|
|
619
|
-
return 'high';
|
|
620
|
-
if (cycle.some(n => n.includes('index') || n.includes('core')))
|
|
621
|
-
return 'high';
|
|
622
|
-
if (cycle.length > 3)
|
|
623
|
-
return 'medium';
|
|
624
|
-
return 'low';
|
|
625
|
-
}
|
|
626
|
-
function getCycleSuggestion(cycle, graph) {
|
|
627
|
-
if (cycle.length === 2) {
|
|
628
|
-
return `Consider extracting shared code into a separate module to break the cycle between ${cycle[0]} and ${cycle[1]}`;
|
|
629
|
-
}
|
|
630
|
-
// Find the weakest link (least important edge)
|
|
631
|
-
let weakestEdge = '';
|
|
632
|
-
let minImports = Infinity;
|
|
633
|
-
for (let i = 0; i < cycle.length - 1; i++) {
|
|
634
|
-
const from = cycle[i];
|
|
635
|
-
const to = cycle[i + 1];
|
|
636
|
-
const fromNode = graph.nodes.get(from);
|
|
637
|
-
if (fromNode && fromNode.imports.length < minImports) {
|
|
638
|
-
minImports = fromNode.imports.length;
|
|
639
|
-
weakestEdge = `${from} -> ${to}`;
|
|
640
|
-
}
|
|
641
|
-
}
|
|
642
|
-
return `Break the cycle by refactoring the dependency: ${weakestEdge}. Consider dependency injection or extracting interfaces.`;
|
|
643
|
-
}
|
|
644
|
-
// ============================================================================
|
|
645
|
-
// Main Analysis Functions
|
|
646
|
-
// ============================================================================
|
|
647
|
-
/**
|
|
648
|
-
* Analyze graph boundaries using MinCut algorithm
|
|
649
|
-
*/
|
|
650
|
-
export async function analyzeMinCutBoundaries(graph, numPartitions = 2) {
|
|
651
|
-
const nodes = Array.from(graph.nodes.keys());
|
|
652
|
-
const edges = graph.edges.map(e => [e.source, e.target, e.weight]);
|
|
653
|
-
const boundaries = [];
|
|
654
|
-
// Try to use ruvector, fallback to built-in
|
|
655
|
-
const ruVector = await loadRuVector();
|
|
656
|
-
// Get initial partition
|
|
657
|
-
let result;
|
|
658
|
-
if (ruVector) {
|
|
659
|
-
result = ruVector.mincut(nodes, edges);
|
|
660
|
-
}
|
|
661
|
-
else {
|
|
662
|
-
result = fallbackMinCut(nodes, edges);
|
|
663
|
-
}
|
|
664
|
-
boundaries.push({
|
|
665
|
-
cutValue: result.cutValue,
|
|
666
|
-
partition1: result.partition1,
|
|
667
|
-
partition2: result.partition2,
|
|
668
|
-
cutEdges: result.cutEdges.map(([s, t]) => {
|
|
669
|
-
const edge = graph.edges.find(e => e.source === s && e.target === t);
|
|
670
|
-
return edge || { source: s, target: t, type: 'import', weight: 1 };
|
|
671
|
-
}),
|
|
672
|
-
suggestion: generateBoundarySuggestion(result.partition1, result.partition2, graph),
|
|
673
|
-
});
|
|
674
|
-
// Recursively partition if needed
|
|
675
|
-
if (numPartitions > 2 && result.partition1.length > 2) {
|
|
676
|
-
const subEdges = edges.filter(([u, v]) => result.partition1.includes(u) && result.partition1.includes(v));
|
|
677
|
-
const subResult = ruVector
|
|
678
|
-
? ruVector.mincut(result.partition1, subEdges)
|
|
679
|
-
: fallbackMinCut(result.partition1, subEdges);
|
|
680
|
-
if (subResult.cutValue > 0) {
|
|
681
|
-
boundaries.push({
|
|
682
|
-
cutValue: subResult.cutValue,
|
|
683
|
-
partition1: subResult.partition1,
|
|
684
|
-
partition2: subResult.partition2,
|
|
685
|
-
cutEdges: subResult.cutEdges.map(([s, t]) => {
|
|
686
|
-
const edge = graph.edges.find(e => e.source === s && e.target === t);
|
|
687
|
-
return edge || { source: s, target: t, type: 'import', weight: 1 };
|
|
688
|
-
}),
|
|
689
|
-
suggestion: generateBoundarySuggestion(subResult.partition1, subResult.partition2, graph),
|
|
690
|
-
});
|
|
691
|
-
}
|
|
692
|
-
}
|
|
693
|
-
return boundaries;
|
|
694
|
-
}
|
|
695
|
-
function generateBoundarySuggestion(partition1, partition2, _graph) {
|
|
696
|
-
// Analyze the partitions to suggest organization
|
|
697
|
-
const p1Dirs = partition1.map(p => dirname(p)).filter(d => d !== '.');
|
|
698
|
-
const p2Dirs = partition2.map(p => dirname(p)).filter(d => d !== '.');
|
|
699
|
-
const p1DirsSet = new Set(p1Dirs);
|
|
700
|
-
const p2DirsSet = new Set(p2Dirs);
|
|
701
|
-
if (p1DirsSet.size === 1 && p2DirsSet.size === 1) {
|
|
702
|
-
const dir1 = p1Dirs[0];
|
|
703
|
-
const dir2 = p2Dirs[0];
|
|
704
|
-
return `Natural boundary detected between ${dir1}/ and ${dir2}/. These could be separate packages.`;
|
|
705
|
-
}
|
|
706
|
-
if (partition1.length > partition2.length * 3) {
|
|
707
|
-
return `Consider extracting ${partition2.length} files into a separate module. They have minimal coupling to the rest.`;
|
|
708
|
-
}
|
|
709
|
-
return `Found ${partition1.length} and ${partition2.length} file groups with minimal coupling. Consider organizing into separate modules.`;
|
|
710
|
-
}
|
|
711
|
-
/**
|
|
712
|
-
* Analyze module communities using Louvain algorithm
|
|
713
|
-
*/
|
|
714
|
-
export async function analyzeModuleCommunities(graph) {
|
|
715
|
-
const nodes = Array.from(graph.nodes.keys());
|
|
716
|
-
const edges = graph.edges.map(e => [e.source, e.target, e.weight]);
|
|
717
|
-
// Try to use ruvector, fallback to built-in
|
|
718
|
-
const ruVector = await loadRuVector();
|
|
719
|
-
const result = ruVector ? ruVector.louvain(nodes, edges) : fallbackLouvain(nodes, edges);
|
|
720
|
-
return result.communities.map(comm => {
|
|
721
|
-
// Find the most connected node as central
|
|
722
|
-
let maxConnections = 0;
|
|
723
|
-
let centralNode = comm.members[0];
|
|
724
|
-
for (const member of comm.members) {
|
|
725
|
-
const connections = graph.edges.filter(e => (e.source === member && comm.members.includes(e.target)) ||
|
|
726
|
-
(e.target === member && comm.members.includes(e.source))).length;
|
|
727
|
-
if (connections > maxConnections) {
|
|
728
|
-
maxConnections = connections;
|
|
729
|
-
centralNode = member;
|
|
730
|
-
}
|
|
731
|
-
}
|
|
732
|
-
// Calculate cohesion (internal edges / total possible edges)
|
|
733
|
-
const internalEdges = graph.edges.filter(e => comm.members.includes(e.source) && comm.members.includes(e.target)).length;
|
|
734
|
-
const possibleEdges = (comm.members.length * (comm.members.length - 1)) / 2;
|
|
735
|
-
const cohesion = possibleEdges > 0 ? internalEdges / possibleEdges : 1;
|
|
736
|
-
// Suggest name based on common directory
|
|
737
|
-
const dirs = comm.members.map(m => dirname(m));
|
|
738
|
-
const commonDir = findCommonPrefix(dirs);
|
|
739
|
-
const suggestedName = commonDir || basename(centralNode, extname(centralNode));
|
|
740
|
-
return {
|
|
741
|
-
id: comm.id,
|
|
742
|
-
members: comm.members,
|
|
743
|
-
cohesion,
|
|
744
|
-
centralNode,
|
|
745
|
-
suggestedName,
|
|
746
|
-
};
|
|
747
|
-
});
|
|
748
|
-
}
|
|
749
|
-
function findCommonPrefix(strings) {
|
|
750
|
-
if (strings.length === 0)
|
|
751
|
-
return '';
|
|
752
|
-
if (strings.length === 1)
|
|
753
|
-
return strings[0];
|
|
754
|
-
const sorted = [...strings].sort();
|
|
755
|
-
const first = sorted[0];
|
|
756
|
-
const last = sorted[sorted.length - 1];
|
|
757
|
-
let i = 0;
|
|
758
|
-
while (i < first.length && first[i] === last[i]) {
|
|
759
|
-
i++;
|
|
760
|
-
}
|
|
761
|
-
const prefix = first.slice(0, i);
|
|
762
|
-
// Return the last complete directory segment
|
|
763
|
-
const lastSlash = prefix.lastIndexOf('/');
|
|
764
|
-
return lastSlash > 0 ? prefix.slice(0, lastSlash) : '';
|
|
765
|
-
}
|
|
766
|
-
/**
|
|
767
|
-
* Full graph analysis (with caching)
|
|
768
|
-
*/
|
|
769
|
-
export async function analyzeGraph(rootDir, options = {}) {
|
|
770
|
-
// Check cache first
|
|
771
|
-
const cacheKey = `analysis:${rootDir}:${JSON.stringify(options)}`;
|
|
772
|
-
if (!options.skipCache) {
|
|
773
|
-
const cached = analysisResultCache.get(cacheKey);
|
|
774
|
-
if (cached && Date.now() - cached.timestamp < ANALYSIS_CACHE_TTL_MS) {
|
|
775
|
-
return cached.result;
|
|
776
|
-
}
|
|
777
|
-
}
|
|
778
|
-
const graph = await buildDependencyGraph(rootDir, { skipCache: options.skipCache });
|
|
779
|
-
// Calculate statistics
|
|
780
|
-
const nodeCount = graph.nodes.size;
|
|
781
|
-
const edgeCount = graph.edges.length;
|
|
782
|
-
const degrees = new Map();
|
|
783
|
-
for (const node of Array.from(graph.nodes.keys())) {
|
|
784
|
-
degrees.set(node, 0);
|
|
785
|
-
}
|
|
786
|
-
for (const edge of graph.edges) {
|
|
787
|
-
degrees.set(edge.source, (degrees.get(edge.source) || 0) + 1);
|
|
788
|
-
degrees.set(edge.target, (degrees.get(edge.target) || 0) + 1);
|
|
789
|
-
}
|
|
790
|
-
const degreeValues = Array.from(degrees.values());
|
|
791
|
-
const avgDegree = degreeValues.length > 0 ? degreeValues.reduce((a, b) => a + b, 0) / degreeValues.length : 0;
|
|
792
|
-
const maxDegree = degreeValues.length > 0 ? Math.max(...degreeValues) : 0;
|
|
793
|
-
const density = nodeCount > 1 ? (2 * edgeCount) / (nodeCount * (nodeCount - 1)) : 0;
|
|
794
|
-
// Count connected components
|
|
795
|
-
const visited = new Set();
|
|
796
|
-
let componentCount = 0;
|
|
797
|
-
function dfs(node) {
|
|
798
|
-
visited.add(node);
|
|
799
|
-
for (const edge of graph.edges) {
|
|
800
|
-
if (edge.source === node && !visited.has(edge.target)) {
|
|
801
|
-
dfs(edge.target);
|
|
802
|
-
}
|
|
803
|
-
if (edge.target === node && !visited.has(edge.source)) {
|
|
804
|
-
dfs(edge.source);
|
|
805
|
-
}
|
|
806
|
-
}
|
|
807
|
-
}
|
|
808
|
-
for (const node of Array.from(graph.nodes.keys())) {
|
|
809
|
-
if (!visited.has(node)) {
|
|
810
|
-
componentCount++;
|
|
811
|
-
dfs(node);
|
|
812
|
-
}
|
|
813
|
-
}
|
|
814
|
-
// Detect circular dependencies
|
|
815
|
-
const circularDependencies = detectCircularDependencies(graph);
|
|
816
|
-
// Analyze boundaries and communities if requested
|
|
817
|
-
let boundaries;
|
|
818
|
-
let communities;
|
|
819
|
-
if (options.includeBoundaries !== false) {
|
|
820
|
-
boundaries = await analyzeMinCutBoundaries(graph, options.numPartitions);
|
|
821
|
-
}
|
|
822
|
-
if (options.includeModules !== false) {
|
|
823
|
-
communities = await analyzeModuleCommunities(graph);
|
|
824
|
-
}
|
|
825
|
-
const result = {
|
|
826
|
-
graph,
|
|
827
|
-
boundaries,
|
|
828
|
-
communities,
|
|
829
|
-
circularDependencies,
|
|
830
|
-
statistics: {
|
|
831
|
-
nodeCount,
|
|
832
|
-
edgeCount,
|
|
833
|
-
avgDegree,
|
|
834
|
-
maxDegree,
|
|
835
|
-
density,
|
|
836
|
-
componentCount,
|
|
837
|
-
},
|
|
838
|
-
};
|
|
839
|
-
// Cache the result
|
|
840
|
-
analysisResultCache.set(cacheKey, { result, timestamp: Date.now() });
|
|
841
|
-
return result;
|
|
842
|
-
}
|
|
843
|
-
// ============================================================================
|
|
844
|
-
// DOT Format Export
|
|
845
|
-
// ============================================================================
|
|
846
|
-
/**
|
|
847
|
-
* Export graph to DOT format for visualization
|
|
848
|
-
*/
|
|
849
|
-
export function exportToDot(result, options = {}) {
|
|
850
|
-
const { graph, communities, circularDependencies } = result;
|
|
851
|
-
const lines = ['digraph DependencyGraph {'];
|
|
852
|
-
lines.push(' rankdir=LR;');
|
|
853
|
-
lines.push(' node [shape=box, style=rounded];');
|
|
854
|
-
lines.push('');
|
|
855
|
-
// Generate colors for communities
|
|
856
|
-
const communityColors = new Map();
|
|
857
|
-
if (options.colorByCommunity && communities) {
|
|
858
|
-
const colors = [
|
|
859
|
-
'#e6194b', '#3cb44b', '#ffe119', '#4363d8', '#f58231',
|
|
860
|
-
'#911eb4', '#42d4f4', '#f032e6', '#bfef45', '#fabed4',
|
|
861
|
-
];
|
|
862
|
-
for (const comm of communities) {
|
|
863
|
-
const color = colors[comm.id % colors.length];
|
|
864
|
-
for (const member of comm.members) {
|
|
865
|
-
communityColors.set(member, color);
|
|
866
|
-
}
|
|
867
|
-
}
|
|
868
|
-
}
|
|
869
|
-
// Find nodes in cycles
|
|
870
|
-
const nodesInCycles = new Set();
|
|
871
|
-
if (options.highlightCycles && circularDependencies) {
|
|
872
|
-
for (const cycle of circularDependencies) {
|
|
873
|
-
for (const node of cycle.cycle) {
|
|
874
|
-
nodesInCycles.add(node);
|
|
875
|
-
}
|
|
876
|
-
}
|
|
877
|
-
}
|
|
878
|
-
// Output nodes
|
|
879
|
-
lines.push(' // Nodes');
|
|
880
|
-
for (const [id, node] of Array.from(graph.nodes.entries())) {
|
|
881
|
-
const attrs = [];
|
|
882
|
-
if (options.includeLabels !== false) {
|
|
883
|
-
attrs.push(`label="${node.name}"`);
|
|
884
|
-
}
|
|
885
|
-
if (communityColors.has(id)) {
|
|
886
|
-
attrs.push(`fillcolor="${communityColors.get(id)}"`, 'style="filled,rounded"');
|
|
887
|
-
}
|
|
888
|
-
if (nodesInCycles.has(id)) {
|
|
889
|
-
attrs.push('color=red', 'penwidth=2');
|
|
890
|
-
}
|
|
891
|
-
const attrStr = attrs.length > 0 ? ` [${attrs.join(', ')}]` : '';
|
|
892
|
-
lines.push(` "${id}"${attrStr};`);
|
|
893
|
-
}
|
|
894
|
-
lines.push('');
|
|
895
|
-
// Output edges
|
|
896
|
-
lines.push(' // Edges');
|
|
897
|
-
for (const edge of graph.edges) {
|
|
898
|
-
const attrs = [];
|
|
899
|
-
if (edge.type === 'dynamic') {
|
|
900
|
-
attrs.push('style=dashed');
|
|
901
|
-
}
|
|
902
|
-
else if (edge.type === 're-export') {
|
|
903
|
-
attrs.push('style=bold');
|
|
904
|
-
}
|
|
905
|
-
// Check if edge is part of a cycle
|
|
906
|
-
if (options.highlightCycles) {
|
|
907
|
-
const isCycleEdge = circularDependencies.some(cd => {
|
|
908
|
-
for (let i = 0; i < cd.cycle.length - 1; i++) {
|
|
909
|
-
if (cd.cycle[i] === edge.source && cd.cycle[i + 1] === edge.target) {
|
|
910
|
-
return true;
|
|
911
|
-
}
|
|
912
|
-
}
|
|
913
|
-
return false;
|
|
914
|
-
});
|
|
915
|
-
if (isCycleEdge) {
|
|
916
|
-
attrs.push('color=red', 'penwidth=2');
|
|
917
|
-
}
|
|
918
|
-
}
|
|
919
|
-
const attrStr = attrs.length > 0 ? ` [${attrs.join(', ')}]` : '';
|
|
920
|
-
lines.push(` "${edge.source}" -> "${edge.target}"${attrStr};`);
|
|
921
|
-
}
|
|
922
|
-
lines.push('}');
|
|
923
|
-
return lines.join('\n');
|
|
924
|
-
}
|
|
925
|
-
// ============================================================================
|
|
926
|
-
// Exports
|
|
927
|
-
// ============================================================================
|
|
928
|
-
export { loadRuVector, fallbackMinCut, fallbackLouvain, };
|
|
929
|
-
//# sourceMappingURL=graph-analyzer.js.map
|