claude-flow-novice 2.18.5 → 2.18.7
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/FILE_MANIFEST.md +50 -0
- package/.claude/MANIFEST_INDEX.md +224 -0
- package/.claude/MANIFEST_README.md +308 -0
- package/.claude/TRIGGER_TASKS_MANIFEST.md +11 -0
- package/.claude/WORKING-SETUP.md +67 -0
- package/.claude/adaptive-context/cfn-v3-reflection.json +21 -0
- package/.claude/agent-principles/SPARSE_LANGUAGE_FINDINGS.md +991 -0
- package/.claude/agent-principles/agent-template.md +96 -0
- package/.claude/agent-principles/prompt-engineering.md +501 -0
- package/.claude/agents/cfn-dev-team/analysts/analyst.md +120 -0
- package/.claude/agents/cfn-dev-team/analysts/root-cause-analyst.md +264 -0
- package/.claude/agents/cfn-dev-team/architecture/api-designer-persona.md +152 -0
- package/.claude/agents/cfn-dev-team/architecture/base-template-generator.md +157 -0
- package/.claude/agents/cfn-dev-team/architecture/goal-planner.md +180 -0
- package/.claude/agents/cfn-dev-team/architecture/planner.md +139 -0
- package/.claude/agents/cfn-dev-team/architecture/system-architect.md +132 -0
- package/.claude/agents/cfn-dev-team/coordinators/cfn-frontend-coordinator.md +893 -0
- package/.claude/agents/cfn-dev-team/coordinators/consensus-builder.md +480 -0
- package/.claude/agents/cfn-dev-team/coordinators/handoff-coordinator.md +747 -0
- package/.claude/agents/cfn-dev-team/coordinators/multi-sprint-coordinator.md +510 -0
- package/.claude/agents/cfn-dev-team/dev-ops/devops-engineer.md +157 -0
- package/.claude/agents/cfn-dev-team/dev-ops/docker-specialist.md +671 -0
- package/.claude/agents/cfn-dev-team/dev-ops/github-commit-agent.md +123 -0
- package/.claude/agents/cfn-dev-team/dev-ops/kubernetes-specialist.md +624 -0
- package/.claude/agents/cfn-dev-team/developers/api-gateway-specialist.md +977 -0
- package/.claude/agents/cfn-dev-team/developers/backend-developer-cerebras.md +210 -0
- package/.claude/agents/cfn-dev-team/developers/backend-developer.md +206 -0
- package/.claude/agents/cfn-dev-team/developers/data/data-engineer.md +672 -0
- package/.claude/agents/cfn-dev-team/developers/database/database-architect.md +376 -0
- package/.claude/agents/cfn-dev-team/developers/database/supabase-specialist.md +746 -0
- package/.claude/agents/cfn-dev-team/developers/frontend/mobile-dev.md +247 -0
- package/.claude/agents/cfn-dev-team/developers/frontend/react-frontend-engineer.md +272 -0
- package/.claude/agents/cfn-dev-team/developers/frontend/typescript-specialist.md +396 -0
- package/.claude/agents/cfn-dev-team/developers/frontend/ui-designer.md +221 -0
- package/.claude/agents/cfn-dev-team/developers/graphql-specialist.md +707 -0
- package/.claude/agents/cfn-dev-team/developers/rust-developer.md +228 -0
- package/.claude/agents/cfn-dev-team/documentation/agent-type-guidelines.md +476 -0
- package/.claude/agents/cfn-dev-team/documentation/api-documentation.md +111 -0
- package/.claude/agents/cfn-dev-team/documentation/pseudocode.md +144 -0
- package/.claude/agents/cfn-dev-team/documentation/specification-agent.md +152 -0
- package/.claude/agents/cfn-dev-team/product-owners/accessibility-advocate-persona.md +119 -0
- package/.claude/agents/cfn-dev-team/product-owners/cto-agent.md +138 -0
- package/.claude/agents/cfn-dev-team/product-owners/power-user-persona.md +151 -0
- package/.claude/agents/cfn-dev-team/product-owners/product-owner.md +483 -0
- package/.claude/agents/cfn-dev-team/reviewers/code-reviewer.md +303 -0
- package/.claude/agents/cfn-dev-team/reviewers/quality/code-quality-validator.md +220 -0
- package/.claude/agents/cfn-dev-team/reviewers/quality/cyclomatic-complexity-reducer.md +334 -0
- package/.claude/agents/cfn-dev-team/reviewers/quality/perf-analyzer.md +257 -0
- package/.claude/agents/cfn-dev-team/reviewers/quality/performance-benchmarker.md +160 -0
- package/.claude/agents/cfn-dev-team/reviewers/quality/quality-metrics.md +386 -0
- package/.claude/agents/cfn-dev-team/testers/api-testing-specialist.md +757 -0
- package/.claude/agents/cfn-dev-team/testers/chaos-engineering-specialist.md +944 -0
- package/.claude/agents/cfn-dev-team/testers/contract-tester.md +687 -0
- package/.claude/agents/cfn-dev-team/testers/e2e/playwright-tester.md +124 -0
- package/.claude/agents/cfn-dev-team/testers/integration-tester.md +785 -0
- package/.claude/agents/cfn-dev-team/testers/interaction-tester.md +188 -0
- package/.claude/agents/cfn-dev-team/testers/load-testing-specialist.md +505 -0
- package/.claude/agents/cfn-dev-team/testers/mutation-testing-specialist.md +643 -0
- package/.claude/agents/cfn-dev-team/testers/playwright-tester.md +253 -0
- package/.claude/agents/cfn-dev-team/testers/tester.md +224 -0
- package/.claude/agents/cfn-dev-team/testers/unit/tdd-london-unit-swarm.md +37 -0
- package/.claude/agents/cfn-dev-team/testers/validation/validation-production-validator.md +27 -0
- package/.claude/agents/cfn-dev-team/testing/test-validation-agent.md +280 -0
- package/.claude/agents/cfn-dev-team/utility/agent-builder.md +487 -0
- package/.claude/agents/cfn-dev-team/utility/context-curator.md +69 -0
- package/.claude/agents/cfn-dev-team/utility/epic-creator-v2.md +2 -0
- package/.claude/agents/cfn-dev-team/utility/epic-creator.md +7 -0
- package/.claude/agents/cfn-dev-team/utility/memory-leak-specialist.md +177 -0
- package/.claude/agents/cfn-dev-team/utility/researcher.md +116 -0
- package/.claude/agents/cfn-dev-team/utility/z-ai-specialist.md +218 -0
- package/.claude/agents/custom/cfn-docker-expert.md +132 -0
- package/.claude/agents/custom/cfn-loops-cli-expert.md +9 -0
- package/.claude/agents/custom/cfn-redis-operations.md +538 -0
- package/.claude/agents/custom/cfn-system-expert.md +489 -0
- package/.claude/agents/custom/claude-code-expert.md +298 -0
- package/.claude/agents/custom/mdap-trigger-specialist.md +82 -0
- package/.claude/agents/custom/trigger-dev-expert.md +386 -0
- package/.claude/agents/docker-coordinators/cfn-docker-v3-coordinator.md +1101 -0
- package/.claude/agents/docker-ts-fixer.md +65 -0
- package/.claude/agents/project-only-agents/npm-package-specialist.md +334 -0
- package/.claude/cfn-config/team-providers.json +102 -0
- package/.claude/commands/README.md +204 -0
- package/.claude/commands/cfn-check-errors.md +34 -0
- package/.claude/commands/cfn-detect-stale-docs.md +26 -0
- package/.claude/commands/cfn-epic-creator-v2.md +10 -0
- package/.claude/commands/cfn-loop/CFN_LOOP_FRONTEND.md +741 -0
- package/.claude/commands/cfn-loop/cfn-loop-cli.md +273 -0
- package/.claude/commands/cfn-loop/cfn-loop-task.md +490 -0
- package/.claude/commands/cfn-loop/cfn-loop-trigger.md +56 -0
- package/.claude/commands/cfn-ruvector-search.md +46 -0
- package/.claude/commands/cfn-test-framework +5 -0
- package/.claude/commands/cfn-update-search-index.md +31 -0
- package/.claude/coordinator-feedback-pattern.md +326 -0
- package/.claude/coordinator-patterns.md +126 -0
- package/.claude/core/agent-manager.js +80 -0
- package/.claude/core/agent-manager.js.map +1 -0
- package/.claude/core/cfn-agent-manager.js +80 -0
- package/.claude/core/cfn-agent-manager.js.map +1 -0
- package/.claude/core/cfn-config.js +1241 -0
- package/.claude/core/cfn-config.js.map +1 -0
- package/.claude/core/cfn-event-bus.js +136 -0
- package/.claude/core/cfn-event-bus.js.map +1 -0
- package/.claude/core/cfn-index.js +6 -0
- package/.claude/core/cfn-index.js.map +1 -0
- package/.claude/core/cfn-json-persistence.js +112 -0
- package/.claude/core/cfn-json-persistence.js.map +1 -0
- package/.claude/core/cfn-logger.js +245 -0
- package/.claude/core/cfn-logger.js.map +1 -0
- package/.claude/core/cfn-orchestrator-fixed.js +236 -0
- package/.claude/core/cfn-orchestrator-fixed.js.map +1 -0
- package/.claude/core/cfn-orchestrator.js +1136 -0
- package/.claude/core/cfn-orchestrator.js.map +1 -0
- package/.claude/core/cfn-persistence.js +185 -0
- package/.claude/core/cfn-persistence.js.map +1 -0
- package/.claude/core/cfn-project-manager.js +80 -0
- package/.claude/core/cfn-project-manager.js.map +1 -0
- package/.claude/core/cfn-slash-command.js +24 -0
- package/.claude/core/cfn-version.js +35 -0
- package/.claude/core/cfn-version.js.map +1 -0
- package/.claude/core/config.js +1241 -0
- package/.claude/core/config.js.map +1 -0
- package/.claude/core/event-bus.js +136 -0
- package/.claude/core/event-bus.js.map +1 -0
- package/.claude/core/index.js +6 -0
- package/.claude/core/index.js.map +1 -0
- package/.claude/core/json-persistence.js +112 -0
- package/.claude/core/json-persistence.js.map +1 -0
- package/.claude/core/logger.js +245 -0
- package/.claude/core/logger.js.map +1 -0
- package/.claude/core/orchestrator-fixed.js +236 -0
- package/.claude/core/orchestrator-fixed.js.map +1 -0
- package/.claude/core/orchestrator.js +1136 -0
- package/.claude/core/orchestrator.js.map +1 -0
- package/.claude/core/persistence.js +185 -0
- package/.claude/core/persistence.js.map +1 -0
- package/.claude/core/project-manager.js +80 -0
- package/.claude/core/project-manager.js.map +1 -0
- package/.claude/core/slash-command.js +24 -0
- package/.claude/core/version.js +35 -0
- package/.claude/core/version.js.map +1 -0
- package/.claude/helpers/cfn-checkpoint-manager.sh +251 -0
- package/.claude/helpers/cfn-github-safe.js +106 -0
- package/.claude/helpers/cfn-github-setup.sh +28 -0
- package/.claude/helpers/cfn-quick-start.sh +19 -0
- package/.claude/helpers/cfn-setup-mcp.sh +18 -0
- package/.claude/helpers/cfn-standard-checkpoint-hooks.sh +179 -0
- package/.claude/helpers/checkpoint-manager.sh +251 -0
- package/.claude/helpers/github-safe.js +106 -0
- package/.claude/helpers/github-setup.sh +28 -0
- package/.claude/helpers/quick-start.sh +19 -0
- package/.claude/helpers/setup-mcp.sh +18 -0
- package/.claude/helpers/standard-checkpoint-hooks.sh +179 -0
- package/.claude/hooks/SKILL.md +518 -0
- package/.claude/hooks/cfn-post-edit.config.json +51 -0
- package/.claude/hooks/cfn-pre-edit-security-warning.sh +40 -0
- package/.claude/hooks/cfn-subagent-start.sh +98 -0
- package/.claude/hooks/cfn-subagent-stop.sh +129 -0
- package/.claude/hooks.json +33 -0
- package/.claude/logs/sprint1-hybrid-routing-v2-decision.json +18 -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/settings.json +172 -0
- package/.claude/settings.local.json +41 -0
- package/.claude/settings.playwright.json +198 -0
- package/.claude/skills/.cfn/task-configs/task-test-123.json +48 -0
- package/.claude/skills/bulk-add-ruvector-instructions.sh +89 -0
- package/.claude/skills/cfn-agent-lifecycle/SKILL.md +290 -0
- package/.claude/skills/cfn-agent-lifecycle/cli/lifecycle-hook.sh +5 -0
- package/.claude/skills/cfn-agent-lifecycle/cli/select-agents.sh +5 -0
- package/.claude/skills/cfn-agent-lifecycle/cli/spawn-agent.sh +5 -0
- package/.claude/skills/cfn-agent-lifecycle/execute.sh +355 -0
- package/.claude/skills/cfn-agent-lifecycle/lib/audit/execute-lifecycle-hook.sh +544 -0
- package/.claude/skills/cfn-agent-lifecycle/lib/selection/src/agent-selector.ts +350 -0
- package/.claude/skills/cfn-agent-lifecycle/lib/selection/src/cli.ts +74 -0
- package/.claude/skills/cfn-agent-lifecycle/lib/spawning/spawn-agent-wrapper.sh +63 -0
- package/.claude/skills/cfn-agent-selector +1 -0
- package/.claude/skills/cfn-agent-spawning +1 -0
- package/.claude/skills/cfn-cerebras-code-generator/SKILL.md +53 -0
- package/.claude/skills/cfn-cerebras-code-generator/context-analyzer.sh +96 -0
- package/.claude/skills/cfn-cerebras-code-generator/generate-code.sh +205 -0
- package/.claude/skills/cfn-cerebras-coordinator/SKILL.md +103 -0
- package/.claude/skills/cfn-cerebras-coordinator/TEST_RESULTS.md +98 -0
- package/.claude/skills/cfn-cerebras-coordinator/coordinate-generation.sh +381 -0
- package/.claude/skills/cfn-cerebras-coordinator/example-fix-scenario.md +254 -0
- package/.claude/skills/cfn-cerebras-coordinator/example-workflow.md +142 -0
- package/.claude/skills/cfn-cerebras-coordinator/feedback-logger.sh +254 -0
- package/.claude/skills/cfn-cerebras-coordinator/fix-existing-code-v2.sh +443 -0
- package/.claude/skills/cfn-cerebras-coordinator/fix-existing-code.sh +519 -0
- package/.claude/skills/cfn-cerebras-coordinator/pattern-examples.md +317 -0
- package/.claude/skills/cfn-cerebras-coordinator/query-patterns.sh +182 -0
- package/.claude/skills/cfn-cerebras-coordinator/tdd-coordinator.sh +638 -0
- package/.claude/skills/cfn-cerebras-coordinator/test-runner.sh +335 -0
- package/.claude/skills/cfn-cerebras-mcp/SKILL.md +64 -0
- package/.claude/skills/cfn-compilation-error-fixer/HANDOFF.md +29 -0
- package/.claude/skills/cfn-compilation-error-fixer/README.md +202 -0
- package/.claude/skills/cfn-compilation-error-fixer/SKILL.md +426 -0
- package/.claude/skills/cfn-compilation-error-fixer/bin/fix-errors.sh +75 -0
- package/.claude/skills/cfn-compilation-error-fixer/index.js +81 -0
- package/.claude/skills/cfn-compilation-error-fixer/install.sh +60 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/README-TypeScript.md +164 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-gated-fixer-v2.ts +1475 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-gated-fixer-v2.ts.bak +1475 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-sdk.d.ts +30 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-wrapper.ts +93 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/package.json +30 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/package.json.bak +23 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/typescript-gated-fixer-v2.ts +977 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/gates/typescript-gates.ts +704 -0
- package/.claude/skills/cfn-compilation-error-fixer/package.json +47 -0
- package/.claude/skills/cfn-compilation-error-fixer/test-fixer-logic.sh +96 -0
- package/.claude/skills/cfn-compilation-error-fixer/test-installation.sh +97 -0
- package/.claude/skills/cfn-compilation-error-fixer/test-rust-fixer-validation.sh +54 -0
- package/.claude/skills/cfn-compilation-error-fixer/test-rust-fixer.sh +380 -0
- package/.claude/skills/cfn-compilation-error-fixer/test-typescript-fixer.sh +278 -0
- package/.claude/skills/cfn-compilation-error-fixer/validate-setup.md +70 -0
- package/.claude/skills/cfn-config/lib/management/manage-config.sh +115 -0
- package/.claude/skills/cfn-dependency-management/SKILL.md +118 -0
- package/.claude/skills/cfn-dependency-management/cfn-dependency-management.sh +18 -0
- package/.claude/skills/cfn-dependency-management/execute.sh +306 -0
- package/.claude/skills/cfn-dependency-management/lib/ingestion/src/ingest-dependencies.ts +563 -0
- package/.claude/skills/cfn-docker-runtime/execute.sh +386 -0
- package/.claude/skills/cfn-docker-wave-execution +1 -0
- package/.claude/skills/cfn-edit-safety/README.md +160 -0
- package/.claude/skills/cfn-edit-safety/cli/edit-safety-cli.sh +337 -0
- package/.claude/skills/cfn-edit-safety/edit-safety.sh +375 -0
- package/.claude/skills/cfn-edit-safety/lib/hooks/post-edit-handler.sh +155 -0
- package/.claude/skills/cfn-epic-parser/SKILL.md +220 -0
- package/.claude/skills/cfn-epic-parser/example-epic.md +49 -0
- package/.claude/skills/cfn-epic-parser/parse.sh +517 -0
- package/.claude/skills/cfn-epic-parser/test-parser.sh +299 -0
- package/.claude/skills/cfn-error-management/cli/batch-errors.sh +4 -0
- package/.claude/skills/cfn-error-management/cli/capture-error.sh +4 -0
- package/.claude/skills/cfn-error-management/cli/log-error.sh +4 -0
- package/.claude/skills/cfn-error-management/lib/logging/src/error-logger.ts +1042 -0
- package/.claude/skills/cfn-error-management/lib/logging/src/index.ts +12 -0
- package/.claude/skills/cfn-error-management/lib/logging/src/types.ts +456 -0
- package/.claude/skills/cfn-expert-update/SKILL.md +149 -0
- package/.claude/skills/cfn-expert-update/test-expert-update.sh +254 -0
- package/.claude/skills/cfn-expert-update/update-expert.sh +484 -0
- package/.claude/skills/cfn-hybrid-routing +1 -0
- package/.claude/skills/cfn-intervention-system/lib/detector/detect-intervention.sh +106 -0
- package/.claude/skills/cfn-knowledge-base/SKILL.md +109 -0
- package/.claude/skills/cfn-knowledge-base/cli/knowledge-base.sh +435 -0
- package/.claude/skills/cfn-knowledge-base/execute.sh +163 -0
- package/.claude/skills/cfn-knowledge-base/lib/playbook/SKILL.md +153 -0
- package/.claude/skills/cfn-knowledge-base/lib/playbook/init-playbook.sh +54 -0
- package/.claude/skills/cfn-knowledge-base/lib/playbook/query-playbook.sh +89 -0
- package/.claude/skills/cfn-knowledge-base/lib/playbook/update-playbook.sh +67 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/COST_TRACKING.md +637 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/EDGE_CASE_TRACKING.md +404 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/README_PHASE4.md +457 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/SKILL.md +110 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/generate-skill-update.sh +525 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/propagate-skill-update.sh +654 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/src/index.ts +24 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/src/pattern-analyzer.ts +537 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/src/types.ts +180 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/track-cost-savings.sh +486 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/track-edge-case.sh +290 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/AGENT_LIFECYCLE_INTEGRATION.md +341 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/Cargo.toml +40 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/README.md +563 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/SKILL.md +343 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/analyze-agent-failures.sh +275 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/cfn-integration.sh +179 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/embeddings_manager.py +289 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/index-code.sh +234 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/ingest-agent-transcript.sh +255 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/init-local-ruvector.sh +112 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/project-structure.md +53 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/query-agent-patterns.sh +197 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/query-local.sh +169 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/requirements.txt +2 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/search_engine.py +200 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/search_engine_v2.py +238 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/sqlite_store.py +220 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/cleanup.rs +134 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/export.rs +40 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/index.rs +301 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/init.rs +127 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/migration.rs +74 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/mod.rs +18 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/query.rs +222 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/reset.rs +37 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/stats.rs +133 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/embeddings.rs +121 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/main.rs +359 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/migration.rs +318 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/search_engine.rs +281 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/sqlite_store.rs +211 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/test-agent-lifecycle-integration.sh +254 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/test-local-ruvector.sh +250 -0
- package/.claude/skills/cfn-loop-orchestration +1 -0
- package/.claude/skills/cfn-loop-orchestration-v2/cli/cfn-orchestrator.cjs +49 -0
- package/.claude/skills/cfn-loop-orchestration-v2/cli/orchestrate.sh +21 -0
- package/.claude/skills/cfn-loop-orchestration-v2/cli/resolve-provider-model.cjs +69 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/agent-spawner/agent-spawner.ts +34 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/cli/orchestrator-cli.ts +396 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/gate-checker/gate-checker.ts +36 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONFIDENCE_AGGREGATOR.md +564 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONFIDENCE_AGGREGATOR_QUICK_REF.md +241 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONTEXT_INJECTOR_QUICK_REFERENCE.md +362 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONTEXT_INJECTOR_README.md +307 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONTEXT_INJECTOR_USAGE_GUIDE.md +508 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/confidence-aggregator.ts +473 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/consensus.ts +87 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/context-injector.ts +349 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/context-lookup.ts +486 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/deliverable-verifier.ts +107 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/gate-check.ts +115 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/iteration-manager.ts +45 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/parse-test-results.ts +372 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/product-owner-decision.ts +316 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/spawn-agents.ts +357 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/timeout-calculator.ts +41 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/validator.ts +276 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/index.ts +16 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/orchestrate.ts +1389 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/orchestrator/orchestrator.ts +31 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/redis/redis-coordinator.ts +72 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/types.ts +244 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/utils/logger.ts +32 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/output/index.ts +6 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/output/output-processor.ts +183 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/output/src/cli/process-loop2.ts +195 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/output/src/cli/process-loop3.ts +157 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/output/src/output-processor.ts +632 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/detect-vapor.sh +59 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/index.ts +12 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/cli/detect-vapor.ts +177 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/cli/validate-deliverables.ts +161 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/cli/validate-gate.ts +139 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/types.ts +215 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/validator.ts +503 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validate-deliverables.sh +59 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validate-gate.sh +63 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validation-framework.ts +237 -0
- package/.claude/skills/cfn-mdap-context-injection/SKILL.md +14 -0
- package/.claude/skills/cfn-mdap-context-injection/inject.sh +348 -0
- package/.claude/skills/cfn-mdap-error-fixer/HANDOFF.md +383 -0
- package/.claude/skills/cfn-mdap-error-fixer/lib/fixer/cerebras-gated-fixer-v2.ts +1500 -0
- package/.claude/skills/cfn-mdap-error-fixer/lib/fixer/package.json +20 -0
- package/.claude/skills/cfn-mdap-error-fixer/skill.md +205 -0
- package/.claude/skills/cfn-memory-persistence/lib/auto/test-memory-persistence.sh +230 -0
- package/.claude/skills/cfn-memory-persistence/lib/sqlite/memory-cli.sh +74 -0
- package/.claude/skills/cfn-memory-persistence/lib/sqlite/ttl-cleanup.sh +266 -0
- package/.claude/skills/cfn-node-heap-sizer/SKILL.md +313 -0
- package/.claude/skills/cfn-node-heap-sizer/task-mode-heap-limiter.sh +326 -0
- package/.claude/skills/cfn-operations/execute.sh +175 -0
- package/.claude/skills/cfn-operations/lib/file/lib/lock.sh +361 -0
- package/.claude/skills/cfn-operations/lib/file/test.sh +373 -0
- package/.claude/skills/cfn-operations/lib/log/test.sh +400 -0
- package/.claude/skills/cfn-parameterized-queries/SKILL.md +368 -0
- package/.claude/skills/cfn-parameterized-queries/parameterized-queries.sh +249 -0
- package/.claude/skills/cfn-parameterized-queries/test-implementation.sh +237 -0
- package/.claude/skills/cfn-planning/execute.sh +159 -0
- package/.claude/skills/cfn-process-management/cfn-process +16 -0
- package/.claude/skills/cfn-process-management/cli/process-manager +186 -0
- package/.claude/skills/cfn-process-management/lib/lifecycle/process-manager.sh +334 -0
- package/.claude/skills/cfn-project-management/SKILL.md +60 -0
- package/.claude/skills/cfn-provider-routing +1 -0
- package/.claude/skills/cfn-redis-coordination +1 -0
- package/.claude/skills/cfn-routing-config/lib/provider/resolve-provider-model.ts +252 -0
- package/.claude/skills/cfn-session-handoff/SKILL.md +53 -0
- package/.claude/skills/cfn-skill-management/FIXES_APPLIED.md +80 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/package.json +56 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/cli.ts +75 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/database-adapter.ts +239 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/file-system-adapter.ts +113 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/index.ts +72 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/logger.ts +43 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/metadata-parser.ts +154 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/skill-propagator.ts +274 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/skill-validator.ts +179 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/types.ts +143 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/version-manager.ts +118 -0
- package/.claude/skills/cfn-skill-management/src/cli/skill-loader.ts +364 -0
- package/.claude/skills/cfn-skill-management/src/lib/database-service.ts +313 -0
- package/.claude/skills/cfn-sprint-execution/execute.sh +257 -0
- package/.claude/skills/cfn-sprint-execution/lib/execution/execute-sprint-task.sh +68 -0
- package/.claude/skills/cfn-task-decomposition/explore-123-subtasks.json +27 -0
- package/.claude/skills/cfn-task-decomposition/prompts/explore-123-analyze-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/prompts/explore-123-scan-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/prompts/test-final-fix-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/prompts/test-final-pattern-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/prompts/test-final-recon-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/prompts/test-final-validate-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/test-456-subtasks.json +60 -0
- package/.claude/skills/cfn-task-decomposition/test-789-subtasks.json +60 -0
- package/.claude/skills/cfn-task-decomposition/test-999-subtasks.json +27 -0
- package/.claude/skills/cfn-task-decomposition/test-debug-subtasks.json +60 -0
- package/.claude/skills/cfn-task-decomposition/test-debug2-subtasks.json +60 -0
- package/.claude/skills/cfn-task-decomposition/test-final-subtasks.json +60 -0
- package/.claude/skills/cfn-task-decomposition/test-simple-subtasks.json +60 -0
- package/.claude/skills/cfn-task-intelligence/SKILL.md +18 -0
- package/.claude/skills/cfn-task-intelligence/cfn-task-intelligence.sh +158 -0
- package/.claude/skills/cfn-task-intelligence/lib/integration/SKILL.md +339 -0
- package/.claude/skills/cfn-task-intelligence/lib/integration/learning-loop.sh +127 -0
- package/.claude/skills/cfn-task-intelligence/lib/integration/post-feedback-hook.sh +124 -0
- package/.claude/skills/cfn-task-intelligence/lib/integration/pre-execution-hook.sh +59 -0
- package/.claude/skills/cfn-task-planning/SKILL.md +15 -0
- package/.claude/skills/cfn-task-planning/cli/classify-task.sh +4 -0
- package/.claude/skills/cfn-task-planning/cli/decompose-task.sh +4 -0
- package/.claude/skills/cfn-task-planning/cli/init-config.sh +4 -0
- package/.claude/skills/cfn-task-planning/lib/audit/get-audit-data.sh +397 -0
- package/.claude/skills/cfn-task-planning/lib/audit/store-task-audit.sh +191 -0
- package/.claude/skills/cfn-task-planning/lib/decomposition/task-decomposer.sh +415 -0
- package/.claude/skills/cfn-test-framework/CLI.md +191 -0
- package/.claude/skills/cfn-test-framework/execute.sh +386 -0
- package/.claude/skills/cfn-transparency-middleware/CACHE_MANAGER.md +98 -0
- package/.claude/skills/cfn-transparency-middleware/Cargo.lock +2358 -0
- package/.claude/skills/cfn-transparency-middleware/Cargo.toml +20 -0
- package/.claude/skills/cfn-transparency-middleware/README.md +327 -0
- package/.claude/skills/cfn-transparency-middleware/SKILL.md +327 -0
- package/.claude/skills/cfn-transparency-middleware/config.json +23 -0
- package/.claude/skills/cfn-transparency-middleware/fix_redact.sh +12 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-filter.sh +98 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-init.sh +224 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-level.sh +333 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-metrics.sh +345 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-observe.sh +140 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-stop.sh +235 -0
- package/.claude/skills/cfn-transparency-middleware/src/agent_metrics.rs +480 -0
- package/.claude/skills/cfn-transparency-middleware/src/api_handler.rs +318 -0
- package/.claude/skills/cfn-transparency-middleware/src/cache_manager.rs +219 -0
- package/.claude/skills/cfn-transparency-middleware/src/fix_regex.rs +9 -0
- package/.claude/skills/cfn-transparency-middleware/src/lib.rs +391 -0
- package/.claude/skills/cfn-transparency-middleware/src/main.rs +205 -0
- package/.claude/skills/cfn-transparency-middleware/src/memory_query.rs +93 -0
- package/.claude/skills/cfn-transparency-middleware/src/memory_repository.rs +169 -0
- package/.claude/skills/cfn-transparency-middleware/src/memory_schema.rs +154 -0
- package/.claude/skills/cfn-transparency-middleware/src/test_fix.txt +2 -0
- package/.claude/skills/cfn-transparency-middleware/test-integration.sh +162 -0
- package/.claude/skills/cfn-utilities/lib/logging.sh +77 -0
- package/.claude/skills/cfn-validation-framework/execute.sh +223 -0
- package/.claude/skills/equation-solver/solve.sh +352 -0
- package/.claude/skills/equation-solver/test.cjs +25 -0
- package/.claude/skills/shared/bootstrap/sqlite-params.sh +156 -0
- package/.claude/skills/shared/lib/path-utils.sh +139 -0
- package/.claude/skills-database/APPROVAL_CRITERIA.md +925 -0
- package/.claude/skills-database/APPROVAL_WORKFLOW.md +1482 -0
- package/.claude/skills-database/ARCHITECTURE_DECISIONS.md +456 -0
- package/.claude/skills-database/IMPLEMENTATION_GUIDE.md +763 -0
- package/.claude/skills-database/README.md +564 -0
- package/.claude/skills-database/TDD_SKILLS_DB_INTEGRATION.md +2286 -0
- package/.claude/skills-database/schema-v2.sql +587 -0
- package/.claude/slash-commands.json +92 -0
- package/.claude/spawn-pattern-examples.md +500 -0
- package/.claude/sprint-configs/cfn-naming-standardization.json +729 -0
- package/.claude/state/cfn-expert-last-commit +2 -0
- package/.claude/tooling/jq +0 -0
- package/fix-node_modules.md +68 -0
- package/package.json +44 -40
- package/readme/COMPONENT_NPM_STATUS.md +1 -1
- package/readme/installation-process.md +1 -1
- package/scripts/cfn-init.js +377 -0
- package/scripts/postinstall.js +144 -0
- package/trigger.config.ts +9 -0
- package/claude-assets/agents/cfn-dev-team/analysts/analyst.md +0 -113
- package/claude-assets/agents/cfn-dev-team/analysts/root-cause-analyst.md +0 -257
- package/claude-assets/agents/cfn-dev-team/architecture/api-designer-persona.md +0 -145
- package/claude-assets/agents/cfn-dev-team/architecture/base-template-generator.md +0 -150
- package/claude-assets/agents/cfn-dev-team/architecture/goal-planner.md +0 -173
- package/claude-assets/agents/cfn-dev-team/architecture/planner.md +0 -132
- package/claude-assets/agents/cfn-dev-team/architecture/system-architect.md +0 -125
- package/claude-assets/agents/cfn-dev-team/coordinators/cfn-frontend-coordinator.md +0 -886
- package/claude-assets/agents/cfn-dev-team/coordinators/consensus-builder.md +0 -473
- package/claude-assets/agents/cfn-dev-team/coordinators/handoff-coordinator.md +0 -740
- package/claude-assets/agents/cfn-dev-team/coordinators/multi-sprint-coordinator.md +0 -503
- package/claude-assets/agents/cfn-dev-team/dev-ops/devops-engineer.md +0 -150
- package/claude-assets/agents/cfn-dev-team/dev-ops/docker-specialist.md +0 -664
- package/claude-assets/agents/cfn-dev-team/dev-ops/github-commit-agent.md +0 -116
- package/claude-assets/agents/cfn-dev-team/dev-ops/kubernetes-specialist.md +0 -617
- package/claude-assets/agents/cfn-dev-team/developers/api-gateway-specialist.md +0 -970
- package/claude-assets/agents/cfn-dev-team/developers/backend-developer.md +0 -192
- package/claude-assets/agents/cfn-dev-team/developers/data/data-engineer.md +0 -665
- package/claude-assets/agents/cfn-dev-team/developers/database/database-architect.md +0 -369
- package/claude-assets/agents/cfn-dev-team/developers/database/supabase-specialist.md +0 -739
- package/claude-assets/agents/cfn-dev-team/developers/frontend/mobile-dev.md +0 -240
- package/claude-assets/agents/cfn-dev-team/developers/frontend/react-frontend-engineer.md +0 -256
- package/claude-assets/agents/cfn-dev-team/developers/frontend/typescript-specialist.md +0 -389
- package/claude-assets/agents/cfn-dev-team/developers/frontend/ui-designer.md +0 -214
- package/claude-assets/agents/cfn-dev-team/developers/graphql-specialist.md +0 -700
- package/claude-assets/agents/cfn-dev-team/developers/rust-developer.md +0 -221
- package/claude-assets/agents/cfn-dev-team/documentation/agent-type-guidelines.md +0 -469
- package/claude-assets/agents/cfn-dev-team/documentation/api-documentation.md +0 -104
- package/claude-assets/agents/cfn-dev-team/documentation/pseudocode.md +0 -137
- package/claude-assets/agents/cfn-dev-team/documentation/specification-agent.md +0 -145
- package/claude-assets/agents/cfn-dev-team/product-owners/accessibility-advocate-persona.md +0 -112
- package/claude-assets/agents/cfn-dev-team/product-owners/cto-agent.md +0 -131
- package/claude-assets/agents/cfn-dev-team/product-owners/power-user-persona.md +0 -144
- package/claude-assets/agents/cfn-dev-team/product-owners/product-owner.md +0 -476
- package/claude-assets/agents/cfn-dev-team/reviewers/code-reviewer.md +0 -287
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/code-quality-validator.md +0 -213
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/cyclomatic-complexity-reducer.md +0 -327
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/perf-analyzer.md +0 -250
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/performance-benchmarker.md +0 -153
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/quality-metrics.md +0 -379
- package/claude-assets/agents/cfn-dev-team/testers/api-testing-specialist.md +0 -750
- package/claude-assets/agents/cfn-dev-team/testers/chaos-engineering-specialist.md +0 -937
- package/claude-assets/agents/cfn-dev-team/testers/contract-tester.md +0 -680
- package/claude-assets/agents/cfn-dev-team/testers/e2e/playwright-tester.md +0 -117
- package/claude-assets/agents/cfn-dev-team/testers/integration-tester.md +0 -778
- package/claude-assets/agents/cfn-dev-team/testers/interaction-tester.md +0 -181
- package/claude-assets/agents/cfn-dev-team/testers/load-testing-specialist.md +0 -498
- package/claude-assets/agents/cfn-dev-team/testers/mutation-testing-specialist.md +0 -636
- package/claude-assets/agents/cfn-dev-team/testers/playwright-tester.md +0 -246
- package/claude-assets/agents/cfn-dev-team/testers/tester.md +0 -208
- package/claude-assets/agents/cfn-dev-team/testers/unit/tdd-london-unit-swarm.md +0 -30
- package/claude-assets/agents/cfn-dev-team/testers/validation/validation-production-validator.md +0 -20
- package/claude-assets/agents/cfn-dev-team/testing/test-validation-agent.md +0 -273
- package/claude-assets/agents/cfn-dev-team/utility/agent-builder.md +0 -480
- package/claude-assets/agents/cfn-dev-team/utility/context-curator.md +0 -62
- package/claude-assets/agents/cfn-dev-team/utility/epic-creator.md +0 -132
- package/claude-assets/agents/cfn-dev-team/utility/memory-leak-specialist.md +0 -170
- package/claude-assets/agents/cfn-dev-team/utility/researcher.md +0 -109
- package/claude-assets/agents/cfn-dev-team/utility/z-ai-specialist.md +0 -211
- package/claude-assets/agents/custom/cfn-docker-expert.md +0 -104
- package/claude-assets/agents/custom/cfn-loops-cli-expert.md +0 -455
- package/claude-assets/agents/custom/cfn-redis-operations.md +0 -531
- package/claude-assets/agents/custom/cfn-system-expert.md +0 -337
- package/claude-assets/agents/custom/claude-code-expert.md +0 -291
- package/claude-assets/agents/custom/mdap-trigger-specialist.md +0 -437
- package/claude-assets/agents/custom/trigger-dev-expert.md +0 -370
- package/claude-assets/agents/docker-coordinators/cfn-docker-v3-coordinator.md +0 -1094
- package/claude-assets/agents/docker-ts-fixer.md +0 -58
- package/claude-assets/agents/project-only-agents/npm-package-specialist.md +0 -327
- package/claude-assets/commands/README.md +0 -205
- package/claude-assets/commands/cfn-loop/CFN_LOOP_FRONTEND.md +0 -741
- package/claude-assets/commands/cfn-loop/CFN_LOOP_TASK_MODE.md +0 -608
- package/claude-assets/commands/cfn-loop/cfn-loop-cli.md +0 -308
- package/claude-assets/commands/cfn-loop/cfn-loop-trigger.md +0 -132
- package/claude-assets/commands/deprecated/README.md +0 -24
- package/claude-assets/hooks/SKILL.md +0 -518
- package/claude-assets/hooks/SKILL.md.backup +0 -471
- package/claude-assets/hooks/cfn-invoke-post-edit-ts.sh.backup +0 -78
- package/claude-assets/hooks/cfn-invoke-post-edit.sh.backup +0 -87
- package/claude-assets/hooks/cfn-invoke-pre-edit-ts.sh.backup +0 -94
- package/claude-assets/hooks/cfn-invoke-pre-edit.sh.backup +0 -88
- package/claude-assets/hooks/cfn-post-edit.config.json +0 -51
- package/claude-assets/hooks/cfn-post-execution/memory-cleanup.sh +0 -20
- package/claude-assets/hooks/cfn-pre-edit-security-warning.sh +0 -40
- package/claude-assets/hooks/cfn-pre-execution/SESSION_START_README.md +0 -87
- package/claude-assets/hooks/cfn-pre-execution/TEST_SESSION_START.md +0 -128
- package/claude-assets/hooks/cfn-pre-execution/memory-check.sh +0 -20
- package/claude-assets/hooks/cfn-pre-execution/session-start-context.sh +0 -111
- package/claude-assets/hooks/subagent-start.sh +0 -98
- package/claude-assets/hooks/subagent-stop.sh +0 -93
- package/claude-assets/skills/cfn-agent-lifecycle/SKILL.md +0 -290
- package/claude-assets/skills/cfn-agent-lifecycle/cli/lifecycle-hook.sh +0 -5
- package/claude-assets/skills/cfn-agent-lifecycle/cli/select-agents.sh +0 -5
- package/claude-assets/skills/cfn-agent-lifecycle/cli/spawn-agent.sh +0 -5
- package/claude-assets/skills/cfn-agent-lifecycle/lib/audit/execute-lifecycle-hook.sh +0 -544
- package/claude-assets/skills/cfn-agent-lifecycle/lib/selection/dist/agent-selector.cjs +0 -297
- package/claude-assets/skills/cfn-agent-lifecycle/lib/selection/dist/agent-selector.js +0 -297
- package/claude-assets/skills/cfn-agent-lifecycle/lib/selection/dist/cli.cjs +0 -96
- package/claude-assets/skills/cfn-agent-lifecycle/lib/selection/dist/cli.js +0 -96
- package/claude-assets/skills/cfn-agent-lifecycle/lib/spawning/spawn-agent-wrapper.sh +0 -63
- package/claude-assets/skills/cfn-cerebras-mcp/SKILL.md +0 -58
- package/claude-assets/skills/cfn-config/lib/management/manage-config.sh +0 -113
- package/claude-assets/skills/cfn-dependency-management/SKILL.md +0 -60
- package/claude-assets/skills/cfn-dependency-management/lib/ingestion/dist/ingest-dependencies.js +0 -478
- package/claude-assets/skills/cfn-docker-runtime/lib/build/SKILL.md +0 -96
- package/claude-assets/skills/cfn-docker-runtime/lib/build/build.sh +0 -73
- package/claude-assets/skills/cfn-docker-runtime/lib/coordination/README.md +0 -349
- package/claude-assets/skills/cfn-docker-runtime/lib/coordination/docker-helpers.sh +0 -433
- package/claude-assets/skills/cfn-docker-runtime/lib/coordination/package.json +0 -38
- package/claude-assets/skills/cfn-edit-safety/lib/backup/SKILL.md.backup +0 -277
- package/claude-assets/skills/cfn-edit-safety/lib/backup/backup.sh.backup +0 -107
- package/claude-assets/skills/cfn-edit-safety/lib/hooks/post-edit-handler.sh +0 -154
- package/claude-assets/skills/cfn-epic-parser/SKILL.md +0 -55
- package/claude-assets/skills/cfn-error-management/cli/batch-errors.sh +0 -4
- package/claude-assets/skills/cfn-error-management/cli/capture-error.sh +0 -4
- package/claude-assets/skills/cfn-error-management/cli/log-error.sh +0 -4
- package/claude-assets/skills/cfn-expert-update/SKILL.md +0 -24
- package/claude-assets/skills/cfn-expert-update/update-expert.sh +0 -346
- package/claude-assets/skills/cfn-github-workflow/SKILL.md +0 -70
- package/claude-assets/skills/cfn-intervention-system/lib/detector/detect-intervention.sh +0 -111
- package/claude-assets/skills/cfn-knowledge-base/SKILL.md +0 -61
- package/claude-assets/skills/cfn-knowledge-base/lib/playbook/SKILL.md +0 -153
- package/claude-assets/skills/cfn-knowledge-base/lib/playbook/init-playbook.sh +0 -54
- package/claude-assets/skills/cfn-knowledge-base/lib/playbook/query-playbook.sh +0 -83
- package/claude-assets/skills/cfn-knowledge-base/lib/playbook/update-playbook.sh +0 -80
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/COST_TRACKING.md +0 -637
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/EDGE_CASE_TRACKING.md +0 -404
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/README_PHASE4.md +0 -457
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/SKILL.md +0 -110
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/generate-skill-update.sh +0 -525
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/propagate-skill-update.sh +0 -648
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/track-cost-savings.sh +0 -486
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/track-edge-case.sh +0 -290
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/coordination/agent-completion.sh.backup +0 -36
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/coordination/coordination-signal.sh.backup +0 -36
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/coordination/coordination-wait.sh.backup +0 -36
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/agent-spawner/agent-spawner.d.ts +0 -15
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/agent-spawner/agent-spawner.js +0 -29
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/cli/orchestrator-cli.d.ts +0 -49
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/cli/orchestrator-cli.js +0 -339
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/gate-checker/gate-checker.d.ts +0 -15
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/gate-checker/gate-checker.js +0 -32
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/confidence-aggregator.d.ts +0 -115
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/confidence-aggregator.js +0 -359
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/consensus.d.ts +0 -36
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/consensus.js +0 -62
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/context-injector.d.ts +0 -135
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/context-injector.js +0 -257
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/context-lookup.d.ts +0 -179
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/context-lookup.js +0 -388
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/deliverable-verifier.d.ts +0 -26
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/deliverable-verifier.js +0 -116
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/gate-check.d.ts +0 -27
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/gate-check.js +0 -92
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/iteration-manager.d.ts +0 -28
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/iteration-manager.js +0 -34
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/parse-test-results.d.ts +0 -21
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/parse-test-results.js +0 -323
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/product-owner-decision.d.ts +0 -86
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/product-owner-decision.js +0 -272
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/spawn-agents.d.ts +0 -61
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/spawn-agents.js +0 -280
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/timeout-calculator.d.ts +0 -15
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/timeout-calculator.js +0 -34
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/validator.d.ts +0 -83
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/validator.js +0 -222
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/index.d.ts +0 -14
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/index.js +0 -32
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/orchestrate.d.ts +0 -325
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/orchestrate.js +0 -1083
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/orchestrator/orchestrator.d.ts +0 -17
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/orchestrator/orchestrator.js +0 -31
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/redis/redis-coordinator.d.ts +0 -46
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/redis/redis-coordinator.js +0 -68
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/types.d.ts +0 -166
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/types.js +0 -101
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/utils/logger.d.ts +0 -16
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/utils/logger.js +0 -29
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/orchestrate.sh.backup2 +0 -959
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/orchestrate.sh.clean +0 -949
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/SKILL.md.backup +0 -353
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/check-dependencies.sh.backup +0 -31
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/detect-vapor.sh +0 -59
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/detect-vapor.sh.backup +0 -37
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/.tsbuildinfo +0 -1
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/detect-vapor.d.ts +0 -14
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/detect-vapor.js +0 -185
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/validate-deliverables.d.ts +0 -14
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/validate-deliverables.js +0 -176
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/validate-gate.d.ts +0 -19
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/validate-gate.js +0 -123
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/types.d.ts +0 -156
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/types.js +0 -66
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/validator.d.ts +0 -85
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/validator.js +0 -411
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/orchestrate-cfn-loop.sh.backup +0 -252
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/validate-deliverables.sh +0 -59
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/validate-deliverables.sh.backup +0 -37
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/validate-gate.sh +0 -63
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/validate-gate.sh.backup +0 -41
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/validate-iteration.sh.backup +0 -134
- package/claude-assets/skills/cfn-mdap-context-injection/SKILL.md +0 -176
- package/claude-assets/skills/cfn-mdap-context-injection/inject.sh +0 -284
- package/claude-assets/skills/cfn-memory-persistence/lib/auto/test-memory-persistence.sh +0 -236
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/agent-log.sh.backup +0 -128
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/agent-recovery.sh.backup +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/analyze-task-complexity.sh.backup +0 -277
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/bash-wrappers/store-context.sh.backup +0 -23
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/cancel-swarm.sh.backup +0 -221
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/cfn-loop-exec.sh.backup +0 -468
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/cfn-loop-relaunch.sh.backup +0 -29
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/collect-confidence-scores.sh.backup +0 -209
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/collect-results.sh.backup +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/complete-swarm.sh.backup +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/agent-logger.d.ts +0 -92
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/agent-logger.js +0 -329
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/agent-recovery.d.ts +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/agent-recovery.js +0 -302
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/completion-reporter.d.ts +0 -58
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/completion-reporter.js +0 -237
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/context-manager.d.ts +0 -63
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/context-manager.js +0 -230
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/index.d.ts +0 -45
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/index.js +0 -114
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/mode-detector.d.ts +0 -31
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/mode-detector.js +0 -185
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/redis-client.d.ts +0 -191
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/redis-client.js +0 -509
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/result-collector.d.ts +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/result-collector.js +0 -281
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/swarm-manager.d.ts +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/swarm-manager.js +0 -354
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/task-analyzer.d.ts +0 -62
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/task-analyzer.js +0 -305
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/task-executor.d.ts +0 -97
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/task-executor.js +0 -283
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/types.d.ts +0 -176
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/types.js +0 -81
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/waiting-coordinator.d.ts +0 -86
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/waiting-coordinator.js +0 -419
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/get-context.sh.backup +0 -146
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/get-success-criteria.sh.backup +0 -54
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/invoke-waiting-mode.sh.backup +0 -225
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/redis-cli-wrapper.sh.backup +0 -43
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/redis-functions.sh.backup +0 -34
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/report-completion.sh.backup +0 -134
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/store-context.sh.backup +0 -123
- package/claude-assets/skills/cfn-memory-persistence/lib/sqlite/memory-cli.sh +0 -88
- package/claude-assets/skills/cfn-memory-persistence/lib/sqlite/ttl-cleanup.sh +0 -266
- package/claude-assets/skills/cfn-node-heap-sizer/SKILL.md +0 -23
- package/claude-assets/skills/cfn-node-heap-sizer/task-mode-heap-limiter.sh +0 -326
- package/claude-assets/skills/cfn-operations/lib/file/lib/lock.sh +0 -361
- package/claude-assets/skills/cfn-operations/lib/file/test.sh +0 -369
- package/claude-assets/skills/cfn-operations/lib/log/test.sh +0 -394
- package/claude-assets/skills/cfn-parameterized-queries/SKILL.md +0 -347
- package/claude-assets/skills/cfn-process-management/lib/lifecycle/process-manager.sh +0 -144
- package/claude-assets/skills/cfn-project-analysis/SKILL.md +0 -113
- package/claude-assets/skills/cfn-project-management/SKILL.md +0 -52
- package/claude-assets/skills/cfn-routing-config/lib/provider/resolve-provider-model.ts +0 -223
- package/claude-assets/skills/cfn-ruvector-codebase-index/.cfn-manifest.json +0 -37
- package/claude-assets/skills/cfn-ruvector-codebase-index/SKILL.md +0 -830
- package/claude-assets/skills/cfn-ruvector-codebase-index/batch-indexer.js +0 -185
- package/claude-assets/skills/cfn-ruvector-codebase-index/check-db.js +0 -8
- package/claude-assets/skills/cfn-ruvector-codebase-index/clean-orphaned-entries.sh +0 -206
- package/claude-assets/skills/cfn-ruvector-codebase-index/config.json +0 -65
- package/claude-assets/skills/cfn-ruvector-codebase-index/debug-search.js +0 -19
- package/claude-assets/skills/cfn-ruvector-codebase-index/detect-stale-docs.sh +0 -325
- package/claude-assets/skills/cfn-ruvector-codebase-index/embeddings.js +0 -181
- package/claude-assets/skills/cfn-ruvector-codebase-index/get-embedding-text.js +0 -26
- package/claude-assets/skills/cfn-ruvector-codebase-index/handle-file-moves.sh +0 -147
- package/claude-assets/skills/cfn-ruvector-codebase-index/index.sh +0 -324
- package/claude-assets/skills/cfn-ruvector-codebase-index/indexer.js +0 -53
- package/claude-assets/skills/cfn-ruvector-codebase-index/init-db.js +0 -27
- package/claude-assets/skills/cfn-ruvector-codebase-index/install-hook.sh +0 -51
- package/claude-assets/skills/cfn-ruvector-codebase-index/package.json +0 -30
- package/claude-assets/skills/cfn-ruvector-codebase-index/parser.js +0 -264
- package/claude-assets/skills/cfn-ruvector-codebase-index/query-error-patterns.sh +0 -42
- package/claude-assets/skills/cfn-ruvector-codebase-index/query-learnings.sh +0 -44
- package/claude-assets/skills/cfn-ruvector-codebase-index/ruvector-learning.js +0 -316
- package/claude-assets/skills/cfn-ruvector-codebase-index/search.js +0 -55
- package/claude-assets/skills/cfn-ruvector-codebase-index/search.sh +0 -137
- package/claude-assets/skills/cfn-ruvector-codebase-index/standalone-indexer.js +0 -129
- package/claude-assets/skills/cfn-ruvector-codebase-index/store-error-pattern.sh +0 -54
- package/claude-assets/skills/cfn-ruvector-codebase-index/store-learning.sh +0 -64
- package/claude-assets/skills/cfn-ruvector-codebase-index/test-comprehensive.js +0 -120
- package/claude-assets/skills/cfn-ruvector-codebase-index/test-db-structure.js +0 -40
- package/claude-assets/skills/cfn-ruvector-codebase-index/test-integration.js +0 -56
- package/claude-assets/skills/cfn-ruvector-codebase-index/test-metadata-fetch.js +0 -57
- package/claude-assets/skills/cfn-ruvector-codebase-index/test-search-debug.js +0 -48
- package/claude-assets/skills/cfn-session-handoff/SKILL.md +0 -273
- package/claude-assets/skills/cfn-skill-management/lib/propagation/package.json +0 -52
- package/claude-assets/skills/cfn-sprint-execution/lib/execution/execute-sprint-task.sh +0 -59
- package/claude-assets/skills/cfn-task-intelligence/SKILL.md +0 -64
- package/claude-assets/skills/cfn-task-planning/SKILL.md +0 -193
- package/claude-assets/skills/cfn-task-planning/cli/classify-task.sh +0 -4
- package/claude-assets/skills/cfn-task-planning/cli/decompose-task.sh +0 -4
- package/claude-assets/skills/cfn-task-planning/cli/init-config.sh +0 -4
- package/claude-assets/skills/cfn-task-planning/lib/audit/get-audit-data.sh +0 -397
- package/claude-assets/skills/cfn-task-planning/lib/audit/store-task-audit.sh +0 -191
- package/claude-assets/skills/cfn-task-planning/lib/decomposition/task-decomposer.sh +0 -279
- package/claude-assets/skills/cfn-transparency-middleware/Cargo.toml +0 -18
- package/claude-assets/skills/cfn-transparency-middleware/README.md +0 -74
- package/claude-assets/skills/cfn-transparency-middleware/SKILL.md +0 -99
- package/claude-assets/skills/cfn-transparency-middleware/config.json +0 -31
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-filter.sh +0 -98
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-init.sh +0 -224
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-level.sh +0 -333
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-metrics.sh +0 -345
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-observe.sh +0 -140
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-stop.sh +0 -235
- package/claude-assets/skills/cfn-transparency-middleware/memory_query.rs +0 -85
- package/claude-assets/skills/cfn-transparency-middleware/memory_repository.rs +0 -140
- package/claude-assets/skills/cfn-transparency-middleware/memory_schema.rs +0 -64
- package/claude-assets/skills/cfn-transparency-middleware/test-integration.sh +0 -162
- package/claude-assets/skills/cfn-utilities/lib/logging.sh +0 -77
- package/claude-assets/skills/equation-solver/solve.sh +0 -348
- package/scripts/init-project.js +0 -455
- /package/{claude-assets → .claude}/agents/AGENT_LIFECYCLE.md +0 -0
- /package/{claude-assets → .claude}/agents/README-AGENT_LIFECYCLE.md +0 -0
- /package/{claude-assets → .claude}/agents/README-VALIDATION.md +0 -0
- /package/{claude-assets → .claude}/agents/SHARED_PROTOCOL.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/CLAUDE.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/README.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/coordinators/README.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/developers/README.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/documentation/README-VALIDATION.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/reviewers/README.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/testers/README.md +0 -0
- /package/{claude-assets → .claude}/agents/csuite/cto-agent.md +0 -0
- /package/{claude-assets → .claude}/agents/validate-agent.js +0 -0
- /package/{claude-assets → .claude}/cfn-extras/.gs-api-quota.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/.gs-progress-state.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cfn-coordinator-enterprise.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cfn-coordinator-mvp.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cfn-coordinator-standard.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cfn-loop-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cfn-v3-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/code-booster.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cost-savings-cfn-loop-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cost-savings-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator-enhanced.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/blocking-coordinator-example.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/byzantine-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-enterprise.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-mvp.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-standard.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-unified.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/coordinator-hybrid.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/gossip-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/hierarchical-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/mesh-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/task-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/test-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/docker-team/csuite/c-suite-template.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/docker-team/infrastructure/team-coordinator-template.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/docker-team/micro-sprint-planner.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/README.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-advanced-analytics-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-api-integrator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-automation-scripting-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-business-validator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-collaboration-security-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-data-transformer.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-data-validation-quality-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-data-validator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-data-visualization-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-design-layout-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-formula-engineer.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-formula-engineering-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-formula-validator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-generalist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-integration-api-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-performance-analyst.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-performance-optimization-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-schema-designer.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-template-architecture-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets-specialist.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/cfn-docker/CFN_DOCKER_CLI.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/cfn-docker/CFN_DOCKER_LOOP.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/cfn-docker/CFN_DOCKER_NATIVE.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/cfn-docker/CFN_DOCKER_TASK.md +0 -0
- /package/{claude-assets/commands/testing → .claude/cfn-extras/commands/cfn-docker}/cfn-docker-core-test-suite.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/CFN_EXPERT_UPDATE.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/README.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/cfn-loop-epic.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/cfn-loop-single.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/cfn-loop-sprints.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/context-curate.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/context-inject.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/context-query.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/context-stats.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/cost-savings-off.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/cost-savings-on.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/custom-routing-activate.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/custom-routing-deactivate.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/github-commit.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/deprecated/github.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/deprecated/hello-world-tests.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/parse-epic.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/deprecated/run-tests.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/suggest-improvements.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/google-sheets/google-sheets-loop.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/docs/GOOGLE_SHEETS_CFN_LOOP.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/GOOGLE_SHEETS_SKILLS_README.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-agent-swap/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-agent-swap/recommend-swap.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-api-validation/test-endpoints.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-context-pruner/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-context-pruner/prune-context.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/README.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/config.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/eventbus-wrapper.cjs +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/invoke-event-publish.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/invoke-event-subscribe.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/invoke-lifecycle-track.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/test-event-bus.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/README.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/config.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-allocate.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-balance.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-metrics.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-register.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/test-fleet-manager.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-task-mode-safety/cli-coordination.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-task-mode-safety/mode-detection.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-task-mode-sanitize/task-mode-env-sanitizer.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/agents-registry-clean.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/agents-registry-fixed.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/agents-registry.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/discover-agents.py +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/discover-agents.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/invoke-registry.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/temp_script.py +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-selector/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-selector/select-agents.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-cli-setup/validate-cli-environment.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-simplified-agent-lifecycle/DESIGN.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-api-coordinator/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-api-coordinator/api-call.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-api-coordinator/test.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-api-coordinator/validate.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-decomposition/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-decomposition/decompose.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-formula-builder/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-formula-builder/build-formula.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-formula-builder/test.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-formula-builder/validate.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-progress/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-progress/test.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-progress/track-progress.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-progress/validate.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-sprint-order/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-sprint-order/order-sprints.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-validation/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-validation/test.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-validation/validate-state.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-validation/validate.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/create-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/get-campaign-performance.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/pause-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/set-budget.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/update-bid-strategy.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-ad-performance.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-conversion-funnel.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-email-performance.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-social-engagement.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-website-traffic.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/get-conversation-history.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/qualify-lead.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/schedule-demo.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/send-message.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/transfer-to-human.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-backlink-profile.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-keyword-rankings.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-trending-topics.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/monitor-competitor.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/search-brand-mentions.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/add-to-segment.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/create-contact.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/get-contact.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/remove-from-segment.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/update-contact.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/create-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/get-campaign-stats.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/list-templates.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/schedule-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/send-test-email.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/create-ab-test.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/create-landing-page.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/get-page-performance.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/publish-page.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/unpublish-page.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/create-crisis-alert.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/export-report.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/get-sentiment-analysis.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/search-mentions.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-outreach/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/search-journalists.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/send-pitch.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/submit-haro-response.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/track-pitch-engagement.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-press-distribution/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/distribute-press-release.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/get-distribution-status.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/get-pickup-metrics.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/list-templates.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/create-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/get-delivery-status.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/opt-out.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/schedule-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/send-sms.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/create-post.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/delete-post.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/get-post-stats.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/schedule-post.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/upload-media.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/DESIGN.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-agents.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-dashboard.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-events.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-metrics.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-start.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-stop.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/test-web-portal-skill.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/validate-deployment.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/utility/cfn-environment-sanitization/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/utility/cfn-environment-sanitization/sanitize-environment.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/utility/cfn-process-instrumentation/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/utility/cfn-process-instrumentation/instrument-process.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-ad-campaigns.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-analytics-data.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-chatbot-conversations.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-competitive-intel.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-crm-contacts.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-email-campaigns.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-landing-pages.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-media-outreach.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-press-distribution.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-sms-campaigns.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-social-publishing.json +0 -0
- /package/{claude-assets/commands/cfn-loop/list-agents-rebuild.md → .claude/commands/cfn-loop/cfn-list-agents-rebuild.md} +0 -0
- /package/{claude-assets → .claude}/commands/cfn-loop/cfn-loop-document.md +0 -0
- /package/{claude-assets → .claude}/commands/cfn-loop/cfn-mode.md +0 -0
- /package/{claude-assets → .claude}/commands/cfn-loop/cfn-optimize-agents.md +0 -0
- /package/{claude-assets/commands/cfn-ruvector/codebase-reindex.md → .claude/commands/cfn-ruvector/cfn-codebase-reindex.md} +0 -0
- /package/{claude-assets/commands/cfn-ruvector/codebase-search.md → .claude/commands/cfn-ruvector/cfn-codebase-search.md} +0 -0
- /package/{claude-assets/commands/cfn-ruvector/detect-stale-docs.md → .claude/commands/cfn-ruvector/cfn-detect-stale-docs.md} +0 -0
- /package/{claude-assets/commands/cost-routing/switch-api.md → .claude/commands/cost-routing/cfn-switch-api.md} +0 -0
- /package/{claude-assets → .claude}/commands/sparc.md +0 -0
- /package/{claude-assets → .claude}/commands/workflow.md +0 -0
- /package/{claude-assets → .claude}/commands/write-plan.md +0 -0
- /package/{claude-assets → .claude}/hooks/GIT-HOOKS-USAGE-EXAMPLES.md +0 -0
- /package/{claude-assets → .claude}/hooks/README-GIT-HOOKS.md +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-BACKUP_USAGE.md +0 -0
- /package/{claude-assets/hooks/validators/credential-scanner.sh → .claude/hooks/cfn-credential-scanner.sh} +0 -0
- /package/{claude-assets/hooks/detect-hardcoded-credentials.sh → .claude/hooks/cfn-detect-hardcoded-credentials.sh} +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-invoke-post-edit-ts.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-invoke-post-edit.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-invoke-pre-edit-ts.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-invoke-pre-edit.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-invoke-security-validation.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-lint-sql-injection.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-post-edit-cfn-retrospective.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-post-edit.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-pre-edit-backup.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-restore-from-backup.sh +0 -0
- /package/{claude-assets → .claude}/hooks/install-git-hooks.sh +0 -0
- /package/{claude-assets → .claude}/hooks/post-commit-codebase-index +0 -0
- /package/{claude-assets → .claude}/root-claude-distribute/CFN-CLAUDE.md +0 -0
- /package/{claude-assets → .claude}/skills/SKILL_TEMPLATE.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/audit/simple-audit.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/output/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/selection/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/selection/agent-mappings.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/selection/select-agents-with-fallback.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/selection/select-agents.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/selection/task-classifier.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/execute-agent.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/get-agent-provider-env.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/parse-agent-provider.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/spawn-agent.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/spawn-templates.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/spawn-worker.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-tooling/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-tooling/lib/generator/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-tooling/lib/generator/generate-agent.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-tooling/lib/linter/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-tooling/lib/linter/lint-agents.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/lib/management/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/lib/management/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/lib/management/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/lib/management/config.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/lib/sanitization/sanitize-environment.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-conversation-sync/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-conversation-sync/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-conversation-sync/sync-conversations.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/extractor/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/extractor/extract-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/build.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/ingest-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/ingest.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/manifests/cli-mode-dependencies.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/manifests/shared-dependencies.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/manifests/trigger-dev-dependencies.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/manifests/trigger-mode-dependencies.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-deployment-lifecycle/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-deployment-lifecycle/lib/deployment/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-deployment-lifecycle/lib/deployment/execute.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-deployment-lifecycle/lib/promotion/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/INTEGRATION.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/SAMPLE_OUTPUTS.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/capture-container-logs.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/enable-logging.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/init-hybrid-logging.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/analytics-summary.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/query-agent-timeline.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/query-consensus-history.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/query-coordination-timeline.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/query-failed-containers.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/query-gate-checks.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/schema.sql +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/sqlite-helpers.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/test-hybrid-logging.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/mcp/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/mcp/skill-mcp-selector.js +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/orchestration/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/orchestration/orchestrate.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/spawning/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/spawning/spawn-agent.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/waves/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/waves/cleanup-wave.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/waves/lib/docker-helpers.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/waves/monitor-wave.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/waves/spawn-wave.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/backup/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/backup/backup.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/auto-resolve.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/feedback-resolver.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/security-scan.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/security-scanner.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/test-root-warning-resolution.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/analyze-errors.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/calculate-waves.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/cli.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/cluster-files.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/create-batches.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/capture/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/capture/capture-agent-error.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/cleanup-error-logs.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/integrate-cli.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/integrate-docker.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/invoke-error-logging.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/test-error-logging.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-intervention-system/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-intervention-system/lib/detector/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-intervention-system/lib/orchestrator/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-intervention-system/lib/orchestrator/execute-intervention.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/playbook/lib/auto-update/auto-update-playbook.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/APPROVAL_WORKFLOW.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/DEPLOY_QUICK_REFERENCE.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/PROPAGATE_UPDATE_QUICK_REFERENCE.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/approval-workflow.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/deploy-approved-skill.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/deploy-approved-skill.sh.backup-1763392820 +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/lib/security-utils.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/package.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/propagate-skill-update.sh.backup-1763392820 +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/review-skill.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/test-integration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/test-metadata-update.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/track-cost-savings.sh.backup-1763392821 +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/decision/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/decision/TYPESCRIPT_IMPLEMENTATION.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/decision/parse-decision.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/decision/test-backlog-integration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/decision/validate-deliverables.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/CONFIGURATION_IMPROVEMENTS.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/CONTEXT_LOOKUP_QUICK_START.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/NORTH_STAR_INDEX.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/ORCHESTRATOR_IMPLEMENTATION.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/ORCHESTRATOR_QUICK_START.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/SPAWN_AGENTS_IMPLEMENTATION.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/VALIDATION_SUMMARY.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/VALIDATOR_MODULE_GUIDE.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/e2e-validation-fixed.js +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/e2e-validation.js +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/package.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/run-north-star-e2e.ts +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/security_utils.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-cfn-orchestration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-cli.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-edge-cases.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-iteration-context-injection.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-typescript-integration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/DELIVERY_SUMMARY.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/EXAMPLES.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/INDEX.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/package.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/INDEX.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/README_TYPESCRIPT.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/SKILL_TYPESCRIPT.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/VAPOR_DETECTION_EXAMPLES.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/config.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/consensus-calculator.js +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/evidence-chain.sql +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/orchestrate-cfn-loop.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/package.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/validate-iteration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/auto/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/auto/persist-agent-output.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/auto/query-agent-history.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/management/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/management/check-memory.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/management/cleanup-memory.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/redis/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/QUICK_REFERENCE.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/acl-queries.sql +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/config.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/test-state-persistence.js +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/file/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/file/execute.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/file/lib/atomic-write.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/log/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/log/execute.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/log/lib/rotate.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/log/lib/search.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/map-dependencies-conflicts.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/plan-coordinator-resources.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/plan-multi-coordinator-work.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/plan-risk-rollout.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/test-multi-coordinator-planning.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/validate-task-planning.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/epic/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/epic/decompose-epic.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/scope/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/scope/simplify-scope.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/lib/instrumentation/instrument-process.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/lib/lifecycle/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/lib/lifecycle/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/lib/lifecycle/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/lib/lifecycle/config.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/backlog/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/backlog/add-backlog-item.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/changelog/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/changelog/add-changelog-entry.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/changelog/bulk-import.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/changelog/lib/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/changelog/lib/validation.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/hybrid/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/hybrid/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/hybrid/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/hybrid/config.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/hybrid/spawn-worker.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/provider/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/provider/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/lib/builder/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/lib/loader/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/lib/loader/execute.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/lib/propagation/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/lib/propagation/propagate-skill-update.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/checkpoint/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/checkpoint/cleanup-orphans.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/checkpoint/resume-wave.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/checkpoint/save-checkpoint.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/execution/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/execution/execute-sprint.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/classifier/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/classifier/classify-task.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/complexity/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/complexity/estimate-complexity.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/specialist/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/specialist/recommend-specialist.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-planning/lib/classifier/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-planning/lib/classifier/classify-task.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/test-cache-reader.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/test-concurrent-conflicts.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/test-coordinator-pattern.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/detect-regressions.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/detect-regressions.sh.backup-1763392821 +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/init-benchmark-db.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/run-all-tests.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/store-benchmarks.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/validate-redis-keys.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/SCREENSHOT_NAMING_CONVENTION.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/capture-screenshot.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/cfn-loop-integration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/compare-screenshots.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/init-storage.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/set-baseline.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/test-webapp-testing.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/SECURITY.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/TEST_RESULTS.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/middleware-config.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/performance-benchmark.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/test-e2e.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/test-transparency-skill.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/test-transparency-skill.sh.unix +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/wrap-agent.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/execute.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/lib/errors.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/lib/file-ops.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/lib/retry.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/test.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/deliverables/confidence-calculator.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/instrumentation/wrapped-executor.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/json/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/json/test-validate-success-criteria.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/json/validate-success-criteria.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/layers/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-vision-analysis/SKILL.md +0 -0
- /package/{claude-assets/skills/cfn-knowledge-base/lib/workflow → .claude/skills/deprecated}/analyze-patterns.sh +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/README.md +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/SECURITY.md +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/package.json +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/test-equation-solver-minimal.sh +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/test-equation-solver.sh +0 -0
|
@@ -0,0 +1,1475 @@
|
|
|
1
|
+
#!/usr/bin/env npx tsx
|
|
2
|
+
/**
|
|
3
|
+
* Gated Rust Error Fixer V2 - Enhanced Gate Architecture
|
|
4
|
+
*
|
|
5
|
+
* Improvements over V1:
|
|
6
|
+
* - New semantic gates (G-K) for import paths, pattern duplicates, impl location, type casts
|
|
7
|
+
* - Regression seed corpus to catch known-bad patterns
|
|
8
|
+
* - Hardened prompts with explicit preservation rules
|
|
9
|
+
* - Enhanced Layer 3 reviewer with checklist
|
|
10
|
+
* - Dry-run patch mode
|
|
11
|
+
* - Gate rejection logging with feedback loop
|
|
12
|
+
* - Targeted crate compile testing
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
import createCerebrasClient from './cerebras-wrapper.js';
|
|
16
|
+
import * as fs from 'fs';
|
|
17
|
+
import * as path from 'path';
|
|
18
|
+
import { execSync } from 'child_process';
|
|
19
|
+
|
|
20
|
+
// ============== CONFIGURATION ==============
|
|
21
|
+
|
|
22
|
+
const CONFIG = {
|
|
23
|
+
maxGlobalIterations: 5,
|
|
24
|
+
maxFileRetries: 2,
|
|
25
|
+
maxLayer1Retries: 3, // Max retries when Layer 1 gates reject
|
|
26
|
+
maxTokens: 4000,
|
|
27
|
+
model: 'zai-glm-4.6',
|
|
28
|
+
projectPath: '/mnt/c/Users/masha/Documents/ourstories-v2/services/rust-services',
|
|
29
|
+
parallelLLMCalls: 10,
|
|
30
|
+
enableLayer3: !process.argv.includes('--no-layer3'),
|
|
31
|
+
enableClippy: !process.argv.includes('--no-clippy'),
|
|
32
|
+
dryRun: process.argv.includes('--dry-run'),
|
|
33
|
+
patchDir: '/tmp/rust-fix-patches',
|
|
34
|
+
verbose: process.argv.includes('--verbose'),
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
// ============== TYPE DEFINITIONS ==============
|
|
38
|
+
|
|
39
|
+
type ErrorDifficulty = 'easy' | 'medium' | 'hard';
|
|
40
|
+
|
|
41
|
+
interface RustError {
|
|
42
|
+
code: string;
|
|
43
|
+
line: number;
|
|
44
|
+
column: number;
|
|
45
|
+
message: string;
|
|
46
|
+
suggestion?: string;
|
|
47
|
+
difficulty: ErrorDifficulty;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
interface LineFix {
|
|
51
|
+
line: number;
|
|
52
|
+
action: 'replace' | 'insert_after' | 'insert_before' | 'delete';
|
|
53
|
+
content: string;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
interface LLMFixResult {
|
|
57
|
+
error: RustError;
|
|
58
|
+
fixes: LineFix[];
|
|
59
|
+
success: boolean;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
interface GateResult {
|
|
63
|
+
passed: boolean;
|
|
64
|
+
reason?: string;
|
|
65
|
+
riskLevel: 1 | 2 | 3 | 4 | 5;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
interface ReviewResult {
|
|
69
|
+
verdict: 'APPROVE' | 'REJECT';
|
|
70
|
+
reason: string;
|
|
71
|
+
riskLevel: 1 | 2 | 3 | 4 | 5;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
interface GateStats {
|
|
75
|
+
layer1Rejections: number;
|
|
76
|
+
layer2Rejections: number;
|
|
77
|
+
layer3Rejections: number;
|
|
78
|
+
approvals: number;
|
|
79
|
+
byGate: Record<string, number>;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
interface GateRejectionLog {
|
|
83
|
+
timestamp: string;
|
|
84
|
+
file: string;
|
|
85
|
+
gate: string;
|
|
86
|
+
reason: string;
|
|
87
|
+
errorCode: string;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
interface Layer1RetryContext {
|
|
91
|
+
attempt: number;
|
|
92
|
+
previousFailures: Array<{ gate: string; reason: string }>;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
const gateStats: GateStats & { layer1Retries: number } = {
|
|
96
|
+
layer1Rejections: 0,
|
|
97
|
+
layer2Rejections: 0,
|
|
98
|
+
layer3Rejections: 0,
|
|
99
|
+
layer1Retries: 0,
|
|
100
|
+
approvals: 0,
|
|
101
|
+
byGate: {}
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
const rejectionLog: GateRejectionLog[] = [];
|
|
105
|
+
|
|
106
|
+
const ERROR_CLASSIFICATION: Record<string, ErrorDifficulty> = {
|
|
107
|
+
'E0425': 'easy', 'E0433': 'easy', 'E0432': 'easy', 'E0412': 'easy',
|
|
108
|
+
'E0422': 'easy', 'E0599': 'easy', 'E0609': 'easy', 'E0616': 'easy',
|
|
109
|
+
'E0624': 'easy', 'E0603': 'easy', 'E0559': 'easy',
|
|
110
|
+
'E0308': 'medium', 'E0277': 'medium', 'E0061': 'medium', 'E0063': 'medium',
|
|
111
|
+
'E0560': 'medium', 'E0369': 'medium', 'E0507': 'medium', 'E0515': 'medium',
|
|
112
|
+
'E0596': 'medium', 'E0597': 'medium', 'E0283': 'medium', 'E0282': 'medium',
|
|
113
|
+
'E0382': 'hard', 'E0499': 'hard', 'E0502': 'hard', 'E0505': 'hard',
|
|
114
|
+
};
|
|
115
|
+
|
|
116
|
+
// ============== REGRESSION SEED CORPUS ==============
|
|
117
|
+
|
|
118
|
+
/**
|
|
119
|
+
* Known-bad patterns that should ALWAYS be rejected.
|
|
120
|
+
* These are learned from previous verification agent failures.
|
|
121
|
+
*/
|
|
122
|
+
const REGRESSION_SEEDS = [
|
|
123
|
+
{
|
|
124
|
+
pattern: /use\s+crate::\w*errors::/,
|
|
125
|
+
antiPattern: /use\s+crate::\w*error::/,
|
|
126
|
+
name: 'error vs errors module confusion',
|
|
127
|
+
description: 'Changed error to errors or vice versa'
|
|
128
|
+
},
|
|
129
|
+
{
|
|
130
|
+
pattern: /(\w+):\s*_,\s*\1:\s*_/,
|
|
131
|
+
name: 'duplicate field binding in match',
|
|
132
|
+
description: 'Same field bound twice in pattern'
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
pattern: /impl\s+\w+[^}]*\n\s*(enum|struct)\s+\w+/,
|
|
136
|
+
name: 'impl before type definition',
|
|
137
|
+
description: 'impl block appears to be inside enum/struct'
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
pattern: /enum\s+\w+\s*\{[^}]*impl\s+/,
|
|
141
|
+
name: 'impl inside enum',
|
|
142
|
+
description: 'impl block nested inside enum definition'
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
pattern: /as\s+usize\s*\)[^;]*\.get\s*\(/,
|
|
146
|
+
name: 'usize cast with Redis get',
|
|
147
|
+
description: 'Redis operations typically need i64, not usize'
|
|
148
|
+
},
|
|
149
|
+
{
|
|
150
|
+
pattern: /\.get\s*\([^)]*as\s+i64/,
|
|
151
|
+
name: 'i64 cast inside get call',
|
|
152
|
+
description: 'Cast should be outside the get call'
|
|
153
|
+
},
|
|
154
|
+
];
|
|
155
|
+
|
|
156
|
+
/**
|
|
157
|
+
* Gate L: Regression Seed Check
|
|
158
|
+
* Validates that the fix doesn't introduce known-bad patterns
|
|
159
|
+
*/
|
|
160
|
+
function gateRegressionSeeds(before: string, after: string): GateResult {
|
|
161
|
+
for (const seed of REGRESSION_SEEDS) {
|
|
162
|
+
const beforeHas = seed.pattern.test(before);
|
|
163
|
+
const afterHas = seed.pattern.test(after);
|
|
164
|
+
|
|
165
|
+
// Pattern introduced by fix
|
|
166
|
+
if (!beforeHas && afterHas) {
|
|
167
|
+
return {
|
|
168
|
+
passed: false,
|
|
169
|
+
reason: `Regression: ${seed.name} - ${seed.description}`,
|
|
170
|
+
riskLevel: 5
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
// Check anti-pattern (e.g., error -> errors swap)
|
|
175
|
+
if (seed.antiPattern) {
|
|
176
|
+
const beforeAnti = seed.antiPattern.test(before);
|
|
177
|
+
const afterAnti = seed.antiPattern.test(after);
|
|
178
|
+
|
|
179
|
+
if (beforeAnti && !afterAnti && afterHas) {
|
|
180
|
+
return {
|
|
181
|
+
passed: false,
|
|
182
|
+
reason: `Regression: ${seed.name} - swapped pattern`,
|
|
183
|
+
riskLevel: 5
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
return { passed: true, riskLevel: 1 };
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
// ============== LAYER 1: STRUCTURAL GATES (A-F from V1) ==============
|
|
193
|
+
|
|
194
|
+
/**
|
|
195
|
+
* Gate A: Line Count Delta Check
|
|
196
|
+
* Rejects fixes that change too many lines for the error type
|
|
197
|
+
*/
|
|
198
|
+
function gateLineCountDelta(before: string, after: string, errorCode: string): GateResult {
|
|
199
|
+
const beforeLines = before.split('\n').length;
|
|
200
|
+
const afterLines = after.split('\n').length;
|
|
201
|
+
const delta = Math.abs(afterLines - beforeLines);
|
|
202
|
+
|
|
203
|
+
const importErrors = ['E0432', 'E0433', 'E0425', 'E0412'];
|
|
204
|
+
if (importErrors.includes(errorCode) && delta > 5) {
|
|
205
|
+
return { passed: false, reason: `Too many line changes (${delta}) for import fix`, riskLevel: 3 };
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
if (delta > 20) {
|
|
209
|
+
return { passed: false, reason: `Suspicious line count change: ${delta} lines`, riskLevel: 4 };
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
return { passed: true, riskLevel: delta > 10 ? 2 : 1 };
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
/**
|
|
216
|
+
* Gate B: Function Signature Preservation
|
|
217
|
+
* Rejects fixes that change function signatures far from the error
|
|
218
|
+
*/
|
|
219
|
+
function gateFunctionSignature(before: string, after: string, errorLine: number): GateResult {
|
|
220
|
+
const fnPattern = /fn\s+(\w+)\s*(?:<[^>]*>)?\s*\([^)]*\)/g;
|
|
221
|
+
|
|
222
|
+
const beforeFns = new Map<string, { sig: string; line: number }>();
|
|
223
|
+
let match;
|
|
224
|
+
let lineNum = 1;
|
|
225
|
+
|
|
226
|
+
for (const line of before.split('\n')) {
|
|
227
|
+
fnPattern.lastIndex = 0;
|
|
228
|
+
while ((match = fnPattern.exec(line)) !== null) {
|
|
229
|
+
beforeFns.set(match[1], { sig: match[0], line: lineNum });
|
|
230
|
+
}
|
|
231
|
+
lineNum++;
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
lineNum = 1;
|
|
235
|
+
for (const line of after.split('\n')) {
|
|
236
|
+
fnPattern.lastIndex = 0;
|
|
237
|
+
while ((match = fnPattern.exec(line)) !== null) {
|
|
238
|
+
const existing = beforeFns.get(match[1]);
|
|
239
|
+
if (existing && existing.sig !== match[0]) {
|
|
240
|
+
if (Math.abs(existing.line - errorLine) > 15) {
|
|
241
|
+
return {
|
|
242
|
+
passed: false,
|
|
243
|
+
reason: `Function ${match[1]} signature changed but not near error`,
|
|
244
|
+
riskLevel: 4
|
|
245
|
+
};
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
lineNum++;
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
return { passed: true, riskLevel: 1 };
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
/**
|
|
256
|
+
* Gate C: Import Duplicate Check
|
|
257
|
+
* Rejects fixes that introduce duplicate use statements
|
|
258
|
+
*/
|
|
259
|
+
function gateImportDuplicates(content: string): GateResult {
|
|
260
|
+
const useStatements = new Map<string, number[]>();
|
|
261
|
+
const lines = content.split('\n');
|
|
262
|
+
|
|
263
|
+
lines.forEach((line, idx) => {
|
|
264
|
+
const useMatch = line.match(/^\s*use\s+(.+);/);
|
|
265
|
+
if (useMatch) {
|
|
266
|
+
const key = useMatch[1].trim();
|
|
267
|
+
if (!useStatements.has(key)) useStatements.set(key, []);
|
|
268
|
+
useStatements.get(key)!.push(idx + 1);
|
|
269
|
+
}
|
|
270
|
+
});
|
|
271
|
+
|
|
272
|
+
for (const [stmt, lineNums] of useStatements) {
|
|
273
|
+
if (lineNums.length > 1) {
|
|
274
|
+
return {
|
|
275
|
+
passed: false,
|
|
276
|
+
reason: `Duplicate import "${stmt.substring(0, 40)}..." on lines ${lineNums.join(', ')}`,
|
|
277
|
+
riskLevel: 5
|
|
278
|
+
};
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
return { passed: true, riskLevel: 1 };
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
/**
|
|
286
|
+
* Gate D: Brace Balance Check
|
|
287
|
+
* Rejects fixes with unbalanced delimiters
|
|
288
|
+
*/
|
|
289
|
+
function gateBraceBalance(content: string): GateResult {
|
|
290
|
+
let braceDepth = 0;
|
|
291
|
+
let parenDepth = 0;
|
|
292
|
+
let bracketDepth = 0;
|
|
293
|
+
const lines = content.split('\n');
|
|
294
|
+
let inString = false;
|
|
295
|
+
let inChar = false;
|
|
296
|
+
|
|
297
|
+
for (let i = 0; i < lines.length; i++) {
|
|
298
|
+
const line = lines[i];
|
|
299
|
+
for (let j = 0; j < line.length; j++) {
|
|
300
|
+
const char = line[j];
|
|
301
|
+
const prevChar = j > 0 ? line[j - 1] : '';
|
|
302
|
+
|
|
303
|
+
if (char === '"' && prevChar !== '\\') inString = !inString;
|
|
304
|
+
if (char === "'" && prevChar !== '\\' && !inString) inChar = !inChar;
|
|
305
|
+
|
|
306
|
+
if (!inString && !inChar) {
|
|
307
|
+
if (char === '{') braceDepth++;
|
|
308
|
+
if (char === '}') braceDepth--;
|
|
309
|
+
if (char === '(') parenDepth++;
|
|
310
|
+
if (char === ')') parenDepth--;
|
|
311
|
+
if (char === '[') bracketDepth++;
|
|
312
|
+
if (char === ']') bracketDepth--;
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
if (braceDepth < 0 || parenDepth < 0 || bracketDepth < 0) {
|
|
317
|
+
return { passed: false, reason: `Unbalanced delimiters at line ${i + 1}`, riskLevel: 5 };
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
|
|
321
|
+
if (braceDepth !== 0) {
|
|
322
|
+
return { passed: false, reason: `Unbalanced braces: ${braceDepth > 0 ? 'missing }' : 'extra }'}`, riskLevel: 5 };
|
|
323
|
+
}
|
|
324
|
+
if (parenDepth !== 0) {
|
|
325
|
+
return { passed: false, reason: `Unbalanced parentheses`, riskLevel: 5 };
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
return { passed: true, riskLevel: 1 };
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
/**
|
|
332
|
+
* Gate E: Semantic Diff Analysis
|
|
333
|
+
* Rejects fixes that duplicate existing code blocks
|
|
334
|
+
*/
|
|
335
|
+
function gateSemanticDiff(before: string, after: string): GateResult {
|
|
336
|
+
const beforeLines = new Set(
|
|
337
|
+
before.split('\n')
|
|
338
|
+
.map(l => l.trim())
|
|
339
|
+
.filter(l => l.length > 15 && !l.startsWith('//') && !l.startsWith('use '))
|
|
340
|
+
);
|
|
341
|
+
|
|
342
|
+
const afterLines = after.split('\n');
|
|
343
|
+
let duplicateCount = 0;
|
|
344
|
+
|
|
345
|
+
for (const line of afterLines) {
|
|
346
|
+
const trimmed = line.trim();
|
|
347
|
+
if (trimmed.length > 15 && beforeLines.has(trimmed)) {
|
|
348
|
+
const count = afterLines.filter(l => l.trim() === trimmed).length;
|
|
349
|
+
const originalCount = before.split('\n').filter(l => l.trim() === trimmed).length;
|
|
350
|
+
if (count > originalCount) {
|
|
351
|
+
duplicateCount++;
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
|
|
356
|
+
if (duplicateCount > 3) {
|
|
357
|
+
return {
|
|
358
|
+
passed: false,
|
|
359
|
+
reason: `${duplicateCount} lines appear more times than in original`,
|
|
360
|
+
riskLevel: 4
|
|
361
|
+
};
|
|
362
|
+
}
|
|
363
|
+
|
|
364
|
+
return { passed: true, riskLevel: duplicateCount > 0 ? 2 : 1 };
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
/**
|
|
368
|
+
* Gate F: Orphaned Code Detection
|
|
369
|
+
* Detects semicolons breaking method chains or orphaned pattern fields
|
|
370
|
+
*/
|
|
371
|
+
function gateOrphanedCode(content: string): GateResult {
|
|
372
|
+
const lines = content.split('\n');
|
|
373
|
+
|
|
374
|
+
for (let i = 0; i < lines.length - 1; i++) {
|
|
375
|
+
const line = lines[i].trim();
|
|
376
|
+
const nextLine = lines[i + 1]?.trim() || '';
|
|
377
|
+
|
|
378
|
+
if (line.endsWith(';') && nextLine.startsWith('.')) {
|
|
379
|
+
return { passed: false, reason: `Semicolon breaks method chain at line ${i + 1}`, riskLevel: 5 };
|
|
380
|
+
}
|
|
381
|
+
|
|
382
|
+
if (line.match(/\}\s*=>\s*[\(\{]/) && nextLine.match(/^\w+:\s*_,?$/)) {
|
|
383
|
+
return { passed: false, reason: `Orphaned field pattern at line ${i + 2}`, riskLevel: 5 };
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
return { passed: true, riskLevel: 1 };
|
|
388
|
+
}
|
|
389
|
+
|
|
390
|
+
// ============== LAYER 1: NEW SEMANTIC GATES (G-K) ==============
|
|
391
|
+
|
|
392
|
+
/**
|
|
393
|
+
* Find crate root directory from a file path
|
|
394
|
+
*/
|
|
395
|
+
function findCrateRoot(filePath: string, projectPath: string): string | null {
|
|
396
|
+
const parts = filePath.split('/');
|
|
397
|
+
for (let i = parts.length - 1; i >= 0; i--) {
|
|
398
|
+
const testPath = path.join(projectPath, ...parts.slice(0, i + 1), 'Cargo.toml');
|
|
399
|
+
if (fs.existsSync(testPath)) {
|
|
400
|
+
return path.join(projectPath, ...parts.slice(0, i + 1));
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
return null;
|
|
404
|
+
}
|
|
405
|
+
|
|
406
|
+
/**
|
|
407
|
+
* Gate G: Import Path Validator
|
|
408
|
+
* Validates that `use crate::...` paths match actual filesystem/module structure
|
|
409
|
+
*/
|
|
410
|
+
function gateImportPath(before: string, after: string, filePath: string): GateResult {
|
|
411
|
+
const beforeImports = new Set(
|
|
412
|
+
before.split('\n')
|
|
413
|
+
.filter(l => l.match(/^\s*use\s+/))
|
|
414
|
+
.map(l => l.trim())
|
|
415
|
+
);
|
|
416
|
+
|
|
417
|
+
const afterLines = after.split('\n');
|
|
418
|
+
const newImports: string[] = [];
|
|
419
|
+
|
|
420
|
+
for (const line of afterLines) {
|
|
421
|
+
const trimmed = line.trim();
|
|
422
|
+
if (trimmed.match(/^use\s+/) && !beforeImports.has(trimmed)) {
|
|
423
|
+
newImports.push(trimmed);
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
|
|
427
|
+
const crateDir = findCrateRoot(filePath, CONFIG.projectPath);
|
|
428
|
+
if (!crateDir) return { passed: true, riskLevel: 1 };
|
|
429
|
+
|
|
430
|
+
for (const imp of newImports) {
|
|
431
|
+
// Check crate imports
|
|
432
|
+
const crateMatch = imp.match(/use\s+crate::(\w+)/);
|
|
433
|
+
if (crateMatch) {
|
|
434
|
+
const moduleName = crateMatch[1];
|
|
435
|
+
|
|
436
|
+
const modFile = path.join(crateDir, 'src', `${moduleName}.rs`);
|
|
437
|
+
const modDir = path.join(crateDir, 'src', moduleName, 'mod.rs');
|
|
438
|
+
const libPath = path.join(crateDir, 'src', 'lib.rs');
|
|
439
|
+
const mainPath = path.join(crateDir, 'src', 'main.rs');
|
|
440
|
+
|
|
441
|
+
const moduleExists = fs.existsSync(modFile) || fs.existsSync(modDir);
|
|
442
|
+
|
|
443
|
+
if (!moduleExists) {
|
|
444
|
+
// Check if module is declared in lib.rs or main.rs
|
|
445
|
+
let isDeclared = false;
|
|
446
|
+
for (const entryPath of [libPath, mainPath]) {
|
|
447
|
+
if (fs.existsSync(entryPath)) {
|
|
448
|
+
try {
|
|
449
|
+
const content = fs.readFileSync(entryPath, 'utf-8');
|
|
450
|
+
if (content.includes(`mod ${moduleName}`) || content.includes(`pub mod ${moduleName}`)) {
|
|
451
|
+
isDeclared = true;
|
|
452
|
+
break;
|
|
453
|
+
}
|
|
454
|
+
} catch {}
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
|
|
458
|
+
if (!isDeclared) {
|
|
459
|
+
return {
|
|
460
|
+
passed: false,
|
|
461
|
+
reason: `Import references non-existent module: crate::${moduleName}`,
|
|
462
|
+
riskLevel: 5
|
|
463
|
+
};
|
|
464
|
+
}
|
|
465
|
+
}
|
|
466
|
+
}
|
|
467
|
+
|
|
468
|
+
// Check for error vs errors confusion
|
|
469
|
+
if (imp.includes('::error::') || imp.includes('::errors::')) {
|
|
470
|
+
const hasError = before.includes('::error::');
|
|
471
|
+
const hasErrors = before.includes('::errors::');
|
|
472
|
+
const newHasError = imp.includes('::error::');
|
|
473
|
+
const newHasErrors = imp.includes('::errors::');
|
|
474
|
+
|
|
475
|
+
if (hasError && newHasErrors && !hasErrors) {
|
|
476
|
+
return {
|
|
477
|
+
passed: false,
|
|
478
|
+
reason: `Import changed 'error' to 'errors' - likely incorrect`,
|
|
479
|
+
riskLevel: 5
|
|
480
|
+
};
|
|
481
|
+
}
|
|
482
|
+
if (hasErrors && newHasError && !hasError) {
|
|
483
|
+
return {
|
|
484
|
+
passed: false,
|
|
485
|
+
reason: `Import changed 'errors' to 'error' - likely incorrect`,
|
|
486
|
+
riskLevel: 5
|
|
487
|
+
};
|
|
488
|
+
}
|
|
489
|
+
}
|
|
490
|
+
}
|
|
491
|
+
|
|
492
|
+
return { passed: true, riskLevel: 1 };
|
|
493
|
+
}
|
|
494
|
+
|
|
495
|
+
/**
|
|
496
|
+
* Gate H: Pattern Duplicate Detector
|
|
497
|
+
* Detects duplicate field bindings in match patterns like `field: _, field: _`
|
|
498
|
+
*/
|
|
499
|
+
function gatePatternDuplicates(content: string): GateResult {
|
|
500
|
+
const lines = content.split('\n');
|
|
501
|
+
|
|
502
|
+
for (let i = 0; i < lines.length; i++) {
|
|
503
|
+
const line = lines[i];
|
|
504
|
+
|
|
505
|
+
// Look for pattern lines with field bindings
|
|
506
|
+
if (line.includes('=>') || line.match(/\{\s*\w+:\s*[_\w]/)) {
|
|
507
|
+
// Extract all field names in pattern (field: _ or field: value)
|
|
508
|
+
const fieldMatches = [...line.matchAll(/(\w+)\s*:\s*[_\w]/g)];
|
|
509
|
+
const fields: string[] = [];
|
|
510
|
+
|
|
511
|
+
for (const match of fieldMatches) {
|
|
512
|
+
const field = match[1];
|
|
513
|
+
// Skip common keywords
|
|
514
|
+
if (['ref', 'mut', 'box'].includes(field)) continue;
|
|
515
|
+
|
|
516
|
+
if (fields.includes(field)) {
|
|
517
|
+
return {
|
|
518
|
+
passed: false,
|
|
519
|
+
reason: `Duplicate field binding '${field}' in match pattern at line ${i + 1}`,
|
|
520
|
+
riskLevel: 5
|
|
521
|
+
};
|
|
522
|
+
}
|
|
523
|
+
fields.push(field);
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
|
|
528
|
+
return { passed: true, riskLevel: 1 };
|
|
529
|
+
}
|
|
530
|
+
|
|
531
|
+
/**
|
|
532
|
+
* Gate I: Impl Location Checker
|
|
533
|
+
* Ensures impl blocks are not nested inside enum/struct definitions
|
|
534
|
+
*/
|
|
535
|
+
function gateImplLocation(content: string): GateResult {
|
|
536
|
+
const lines = content.split('\n');
|
|
537
|
+
let depth = 0;
|
|
538
|
+
let inEnumOrStruct = false;
|
|
539
|
+
let enumStructName = '';
|
|
540
|
+
let enumStructStart = 0;
|
|
541
|
+
let enumStructDepth = 0;
|
|
542
|
+
|
|
543
|
+
for (let i = 0; i < lines.length; i++) {
|
|
544
|
+
const line = lines[i];
|
|
545
|
+
const trimmed = line.trim();
|
|
546
|
+
|
|
547
|
+
// Track enum/struct definitions (not impl blocks)
|
|
548
|
+
const typeMatch = trimmed.match(/^(pub\s+)?(enum|struct)\s+(\w+)/);
|
|
549
|
+
if (typeMatch && !trimmed.includes(';')) {
|
|
550
|
+
// Only track if this starts a block (has { or will have { on next line)
|
|
551
|
+
if (trimmed.includes('{') || (i < lines.length - 1 && lines[i + 1].trim().startsWith('{'))) {
|
|
552
|
+
inEnumOrStruct = true;
|
|
553
|
+
enumStructName = typeMatch[3];
|
|
554
|
+
enumStructStart = i + 1;
|
|
555
|
+
enumStructDepth = depth;
|
|
556
|
+
}
|
|
557
|
+
}
|
|
558
|
+
|
|
559
|
+
// Count braces
|
|
560
|
+
for (const char of line) {
|
|
561
|
+
if (char === '{') depth++;
|
|
562
|
+
if (char === '}') depth--;
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
// Exit enum/struct when we return to original depth
|
|
566
|
+
if (inEnumOrStruct && depth <= enumStructDepth && trimmed.includes('}')) {
|
|
567
|
+
inEnumOrStruct = false;
|
|
568
|
+
}
|
|
569
|
+
|
|
570
|
+
// Check for impl inside enum/struct
|
|
571
|
+
if (inEnumOrStruct && depth > enumStructDepth && trimmed.match(/^impl\s+/)) {
|
|
572
|
+
return {
|
|
573
|
+
passed: false,
|
|
574
|
+
reason: `impl block found inside ${enumStructName} definition (line ${enumStructStart})`,
|
|
575
|
+
riskLevel: 5
|
|
576
|
+
};
|
|
577
|
+
}
|
|
578
|
+
}
|
|
579
|
+
|
|
580
|
+
return { passed: true, riskLevel: 1 };
|
|
581
|
+
}
|
|
582
|
+
|
|
583
|
+
/**
|
|
584
|
+
* Gate J: Type Cast Validator
|
|
585
|
+
* Detects suspicious type cast changes (e.g., `as i64` <-> `as usize`)
|
|
586
|
+
*/
|
|
587
|
+
function gateTypeCast(before: string, after: string): GateResult {
|
|
588
|
+
const castPattern = /as\s+(i8|i16|i32|i64|i128|u8|u16|u32|u64|u128|usize|isize|f32|f64)/g;
|
|
589
|
+
|
|
590
|
+
const beforeCasts = [...before.matchAll(castPattern)];
|
|
591
|
+
const afterCasts = [...after.matchAll(castPattern)];
|
|
592
|
+
|
|
593
|
+
const beforeFreq: Record<string, number> = {};
|
|
594
|
+
const afterFreq: Record<string, number> = {};
|
|
595
|
+
|
|
596
|
+
for (const m of beforeCasts) beforeFreq[m[1]] = (beforeFreq[m[1]] || 0) + 1;
|
|
597
|
+
for (const m of afterCasts) afterFreq[m[1]] = (afterFreq[m[1]] || 0) + 1;
|
|
598
|
+
|
|
599
|
+
// Check for suspicious swaps
|
|
600
|
+
const suspiciousSwaps = [
|
|
601
|
+
['i64', 'usize'],
|
|
602
|
+
['usize', 'i64'],
|
|
603
|
+
['i32', 'usize'],
|
|
604
|
+
['usize', 'i32'],
|
|
605
|
+
];
|
|
606
|
+
|
|
607
|
+
for (const [from, to] of suspiciousSwaps) {
|
|
608
|
+
const beforeFrom = beforeFreq[from] || 0;
|
|
609
|
+
const afterFrom = afterFreq[from] || 0;
|
|
610
|
+
const beforeTo = beforeFreq[to] || 0;
|
|
611
|
+
const afterTo = afterFreq[to] || 0;
|
|
612
|
+
|
|
613
|
+
// Cast type decreased while other increased
|
|
614
|
+
if (beforeFrom > afterFrom && afterTo > beforeTo) {
|
|
615
|
+
return {
|
|
616
|
+
passed: false,
|
|
617
|
+
reason: `Suspicious cast change: 'as ${from}' -> 'as ${to}'`,
|
|
618
|
+
riskLevel: 4
|
|
619
|
+
};
|
|
620
|
+
}
|
|
621
|
+
}
|
|
622
|
+
|
|
623
|
+
return { passed: true, riskLevel: 1 };
|
|
624
|
+
}
|
|
625
|
+
|
|
626
|
+
/**
|
|
627
|
+
* Gate K: Match Arm Validator
|
|
628
|
+
* Validates match block structure wasn't significantly altered
|
|
629
|
+
*/
|
|
630
|
+
function gateMatchArm(before: string, after: string): GateResult {
|
|
631
|
+
// Count match blocks
|
|
632
|
+
const matchCount = (s: string) => (s.match(/\bmatch\s+\w+/g) || []).length;
|
|
633
|
+
const beforeCount = matchCount(before);
|
|
634
|
+
const afterCount = matchCount(after);
|
|
635
|
+
|
|
636
|
+
if (Math.abs(beforeCount - afterCount) > 2) {
|
|
637
|
+
return {
|
|
638
|
+
passed: false,
|
|
639
|
+
reason: `Match block count changed significantly: ${beforeCount} -> ${afterCount}`,
|
|
640
|
+
riskLevel: 3
|
|
641
|
+
};
|
|
642
|
+
}
|
|
643
|
+
|
|
644
|
+
// Check for orphaned match arms (=> without match)
|
|
645
|
+
const afterLines = after.split('\n');
|
|
646
|
+
for (let i = 0; i < afterLines.length; i++) {
|
|
647
|
+
const line = afterLines[i].trim();
|
|
648
|
+
if (line.match(/^\w+\s*=>\s*\{?$/) && i > 0) {
|
|
649
|
+
// Look backward for a match statement
|
|
650
|
+
let foundMatch = false;
|
|
651
|
+
for (let j = i - 1; j >= Math.max(0, i - 20); j--) {
|
|
652
|
+
if (afterLines[j].includes('match ')) {
|
|
653
|
+
foundMatch = true;
|
|
654
|
+
break;
|
|
655
|
+
}
|
|
656
|
+
if (afterLines[j].trim().startsWith('fn ') || afterLines[j].trim().startsWith('impl ')) {
|
|
657
|
+
break;
|
|
658
|
+
}
|
|
659
|
+
}
|
|
660
|
+
if (!foundMatch) {
|
|
661
|
+
return {
|
|
662
|
+
passed: false,
|
|
663
|
+
reason: `Orphaned match arm at line ${i + 1}`,
|
|
664
|
+
riskLevel: 4
|
|
665
|
+
};
|
|
666
|
+
}
|
|
667
|
+
}
|
|
668
|
+
}
|
|
669
|
+
|
|
670
|
+
return { passed: true, riskLevel: 1 };
|
|
671
|
+
}
|
|
672
|
+
|
|
673
|
+
// ============== RUN ALL LAYER 1 GATES ==============
|
|
674
|
+
|
|
675
|
+
interface GateDefinition {
|
|
676
|
+
name: string;
|
|
677
|
+
check: () => GateResult;
|
|
678
|
+
}
|
|
679
|
+
|
|
680
|
+
function runLayer1Gates(
|
|
681
|
+
before: string,
|
|
682
|
+
after: string,
|
|
683
|
+
errorCode: string,
|
|
684
|
+
errorLine: number,
|
|
685
|
+
filePath: string
|
|
686
|
+
): GateResult {
|
|
687
|
+
const gates: GateDefinition[] = [
|
|
688
|
+
// Original gates A-F
|
|
689
|
+
{ name: 'LineCount', check: () => gateLineCountDelta(before, after, errorCode) },
|
|
690
|
+
{ name: 'FnSignature', check: () => gateFunctionSignature(before, after, errorLine) },
|
|
691
|
+
{ name: 'ImportDup', check: () => gateImportDuplicates(after) },
|
|
692
|
+
{ name: 'BraceBalance', check: () => gateBraceBalance(after) },
|
|
693
|
+
{ name: 'SemanticDiff', check: () => gateSemanticDiff(before, after) },
|
|
694
|
+
{ name: 'OrphanedCode', check: () => gateOrphanedCode(after) },
|
|
695
|
+
// New gates G-L
|
|
696
|
+
{ name: 'ImportPath', check: () => gateImportPath(before, after, filePath) },
|
|
697
|
+
{ name: 'PatternDup', check: () => gatePatternDuplicates(after) },
|
|
698
|
+
{ name: 'ImplLocation', check: () => gateImplLocation(after) },
|
|
699
|
+
{ name: 'TypeCast', check: () => gateTypeCast(before, after) },
|
|
700
|
+
{ name: 'MatchArm', check: () => gateMatchArm(before, after) },
|
|
701
|
+
{ name: 'Regression', check: () => gateRegressionSeeds(before, after) },
|
|
702
|
+
];
|
|
703
|
+
|
|
704
|
+
let maxRisk: 1 | 2 | 3 | 4 | 5 = 1;
|
|
705
|
+
|
|
706
|
+
for (const gate of gates) {
|
|
707
|
+
const result = gate.check();
|
|
708
|
+
if (!result.passed) {
|
|
709
|
+
if (CONFIG.verbose) {
|
|
710
|
+
console.log(` [L1] ${gate.name}: ${result.reason}`);
|
|
711
|
+
}
|
|
712
|
+
gateStats.byGate[gate.name] = (gateStats.byGate[gate.name] || 0) + 1;
|
|
713
|
+
return { ...result, reason: `[${gate.name}] ${result.reason}` };
|
|
714
|
+
}
|
|
715
|
+
maxRisk = Math.max(maxRisk, result.riskLevel) as 1 | 2 | 3 | 4 | 5;
|
|
716
|
+
}
|
|
717
|
+
|
|
718
|
+
return { passed: true, riskLevel: maxRisk };
|
|
719
|
+
}
|
|
720
|
+
|
|
721
|
+
// ============== LAYER 2: COMPILATION VALIDATION ==============
|
|
722
|
+
|
|
723
|
+
function getPackageName(filePath: string): string {
|
|
724
|
+
const parts = filePath.split('/');
|
|
725
|
+
for (let i = parts.length - 1; i >= 0; i--) {
|
|
726
|
+
const cargoPath = path.join(CONFIG.projectPath, ...parts.slice(0, i + 1), 'Cargo.toml');
|
|
727
|
+
if (fs.existsSync(cargoPath)) {
|
|
728
|
+
try {
|
|
729
|
+
const content = fs.readFileSync(cargoPath, 'utf-8');
|
|
730
|
+
const match = content.match(/name\s*=\s*"([^"]+)"/);
|
|
731
|
+
if (match) return match[1];
|
|
732
|
+
} catch {}
|
|
733
|
+
}
|
|
734
|
+
}
|
|
735
|
+
return '';
|
|
736
|
+
}
|
|
737
|
+
|
|
738
|
+
function runTargetedCargoCheck(affectedFiles: string[]): { errors: Map<string, RustError[]>; totalCount: number } {
|
|
739
|
+
const packages = new Set<string>();
|
|
740
|
+
for (const file of affectedFiles) {
|
|
741
|
+
const pkg = getPackageName(file);
|
|
742
|
+
if (pkg) packages.add(pkg);
|
|
743
|
+
}
|
|
744
|
+
|
|
745
|
+
if (packages.size === 0) return runCargoCheck();
|
|
746
|
+
|
|
747
|
+
const pkgArgs = [...packages].map(p => `-p ${p}`).join(' ');
|
|
748
|
+
try {
|
|
749
|
+
execSync(`SQLX_OFFLINE=true cargo check ${pkgArgs} 2>&1`, {
|
|
750
|
+
cwd: CONFIG.projectPath,
|
|
751
|
+
encoding: 'utf-8',
|
|
752
|
+
maxBuffer: 50 * 1024 * 1024,
|
|
753
|
+
});
|
|
754
|
+
return { errors: new Map(), totalCount: 0 };
|
|
755
|
+
} catch (error: any) {
|
|
756
|
+
const errors = parseCargoErrors(error.stdout || error.stderr || '');
|
|
757
|
+
let totalCount = 0;
|
|
758
|
+
for (const e of errors.values()) totalCount += e.length;
|
|
759
|
+
return { errors, totalCount };
|
|
760
|
+
}
|
|
761
|
+
}
|
|
762
|
+
|
|
763
|
+
function runClippyCheck(filePath: string): { warnings: number; critical: string[] } {
|
|
764
|
+
if (!CONFIG.enableClippy) return { warnings: 0, critical: [] };
|
|
765
|
+
|
|
766
|
+
const pkg = getPackageName(filePath);
|
|
767
|
+
if (!pkg) return { warnings: 0, critical: [] };
|
|
768
|
+
|
|
769
|
+
try {
|
|
770
|
+
execSync(
|
|
771
|
+
`SQLX_OFFLINE=true cargo clippy -p ${pkg} -- -W clippy::match_same_arms -W clippy::if_same_then_else 2>&1`,
|
|
772
|
+
{ cwd: CONFIG.projectPath, encoding: 'utf-8', maxBuffer: 50 * 1024 * 1024 }
|
|
773
|
+
);
|
|
774
|
+
return { warnings: 0, critical: [] };
|
|
775
|
+
} catch (error: any) {
|
|
776
|
+
const output = error.stdout || error.stderr || '';
|
|
777
|
+
const warnings = (output.match(/warning:/g) || []).length;
|
|
778
|
+
|
|
779
|
+
const criticalPatterns = [
|
|
780
|
+
{ pattern: /match_same_arms/, name: 'match_same_arms' },
|
|
781
|
+
{ pattern: /if_same_then_else/, name: 'if_same_then_else' },
|
|
782
|
+
{ pattern: /redundant_clone/, name: 'redundant_clone' },
|
|
783
|
+
{ pattern: /duplicate_mod/, name: 'duplicate_mod' },
|
|
784
|
+
];
|
|
785
|
+
|
|
786
|
+
const critical: string[] = [];
|
|
787
|
+
for (const { pattern, name } of criticalPatterns) {
|
|
788
|
+
if (pattern.test(output)) {
|
|
789
|
+
critical.push(name);
|
|
790
|
+
}
|
|
791
|
+
}
|
|
792
|
+
|
|
793
|
+
return { warnings, critical };
|
|
794
|
+
}
|
|
795
|
+
}
|
|
796
|
+
|
|
797
|
+
// ============== LAYER 3: ENHANCED LLM REVIEW ==============
|
|
798
|
+
|
|
799
|
+
async function llmReviewGate(
|
|
800
|
+
client: any,
|
|
801
|
+
originalCode: string,
|
|
802
|
+
fixedCode: string,
|
|
803
|
+
errorMessage: string,
|
|
804
|
+
filePath: string
|
|
805
|
+
): Promise<ReviewResult> {
|
|
806
|
+
const beforeContext = originalCode.split('\n').slice(0, 150).join('\n');
|
|
807
|
+
const afterContext = fixedCode.split('\n').slice(0, 150).join('\n');
|
|
808
|
+
|
|
809
|
+
const reviewPrompt = `ROLE: Strict Code Review Gate with Checklist
|
|
810
|
+
|
|
811
|
+
CHECKLIST - REJECT if ANY violation:
|
|
812
|
+
1. Import paths match filesystem (no 'error' vs 'errors' confusion)
|
|
813
|
+
2. No duplicate field bindings in match patterns
|
|
814
|
+
3. Type casts unchanged unless error explicitly requires it
|
|
815
|
+
4. No impl blocks inside enum/struct definitions
|
|
816
|
+
5. All added imports reference modules that exist
|
|
817
|
+
6. Match block count unchanged
|
|
818
|
+
7. No semantic behavior changes beyond the error fix
|
|
819
|
+
|
|
820
|
+
ERROR: ${errorMessage}
|
|
821
|
+
FILE: ${filePath}
|
|
822
|
+
|
|
823
|
+
BEFORE:
|
|
824
|
+
\`\`\`rust
|
|
825
|
+
${beforeContext}
|
|
826
|
+
\`\`\`
|
|
827
|
+
|
|
828
|
+
AFTER:
|
|
829
|
+
\`\`\`rust
|
|
830
|
+
${afterContext}
|
|
831
|
+
\`\`\`
|
|
832
|
+
|
|
833
|
+
Instructions:
|
|
834
|
+
- Review the diff against each checklist item
|
|
835
|
+
- If ANY violation found, output REJECT with the LINE NUMBER
|
|
836
|
+
- Only APPROVE if all 7 checklist items pass
|
|
837
|
+
|
|
838
|
+
Output ONLY valid JSON:
|
|
839
|
+
{"verdict":"APPROVE"|"REJECT","reason":"<cite line numbers if rejecting>","riskLevel":1-5}`;
|
|
840
|
+
|
|
841
|
+
try {
|
|
842
|
+
const response = await client.chat.completions.create({
|
|
843
|
+
model: CONFIG.model,
|
|
844
|
+
messages: [{ role: 'user', content: reviewPrompt }],
|
|
845
|
+
max_completion_tokens: 200,
|
|
846
|
+
temperature: 0.0,
|
|
847
|
+
});
|
|
848
|
+
|
|
849
|
+
const content = (response as any).choices?.[0]?.message?.content || '';
|
|
850
|
+
const jsonMatch = content.match(/\{[\s\S]*\}/);
|
|
851
|
+
|
|
852
|
+
if (jsonMatch) {
|
|
853
|
+
try {
|
|
854
|
+
const parsed = JSON.parse(jsonMatch[0]);
|
|
855
|
+
return {
|
|
856
|
+
verdict: parsed.verdict === 'APPROVE' ? 'APPROVE' : 'REJECT',
|
|
857
|
+
reason: String(parsed.reason || 'Unknown').substring(0, 100),
|
|
858
|
+
riskLevel: Math.min(5, Math.max(1, Number(parsed.riskLevel) || 3)) as 1 | 2 | 3 | 4 | 5,
|
|
859
|
+
};
|
|
860
|
+
} catch {}
|
|
861
|
+
}
|
|
862
|
+
|
|
863
|
+
// Default to REJECT if can't parse (fail-safe)
|
|
864
|
+
return { verdict: 'REJECT', reason: 'Could not parse review response', riskLevel: 4 };
|
|
865
|
+
} catch (error: any) {
|
|
866
|
+
console.log(` [L3] Review API error`);
|
|
867
|
+
return { verdict: 'REJECT', reason: 'API error', riskLevel: 3 };
|
|
868
|
+
}
|
|
869
|
+
}
|
|
870
|
+
|
|
871
|
+
// ============== CORE FUNCTIONS ==============
|
|
872
|
+
|
|
873
|
+
function loadCerebrasKey(): string {
|
|
874
|
+
const envPaths = ['/mnt/c/Users/masha/Documents/ourstories-v2/.env'];
|
|
875
|
+
for (const envPath of envPaths) {
|
|
876
|
+
try {
|
|
877
|
+
const content = fs.readFileSync(envPath, 'utf-8');
|
|
878
|
+
const match = content.match(/CEREBRAS_API_KEY=([^\r\n]+)/);
|
|
879
|
+
if (match) return match[1].trim();
|
|
880
|
+
} catch {}
|
|
881
|
+
}
|
|
882
|
+
return process.env.CEREBRAS_API_KEY || '';
|
|
883
|
+
}
|
|
884
|
+
|
|
885
|
+
function parseCargoErrors(output: string): Map<string, RustError[]> {
|
|
886
|
+
const errorsByFile = new Map<string, RustError[]>();
|
|
887
|
+
const lines = output.split('\n');
|
|
888
|
+
|
|
889
|
+
for (let i = 0; i < lines.length; i++) {
|
|
890
|
+
const fileMatch = lines[i].match(/^\s*-->\s+(.+):(\d+):(\d+)/);
|
|
891
|
+
if (!fileMatch) continue;
|
|
892
|
+
|
|
893
|
+
const [, filePath, lineNum, colNum] = fileMatch;
|
|
894
|
+
let code = '', message = '', suggestion = '';
|
|
895
|
+
|
|
896
|
+
for (let j = i - 1; j >= Math.max(0, i - 15); j--) {
|
|
897
|
+
const errorMatch = lines[j].match(/error\[(E\d{4})\]:\s*(.+)/);
|
|
898
|
+
if (errorMatch) {
|
|
899
|
+
code = errorMatch[1];
|
|
900
|
+
message = errorMatch[2];
|
|
901
|
+
break;
|
|
902
|
+
}
|
|
903
|
+
}
|
|
904
|
+
|
|
905
|
+
for (let j = i + 1; j < Math.min(lines.length, i + 20); j++) {
|
|
906
|
+
if (lines[j].includes('help:')) {
|
|
907
|
+
suggestion = lines[j].replace(/.*help:\s*/, '').trim();
|
|
908
|
+
break;
|
|
909
|
+
}
|
|
910
|
+
if (lines[j].match(/^error\[/)) break;
|
|
911
|
+
}
|
|
912
|
+
|
|
913
|
+
if (code && message) {
|
|
914
|
+
if (!errorsByFile.has(filePath)) errorsByFile.set(filePath, []);
|
|
915
|
+
errorsByFile.get(filePath)!.push({
|
|
916
|
+
code,
|
|
917
|
+
line: parseInt(lineNum, 10),
|
|
918
|
+
column: parseInt(colNum, 10),
|
|
919
|
+
message,
|
|
920
|
+
suggestion,
|
|
921
|
+
difficulty: ERROR_CLASSIFICATION[code] || 'medium',
|
|
922
|
+
});
|
|
923
|
+
}
|
|
924
|
+
}
|
|
925
|
+
return errorsByFile;
|
|
926
|
+
}
|
|
927
|
+
|
|
928
|
+
function runCargoCheck(): { errors: Map<string, RustError[]>; totalCount: number } {
|
|
929
|
+
try {
|
|
930
|
+
execSync(`SQLX_OFFLINE=true cargo check 2>&1`, {
|
|
931
|
+
cwd: CONFIG.projectPath,
|
|
932
|
+
encoding: 'utf-8',
|
|
933
|
+
maxBuffer: 50 * 1024 * 1024,
|
|
934
|
+
});
|
|
935
|
+
return { errors: new Map(), totalCount: 0 };
|
|
936
|
+
} catch (error: any) {
|
|
937
|
+
const errors = parseCargoErrors(error.stdout || error.stderr || '');
|
|
938
|
+
let totalCount = 0;
|
|
939
|
+
for (const e of errors.values()) totalCount += e.length;
|
|
940
|
+
return { errors, totalCount };
|
|
941
|
+
}
|
|
942
|
+
}
|
|
943
|
+
|
|
944
|
+
function applyLineFixes(content: string, fixes: LineFix[]): string {
|
|
945
|
+
const lines = content.split('\n');
|
|
946
|
+
const sortedFixes = [...fixes].sort((a, b) => {
|
|
947
|
+
if (b.line !== a.line) return b.line - a.line;
|
|
948
|
+
const priority = { insert_before: 0, insert_after: 1, replace: 2, delete: 3 };
|
|
949
|
+
return priority[a.action] - priority[b.action];
|
|
950
|
+
});
|
|
951
|
+
|
|
952
|
+
const seenLines = new Set<string>();
|
|
953
|
+
const dedupedFixes = sortedFixes.filter(f => {
|
|
954
|
+
const key = `${f.line}-${f.action}`;
|
|
955
|
+
if (seenLines.has(key)) return false;
|
|
956
|
+
seenLines.add(key);
|
|
957
|
+
return true;
|
|
958
|
+
});
|
|
959
|
+
|
|
960
|
+
for (const fix of dedupedFixes) {
|
|
961
|
+
const idx = fix.line - 1;
|
|
962
|
+
if (idx < 0 || idx >= lines.length + 10) continue;
|
|
963
|
+
|
|
964
|
+
switch (fix.action) {
|
|
965
|
+
case 'replace': if (idx < lines.length) lines[idx] = fix.content; break;
|
|
966
|
+
case 'insert_after': lines.splice(idx + 1, 0, fix.content); break;
|
|
967
|
+
case 'insert_before': lines.splice(idx, 0, fix.content); break;
|
|
968
|
+
case 'delete': if (idx < lines.length) lines.splice(idx, 1); break;
|
|
969
|
+
}
|
|
970
|
+
}
|
|
971
|
+
return lines.join('\n');
|
|
972
|
+
}
|
|
973
|
+
|
|
974
|
+
function getCrateContext(filePath: string): string {
|
|
975
|
+
const crateDir = findCrateRoot(filePath, CONFIG.projectPath);
|
|
976
|
+
if (!crateDir) return '';
|
|
977
|
+
|
|
978
|
+
let context = '';
|
|
979
|
+
|
|
980
|
+
const libPath = path.join(crateDir, 'src', 'lib.rs');
|
|
981
|
+
const mainPath = path.join(crateDir, 'src', 'main.rs');
|
|
982
|
+
const entryPath = fs.existsSync(libPath) ? libPath : (fs.existsSync(mainPath) ? mainPath : '');
|
|
983
|
+
|
|
984
|
+
if (entryPath) {
|
|
985
|
+
try {
|
|
986
|
+
const content = fs.readFileSync(entryPath, 'utf-8');
|
|
987
|
+
const lines = content.split('\n');
|
|
988
|
+
const exports = lines.slice(0, 100).filter(l =>
|
|
989
|
+
l.match(/^pub\s+(mod|use|struct|enum|type|trait|fn)\s+/) ||
|
|
990
|
+
l.match(/^mod\s+\w+;/)
|
|
991
|
+
);
|
|
992
|
+
if (exports.length > 0) {
|
|
993
|
+
context += `\nCRATE EXPORTS:\n${exports.join('\n')}\n`;
|
|
994
|
+
}
|
|
995
|
+
} catch {}
|
|
996
|
+
}
|
|
997
|
+
|
|
998
|
+
return context;
|
|
999
|
+
}
|
|
1000
|
+
|
|
1001
|
+
function parseJsonResponse(response: string): LineFix[] | null {
|
|
1002
|
+
const patterns = [/\[\s*\{[\s\S]*?\}\s*\]/g, /```json\s*([\s\S]*?)\s*```/, /```\s*([\s\S]*?)\s*```/];
|
|
1003
|
+
for (const pattern of patterns) {
|
|
1004
|
+
const match = response.match(pattern);
|
|
1005
|
+
if (match) {
|
|
1006
|
+
try {
|
|
1007
|
+
const parsed = JSON.parse(match[1] || match[0]);
|
|
1008
|
+
if (Array.isArray(parsed)) {
|
|
1009
|
+
return parsed.filter(f =>
|
|
1010
|
+
typeof f.line === 'number' &&
|
|
1011
|
+
['replace', 'insert_after', 'insert_before', 'delete'].includes(f.action) &&
|
|
1012
|
+
typeof f.content === 'string'
|
|
1013
|
+
);
|
|
1014
|
+
}
|
|
1015
|
+
} catch {}
|
|
1016
|
+
}
|
|
1017
|
+
}
|
|
1018
|
+
return null;
|
|
1019
|
+
}
|
|
1020
|
+
|
|
1021
|
+
function buildPrompt(error: RustError, fileContent: string, filePath: string, feedback?: string, layer1Context?: Layer1RetryContext): string {
|
|
1022
|
+
const lines = fileContent.split('\n');
|
|
1023
|
+
const contextSize = 20;
|
|
1024
|
+
const start = Math.max(0, error.line - contextSize - 1);
|
|
1025
|
+
const end = Math.min(lines.length, error.line + contextSize);
|
|
1026
|
+
|
|
1027
|
+
const errorContext = lines.slice(start, end).map((line, i) => {
|
|
1028
|
+
const num = start + i + 1;
|
|
1029
|
+
const marker = num === error.line ? ' >>> ' : ' ';
|
|
1030
|
+
return `${num}:${marker}${line}`;
|
|
1031
|
+
}).join('\n');
|
|
1032
|
+
|
|
1033
|
+
const imports = lines.filter(l =>
|
|
1034
|
+
l.startsWith('use ') || l.startsWith('pub use ') ||
|
|
1035
|
+
l.startsWith('mod ') || l.startsWith('pub mod ')
|
|
1036
|
+
).slice(0, 60).join('\n');
|
|
1037
|
+
|
|
1038
|
+
const crateContext = getCrateContext(filePath);
|
|
1039
|
+
|
|
1040
|
+
// Build Layer 1 failure feedback if retrying
|
|
1041
|
+
let layer1Feedback = '';
|
|
1042
|
+
if (layer1Context && layer1Context.previousFailures.length > 0) {
|
|
1043
|
+
layer1Feedback = `
|
|
1044
|
+
PREVIOUS LAYER 1 GATE FAILURES (attempt ${layer1Context.attempt}/${CONFIG.maxLayer1Retries}):
|
|
1045
|
+
${layer1Context.previousFailures.map((f, i) => ` ${i + 1}. [${f.gate}] ${f.reason}`).join('\n')}
|
|
1046
|
+
|
|
1047
|
+
Your previous fix was REJECTED by these structural validation gates. You MUST:
|
|
1048
|
+
- Avoid the specific issues mentioned above
|
|
1049
|
+
- Generate a DIFFERENT fix that passes these gates
|
|
1050
|
+
- If Gate BraceBalance failed: ensure all {}, (), [] are balanced
|
|
1051
|
+
- If Gate ImportDup failed: do NOT add imports that already exist
|
|
1052
|
+
- If Gate FnSignature failed: do NOT change function signatures
|
|
1053
|
+
- If Gate SemanticDiff failed: do NOT duplicate existing code
|
|
1054
|
+
- If Gate ImportPath failed: verify module paths exist
|
|
1055
|
+
- If Gate PatternDup failed: no duplicate field bindings in match
|
|
1056
|
+
|
|
1057
|
+
`;
|
|
1058
|
+
}
|
|
1059
|
+
|
|
1060
|
+
// HARDENED PROMPT with explicit preservation rules
|
|
1061
|
+
const prompt = `Fix this Rust error. Return ONLY JSON array.
|
|
1062
|
+
${layer1Feedback}
|
|
1063
|
+
|
|
1064
|
+
ERROR: [${error.code}] ${error.message}
|
|
1065
|
+
${error.suggestion ? `HINT: ${error.suggestion}` : ''}
|
|
1066
|
+
FILE: ${filePath}
|
|
1067
|
+
|
|
1068
|
+
CURRENT IMPORTS:
|
|
1069
|
+
${imports}
|
|
1070
|
+
${crateContext}
|
|
1071
|
+
CODE (line ${error.line}):
|
|
1072
|
+
${errorContext}
|
|
1073
|
+
|
|
1074
|
+
CRITICAL RULES (VIOLATIONS WILL BE REJECTED):
|
|
1075
|
+
1. PRESERVE EXACT MODULE PATHS - Do not change 'error' to 'errors' or vice versa
|
|
1076
|
+
2. NO DUPLICATE IMPORTS - Never add an import that already exists
|
|
1077
|
+
3. NO DUPLICATE PATTERN BINDINGS - Never use same field twice in a match pattern
|
|
1078
|
+
4. KEEP TYPE CASTS UNCHANGED - Do not change 'as i64' to 'as usize' unless error requires it
|
|
1079
|
+
5. NO IMPL INSIDE ENUM/STRUCT - impl blocks must be outside type definitions
|
|
1080
|
+
6. IMPORTS MUST EXIST - Only add imports for modules declared in lib.rs/mod.rs
|
|
1081
|
+
7. PRESERVE FUNCTION SIGNATURES - Don't change fn signatures unless error requires it
|
|
1082
|
+
8. FAIL-SAFE - Return [] if uncertain about the fix
|
|
1083
|
+
|
|
1084
|
+
${feedback ? `PREVIOUS FIX FAILED: ${feedback}\nAdjust your fix accordingly.\n` : ''}
|
|
1085
|
+
OUTPUT: JSON array only
|
|
1086
|
+
[{"line": N, "action": "replace"|"insert_after"|"insert_before"|"delete", "content": "exact line"}]
|
|
1087
|
+
|
|
1088
|
+
Return [] if unsure or if fix requires significant changes.
|
|
1089
|
+
JSON:`;
|
|
1090
|
+
|
|
1091
|
+
return prompt;
|
|
1092
|
+
}
|
|
1093
|
+
|
|
1094
|
+
async function processInChunks<T, R>(
|
|
1095
|
+
items: T[],
|
|
1096
|
+
processor: (item: T) => Promise<R>,
|
|
1097
|
+
concurrency: number
|
|
1098
|
+
): Promise<R[]> {
|
|
1099
|
+
const results: R[] = [];
|
|
1100
|
+
for (let i = 0; i < items.length; i += concurrency) {
|
|
1101
|
+
const chunk = items.slice(i, i + concurrency);
|
|
1102
|
+
const chunkResults = await Promise.all(chunk.map(processor));
|
|
1103
|
+
results.push(...chunkResults);
|
|
1104
|
+
}
|
|
1105
|
+
return results;
|
|
1106
|
+
}
|
|
1107
|
+
|
|
1108
|
+
async function getLLMFix(
|
|
1109
|
+
client: any,
|
|
1110
|
+
error: RustError,
|
|
1111
|
+
fileContent: string,
|
|
1112
|
+
filePath: string,
|
|
1113
|
+
feedback?: string,
|
|
1114
|
+
layer1Context?: Layer1RetryContext
|
|
1115
|
+
): Promise<LLMFixResult> {
|
|
1116
|
+
const prompt = buildPrompt(error, fileContent, filePath, feedback, layer1Context);
|
|
1117
|
+
|
|
1118
|
+
try {
|
|
1119
|
+
const response = await client.chat.completions.create({
|
|
1120
|
+
model: CONFIG.model,
|
|
1121
|
+
messages: [{ role: 'user', content: prompt }],
|
|
1122
|
+
max_completion_tokens: CONFIG.maxTokens,
|
|
1123
|
+
temperature: 0.1,
|
|
1124
|
+
});
|
|
1125
|
+
|
|
1126
|
+
const content = (response as any).choices?.[0]?.message?.content || '';
|
|
1127
|
+
const fixes = parseJsonResponse(content);
|
|
1128
|
+
|
|
1129
|
+
return {
|
|
1130
|
+
error,
|
|
1131
|
+
fixes: fixes || [],
|
|
1132
|
+
success: fixes !== null && fixes.length > 0,
|
|
1133
|
+
};
|
|
1134
|
+
} catch (err: any) {
|
|
1135
|
+
return { error, fixes: [], success: false };
|
|
1136
|
+
}
|
|
1137
|
+
}
|
|
1138
|
+
|
|
1139
|
+
function generateUnifiedDiff(before: string, after: string, filePath: string): string {
|
|
1140
|
+
const beforeLines = before.split('\n');
|
|
1141
|
+
const afterLines = after.split('\n');
|
|
1142
|
+
|
|
1143
|
+
let diff = `--- a/${filePath}\n+++ b/${filePath}\n`;
|
|
1144
|
+
|
|
1145
|
+
// Simple line-by-line diff (not a true unified diff, but useful)
|
|
1146
|
+
const maxLines = Math.max(beforeLines.length, afterLines.length);
|
|
1147
|
+
let inHunk = false;
|
|
1148
|
+
let hunkStart = 0;
|
|
1149
|
+
let hunkLines: string[] = [];
|
|
1150
|
+
|
|
1151
|
+
for (let i = 0; i < maxLines; i++) {
|
|
1152
|
+
const beforeLine = beforeLines[i] || '';
|
|
1153
|
+
const afterLine = afterLines[i] || '';
|
|
1154
|
+
|
|
1155
|
+
if (beforeLine !== afterLine) {
|
|
1156
|
+
if (!inHunk) {
|
|
1157
|
+
inHunk = true;
|
|
1158
|
+
hunkStart = i + 1;
|
|
1159
|
+
hunkLines = [`@@ -${hunkStart},3 +${hunkStart},3 @@`];
|
|
1160
|
+
}
|
|
1161
|
+
if (beforeLines[i] !== undefined) hunkLines.push(`-${beforeLine}`);
|
|
1162
|
+
if (afterLines[i] !== undefined) hunkLines.push(`+${afterLine}`);
|
|
1163
|
+
} else {
|
|
1164
|
+
if (inHunk) {
|
|
1165
|
+
hunkLines.push(` ${beforeLine}`);
|
|
1166
|
+
if (hunkLines.length > 10) {
|
|
1167
|
+
diff += hunkLines.join('\n') + '\n';
|
|
1168
|
+
inHunk = false;
|
|
1169
|
+
hunkLines = [];
|
|
1170
|
+
}
|
|
1171
|
+
}
|
|
1172
|
+
}
|
|
1173
|
+
}
|
|
1174
|
+
|
|
1175
|
+
if (hunkLines.length > 0) {
|
|
1176
|
+
diff += hunkLines.join('\n') + '\n';
|
|
1177
|
+
}
|
|
1178
|
+
|
|
1179
|
+
return diff;
|
|
1180
|
+
}
|
|
1181
|
+
|
|
1182
|
+
async function processFileWithGates(
|
|
1183
|
+
client: any,
|
|
1184
|
+
filePath: string,
|
|
1185
|
+
errors: RustError[],
|
|
1186
|
+
feedback?: Map<number, string>
|
|
1187
|
+
): Promise<{ applied: number; content: string }> {
|
|
1188
|
+
const fullPath = path.join(CONFIG.projectPath, filePath);
|
|
1189
|
+
const originalContent = fs.readFileSync(fullPath, 'utf-8');
|
|
1190
|
+
|
|
1191
|
+
const fixableErrors = errors.filter(e => e.difficulty !== 'hard');
|
|
1192
|
+
if (fixableErrors.length === 0) {
|
|
1193
|
+
return { applied: 0, content: originalContent };
|
|
1194
|
+
}
|
|
1195
|
+
|
|
1196
|
+
// Layer 1 retry context for tracking failures across attempts
|
|
1197
|
+
const layer1RetryContext: Layer1RetryContext = {
|
|
1198
|
+
attempt: 0,
|
|
1199
|
+
previousFailures: []
|
|
1200
|
+
};
|
|
1201
|
+
|
|
1202
|
+
let candidateContent = '';
|
|
1203
|
+
let successCount = 0;
|
|
1204
|
+
let layer1RiskLevel: 1 | 2 | 3 | 4 | 5 = 1;
|
|
1205
|
+
|
|
1206
|
+
// ===== LAYER 1 RETRY LOOP =====
|
|
1207
|
+
while (layer1RetryContext.attempt < CONFIG.maxLayer1Retries) {
|
|
1208
|
+
layer1RetryContext.attempt++;
|
|
1209
|
+
|
|
1210
|
+
// Get LLM fixes (with retry context if not first attempt)
|
|
1211
|
+
const llmResults = await processInChunks(
|
|
1212
|
+
fixableErrors,
|
|
1213
|
+
(error) => getLLMFix(
|
|
1214
|
+
client,
|
|
1215
|
+
error,
|
|
1216
|
+
originalContent,
|
|
1217
|
+
filePath,
|
|
1218
|
+
feedback?.get(error.line),
|
|
1219
|
+
layer1RetryContext.attempt > 1 ? layer1RetryContext : undefined
|
|
1220
|
+
),
|
|
1221
|
+
CONFIG.parallelLLMCalls
|
|
1222
|
+
);
|
|
1223
|
+
|
|
1224
|
+
const allFixes: LineFix[] = [];
|
|
1225
|
+
successCount = 0;
|
|
1226
|
+
for (const result of llmResults) {
|
|
1227
|
+
if (result.success && result.fixes.length > 0) {
|
|
1228
|
+
allFixes.push(...result.fixes);
|
|
1229
|
+
successCount++;
|
|
1230
|
+
}
|
|
1231
|
+
}
|
|
1232
|
+
|
|
1233
|
+
if (allFixes.length === 0) {
|
|
1234
|
+
if (layer1RetryContext.attempt === 1) {
|
|
1235
|
+
return { applied: 0, content: originalContent };
|
|
1236
|
+
}
|
|
1237
|
+
// No fixes on retry, give up
|
|
1238
|
+
console.log(` No fixes generated on retry ${layer1RetryContext.attempt}`);
|
|
1239
|
+
return { applied: 0, content: originalContent };
|
|
1240
|
+
}
|
|
1241
|
+
|
|
1242
|
+
candidateContent = applyLineFixes(originalContent, allFixes);
|
|
1243
|
+
|
|
1244
|
+
// ===== LAYER 1: Pre-application structural gates =====
|
|
1245
|
+
const attemptLabel = layer1RetryContext.attempt > 1
|
|
1246
|
+
? ` (retry ${layer1RetryContext.attempt}/${CONFIG.maxLayer1Retries})`
|
|
1247
|
+
: '';
|
|
1248
|
+
console.log(` [L1] Running 12 structural gates...${attemptLabel}`);
|
|
1249
|
+
|
|
1250
|
+
const layer1Result = runLayer1Gates(
|
|
1251
|
+
originalContent,
|
|
1252
|
+
candidateContent,
|
|
1253
|
+
errors[0].code,
|
|
1254
|
+
errors[0].line,
|
|
1255
|
+
filePath
|
|
1256
|
+
);
|
|
1257
|
+
|
|
1258
|
+
if (layer1Result.passed) {
|
|
1259
|
+
console.log(` OK (risk: ${layer1Result.riskLevel}/5)`);
|
|
1260
|
+
layer1RiskLevel = layer1Result.riskLevel;
|
|
1261
|
+
break; // Exit retry loop on success
|
|
1262
|
+
}
|
|
1263
|
+
|
|
1264
|
+
// Gate failed - record failure and potentially retry
|
|
1265
|
+
const failedGate = layer1Result.reason?.match(/\[(\w+)\]/)?.[1] || 'Unknown';
|
|
1266
|
+
layer1RetryContext.previousFailures.push({
|
|
1267
|
+
gate: failedGate,
|
|
1268
|
+
reason: layer1Result.reason || 'Unknown'
|
|
1269
|
+
});
|
|
1270
|
+
|
|
1271
|
+
gateStats.byGate[failedGate] = (gateStats.byGate[failedGate] || 0) + 1;
|
|
1272
|
+
|
|
1273
|
+
if (layer1RetryContext.attempt >= CONFIG.maxLayer1Retries) {
|
|
1274
|
+
// Final attempt failed, reject
|
|
1275
|
+
gateStats.layer1Rejections++;
|
|
1276
|
+
rejectionLog.push({
|
|
1277
|
+
timestamp: new Date().toISOString(),
|
|
1278
|
+
file: filePath,
|
|
1279
|
+
gate: 'Layer1',
|
|
1280
|
+
reason: `Failed after ${layer1RetryContext.attempt} attempts: ${layer1Result.reason}`,
|
|
1281
|
+
errorCode: errors[0].code
|
|
1282
|
+
});
|
|
1283
|
+
console.log(` REJECTED after ${layer1RetryContext.attempt} retries: ${layer1Result.reason}`);
|
|
1284
|
+
return { applied: 0, content: originalContent };
|
|
1285
|
+
}
|
|
1286
|
+
|
|
1287
|
+
// Log retry
|
|
1288
|
+
gateStats.layer1Retries++;
|
|
1289
|
+
console.log(` Gate failed [${failedGate}]: ${layer1Result.reason}`);
|
|
1290
|
+
console.log(` Retrying with feedback (attempt ${layer1RetryContext.attempt + 1}/${CONFIG.maxLayer1Retries})...`);
|
|
1291
|
+
}
|
|
1292
|
+
|
|
1293
|
+
// ===== LAYER 3: LLM Review Gate (for high-risk fixes) =====
|
|
1294
|
+
if (CONFIG.enableLayer3 && layer1RiskLevel >= 2) {
|
|
1295
|
+
console.log(` [L3] LLM review with checklist...`);
|
|
1296
|
+
const reviewResult = await llmReviewGate(
|
|
1297
|
+
client,
|
|
1298
|
+
originalContent,
|
|
1299
|
+
candidateContent,
|
|
1300
|
+
errors.map(e => `[${e.code}] ${e.message}`).join('; '),
|
|
1301
|
+
filePath
|
|
1302
|
+
);
|
|
1303
|
+
|
|
1304
|
+
if (reviewResult.verdict === 'REJECT') {
|
|
1305
|
+
console.log(` REJECTED: ${reviewResult.reason}`);
|
|
1306
|
+
gateStats.layer3Rejections++;
|
|
1307
|
+
rejectionLog.push({
|
|
1308
|
+
timestamp: new Date().toISOString(),
|
|
1309
|
+
file: filePath,
|
|
1310
|
+
gate: 'Layer3-LLMReview',
|
|
1311
|
+
reason: reviewResult.reason,
|
|
1312
|
+
errorCode: errors[0].code
|
|
1313
|
+
});
|
|
1314
|
+
return { applied: 0, content: originalContent };
|
|
1315
|
+
}
|
|
1316
|
+
console.log(` APPROVED (risk: ${reviewResult.riskLevel}/5)`);
|
|
1317
|
+
}
|
|
1318
|
+
|
|
1319
|
+
// ===== DRY-RUN MODE =====
|
|
1320
|
+
if (CONFIG.dryRun) {
|
|
1321
|
+
const patchContent = generateUnifiedDiff(originalContent, candidateContent, filePath);
|
|
1322
|
+
const patchFile = path.join(CONFIG.patchDir, `${path.basename(filePath)}.patch`);
|
|
1323
|
+
fs.mkdirSync(CONFIG.patchDir, { recursive: true });
|
|
1324
|
+
fs.writeFileSync(patchFile, patchContent);
|
|
1325
|
+
console.log(` [DRY-RUN] Patch written to ${patchFile}`);
|
|
1326
|
+
return { applied: 0, content: originalContent };
|
|
1327
|
+
}
|
|
1328
|
+
|
|
1329
|
+
gateStats.approvals++;
|
|
1330
|
+
return { applied: successCount, content: candidateContent };
|
|
1331
|
+
}
|
|
1332
|
+
|
|
1333
|
+
async function main() {
|
|
1334
|
+
console.log('=== Gated Rust Error Fixer V2 ===');
|
|
1335
|
+
console.log('Enhanced Gate Architecture with 12 Layer-1 Gates + Retry-with-Feedback');
|
|
1336
|
+
console.log();
|
|
1337
|
+
console.log('Gates:');
|
|
1338
|
+
console.log(' A: LineCount B: FnSignature C: ImportDup D: BraceBalance');
|
|
1339
|
+
console.log(' E: SemanticDiff F: OrphanedCode G: ImportPath H: PatternDup');
|
|
1340
|
+
console.log(' I: ImplLocation J: TypeCast K: MatchArm L: Regression');
|
|
1341
|
+
console.log();
|
|
1342
|
+
console.log(`Layer 3 LLM Review: ${CONFIG.enableLayer3 ? 'ON' : 'OFF'}`);
|
|
1343
|
+
console.log(`Clippy: ${CONFIG.enableClippy ? 'ON' : 'OFF'}`);
|
|
1344
|
+
console.log(`Dry-Run: ${CONFIG.dryRun ? 'ON' : 'OFF'}`);
|
|
1345
|
+
console.log();
|
|
1346
|
+
|
|
1347
|
+
const apiKey = loadCerebrasKey();
|
|
1348
|
+
if (!apiKey) {
|
|
1349
|
+
console.error('No CEREBRAS_API_KEY found');
|
|
1350
|
+
process.exit(1);
|
|
1351
|
+
}
|
|
1352
|
+
const client = createCerebrasClient(apiKey);
|
|
1353
|
+
|
|
1354
|
+
let iteration = 0;
|
|
1355
|
+
let previousErrorCount = Infinity;
|
|
1356
|
+
const allAffectedFiles: string[] = [];
|
|
1357
|
+
|
|
1358
|
+
while (iteration < CONFIG.maxGlobalIterations) {
|
|
1359
|
+
iteration++;
|
|
1360
|
+
console.log(`\n========== ITERATION ${iteration} ==========`);
|
|
1361
|
+
|
|
1362
|
+
console.log('Running cargo check...');
|
|
1363
|
+
const { errors: allErrors, totalCount } = runCargoCheck();
|
|
1364
|
+
|
|
1365
|
+
console.log(`Found ${totalCount} errors in ${allErrors.size} files`);
|
|
1366
|
+
|
|
1367
|
+
if (totalCount === 0) {
|
|
1368
|
+
console.log('\n*** All errors fixed! ***');
|
|
1369
|
+
break;
|
|
1370
|
+
}
|
|
1371
|
+
|
|
1372
|
+
if (totalCount >= previousErrorCount) {
|
|
1373
|
+
console.log(`\nNo progress (${totalCount} >= ${previousErrorCount}). Stopping.`);
|
|
1374
|
+
break;
|
|
1375
|
+
}
|
|
1376
|
+
|
|
1377
|
+
previousErrorCount = totalCount;
|
|
1378
|
+
|
|
1379
|
+
const originalContents = new Map<string, string>();
|
|
1380
|
+
const fileFeedback = new Map<string, Map<number, string>>();
|
|
1381
|
+
|
|
1382
|
+
let totalApplied = 0;
|
|
1383
|
+
const files = [...allErrors.entries()];
|
|
1384
|
+
|
|
1385
|
+
for (const [filePath, errors] of files) {
|
|
1386
|
+
const fullPath = path.join(CONFIG.projectPath, filePath);
|
|
1387
|
+
try {
|
|
1388
|
+
originalContents.set(filePath, fs.readFileSync(fullPath, 'utf-8'));
|
|
1389
|
+
} catch { continue; }
|
|
1390
|
+
|
|
1391
|
+
const feedback = fileFeedback.get(filePath);
|
|
1392
|
+
console.log(`\n ${filePath}: ${errors.length} errors`);
|
|
1393
|
+
|
|
1394
|
+
const result = await processFileWithGates(client, filePath, errors, feedback);
|
|
1395
|
+
|
|
1396
|
+
if (result.applied > 0) {
|
|
1397
|
+
fs.writeFileSync(fullPath, result.content);
|
|
1398
|
+
console.log(` Applied ${result.applied} fixes`);
|
|
1399
|
+
totalApplied += result.applied;
|
|
1400
|
+
allAffectedFiles.push(filePath);
|
|
1401
|
+
} else {
|
|
1402
|
+
console.log(` No fixes passed gates`);
|
|
1403
|
+
}
|
|
1404
|
+
}
|
|
1405
|
+
|
|
1406
|
+
if (totalApplied === 0) {
|
|
1407
|
+
console.log('\nNo fixes applied this iteration. Stopping.');
|
|
1408
|
+
break;
|
|
1409
|
+
}
|
|
1410
|
+
|
|
1411
|
+
// ===== LAYER 2: Targeted compilation validation =====
|
|
1412
|
+
console.log('\n[L2] Validating changes (targeted crates)...');
|
|
1413
|
+
const { totalCount: newCount, errors: newErrors } = runTargetedCargoCheck(allAffectedFiles);
|
|
1414
|
+
|
|
1415
|
+
if (newCount > totalCount) {
|
|
1416
|
+
console.log(`\n[L2] FAILED: More errors (${newCount} > ${totalCount})`);
|
|
1417
|
+
gateStats.layer2Rejections++;
|
|
1418
|
+
|
|
1419
|
+
for (const [filePath, original] of originalContents) {
|
|
1420
|
+
const fullPath = path.join(CONFIG.projectPath, filePath);
|
|
1421
|
+
fs.writeFileSync(fullPath, original);
|
|
1422
|
+
}
|
|
1423
|
+
|
|
1424
|
+
for (const [filePath, errors] of newErrors) {
|
|
1425
|
+
if (!fileFeedback.has(filePath)) {
|
|
1426
|
+
fileFeedback.set(filePath, new Map());
|
|
1427
|
+
}
|
|
1428
|
+
for (const error of errors) {
|
|
1429
|
+
fileFeedback.get(filePath)!.set(error.line, `Previous fix caused: ${error.message}`);
|
|
1430
|
+
}
|
|
1431
|
+
}
|
|
1432
|
+
|
|
1433
|
+
console.log('Rolled back. Will retry with feedback.');
|
|
1434
|
+
} else {
|
|
1435
|
+
const reduced = totalCount - newCount;
|
|
1436
|
+
console.log(`[L2] OK: Reduced by ${reduced} (${totalCount} -> ${newCount})`);
|
|
1437
|
+
}
|
|
1438
|
+
}
|
|
1439
|
+
|
|
1440
|
+
// ===== FINAL SUMMARY =====
|
|
1441
|
+
console.log('\n========== FINAL SUMMARY ==========');
|
|
1442
|
+
const { totalCount: finalCount } = runCargoCheck();
|
|
1443
|
+
console.log(`Final error count: ${finalCount}`);
|
|
1444
|
+
|
|
1445
|
+
console.log('\n========== GATE STATISTICS ==========');
|
|
1446
|
+
console.log(`Layer 1 rejections: ${gateStats.layer1Rejections}`);
|
|
1447
|
+
console.log(`Layer 1 retries: ${gateStats.layer1Retries}`);
|
|
1448
|
+
console.log(`Layer 2 rejections: ${gateStats.layer2Rejections}`);
|
|
1449
|
+
console.log(`Layer 3 rejections: ${gateStats.layer3Rejections}`);
|
|
1450
|
+
console.log(`Approved fixes: ${gateStats.approvals}`);
|
|
1451
|
+
|
|
1452
|
+
if (Object.keys(gateStats.byGate).length > 0) {
|
|
1453
|
+
console.log('\nRejections by gate:');
|
|
1454
|
+
for (const [gate, count] of Object.entries(gateStats.byGate).sort((a, b) => b[1] - a[1])) {
|
|
1455
|
+
console.log(` ${gate}: ${count}`);
|
|
1456
|
+
}
|
|
1457
|
+
}
|
|
1458
|
+
|
|
1459
|
+
const totalAttempts = gateStats.approvals + gateStats.layer1Rejections +
|
|
1460
|
+
gateStats.layer2Rejections + gateStats.layer3Rejections;
|
|
1461
|
+
if (totalAttempts > 0) {
|
|
1462
|
+
const rejectionRate = ((gateStats.layer1Rejections + gateStats.layer2Rejections +
|
|
1463
|
+
gateStats.layer3Rejections) / totalAttempts * 100).toFixed(1);
|
|
1464
|
+
console.log(`\nRejection rate: ${rejectionRate}%`);
|
|
1465
|
+
}
|
|
1466
|
+
|
|
1467
|
+
// Save rejection log
|
|
1468
|
+
if (rejectionLog.length > 0) {
|
|
1469
|
+
const logPath = '/tmp/gate-rejections.json';
|
|
1470
|
+
fs.writeFileSync(logPath, JSON.stringify(rejectionLog, null, 2));
|
|
1471
|
+
console.log(`\nGate rejections logged to ${logPath}`);
|
|
1472
|
+
}
|
|
1473
|
+
}
|
|
1474
|
+
|
|
1475
|
+
main().catch(console.error);
|