@heyai-rules/pilo-masterkit 1.2.2 → 2.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/PILO_MASTER.md +77 -77
- package/.agent/agents/backend-specialist.md +263 -263
- package/.agent/agents/code-archaeologist.md +106 -106
- package/.agent/agents/csharp-reviewer.md +101 -0
- package/.agent/agents/dart-build-resolver.md +201 -0
- package/.agent/agents/database-architect.md +226 -226
- package/.agent/agents/debugger.md +225 -225
- package/.agent/agents/devops-engineer.md +242 -242
- package/.agent/agents/documentation-writer.md +104 -104
- package/.agent/agents/explorer-agent.md +73 -73
- package/.agent/agents/frontend-specialist.md +593 -593
- package/.agent/agents/game-developer.md +162 -162
- 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/healthcare-reviewer.md +83 -0
- package/.agent/agents/mobile-developer.md +377 -377
- 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/orchestrator.md +416 -416
- package/.agent/agents/penetration-tester.md +188 -188
- package/.agent/agents/performance-optimizer.md +446 -187
- 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/product-manager.md +112 -112
- package/.agent/agents/product-owner.md +95 -95
- package/.agent/agents/project-planner.md +406 -406
- package/.agent/agents/qa-automation-engineer.md +103 -103
- package/.agent/agents/security-auditor.md +170 -170
- package/.agent/agents/seo-specialist.md +111 -111
- package/.agent/agents/test-engineer.md +158 -158
- 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/ARCHITECTURAL_BLUEPRINTS.md +62 -62
- package/.agent/rules/CODE_CRAFTSMANSHIP.md +69 -69
- package/.agent/rules/CORE_RULES.md +72 -72
- package/.agent/rules/PROJECT_MAP.md +58 -58
- package/.agent/rules/QUALITY_ASSURANCE.md +54 -54
- package/.agent/rules/SECURITY_ARMOR.md +44 -44
- package/.agent/rules/VERSION_ORCHESTRATION.md +64 -64
- package/.agent/rules/WORKFLOW_ORCHESTRATION.md +55 -55
- 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/scripts/auto_preview.py +148 -148
- package/.agent/scripts/checklist.py +217 -217
- package/.agent/scripts/session_manager.py +120 -120
- package/.agent/scripts/verify_all.py +327 -327
- 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/api-patterns/SKILL.md +81 -81
- package/.agent/skills/api-patterns/api-style.md +42 -42
- package/.agent/skills/api-patterns/auth.md +24 -24
- package/.agent/skills/api-patterns/documentation.md +26 -26
- package/.agent/skills/api-patterns/graphql.md +41 -41
- package/.agent/skills/api-patterns/rate-limiting.md +31 -31
- package/.agent/skills/api-patterns/response.md +37 -37
- package/.agent/skills/api-patterns/rest.md +40 -40
- package/.agent/skills/api-patterns/scripts/api_validator.py +211 -211
- package/.agent/skills/api-patterns/security-testing.md +122 -122
- package/.agent/skills/api-patterns/trpc.md +41 -41
- package/.agent/skills/api-patterns/versioning.md +22 -22
- package/.agent/skills/app-builder/SKILL.md +75 -75
- package/.agent/skills/app-builder/agent-coordination.md +71 -71
- package/.agent/skills/app-builder/feature-building.md +53 -53
- package/.agent/skills/app-builder/project-detection.md +34 -34
- package/.agent/skills/app-builder/scaffolding.md +118 -118
- package/.agent/skills/app-builder/tech-stack.md +41 -41
- package/.agent/skills/app-builder/templates/SKILL.md +39 -39
- package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +76 -76
- package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +92 -92
- package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +88 -88
- package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +88 -88
- package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +83 -83
- package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +90 -90
- package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -90
- package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +122 -122
- package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +122 -122
- package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +169 -169
- package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +134 -134
- package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +83 -83
- package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +119 -119
- package/.agent/skills/architecture/SKILL.md +55 -55
- package/.agent/skills/architecture/context-discovery.md +43 -43
- package/.agent/skills/architecture/examples.md +94 -94
- package/.agent/skills/architecture/pattern-selection.md +68 -68
- package/.agent/skills/architecture/patterns-reference.md +50 -50
- package/.agent/skills/architecture/trade-off-analysis.md +77 -77
- 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/bash-linux/SKILL.md +199 -199
- package/.agent/skills/behavioral-modes/SKILL.md +242 -242
- package/.agent/skills/benchmark/SKILL.md +93 -0
- package/.agent/skills/blueprint/SKILL.md +105 -0
- package/.agent/skills/brainstorming/SKILL.md +163 -163
- package/.agent/skills/brainstorming/dynamic-questioning.md +350 -350
- 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/clean-code/SKILL.md +201 -201
- package/.agent/skills/click-path-audit/SKILL.md +244 -0
- package/.agent/skills/clickhouse-io/SKILL.md +439 -0
- package/.agent/skills/code-review-checklist/SKILL.md +109 -109
- 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-design/SKILL.md +52 -52
- package/.agent/skills/database-design/database-selection.md +43 -43
- package/.agent/skills/database-design/indexing.md +39 -39
- package/.agent/skills/database-design/migrations.md +48 -48
- package/.agent/skills/database-design/optimization.md +36 -36
- package/.agent/skills/database-design/orm-selection.md +30 -30
- package/.agent/skills/database-design/schema-design.md +56 -56
- package/.agent/skills/database-design/scripts/schema_validator.py +172 -172
- 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/deployment-procedures/SKILL.md +241 -241
- 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/doc.md +177 -177
- package/.agent/skills/docker-patterns/SKILL.md +364 -0
- package/.agent/skills/documentation-lookup/SKILL.md +90 -0
- package/.agent/skills/documentation-templates/SKILL.md +194 -194
- 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-design/SKILL.md +452 -452
- package/.agent/skills/frontend-design/animation-guide.md +331 -331
- package/.agent/skills/frontend-design/color-system.md +311 -311
- package/.agent/skills/frontend-design/decision-trees.md +418 -418
- package/.agent/skills/frontend-design/motion-graphics.md +306 -306
- package/.agent/skills/frontend-design/scripts/accessibility_checker.py +183 -183
- package/.agent/skills/frontend-design/scripts/ux_audit.py +722 -722
- package/.agent/skills/frontend-design/typography-system.md +345 -345
- package/.agent/skills/frontend-design/ux-psychology.md +1116 -1116
- package/.agent/skills/frontend-design/visual-effects.md +383 -383
- 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/game-development/2d-games/SKILL.md +119 -119
- package/.agent/skills/game-development/3d-games/SKILL.md +135 -135
- package/.agent/skills/game-development/SKILL.md +167 -167
- package/.agent/skills/game-development/game-art/SKILL.md +185 -185
- package/.agent/skills/game-development/game-audio/SKILL.md +190 -190
- package/.agent/skills/game-development/game-design/SKILL.md +129 -129
- package/.agent/skills/game-development/mobile-games/SKILL.md +108 -108
- package/.agent/skills/game-development/multiplayer/SKILL.md +132 -132
- package/.agent/skills/game-development/pc-games/SKILL.md +144 -144
- package/.agent/skills/game-development/vr-ar/SKILL.md +123 -123
- package/.agent/skills/game-development/web-games/SKILL.md +150 -150
- package/.agent/skills/gan-style-harness/SKILL.md +278 -0
- package/.agent/skills/geo-fundamentals/SKILL.md +156 -156
- package/.agent/skills/geo-fundamentals/scripts/geo_checker.py +289 -289
- 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/i18n-localization/SKILL.md +154 -154
- package/.agent/skills/i18n-localization/scripts/i18n_checker.py +241 -241
- package/.agent/skills/intelligent-routing/SKILL.md +335 -335
- 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/lint-and-validate/SKILL.md +45 -45
- package/.agent/skills/lint-and-validate/scripts/lint_runner.py +184 -184
- package/.agent/skills/lint-and-validate/scripts/type_coverage.py +173 -173
- 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/mobile-design/SKILL.md +394 -394
- package/.agent/skills/mobile-design/decision-trees.md +516 -516
- package/.agent/skills/mobile-design/mobile-backend.md +491 -491
- package/.agent/skills/mobile-design/mobile-color-system.md +420 -420
- package/.agent/skills/mobile-design/mobile-debugging.md +122 -122
- package/.agent/skills/mobile-design/mobile-design-thinking.md +357 -357
- package/.agent/skills/mobile-design/mobile-navigation.md +458 -458
- package/.agent/skills/mobile-design/mobile-performance.md +767 -767
- package/.agent/skills/mobile-design/mobile-testing.md +356 -356
- package/.agent/skills/mobile-design/mobile-typography.md +433 -433
- package/.agent/skills/mobile-design/platform-android.md +666 -666
- package/.agent/skills/mobile-design/platform-ios.md +561 -561
- package/.agent/skills/mobile-design/scripts/mobile_audit.py +670 -670
- package/.agent/skills/mobile-design/touch-psychology.md +537 -537
- package/.agent/skills/nanoclaw-repl/SKILL.md +33 -0
- package/.agent/skills/nestjs-patterns/SKILL.md +230 -0
- package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +351 -351
- package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +240 -240
- package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +490 -490
- package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +264 -264
- package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +581 -581
- package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +432 -432
- package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +684 -684
- package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +150 -150
- package/.agent/skills/nextjs-react-expert/9-cache-components.md +103 -103
- package/.agent/skills/nextjs-react-expert/SKILL.md +293 -293
- package/.agent/skills/nextjs-react-expert/scripts/convert_rules.py +222 -222
- package/.agent/skills/nextjs-react-expert/scripts/react_performance_checker.py +252 -252
- package/.agent/skills/nextjs-turbopack/SKILL.md +44 -0
- package/.agent/skills/nodejs-best-practices/SKILL.md +333 -333
- 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/parallel-agents/SKILL.md +175 -175
- package/.agent/skills/performance-profiling/SKILL.md +143 -143
- package/.agent/skills/performance-profiling/scripts/lighthouse_audit.py +76 -76
- 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/plan-writing/SKILL.md +152 -152
- package/.agent/skills/plankton-code-quality/SKILL.md +236 -0
- package/.agent/skills/postgres-patterns/SKILL.md +147 -0
- package/.agent/skills/powershell-windows/SKILL.md +167 -167
- 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 +750 -441
- 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/red-team-tactics/SKILL.md +199 -199
- 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-pro/SKILL.md +175 -175
- 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/seo-fundamentals/SKILL.md +129 -129
- package/.agent/skills/seo-fundamentals/scripts/seo_checker.py +219 -219
- package/.agent/skills/server-management/SKILL.md +161 -161
- 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/systematic-debugging/SKILL.md +109 -109
- package/.agent/skills/tailwind-patterns/SKILL.md +269 -269
- package/.agent/skills/tdd-workflow/SKILL.md +463 -149
- package/.agent/skills/team-builder/SKILL.md +168 -0
- package/.agent/skills/testing-patterns/SKILL.md +178 -178
- package/.agent/skills/testing-patterns/scripts/test_runner.py +219 -219
- 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/SKILL.md +292 -292
- package/.agent/skills/ui-ux-pro-max/data/icons.csv +101 -101
- package/.agent/skills/ui-ux-pro-max/data/landing.csv +3 -3
- package/.agent/skills/ui-ux-pro-max/data/react-performance.csv +45 -45
- package/.agent/skills/ui-ux-pro-max/data/stacks/astro.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -51
- package/.agent/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -59
- package/.agent/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -61
- package/.agent/skills/ui-ux-pro-max/data/typography.csv +57 -57
- package/.agent/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -101
- package/.agent/skills/ui-ux-pro-max/data/web-interface.csv +31 -31
- package/.agent/skills/ui-ux-pro-max/scripts/core.py +253 -253
- package/.agent/skills/ui-ux-pro-max/scripts/design_system.py +1067 -1067
- 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/vulnerability-scanner/SKILL.md +276 -276
- package/.agent/skills/vulnerability-scanner/checklists.md +121 -121
- package/.agent/skills/vulnerability-scanner/scripts/security_scan.py +458 -458
- package/.agent/skills/web-design-guidelines/SKILL.md +57 -57
- package/.agent/skills/webapp-testing/SKILL.md +187 -187
- package/.agent/skills/webapp-testing/scripts/playwright_runner.py +173 -173
- package/.agent/skills/workspace-surface-audit/SKILL.md +125 -0
- package/.agent/skills/x-api/SKILL.md +230 -0
- package/.agent/tasks/lessons.md +40 -40
- package/.agent/tasks/todo.md +33 -33
- package/.agent/tasks/two-track-merge-contract.md +29 -0
- package/.agent/workflows/aside.md +3 -3
- package/.agent/workflows/brainstorm.md +113 -113
- package/.agent/workflows/claw.md +13 -41
- package/.agent/workflows/clean-memory.md +34 -0
- package/.agent/workflows/code-review.md +260 -11
- package/.agent/workflows/context-budget.md +12 -18
- package/.agent/workflows/cpp-build.md +1 -1
- package/.agent/workflows/cpp-review.md +4 -4
- package/.agent/workflows/create.md +59 -59
- package/.agent/workflows/debug.md +103 -103
- package/.agent/workflows/deploy.md +176 -176
- package/.agent/workflows/devfleet.md +13 -82
- package/.agent/workflows/docs.md +13 -21
- package/.agent/workflows/e2e.md +38 -135
- package/.agent/workflows/enhance.md +63 -63
- package/.agent/workflows/eval.md +15 -112
- 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 +1 -1
- package/.agent/workflows/go-review.md +4 -4
- package/.agent/workflows/harness-audit.md +5 -3
- package/.agent/workflows/init-docs.md +46 -46
- package/.agent/workflows/instinct-import.md +4 -4
- package/.agent/workflows/jira.md +106 -0
- package/.agent/workflows/kotlin-build.md +1 -1
- package/.agent/workflows/kotlin-review.md +5 -5
- package/.agent/workflows/learn-eval.md +9 -9
- package/.agent/workflows/multi-plan.md +10 -10
- package/.agent/workflows/orchestrate.md +23 -119
- package/.agent/workflows/plan.md +2 -0
- package/.agent/workflows/preview.md +81 -81
- package/.agent/workflows/prompt-optimize.md +13 -28
- 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/python-review.md +5 -5
- package/.agent/workflows/refactor-clean.md +1 -1
- package/.agent/workflows/resume-session.md +10 -10
- package/.agent/workflows/rules-distill.md +14 -5
- package/.agent/workflows/santa-loop.md +175 -0
- package/.agent/workflows/save-session.md +9 -9
- package/.agent/workflows/status.md +86 -86
- package/.agent/workflows/tdd.md +30 -127
- package/.agent/workflows/test-coverage.md +1 -1
- package/.agent/workflows/test.md +144 -144
- package/.agent/workflows/ui-ux-pro-max.md +295 -295
- package/.agent/workflows/verify.md +15 -51
- package/README.md +144 -136
- package/RELEASE.md +32 -36
- package/package.json +87 -79
- package/scripts/release-check.js +1 -1
- package/src/bin/cli.js +354 -78
- package/src/lib/installer.js +151 -117
- 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,224 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* ck — Context Keeper v2
|
|
4
|
+
* session-start.mjs — inject compact project context on session start.
|
|
5
|
+
*
|
|
6
|
+
* Injects ~100 tokens (not ~2,500 like v1).
|
|
7
|
+
* SKILL.md is injected separately (still small at ~50 lines).
|
|
8
|
+
*
|
|
9
|
+
* Features:
|
|
10
|
+
* - Compact 5-line summary for registered projects
|
|
11
|
+
* - Unsaved session detection → "Last session wasn't saved. Run /ck:save."
|
|
12
|
+
* - Git activity since last session
|
|
13
|
+
* - Goal mismatch detection vs CLAUDE.md
|
|
14
|
+
* - Mini portfolio for unregistered directories
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
import { readFileSync, writeFileSync, existsSync } from 'fs';
|
|
18
|
+
import { resolve } from 'path';
|
|
19
|
+
import { homedir } from 'os';
|
|
20
|
+
import { spawnSync } from 'child_process';
|
|
21
|
+
|
|
22
|
+
const CK_HOME = resolve(homedir(), '.claude', 'ck');
|
|
23
|
+
const PROJECTS_FILE = resolve(CK_HOME, 'projects.json');
|
|
24
|
+
const CURRENT_SESSION = resolve(CK_HOME, 'current-session.json');
|
|
25
|
+
const SKILL_FILE = resolve(homedir(), '.claude', 'skills', 'ck', 'SKILL.md');
|
|
26
|
+
|
|
27
|
+
// ─── Helpers ──────────────────────────────────────────────────────────────────
|
|
28
|
+
|
|
29
|
+
function readJson(p) {
|
|
30
|
+
try { return JSON.parse(readFileSync(p, 'utf8')); } catch { return null; }
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
function daysAgo(dateStr) {
|
|
34
|
+
if (!dateStr) return 'unknown';
|
|
35
|
+
const diff = Math.floor((Date.now() - new Date(dateStr)) / 86_400_000);
|
|
36
|
+
if (diff === 0) return 'today';
|
|
37
|
+
if (diff === 1) return '1 day ago';
|
|
38
|
+
return `${diff} days ago`;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
function stalenessIcon(dateStr) {
|
|
42
|
+
if (!dateStr) return '○';
|
|
43
|
+
const diff = Math.floor((Date.now() - new Date(dateStr)) / 86_400_000);
|
|
44
|
+
return diff < 1 ? '●' : diff <= 5 ? '◐' : '○';
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function gitLogSince(projectPath, sinceDate) {
|
|
48
|
+
if (!sinceDate || !existsSync(resolve(projectPath, '.git'))) return null;
|
|
49
|
+
try {
|
|
50
|
+
const result = spawnSync(
|
|
51
|
+
'git',
|
|
52
|
+
['-C', projectPath, 'log', '--oneline', `--since=${sinceDate}`],
|
|
53
|
+
{ timeout: 3000, stdio: 'pipe', encoding: 'utf8' },
|
|
54
|
+
);
|
|
55
|
+
if (result.status !== 0) return null;
|
|
56
|
+
const output = result.stdout.trim();
|
|
57
|
+
const commits = output.split('\n').filter(Boolean).length;
|
|
58
|
+
return commits > 0 ? `${commits} commit${commits !== 1 ? 's' : ''} since last session` : null;
|
|
59
|
+
} catch { return null; }
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
function extractClaudeMdGoal(projectPath) {
|
|
63
|
+
const p = resolve(projectPath, 'CLAUDE.md');
|
|
64
|
+
if (!existsSync(p)) return null;
|
|
65
|
+
try {
|
|
66
|
+
const md = readFileSync(p, 'utf8');
|
|
67
|
+
const m = md.match(/## Current Goal\n([\s\S]*?)(?=\n## |$)/);
|
|
68
|
+
return m ? m[1].trim().split('\n')[0].trim() : null;
|
|
69
|
+
} catch { return null; }
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// ─── Session ID from stdin ────────────────────────────────────────────────────
|
|
73
|
+
|
|
74
|
+
function readSessionId() {
|
|
75
|
+
try {
|
|
76
|
+
const raw = readFileSync(0, 'utf8');
|
|
77
|
+
return JSON.parse(raw).session_id || null;
|
|
78
|
+
} catch { return null; }
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
// ─── Main ─────────────────────────────────────────────────────────────────────
|
|
82
|
+
|
|
83
|
+
function main() {
|
|
84
|
+
const cwd = process.env.PWD || process.cwd();
|
|
85
|
+
const sessionId = readSessionId();
|
|
86
|
+
|
|
87
|
+
// Load skill (always inject — now only ~50 lines)
|
|
88
|
+
const skill = existsSync(SKILL_FILE) ? readFileSync(SKILL_FILE, 'utf8') : '';
|
|
89
|
+
|
|
90
|
+
const projects = readJson(PROJECTS_FILE) || {};
|
|
91
|
+
const entry = projects[cwd];
|
|
92
|
+
|
|
93
|
+
// Read previous session BEFORE overwriting current-session.json
|
|
94
|
+
const prevSession = readJson(CURRENT_SESSION);
|
|
95
|
+
|
|
96
|
+
// Write current-session.json
|
|
97
|
+
try {
|
|
98
|
+
writeFileSync(CURRENT_SESSION, JSON.stringify({
|
|
99
|
+
sessionId,
|
|
100
|
+
projectPath: cwd,
|
|
101
|
+
projectName: entry?.name || null,
|
|
102
|
+
startedAt: new Date().toISOString(),
|
|
103
|
+
}, null, 2), 'utf8');
|
|
104
|
+
} catch { /* non-fatal */ }
|
|
105
|
+
|
|
106
|
+
const parts = [];
|
|
107
|
+
if (skill) parts.push(skill);
|
|
108
|
+
|
|
109
|
+
// ── REGISTERED PROJECT ────────────────────────────────────────────────────
|
|
110
|
+
if (entry?.contextDir) {
|
|
111
|
+
const contextFile = resolve(CK_HOME, 'contexts', entry.contextDir, 'context.json');
|
|
112
|
+
const context = readJson(contextFile);
|
|
113
|
+
|
|
114
|
+
if (context) {
|
|
115
|
+
const latest = context.sessions?.[context.sessions.length - 1] || {};
|
|
116
|
+
const sessionDate = latest.date || context.createdAt;
|
|
117
|
+
const sessionCount = context.sessions?.length || 0;
|
|
118
|
+
const displayName = context.displayName ?? context.name;
|
|
119
|
+
|
|
120
|
+
// ── Compact summary block (~100 tokens) ──────────────────────────────
|
|
121
|
+
const summaryLines = [
|
|
122
|
+
`ck: ${displayName} | ${daysAgo(sessionDate)} | ${sessionCount} session${sessionCount !== 1 ? 's' : ''}`,
|
|
123
|
+
`Goal: ${context.goal || '—'}`,
|
|
124
|
+
latest.leftOff ? `Left off: ${latest.leftOff.split('\n')[0]}` : null,
|
|
125
|
+
latest.nextSteps?.length ? `Next: ${latest.nextSteps.slice(0, 2).join(' · ')}` : null,
|
|
126
|
+
].filter(Boolean);
|
|
127
|
+
|
|
128
|
+
// ── Unsaved session detection ─────────────────────────────────────────
|
|
129
|
+
if (prevSession?.sessionId && prevSession.sessionId !== sessionId) {
|
|
130
|
+
// Check if previous session ID exists in sessions array
|
|
131
|
+
const alreadySaved = context.sessions?.some(s => s.id === prevSession.sessionId);
|
|
132
|
+
if (!alreadySaved) {
|
|
133
|
+
summaryLines.push(`WARNING Last session wasn't saved — run /ck:save to capture it`);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// ── Git activity ──────────────────────────────────────────────────────
|
|
138
|
+
const gitLine = gitLogSince(cwd, sessionDate);
|
|
139
|
+
if (gitLine) summaryLines.push(`Git: ${gitLine}`);
|
|
140
|
+
|
|
141
|
+
// ── Goal mismatch detection ───────────────────────────────────────────
|
|
142
|
+
const claudeMdGoal = extractClaudeMdGoal(cwd);
|
|
143
|
+
if (claudeMdGoal && context.goal &&
|
|
144
|
+
claudeMdGoal.toLowerCase().trim() !== context.goal.toLowerCase().trim()) {
|
|
145
|
+
summaryLines.push(`WARNING Goal mismatch — ck: "${context.goal.slice(0, 40)}" · CLAUDE.md: "${claudeMdGoal.slice(0, 40)}"`);
|
|
146
|
+
summaryLines.push(` Run /ck:save with updated goal to sync`);
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
parts.push([
|
|
150
|
+
`---`,
|
|
151
|
+
`## ck: ${displayName}`,
|
|
152
|
+
``,
|
|
153
|
+
summaryLines.join('\n'),
|
|
154
|
+
].join('\n'));
|
|
155
|
+
|
|
156
|
+
// Instruct Claude to display compact briefing at session start
|
|
157
|
+
parts.push([
|
|
158
|
+
`---`,
|
|
159
|
+
`## ck: SESSION START`,
|
|
160
|
+
``,
|
|
161
|
+
`IMPORTANT: Display the following as your FIRST message, verbatim:`,
|
|
162
|
+
``,
|
|
163
|
+
'```',
|
|
164
|
+
summaryLines.join('\n'),
|
|
165
|
+
'```',
|
|
166
|
+
``,
|
|
167
|
+
`After the block, add one line: "Ready — what are we working on?"`,
|
|
168
|
+
`If you see WARNING lines above, mention them briefly after the block.`,
|
|
169
|
+
].join('\n'));
|
|
170
|
+
|
|
171
|
+
return parts;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
// ── NOT IN A REGISTERED PROJECT ────────────────────────────────────────────
|
|
176
|
+
const entries = Object.entries(projects);
|
|
177
|
+
if (entries.length === 0) return parts;
|
|
178
|
+
|
|
179
|
+
// Load and sort by most recent
|
|
180
|
+
const recent = entries
|
|
181
|
+
.map(([path, info]) => {
|
|
182
|
+
const ctx = readJson(resolve(CK_HOME, 'contexts', info.contextDir, 'context.json'));
|
|
183
|
+
const latest = ctx?.sessions?.[ctx.sessions.length - 1] || {};
|
|
184
|
+
return { name: info.name, path, lastDate: latest.date || '', summary: latest.summary || '—', ctx };
|
|
185
|
+
})
|
|
186
|
+
.sort((a, b) => (b.lastDate > a.lastDate ? 1 : -1))
|
|
187
|
+
.slice(0, 3);
|
|
188
|
+
|
|
189
|
+
const miniRows = recent.map(p => {
|
|
190
|
+
const icon = stalenessIcon(p.lastDate);
|
|
191
|
+
const when = daysAgo(p.lastDate);
|
|
192
|
+
const name = p.name.padEnd(16).slice(0, 16);
|
|
193
|
+
const whenStr = when.padEnd(12).slice(0, 12);
|
|
194
|
+
const summary = p.summary.slice(0, 32);
|
|
195
|
+
return ` ${name} ${icon} ${whenStr} ${summary}`;
|
|
196
|
+
});
|
|
197
|
+
|
|
198
|
+
const miniStatus = [
|
|
199
|
+
`ck — recent projects:`,
|
|
200
|
+
` ${'PROJECT'.padEnd(16)} S ${'LAST SEEN'.padEnd(12)} LAST SESSION`,
|
|
201
|
+
` ${'─'.repeat(68)}`,
|
|
202
|
+
...miniRows,
|
|
203
|
+
``,
|
|
204
|
+
`Run /ck:list · /ck:resume <name> · /ck:init to register this folder`,
|
|
205
|
+
].join('\n');
|
|
206
|
+
|
|
207
|
+
parts.push([
|
|
208
|
+
`---`,
|
|
209
|
+
`## ck: SESSION START`,
|
|
210
|
+
``,
|
|
211
|
+
`IMPORTANT: Display the following as your FIRST message, verbatim:`,
|
|
212
|
+
``,
|
|
213
|
+
'```',
|
|
214
|
+
miniStatus,
|
|
215
|
+
'```',
|
|
216
|
+
].join('\n'));
|
|
217
|
+
|
|
218
|
+
return parts;
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
const parts = main();
|
|
222
|
+
if (parts.length > 0) {
|
|
223
|
+
console.log(JSON.stringify({ additionalContext: parts.join('\n\n---\n\n') }));
|
|
224
|
+
}
|
|
@@ -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.
|