claude-code-pilot 2.0.0 → 3.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +76 -97
- package/bin/install.js +267 -250
- package/manifest.json +5 -18
- package/package.json +5 -7
- package/src/agents/build-error-resolver.md +114 -0
- package/src/agents/ccp-advisor-researcher.md +104 -0
- package/src/agents/ccp-assumptions-analyzer.md +105 -0
- package/{gsd/agents/gsd-codebase-mapper.md → src/agents/ccp-codebase-mapper.md} +7 -7
- package/{gsd/agents/gsd-debugger.md → src/agents/ccp-debugger.md} +125 -8
- package/{gsd/agents/gsd-executor.md → src/agents/ccp-executor.md} +31 -20
- package/{gsd/agents/gsd-integration-checker.md → src/agents/ccp-integration-checker.md} +2 -2
- package/{gsd/agents/gsd-nyquist-auditor.md → src/agents/ccp-nyquist-auditor.md} +3 -3
- package/{gsd/agents/gsd-phase-researcher.md → src/agents/ccp-phase-researcher.md} +127 -13
- package/{gsd/agents/gsd-plan-checker.md → src/agents/ccp-plan-checker.md} +57 -21
- package/{gsd/agents/gsd-planner.md → src/agents/ccp-planner.md} +61 -23
- package/{gsd/agents/gsd-project-researcher.md → src/agents/ccp-project-researcher.md} +33 -6
- package/{gsd/agents/gsd-research-synthesizer.md → src/agents/ccp-research-synthesizer.md} +11 -11
- package/{gsd/agents/gsd-roadmapper.md → src/agents/ccp-roadmapper.md} +39 -10
- package/src/agents/ccp-ui-auditor.md +439 -0
- package/src/agents/ccp-ui-checker.md +300 -0
- package/src/agents/ccp-ui-researcher.md +357 -0
- package/{gsd/agents/gsd-verifier.md → src/agents/ccp-verifier.md} +81 -15
- package/src/agents/cpp-build-resolver.md +90 -0
- package/src/agents/cpp-reviewer.md +72 -0
- package/src/agents/database-reviewer.md +91 -0
- package/{ecc → src}/agents/doc-updater.md +1 -1
- package/src/agents/docs-lookup.md +68 -0
- package/src/agents/flutter-reviewer.md +243 -0
- package/src/agents/gan-evaluator.md +209 -0
- package/src/agents/gan-generator.md +131 -0
- package/src/agents/gan-planner.md +99 -0
- package/src/agents/go-build-resolver.md +94 -0
- package/src/agents/go-reviewer.md +76 -0
- package/src/agents/harness-optimizer.md +35 -0
- package/src/agents/java-build-resolver.md +153 -0
- package/src/agents/java-reviewer.md +92 -0
- package/src/agents/kotlin-build-resolver.md +118 -0
- package/src/agents/kotlin-reviewer.md +159 -0
- package/src/agents/loop-operator.md +36 -0
- package/src/agents/opensource-forker.md +198 -0
- package/src/agents/opensource-packager.md +249 -0
- package/src/agents/opensource-sanitizer.md +188 -0
- package/src/agents/performance-optimizer.md +446 -0
- package/src/agents/planner.md +212 -0
- package/src/agents/python-reviewer.md +98 -0
- package/src/agents/pytorch-build-resolver.md +120 -0
- package/src/agents/refactor-cleaner.md +85 -0
- package/src/agents/rust-build-resolver.md +148 -0
- package/src/agents/rust-reviewer.md +94 -0
- package/src/agents/typescript-reviewer.md +112 -0
- package/src/available-rules/README.md +80 -0
- package/src/available-rules/cpp/coding-style.md +44 -0
- package/src/available-rules/cpp/hooks.md +39 -0
- package/src/available-rules/cpp/patterns.md +51 -0
- package/src/available-rules/cpp/security.md +51 -0
- package/src/available-rules/cpp/testing.md +44 -0
- package/src/available-rules/csharp/coding-style.md +72 -0
- package/src/available-rules/csharp/hooks.md +25 -0
- package/src/available-rules/csharp/patterns.md +50 -0
- package/src/available-rules/csharp/security.md +58 -0
- package/src/available-rules/csharp/testing.md +46 -0
- package/src/available-rules/java/coding-style.md +114 -0
- package/src/available-rules/java/hooks.md +18 -0
- package/src/available-rules/java/patterns.md +146 -0
- package/src/available-rules/java/security.md +100 -0
- package/src/available-rules/java/testing.md +131 -0
- package/src/available-rules/kotlin/hooks.md +17 -0
- package/src/available-rules/rust/coding-style.md +151 -0
- package/src/available-rules/rust/hooks.md +16 -0
- package/src/available-rules/rust/patterns.md +168 -0
- package/src/available-rules/rust/security.md +141 -0
- package/src/available-rules/rust/testing.md +154 -0
- package/src/commands/ccp/add-backlog.md +76 -0
- package/{gsd/commands-gsd → src/commands/ccp}/add-phase.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/add-tests.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/add-todo.md +4 -4
- package/src/commands/ccp/aside.md +165 -0
- package/{gsd/commands-gsd → src/commands/ccp}/audit-milestone.md +3 -3
- package/src/commands/ccp/audit-uat.md +24 -0
- package/src/commands/ccp/autonomous.md +41 -0
- package/src/commands/ccp/build-fix.md +67 -0
- package/{gsd/commands-gsd → src/commands/ccp}/check-todos.md +3 -3
- package/{ecc/commands → src/commands/ccp}/checkpoint.md +12 -7
- package/{gsd/commands-gsd → src/commands/ccp}/cleanup.md +3 -3
- package/src/commands/ccp/code-review.md +45 -0
- package/{gsd/commands-gsd → src/commands/ccp}/complete-milestone.md +9 -9
- package/src/commands/ccp/context-budget.md +30 -0
- package/src/commands/ccp/cpp-build.md +174 -0
- package/src/commands/ccp/cpp-review.md +133 -0
- package/src/commands/ccp/cpp-test.md +252 -0
- package/{gsd/commands-gsd → src/commands/ccp}/debug.md +14 -9
- package/src/commands/ccp/discuss-phase.md +64 -0
- package/src/commands/ccp/do.md +30 -0
- package/src/commands/ccp/docs-update.md +48 -0
- package/src/commands/ccp/docs.md +32 -0
- package/src/commands/ccp/e2e.md +365 -0
- package/src/commands/ccp/eval.md +125 -0
- package/{ecc/commands → src/commands/ccp}/evolve.md +5 -5
- package/src/commands/ccp/execute-phase.md +59 -0
- package/src/commands/ccp/fast.md +30 -0
- package/src/commands/ccp/forensics.md +56 -0
- package/src/commands/ccp/go-build.md +184 -0
- package/src/commands/ccp/go-review.md +149 -0
- package/src/commands/ccp/go-test.md +269 -0
- package/src/commands/ccp/gradle-build.md +71 -0
- package/src/commands/ccp/harness-audit.md +76 -0
- package/{gsd/commands-gsd → src/commands/ccp}/health.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/help.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/insert-phase.md +3 -3
- package/src/commands/ccp/kotlin-build.md +175 -0
- package/src/commands/ccp/kotlin-review.md +141 -0
- package/src/commands/ccp/kotlin-test.md +313 -0
- package/{ecc/commands → src/commands/ccp}/learn.md +7 -2
- package/{gsd/commands-gsd → src/commands/ccp}/list-phase-assumptions.md +2 -2
- package/src/commands/ccp/manager.md +39 -0
- package/{gsd/commands-gsd → src/commands/ccp}/map-codebase.md +7 -7
- package/src/commands/ccp/milestone-summary.md +51 -0
- package/{ecc/commands → src/commands/ccp}/model-route.md +6 -1
- package/{gsd/commands-gsd → src/commands/ccp}/new-milestone.md +8 -8
- package/{gsd/commands-gsd → src/commands/ccp}/new-project.md +8 -8
- package/src/commands/ccp/next.md +24 -0
- package/src/commands/ccp/note.md +34 -0
- package/src/commands/ccp/orchestrate.md +232 -0
- package/{gsd/commands-gsd → src/commands/ccp}/pause-work.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/plan-milestone-gaps.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/plan-phase.md +9 -7
- package/src/commands/ccp/plan.md +115 -0
- package/src/commands/ccp/plant-seed.md +28 -0
- package/src/commands/ccp/pr-branch.md +25 -0
- package/src/commands/ccp/profile-user.md +46 -0
- package/{gsd/commands-gsd → src/commands/ccp}/progress.md +3 -3
- package/src/commands/ccp/prompt-optimize.md +39 -0
- package/src/commands/ccp/prune.md +25 -0
- package/src/commands/ccp/python-review.md +298 -0
- package/{ecc/commands → src/commands/ccp}/quality-gate.md +7 -2
- package/{gsd/commands-gsd → src/commands/ccp}/quick.md +10 -8
- package/src/commands/ccp/refactor-clean.md +85 -0
- package/{gsd/commands-gsd → src/commands/ccp}/remove-phase.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/research-phase.md +17 -12
- package/{ecc/commands → src/commands/ccp}/resume-session.md +9 -8
- package/{gsd/commands-gsd → src/commands/ccp}/resume-work.md +3 -3
- package/src/commands/ccp/review-backlog.md +61 -0
- package/src/commands/ccp/review.md +37 -0
- package/src/commands/ccp/rules-distill.md +12 -0
- package/src/commands/ccp/rust-build.md +188 -0
- package/src/commands/ccp/rust-review.md +143 -0
- package/src/commands/ccp/rust-test.md +309 -0
- package/{ecc/commands → src/commands/ccp}/save-session.md +2 -1
- package/src/commands/ccp/secure-phase.md +35 -0
- package/src/commands/ccp/session-report.md +19 -0
- package/{ecc/commands → src/commands/ccp}/sessions.md +39 -34
- package/src/commands/ccp/set-profile.md +12 -0
- package/{gsd/commands-gsd → src/commands/ccp}/settings.md +5 -5
- package/src/commands/ccp/setup-pm.md +81 -0
- package/{kit/commands → src/commands/ccp}/setup-refresh.md +4 -3
- package/{kit/commands → src/commands/ccp}/setup.md +67 -40
- package/src/commands/ccp/ship.md +23 -0
- package/src/commands/ccp/skill-create.md +172 -0
- package/src/commands/ccp/skill-health.md +51 -0
- package/src/commands/ccp/stats.md +18 -0
- package/src/commands/ccp/tdd.md +329 -0
- package/src/commands/ccp/test-coverage.md +74 -0
- package/src/commands/ccp/thread.md +127 -0
- package/{kit/commands → src/commands/ccp}/tool-guide.md +2 -1
- package/src/commands/ccp/ui-phase.md +34 -0
- package/src/commands/ccp/ui-review.md +32 -0
- package/src/commands/ccp/update-codemaps.md +77 -0
- package/src/commands/ccp/update-docs.md +89 -0
- package/{gsd/commands-gsd → src/commands/ccp}/update.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/validate-phase.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/verify-work.md +5 -5
- package/{ecc/commands → src/commands/ccp}/verify.md +5 -0
- package/src/commands/ccp/workstreams.md +68 -0
- package/{ecc → src}/examples/CLAUDE.md +4 -4
- package/{ecc → src}/examples/django-api-CLAUDE.md +5 -5
- package/{ecc → src}/examples/go-microservice-CLAUDE.md +6 -6
- package/{ecc → src}/examples/rust-api-CLAUDE.md +4 -4
- package/{ecc → src}/examples/saas-nextjs-CLAUDE.md +8 -8
- package/{gsd/hooks/gsd-context-monitor.js → src/hooks/ccp-context-monitor.js} +3 -3
- package/src/hooks/ccp-prompt-guard.js +96 -0
- package/{gsd/hooks/gsd-statusline.js → src/hooks/ccp-statusline.js} +7 -7
- package/src/hooks/ccp-workflow-guard.js +94 -0
- package/src/hooks/config-protection.js +141 -0
- package/{kit → src}/hooks/kit-check-update.js +7 -4
- package/src/hooks/mcp-health-check.js +620 -0
- package/{ecc/scripts → src}/hooks/run-with-flags-shell.sh +1 -1
- package/{ecc/scripts → src}/hooks/run-with-flags.js +74 -13
- package/src/hooks/session-end-marker.js +29 -0
- package/{ecc/scripts → src}/hooks/session-end.js +83 -40
- package/{ecc/scripts → src}/hooks/session-start.js +76 -10
- package/{ecc/scripts → src}/lib/hook-flags.js +8 -4
- package/{ecc/scripts → src}/lib/project-detect.js +2 -1
- package/{ecc/scripts → src}/lib/session-manager.d.ts +5 -1
- package/{ecc/scripts → src}/lib/session-manager.js +202 -92
- package/{ecc/scripts → src}/lib/utils.d.ts +23 -1
- package/{ecc/scripts → src}/lib/utils.js +91 -3
- package/{gsd/get-shit-done/bin/gsd-tools.cjs → src/pilot/bin/ccp-tools.cjs} +257 -86
- package/{gsd/get-shit-done → src/pilot}/bin/lib/commands.cjs +1 -1
- package/src/pilot/bin/lib/config.cjs +444 -0
- package/src/pilot/bin/lib/core.cjs +1190 -0
- package/src/pilot/bin/lib/init.cjs +1281 -0
- package/src/pilot/bin/lib/model-profiles.cjs +67 -0
- package/{gsd/get-shit-done → src/pilot}/bin/lib/phase.cjs +2 -2
- package/src/pilot/bin/lib/security.cjs +382 -0
- package/{gsd/get-shit-done → src/pilot}/bin/lib/state.cjs +1 -1
- package/src/pilot/bin/lib/uat.cjs +282 -0
- package/{gsd/get-shit-done → src/pilot}/bin/lib/verify.cjs +10 -10
- package/{gsd/get-shit-done → src/pilot}/references/continuation-format.md +16 -16
- package/{gsd/get-shit-done → src/pilot}/references/decimal-phase-calculation.md +5 -5
- package/{gsd/get-shit-done → src/pilot}/references/git-integration.md +5 -5
- package/{gsd/get-shit-done → src/pilot}/references/git-planning-commit.md +4 -4
- package/src/pilot/references/mcp-servers.json +153 -0
- package/{gsd/get-shit-done → src/pilot}/references/model-profile-resolution.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/references/model-profiles.md +20 -20
- package/{gsd/get-shit-done → src/pilot}/references/phase-argument-parsing.md +4 -4
- package/{gsd/get-shit-done → src/pilot}/references/planning-config.md +15 -15
- package/{gsd/get-shit-done → src/pilot}/references/ui-brand.md +5 -5
- package/{gsd/get-shit-done → src/pilot}/references/verification-patterns.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/templates/DEBUG.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/templates/UAT.md +3 -3
- package/src/pilot/templates/UI-SPEC.md +100 -0
- package/{gsd/get-shit-done → src/pilot}/templates/VALIDATION.md +1 -1
- package/src/pilot/templates/claude-md.md +122 -0
- package/{gsd/get-shit-done → src/pilot}/templates/codebase/architecture.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/templates/codebase/structure.md +13 -13
- package/{gsd/get-shit-done → src/pilot}/templates/context.md +4 -4
- package/src/pilot/templates/copilot-instructions.md +7 -0
- package/{gsd/get-shit-done → src/pilot}/templates/debug-subagent-prompt.md +4 -4
- package/src/pilot/templates/dev-preferences.md +21 -0
- package/{gsd/get-shit-done → src/pilot}/templates/discovery.md +2 -2
- package/src/pilot/templates/discussion-log.md +63 -0
- package/{gsd/get-shit-done → src/pilot}/templates/phase-prompt.md +12 -12
- package/{gsd/get-shit-done → src/pilot}/templates/planner-subagent-prompt.md +7 -7
- package/{gsd/get-shit-done → src/pilot}/templates/project.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/templates/research.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/templates/state.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/templates/summary-complex.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/workflows/add-phase.md +11 -11
- package/{gsd/get-shit-done → src/pilot}/workflows/add-tests.md +15 -15
- package/{gsd/get-shit-done → src/pilot}/workflows/add-todo.md +7 -7
- package/{gsd/get-shit-done → src/pilot}/workflows/audit-milestone.md +24 -16
- package/src/pilot/workflows/audit-uat.md +109 -0
- package/src/pilot/workflows/autonomous.md +891 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/check-todos.md +10 -10
- package/{gsd/get-shit-done → src/pilot}/workflows/cleanup.md +3 -3
- package/{gsd/get-shit-done → src/pilot}/workflows/complete-milestone.md +19 -16
- package/{gsd/get-shit-done → src/pilot}/workflows/diagnose-issues.md +9 -4
- package/{gsd/get-shit-done → src/pilot}/workflows/discovery-phase.md +8 -8
- package/src/pilot/workflows/discuss-phase-assumptions.md +653 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/discuss-phase.md +407 -49
- package/src/pilot/workflows/do.md +104 -0
- package/src/pilot/workflows/docs-update.md +1165 -0
- package/src/pilot/workflows/execute-phase.md +821 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/execute-plan.md +79 -28
- package/src/pilot/workflows/fast.md +105 -0
- package/src/pilot/workflows/forensics.md +265 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/health.md +34 -11
- package/src/pilot/workflows/help.md +767 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/insert-phase.md +10 -10
- package/{gsd/get-shit-done → src/pilot}/workflows/list-phase-assumptions.md +4 -4
- package/src/pilot/workflows/manager.md +362 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/map-codebase.md +27 -17
- package/src/pilot/workflows/milestone-summary.md +223 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/new-milestone.md +135 -33
- package/{gsd/get-shit-done → src/pilot}/workflows/new-project.md +152 -79
- package/src/pilot/workflows/next.md +97 -0
- package/src/pilot/workflows/node-repair.md +92 -0
- package/src/pilot/workflows/note.md +156 -0
- package/src/pilot/workflows/pause-work.md +177 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/plan-milestone-gaps.md +10 -11
- package/src/pilot/workflows/plan-phase.md +859 -0
- package/src/pilot/workflows/plant-seed.md +169 -0
- package/src/pilot/workflows/pr-branch.md +129 -0
- package/src/pilot/workflows/profile-user.md +452 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/progress.md +95 -34
- package/{gsd/get-shit-done → src/pilot}/workflows/quick.md +33 -21
- package/{gsd/get-shit-done → src/pilot}/workflows/remove-phase.md +14 -14
- package/{gsd/get-shit-done → src/pilot}/workflows/research-phase.md +18 -10
- package/{gsd/get-shit-done → src/pilot}/workflows/resume-project.md +37 -18
- package/src/pilot/workflows/review.md +244 -0
- package/src/pilot/workflows/secure-phase.md +164 -0
- package/src/pilot/workflows/session-report.md +146 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/set-profile.md +7 -7
- package/{gsd/get-shit-done → src/pilot}/workflows/settings.md +75 -22
- package/src/pilot/workflows/ship.md +228 -0
- package/src/pilot/workflows/stats.md +60 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/transition.md +57 -17
- package/src/pilot/workflows/ui-phase.md +302 -0
- package/src/pilot/workflows/ui-review.md +165 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/update.md +88 -58
- package/{gsd/get-shit-done → src/pilot}/workflows/validate-phase.md +24 -17
- package/{gsd/get-shit-done → src/pilot}/workflows/verify-phase.md +26 -15
- package/{gsd/get-shit-done → src/pilot}/workflows/verify-work.md +89 -37
- package/{ecc → src}/rules/common/agents.md +1 -0
- package/src/rules/common/code-review.md +124 -0
- package/{ecc → src}/rules/common/coding-style.md +21 -0
- package/src/rules/zh/README.md +108 -0
- package/src/rules/zh/agents.md +50 -0
- package/src/rules/zh/code-review.md +124 -0
- package/src/rules/zh/coding-style.md +48 -0
- package/src/rules/zh/development-workflow.md +44 -0
- package/src/rules/zh/git-workflow.md +24 -0
- package/src/rules/zh/hooks.md +30 -0
- package/src/rules/zh/patterns.md +31 -0
- package/src/rules/zh/performance.md +55 -0
- package/src/rules/zh/security.md +29 -0
- package/src/rules/zh/testing.md +29 -0
- package/src/skills/agentic-engineering/SKILL.md +63 -0
- package/src/skills/ai-first-engineering/SKILL.md +51 -0
- package/src/skills/ai-regression-testing/SKILL.md +385 -0
- package/src/skills/api-design/SKILL.md +523 -0
- package/src/skills/architecture-decision-records/SKILL.md +179 -0
- package/src/skills/autonomous-agent-harness/SKILL.md +267 -0
- package/src/skills/autonomous-loops/SKILL.md +610 -0
- package/src/skills/backend-patterns/SKILL.md +598 -0
- package/src/skills/benchmark/SKILL.md +87 -0
- package/src/skills/blueprint/SKILL.md +90 -0
- package/src/skills/browser-qa/SKILL.md +81 -0
- package/src/skills/bun-runtime/SKILL.md +84 -0
- package/src/skills/claude-api/SKILL.md +337 -0
- package/src/skills/codebase-onboarding/SKILL.md +233 -0
- package/src/skills/coding-standards/SKILL.md +530 -0
- package/src/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/src/skills/context-budget/SKILL.md +135 -0
- package/{ecc → src}/skills/continuous-learning-v2/SKILL.md +6 -6
- package/{ecc → src}/skills/continuous-learning-v2/agents/observer-loop.sh +1 -1
- package/{ecc → src}/skills/continuous-learning-v2/agents/observer.md +1 -1
- package/src/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/src/skills/cpp-coding-standards/SKILL.md +723 -0
- package/src/skills/cpp-testing/SKILL.md +324 -0
- package/src/skills/database-migrations/SKILL.md +429 -0
- package/src/skills/deep-research/SKILL.md +155 -0
- package/src/skills/deployment-patterns/SKILL.md +427 -0
- package/src/skills/design-system/SKILL.md +82 -0
- package/src/skills/django-patterns/SKILL.md +734 -0
- package/src/skills/django-security/SKILL.md +593 -0
- package/src/skills/django-tdd/SKILL.md +729 -0
- package/src/skills/django-verification/SKILL.md +469 -0
- package/src/skills/docker-patterns/SKILL.md +364 -0
- package/src/skills/documentation-lookup/SKILL.md +90 -0
- package/src/skills/e2e-testing/SKILL.md +326 -0
- package/src/skills/eval-harness/SKILL.md +270 -0
- package/src/skills/exa-search/SKILL.md +103 -0
- package/src/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/src/skills/frontend-patterns/SKILL.md +642 -0
- package/src/skills/gan-style-harness/SKILL.md +278 -0
- package/src/skills/git-workflow/SKILL.md +715 -0
- package/src/skills/golang-patterns/SKILL.md +674 -0
- package/src/skills/golang-testing/SKILL.md +720 -0
- package/src/skills/hexagonal-architecture/SKILL.md +276 -0
- package/src/skills/iterative-retrieval/SKILL.md +211 -0
- package/src/skills/java-coding-standards/SKILL.md +147 -0
- package/src/skills/jpa-patterns/SKILL.md +151 -0
- package/src/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/src/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/src/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/src/skills/kotlin-patterns/SKILL.md +711 -0
- package/src/skills/kotlin-testing/SKILL.md +824 -0
- package/src/skills/laravel-patterns/SKILL.md +415 -0
- package/src/skills/laravel-plugin-discovery/SKILL.md +229 -0
- package/src/skills/laravel-security/SKILL.md +285 -0
- package/src/skills/laravel-tdd/SKILL.md +283 -0
- package/src/skills/laravel-verification/SKILL.md +179 -0
- package/src/skills/mcp-server-patterns/SKILL.md +67 -0
- package/src/skills/nextjs-turbopack/SKILL.md +44 -0
- package/src/skills/nuxt4-patterns/SKILL.md +100 -0
- package/src/skills/opensource-pipeline/SKILL.md +255 -0
- package/src/skills/perl-patterns/SKILL.md +504 -0
- package/src/skills/perl-security/SKILL.md +503 -0
- package/src/skills/perl-testing/SKILL.md +475 -0
- package/src/skills/postgres-patterns/SKILL.md +147 -0
- package/src/skills/project-flow-ops/SKILL.md +111 -0
- package/src/skills/project-guidelines-example/SKILL.md +349 -0
- package/src/skills/prompt-optimizer/SKILL.md +397 -0
- package/src/skills/python-patterns/SKILL.md +750 -0
- package/src/skills/python-testing/SKILL.md +816 -0
- package/src/skills/pytorch-patterns/SKILL.md +396 -0
- package/src/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/src/skills/repo-scan/SKILL.md +78 -0
- package/src/skills/rules-distill/SKILL.md +264 -0
- package/src/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/src/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/src/skills/rust-patterns/SKILL.md +499 -0
- package/src/skills/rust-testing/SKILL.md +500 -0
- package/src/skills/safety-guard/SKILL.md +69 -0
- package/src/skills/search-first/SKILL.md +161 -0
- package/src/skills/security-review/SKILL.md +495 -0
- package/src/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/src/skills/security-scan/SKILL.md +165 -0
- package/src/skills/springboot-patterns/SKILL.md +314 -0
- package/src/skills/springboot-security/SKILL.md +272 -0
- package/src/skills/springboot-tdd/SKILL.md +158 -0
- package/src/skills/springboot-verification/SKILL.md +231 -0
- package/src/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/src/skills/tdd-workflow/SKILL.md +410 -0
- package/src/skills/token-budget-advisor/SKILL.md +133 -0
- package/{ecc/skills/verification-loop-SKILL.md → src/skills/verification-loop/SKILL.md} +1 -1
- package/src/skills/workspace-surface-audit/SKILL.md +125 -0
- package/ecc/scripts/hooks/session-end-marker.js +0 -15
- package/gsd/LICENSE +0 -21
- package/gsd/commands-gsd/discuss-phase.md +0 -90
- package/gsd/commands-gsd/execute-phase.md +0 -41
- package/gsd/commands-gsd/join-discord.md +0 -18
- package/gsd/commands-gsd/reapply-patches.md +0 -123
- package/gsd/commands-gsd/set-profile.md +0 -34
- package/gsd/get-shit-done/bin/lib/config.cjs +0 -169
- package/gsd/get-shit-done/bin/lib/core.cjs +0 -492
- package/gsd/get-shit-done/bin/lib/init.cjs +0 -710
- package/gsd/get-shit-done/workflows/execute-phase.md +0 -459
- package/gsd/get-shit-done/workflows/help.md +0 -489
- package/gsd/get-shit-done/workflows/pause-work.md +0 -122
- package/gsd/get-shit-done/workflows/plan-phase.md +0 -560
- package/gsd/hooks/gsd-check-update.js +0 -81
- package/kit/CLAUDE.md +0 -43
- package/kit/commands/kit/update.md +0 -46
- package/kit/mcp.json +0 -10
- package/kit/rules/code-style.md +0 -24
- /package/{ecc → src}/agents/architect.md +0 -0
- /package/{ecc → src}/agents/code-reviewer.md +0 -0
- /package/{ecc → src}/agents/e2e-runner.md +0 -0
- /package/{ecc → src}/agents/security-reviewer.md +0 -0
- /package/{ecc → src}/agents/tdd-guide.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/testing.md +0 -0
- /package/{ecc → src}/contexts/dev.md +0 -0
- /package/{ecc → src}/contexts/research.md +0 -0
- /package/{ecc → src}/contexts/review.md +0 -0
- /package/{ecc → src}/examples/user-CLAUDE.md +0 -0
- /package/{ecc/scripts → src}/hooks/check-hook-enabled.js +0 -0
- /package/{ecc/scripts → src}/hooks/evaluate-session.js +0 -0
- /package/{ecc/scripts → src}/hooks/pre-compact.js +0 -0
- /package/{ecc/scripts → src}/hooks/suggest-compact.js +0 -0
- /package/{ecc/scripts → src}/lib/package-manager.d.ts +0 -0
- /package/{ecc/scripts → src}/lib/package-manager.js +0 -0
- /package/{ecc/scripts → src}/lib/resolve-formatter.js +0 -0
- /package/{ecc/scripts → src}/lib/session-aliases.d.ts +0 -0
- /package/{ecc/scripts → src}/lib/session-aliases.js +0 -0
- /package/{ecc/scripts → src}/lib/shell-split.js +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/frontmatter.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/milestone.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/roadmap.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/template.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/references/checkpoints.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/references/questioning.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/references/tdd.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/concerns.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/conventions.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/integrations.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/stack.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/testing.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/config.json +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/continue-here.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/milestone-archive.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/milestone.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/requirements.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/ARCHITECTURE.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/FEATURES.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/PITFALLS.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/STACK.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/SUMMARY.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/retrospective.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/roadmap.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/summary-minimal.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/summary-standard.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/summary.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/user-setup.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/verification-report.md +0 -0
- /package/{ecc → src}/rules/common/development-workflow.md +0 -0
- /package/{ecc → src}/rules/common/git-workflow.md +0 -0
- /package/{ecc → src}/rules/common/hooks.md +0 -0
- /package/{ecc → src}/rules/common/patterns.md +0 -0
- /package/{ecc → src}/rules/common/performance.md +0 -0
- /package/{ecc → src}/rules/common/security.md +0 -0
- /package/{ecc → src}/rules/common/testing.md +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/agents/start-observer.sh +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/config.json +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/hooks/observe.sh +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/scripts/detect-project.sh +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -0
- /package/{ecc → src}/skills/strategic-compact/SKILL.md +0 -0
- /package/{ecc → src}/skills/strategic-compact/suggest-compact.sh +0 -0
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: context-budget
|
|
3
|
+
description: Audits Claude Code context window consumption across agents, skills, MCP servers, and rules. Identifies bloat, redundant components, and produces prioritized token-savings recommendations.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Context Budget
|
|
8
|
+
|
|
9
|
+
Analyze token overhead across every loaded component in a Claude Code session and surface actionable optimizations to reclaim context space.
|
|
10
|
+
|
|
11
|
+
## When to Use
|
|
12
|
+
|
|
13
|
+
- Session performance feels sluggish or output quality is degrading
|
|
14
|
+
- You've recently added many skills, agents, or MCP servers
|
|
15
|
+
- You want to know how much context headroom you actually have
|
|
16
|
+
- Planning to add more components and need to know if there's room
|
|
17
|
+
- Running `/ccp:context-budget` command (this skill backs it)
|
|
18
|
+
|
|
19
|
+
## How It Works
|
|
20
|
+
|
|
21
|
+
### Phase 1: Inventory
|
|
22
|
+
|
|
23
|
+
Scan all component directories and estimate token consumption:
|
|
24
|
+
|
|
25
|
+
**Agents** (`agents/*.md`)
|
|
26
|
+
- Count lines and tokens per file (words × 1.3)
|
|
27
|
+
- Extract `description` frontmatter length
|
|
28
|
+
- Flag: files >200 lines (heavy), description >30 words (bloated frontmatter)
|
|
29
|
+
|
|
30
|
+
**Skills** (`skills/*/SKILL.md`)
|
|
31
|
+
- Count tokens per SKILL.md
|
|
32
|
+
- Flag: files >400 lines
|
|
33
|
+
- Check for duplicate copies in `.agents/skills/` — skip identical copies to avoid double-counting
|
|
34
|
+
|
|
35
|
+
**Rules** (`rules/**/*.md`)
|
|
36
|
+
- Count tokens per file
|
|
37
|
+
- Flag: files >100 lines
|
|
38
|
+
- Detect content overlap between rule files in the same language module
|
|
39
|
+
|
|
40
|
+
**MCP Servers** (`.mcp.json` or active MCP config)
|
|
41
|
+
- Count configured servers and total tool count
|
|
42
|
+
- Estimate schema overhead at ~500 tokens per tool
|
|
43
|
+
- Flag: servers with >20 tools, servers that wrap simple CLI commands (`gh`, `git`, `npm`, `supabase`, `vercel`)
|
|
44
|
+
|
|
45
|
+
**CLAUDE.md** (project + user-level)
|
|
46
|
+
- Count tokens per file in the CLAUDE.md chain
|
|
47
|
+
- Flag: combined total >300 lines
|
|
48
|
+
|
|
49
|
+
### Phase 2: Classify
|
|
50
|
+
|
|
51
|
+
Sort every component into a bucket:
|
|
52
|
+
|
|
53
|
+
| Bucket | Criteria | Action |
|
|
54
|
+
|--------|----------|--------|
|
|
55
|
+
| **Always needed** | Referenced in CLAUDE.md, backs an active command, or matches current project type | Keep |
|
|
56
|
+
| **Sometimes needed** | Domain-specific (e.g. language patterns), not referenced in CLAUDE.md | Consider on-demand activation |
|
|
57
|
+
| **Rarely needed** | No command reference, overlapping content, or no obvious project match | Remove or lazy-load |
|
|
58
|
+
|
|
59
|
+
### Phase 3: Detect Issues
|
|
60
|
+
|
|
61
|
+
Identify the following problem patterns:
|
|
62
|
+
|
|
63
|
+
- **Bloated agent descriptions** — description >30 words in frontmatter loads into every Task tool invocation
|
|
64
|
+
- **Heavy agents** — files >200 lines inflate Task tool context on every spawn
|
|
65
|
+
- **Redundant components** — skills that duplicate agent logic, rules that duplicate CLAUDE.md
|
|
66
|
+
- **MCP over-subscription** — >10 servers, or servers wrapping CLI tools available for free
|
|
67
|
+
- **CLAUDE.md bloat** — verbose explanations, outdated sections, instructions that should be rules
|
|
68
|
+
|
|
69
|
+
### Phase 4: Report
|
|
70
|
+
|
|
71
|
+
Produce the context budget report:
|
|
72
|
+
|
|
73
|
+
```
|
|
74
|
+
Context Budget Report
|
|
75
|
+
═══════════════════════════════════════
|
|
76
|
+
|
|
77
|
+
Total estimated overhead: ~XX,XXX tokens
|
|
78
|
+
Context model: Claude Sonnet (200K window)
|
|
79
|
+
Effective available context: ~XXX,XXX tokens (XX%)
|
|
80
|
+
|
|
81
|
+
Component Breakdown:
|
|
82
|
+
┌─────────────────┬────────┬───────────┐
|
|
83
|
+
│ Component │ Count │ Tokens │
|
|
84
|
+
├─────────────────┼────────┼───────────┤
|
|
85
|
+
│ Agents │ N │ ~X,XXX │
|
|
86
|
+
│ Skills │ N │ ~X,XXX │
|
|
87
|
+
│ Rules │ N │ ~X,XXX │
|
|
88
|
+
│ MCP tools │ N │ ~XX,XXX │
|
|
89
|
+
│ CLAUDE.md │ N │ ~X,XXX │
|
|
90
|
+
└─────────────────┴────────┴───────────┘
|
|
91
|
+
|
|
92
|
+
⚠ Issues Found (N):
|
|
93
|
+
[ranked by token savings]
|
|
94
|
+
|
|
95
|
+
Top 3 Optimizations:
|
|
96
|
+
1. [action] → save ~X,XXX tokens
|
|
97
|
+
2. [action] → save ~X,XXX tokens
|
|
98
|
+
3. [action] → save ~X,XXX tokens
|
|
99
|
+
|
|
100
|
+
Potential savings: ~XX,XXX tokens (XX% of current overhead)
|
|
101
|
+
```
|
|
102
|
+
|
|
103
|
+
In verbose mode, additionally output per-file token counts, line-by-line breakdown of the heaviest files, specific redundant lines between overlapping components, and MCP tool list with per-tool schema size estimates.
|
|
104
|
+
|
|
105
|
+
## Examples
|
|
106
|
+
|
|
107
|
+
**Basic audit**
|
|
108
|
+
```
|
|
109
|
+
User: /ccp:context-budget
|
|
110
|
+
Skill: Scans setup → 16 agents (12,400 tokens), 28 skills (6,200), 87 MCP tools (43,500), 2 CLAUDE.md (1,200)
|
|
111
|
+
Flags: 3 heavy agents, 14 MCP servers (3 CLI-replaceable)
|
|
112
|
+
Top saving: remove 3 MCP servers → -27,500 tokens (47% overhead reduction)
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
**Verbose mode**
|
|
116
|
+
```
|
|
117
|
+
User: /ccp:context-budget --verbose
|
|
118
|
+
Skill: Full report + per-file breakdown showing planner.md (213 lines, 1,840 tokens),
|
|
119
|
+
MCP tool list with per-tool sizes, duplicated rule lines side by side
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
**Pre-expansion check**
|
|
123
|
+
```
|
|
124
|
+
User: I want to add 5 more MCP servers, do I have room?
|
|
125
|
+
Skill: Current overhead 33% → adding 5 servers (~50 tools) would add ~25,000 tokens → pushes to 45% overhead
|
|
126
|
+
Recommendation: remove 2 CLI-replaceable servers first to stay under 40%
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
## Best Practices
|
|
130
|
+
|
|
131
|
+
- **Token estimation**: use `words × 1.3` for prose, `chars / 4` for code-heavy files
|
|
132
|
+
- **MCP is the biggest lever**: each tool schema costs ~500 tokens; a 30-tool server costs more than all your skills combined
|
|
133
|
+
- **Agent descriptions are loaded always**: even if the agent is never invoked, its description field is present in every Task tool context
|
|
134
|
+
- **Verbose mode for debugging**: use when you need to pinpoint the exact files driving overhead, not for regular audits
|
|
135
|
+
- **Audit after changes**: run after adding any agent, skill, or MCP server to catch creep early
|
|
@@ -112,7 +112,7 @@ Session Activity (in a git repo)
|
|
|
112
112
|
| * grep-before-edit.yaml (0.6) [global] |
|
|
113
113
|
+---------------------------------------------+
|
|
114
114
|
|
|
|
115
|
-
| /evolve clusters + /promote
|
|
115
|
+
| /ccp:evolve clusters + /promote
|
|
116
116
|
v
|
|
117
117
|
+---------------------------------------------+
|
|
118
118
|
| projects/<hash>/evolved/ (project-scoped) |
|
|
@@ -149,14 +149,14 @@ Add to your `~/.claude/settings.json`.
|
|
|
149
149
|
"matcher": "*",
|
|
150
150
|
"hooks": [{
|
|
151
151
|
"type": "command",
|
|
152
|
-
"command": "$
|
|
152
|
+
"command": "$(getClaudeDir)/skills/continuous-learning-v2/hooks/observe.sh"
|
|
153
153
|
}]
|
|
154
154
|
}],
|
|
155
155
|
"PostToolUse": [{
|
|
156
156
|
"matcher": "*",
|
|
157
157
|
"hooks": [{
|
|
158
158
|
"type": "command",
|
|
159
|
-
"command": "$
|
|
159
|
+
"command": "$(getClaudeDir)/skills/continuous-learning-v2/hooks/observe.sh"
|
|
160
160
|
}]
|
|
161
161
|
}]
|
|
162
162
|
}
|
|
@@ -201,7 +201,7 @@ mkdir -p ~/.claude/homunculus/{instincts/{personal,inherited},evolved/{agents,sk
|
|
|
201
201
|
|
|
202
202
|
```bash
|
|
203
203
|
/instinct-status # Show learned instincts (project + global)
|
|
204
|
-
/evolve
|
|
204
|
+
/ccp:evolve # Cluster related instincts into skills/commands
|
|
205
205
|
/instinct-export # Export instincts to file
|
|
206
206
|
/instinct-import # Import instincts from others
|
|
207
207
|
/promote # Promote project instincts to global scope
|
|
@@ -213,7 +213,7 @@ mkdir -p ~/.claude/homunculus/{instincts/{personal,inherited},evolved/{agents,sk
|
|
|
213
213
|
| Command | Description |
|
|
214
214
|
|---------|-------------|
|
|
215
215
|
| `/instinct-status` | Show all instincts (project-scoped + global) with confidence |
|
|
216
|
-
| `/evolve` | Cluster related instincts into skills/commands, suggest promotions |
|
|
216
|
+
| `/ccp:evolve` | Cluster related instincts into skills/commands, suggest promotions |
|
|
217
217
|
| `/instinct-export` | Export instincts (filterable by scope/domain) |
|
|
218
218
|
| `/instinct-import <file>` | Import instincts with scope control |
|
|
219
219
|
| `/promote [id]` | Promote project instincts to global scope |
|
|
@@ -306,7 +306,7 @@ python3 instinct-cli.py promote
|
|
|
306
306
|
python3 instinct-cli.py promote --dry-run
|
|
307
307
|
```
|
|
308
308
|
|
|
309
|
-
The `/evolve` command also suggests promotion candidates.
|
|
309
|
+
The `/ccp:evolve` command also suggests promotion candidates.
|
|
310
310
|
|
|
311
311
|
## Confidence Scoring
|
|
312
312
|
|
|
@@ -38,7 +38,7 @@ analyze_observations() {
|
|
|
38
38
|
return
|
|
39
39
|
fi
|
|
40
40
|
|
|
41
|
-
prompt_file="$(mktemp "${TMPDIR:-/tmp}/
|
|
41
|
+
prompt_file="$(mktemp "${TMPDIR:-/tmp}/ccp-observer-prompt.XXXXXX")"
|
|
42
42
|
cat > "$prompt_file" <<PROMPT
|
|
43
43
|
Read ${OBSERVATIONS_FILE} and identify patterns for the project ${PROJECT_NAME} (user corrections, error resolutions, repeated workflows, tool preferences).
|
|
44
44
|
If you find 3+ occurrences of the same pattern, create an instinct file in ${INSTINCTS_DIR}/<id>.md.
|
|
@@ -154,7 +154,7 @@ An instinct should be promoted from project-scoped to global when:
|
|
|
154
154
|
2. Each instance has confidence **>= 0.8**
|
|
155
155
|
3. The domain is in the global-friendly list (security, general-best-practices, workflow)
|
|
156
156
|
|
|
157
|
-
Promotion is handled by the `instinct-cli.py promote` command or the `/evolve` analysis.
|
|
157
|
+
Promotion is handled by the `instinct-cli.py promote` command or the `/ccp:evolve` analysis.
|
|
158
158
|
|
|
159
159
|
## Important Guidelines
|
|
160
160
|
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: cost-aware-llm-pipeline
|
|
3
|
+
description: Cost optimization patterns for LLM API usage — model routing by task complexity, budget tracking, retry logic, and prompt caching.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Cost-Aware LLM Pipeline
|
|
8
|
+
|
|
9
|
+
Patterns for controlling LLM API costs while maintaining quality. Combines model routing, budget tracking, retry logic, and prompt caching into a composable pipeline.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- Building applications that call LLM APIs (Claude, GPT, etc.)
|
|
14
|
+
- Processing batches of items with varying complexity
|
|
15
|
+
- Need to stay within a budget for API spend
|
|
16
|
+
- Optimizing cost without sacrificing quality on complex tasks
|
|
17
|
+
|
|
18
|
+
## Core Concepts
|
|
19
|
+
|
|
20
|
+
### 1. Model Routing by Task Complexity
|
|
21
|
+
|
|
22
|
+
Automatically select cheaper models for simple tasks, reserving expensive models for complex ones.
|
|
23
|
+
|
|
24
|
+
```python
|
|
25
|
+
MODEL_SONNET = "claude-sonnet-4-6"
|
|
26
|
+
MODEL_HAIKU = "claude-haiku-4-5-20251001"
|
|
27
|
+
|
|
28
|
+
_SONNET_TEXT_THRESHOLD = 10_000 # chars
|
|
29
|
+
_SONNET_ITEM_THRESHOLD = 30 # items
|
|
30
|
+
|
|
31
|
+
def select_model(
|
|
32
|
+
text_length: int,
|
|
33
|
+
item_count: int,
|
|
34
|
+
force_model: str | None = None,
|
|
35
|
+
) -> str:
|
|
36
|
+
"""Select model based on task complexity."""
|
|
37
|
+
if force_model is not None:
|
|
38
|
+
return force_model
|
|
39
|
+
if text_length >= _SONNET_TEXT_THRESHOLD or item_count >= _SONNET_ITEM_THRESHOLD:
|
|
40
|
+
return MODEL_SONNET # Complex task
|
|
41
|
+
return MODEL_HAIKU # Simple task (3-4x cheaper)
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
### 2. Immutable Cost Tracking
|
|
45
|
+
|
|
46
|
+
Track cumulative spend with frozen dataclasses. Each API call returns a new tracker — never mutates state.
|
|
47
|
+
|
|
48
|
+
```python
|
|
49
|
+
from dataclasses import dataclass
|
|
50
|
+
|
|
51
|
+
@dataclass(frozen=True, slots=True)
|
|
52
|
+
class CostRecord:
|
|
53
|
+
model: str
|
|
54
|
+
input_tokens: int
|
|
55
|
+
output_tokens: int
|
|
56
|
+
cost_usd: float
|
|
57
|
+
|
|
58
|
+
@dataclass(frozen=True, slots=True)
|
|
59
|
+
class CostTracker:
|
|
60
|
+
budget_limit: float = 1.00
|
|
61
|
+
records: tuple[CostRecord, ...] = ()
|
|
62
|
+
|
|
63
|
+
def add(self, record: CostRecord) -> "CostTracker":
|
|
64
|
+
"""Return new tracker with added record (never mutates self)."""
|
|
65
|
+
return CostTracker(
|
|
66
|
+
budget_limit=self.budget_limit,
|
|
67
|
+
records=(*self.records, record),
|
|
68
|
+
)
|
|
69
|
+
|
|
70
|
+
@property
|
|
71
|
+
def total_cost(self) -> float:
|
|
72
|
+
return sum(r.cost_usd for r in self.records)
|
|
73
|
+
|
|
74
|
+
@property
|
|
75
|
+
def over_budget(self) -> bool:
|
|
76
|
+
return self.total_cost > self.budget_limit
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
### 3. Narrow Retry Logic
|
|
80
|
+
|
|
81
|
+
Retry only on transient errors. Fail fast on authentication or bad request errors.
|
|
82
|
+
|
|
83
|
+
```python
|
|
84
|
+
from anthropic import (
|
|
85
|
+
APIConnectionError,
|
|
86
|
+
InternalServerError,
|
|
87
|
+
RateLimitError,
|
|
88
|
+
)
|
|
89
|
+
|
|
90
|
+
_RETRYABLE_ERRORS = (APIConnectionError, RateLimitError, InternalServerError)
|
|
91
|
+
_MAX_RETRIES = 3
|
|
92
|
+
|
|
93
|
+
def call_with_retry(func, *, max_retries: int = _MAX_RETRIES):
|
|
94
|
+
"""Retry only on transient errors, fail fast on others."""
|
|
95
|
+
for attempt in range(max_retries):
|
|
96
|
+
try:
|
|
97
|
+
return func()
|
|
98
|
+
except _RETRYABLE_ERRORS:
|
|
99
|
+
if attempt == max_retries - 1:
|
|
100
|
+
raise
|
|
101
|
+
time.sleep(2 ** attempt) # Exponential backoff
|
|
102
|
+
# AuthenticationError, BadRequestError etc. → raise immediately
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
### 4. Prompt Caching
|
|
106
|
+
|
|
107
|
+
Cache long system prompts to avoid resending them on every request.
|
|
108
|
+
|
|
109
|
+
```python
|
|
110
|
+
messages = [
|
|
111
|
+
{
|
|
112
|
+
"role": "user",
|
|
113
|
+
"content": [
|
|
114
|
+
{
|
|
115
|
+
"type": "text",
|
|
116
|
+
"text": system_prompt,
|
|
117
|
+
"cache_control": {"type": "ephemeral"}, # Cache this
|
|
118
|
+
},
|
|
119
|
+
{
|
|
120
|
+
"type": "text",
|
|
121
|
+
"text": user_input, # Variable part
|
|
122
|
+
},
|
|
123
|
+
],
|
|
124
|
+
}
|
|
125
|
+
]
|
|
126
|
+
```
|
|
127
|
+
|
|
128
|
+
## Composition
|
|
129
|
+
|
|
130
|
+
Combine all four techniques in a single pipeline function:
|
|
131
|
+
|
|
132
|
+
```python
|
|
133
|
+
def process(text: str, config: Config, tracker: CostTracker) -> tuple[Result, CostTracker]:
|
|
134
|
+
# 1. Route model
|
|
135
|
+
model = select_model(len(text), estimated_items, config.force_model)
|
|
136
|
+
|
|
137
|
+
# 2. Check budget
|
|
138
|
+
if tracker.over_budget:
|
|
139
|
+
raise BudgetExceededError(tracker.total_cost, tracker.budget_limit)
|
|
140
|
+
|
|
141
|
+
# 3. Call with retry + caching
|
|
142
|
+
response = call_with_retry(lambda: client.messages.create(
|
|
143
|
+
model=model,
|
|
144
|
+
messages=build_cached_messages(system_prompt, text),
|
|
145
|
+
))
|
|
146
|
+
|
|
147
|
+
# 4. Track cost (immutable)
|
|
148
|
+
record = CostRecord(model=model, input_tokens=..., output_tokens=..., cost_usd=...)
|
|
149
|
+
tracker = tracker.add(record)
|
|
150
|
+
|
|
151
|
+
return parse_result(response), tracker
|
|
152
|
+
```
|
|
153
|
+
|
|
154
|
+
## Pricing Reference (2025-2026)
|
|
155
|
+
|
|
156
|
+
| Model | Input ($/1M tokens) | Output ($/1M tokens) | Relative Cost |
|
|
157
|
+
|-------|---------------------|----------------------|---------------|
|
|
158
|
+
| Haiku 4.5 | $0.80 | $4.00 | 1x |
|
|
159
|
+
| Sonnet 4.6 | $3.00 | $15.00 | ~4x |
|
|
160
|
+
| Opus 4.5 | $15.00 | $75.00 | ~19x |
|
|
161
|
+
|
|
162
|
+
## Best Practices
|
|
163
|
+
|
|
164
|
+
- **Start with the cheapest model** and only route to expensive models when complexity thresholds are met
|
|
165
|
+
- **Set explicit budget limits** before processing batches — fail early rather than overspend
|
|
166
|
+
- **Log model selection decisions** so you can tune thresholds based on real data
|
|
167
|
+
- **Use prompt caching** for system prompts over 1024 tokens — saves both cost and latency
|
|
168
|
+
- **Never retry on authentication or validation errors** — only transient failures (network, rate limit, server error)
|
|
169
|
+
|
|
170
|
+
## Anti-Patterns to Avoid
|
|
171
|
+
|
|
172
|
+
- Using the most expensive model for all requests regardless of complexity
|
|
173
|
+
- Retrying on all errors (wastes budget on permanent failures)
|
|
174
|
+
- Mutating cost tracking state (makes debugging and auditing difficult)
|
|
175
|
+
- Hardcoding model names throughout the codebase (use constants or config)
|
|
176
|
+
- Ignoring prompt caching for repetitive system prompts
|
|
177
|
+
|
|
178
|
+
## When to Use
|
|
179
|
+
|
|
180
|
+
- Any application calling Claude, OpenAI, or similar LLM APIs
|
|
181
|
+
- Batch processing pipelines where cost adds up quickly
|
|
182
|
+
- Multi-model architectures that need intelligent routing
|
|
183
|
+
- Production systems that need budget guardrails
|