@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,111 @@
|
|
|
1
|
+
# Rules
|
|
2
|
+
## Structure
|
|
3
|
+
|
|
4
|
+
Rules are organized into a **common** layer plus **language-specific** directories:
|
|
5
|
+
|
|
6
|
+
```
|
|
7
|
+
rules/
|
|
8
|
+
├── common/ # Language-agnostic principles (always install)
|
|
9
|
+
│ ├── coding-style.md
|
|
10
|
+
│ ├── git-workflow.md
|
|
11
|
+
│ ├── testing.md
|
|
12
|
+
│ ├── performance.md
|
|
13
|
+
│ ├── patterns.md
|
|
14
|
+
│ ├── hooks.md
|
|
15
|
+
│ ├── agents.md
|
|
16
|
+
│ └── security.md
|
|
17
|
+
├── typescript/ # TypeScript/JavaScript specific
|
|
18
|
+
├── python/ # Python specific
|
|
19
|
+
├── golang/ # Go specific
|
|
20
|
+
├── web/ # Web and frontend specific
|
|
21
|
+
├── swift/ # Swift specific
|
|
22
|
+
└── php/ # PHP specific
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
- **common/** contains universal principles — no language-specific code examples.
|
|
26
|
+
- **Language directories** extend the common rules with framework-specific patterns, tools, and code examples. Each file references its common counterpart.
|
|
27
|
+
|
|
28
|
+
## Installation
|
|
29
|
+
|
|
30
|
+
### Option 1: Install Script (Recommended)
|
|
31
|
+
|
|
32
|
+
```bash
|
|
33
|
+
# Install common + one or more language-specific rule sets
|
|
34
|
+
./install.sh typescript
|
|
35
|
+
./install.sh python
|
|
36
|
+
./install.sh golang
|
|
37
|
+
./install.sh web
|
|
38
|
+
./install.sh swift
|
|
39
|
+
./install.sh php
|
|
40
|
+
|
|
41
|
+
# Install multiple languages at once
|
|
42
|
+
./install.sh typescript python
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
### Option 2: Manual Installation
|
|
46
|
+
|
|
47
|
+
> **Important:** Copy entire directories — do NOT flatten with `/*`.
|
|
48
|
+
> Common and language-specific directories contain files with the same names.
|
|
49
|
+
> Flattening them into one directory causes language-specific files to overwrite
|
|
50
|
+
> common rules, and breaks the relative `../common/` references used by
|
|
51
|
+
> language-specific files.
|
|
52
|
+
|
|
53
|
+
```bash
|
|
54
|
+
# Install common rules (required for all projects)
|
|
55
|
+
cp -r rules/common ~/.claude/rules/common
|
|
56
|
+
|
|
57
|
+
# Install language-specific rules based on your project's tech stack
|
|
58
|
+
cp -r rules/typescript ~/.claude/rules/typescript
|
|
59
|
+
cp -r rules/python ~/.claude/rules/python
|
|
60
|
+
cp -r rules/golang ~/.claude/rules/golang
|
|
61
|
+
cp -r rules/web ~/.claude/rules/web
|
|
62
|
+
cp -r rules/swift ~/.claude/rules/swift
|
|
63
|
+
cp -r rules/php ~/.claude/rules/php
|
|
64
|
+
|
|
65
|
+
# Attention ! ! ! Configure according to your actual project requirements; the configuration here is for reference only.
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
## Rules vs Skills
|
|
69
|
+
|
|
70
|
+
- **Rules** define standards, conventions, and checklists that apply broadly (e.g., "80% test coverage", "no hardcoded secrets").
|
|
71
|
+
- **Skills** (`skills/` directory) provide deep, actionable reference material for specific tasks (e.g., `python-patterns`, `golang-testing`).
|
|
72
|
+
|
|
73
|
+
Language-specific rule files reference relevant skills where appropriate. Rules tell you *what* to do; skills tell you *how* to do it.
|
|
74
|
+
|
|
75
|
+
## Adding a New Language
|
|
76
|
+
|
|
77
|
+
To add support for a new language (e.g., `rust/`):
|
|
78
|
+
|
|
79
|
+
1. Create a `rules/rust/` directory
|
|
80
|
+
2. Add files that extend the common rules:
|
|
81
|
+
- `coding-style.md` — formatting tools, idioms, error handling patterns
|
|
82
|
+
- `testing.md` — test framework, coverage tools, test organization
|
|
83
|
+
- `patterns.md` — language-specific design patterns
|
|
84
|
+
- `hooks.md` — PostToolUse hooks for formatters, linters, type checkers
|
|
85
|
+
- `security.md` — secret management, security scanning tools
|
|
86
|
+
3. Each file should start with:
|
|
87
|
+
```
|
|
88
|
+
> This file extends [common/xxx.md](../common/xxx.md) with <Language> specific content.
|
|
89
|
+
```
|
|
90
|
+
4. Reference existing skills if available, or create new ones under `skills/`.
|
|
91
|
+
|
|
92
|
+
For non-language domains like `web/`, follow the same layered pattern when there is enough reusable domain-specific guidance to justify a standalone ruleset.
|
|
93
|
+
|
|
94
|
+
## Rule Priority
|
|
95
|
+
|
|
96
|
+
When language-specific rules and common rules conflict, **language-specific rules take precedence** (specific overrides general). This follows the standard layered configuration pattern (similar to CSS specificity or `.gitignore` precedence).
|
|
97
|
+
|
|
98
|
+
- `rules/common/` defines universal defaults applicable to all projects.
|
|
99
|
+
- `rules/golang/`, `rules/python/`, `rules/swift/`, `rules/php/`, `rules/typescript/`, etc. override those defaults where language idioms differ.
|
|
100
|
+
|
|
101
|
+
### Example
|
|
102
|
+
|
|
103
|
+
`common/coding-style.md` recommends immutability as a default principle. A language-specific `golang/coding-style.md` can override this:
|
|
104
|
+
|
|
105
|
+
> Idiomatic Go uses pointer receivers for struct mutation — see [common/coding-style.md](../common/coding-style.md) for the general principle, but Go-idiomatic mutation is preferred here.
|
|
106
|
+
|
|
107
|
+
### Common rules with override notes
|
|
108
|
+
|
|
109
|
+
Rules in `rules/common/` that may be overridden by language-specific files are marked with:
|
|
110
|
+
|
|
111
|
+
> **Language note**: This rule may be overridden by language-specific rules for languages where this pattern is not idiomatic.
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
---
|
|
2
|
+
paths:
|
|
3
|
+
- "**/*.rs"
|
|
4
|
+
---
|
|
5
|
+
# Rust Coding Style
|
|
6
|
+
|
|
7
|
+
> This file extends [common/coding-style.md](../common/coding-style.md) with Rust-specific content.
|
|
8
|
+
|
|
9
|
+
## Formatting
|
|
10
|
+
|
|
11
|
+
- **rustfmt** for enforcement — always run `cargo fmt` before committing
|
|
12
|
+
- **clippy** for lints — `cargo clippy -- -D warnings` (treat warnings as errors)
|
|
13
|
+
- 4-space indent (rustfmt default)
|
|
14
|
+
- Max line width: 100 characters (rustfmt default)
|
|
15
|
+
|
|
16
|
+
## Immutability
|
|
17
|
+
|
|
18
|
+
Rust variables are immutable by default — embrace this:
|
|
19
|
+
|
|
20
|
+
- Use `let` by default; only use `let mut` when mutation is required
|
|
21
|
+
- Prefer returning new values over mutating in place
|
|
22
|
+
- Use `Cow<'_, T>` when a function may or may not need to allocate
|
|
23
|
+
|
|
24
|
+
```rust
|
|
25
|
+
use std::borrow::Cow;
|
|
26
|
+
|
|
27
|
+
// GOOD — immutable by default, new value returned
|
|
28
|
+
fn normalize(input: &str) -> Cow<'_, str> {
|
|
29
|
+
if input.contains(' ') {
|
|
30
|
+
Cow::Owned(input.replace(' ', "_"))
|
|
31
|
+
} else {
|
|
32
|
+
Cow::Borrowed(input)
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// BAD — unnecessary mutation
|
|
37
|
+
fn normalize_bad(input: &mut String) {
|
|
38
|
+
*input = input.replace(' ', "_");
|
|
39
|
+
}
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
## Naming
|
|
43
|
+
|
|
44
|
+
Follow standard Rust conventions:
|
|
45
|
+
- `snake_case` for functions, methods, variables, modules, crates
|
|
46
|
+
- `PascalCase` (UpperCamelCase) for types, traits, enums, type parameters
|
|
47
|
+
- `SCREAMING_SNAKE_CASE` for constants and statics
|
|
48
|
+
- Lifetimes: short lowercase (`'a`, `'de`) — descriptive names for complex cases (`'input`)
|
|
49
|
+
|
|
50
|
+
## Ownership and Borrowing
|
|
51
|
+
|
|
52
|
+
- Borrow (`&T`) by default; take ownership only when you need to store or consume
|
|
53
|
+
- Never clone to satisfy the borrow checker without understanding the root cause
|
|
54
|
+
- Accept `&str` over `String`, `&[T]` over `Vec<T>` in function parameters
|
|
55
|
+
- Use `impl Into<String>` for constructors that need to own a `String`
|
|
56
|
+
|
|
57
|
+
```rust
|
|
58
|
+
// GOOD — borrows when ownership isn't needed
|
|
59
|
+
fn word_count(text: &str) -> usize {
|
|
60
|
+
text.split_whitespace().count()
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
// GOOD — takes ownership in constructor via Into
|
|
64
|
+
fn new(name: impl Into<String>) -> Self {
|
|
65
|
+
Self { name: name.into() }
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
// BAD — takes String when &str suffices
|
|
69
|
+
fn word_count_bad(text: String) -> usize {
|
|
70
|
+
text.split_whitespace().count()
|
|
71
|
+
}
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
## Error Handling
|
|
75
|
+
|
|
76
|
+
- Use `Result<T, E>` and `?` for propagation — never `unwrap()` in production code
|
|
77
|
+
- **Libraries**: define typed errors with `thiserror`
|
|
78
|
+
- **Applications**: use `anyhow` for flexible error context
|
|
79
|
+
- Add context with `.with_context(|| format!("failed to ..."))?`
|
|
80
|
+
- Reserve `unwrap()` / `expect()` for tests and truly unreachable states
|
|
81
|
+
|
|
82
|
+
```rust
|
|
83
|
+
// GOOD — library error with thiserror
|
|
84
|
+
#[derive(Debug, thiserror::Error)]
|
|
85
|
+
pub enum ConfigError {
|
|
86
|
+
#[error("failed to read config: {0}")]
|
|
87
|
+
Io(#[from] std::io::Error),
|
|
88
|
+
#[error("invalid config format: {0}")]
|
|
89
|
+
Parse(String),
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
// GOOD — application error with anyhow
|
|
93
|
+
use anyhow::Context;
|
|
94
|
+
|
|
95
|
+
fn load_config(path: &str) -> anyhow::Result<Config> {
|
|
96
|
+
let content = std::fs::read_to_string(path)
|
|
97
|
+
.with_context(|| format!("failed to read {path}"))?;
|
|
98
|
+
toml::from_str(&content)
|
|
99
|
+
.with_context(|| format!("failed to parse {path}"))
|
|
100
|
+
}
|
|
101
|
+
```
|
|
102
|
+
|
|
103
|
+
## Iterators Over Loops
|
|
104
|
+
|
|
105
|
+
Prefer iterator chains for transformations; use loops for complex control flow:
|
|
106
|
+
|
|
107
|
+
```rust
|
|
108
|
+
// GOOD — declarative and composable
|
|
109
|
+
let active_emails: Vec<&str> = users.iter()
|
|
110
|
+
.filter(|u| u.is_active)
|
|
111
|
+
.map(|u| u.email.as_str())
|
|
112
|
+
.collect();
|
|
113
|
+
|
|
114
|
+
// GOOD — loop for complex logic with early returns
|
|
115
|
+
for user in &users {
|
|
116
|
+
if let Some(verified) = verify_email(&user.email)? {
|
|
117
|
+
send_welcome(&verified)?;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
## Module Organization
|
|
123
|
+
|
|
124
|
+
Organize by domain, not by type:
|
|
125
|
+
|
|
126
|
+
```text
|
|
127
|
+
src/
|
|
128
|
+
├── main.rs
|
|
129
|
+
├── lib.rs
|
|
130
|
+
├── auth/ # Domain module
|
|
131
|
+
│ ├── mod.rs
|
|
132
|
+
│ ├── token.rs
|
|
133
|
+
│ └── middleware.rs
|
|
134
|
+
├── orders/ # Domain module
|
|
135
|
+
│ ├── mod.rs
|
|
136
|
+
│ ├── model.rs
|
|
137
|
+
│ └── service.rs
|
|
138
|
+
└── db/ # Infrastructure
|
|
139
|
+
├── mod.rs
|
|
140
|
+
└── pool.rs
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
## Visibility
|
|
144
|
+
|
|
145
|
+
- Default to private; use `pub(crate)` for internal sharing
|
|
146
|
+
- Only mark `pub` what is part of the crate's public API
|
|
147
|
+
- Re-export public API from `lib.rs`
|
|
148
|
+
|
|
149
|
+
## References
|
|
150
|
+
|
|
151
|
+
See skill: `rust-patterns` for comprehensive Rust idioms and patterns.
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
---
|
|
2
|
+
paths:
|
|
3
|
+
- "**/*.rs"
|
|
4
|
+
- "**/Cargo.toml"
|
|
5
|
+
---
|
|
6
|
+
# Rust Hooks
|
|
7
|
+
|
|
8
|
+
> This file extends [common/hooks.md](../common/hooks.md) with Rust-specific content.
|
|
9
|
+
|
|
10
|
+
## PostToolUse Hooks
|
|
11
|
+
|
|
12
|
+
Configure in `~/.claude/settings.json`:
|
|
13
|
+
|
|
14
|
+
- **cargo fmt**: Auto-format `.rs` files after edit
|
|
15
|
+
- **cargo clippy**: Run lint checks after editing Rust files
|
|
16
|
+
- **cargo check**: Verify compilation after changes (faster than `cargo build`)
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
---
|
|
2
|
+
paths:
|
|
3
|
+
- "**/*.rs"
|
|
4
|
+
---
|
|
5
|
+
# Rust Patterns
|
|
6
|
+
|
|
7
|
+
> This file extends [common/patterns.md](../common/patterns.md) with Rust-specific content.
|
|
8
|
+
|
|
9
|
+
## Repository Pattern with Traits
|
|
10
|
+
|
|
11
|
+
Encapsulate data access behind a trait:
|
|
12
|
+
|
|
13
|
+
```rust
|
|
14
|
+
pub trait OrderRepository: Send + Sync {
|
|
15
|
+
fn find_by_id(&self, id: u64) -> Result<Option<Order>, StorageError>;
|
|
16
|
+
fn find_all(&self) -> Result<Vec<Order>, StorageError>;
|
|
17
|
+
fn save(&self, order: &Order) -> Result<Order, StorageError>;
|
|
18
|
+
fn delete(&self, id: u64) -> Result<(), StorageError>;
|
|
19
|
+
}
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
Concrete implementations handle storage details (Postgres, SQLite, in-memory for tests).
|
|
23
|
+
|
|
24
|
+
## Service Layer
|
|
25
|
+
|
|
26
|
+
Business logic in service structs; inject dependencies via constructor:
|
|
27
|
+
|
|
28
|
+
```rust
|
|
29
|
+
pub struct OrderService {
|
|
30
|
+
repo: Box<dyn OrderRepository>,
|
|
31
|
+
payment: Box<dyn PaymentGateway>,
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
impl OrderService {
|
|
35
|
+
pub fn new(repo: Box<dyn OrderRepository>, payment: Box<dyn PaymentGateway>) -> Self {
|
|
36
|
+
Self { repo, payment }
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
pub fn place_order(&self, request: CreateOrderRequest) -> anyhow::Result<OrderSummary> {
|
|
40
|
+
let order = Order::from(request);
|
|
41
|
+
self.payment.charge(order.total())?;
|
|
42
|
+
let saved = self.repo.save(&order)?;
|
|
43
|
+
Ok(OrderSummary::from(saved))
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
## Newtype Pattern for Type Safety
|
|
49
|
+
|
|
50
|
+
Prevent argument mix-ups with distinct wrapper types:
|
|
51
|
+
|
|
52
|
+
```rust
|
|
53
|
+
struct UserId(u64);
|
|
54
|
+
struct OrderId(u64);
|
|
55
|
+
|
|
56
|
+
fn get_order(user: UserId, order: OrderId) -> anyhow::Result<Order> {
|
|
57
|
+
// Can't accidentally swap user and order IDs at call sites
|
|
58
|
+
todo!()
|
|
59
|
+
}
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
## Enum State Machines
|
|
63
|
+
|
|
64
|
+
Model states as enums — make illegal states unrepresentable:
|
|
65
|
+
|
|
66
|
+
```rust
|
|
67
|
+
enum ConnectionState {
|
|
68
|
+
Disconnected,
|
|
69
|
+
Connecting { attempt: u32 },
|
|
70
|
+
Connected { session_id: String },
|
|
71
|
+
Failed { reason: String, retries: u32 },
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
fn handle(state: &ConnectionState) {
|
|
75
|
+
match state {
|
|
76
|
+
ConnectionState::Disconnected => connect(),
|
|
77
|
+
ConnectionState::Connecting { attempt } if *attempt > 3 => abort(),
|
|
78
|
+
ConnectionState::Connecting { .. } => wait(),
|
|
79
|
+
ConnectionState::Connected { session_id } => use_session(session_id),
|
|
80
|
+
ConnectionState::Failed { retries, .. } if *retries < 5 => retry(),
|
|
81
|
+
ConnectionState::Failed { reason, .. } => log_failure(reason),
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
Always match exhaustively — no wildcard `_` for business-critical enums.
|
|
87
|
+
|
|
88
|
+
## Builder Pattern
|
|
89
|
+
|
|
90
|
+
Use for structs with many optional parameters:
|
|
91
|
+
|
|
92
|
+
```rust
|
|
93
|
+
pub struct ServerConfig {
|
|
94
|
+
host: String,
|
|
95
|
+
port: u16,
|
|
96
|
+
max_connections: usize,
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
impl ServerConfig {
|
|
100
|
+
pub fn builder(host: impl Into<String>, port: u16) -> ServerConfigBuilder {
|
|
101
|
+
ServerConfigBuilder {
|
|
102
|
+
host: host.into(),
|
|
103
|
+
port,
|
|
104
|
+
max_connections: 100,
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
pub struct ServerConfigBuilder {
|
|
110
|
+
host: String,
|
|
111
|
+
port: u16,
|
|
112
|
+
max_connections: usize,
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
impl ServerConfigBuilder {
|
|
116
|
+
pub fn max_connections(mut self, n: usize) -> Self {
|
|
117
|
+
self.max_connections = n;
|
|
118
|
+
self
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
pub fn build(self) -> ServerConfig {
|
|
122
|
+
ServerConfig {
|
|
123
|
+
host: self.host,
|
|
124
|
+
port: self.port,
|
|
125
|
+
max_connections: self.max_connections,
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
## Sealed Traits for Extensibility Control
|
|
132
|
+
|
|
133
|
+
Use a private module to seal a trait, preventing external implementations:
|
|
134
|
+
|
|
135
|
+
```rust
|
|
136
|
+
mod private {
|
|
137
|
+
pub trait Sealed {}
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
pub trait Format: private::Sealed {
|
|
141
|
+
fn encode(&self, data: &[u8]) -> Vec<u8>;
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
pub struct Json;
|
|
145
|
+
impl private::Sealed for Json {}
|
|
146
|
+
impl Format for Json {
|
|
147
|
+
fn encode(&self, data: &[u8]) -> Vec<u8> { todo!() }
|
|
148
|
+
}
|
|
149
|
+
```
|
|
150
|
+
|
|
151
|
+
## API Response Envelope
|
|
152
|
+
|
|
153
|
+
Consistent API responses using a generic enum:
|
|
154
|
+
|
|
155
|
+
```rust
|
|
156
|
+
#[derive(Debug, serde::Serialize)]
|
|
157
|
+
#[serde(tag = "status")]
|
|
158
|
+
pub enum ApiResponse<T: serde::Serialize> {
|
|
159
|
+
#[serde(rename = "ok")]
|
|
160
|
+
Ok { data: T },
|
|
161
|
+
#[serde(rename = "error")]
|
|
162
|
+
Error { message: String },
|
|
163
|
+
}
|
|
164
|
+
```
|
|
165
|
+
|
|
166
|
+
## References
|
|
167
|
+
|
|
168
|
+
See skill: `rust-patterns` for comprehensive patterns including ownership, traits, generics, concurrency, and async.
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
---
|
|
2
|
+
paths:
|
|
3
|
+
- "**/*.rs"
|
|
4
|
+
---
|
|
5
|
+
# Rust Security
|
|
6
|
+
|
|
7
|
+
> This file extends [common/security.md](../common/security.md) with Rust-specific content.
|
|
8
|
+
|
|
9
|
+
## Secrets Management
|
|
10
|
+
|
|
11
|
+
- Never hardcode API keys, tokens, or credentials in source code
|
|
12
|
+
- Use environment variables: `std::env::var("API_KEY")`
|
|
13
|
+
- Fail fast if required secrets are missing at startup
|
|
14
|
+
- Keep `.env` files in `.gitignore`
|
|
15
|
+
|
|
16
|
+
```rust
|
|
17
|
+
// BAD
|
|
18
|
+
const API_KEY: &str = "sk-abc123...";
|
|
19
|
+
|
|
20
|
+
// GOOD — environment variable with early validation
|
|
21
|
+
fn load_api_key() -> anyhow::Result<String> {
|
|
22
|
+
std::env::var("PAYMENT_API_KEY")
|
|
23
|
+
.context("PAYMENT_API_KEY must be set")
|
|
24
|
+
}
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
## SQL Injection Prevention
|
|
28
|
+
|
|
29
|
+
- Always use parameterized queries — never format user input into SQL strings
|
|
30
|
+
- Use query builder or ORM (sqlx, diesel, sea-orm) with bind parameters
|
|
31
|
+
|
|
32
|
+
```rust
|
|
33
|
+
// BAD — SQL injection via format string
|
|
34
|
+
let query = format!("SELECT * FROM users WHERE name = '{name}'");
|
|
35
|
+
sqlx::query(&query).fetch_one(&pool).await?;
|
|
36
|
+
|
|
37
|
+
// GOOD — parameterized query with sqlx
|
|
38
|
+
// Placeholder syntax varies by backend: Postgres: $1 | MySQL: ? | SQLite: $1
|
|
39
|
+
sqlx::query("SELECT * FROM users WHERE name = $1")
|
|
40
|
+
.bind(&name)
|
|
41
|
+
.fetch_one(&pool)
|
|
42
|
+
.await?;
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
## Input Validation
|
|
46
|
+
|
|
47
|
+
- Validate all user input at system boundaries before processing
|
|
48
|
+
- Use the type system to enforce invariants (newtype pattern)
|
|
49
|
+
- Parse, don't validate — convert unstructured data to typed structs at the boundary
|
|
50
|
+
- Reject invalid input with clear error messages
|
|
51
|
+
|
|
52
|
+
```rust
|
|
53
|
+
// Parse, don't validate — invalid states are unrepresentable
|
|
54
|
+
pub struct Email(String);
|
|
55
|
+
|
|
56
|
+
impl Email {
|
|
57
|
+
pub fn parse(input: &str) -> Result<Self, ValidationError> {
|
|
58
|
+
let trimmed = input.trim();
|
|
59
|
+
let at_pos = trimmed.find('@')
|
|
60
|
+
.filter(|&p| p > 0 && p < trimmed.len() - 1)
|
|
61
|
+
.ok_or_else(|| ValidationError::InvalidEmail(input.to_string()))?;
|
|
62
|
+
let domain = &trimmed[at_pos + 1..];
|
|
63
|
+
if trimmed.len() > 254 || !domain.contains('.') {
|
|
64
|
+
return Err(ValidationError::InvalidEmail(input.to_string()));
|
|
65
|
+
}
|
|
66
|
+
// For production use, prefer a validated email crate (e.g., `email_address`)
|
|
67
|
+
Ok(Self(trimmed.to_string()))
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
pub fn as_str(&self) -> &str {
|
|
71
|
+
&self.0
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
## Unsafe Code
|
|
77
|
+
|
|
78
|
+
- Minimize `unsafe` blocks — prefer safe abstractions
|
|
79
|
+
- Every `unsafe` block must have a `// SAFETY:` comment explaining the invariant
|
|
80
|
+
- Never use `unsafe` to bypass the borrow checker for convenience
|
|
81
|
+
- Audit all `unsafe` code during review — it is a red flag without justification
|
|
82
|
+
- Prefer `safe` FFI wrappers around C libraries
|
|
83
|
+
|
|
84
|
+
```rust
|
|
85
|
+
// GOOD — safety comment documents ALL required invariants
|
|
86
|
+
let widget: &Widget = {
|
|
87
|
+
// SAFETY: `ptr` is non-null, aligned, points to an initialized Widget,
|
|
88
|
+
// and no mutable references or mutations exist for its lifetime.
|
|
89
|
+
unsafe { &*ptr }
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
// BAD — no safety justification
|
|
93
|
+
unsafe { &*ptr }
|
|
94
|
+
```
|
|
95
|
+
|
|
96
|
+
## Dependency Security
|
|
97
|
+
|
|
98
|
+
- Run `cargo audit` to scan for known CVEs in dependencies
|
|
99
|
+
- Run `cargo deny check` for license and advisory compliance
|
|
100
|
+
- Use `cargo tree` to audit transitive dependencies
|
|
101
|
+
- Keep dependencies updated — set up Dependabot or Renovate
|
|
102
|
+
- Minimize dependency count — evaluate before adding new crates
|
|
103
|
+
|
|
104
|
+
```bash
|
|
105
|
+
# Security audit
|
|
106
|
+
cargo audit
|
|
107
|
+
|
|
108
|
+
# Deny advisories, duplicate versions, and restricted licenses
|
|
109
|
+
cargo deny check
|
|
110
|
+
|
|
111
|
+
# Inspect dependency tree
|
|
112
|
+
cargo tree
|
|
113
|
+
cargo tree -d # Show duplicates only
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
## Error Messages
|
|
117
|
+
|
|
118
|
+
- Never expose internal paths, stack traces, or database errors in API responses
|
|
119
|
+
- Log detailed errors server-side; return generic messages to clients
|
|
120
|
+
- Use `tracing` or `log` for structured server-side logging
|
|
121
|
+
|
|
122
|
+
```rust
|
|
123
|
+
// Map errors to appropriate status codes and generic messages
|
|
124
|
+
// (Example uses axum; adapt the response type to your framework)
|
|
125
|
+
match order_service.find_by_id(id) {
|
|
126
|
+
Ok(order) => Ok((StatusCode::OK, Json(order))),
|
|
127
|
+
Err(ServiceError::NotFound(_)) => {
|
|
128
|
+
tracing::info!(order_id = id, "order not found");
|
|
129
|
+
Err((StatusCode::NOT_FOUND, "Resource not found"))
|
|
130
|
+
}
|
|
131
|
+
Err(e) => {
|
|
132
|
+
tracing::error!(order_id = id, error = %e, "unexpected error");
|
|
133
|
+
Err((StatusCode::INTERNAL_SERVER_ERROR, "Internal server error"))
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
## References
|
|
139
|
+
|
|
140
|
+
See skill: `rust-patterns` for unsafe code guidelines and ownership patterns.
|
|
141
|
+
See skill: `security-review` for general security checklists.
|