claude-flow-novice 2.5.2 → 2.8.1
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/.claude/adaptive-context/cfn-v3-reflection.json +21 -0
- package/.claude/agents/AGENT_LIFECYCLE.md +495 -0
- package/.claude/agents/CLAUDE.md +1002 -1233
- package/.claude/agents/accessibility-advocate.md +457 -0
- package/.claude/agents/agent-principles/README.md +226 -226
- package/.claude/agents/agent-principles/agent-type-guidelines.md +10 -0
- package/.claude/agents/agent-principles/format-selection.md +10 -0
- package/.claude/agents/agent-principles/phase4-template-optimization.md +502 -494
- package/.claude/agents/agent-principles/prompt-engineering.md +8 -0
- package/.claude/agents/agent-principles/quality-metrics.md +8 -0
- package/.claude/agents/analysis/code-analyzer.md +7 -17
- package/.claude/agents/analysis/code-review/analyze-code-quality.md +2 -104
- package/.claude/agents/analysis/perf-analyzer.md +2 -196
- package/.claude/agents/context/context-curator.md +78 -84
- package/.claude/agents/context/context-reflector.md +27 -81
- package/.claude/agents/coordinators/README.md +42 -0
- package/.claude/agents/coordinators/cfn-v3-coordinator.md +440 -0
- package/.claude/agents/{product-owner-team → coordinators}/cto-agent.md +154 -187
- package/.claude/agents/coordinators/multi-sprint-coordinator.md +50 -0
- package/.claude/agents/{product-owner-team → coordinators}/product-owner-agent.md +6 -39
- package/.claude/agents/{cfn-loop → coordinators}/product-owner.md +72 -17
- package/.claude/agents/core-agents/reviewer.md +114 -135
- package/.claude/agents/custom/agent-builder.md +637 -0
- package/.claude/agents/developers/README.md +69 -0
- package/.claude/agents/developers/backend-dev.md +77 -0
- package/.claude/agents/{core-agents → developers}/coder.md +131 -26
- package/.claude/agents/developers/react-frontend-engineer.md +121 -0
- package/.claude/agents/{frontend → developers}/state-architect.md +1 -0
- package/.claude/agents/{frontend → developers}/ui-designer.md +1 -0
- package/.claude/agents/development/backend/dev-backend-api.md +0 -29
- package/.claude/agents/development/npm-package-specialist.md +355 -347
- package/.claude/agents/documentation/api-docs/docs-api-openapi.md +8 -0
- package/.claude/agents/documentation/api-docs.md +8 -0
- package/.claude/agents/github/github-commit-agent.md +125 -117
- package/.claude/agents/goal/goal-planner.md +8 -0
- package/.claude/agents/infrastructure/README.md +100 -0
- package/.claude/agents/{specialized → infrastructure}/devops-engineer.md +131 -150
- package/.claude/agents/planners/README.md +94 -0
- package/.claude/agents/{core-agents → planners}/analyst.md +1 -22
- package/.claude/agents/{planning-team → planners}/api-designer-persona.md +8 -0
- package/.claude/agents/{core-agents → planners}/architect.md +7 -20
- package/.claude/agents/{core-agents → planners}/planner.md +0 -21
- package/.claude/agents/{planning-team → planners}/security-architect-persona.md +8 -28
- package/.claude/agents/{planning-team → planners}/system-architect-persona.md +6 -38
- package/.claude/agents/{architecture → planners}/system-architect.md +12 -17
- package/.claude/agents/product-owner-team/accessibility-advocate-persona.md +132 -161
- package/.claude/agents/product-owner-team/power-user-persona.md +149 -182
- package/.claude/agents/retrospective-analyst.md +84 -0
- package/.claude/agents/reviewers/README.md +58 -0
- package/.claude/agents/{analysis → reviewers}/code-quality-validator.md +8 -17
- package/.claude/agents/reviewers/reviewer.md +181 -0
- package/.claude/agents/sparc/architecture.md +6 -25
- package/.claude/agents/sparc/pseudocode.md +6 -0
- package/.claude/agents/sparc/refinement.md +6 -0
- package/.claude/agents/sparc/specification.md +1 -0
- package/.claude/agents/specialists/README.md +60 -0
- package/.claude/agents/{core-agents → specialists}/base-template-generator.md +8 -21
- package/.claude/agents/{specialized → specialists}/cli-agent-optimizer.md +1 -1
- package/.claude/agents/{specialized → specialists}/code-booster.md +1 -0
- package/.claude/agents/{consensus → specialists}/consensus-builder.md +1 -17
- package/.claude/agents/{specialized/mobile → specialists}/mobile-dev.md +0 -20
- package/.claude/agents/{core-agents → specialists}/performance-benchmarker.md +134 -148
- package/.claude/agents/{specialized → specialists}/rust-developer.md +1 -20
- package/.claude/agents/{specialized → specialists}/rust-enterprise-developer.md +1 -20
- package/.claude/agents/{specialized → specialists}/rust-mvp-developer.md +1 -20
- package/.claude/agents/{core-agents → specialists}/security-manager.md +68 -88
- package/.claude/agents/{security → specialists}/security-specialist-existing.md +6 -57
- package/.claude/agents/{security → specialists}/security-specialist.md +6 -30
- package/.claude/agents/{specialized/mobile → specialists}/spec-mobile-react-native.md +2 -21
- package/.claude/agents/testers/README.md +94 -0
- package/.claude/agents/{testing → testers}/e2e/playwright-agent.md +1 -20
- package/.claude/agents/{testing → testers}/interaction-tester.md +1 -20
- package/.claude/agents/{testing → testers}/playwright-tester.md +1 -1
- package/.claude/agents/testers/tester.md +139 -0
- package/.claude/agents/testers/unit/tdd-london-swarm.md +49 -0
- package/.claude/agents/testers/validation/production-validator.md +33 -0
- package/.claude/agents-ignore/cfn-loop-coordinator.md +157 -0
- package/.claude/agents-ignore/cfn-loop-coordinator.md.backup +156 -0
- package/.claude/agents-ignore/coordinator.md.backup +182 -0
- package/.claude/agents-ignore/cost-savings-cfn-loop-coordinator.md +760 -0
- package/.claude/agents-ignore/cost-savings-coordinator.md +173 -0
- package/.claude/artifacts/ace-reflections/REFLECT-001-summary.json +39 -0
- package/.claude/artifacts/ace-reflections/sprint-7_$(date -u +/"%Y%m%d_%H%M%S/").json" +47 -0
- package/.claude/artifacts/reflection-merge-logs/cli-agent-spawning-v2.5.2-merge-report.md +61 -0
- package/.claude/commands/CFN_COORDINATOR_PARAMETERS.md +10 -10
- package/.claude/commands/cfn-loop-epic.md +43 -19
- package/.claude/commands/cfn-loop-single.md +3 -3
- package/.claude/commands/cfn-loop-sprints.md +1 -1
- package/.claude/commands/cfn-loop.md +45 -32
- package/.claude/commands/cfn-mode.md +20 -0
- package/.claude/commands/custom-routing-activate.md +37 -123
- package/.claude/commands/custom-routing-deactivate.md +27 -124
- package/.claude/commands/switch-api.md +41 -16
- package/.claude/commands/write-plan.md +104 -0
- package/.claude/data/cfn-loop.db +0 -0
- package/.claude/data/cfn_loop_logs.db +0 -0
- package/.claude/hooks/BACKUP_USAGE.md +243 -0
- package/.claude/hooks/post-edit-cfn-retrospective.sh +79 -0
- package/.claude/hooks/post-edit.sh +21 -0
- package/.claude/hooks/pre-edit-backup.sh +71 -0
- package/.claude/hooks/restore-from-backup.sh +37 -0
- package/.claude/prompts/cfn-loop-context.md +115 -0
- package/.claude/prompts/loop-specific/loop2.md +50 -0
- package/.claude/prompts/loop-specific/loop3.md +43 -0
- package/.claude/prompts/loop-specific/loop4.md +54 -0
- package/.claude/root-claude-distribute/CLAUDE.md +76 -2
- package/.claude/skills/ace-system/sprint-7-lessons.json +46 -0
- package/.claude/skills/ace-system/store-reflection.sh +33 -136
- package/.claude/skills/agent-discovery/SKILL.md +40 -0
- package/.claude/skills/agent-discovery/agents-registry-clean.json +0 -0
- package/.claude/skills/agent-discovery/agents-registry-fixed.json +19 -0
- package/.claude/skills/agent-discovery/agents-registry.json +718 -0
- package/.claude/skills/agent-discovery/discover-agents.py +175 -0
- package/.claude/skills/agent-discovery/discover-agents.sh +87 -0
- package/.claude/skills/agent-discovery/invoke-registry.sh +11 -0
- package/.claude/skills/agent-discovery/temp_script.py +0 -0
- package/.claude/skills/agent-execution/execute-agent.sh +126 -0
- package/.claude/skills/agent-output-processing/SKILL.md +359 -0
- package/.claude/skills/agent-selector/SKILL.md +90 -0
- package/.claude/skills/agent-selector/select-agents.sh +96 -0
- package/.claude/skills/agent-spawning/agent-selection-guide.md +1 -1
- package/.claude/skills/agent-swap/SKILL.md +36 -0
- package/.claude/skills/agent-swap/recommend-swap.sh +60 -0
- package/.claude/skills/api-validation/test-endpoints.sh +54 -0
- package/.claude/skills/automatic-memory-persistence/SKILL.md +73 -0
- package/.claude/skills/automatic-memory-persistence/persist-agent-output.sh +49 -0
- package/.claude/skills/automatic-memory-persistence/query-agent-history.sh +35 -0
- package/.claude/skills/automatic-memory-persistence/test-memory-persistence.sh +235 -0
- package/.claude/skills/cfn-loop-orchestration/README.md +41 -0
- package/.claude/skills/cfn-loop-orchestration/SKILL.md +299 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/auto-tune-timeouts.sh +228 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/consensus.sh +84 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/deliverable-verifier.sh +71 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/gate-check.sh +90 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/iteration-manager.sh +87 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/timeout-calculator.sh +51 -0
- package/.claude/skills/cfn-loop-orchestration/inject-loop-context.sh +41 -0
- package/.claude/skills/cfn-loop-orchestration/monitor-execution.sh +156 -0
- package/.claude/skills/cfn-loop-orchestration/orchestrate.sh +840 -0
- package/.claude/skills/cfn-loop-orchestration/security_utils.sh +99 -0
- package/.claude/skills/cfn-loop-orchestration/test-cfn-orchestration.sh +281 -0
- package/.claude/skills/cfn-loop-orchestration/test-edge-cases.sh +188 -0
- package/.claude/skills/cfn-loop-validation/SKILL.md +307 -217
- package/.claude/skills/complexity-estimator/SKILL.md +96 -0
- package/.claude/skills/complexity-estimator/estimate-complexity.sh +144 -0
- package/.claude/skills/context-pruner/SKILL.md +75 -0
- package/.claude/skills/context-pruner/prune-context.sh +73 -0
- package/.claude/skills/defense-in-depth/SKILL.md +133 -0
- package/.claude/skills/dependency-extractor/SKILL.md +35 -0
- package/.claude/skills/dependency-extractor/extract-dependencies.sh +66 -0
- package/.claude/skills/epic-decomposer/SKILL.md +44 -0
- package/.claude/skills/epic-decomposer/decompose-epic.sh +104 -0
- package/.claude/skills/improvement-recommender/SKILL.md +33 -0
- package/.claude/skills/improvement-recommender/recommend-improvements.sh +92 -0
- package/.claude/skills/intervention-detector/SKILL.md +39 -0
- package/.claude/skills/intervention-detector/detect-intervention.sh +111 -0
- package/.claude/skills/intervention-orchestrator/SKILL.md +43 -0
- package/.claude/skills/intervention-orchestrator/execute-intervention.sh +59 -0
- package/.claude/skills/loop2-output-processing/SKILL.md +163 -0
- package/.claude/skills/loop2-output-processing/execute-and-extract.sh +77 -0
- package/.claude/skills/loop2-output-processing/execute-and-extract.sh.backup +36 -0
- package/.claude/skills/loop2-output-processing/parse-feedback.sh +147 -0
- package/.claude/skills/loop2-output-processing/process-validator-output.sh +275 -0
- package/.claude/skills/loop2-output-processing/test-bug27-fix.sh +200 -0
- package/.claude/skills/loop2-output-processing/test-loop2-processing.sh +113 -0
- package/.claude/skills/loop3-output-processing/AGENT_COMPLETION_PROTOCOL.md +206 -0
- package/.claude/skills/loop3-output-processing/SKILL.md +421 -0
- package/.claude/skills/loop3-output-processing/calculate-confidence.sh +28 -0
- package/.claude/skills/loop3-output-processing/execute-and-extract.sh +85 -0
- package/.claude/skills/loop3-output-processing/parse-confidence.sh +31 -0
- package/.claude/skills/loop3-output-processing/test-agent-timeout.sh +327 -0
- package/.claude/skills/loop3-output-processing/test-loop3-processing.sh +155 -0
- package/.claude/skills/loop3-output-processing/verify-deliverables.sh +42 -0
- package/.claude/skills/pattern-extraction/SKILL.md +30 -0
- package/.claude/skills/pattern-extraction/extract-patterns.sh +80 -0
- package/.claude/skills/playbook/SKILL.md +113 -0
- package/.claude/skills/playbook/init-playbook.sh +54 -0
- package/.claude/skills/playbook/playbook.db +0 -0
- package/.claude/skills/playbook/query-playbook.sh +79 -0
- package/.claude/skills/playbook/update-playbook.sh +69 -0
- package/.claude/skills/playbook-auto-update/SKILL.md +29 -0
- package/.claude/skills/playbook-auto-update/auto-update-playbook.sh +86 -0
- package/.claude/skills/product-owner-decision/SKILL.md +332 -0
- package/.claude/skills/product-owner-decision/execute-decision.sh +176 -0
- package/.claude/skills/product-owner-decision/parse-decision.sh +66 -0
- package/.claude/skills/product-owner-decision/validate-deliverables.sh +82 -0
- package/.claude/skills/redis-coordination/AGENT_LOGGING.md +280 -0
- package/.claude/skills/redis-coordination/LOGGING.md +260 -0
- package/.claude/skills/redis-coordination/README.md +30 -29
- package/.claude/skills/redis-coordination/SKILL.md +685 -83
- package/.claude/skills/redis-coordination/agent-log.sh +124 -0
- package/.claude/skills/redis-coordination/analyze-task-complexity.sh +277 -0
- package/.claude/skills/redis-coordination/cfn-loop-exec.sh +468 -0
- package/.claude/skills/redis-coordination/collect-confidence-scores.sh +179 -0
- package/.claude/skills/redis-coordination/collect-results.sh +75 -0
- package/.claude/skills/redis-coordination/data/cfn-loop.db +0 -0
- package/.claude/skills/redis-coordination/demos/test-iteration-feedback.sh +320 -0
- package/.claude/skills/redis-coordination/{test-orchestrator.sh → demos/test-orchestrator.sh} +25 -0
- package/.claude/skills/redis-coordination/execute-product-owner-decision.sh +258 -0
- package/.claude/skills/redis-coordination/get-agent-timeout.sh +176 -176
- package/.claude/skills/redis-coordination/init-swarm.sh +6 -1
- package/.claude/skills/redis-coordination/invoke-waiting-mode.sh +106 -183
- package/.claude/skills/redis-coordination/invoke-waiting-mode.sh.backup-p7 +423 -0
- package/.claude/skills/redis-coordination/log-event.sh +109 -0
- package/.claude/skills/redis-coordination/monitor-cfn-violations.sh +391 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop-v3.sh +141 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh +31 -933
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup +38 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-1761167675 +1672 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-p5 +1604 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-phase1 +1550 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-phase2 +1621 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-phase3 +1621 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.bak +0 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.broken +1627 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.corrupted +80 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.deprecated +1864 -0
- package/.claude/skills/redis-coordination/query-logs.sh +103 -0
- package/.claude/skills/redis-coordination/retrieve-context.sh +58 -0
- package/.claude/skills/redis-coordination/select-specialist-agent.sh +371 -0
- package/.claude/skills/redis-coordination/semantic-match-tfidf.py +252 -0
- package/.claude/skills/redis-coordination/send-heartbeat.sh +164 -72
- package/.claude/skills/redis-coordination/signal.sh +38 -0
- package/.claude/skills/redis-coordination/store-context.sh +86 -0
- package/.claude/skills/redis-coordination/store-epic-context.sh +123 -0
- package/.claude/skills/redis-coordination/test-context-injection.sh +354 -0
- package/.claude/skills/redis-coordination/test-timeout-enforcement.sh +513 -0
- package/.claude/skills/redis-coordination/tests/convert-line-endings.sh +15 -0
- package/.claude/skills/redis-coordination/tests/dlq-functionality-test.sh +101 -101
- package/.claude/skills/redis-coordination/tests/edge-cases-test.sh +98 -98
- package/.claude/skills/redis-coordination/tests/integration-test.sh +169 -169
- package/.claude/skills/redis-coordination/tests/retry-mechanism-test.sh +81 -81
- package/.claude/skills/redis-coordination/tests/run-test-suite.sh +91 -91
- package/.claude/skills/redis-coordination/tests/run-tests.sh +4 -0
- package/.claude/skills/redis-coordination/tests/test-primitives.sh +166 -0
- package/.claude/skills/redis-coordination/tests/test-utils.sh +53 -121
- package/.claude/skills/redis-coordination/tests/test_coordination_primitives.sh.deprecated +20 -0
- package/.claude/skills/redis-coordination/tests/test_utils.sh +49 -0
- package/.claude/skills/redis-coordination/v2_modularization/core_orchestration.sh +76 -0
- package/.claude/skills/redis-coordination/validate-parameters.sh +492 -0
- package/.claude/skills/retrospective-report/SKILL.md +31 -0
- package/.claude/skills/retrospective-report/generate-report.sh +101 -0
- package/.claude/skills/run-all-skill-tests.sh +124 -0
- package/.claude/skills/scope-simplifier/SKILL.md +37 -0
- package/.claude/skills/scope-simplifier/simplify-scope.sh +68 -0
- package/.claude/skills/simplified-agent-lifecycle/COST_ANALYSIS.md +49 -0
- package/.claude/skills/simplified-agent-lifecycle/DESIGN.md +98 -0
- package/.claude/skills/simplified-agent-lifecycle/MIGRATION_PLAN.md +74 -0
- package/.claude/skills/skill-builder/SKILL.md +910 -0
- package/.claude/skills/specialist-injection/SKILL.md +41 -0
- package/.claude/skills/specialist-injection/recommend-specialist.sh +57 -0
- package/.claude/skills/sprint-execution/SKILL.md +27 -0
- package/.claude/skills/sprint-execution/execute-sprint-task.sh +59 -0
- package/.claude/skills/sprint-execution/execute-sprint.sh +65 -0
- package/.claude/skills/sprint-planner/SKILL.md +37 -0
- package/.claude/skills/sprint-planner/plan-sprint.sh +85 -0
- package/.claude/skills/standardized-error-handling/SKILL.md +56 -0
- package/.claude/skills/standardized-error-handling/capture-agent-error.sh +87 -0
- package/.claude/skills/standardized-error-handling/test-error-handling.sh +166 -0
- package/.claude/skills/task-classifier/SKILL.md +94 -0
- package/.claude/skills/task-classifier/classify-task.sh +115 -0
- package/.claude/skills/validation-templates/SKILL.md +47 -0
- package/.claude/skills/validation-templates/content.json +38 -0
- package/.claude/skills/validation-templates/data.json +38 -0
- package/.claude/skills/validation-templates/design.json +38 -0
- package/.claude/skills/validation-templates/infrastructure.json +38 -0
- package/.claude/skills/validation-templates/research.json +38 -0
- package/.claude/skills/validation-templates/software.json +38 -0
- package/.claude/skills/webapp-testing/README.md +142 -0
- package/.claude/skills/webapp-testing/SCREENSHOT_NAMING_CONVENTION.md +547 -0
- package/.claude/skills/webapp-testing/SKILL.md +877 -0
- package/.claude/skills/webapp-testing/capture-screenshot.sh +238 -0
- package/.claude/skills/webapp-testing/cfn-loop-integration.sh +265 -0
- package/.claude/skills/webapp-testing/compare-screenshots.sh +199 -0
- package/.claude/skills/webapp-testing/init-storage.sh +150 -0
- package/.claude/skills/webapp-testing/set-baseline.sh +196 -0
- package/.claude/skills/webapp-testing/test-webapp-testing.sh +233 -0
- package/.claude/spawn-pattern-examples.md +3 -3
- package/CLAUDE.md +364 -16
- package/README.md +598 -251
- package/dist/agents/agent-loader.js +146 -165
- package/dist/agents/agent-loader.js.map +1 -1
- package/dist/cli/agent-command.js +153 -0
- package/dist/cli/agent-command.js.map +1 -0
- package/dist/cli/agent-definition-parser.js +183 -0
- package/dist/cli/agent-definition-parser.js.map +1 -0
- package/dist/cli/agent-executor.js +310 -0
- package/dist/cli/agent-executor.js.map +1 -0
- package/dist/cli/agent-prompt-builder.js +268 -0
- package/dist/cli/agent-prompt-builder.js.map +1 -0
- package/dist/cli/agent-spawn.js +56 -2
- package/dist/cli/agent-spawn.js.map +1 -1
- package/dist/cli/anthropic-client.js +421 -0
- package/dist/cli/anthropic-client.js.map +1 -0
- package/dist/cli/cfn-context.js +150 -0
- package/dist/cli/cfn-context.js.map +1 -1
- package/dist/cli/cfn-fork.js +159 -0
- package/dist/cli/cfn-fork.js.map +1 -0
- package/dist/cli/cli-agent-context.js +358 -0
- package/dist/cli/cli-agent-context.js.map +1 -0
- package/dist/cli/config-manager.js +109 -91
- package/dist/cli/config-manager.js.map +1 -1
- package/dist/cli/conversation-fork.js +201 -0
- package/dist/cli/conversation-fork.js.map +1 -0
- package/dist/cli/index.js +119 -2
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/iteration-history.js +188 -0
- package/dist/cli/iteration-history.js.map +1 -0
- package/dist/cli/tool-definitions.js +263 -0
- package/dist/cli/tool-definitions.js.map +1 -0
- package/dist/cli/tool-executor.js +247 -0
- package/dist/cli/tool-executor.js.map +1 -0
- package/dist/hello.js +8 -0
- package/dist/hello.js.map +1 -0
- package/package.json +16 -6
- package/scripts/README.md +68 -0
- package/scripts/cfn-intervention-example.sh +21 -0
- package/scripts/migrate-test-infrastructure.sh +40 -0
- package/scripts/switch-api.sh +233 -0
- package/scripts/validate-test-migration.sh +49 -0
- package/scripts/verify-no-secrets.sh +55 -0
- package/.claude/agents/architecture/system-architect.md.backup +0 -603
- package/.claude/agents/code-booster.md +0 -131
- package/.claude/agents/consensus/performance-benchmarker.md +0 -101
- package/.claude/agents/consensus/security-manager.md +0 -107
- package/.claude/agents/context-curator.md +0 -167
- package/.claude/agents/context-reflector.md +0 -65
- package/.claude/agents/core-agents/cfn-loop-coordinator.md +0 -134
- package/.claude/agents/core-agents/code-quality-validator.md +0 -149
- package/.claude/agents/core-agents/context-curator.md +0 -452
- package/.claude/agents/core-agents/context-reflector.md +0 -273
- package/.claude/agents/core-agents/cost-savings-cfn-loop-coordinator.md +0 -190
- package/.claude/agents/core-agents/tester.md +0 -170
- package/.claude/agents/development/backend-dev.md +0 -165
- package/.claude/agents/devops/devops-engineer.md +0 -148
- package/.claude/agents/frontend/interaction-tester.md +0 -139
- package/.claude/agents/frontend/react-frontend-engineer.md +0 -9
- package/.claude/agents/personas/accessibility-advocate-persona.md +0 -107
- package/.claude/agents/testing/production-validator.md +0 -179
- package/.claude/agents/testing/tdd-london-swarm.md +0 -209
- package/.claude/agents/testing/unit/tdd-london-swarm.md +0 -43
- package/.claude/agents/testing/validation/production-validator.md +0 -43
- package/dist/coordination/fleet-manager.test.js +0 -141
- package/dist/coordination/fleet-manager.test.js.map +0 -1
- package/dist/middleware/transparency-middleware.test.js +0 -184
- package/dist/middleware/transparency-middleware.test.js.map +0 -1
- /package/.claude/agents/{core-agents → developers}/researcher.md +0 -0
- /package/.claude/agents/{consensus → specialists}/crdt-synchronizer.md +0 -0
- /package/.claude/agents/{consensus → specialists}/quorum-manager.md +0 -0
- /package/.claude/agents/{consensus → specialists}/raft-manager.md +0 -0
- /package/.claude/{agents/core-agents → agents-ignore}/coordinator.md +0 -0
- /package/.claude/{agents/core-agents/cost-savings-coordinator.md → agents-ignore/cost-savings-coordinator.md.backup} +0 -0
- /package/.claude/skills/redis-coordination/{phase4-wake-queue-test-report.md → demos/phase4-wake-queue-test-report.md} +0 -0
- /package/.claude/skills/redis-coordination/{test-bzpopmin-fix.sh → demos/test-bzpopmin-fix.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-cancel-swarm.sh → demos/test-cancel-swarm.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-dlq.sh → demos/test-dlq.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-priority-wake-phase4-unix.sh → demos/test-priority-wake-phase4-unix.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-priority-wake-phase4.sh → demos/test-priority-wake-phase4.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-priority-wake.sh → demos/test-priority-wake.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quick-fix.sh → demos/test-quick-fix.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quorum-absolute.sh → demos/test-quorum-absolute.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quorum-fallback.sh → demos/test-quorum-fallback.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quorum-percentage.sh → demos/test-quorum-percentage.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quorum-with-retry.sh → demos/test-quorum-with-retry.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quorum.sh → demos/test-quorum.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-shutdown-handling.sh → demos/test-shutdown-handling.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-shutdown.sh → demos/test-shutdown.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-utils-unix.sh → demos/test-utils-unix.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-utils.sh → demos/test-utils.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-waiting-mode.sh → demos/test-waiting-mode.sh} +0 -0
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
|
|
3
|
+
# Agent Logging Utility - Dual output (terminal + Redis)
|
|
4
|
+
#
|
|
5
|
+
# Usage:
|
|
6
|
+
# source agent-log.sh
|
|
7
|
+
# agent_log "info" "Message here"
|
|
8
|
+
# agent_log "error" "Error occurred"
|
|
9
|
+
#
|
|
10
|
+
# Or as standalone:
|
|
11
|
+
# ./agent-log.sh "info" "Agent started" --agent-id "researcher-1" --task-id "task-123"
|
|
12
|
+
|
|
13
|
+
set -euo pipefail
|
|
14
|
+
|
|
15
|
+
# Color codes for terminal output
|
|
16
|
+
COLOR_RESET="\033[0m"
|
|
17
|
+
COLOR_DEBUG="\033[0;36m" # Cyan
|
|
18
|
+
COLOR_INFO="\033[0;32m" # Green
|
|
19
|
+
COLOR_WARN="\033[0;33m" # Yellow
|
|
20
|
+
COLOR_ERROR="\033[0;31m" # Red
|
|
21
|
+
COLOR_AGENT="\033[0;35m" # Magenta
|
|
22
|
+
|
|
23
|
+
# Get color for log level
|
|
24
|
+
get_log_color() {
|
|
25
|
+
local level="$1"
|
|
26
|
+
case "$level" in
|
|
27
|
+
debug) echo "$COLOR_DEBUG" ;;
|
|
28
|
+
info) echo "$COLOR_INFO" ;;
|
|
29
|
+
warn) echo "$COLOR_WARN" ;;
|
|
30
|
+
error) echo "$COLOR_ERROR" ;;
|
|
31
|
+
*) echo "$COLOR_RESET" ;;
|
|
32
|
+
esac
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
# Main logging function
|
|
36
|
+
# Usage: agent_log <level> <message> [--agent-id <id>] [--task-id <id>] [--no-terminal] [--no-redis]
|
|
37
|
+
agent_log() {
|
|
38
|
+
local LEVEL="${1:-info}"
|
|
39
|
+
local MESSAGE="${2:-}"
|
|
40
|
+
local AGENT_ID="${AGENT_ID:-unknown}"
|
|
41
|
+
local TASK_ID="${TASK_ID:-unknown}"
|
|
42
|
+
local REPOSITORY=$(basename "$(pwd)")
|
|
43
|
+
local NO_TERMINAL=false
|
|
44
|
+
local NO_REDIS=false
|
|
45
|
+
|
|
46
|
+
# Parse optional arguments
|
|
47
|
+
shift 2 || true
|
|
48
|
+
while [[ $# -gt 0 ]]; do
|
|
49
|
+
case "$1" in
|
|
50
|
+
--agent-id)
|
|
51
|
+
AGENT_ID="$2"
|
|
52
|
+
shift 2
|
|
53
|
+
;;
|
|
54
|
+
--task-id)
|
|
55
|
+
TASK_ID="$2"
|
|
56
|
+
shift 2
|
|
57
|
+
;;
|
|
58
|
+
--no-terminal)
|
|
59
|
+
NO_TERMINAL=true
|
|
60
|
+
shift
|
|
61
|
+
;;
|
|
62
|
+
--no-redis)
|
|
63
|
+
NO_REDIS=true
|
|
64
|
+
shift
|
|
65
|
+
;;
|
|
66
|
+
*)
|
|
67
|
+
shift
|
|
68
|
+
;;
|
|
69
|
+
esac
|
|
70
|
+
done
|
|
71
|
+
|
|
72
|
+
local TIMESTAMP=$(date -u +"%Y-%m-%dT%H:%M:%SZ")
|
|
73
|
+
local COLOR=$(get_log_color "$LEVEL")
|
|
74
|
+
|
|
75
|
+
# 1. Terminal output (with colors)
|
|
76
|
+
if [ "$NO_TERMINAL" = false ]; then
|
|
77
|
+
echo -e "${COLOR}[${LEVEL^^}]${COLOR_RESET} ${COLOR_AGENT}[${AGENT_ID}]${COLOR_RESET} ${MESSAGE}"
|
|
78
|
+
fi
|
|
79
|
+
|
|
80
|
+
# 2. File output (no colors, in /tmp)
|
|
81
|
+
local LOG_FILE="/tmp/agent-${AGENT_ID}.log"
|
|
82
|
+
echo "[${TIMESTAMP}] [${LEVEL^^}] [${AGENT_ID}] ${MESSAGE}" >> "$LOG_FILE"
|
|
83
|
+
|
|
84
|
+
# 3. Redis pub/sub (for portal)
|
|
85
|
+
if [ "$NO_REDIS" = false ]; then
|
|
86
|
+
local LOG_PAYLOAD=$(cat <<EOF
|
|
87
|
+
{
|
|
88
|
+
"level": "${LEVEL}",
|
|
89
|
+
"message": "${MESSAGE}",
|
|
90
|
+
"agentId": "${AGENT_ID}",
|
|
91
|
+
"taskId": "${TASK_ID}",
|
|
92
|
+
"repository": "${REPOSITORY}",
|
|
93
|
+
"timestamp": "${TIMESTAMP}"
|
|
94
|
+
}
|
|
95
|
+
EOF
|
|
96
|
+
)
|
|
97
|
+
|
|
98
|
+
# Publish to Redis channel: swarm:<task-id>:logs
|
|
99
|
+
redis-cli publish "swarm:${TASK_ID}:logs" "$LOG_PAYLOAD" > /dev/null 2>&1 || true
|
|
100
|
+
|
|
101
|
+
# Also add to sorted set for persistence (with timestamp as score)
|
|
102
|
+
local SCORE=$(date +%s)
|
|
103
|
+
redis-cli zadd "swarm:${TASK_ID}:logs:history" "$SCORE" "$LOG_PAYLOAD" > /dev/null 2>&1 || true
|
|
104
|
+
|
|
105
|
+
# Set TTL on history (7 days)
|
|
106
|
+
redis-cli expire "swarm:${TASK_ID}:logs:history" 604800 > /dev/null 2>&1 || true
|
|
107
|
+
fi
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
# If script is executed directly (not sourced)
|
|
111
|
+
if [ "${BASH_SOURCE[0]}" = "${0}" ]; then
|
|
112
|
+
if [ $# -lt 2 ]; then
|
|
113
|
+
echo "Usage: $0 <level> <message> [--agent-id <id>] [--task-id <id>]"
|
|
114
|
+
echo ""
|
|
115
|
+
echo "Levels: debug, info, warn, error"
|
|
116
|
+
echo ""
|
|
117
|
+
echo "Examples:"
|
|
118
|
+
echo " $0 info \"Agent started\" --agent-id researcher-1 --task-id task-123"
|
|
119
|
+
echo " $0 error \"Connection failed\" --agent-id reviewer-2 --task-id task-456"
|
|
120
|
+
exit 1
|
|
121
|
+
fi
|
|
122
|
+
|
|
123
|
+
agent_log "$@"
|
|
124
|
+
fi
|
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
##############################################################################
|
|
3
|
+
# Task Complexity Analyzer
|
|
4
|
+
#
|
|
5
|
+
# Purpose: Deterministically analyze task complexity and determine optimal
|
|
6
|
+
# number of Loop 3 agents needed.
|
|
7
|
+
#
|
|
8
|
+
# Usage:
|
|
9
|
+
# ./analyze-task-complexity.sh --task "Build React dashboard" [--difficulty auto]
|
|
10
|
+
#
|
|
11
|
+
# Output (JSON):
|
|
12
|
+
# {
|
|
13
|
+
# "complexity_score": 7.5,
|
|
14
|
+
# "difficulty": "standard",
|
|
15
|
+
# "domains": ["frontend", "backend"],
|
|
16
|
+
# "suggested_agents": {
|
|
17
|
+
# "loop3_count": 3,
|
|
18
|
+
# "loop2_count": 4
|
|
19
|
+
# },
|
|
20
|
+
# "reasoning": "Multi-domain task with moderate scope"
|
|
21
|
+
# }
|
|
22
|
+
##############################################################################
|
|
23
|
+
|
|
24
|
+
set -euo pipefail
|
|
25
|
+
|
|
26
|
+
# Configuration
|
|
27
|
+
TASK_DESCRIPTION=""
|
|
28
|
+
DIFFICULTY="auto" # auto | simple | standard | complex | enterprise
|
|
29
|
+
|
|
30
|
+
# Parse arguments
|
|
31
|
+
while [[ $# -gt 0 ]]; do
|
|
32
|
+
case $1 in
|
|
33
|
+
--task)
|
|
34
|
+
TASK_DESCRIPTION="$2"
|
|
35
|
+
shift 2
|
|
36
|
+
;;
|
|
37
|
+
--difficulty)
|
|
38
|
+
DIFFICULTY="$2"
|
|
39
|
+
shift 2
|
|
40
|
+
;;
|
|
41
|
+
*)
|
|
42
|
+
echo "Unknown option: $1" >&2
|
|
43
|
+
exit 1
|
|
44
|
+
;;
|
|
45
|
+
esac
|
|
46
|
+
done
|
|
47
|
+
|
|
48
|
+
if [ -z "$TASK_DESCRIPTION" ]; then
|
|
49
|
+
echo "Error: --task required" >&2
|
|
50
|
+
exit 1
|
|
51
|
+
fi
|
|
52
|
+
|
|
53
|
+
##############################################################################
|
|
54
|
+
# Complexity Scoring Algorithm
|
|
55
|
+
##############################################################################
|
|
56
|
+
|
|
57
|
+
TASK_LOWER=$(echo "$TASK_DESCRIPTION" | tr '[:upper:]' '[:lower:]')
|
|
58
|
+
COMPLEXITY_SCORE=0
|
|
59
|
+
DETECTED_DOMAINS=()
|
|
60
|
+
REASONING=""
|
|
61
|
+
|
|
62
|
+
# 1. Word Count (longer = more complex)
|
|
63
|
+
WORD_COUNT=$(echo "$TASK_DESCRIPTION" | wc -w)
|
|
64
|
+
if [ "$WORD_COUNT" -lt 5 ]; then
|
|
65
|
+
WORD_SCORE=1
|
|
66
|
+
elif [ "$WORD_COUNT" -lt 10 ]; then
|
|
67
|
+
WORD_SCORE=2
|
|
68
|
+
elif [ "$WORD_COUNT" -lt 20 ]; then
|
|
69
|
+
WORD_SCORE=3
|
|
70
|
+
else
|
|
71
|
+
WORD_SCORE=4
|
|
72
|
+
fi
|
|
73
|
+
COMPLEXITY_SCORE=$((COMPLEXITY_SCORE + WORD_SCORE))
|
|
74
|
+
|
|
75
|
+
# 2. Domain Detection (multi-domain = more complex)
|
|
76
|
+
DOMAIN_COUNT=0
|
|
77
|
+
|
|
78
|
+
if [[ "$TASK_LOWER" =~ react|frontend|ui|component|dashboard ]]; then
|
|
79
|
+
DETECTED_DOMAINS+=("frontend")
|
|
80
|
+
DOMAIN_COUNT=$((DOMAIN_COUNT + 1))
|
|
81
|
+
fi
|
|
82
|
+
|
|
83
|
+
if [[ "$TASK_LOWER" =~ api|backend|server|endpoint|rest|graphql ]]; then
|
|
84
|
+
DETECTED_DOMAINS+=("backend")
|
|
85
|
+
DOMAIN_COUNT=$((DOMAIN_COUNT + 1))
|
|
86
|
+
fi
|
|
87
|
+
|
|
88
|
+
if [[ "$TASK_LOWER" =~ database|db|sql|postgres|mongo|redis ]]; then
|
|
89
|
+
DETECTED_DOMAINS+=("database")
|
|
90
|
+
DOMAIN_COUNT=$((DOMAIN_COUNT + 1))
|
|
91
|
+
fi
|
|
92
|
+
|
|
93
|
+
if [[ "$TASK_LOWER" =~ deploy|infra|docker|k8s|kubernetes|aws|cloud ]]; then
|
|
94
|
+
DETECTED_DOMAINS+=("infrastructure")
|
|
95
|
+
DOMAIN_COUNT=$((DOMAIN_COUNT + 1))
|
|
96
|
+
fi
|
|
97
|
+
|
|
98
|
+
if [[ "$TASK_LOWER" =~ auth|security|encrypt|permission|rbac ]]; then
|
|
99
|
+
DETECTED_DOMAINS+=("security")
|
|
100
|
+
DOMAIN_COUNT=$((DOMAIN_COUNT + 1))
|
|
101
|
+
fi
|
|
102
|
+
|
|
103
|
+
if [[ "$TASK_LOWER" =~ test|qa|validation|coverage ]]; then
|
|
104
|
+
DETECTED_DOMAINS+=("testing")
|
|
105
|
+
DOMAIN_COUNT=$((DOMAIN_COUNT + 1))
|
|
106
|
+
fi
|
|
107
|
+
|
|
108
|
+
if [[ "$TASK_LOWER" =~ architect|design|pattern|system ]]; then
|
|
109
|
+
DETECTED_DOMAINS+=("architecture")
|
|
110
|
+
DOMAIN_COUNT=$((DOMAIN_COUNT + 1))
|
|
111
|
+
fi
|
|
112
|
+
|
|
113
|
+
if [[ "$TASK_LOWER" =~ rust|cargo|tokio ]]; then
|
|
114
|
+
DETECTED_DOMAINS+=("rust")
|
|
115
|
+
DOMAIN_COUNT=$((DOMAIN_COUNT + 1))
|
|
116
|
+
fi
|
|
117
|
+
|
|
118
|
+
# Domain score: 2 points per domain
|
|
119
|
+
DOMAIN_SCORE=$((DOMAIN_COUNT * 2))
|
|
120
|
+
COMPLEXITY_SCORE=$((COMPLEXITY_SCORE + DOMAIN_SCORE))
|
|
121
|
+
|
|
122
|
+
# 3. Explicit Scope Indicators
|
|
123
|
+
if [[ "$TASK_LOWER" =~ simple|quick|small|basic|minimal|mvp ]]; then
|
|
124
|
+
SCOPE_MODIFIER=-2
|
|
125
|
+
SCOPE_LABEL="reduced (MVP scope detected)"
|
|
126
|
+
elif [[ "$TASK_LOWER" =~ production|enterprise|scalable|robust|complete|full ]]; then
|
|
127
|
+
SCOPE_MODIFIER=3
|
|
128
|
+
SCOPE_LABEL="increased (enterprise scope detected)"
|
|
129
|
+
elif [[ "$TASK_LOWER" =~ prototype|poc|proof.of.concept ]]; then
|
|
130
|
+
SCOPE_MODIFIER=-1
|
|
131
|
+
SCOPE_LABEL="slightly reduced (prototype scope)"
|
|
132
|
+
else
|
|
133
|
+
SCOPE_MODIFIER=0
|
|
134
|
+
SCOPE_LABEL="standard"
|
|
135
|
+
fi
|
|
136
|
+
COMPLEXITY_SCORE=$((COMPLEXITY_SCORE + SCOPE_MODIFIER))
|
|
137
|
+
|
|
138
|
+
# 4. Feature Counting (and, with, includes, etc.)
|
|
139
|
+
FEATURE_COUNT=0
|
|
140
|
+
if [[ "$TASK_LOWER" =~ " and " ]]; then
|
|
141
|
+
FEATURE_COUNT=$((FEATURE_COUNT + 1))
|
|
142
|
+
fi
|
|
143
|
+
if [[ "$TASK_LOWER" =~ " with " ]]; then
|
|
144
|
+
FEATURE_COUNT=$((FEATURE_COUNT + 1))
|
|
145
|
+
fi
|
|
146
|
+
if [[ "$TASK_LOWER" =~ " including " ]]; then
|
|
147
|
+
FEATURE_COUNT=$((FEATURE_COUNT + 1))
|
|
148
|
+
fi
|
|
149
|
+
|
|
150
|
+
FEATURE_SCORE=$((FEATURE_COUNT))
|
|
151
|
+
COMPLEXITY_SCORE=$((COMPLEXITY_SCORE + FEATURE_SCORE))
|
|
152
|
+
|
|
153
|
+
# 5. Integration Keywords (increases complexity)
|
|
154
|
+
INTEGRATION_COUNT=0
|
|
155
|
+
if [[ "$TASK_LOWER" =~ integrat|connect|sync|webhook ]]; then
|
|
156
|
+
INTEGRATION_COUNT=$((INTEGRATION_COUNT + 1))
|
|
157
|
+
fi
|
|
158
|
+
if [[ "$TASK_LOWER" =~ third.party|external|api ]]; then
|
|
159
|
+
INTEGRATION_COUNT=$((INTEGRATION_COUNT + 1))
|
|
160
|
+
fi
|
|
161
|
+
|
|
162
|
+
INTEGRATION_SCORE=$((INTEGRATION_COUNT))
|
|
163
|
+
COMPLEXITY_SCORE=$((COMPLEXITY_SCORE + INTEGRATION_SCORE))
|
|
164
|
+
|
|
165
|
+
##############################################################################
|
|
166
|
+
# Difficulty Classification
|
|
167
|
+
##############################################################################
|
|
168
|
+
|
|
169
|
+
if [ "$DIFFICULTY" = "auto" ]; then
|
|
170
|
+
if [ "$COMPLEXITY_SCORE" -le 3 ]; then
|
|
171
|
+
DIFFICULTY="simple"
|
|
172
|
+
elif [ "$COMPLEXITY_SCORE" -le 7 ]; then
|
|
173
|
+
DIFFICULTY="standard"
|
|
174
|
+
elif [ "$COMPLEXITY_SCORE" -le 12 ]; then
|
|
175
|
+
DIFFICULTY="complex"
|
|
176
|
+
else
|
|
177
|
+
DIFFICULTY="enterprise"
|
|
178
|
+
fi
|
|
179
|
+
fi
|
|
180
|
+
|
|
181
|
+
##############################################################################
|
|
182
|
+
# Agent Count Calculation
|
|
183
|
+
##############################################################################
|
|
184
|
+
|
|
185
|
+
case "$DIFFICULTY" in
|
|
186
|
+
simple)
|
|
187
|
+
# MVP/Simple: 1-2 Loop 3 agents
|
|
188
|
+
BASE_LOOP3=1
|
|
189
|
+
BASE_LOOP2=2
|
|
190
|
+
REASONING="Simple task with minimal scope"
|
|
191
|
+
;;
|
|
192
|
+
standard)
|
|
193
|
+
# Standard: 2-3 Loop 3 agents
|
|
194
|
+
BASE_LOOP3=2
|
|
195
|
+
BASE_LOOP2=3
|
|
196
|
+
REASONING="Standard task with moderate complexity"
|
|
197
|
+
;;
|
|
198
|
+
complex)
|
|
199
|
+
# Complex: 3-5 Loop 3 agents
|
|
200
|
+
BASE_LOOP3=3
|
|
201
|
+
BASE_LOOP2=4
|
|
202
|
+
REASONING="Complex task with multiple domains"
|
|
203
|
+
;;
|
|
204
|
+
enterprise)
|
|
205
|
+
# Enterprise: 5-8 Loop 3 agents
|
|
206
|
+
BASE_LOOP3=5
|
|
207
|
+
BASE_LOOP2=5
|
|
208
|
+
REASONING="Enterprise-grade task with high complexity"
|
|
209
|
+
;;
|
|
210
|
+
*)
|
|
211
|
+
echo "Error: Invalid difficulty: $DIFFICULTY" >&2
|
|
212
|
+
exit 1
|
|
213
|
+
;;
|
|
214
|
+
esac
|
|
215
|
+
|
|
216
|
+
# Scale by domain count (1 extra agent per additional domain beyond 2)
|
|
217
|
+
if [ "$DOMAIN_COUNT" -gt 2 ]; then
|
|
218
|
+
EXTRA_AGENTS=$((DOMAIN_COUNT - 2))
|
|
219
|
+
LOOP3_COUNT=$((BASE_LOOP3 + EXTRA_AGENTS))
|
|
220
|
+
else
|
|
221
|
+
LOOP3_COUNT=$BASE_LOOP3
|
|
222
|
+
fi
|
|
223
|
+
|
|
224
|
+
# Cap at reasonable limits
|
|
225
|
+
if [ "$LOOP3_COUNT" -gt 8 ]; then
|
|
226
|
+
LOOP3_COUNT=8
|
|
227
|
+
fi
|
|
228
|
+
|
|
229
|
+
# Loop 2 scales with Loop 3 (but slower: +1 validator per 2 implementers)
|
|
230
|
+
LOOP2_COUNT=$((BASE_LOOP2 + (LOOP3_COUNT - BASE_LOOP3) / 2))
|
|
231
|
+
if [ "$LOOP2_COUNT" -gt 6 ]; then
|
|
232
|
+
LOOP2_COUNT=6
|
|
233
|
+
fi
|
|
234
|
+
|
|
235
|
+
# Ensure minimum validators
|
|
236
|
+
if [ "$LOOP2_COUNT" -lt 2 ]; then
|
|
237
|
+
LOOP2_COUNT=2
|
|
238
|
+
fi
|
|
239
|
+
|
|
240
|
+
##############################################################################
|
|
241
|
+
# Build Reasoning String
|
|
242
|
+
##############################################################################
|
|
243
|
+
|
|
244
|
+
REASONING_DETAILS="$REASONING (complexity score: $COMPLEXITY_SCORE, domains: $DOMAIN_COUNT, scope: $SCOPE_LABEL)"
|
|
245
|
+
|
|
246
|
+
##############################################################################
|
|
247
|
+
# Output JSON
|
|
248
|
+
##############################################################################
|
|
249
|
+
|
|
250
|
+
# Convert array to JSON array
|
|
251
|
+
DOMAINS_JSON=$(printf '%s\n' "${DETECTED_DOMAINS[@]}" | jq -R . | jq -s .)
|
|
252
|
+
|
|
253
|
+
jq -nc \
|
|
254
|
+
--arg complexity "$COMPLEXITY_SCORE" \
|
|
255
|
+
--arg difficulty "$DIFFICULTY" \
|
|
256
|
+
--argjson domains "$DOMAINS_JSON" \
|
|
257
|
+
--arg loop3 "$LOOP3_COUNT" \
|
|
258
|
+
--arg loop2 "$LOOP2_COUNT" \
|
|
259
|
+
--arg reasoning "$REASONING_DETAILS" \
|
|
260
|
+
--arg word_count "$WORD_COUNT" \
|
|
261
|
+
--arg domain_count "$DOMAIN_COUNT" \
|
|
262
|
+
--arg feature_count "$FEATURE_COUNT" \
|
|
263
|
+
'{
|
|
264
|
+
complexity_score: ($complexity | tonumber),
|
|
265
|
+
difficulty: $difficulty,
|
|
266
|
+
domains: $domains,
|
|
267
|
+
suggested_agents: {
|
|
268
|
+
loop3_count: ($loop3 | tonumber),
|
|
269
|
+
loop2_count: ($loop2 | tonumber)
|
|
270
|
+
},
|
|
271
|
+
reasoning: $reasoning,
|
|
272
|
+
analysis: {
|
|
273
|
+
word_count: ($word_count | tonumber),
|
|
274
|
+
domain_count: ($domain_count | tonumber),
|
|
275
|
+
feature_count: ($feature_count | tonumber)
|
|
276
|
+
}
|
|
277
|
+
}'
|