@heyai-rules/pilo-masterkit 1.2.2 → 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/.agent/agents/architect.md +211 -211
- package/.agent/agents/build-error-resolver.md +114 -114
- package/.agent/agents/chief-of-staff.md +151 -151
- package/.agent/agents/code-reviewer.md +237 -237
- package/.agent/agents/cpp-build-resolver.md +90 -90
- package/.agent/agents/cpp-reviewer.md +72 -72
- package/.agent/agents/csharp-reviewer.md +101 -0
- package/.agent/agents/dart-build-resolver.md +201 -0
- package/.agent/agents/database-reviewer.md +91 -91
- package/.agent/agents/doc-updater.md +107 -107
- package/.agent/agents/docs-lookup.md +68 -68
- package/.agent/agents/e2e-runner.md +107 -107
- package/.agent/agents/flutter-reviewer.md +243 -243
- package/.agent/agents/gan-evaluator.md +209 -0
- package/.agent/agents/gan-generator.md +131 -0
- package/.agent/agents/gan-planner.md +99 -0
- package/.agent/agents/go-build-resolver.md +94 -94
- package/.agent/agents/go-reviewer.md +76 -76
- package/.agent/agents/harness-optimizer.md +35 -35
- package/.agent/agents/healthcare-reviewer.md +83 -0
- package/.agent/agents/java-build-resolver.md +153 -153
- package/.agent/agents/java-reviewer.md +92 -92
- package/.agent/agents/kotlin-build-resolver.md +118 -118
- package/.agent/agents/kotlin-reviewer.md +159 -159
- package/.agent/agents/loop-operator.md +36 -36
- package/.agent/agents/opensource-forker.md +198 -0
- package/.agent/agents/opensource-packager.md +249 -0
- package/.agent/agents/opensource-sanitizer.md +188 -0
- package/.agent/agents/performance-optimizer.md +392 -133
- package/.agent/agents/personas/athena-agent/agent.json +10 -0
- package/.agent/agents/personas/athena-agent/athena-backend-logic-architecture-profile.md +189 -0
- package/.agent/agents/personas/athena-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/athena-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/athena-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/athena-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/athena-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/athena-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/da-vinci-agent/agent.json +10 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/da-vinci-agent/da-vinci-frontend-ui-ux-design-profile.md +189 -0
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/duong-tang-agent/agent.json +10 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/duong-tang-agent/tang-monk-quality-testing-documentation-profile.md +189 -0
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/gia-cat-luong-agent/agent.json +10 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/gia-cat-luong-agent/kongming-research-strategy-analysis-profile.md +189 -0
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/mihata-agent/agent.json +10 -0
- package/.agent/agents/personas/mihata-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/mihata-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/mihata-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/mihata-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/mihata-agent/mihata-multi-agent-orchestration-profile.md +189 -0
- package/.agent/agents/personas/mihata-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/mihata-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/tesla-agent/agent.json +10 -0
- package/.agent/agents/personas/tesla-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/tesla-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/tesla-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/tesla-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/tesla-agent/tesla-fullstack-system-optimization-profile.md +189 -0
- package/.agent/agents/personas/tesla-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/tesla-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/tu-ma-y-agent/agent.json +10 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/tu-ma-y-agent/simayi-feasibility-risk-control-profile.md +189 -0
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/venti-agent/agent.json +10 -0
- package/.agent/agents/personas/venti-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/venti-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/venti-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/venti-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/venti-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/venti-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/venti-agent/venti-learning-communication-mentoring-profile.md +189 -0
- package/.agent/agents/planner.md +212 -212
- package/.agent/agents/python-reviewer.md +98 -98
- package/.agent/agents/pytorch-build-resolver.md +120 -120
- package/.agent/agents/refactor-cleaner.md +85 -85
- package/.agent/agents/rust-build-resolver.md +148 -148
- package/.agent/agents/rust-reviewer.md +94 -94
- package/.agent/agents/security-reviewer.md +108 -108
- package/.agent/agents/tdd-guide.md +91 -91
- package/.agent/agents/typescript-reviewer.md +112 -112
- package/.agent/contexts/dev.md +20 -0
- package/.agent/contexts/research.md +26 -0
- package/.agent/contexts/review.md +22 -0
- package/.agent/hooks/hooks.json +395 -0
- package/.agent/hooks/readme.md +222 -0
- package/.agent/mcp-configs/mcp-servers.json +181 -0
- package/.agent/rules/common/agents.md +50 -0
- package/.agent/rules/common/code-review.md +124 -0
- package/.agent/rules/common/coding-style.md +48 -0
- package/.agent/rules/common/development-workflow.md +44 -0
- package/.agent/rules/common/git-workflow.md +24 -0
- package/.agent/rules/common/hooks.md +30 -0
- package/.agent/rules/common/patterns.md +31 -0
- package/.agent/rules/common/performance.md +55 -0
- package/.agent/rules/common/security.md +29 -0
- package/.agent/rules/common/testing.md +29 -0
- package/.agent/rules/cpp/coding-style.md +44 -0
- package/.agent/rules/cpp/hooks.md +39 -0
- package/.agent/rules/cpp/patterns.md +51 -0
- package/.agent/rules/cpp/security.md +51 -0
- package/.agent/rules/cpp/testing.md +44 -0
- package/.agent/rules/csharp/coding-style.md +72 -0
- package/.agent/rules/csharp/hooks.md +25 -0
- package/.agent/rules/csharp/patterns.md +50 -0
- package/.agent/rules/csharp/security.md +58 -0
- package/.agent/rules/csharp/testing.md +46 -0
- package/.agent/rules/dart/coding-style.md +159 -0
- package/.agent/rules/dart/hooks.md +66 -0
- package/.agent/rules/dart/patterns.md +261 -0
- package/.agent/rules/dart/security.md +135 -0
- package/.agent/rules/dart/testing.md +215 -0
- package/.agent/rules/golang/coding-style.md +32 -0
- package/.agent/rules/golang/hooks.md +17 -0
- package/.agent/rules/golang/patterns.md +45 -0
- package/.agent/rules/golang/security.md +34 -0
- package/.agent/rules/golang/testing.md +31 -0
- package/.agent/rules/java/coding-style.md +114 -0
- package/.agent/rules/java/hooks.md +18 -0
- package/.agent/rules/java/patterns.md +146 -0
- package/.agent/rules/java/security.md +100 -0
- package/.agent/rules/java/testing.md +131 -0
- package/.agent/rules/kotlin/coding-style.md +86 -0
- package/.agent/rules/kotlin/hooks.md +17 -0
- package/.agent/rules/kotlin/patterns.md +146 -0
- package/.agent/rules/kotlin/security.md +82 -0
- package/.agent/rules/kotlin/testing.md +128 -0
- package/.agent/rules/perl/coding-style.md +46 -0
- package/.agent/rules/perl/hooks.md +22 -0
- package/.agent/rules/perl/patterns.md +76 -0
- package/.agent/rules/perl/security.md +69 -0
- package/.agent/rules/perl/testing.md +54 -0
- package/.agent/rules/php/coding-style.md +40 -0
- package/.agent/rules/php/hooks.md +24 -0
- package/.agent/rules/php/patterns.md +33 -0
- package/.agent/rules/php/security.md +37 -0
- package/.agent/rules/php/testing.md +39 -0
- package/.agent/rules/python/coding-style.md +42 -0
- package/.agent/rules/python/hooks.md +19 -0
- package/.agent/rules/python/patterns.md +39 -0
- package/.agent/rules/python/security.md +30 -0
- package/.agent/rules/python/testing.md +38 -0
- package/.agent/rules/readme.md +111 -0
- package/.agent/rules/rust/coding-style.md +151 -0
- package/.agent/rules/rust/hooks.md +16 -0
- package/.agent/rules/rust/patterns.md +168 -0
- package/.agent/rules/rust/security.md +141 -0
- package/.agent/rules/rust/testing.md +154 -0
- package/.agent/rules/swift/coding-style.md +47 -0
- package/.agent/rules/swift/hooks.md +20 -0
- package/.agent/rules/swift/patterns.md +66 -0
- package/.agent/rules/swift/security.md +33 -0
- package/.agent/rules/swift/testing.md +45 -0
- package/.agent/rules/typescript/coding-style.md +199 -0
- package/.agent/rules/typescript/hooks.md +22 -0
- package/.agent/rules/typescript/patterns.md +52 -0
- package/.agent/rules/typescript/security.md +28 -0
- package/.agent/rules/typescript/testing.md +18 -0
- package/.agent/rules/web/coding-style.md +96 -0
- package/.agent/rules/web/design-quality.md +63 -0
- package/.agent/rules/web/hooks.md +120 -0
- package/.agent/rules/web/patterns.md +79 -0
- package/.agent/rules/web/performance.md +64 -0
- package/.agent/rules/web/security.md +57 -0
- package/.agent/rules/web/testing.md +55 -0
- package/.agent/rules/zh/agents.md +50 -0
- package/.agent/rules/zh/code-review.md +124 -0
- package/.agent/rules/zh/coding-style.md +48 -0
- package/.agent/rules/zh/development-workflow.md +44 -0
- package/.agent/rules/zh/git-workflow.md +24 -0
- package/.agent/rules/zh/hooks.md +30 -0
- package/.agent/rules/zh/patterns.md +31 -0
- package/.agent/rules/zh/performance.md +55 -0
- package/.agent/rules/zh/readme.md +108 -0
- package/.agent/rules/zh/security.md +29 -0
- package/.agent/rules/zh/testing.md +29 -0
- package/.agent/skills/agent-eval/SKILL.md +145 -0
- package/.agent/skills/agent-harness-construction/SKILL.md +73 -0
- package/.agent/skills/agent-payment-x402/SKILL.md +178 -0
- package/.agent/skills/agentic-engineering/SKILL.md +63 -0
- package/.agent/skills/ai-first-engineering/SKILL.md +51 -0
- package/.agent/skills/ai-regression-testing/SKILL.md +385 -0
- package/.agent/skills/android-clean-architecture/SKILL.md +339 -0
- package/.agent/skills/api-design/SKILL.md +523 -0
- package/.agent/skills/architecture-decision-records/SKILL.md +179 -0
- package/.agent/skills/article-writing/SKILL.md +79 -0
- package/.agent/skills/autonomous-agent-harness/SKILL.md +267 -0
- package/.agent/skills/autonomous-loops/SKILL.md +610 -0
- package/.agent/skills/backend-patterns/SKILL.md +598 -0
- package/.agent/skills/benchmark/SKILL.md +93 -0
- package/.agent/skills/blueprint/SKILL.md +105 -0
- package/.agent/skills/brand-voice/SKILL.md +97 -0
- package/.agent/skills/brand-voice/references/voice-profile-schema.md +55 -0
- package/.agent/skills/browser-qa/SKILL.md +87 -0
- package/.agent/skills/bun-runtime/SKILL.md +84 -0
- package/.agent/skills/canary-watch/SKILL.md +99 -0
- package/.agent/skills/carrier-relationship-management/SKILL.md +212 -0
- package/.agent/skills/ck/SKILL.md +147 -0
- package/.agent/skills/ck/commands/forget.mjs +44 -0
- package/.agent/skills/ck/commands/info.mjs +24 -0
- package/.agent/skills/ck/commands/init.mjs +143 -0
- package/.agent/skills/ck/commands/list.mjs +40 -0
- package/.agent/skills/ck/commands/migrate.mjs +202 -0
- package/.agent/skills/ck/commands/resume.mjs +36 -0
- package/.agent/skills/ck/commands/save.mjs +210 -0
- package/.agent/skills/ck/commands/shared.mjs +387 -0
- package/.agent/skills/ck/hooks/session-start.mjs +224 -0
- package/.agent/skills/claude-api/SKILL.md +337 -0
- package/.agent/skills/claude-devfleet/SKILL.md +103 -0
- package/.agent/skills/click-path-audit/SKILL.md +244 -0
- package/.agent/skills/clickhouse-io/SKILL.md +439 -0
- package/.agent/skills/codebase-onboarding/SKILL.md +233 -0
- package/.agent/skills/coding-standards/SKILL.md +530 -0
- package/.agent/skills/compose-multiplatform-patterns/SKILL.md +299 -0
- package/.agent/skills/configure-ecc/SKILL.md +367 -0
- package/.agent/skills/connections-optimizer/SKILL.md +189 -0
- package/.agent/skills/content-engine/SKILL.md +131 -0
- package/.agent/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/.agent/skills/context-budget/SKILL.md +135 -0
- package/.agent/skills/continuous-agent-loop/SKILL.md +45 -0
- package/.agent/skills/continuous-learning/SKILL.md +119 -0
- package/.agent/skills/continuous-learning/config.json +18 -0
- package/.agent/skills/continuous-learning/evaluate-session.sh +69 -0
- package/.agent/skills/continuous-learning-v2/SKILL.md +365 -0
- package/.agent/skills/continuous-learning-v2/agents/observer-loop.sh +271 -0
- package/.agent/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/.agent/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/.agent/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
- package/.agent/skills/continuous-learning-v2/config.json +8 -0
- package/.agent/skills/continuous-learning-v2/hooks/observe.sh +428 -0
- package/.agent/skills/continuous-learning-v2/scripts/detect-project.sh +228 -0
- package/.agent/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
- package/.agent/skills/continuous-learning-v2/scripts/test-parse-instinct.py +984 -0
- package/.agent/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/.agent/skills/cpp-coding-standards/SKILL.md +723 -0
- package/.agent/skills/cpp-testing/SKILL.md +324 -0
- package/.agent/skills/crosspost/SKILL.md +111 -0
- package/.agent/skills/csharp-testing/SKILL.md +321 -0
- package/.agent/skills/customer-billing-ops/SKILL.md +140 -0
- package/.agent/skills/customs-trade-compliance/SKILL.md +263 -0
- package/.agent/skills/dart-flutter-patterns/SKILL.md +563 -0
- package/.agent/skills/data-scraper-agent/SKILL.md +764 -0
- package/.agent/skills/database-migrations/SKILL.md +429 -0
- package/.agent/skills/deep-research/SKILL.md +155 -0
- package/.agent/skills/deployment-patterns/SKILL.md +427 -0
- package/.agent/skills/design-system/SKILL.md +82 -0
- package/.agent/skills/django-patterns/SKILL.md +734 -0
- package/.agent/skills/django-security/SKILL.md +593 -0
- package/.agent/skills/django-tdd/SKILL.md +729 -0
- package/.agent/skills/django-verification/SKILL.md +469 -0
- package/.agent/skills/dmux-workflows/SKILL.md +191 -0
- package/.agent/skills/docker-patterns/SKILL.md +364 -0
- package/.agent/skills/documentation-lookup/SKILL.md +90 -0
- package/.agent/skills/dotnet-patterns/SKILL.md +321 -0
- package/.agent/skills/e2e-testing/SKILL.md +326 -0
- package/.agent/skills/energy-procurement/SKILL.md +228 -0
- package/.agent/skills/enterprise-agent-ops/SKILL.md +50 -0
- package/.agent/skills/eval-harness/SKILL.md +270 -0
- package/.agent/skills/exa-search/SKILL.md +103 -0
- package/.agent/skills/fal-ai-media/SKILL.md +284 -0
- package/.agent/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/.agent/skills/foundation-models-on-device/SKILL.md +243 -0
- package/.agent/skills/frontend-patterns/SKILL.md +642 -0
- package/.agent/skills/frontend-slides/SKILL.md +184 -0
- package/.agent/skills/frontend-slides/style-presets.md +330 -0
- package/.agent/skills/gan-style-harness/SKILL.md +278 -0
- package/.agent/skills/git-workflow/SKILL.md +715 -0
- package/.agent/skills/golang-patterns/SKILL.md +674 -0
- package/.agent/skills/golang-testing/SKILL.md +720 -0
- package/.agent/skills/google-workspace-ops/SKILL.md +95 -0
- package/.agent/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/.agent/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/.agent/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/.agent/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/.agent/skills/hexagonal-architecture/SKILL.md +276 -0
- package/.agent/skills/inventory-demand-planning/SKILL.md +247 -0
- package/.agent/skills/investor-materials/SKILL.md +96 -0
- package/.agent/skills/investor-outreach/SKILL.md +91 -0
- package/.agent/skills/iterative-retrieval/SKILL.md +211 -0
- package/.agent/skills/java-coding-standards/SKILL.md +147 -0
- package/.agent/skills/jira-integration/SKILL.md +293 -0
- package/.agent/skills/jpa-patterns/SKILL.md +151 -0
- package/.agent/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/.agent/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/.agent/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/.agent/skills/kotlin-patterns/SKILL.md +711 -0
- package/.agent/skills/kotlin-testing/SKILL.md +824 -0
- package/.agent/skills/laravel-patterns/SKILL.md +415 -0
- package/.agent/skills/laravel-plugin-discovery/SKILL.md +229 -0
- package/.agent/skills/laravel-security/SKILL.md +285 -0
- package/.agent/skills/laravel-tdd/SKILL.md +283 -0
- package/.agent/skills/laravel-verification/SKILL.md +179 -0
- package/.agent/skills/lead-intelligence/SKILL.md +321 -0
- package/.agent/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/.agent/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/.agent/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/.agent/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/.agent/skills/liquid-glass-design/SKILL.md +279 -0
- package/.agent/skills/logistics-exception-management/SKILL.md +222 -0
- package/.agent/skills/manim-video/SKILL.md +89 -0
- package/.agent/skills/manim-video/assets/network-graph-scene.py +52 -0
- package/.agent/skills/market-research/SKILL.md +75 -0
- package/.agent/skills/mcp-builder/SKILL.md +173 -113
- package/.agent/skills/mcp-builder/license.txt +202 -0
- package/.agent/skills/mcp-builder/reference/evaluation.md +602 -0
- package/.agent/skills/mcp-builder/reference/mcp-best-practices.md +249 -0
- package/.agent/skills/mcp-builder/reference/node-mcp-server.md +970 -0
- package/.agent/skills/mcp-builder/reference/python-mcp-server.md +719 -0
- package/.agent/skills/mcp-builder/scripts/connections.py +151 -0
- package/.agent/skills/mcp-builder/scripts/evaluation.py +373 -0
- package/.agent/skills/mcp-builder/scripts/example-evaluation.xml +22 -0
- package/.agent/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/.agent/skills/mcp-server-patterns/SKILL.md +67 -0
- package/.agent/skills/nanoclaw-repl/SKILL.md +33 -0
- package/.agent/skills/nestjs-patterns/SKILL.md +230 -0
- package/.agent/skills/nextjs-turbopack/SKILL.md +44 -0
- package/.agent/skills/nutrient-document-processing/SKILL.md +167 -0
- package/.agent/skills/nuxt4-patterns/SKILL.md +100 -0
- package/.agent/skills/openclaw-persona-forge/SKILL.md +296 -0
- package/.agent/skills/openclaw-persona-forge/gacha.py +224 -0
- package/.agent/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/.agent/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/.agent/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/.agent/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/.agent/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/.agent/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/.agent/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/.agent/skills/opensource-pipeline/SKILL.md +255 -0
- package/.agent/skills/perl-patterns/SKILL.md +504 -0
- package/.agent/skills/perl-security/SKILL.md +503 -0
- package/.agent/skills/perl-testing/SKILL.md +475 -0
- package/.agent/skills/plankton-code-quality/SKILL.md +236 -0
- package/.agent/skills/postgres-patterns/SKILL.md +147 -0
- package/.agent/skills/product-lens/SKILL.md +85 -0
- package/.agent/skills/production-scheduling/SKILL.md +238 -0
- package/.agent/skills/project-flow-ops/SKILL.md +111 -0
- package/.agent/skills/project-guidelines-example/SKILL.md +349 -0
- package/.agent/skills/prompt-optimizer/SKILL.md +397 -0
- package/.agent/skills/python-patterns/SKILL.md +622 -313
- package/.agent/skills/python-testing/SKILL.md +816 -0
- package/.agent/skills/pytorch-patterns/SKILL.md +396 -0
- package/.agent/skills/quality-nonconformance/SKILL.md +260 -0
- package/.agent/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
- package/.agent/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/.agent/skills/remotion-video-creation/SKILL.md +43 -0
- package/.agent/skills/remotion-video-creation/rules/3d.md +86 -0
- package/.agent/skills/remotion-video-creation/rules/animations.md +29 -0
- package/.agent/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/.agent/skills/remotion-video-creation/rules/assets.md +78 -0
- package/.agent/skills/remotion-video-creation/rules/audio.md +172 -0
- package/.agent/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/.agent/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/.agent/skills/remotion-video-creation/rules/charts.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/.agent/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/.agent/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/.agent/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/.agent/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/.agent/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/.agent/skills/remotion-video-creation/rules/images.md +130 -0
- package/.agent/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/.agent/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/.agent/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/.agent/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/.agent/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/.agent/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/.agent/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/.agent/skills/remotion-video-creation/rules/timing.md +179 -0
- package/.agent/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/.agent/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/.agent/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/.agent/skills/remotion-video-creation/rules/videos.md +171 -0
- package/.agent/skills/repo-scan/SKILL.md +78 -0
- package/.agent/skills/returns-reverse-logistics/SKILL.md +240 -0
- package/.agent/skills/rules-distill/SKILL.md +264 -0
- package/.agent/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/.agent/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/.agent/skills/rust-patterns/SKILL.md +499 -0
- package/.agent/skills/rust-testing/SKILL.md +500 -0
- package/.agent/skills/safety-guard/SKILL.md +75 -0
- package/.agent/skills/santa-method/SKILL.md +306 -0
- package/.agent/skills/search-first/SKILL.md +161 -0
- package/.agent/skills/security-review/SKILL.md +495 -0
- package/.agent/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/.agent/skills/security-scan/SKILL.md +165 -0
- package/.agent/skills/skill-comply/SKILL.md +58 -0
- package/.agent/skills/skill-comply/fixtures/compliant-trace.jsonl +5 -0
- package/.agent/skills/skill-comply/fixtures/noncompliant-trace.jsonl +3 -0
- package/.agent/skills/skill-comply/fixtures/tdd-spec.yaml +44 -0
- package/.agent/skills/skill-comply/prompts/classifier.md +24 -0
- package/.agent/skills/skill-comply/prompts/scenario-generator.md +62 -0
- package/.agent/skills/skill-comply/prompts/spec-generator.md +42 -0
- package/.agent/skills/skill-comply/pyproject.toml +15 -0
- package/.agent/skills/skill-comply/scripts/classifier.py +85 -0
- package/.agent/skills/skill-comply/scripts/grader.py +122 -0
- package/.agent/skills/skill-comply/scripts/init.py +0 -0
- package/.agent/skills/skill-comply/scripts/parser.py +107 -0
- package/.agent/skills/skill-comply/scripts/report.py +170 -0
- package/.agent/skills/skill-comply/scripts/run.py +127 -0
- package/.agent/skills/skill-comply/scripts/runner.py +161 -0
- package/.agent/skills/skill-comply/scripts/scenario-generator.py +70 -0
- package/.agent/skills/skill-comply/scripts/spec-generator.py +72 -0
- package/.agent/skills/skill-comply/scripts/utils.py +13 -0
- package/.agent/skills/skill-comply/tests/test-grader.py +137 -0
- package/.agent/skills/skill-comply/tests/test-parser.py +90 -0
- package/.agent/skills/skill-creator/SKILL.md +485 -0
- package/.agent/skills/skill-creator/agents/analyzer.md +274 -0
- package/.agent/skills/skill-creator/agents/comparator.md +202 -0
- package/.agent/skills/skill-creator/agents/grader.md +223 -0
- package/.agent/skills/skill-creator/assets/eval-review.html +146 -0
- package/.agent/skills/skill-creator/eval-viewer/generate-review.py +471 -0
- package/.agent/skills/skill-creator/eval-viewer/viewer.html +1325 -0
- package/.agent/skills/skill-creator/license.txt +202 -0
- package/.agent/skills/skill-creator/references/schemas.md +430 -0
- package/.agent/skills/skill-creator/scripts/aggregate-benchmark.py +401 -0
- package/.agent/skills/skill-creator/scripts/generate-report.py +326 -0
- package/.agent/skills/skill-creator/scripts/improve-description.py +247 -0
- package/.agent/skills/skill-creator/scripts/init.py +0 -0
- package/.agent/skills/skill-creator/scripts/package-skill.py +136 -0
- package/.agent/skills/skill-creator/scripts/quick-validate.py +103 -0
- package/.agent/skills/skill-creator/scripts/run-eval.py +310 -0
- package/.agent/skills/skill-creator/scripts/run-loop.py +328 -0
- package/.agent/skills/skill-creator/scripts/utils.py +47 -0
- package/.agent/skills/skill-stocktake/SKILL.md +193 -0
- package/.agent/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/.agent/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/.agent/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/.agent/skills/social-graph-ranker/SKILL.md +154 -0
- package/.agent/skills/springboot-patterns/SKILL.md +314 -0
- package/.agent/skills/springboot-security/SKILL.md +272 -0
- package/.agent/skills/springboot-tdd/SKILL.md +158 -0
- package/.agent/skills/springboot-verification/SKILL.md +231 -0
- package/.agent/skills/strategic-compact/SKILL.md +131 -0
- package/.agent/skills/strategic-compact/suggest-compact.sh +54 -0
- package/.agent/skills/swift-actor-persistence/SKILL.md +143 -0
- package/.agent/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/.agent/skills/swift-protocol-di-testing/SKILL.md +190 -0
- package/.agent/skills/swiftui-patterns/SKILL.md +259 -0
- package/.agent/skills/tdd-workflow/SKILL.md +412 -98
- package/.agent/skills/team-builder/SKILL.md +168 -0
- package/.agent/skills/token-budget-advisor/SKILL.md +133 -0
- package/.agent/skills/ui-demo/SKILL.md +465 -0
- package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -26
- package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -97
- package/.agent/skills/ui-ux-pro-max/data/landing.csv +28 -28
- package/.agent/skills/ui-ux-pro-max/data/products.csv +96 -96
- package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
- package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
- package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
- package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
- package/.agent/skills/ui-ux-pro-max/data/styles.csv +68 -68
- package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
- package/.agent/skills/ui-ux-pro-max/scripts/search.py +114 -114
- package/.agent/skills/verification-loop/SKILL.md +126 -0
- package/.agent/skills/video-editing/SKILL.md +310 -0
- package/.agent/skills/videodb/SKILL.md +374 -0
- package/.agent/skills/videodb/reference/api-reference.md +550 -0
- package/.agent/skills/videodb/reference/capture-reference.md +407 -0
- package/.agent/skills/videodb/reference/capture.md +101 -0
- package/.agent/skills/videodb/reference/editor.md +443 -0
- package/.agent/skills/videodb/reference/generative.md +331 -0
- package/.agent/skills/videodb/reference/rtstream-reference.md +564 -0
- package/.agent/skills/videodb/reference/rtstream.md +65 -0
- package/.agent/skills/videodb/reference/search.md +230 -0
- package/.agent/skills/videodb/reference/streaming.md +406 -0
- package/.agent/skills/videodb/reference/use-cases.md +118 -0
- package/.agent/skills/videodb/scripts/ws-listener.py +282 -0
- package/.agent/skills/visa-doc-translate/SKILL.md +117 -0
- package/.agent/skills/visa-doc-translate/readme.md +86 -0
- package/.agent/skills/workspace-surface-audit/SKILL.md +125 -0
- package/.agent/skills/x-api/SKILL.md +230 -0
- package/.agent/tasks/two-track-merge-contract.md +29 -0
- package/.agent/workflows/aside.md +164 -164
- package/.agent/workflows/build-fix.md +62 -62
- package/.agent/workflows/checkpoint.md +74 -74
- package/.agent/workflows/claw.md +23 -51
- package/.agent/workflows/clean-memory.md +34 -0
- package/.agent/workflows/code-review.md +289 -40
- package/.agent/workflows/context-budget.md +23 -29
- package/.agent/workflows/cpp-build.md +173 -173
- package/.agent/workflows/cpp-review.md +132 -132
- package/.agent/workflows/cpp-test.md +251 -251
- package/.agent/workflows/devfleet.md +23 -92
- package/.agent/workflows/docs.md +23 -31
- package/.agent/workflows/e2e.md +268 -365
- package/.agent/workflows/eval.md +23 -120
- package/.agent/workflows/evolve.md +178 -178
- package/.agent/workflows/flutter-build.md +164 -0
- package/.agent/workflows/flutter-review.md +116 -0
- package/.agent/workflows/flutter-test.md +144 -0
- package/.agent/workflows/gan-build.md +99 -0
- package/.agent/workflows/gan-design.md +35 -0
- package/.agent/workflows/go-build.md +183 -183
- package/.agent/workflows/go-review.md +148 -148
- package/.agent/workflows/go-test.md +268 -268
- package/.agent/workflows/gradle-build.md +70 -70
- package/.agent/workflows/harness-audit.md +73 -71
- package/.agent/workflows/instinct-export.md +66 -66
- package/.agent/workflows/instinct-import.md +114 -114
- package/.agent/workflows/instinct-status.md +59 -59
- package/.agent/workflows/jira.md +106 -0
- package/.agent/workflows/kotlin-build.md +174 -174
- package/.agent/workflows/kotlin-review.md +140 -140
- package/.agent/workflows/kotlin-test.md +312 -312
- package/.agent/workflows/learn-eval.md +116 -116
- package/.agent/workflows/learn.md +70 -70
- package/.agent/workflows/loop-start.md +32 -32
- package/.agent/workflows/loop-status.md +24 -24
- package/.agent/workflows/model-route.md +26 -26
- package/.agent/workflows/multi-backend.md +158 -158
- package/.agent/workflows/multi-execute.md +315 -315
- package/.agent/workflows/multi-frontend.md +158 -158
- package/.agent/workflows/multi-plan.md +268 -268
- package/.agent/workflows/multi-workflow.md +191 -191
- package/.agent/workflows/orchestrate.md +135 -231
- package/.agent/workflows/plan.md +117 -115
- package/.agent/workflows/pm2.md +272 -272
- package/.agent/workflows/projects.md +39 -39
- package/.agent/workflows/promote.md +41 -41
- package/.agent/workflows/prompt-optimize.md +23 -38
- package/.agent/workflows/prp-commit.md +112 -0
- package/.agent/workflows/prp-implement.md +385 -0
- package/.agent/workflows/prp-plan.md +502 -0
- package/.agent/workflows/prp-pr.md +184 -0
- package/.agent/workflows/prp-prd.md +447 -0
- package/.agent/workflows/prune.md +31 -31
- package/.agent/workflows/python-review.md +297 -297
- package/.agent/workflows/quality-gate.md +29 -29
- package/.agent/workflows/refactor-clean.md +80 -80
- package/.agent/workflows/resume-session.md +156 -156
- package/.agent/workflows/rules-distill.md +20 -11
- package/.agent/workflows/rust-build.md +187 -187
- package/.agent/workflows/rust-review.md +142 -142
- package/.agent/workflows/rust-test.md +308 -308
- package/.agent/workflows/santa-loop.md +175 -0
- package/.agent/workflows/save-session.md +275 -275
- package/.agent/workflows/sessions.md +333 -333
- package/.agent/workflows/setup-pm.md +80 -80
- package/.agent/workflows/skill-create.md +174 -174
- package/.agent/workflows/skill-health.md +54 -54
- package/.agent/workflows/tdd.md +231 -328
- package/.agent/workflows/test-coverage.md +69 -69
- package/.agent/workflows/update-codemaps.md +72 -72
- package/.agent/workflows/update-docs.md +84 -84
- package/.agent/workflows/verify.md +23 -59
- package/LICENSE +176 -176
- package/README.md +28 -20
- package/RELEASE.md +32 -36
- package/package.json +87 -79
- package/scripts/release-check.js +55 -55
- package/src/bin/cli.js +399 -53
- package/src/lib/installer.js +360 -114
- package/src/lib/manifests/stacks.js +122 -0
- package/src/lib/slash-commands.js +28 -0
- package/src/templates/claude/CLAUDE.en.md +42 -0
- package/src/templates/claude/CLAUDE.md +42 -0
- package/src/templates/claude/CLAUDE.vi.md +42 -0
- package/src/templates/codex/AGENTS.en.md +40 -0
- package/src/templates/codex/AGENTS.md +40 -0
- package/src/templates/codex/AGENTS.vi.md +40 -0
- package/src/templates/cursor/pilo-masterkit.mdc +20 -0
- package/src/templates/gemini/GEMINI.en.md +56 -0
- package/src/templates/gemini/GEMINI.md +56 -0
- package/src/templates/gemini/GEMINI.vi.md +56 -0
- package/src/templates/github/copilot-instructions.md +16 -0
|
@@ -0,0 +1,337 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: claude-api
|
|
3
|
+
description: Anthropic Claude API patterns for Python and TypeScript. Covers Messages API, streaming, tool use, vision, extended thinking, batches, prompt caching, and Claude Agent SDK. Use when building applications with the Claude API or Anthropic SDKs.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Claude API
|
|
8
|
+
|
|
9
|
+
Build applications with the Anthropic Claude API and SDKs.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- Building applications that call the Claude API
|
|
14
|
+
- Code imports `anthropic` (Python) or `@anthropic-ai/sdk` (TypeScript)
|
|
15
|
+
- User asks about Claude API patterns, tool use, streaming, or vision
|
|
16
|
+
- Implementing agent workflows with Claude Agent SDK
|
|
17
|
+
- Optimizing API costs, token usage, or latency
|
|
18
|
+
|
|
19
|
+
## Model Selection
|
|
20
|
+
|
|
21
|
+
| Model | ID | Best For |
|
|
22
|
+
|-------|-----|----------|
|
|
23
|
+
| Opus 4.1 | `claude-opus-4-1` | Complex reasoning, architecture, research |
|
|
24
|
+
| Sonnet 4 | `claude-sonnet-4-0` | Balanced coding, most development tasks |
|
|
25
|
+
| Haiku 3.5 | `claude-3-5-haiku-latest` | Fast responses, high-volume, cost-sensitive |
|
|
26
|
+
|
|
27
|
+
Default to Sonnet 4 unless the task requires deep reasoning (Opus) or speed/cost optimization (Haiku). For production, prefer pinned snapshot IDs over aliases.
|
|
28
|
+
|
|
29
|
+
## Python SDK
|
|
30
|
+
|
|
31
|
+
### Installation
|
|
32
|
+
|
|
33
|
+
```bash
|
|
34
|
+
pip install anthropic
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
### Basic Message
|
|
38
|
+
|
|
39
|
+
```python
|
|
40
|
+
import anthropic
|
|
41
|
+
|
|
42
|
+
client = anthropic.Anthropic() # reads ANTHROPIC_API_KEY from env
|
|
43
|
+
|
|
44
|
+
message = client.messages.create(
|
|
45
|
+
model="claude-sonnet-4-0",
|
|
46
|
+
max_tokens=1024,
|
|
47
|
+
messages=[
|
|
48
|
+
{"role": "user", "content": "Explain async/await in Python"}
|
|
49
|
+
]
|
|
50
|
+
)
|
|
51
|
+
print(message.content[0].text)
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
### Streaming
|
|
55
|
+
|
|
56
|
+
```python
|
|
57
|
+
with client.messages.stream(
|
|
58
|
+
model="claude-sonnet-4-0",
|
|
59
|
+
max_tokens=1024,
|
|
60
|
+
messages=[{"role": "user", "content": "Write a haiku about coding"}]
|
|
61
|
+
) as stream:
|
|
62
|
+
for text in stream.text_stream:
|
|
63
|
+
print(text, end="", flush=True)
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
### System Prompt
|
|
67
|
+
|
|
68
|
+
```python
|
|
69
|
+
message = client.messages.create(
|
|
70
|
+
model="claude-sonnet-4-0",
|
|
71
|
+
max_tokens=1024,
|
|
72
|
+
system="You are a senior Python developer. Be concise.",
|
|
73
|
+
messages=[{"role": "user", "content": "Review this function"}]
|
|
74
|
+
)
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
## TypeScript SDK
|
|
78
|
+
|
|
79
|
+
### Installation
|
|
80
|
+
|
|
81
|
+
```bash
|
|
82
|
+
npm install @anthropic-ai/sdk
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
### Basic Message
|
|
86
|
+
|
|
87
|
+
```typescript
|
|
88
|
+
import Anthropic from "@anthropic-ai/sdk";
|
|
89
|
+
|
|
90
|
+
const client = new Anthropic(); // reads ANTHROPIC_API_KEY from env
|
|
91
|
+
|
|
92
|
+
const message = await client.messages.create({
|
|
93
|
+
model: "claude-sonnet-4-0",
|
|
94
|
+
max_tokens: 1024,
|
|
95
|
+
messages: [
|
|
96
|
+
{ role: "user", content: "Explain async/await in TypeScript" }
|
|
97
|
+
],
|
|
98
|
+
});
|
|
99
|
+
console.log(message.content[0].text);
|
|
100
|
+
```
|
|
101
|
+
|
|
102
|
+
### Streaming
|
|
103
|
+
|
|
104
|
+
```typescript
|
|
105
|
+
const stream = client.messages.stream({
|
|
106
|
+
model: "claude-sonnet-4-0",
|
|
107
|
+
max_tokens: 1024,
|
|
108
|
+
messages: [{ role: "user", content: "Write a haiku" }],
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
for await (const event of stream) {
|
|
112
|
+
if (event.type === "content_block_delta" && event.delta.type === "text_delta") {
|
|
113
|
+
process.stdout.write(event.delta.text);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
```
|
|
117
|
+
|
|
118
|
+
## Tool Use
|
|
119
|
+
|
|
120
|
+
Define tools and let Claude call them:
|
|
121
|
+
|
|
122
|
+
```python
|
|
123
|
+
tools = [
|
|
124
|
+
{
|
|
125
|
+
"name": "get_weather",
|
|
126
|
+
"description": "Get current weather for a location",
|
|
127
|
+
"input_schema": {
|
|
128
|
+
"type": "object",
|
|
129
|
+
"properties": {
|
|
130
|
+
"location": {"type": "string", "description": "City name"},
|
|
131
|
+
"unit": {"type": "string", "enum": ["celsius", "fahrenheit"]}
|
|
132
|
+
},
|
|
133
|
+
"required": ["location"]
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
]
|
|
137
|
+
|
|
138
|
+
message = client.messages.create(
|
|
139
|
+
model="claude-sonnet-4-0",
|
|
140
|
+
max_tokens=1024,
|
|
141
|
+
tools=tools,
|
|
142
|
+
messages=[{"role": "user", "content": "What's the weather in SF?"}]
|
|
143
|
+
)
|
|
144
|
+
|
|
145
|
+
# Handle tool use response
|
|
146
|
+
for block in message.content:
|
|
147
|
+
if block.type == "tool_use":
|
|
148
|
+
# Execute the tool with block.input
|
|
149
|
+
result = get_weather(**block.input)
|
|
150
|
+
# Send result back
|
|
151
|
+
follow_up = client.messages.create(
|
|
152
|
+
model="claude-sonnet-4-0",
|
|
153
|
+
max_tokens=1024,
|
|
154
|
+
tools=tools,
|
|
155
|
+
messages=[
|
|
156
|
+
{"role": "user", "content": "What's the weather in SF?"},
|
|
157
|
+
{"role": "assistant", "content": message.content},
|
|
158
|
+
{"role": "user", "content": [
|
|
159
|
+
{"type": "tool_result", "tool_use_id": block.id, "content": str(result)}
|
|
160
|
+
]}
|
|
161
|
+
]
|
|
162
|
+
)
|
|
163
|
+
```
|
|
164
|
+
|
|
165
|
+
## Vision
|
|
166
|
+
|
|
167
|
+
Send images for analysis:
|
|
168
|
+
|
|
169
|
+
```python
|
|
170
|
+
import base64
|
|
171
|
+
|
|
172
|
+
with open("diagram.png", "rb") as f:
|
|
173
|
+
image_data = base64.standard_b64encode(f.read()).decode("utf-8")
|
|
174
|
+
|
|
175
|
+
message = client.messages.create(
|
|
176
|
+
model="claude-sonnet-4-0",
|
|
177
|
+
max_tokens=1024,
|
|
178
|
+
messages=[{
|
|
179
|
+
"role": "user",
|
|
180
|
+
"content": [
|
|
181
|
+
{"type": "image", "source": {"type": "base64", "media_type": "image/png", "data": image_data}},
|
|
182
|
+
{"type": "text", "text": "Describe this diagram"}
|
|
183
|
+
]
|
|
184
|
+
}]
|
|
185
|
+
)
|
|
186
|
+
```
|
|
187
|
+
|
|
188
|
+
## Extended Thinking
|
|
189
|
+
|
|
190
|
+
For complex reasoning tasks:
|
|
191
|
+
|
|
192
|
+
```python
|
|
193
|
+
message = client.messages.create(
|
|
194
|
+
model="claude-sonnet-4-0",
|
|
195
|
+
max_tokens=16000,
|
|
196
|
+
thinking={
|
|
197
|
+
"type": "enabled",
|
|
198
|
+
"budget_tokens": 10000
|
|
199
|
+
},
|
|
200
|
+
messages=[{"role": "user", "content": "Solve this math problem step by step..."}]
|
|
201
|
+
)
|
|
202
|
+
|
|
203
|
+
for block in message.content:
|
|
204
|
+
if block.type == "thinking":
|
|
205
|
+
print(f"Thinking: {block.thinking}")
|
|
206
|
+
elif block.type == "text":
|
|
207
|
+
print(f"Answer: {block.text}")
|
|
208
|
+
```
|
|
209
|
+
|
|
210
|
+
## Prompt Caching
|
|
211
|
+
|
|
212
|
+
Cache large system prompts or context to reduce costs:
|
|
213
|
+
|
|
214
|
+
```python
|
|
215
|
+
message = client.messages.create(
|
|
216
|
+
model="claude-sonnet-4-0",
|
|
217
|
+
max_tokens=1024,
|
|
218
|
+
system=[
|
|
219
|
+
{"type": "text", "text": large_system_prompt, "cache_control": {"type": "ephemeral"}}
|
|
220
|
+
],
|
|
221
|
+
messages=[{"role": "user", "content": "Question about the cached context"}]
|
|
222
|
+
)
|
|
223
|
+
# Check cache usage
|
|
224
|
+
print(f"Cache read: {message.usage.cache_read_input_tokens}")
|
|
225
|
+
print(f"Cache creation: {message.usage.cache_creation_input_tokens}")
|
|
226
|
+
```
|
|
227
|
+
|
|
228
|
+
## Batches API
|
|
229
|
+
|
|
230
|
+
Process large volumes asynchronously at 50% cost reduction:
|
|
231
|
+
|
|
232
|
+
```python
|
|
233
|
+
import time
|
|
234
|
+
|
|
235
|
+
batch = client.messages.batches.create(
|
|
236
|
+
requests=[
|
|
237
|
+
{
|
|
238
|
+
"custom_id": f"request-{i}",
|
|
239
|
+
"params": {
|
|
240
|
+
"model": "claude-sonnet-4-0",
|
|
241
|
+
"max_tokens": 1024,
|
|
242
|
+
"messages": [{"role": "user", "content": prompt}]
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
for i, prompt in enumerate(prompts)
|
|
246
|
+
]
|
|
247
|
+
)
|
|
248
|
+
|
|
249
|
+
# Poll for completion
|
|
250
|
+
while True:
|
|
251
|
+
status = client.messages.batches.retrieve(batch.id)
|
|
252
|
+
if status.processing_status == "ended":
|
|
253
|
+
break
|
|
254
|
+
time.sleep(30)
|
|
255
|
+
|
|
256
|
+
# Get results
|
|
257
|
+
for result in client.messages.batches.results(batch.id):
|
|
258
|
+
print(result.result.message.content[0].text)
|
|
259
|
+
```
|
|
260
|
+
|
|
261
|
+
## Claude Agent SDK
|
|
262
|
+
|
|
263
|
+
Build multi-step agents:
|
|
264
|
+
|
|
265
|
+
```python
|
|
266
|
+
# Note: Agent SDK API surface may change — check official docs
|
|
267
|
+
import anthropic
|
|
268
|
+
|
|
269
|
+
# Define tools as functions
|
|
270
|
+
tools = [{
|
|
271
|
+
"name": "search_codebase",
|
|
272
|
+
"description": "Search the codebase for relevant code",
|
|
273
|
+
"input_schema": {
|
|
274
|
+
"type": "object",
|
|
275
|
+
"properties": {"query": {"type": "string"}},
|
|
276
|
+
"required": ["query"]
|
|
277
|
+
}
|
|
278
|
+
}]
|
|
279
|
+
|
|
280
|
+
# Run an agentic loop with tool use
|
|
281
|
+
client = anthropic.Anthropic()
|
|
282
|
+
messages = [{"role": "user", "content": "Review the auth module for security issues"}]
|
|
283
|
+
|
|
284
|
+
while True:
|
|
285
|
+
response = client.messages.create(
|
|
286
|
+
model="claude-sonnet-4-0",
|
|
287
|
+
max_tokens=4096,
|
|
288
|
+
tools=tools,
|
|
289
|
+
messages=messages,
|
|
290
|
+
)
|
|
291
|
+
if response.stop_reason == "end_turn":
|
|
292
|
+
break
|
|
293
|
+
# Handle tool calls and continue the loop
|
|
294
|
+
messages.append({"role": "assistant", "content": response.content})
|
|
295
|
+
# ... execute tools and append tool_result messages
|
|
296
|
+
```
|
|
297
|
+
|
|
298
|
+
## Cost Optimization
|
|
299
|
+
|
|
300
|
+
| Strategy | Savings | When to Use |
|
|
301
|
+
|----------|---------|-------------|
|
|
302
|
+
| Prompt caching | Up to 90% on cached tokens | Repeated system prompts or context |
|
|
303
|
+
| Batches API | 50% | Non-time-sensitive bulk processing |
|
|
304
|
+
| Haiku instead of Sonnet | ~75% | Simple tasks, classification, extraction |
|
|
305
|
+
| Shorter max_tokens | Variable | When you know output will be short |
|
|
306
|
+
| Streaming | None (same cost) | Better UX, same price |
|
|
307
|
+
|
|
308
|
+
## Error Handling
|
|
309
|
+
|
|
310
|
+
```python
|
|
311
|
+
import time
|
|
312
|
+
|
|
313
|
+
from anthropic import APIError, RateLimitError, APIConnectionError
|
|
314
|
+
|
|
315
|
+
try:
|
|
316
|
+
message = client.messages.create(...)
|
|
317
|
+
except RateLimitError:
|
|
318
|
+
# Back off and retry
|
|
319
|
+
time.sleep(60)
|
|
320
|
+
except APIConnectionError:
|
|
321
|
+
# Network issue, retry with backoff
|
|
322
|
+
pass
|
|
323
|
+
except APIError as e:
|
|
324
|
+
print(f"API error {e.status_code}: {e.message}")
|
|
325
|
+
```
|
|
326
|
+
|
|
327
|
+
## Environment Setup
|
|
328
|
+
|
|
329
|
+
```bash
|
|
330
|
+
# Required
|
|
331
|
+
export ANTHROPIC_API_KEY="your-api-key-here"
|
|
332
|
+
|
|
333
|
+
# Optional: set default model
|
|
334
|
+
export ANTHROPIC_MODEL="claude-sonnet-4-0"
|
|
335
|
+
```
|
|
336
|
+
|
|
337
|
+
Never hardcode API keys. Always use environment variables.
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: claude-devfleet
|
|
3
|
+
description: Orchestrate multi-agent coding tasks via Claude DevFleet — plan projects, dispatch parallel agents in isolated worktrees, monitor progress, and read structured reports.
|
|
4
|
+
origin: community
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Claude DevFleet Multi-Agent Orchestration
|
|
8
|
+
|
|
9
|
+
## When to Use
|
|
10
|
+
|
|
11
|
+
Use this skill when you need to dispatch multiple Claude Code agents to work on coding tasks in parallel. Each agent runs in an isolated git worktree with full tooling.
|
|
12
|
+
|
|
13
|
+
Requires a running Claude DevFleet instance connected via MCP:
|
|
14
|
+
```bash
|
|
15
|
+
claude mcp add devfleet --transport http http://localhost:18801/mcp
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
## How It Works
|
|
19
|
+
|
|
20
|
+
```
|
|
21
|
+
User → "Build a REST API with auth and tests"
|
|
22
|
+
↓
|
|
23
|
+
plan_project(prompt) → project_id + mission DAG
|
|
24
|
+
↓
|
|
25
|
+
Show plan to user → get approval
|
|
26
|
+
↓
|
|
27
|
+
dispatch_mission(M1) → Agent 1 spawns in worktree
|
|
28
|
+
↓
|
|
29
|
+
M1 completes → auto-merge → auto-dispatch M2 (depends_on M1)
|
|
30
|
+
↓
|
|
31
|
+
M2 completes → auto-merge
|
|
32
|
+
↓
|
|
33
|
+
get_report(M2) → files_changed, what_done, errors, next_steps
|
|
34
|
+
↓
|
|
35
|
+
Report back to user
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
### Tools
|
|
39
|
+
|
|
40
|
+
| Tool | Purpose |
|
|
41
|
+
|------|---------|
|
|
42
|
+
| `plan_project(prompt)` | AI breaks a description into a project with chained missions |
|
|
43
|
+
| `create_project(name, path?, description?)` | Create a project manually, returns `project_id` |
|
|
44
|
+
| `create_mission(project_id, title, prompt, depends_on?, auto_dispatch?)` | Add a mission. `depends_on` is a list of mission ID strings (e.g., `["abc-123"]`). Set `auto_dispatch=true` to auto-start when deps are met. |
|
|
45
|
+
| `dispatch_mission(mission_id, model?, max_turns?)` | Start an agent on a mission |
|
|
46
|
+
| `cancel_mission(mission_id)` | Stop a running agent |
|
|
47
|
+
| `wait_for_mission(mission_id, timeout_seconds?)` | Block until a mission completes (see note below) |
|
|
48
|
+
| `get_mission_status(mission_id)` | Check mission progress without blocking |
|
|
49
|
+
| `get_report(mission_id)` | Read structured report (files changed, tested, errors, next steps) |
|
|
50
|
+
| `get_dashboard()` | System overview: running agents, stats, recent activity |
|
|
51
|
+
| `list_projects()` | Browse all projects |
|
|
52
|
+
| `list_missions(project_id, status?)` | List missions in a project |
|
|
53
|
+
|
|
54
|
+
> **Note on `wait_for_mission`:** This blocks the conversation for up to `timeout_seconds` (default 600). For long-running missions, prefer polling with `get_mission_status` every 30–60 seconds instead, so the user sees progress updates.
|
|
55
|
+
|
|
56
|
+
### Workflow: Plan → Dispatch → Monitor → Report
|
|
57
|
+
|
|
58
|
+
1. **Plan**: Call `plan_project(prompt="...")` → returns `project_id` + list of missions with `depends_on` chains and `auto_dispatch=true`.
|
|
59
|
+
2. **Show plan**: Present mission titles, types, and dependency chain to the user.
|
|
60
|
+
3. **Dispatch**: Call `dispatch_mission(mission_id=<first_mission_id>)` on the root mission (empty `depends_on`). Remaining missions auto-dispatch as their dependencies complete (because `plan_project` sets `auto_dispatch=true` on them).
|
|
61
|
+
4. **Monitor**: Call `get_mission_status(mission_id=...)` or `get_dashboard()` to check progress.
|
|
62
|
+
5. **Report**: Call `get_report(mission_id=...)` when missions complete. Share highlights with the user.
|
|
63
|
+
|
|
64
|
+
### Concurrency
|
|
65
|
+
|
|
66
|
+
DevFleet runs up to 3 concurrent agents by default (configurable via `DEVFLEET_MAX_AGENTS`). When all slots are full, missions with `auto_dispatch=true` queue in the mission watcher and dispatch automatically as slots free up. Check `get_dashboard()` for current slot usage.
|
|
67
|
+
|
|
68
|
+
## Examples
|
|
69
|
+
|
|
70
|
+
### Full auto: plan and launch
|
|
71
|
+
|
|
72
|
+
1. `plan_project(prompt="...")` → shows plan with missions and dependencies.
|
|
73
|
+
2. Dispatch the first mission (the one with empty `depends_on`).
|
|
74
|
+
3. Remaining missions auto-dispatch as dependencies resolve (they have `auto_dispatch=true`).
|
|
75
|
+
4. Report back with project ID and mission count so the user knows what was launched.
|
|
76
|
+
5. Poll with `get_mission_status` or `get_dashboard()` periodically until all missions reach a terminal state (`completed`, `failed`, or `cancelled`).
|
|
77
|
+
6. `get_report(mission_id=...)` for each terminal mission — summarize successes and call out failures with errors and next steps.
|
|
78
|
+
|
|
79
|
+
### Manual: step-by-step control
|
|
80
|
+
|
|
81
|
+
1. `create_project(name="My Project")` → returns `project_id`.
|
|
82
|
+
2. `create_mission(project_id=project_id, title="...", prompt="...", auto_dispatch=true)` for the first (root) mission → capture `root_mission_id`.
|
|
83
|
+
`create_mission(project_id=project_id, title="...", prompt="...", auto_dispatch=true, depends_on=["<root_mission_id>"])` for each subsequent task.
|
|
84
|
+
3. `dispatch_mission(mission_id=...)` on the first mission to start the chain.
|
|
85
|
+
4. `get_report(mission_id=...)` when done.
|
|
86
|
+
|
|
87
|
+
### Sequential with review
|
|
88
|
+
|
|
89
|
+
1. `create_project(name="...")` → get `project_id`.
|
|
90
|
+
2. `create_mission(project_id=project_id, title="Implement feature", prompt="...")` → get `impl_mission_id`.
|
|
91
|
+
3. `dispatch_mission(mission_id=impl_mission_id)`, then poll with `get_mission_status` until complete.
|
|
92
|
+
4. `get_report(mission_id=impl_mission_id)` to review results.
|
|
93
|
+
5. `create_mission(project_id=project_id, title="Review", prompt="...", depends_on=[impl_mission_id], auto_dispatch=true)` — auto-starts since the dependency is already met.
|
|
94
|
+
|
|
95
|
+
## Guidelines
|
|
96
|
+
|
|
97
|
+
- Always confirm the plan with the user before dispatching, unless they said to go ahead.
|
|
98
|
+
- Include mission titles and IDs when reporting status.
|
|
99
|
+
- If a mission fails, read its report before retrying.
|
|
100
|
+
- Check `get_dashboard()` for agent slot availability before bulk dispatching.
|
|
101
|
+
- Mission dependencies form a DAG — do not create circular dependencies.
|
|
102
|
+
- Each agent runs in an isolated git worktree and auto-merges on completion. If a merge conflict occurs, the changes remain on the agent's worktree branch for manual resolution.
|
|
103
|
+
- When manually creating missions, always set `auto_dispatch=true` if you want them to trigger automatically when dependencies complete. Without this flag, missions stay in `draft` status.
|
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: click-path-audit
|
|
3
|
+
description: "Trace every user-facing button/touchpoint through its full state change sequence to find bugs where functions individually work but cancel each other out, produce wrong final state, or leave the UI in an inconsistent state. Use when: systematic debugging found no bugs but users report broken buttons, or after any major refactor touching shared state stores."
|
|
4
|
+
origin: community
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# /click-path-audit — Behavioural Flow Audit
|
|
8
|
+
|
|
9
|
+
Find bugs that static code reading misses: state interaction side effects, race conditions between sequential calls, and handlers that silently undo each other.
|
|
10
|
+
|
|
11
|
+
## The Problem This Solves
|
|
12
|
+
|
|
13
|
+
Traditional debugging checks:
|
|
14
|
+
- Does the function exist? (missing wiring)
|
|
15
|
+
- Does it crash? (runtime errors)
|
|
16
|
+
- Does it return the right type? (data flow)
|
|
17
|
+
|
|
18
|
+
But it does NOT check:
|
|
19
|
+
- **Does the final UI state match what the button label promises?**
|
|
20
|
+
- **Does function B silently undo what function A just did?**
|
|
21
|
+
- **Does shared state (Zustand/Redux/context) have side effects that cancel the intended action?**
|
|
22
|
+
|
|
23
|
+
Real example: A "New Email" button called `setComposeMode(true)` then `selectThread(null)`. Both worked individually. But `selectThread` had a side effect resetting `composeMode: false`. The button did nothing. 54 bugs were found by systematic debugging — this one was missed.
|
|
24
|
+
|
|
25
|
+
---
|
|
26
|
+
|
|
27
|
+
## How It Works
|
|
28
|
+
|
|
29
|
+
For EVERY interactive touchpoint in the target area:
|
|
30
|
+
|
|
31
|
+
```
|
|
32
|
+
1. IDENTIFY the handler (onClick, onSubmit, onChange, etc.)
|
|
33
|
+
2. TRACE every function call in the handler, IN ORDER
|
|
34
|
+
3. For EACH function call:
|
|
35
|
+
a. What state does it READ?
|
|
36
|
+
b. What state does it WRITE?
|
|
37
|
+
c. Does it have SIDE EFFECTS on shared state?
|
|
38
|
+
d. Does it reset/clear any state as a side effect?
|
|
39
|
+
4. CHECK: Does any later call UNDO a state change from an earlier call?
|
|
40
|
+
5. CHECK: Is the FINAL state what the user expects from the button label?
|
|
41
|
+
6. CHECK: Are there race conditions (async calls that resolve in wrong order)?
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
---
|
|
45
|
+
|
|
46
|
+
## Execution Steps
|
|
47
|
+
|
|
48
|
+
### Step 1: Map State Stores
|
|
49
|
+
|
|
50
|
+
Before auditing any touchpoint, build a side-effect map of every state store action:
|
|
51
|
+
|
|
52
|
+
```
|
|
53
|
+
For each Zustand store / React context in scope:
|
|
54
|
+
For each action/setter:
|
|
55
|
+
- What fields does it set?
|
|
56
|
+
- Does it RESET other fields as a side effect?
|
|
57
|
+
- Document: actionName → {sets: [...], resets: [...]}
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
This is the critical reference. The "New Email" bug was invisible without knowing that `selectThread` resets `composeMode`.
|
|
61
|
+
|
|
62
|
+
**Output format:**
|
|
63
|
+
```
|
|
64
|
+
STORE: emailStore
|
|
65
|
+
setComposeMode(bool) → sets: {composeMode}
|
|
66
|
+
selectThread(thread|null) → sets: {selectedThread, selectedThreadId, messages, drafts, selectedDraft, summary} RESETS: {composeMode: false, composeData: null, redraftOpen: false}
|
|
67
|
+
setDraftGenerating(bool) → sets: {draftGenerating}
|
|
68
|
+
...
|
|
69
|
+
|
|
70
|
+
DANGEROUS RESETS (actions that clear state they don't own):
|
|
71
|
+
selectThread → resets composeMode (owned by setComposeMode)
|
|
72
|
+
reset → resets everything
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
### Step 2: Audit Each Touchpoint
|
|
76
|
+
|
|
77
|
+
For each button/toggle/form submit in the target area:
|
|
78
|
+
|
|
79
|
+
```
|
|
80
|
+
TOUCHPOINT: [Button label] in [Component:line]
|
|
81
|
+
HANDLER: onClick → {
|
|
82
|
+
call 1: functionA() → sets {X: true}
|
|
83
|
+
call 2: functionB() → sets {Y: null} RESETS {X: false} ← CONFLICT
|
|
84
|
+
}
|
|
85
|
+
EXPECTED: User sees [description of what button label promises]
|
|
86
|
+
ACTUAL: X is false because functionB reset it
|
|
87
|
+
VERDICT: BUG — [description]
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
**Check each of these bug patterns:**
|
|
91
|
+
|
|
92
|
+
#### Pattern 1: Sequential Undo
|
|
93
|
+
```
|
|
94
|
+
handler() {
|
|
95
|
+
setState_A(true) // sets X = true
|
|
96
|
+
setState_B(null) // side effect: resets X = false
|
|
97
|
+
}
|
|
98
|
+
// Result: X is false. First call was pointless.
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
#### Pattern 2: Async Race
|
|
102
|
+
```
|
|
103
|
+
handler() {
|
|
104
|
+
fetchA().then(() => setState({ loading: false }))
|
|
105
|
+
fetchB().then(() => setState({ loading: true }))
|
|
106
|
+
}
|
|
107
|
+
// Result: final loading state depends on which resolves first
|
|
108
|
+
```
|
|
109
|
+
|
|
110
|
+
#### Pattern 3: Stale Closure
|
|
111
|
+
```
|
|
112
|
+
const [count, setCount] = useState(0)
|
|
113
|
+
const handler = useCallback(() => {
|
|
114
|
+
setCount(count + 1) // captures stale count
|
|
115
|
+
setCount(count + 1) // same stale count — increments by 1, not 2
|
|
116
|
+
}, [count])
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
#### Pattern 4: Missing State Transition
|
|
120
|
+
```
|
|
121
|
+
// Button says "Save" but handler only validates, never actually saves
|
|
122
|
+
// Button says "Delete" but handler sets a flag without calling the API
|
|
123
|
+
// Button says "Send" but the API endpoint is removed/broken
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
#### Pattern 5: Conditional Dead Path
|
|
127
|
+
```
|
|
128
|
+
handler() {
|
|
129
|
+
if (someState) { // someState is ALWAYS false at this point
|
|
130
|
+
doTheActualThing() // never reached
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
```
|
|
134
|
+
|
|
135
|
+
#### Pattern 6: useEffect Interference
|
|
136
|
+
```
|
|
137
|
+
// Button sets stateX = true
|
|
138
|
+
// A useEffect watches stateX and resets it to false
|
|
139
|
+
// User sees nothing happen
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
### Step 3: Report
|
|
143
|
+
|
|
144
|
+
For each bug found:
|
|
145
|
+
|
|
146
|
+
```
|
|
147
|
+
CLICK-PATH-NNN: [severity: CRITICAL/HIGH/MEDIUM/LOW]
|
|
148
|
+
Touchpoint: [Button label] in [file:line]
|
|
149
|
+
Pattern: [Sequential Undo / Async Race / Stale Closure / Missing Transition / Dead Path / useEffect Interference]
|
|
150
|
+
Handler: [function name or inline]
|
|
151
|
+
Trace:
|
|
152
|
+
1. [call] → sets {field: value}
|
|
153
|
+
2. [call] → RESETS {field: value} ← CONFLICT
|
|
154
|
+
Expected: [what user expects]
|
|
155
|
+
Actual: [what actually happens]
|
|
156
|
+
Fix: [specific fix]
|
|
157
|
+
```
|
|
158
|
+
|
|
159
|
+
---
|
|
160
|
+
|
|
161
|
+
## Scope Control
|
|
162
|
+
|
|
163
|
+
This audit is expensive. Scope it appropriately:
|
|
164
|
+
|
|
165
|
+
- **Full app audit:** Use when launching or after major refactor. Launch parallel agents per page.
|
|
166
|
+
- **Single page audit:** Use after building a new page or after a user reports a broken button.
|
|
167
|
+
- **Store-focused audit:** Use after modifying a Zustand store — audit all consumers of the changed actions.
|
|
168
|
+
|
|
169
|
+
### Recommended agent split for full app:
|
|
170
|
+
|
|
171
|
+
```
|
|
172
|
+
Agent 1: Map ALL state stores (Step 1) — this is shared context for all other agents
|
|
173
|
+
Agent 2: Dashboard (Tasks, Notes, Journal, Ideas)
|
|
174
|
+
Agent 3: Chat (DanteChatColumn, JustChatPage)
|
|
175
|
+
Agent 4: Emails (ThreadList, DraftArea, EmailsPage)
|
|
176
|
+
Agent 5: Projects (ProjectsPage, ProjectOverviewTab, NewProjectWizard)
|
|
177
|
+
Agent 6: CRM (all sub-tabs)
|
|
178
|
+
Agent 7: Profile, Settings, Vault, Notifications
|
|
179
|
+
Agent 8: Management Suite (all pages)
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
Agent 1 MUST complete first. Its output is input for all other agents.
|
|
183
|
+
|
|
184
|
+
---
|
|
185
|
+
|
|
186
|
+
## When to Use
|
|
187
|
+
|
|
188
|
+
- After systematic debugging finds "no bugs" but users report broken UI
|
|
189
|
+
- After modifying any Zustand store action (check all callers)
|
|
190
|
+
- After any refactor that touches shared state
|
|
191
|
+
- Before release, on critical user flows
|
|
192
|
+
- When a button "does nothing" — this is THE tool for that
|
|
193
|
+
|
|
194
|
+
## When NOT to Use
|
|
195
|
+
|
|
196
|
+
- For API-level bugs (wrong response shape, missing endpoint) — use systematic-debugging
|
|
197
|
+
- For styling/layout issues — visual inspection
|
|
198
|
+
- For performance issues — profiling tools
|
|
199
|
+
|
|
200
|
+
---
|
|
201
|
+
|
|
202
|
+
## Integration with Other Skills
|
|
203
|
+
|
|
204
|
+
- Run AFTER `/superpowers:systematic-debugging` (which finds the other 54 bug types)
|
|
205
|
+
- Run BEFORE `/superpowers:verification-before-completion` (which verifies fixes work)
|
|
206
|
+
- Feeds into `/superpowers:test-driven-development` — every bug found here should get a test
|
|
207
|
+
|
|
208
|
+
---
|
|
209
|
+
|
|
210
|
+
## Example: The Bug That Inspired This Skill
|
|
211
|
+
|
|
212
|
+
**ThreadList.tsx "New Email" button:**
|
|
213
|
+
```
|
|
214
|
+
onClick={() => {
|
|
215
|
+
useEmailStore.getState().setComposeMode(true) // ✓ sets composeMode = true
|
|
216
|
+
useEmailStore.getState().selectThread(null) // ✗ RESETS composeMode = false
|
|
217
|
+
}}
|
|
218
|
+
```
|
|
219
|
+
|
|
220
|
+
Store definition:
|
|
221
|
+
```
|
|
222
|
+
selectThread: (thread) => set({
|
|
223
|
+
selectedThread: thread,
|
|
224
|
+
selectedThreadId: thread?.id ?? null,
|
|
225
|
+
messages: [],
|
|
226
|
+
drafts: [],
|
|
227
|
+
selectedDraft: null,
|
|
228
|
+
summary: null,
|
|
229
|
+
composeMode: false, // ← THIS silent reset killed the button
|
|
230
|
+
composeData: null,
|
|
231
|
+
redraftOpen: false,
|
|
232
|
+
})
|
|
233
|
+
```
|
|
234
|
+
|
|
235
|
+
**Systematic debugging missed it** because:
|
|
236
|
+
- The button has an onClick handler (not dead)
|
|
237
|
+
- Both functions exist (no missing wiring)
|
|
238
|
+
- Neither function crashes (no runtime error)
|
|
239
|
+
- The data types are correct (no type mismatch)
|
|
240
|
+
|
|
241
|
+
**Click-path audit catches it** because:
|
|
242
|
+
- Step 1 maps `selectThread` resets `composeMode`
|
|
243
|
+
- Step 2 traces the handler: call 1 sets true, call 2 resets false
|
|
244
|
+
- Verdict: Sequential Undo — final state contradicts button intent
|