claudecode-omc 5.5.2 → 5.6.1
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/.local/skills/de-ai-writing/SKILL.md +243 -0
- package/.local/skills/de-ai-writing/references/chinese-patterns.md +152 -0
- package/.local/skills/de-ai-writing/references/chinese-signals.md +121 -0
- package/.local/skills/de-ai-writing/references/domain-playbooks.md +120 -0
- package/.local/skills/de-ai-writing/references/wikipedia-signs.md +196 -0
- package/README.md +102 -10
- package/bundled/manifest.json +3 -2
- package/bundled/upstream/ecc/.omc-source/bundle.json +23 -0
- package/bundled/upstream/ecc/.omc-source/last-plan-apply.json +439 -0
- package/bundled/upstream/ecc/.omc-source/manifests/.claude-plugin/marketplace.json +47 -0
- package/bundled/upstream/ecc/agents/a11y-architect.md +141 -0
- package/bundled/upstream/ecc/agents/architect.md +211 -0
- package/bundled/upstream/ecc/agents/build-error-resolver.md +114 -0
- package/bundled/upstream/ecc/agents/chief-of-staff.md +151 -0
- package/bundled/upstream/ecc/agents/code-architect.md +71 -0
- package/bundled/upstream/ecc/agents/code-explorer.md +69 -0
- package/bundled/upstream/ecc/agents/code-reviewer.md +237 -0
- package/bundled/upstream/ecc/agents/code-simplifier.md +47 -0
- package/bundled/upstream/ecc/agents/comment-analyzer.md +45 -0
- package/bundled/upstream/ecc/agents/conversation-analyzer.md +52 -0
- package/bundled/upstream/ecc/agents/cpp-build-resolver.md +90 -0
- package/bundled/upstream/ecc/agents/cpp-reviewer.md +72 -0
- package/bundled/upstream/ecc/agents/csharp-reviewer.md +101 -0
- package/bundled/upstream/ecc/agents/dart-build-resolver.md +201 -0
- package/bundled/upstream/ecc/agents/database-reviewer.md +91 -0
- package/bundled/upstream/ecc/agents/doc-updater.md +107 -0
- package/bundled/upstream/ecc/agents/docs-lookup.md +68 -0
- package/bundled/upstream/ecc/agents/e2e-runner.md +107 -0
- package/bundled/upstream/ecc/agents/flutter-reviewer.md +243 -0
- package/bundled/upstream/ecc/agents/gan-evaluator.md +209 -0
- package/bundled/upstream/ecc/agents/gan-generator.md +131 -0
- package/bundled/upstream/ecc/agents/gan-planner.md +99 -0
- package/bundled/upstream/ecc/agents/go-build-resolver.md +94 -0
- package/bundled/upstream/ecc/agents/go-reviewer.md +76 -0
- package/bundled/upstream/ecc/agents/harness-optimizer.md +35 -0
- package/bundled/upstream/ecc/agents/healthcare-reviewer.md +83 -0
- package/bundled/upstream/ecc/agents/java-build-resolver.md +153 -0
- package/bundled/upstream/ecc/agents/java-reviewer.md +92 -0
- package/bundled/upstream/ecc/agents/kotlin-build-resolver.md +118 -0
- package/bundled/upstream/ecc/agents/kotlin-reviewer.md +159 -0
- package/bundled/upstream/ecc/agents/loop-operator.md +36 -0
- package/bundled/upstream/ecc/agents/opensource-forker.md +198 -0
- package/bundled/upstream/ecc/agents/opensource-packager.md +249 -0
- package/bundled/upstream/ecc/agents/opensource-sanitizer.md +188 -0
- package/bundled/upstream/ecc/agents/performance-optimizer.md +446 -0
- package/bundled/upstream/ecc/agents/planner.md +212 -0
- package/bundled/upstream/ecc/agents/pr-test-analyzer.md +45 -0
- package/bundled/upstream/ecc/agents/python-reviewer.md +98 -0
- package/bundled/upstream/ecc/agents/pytorch-build-resolver.md +120 -0
- package/bundled/upstream/ecc/agents/refactor-cleaner.md +85 -0
- package/bundled/upstream/ecc/agents/rust-build-resolver.md +148 -0
- package/bundled/upstream/ecc/agents/rust-reviewer.md +94 -0
- package/bundled/upstream/ecc/agents/security-reviewer.md +108 -0
- package/bundled/upstream/ecc/agents/seo-specialist.md +62 -0
- package/bundled/upstream/ecc/agents/silent-failure-hunter.md +50 -0
- package/bundled/upstream/ecc/agents/tdd-guide.md +91 -0
- package/bundled/upstream/ecc/agents/type-design-analyzer.md +41 -0
- package/bundled/upstream/ecc/agents/typescript-reviewer.md +112 -0
- package/bundled/upstream/ecc/commands/agent-sort.md +23 -0
- package/bundled/upstream/ecc/commands/aside.md +164 -0
- package/bundled/upstream/ecc/commands/build-fix.md +62 -0
- package/bundled/upstream/ecc/commands/checkpoint.md +74 -0
- package/bundled/upstream/ecc/commands/claw.md +23 -0
- package/bundled/upstream/ecc/commands/code-review.md +289 -0
- package/bundled/upstream/ecc/commands/context-budget.md +23 -0
- package/bundled/upstream/ecc/commands/cpp-build.md +173 -0
- package/bundled/upstream/ecc/commands/cpp-review.md +132 -0
- package/bundled/upstream/ecc/commands/cpp-test.md +251 -0
- package/bundled/upstream/ecc/commands/devfleet.md +23 -0
- package/bundled/upstream/ecc/commands/docs.md +23 -0
- package/bundled/upstream/ecc/commands/e2e.md +268 -0
- package/bundled/upstream/ecc/commands/eval.md +23 -0
- package/bundled/upstream/ecc/commands/evolve.md +178 -0
- package/bundled/upstream/ecc/commands/feature-dev.md +49 -0
- package/bundled/upstream/ecc/commands/flutter-build.md +164 -0
- package/bundled/upstream/ecc/commands/flutter-review.md +116 -0
- package/bundled/upstream/ecc/commands/flutter-test.md +144 -0
- package/bundled/upstream/ecc/commands/gan-build.md +99 -0
- package/bundled/upstream/ecc/commands/gan-design.md +35 -0
- package/bundled/upstream/ecc/commands/go-build.md +183 -0
- package/bundled/upstream/ecc/commands/go-review.md +148 -0
- package/bundled/upstream/ecc/commands/go-test.md +268 -0
- package/bundled/upstream/ecc/commands/gradle-build.md +70 -0
- package/bundled/upstream/ecc/commands/harness-audit.md +73 -0
- package/bundled/upstream/ecc/commands/hookify-configure.md +14 -0
- package/bundled/upstream/ecc/commands/hookify-help.md +46 -0
- package/bundled/upstream/ecc/commands/hookify-list.md +21 -0
- package/bundled/upstream/ecc/commands/hookify.md +50 -0
- package/bundled/upstream/ecc/commands/instinct-export.md +66 -0
- package/bundled/upstream/ecc/commands/instinct-import.md +114 -0
- package/bundled/upstream/ecc/commands/instinct-status.md +59 -0
- package/bundled/upstream/ecc/commands/jira.md +106 -0
- package/bundled/upstream/ecc/commands/kotlin-build.md +174 -0
- package/bundled/upstream/ecc/commands/kotlin-review.md +140 -0
- package/bundled/upstream/ecc/commands/kotlin-test.md +312 -0
- package/bundled/upstream/ecc/commands/learn-eval.md +116 -0
- package/bundled/upstream/ecc/commands/learn.md +70 -0
- package/bundled/upstream/ecc/commands/loop-start.md +32 -0
- package/bundled/upstream/ecc/commands/loop-status.md +24 -0
- package/bundled/upstream/ecc/commands/model-route.md +26 -0
- package/bundled/upstream/ecc/commands/multi-backend.md +158 -0
- package/bundled/upstream/ecc/commands/multi-execute.md +315 -0
- package/bundled/upstream/ecc/commands/multi-frontend.md +158 -0
- package/bundled/upstream/ecc/commands/multi-plan.md +268 -0
- package/bundled/upstream/ecc/commands/multi-workflow.md +191 -0
- package/bundled/upstream/ecc/commands/orchestrate.md +135 -0
- package/bundled/upstream/ecc/commands/plan.md +117 -0
- package/bundled/upstream/ecc/commands/pm2.md +272 -0
- package/bundled/upstream/ecc/commands/projects.md +39 -0
- package/bundled/upstream/ecc/commands/promote.md +41 -0
- package/bundled/upstream/ecc/commands/prompt-optimize.md +23 -0
- package/bundled/upstream/ecc/commands/prp-commit.md +112 -0
- package/bundled/upstream/ecc/commands/prp-implement.md +385 -0
- package/bundled/upstream/ecc/commands/prp-plan.md +502 -0
- package/bundled/upstream/ecc/commands/prp-pr.md +184 -0
- package/bundled/upstream/ecc/commands/prp-prd.md +447 -0
- package/bundled/upstream/ecc/commands/prune.md +31 -0
- package/bundled/upstream/ecc/commands/python-review.md +297 -0
- package/bundled/upstream/ecc/commands/quality-gate.md +29 -0
- package/bundled/upstream/ecc/commands/refactor-clean.md +80 -0
- package/bundled/upstream/ecc/commands/resume-session.md +156 -0
- package/bundled/upstream/ecc/commands/review-pr.md +37 -0
- package/bundled/upstream/ecc/commands/rules-distill.md +20 -0
- package/bundled/upstream/ecc/commands/rust-build.md +187 -0
- package/bundled/upstream/ecc/commands/rust-review.md +142 -0
- package/bundled/upstream/ecc/commands/rust-test.md +308 -0
- package/bundled/upstream/ecc/commands/santa-loop.md +175 -0
- package/bundled/upstream/ecc/commands/save-session.md +275 -0
- package/bundled/upstream/ecc/commands/sessions.md +339 -0
- package/bundled/upstream/ecc/commands/setup-pm.md +80 -0
- package/bundled/upstream/ecc/commands/skill-create.md +174 -0
- package/bundled/upstream/ecc/commands/skill-health.md +54 -0
- package/bundled/upstream/ecc/commands/tdd.md +231 -0
- package/bundled/upstream/ecc/commands/test-coverage.md +69 -0
- package/bundled/upstream/ecc/commands/update-codemaps.md +72 -0
- package/bundled/upstream/ecc/commands/update-docs.md +84 -0
- package/bundled/upstream/ecc/commands/verify.md +23 -0
- package/bundled/upstream/ecc/hooks/README.md +237 -0
- package/bundled/upstream/ecc/hooks/hooks.json +330 -0
- package/bundled/upstream/ecc/skills/accessibility/SKILL.md +146 -0
- package/bundled/upstream/ecc/skills/agent-eval/SKILL.md +145 -0
- package/bundled/upstream/ecc/skills/agent-harness-construction/SKILL.md +73 -0
- package/bundled/upstream/ecc/skills/agent-introspection-debugging/SKILL.md +153 -0
- package/bundled/upstream/ecc/skills/agent-payment-x402/SKILL.md +178 -0
- package/bundled/upstream/ecc/skills/agent-sort/SKILL.md +215 -0
- package/bundled/upstream/ecc/skills/agentic-engineering/SKILL.md +63 -0
- package/bundled/upstream/ecc/skills/ai-first-engineering/SKILL.md +51 -0
- package/bundled/upstream/ecc/skills/ai-regression-testing/SKILL.md +385 -0
- package/bundled/upstream/ecc/skills/android-clean-architecture/SKILL.md +339 -0
- package/bundled/upstream/ecc/skills/api-connector-builder/SKILL.md +120 -0
- package/bundled/upstream/ecc/skills/api-design/SKILL.md +523 -0
- package/bundled/upstream/ecc/skills/architecture-decision-records/SKILL.md +179 -0
- package/bundled/upstream/ecc/skills/article-writing/SKILL.md +79 -0
- package/bundled/upstream/ecc/skills/automation-audit-ops/SKILL.md +142 -0
- package/bundled/upstream/ecc/skills/autonomous-agent-harness/SKILL.md +267 -0
- package/bundled/upstream/ecc/skills/autonomous-loops/SKILL.md +610 -0
- package/bundled/upstream/ecc/skills/backend-patterns/SKILL.md +598 -0
- package/bundled/upstream/ecc/skills/benchmark/SKILL.md +93 -0
- package/bundled/upstream/ecc/skills/blueprint/SKILL.md +105 -0
- package/bundled/upstream/ecc/skills/brand-voice/SKILL.md +97 -0
- package/bundled/upstream/ecc/skills/brand-voice/references/voice-profile-schema.md +55 -0
- package/bundled/upstream/ecc/skills/browser-qa/SKILL.md +87 -0
- package/bundled/upstream/ecc/skills/bun-runtime/SKILL.md +84 -0
- package/bundled/upstream/ecc/skills/canary-watch/SKILL.md +99 -0
- package/bundled/upstream/ecc/skills/carrier-relationship-management/SKILL.md +212 -0
- package/bundled/upstream/ecc/skills/ck/SKILL.md +147 -0
- package/bundled/upstream/ecc/skills/ck/commands/forget.mjs +44 -0
- package/bundled/upstream/ecc/skills/ck/commands/info.mjs +24 -0
- package/bundled/upstream/ecc/skills/ck/commands/init.mjs +143 -0
- package/bundled/upstream/ecc/skills/ck/commands/list.mjs +40 -0
- package/bundled/upstream/ecc/skills/ck/commands/migrate.mjs +202 -0
- package/bundled/upstream/ecc/skills/ck/commands/resume.mjs +36 -0
- package/bundled/upstream/ecc/skills/ck/commands/save.mjs +210 -0
- package/bundled/upstream/ecc/skills/ck/commands/shared.mjs +387 -0
- package/bundled/upstream/ecc/skills/ck/hooks/session-start.mjs +224 -0
- package/bundled/upstream/ecc/skills/claude-api/SKILL.md +337 -0
- package/bundled/upstream/ecc/skills/claude-devfleet/SKILL.md +103 -0
- package/bundled/upstream/ecc/skills/click-path-audit/SKILL.md +244 -0
- package/bundled/upstream/ecc/skills/clickhouse-io/SKILL.md +439 -0
- package/bundled/upstream/ecc/skills/code-tour/SKILL.md +236 -0
- package/bundled/upstream/ecc/skills/codebase-onboarding/SKILL.md +233 -0
- package/bundled/upstream/ecc/skills/coding-standards/SKILL.md +549 -0
- package/bundled/upstream/ecc/skills/compose-multiplatform-patterns/SKILL.md +299 -0
- package/bundled/upstream/ecc/skills/configure-ecc/SKILL.md +367 -0
- package/bundled/upstream/ecc/skills/connections-optimizer/SKILL.md +189 -0
- package/bundled/upstream/ecc/skills/content-engine/SKILL.md +131 -0
- package/bundled/upstream/ecc/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/bundled/upstream/ecc/skills/context-budget/SKILL.md +135 -0
- package/bundled/upstream/ecc/skills/continuous-agent-loop/SKILL.md +45 -0
- package/bundled/upstream/ecc/skills/continuous-learning/SKILL.md +123 -0
- package/bundled/upstream/ecc/skills/continuous-learning/config.json +18 -0
- package/bundled/upstream/ecc/skills/continuous-learning/evaluate-session.sh +69 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/SKILL.md +346 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/observer-loop.sh +282 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/config.json +8 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/hooks/observe.sh +460 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/detect-project.sh +243 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/test_parse_instinct.py +984 -0
- package/bundled/upstream/ecc/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/bundled/upstream/ecc/skills/council/SKILL.md +203 -0
- package/bundled/upstream/ecc/skills/cpp-coding-standards/SKILL.md +723 -0
- package/bundled/upstream/ecc/skills/cpp-testing/SKILL.md +324 -0
- package/bundled/upstream/ecc/skills/crosspost/SKILL.md +111 -0
- package/bundled/upstream/ecc/skills/csharp-testing/SKILL.md +321 -0
- package/bundled/upstream/ecc/skills/customer-billing-ops/SKILL.md +140 -0
- package/bundled/upstream/ecc/skills/customs-trade-compliance/SKILL.md +263 -0
- package/bundled/upstream/ecc/skills/dart-flutter-patterns/SKILL.md +563 -0
- package/bundled/upstream/ecc/skills/dashboard-builder/SKILL.md +108 -0
- package/bundled/upstream/ecc/skills/data-scraper-agent/SKILL.md +764 -0
- package/bundled/upstream/ecc/skills/database-migrations/SKILL.md +429 -0
- package/bundled/upstream/ecc/skills/deep-research/SKILL.md +155 -0
- package/bundled/upstream/ecc/skills/defi-amm-security/SKILL.md +160 -0
- package/bundled/upstream/ecc/skills/deployment-patterns/SKILL.md +427 -0
- package/bundled/upstream/ecc/skills/design-system/SKILL.md +82 -0
- package/bundled/upstream/ecc/skills/django-patterns/SKILL.md +734 -0
- package/bundled/upstream/ecc/skills/django-security/SKILL.md +593 -0
- package/bundled/upstream/ecc/skills/django-tdd/SKILL.md +729 -0
- package/bundled/upstream/ecc/skills/django-verification/SKILL.md +469 -0
- package/bundled/upstream/ecc/skills/dmux-workflows/SKILL.md +191 -0
- package/bundled/upstream/ecc/skills/docker-patterns/SKILL.md +364 -0
- package/bundled/upstream/ecc/skills/documentation-lookup/SKILL.md +90 -0
- package/bundled/upstream/ecc/skills/dotnet-patterns/SKILL.md +321 -0
- package/bundled/upstream/ecc/skills/e2e-testing/SKILL.md +326 -0
- package/bundled/upstream/ecc/skills/ecc-tools-cost-audit/SKILL.md +160 -0
- package/bundled/upstream/ecc/skills/email-ops/SKILL.md +121 -0
- package/bundled/upstream/ecc/skills/energy-procurement/SKILL.md +228 -0
- package/bundled/upstream/ecc/skills/enterprise-agent-ops/SKILL.md +50 -0
- package/bundled/upstream/ecc/skills/eval-harness/SKILL.md +270 -0
- package/bundled/upstream/ecc/skills/evm-token-decimals/SKILL.md +130 -0
- package/bundled/upstream/ecc/skills/exa-search/SKILL.md +103 -0
- package/bundled/upstream/ecc/skills/fal-ai-media/SKILL.md +284 -0
- package/bundled/upstream/ecc/skills/finance-billing-ops/SKILL.md +127 -0
- package/bundled/upstream/ecc/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/bundled/upstream/ecc/skills/foundation-models-on-device/SKILL.md +243 -0
- package/bundled/upstream/ecc/skills/frontend-design/SKILL.md +145 -0
- package/bundled/upstream/ecc/skills/frontend-patterns/SKILL.md +642 -0
- package/bundled/upstream/ecc/skills/frontend-slides/SKILL.md +184 -0
- package/bundled/upstream/ecc/skills/frontend-slides/STYLE_PRESETS.md +330 -0
- package/bundled/upstream/ecc/skills/gan-style-harness/SKILL.md +278 -0
- package/bundled/upstream/ecc/skills/gateguard/SKILL.md +121 -0
- package/bundled/upstream/ecc/skills/git-workflow/SKILL.md +715 -0
- package/bundled/upstream/ecc/skills/github-ops/SKILL.md +144 -0
- package/bundled/upstream/ecc/skills/golang-patterns/SKILL.md +674 -0
- package/bundled/upstream/ecc/skills/golang-testing/SKILL.md +720 -0
- package/bundled/upstream/ecc/skills/google-workspace-ops/SKILL.md +95 -0
- package/bundled/upstream/ecc/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/bundled/upstream/ecc/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/bundled/upstream/ecc/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/bundled/upstream/ecc/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/bundled/upstream/ecc/skills/hexagonal-architecture/SKILL.md +276 -0
- package/bundled/upstream/ecc/skills/hipaa-compliance/SKILL.md +78 -0
- package/bundled/upstream/ecc/skills/hookify-rules/SKILL.md +128 -0
- package/bundled/upstream/ecc/skills/inventory-demand-planning/SKILL.md +247 -0
- package/bundled/upstream/ecc/skills/investor-materials/SKILL.md +96 -0
- package/bundled/upstream/ecc/skills/investor-outreach/SKILL.md +91 -0
- package/bundled/upstream/ecc/skills/iterative-retrieval/SKILL.md +211 -0
- package/bundled/upstream/ecc/skills/java-coding-standards/SKILL.md +147 -0
- package/bundled/upstream/ecc/skills/jira-integration/SKILL.md +293 -0
- package/bundled/upstream/ecc/skills/jpa-patterns/SKILL.md +151 -0
- package/bundled/upstream/ecc/skills/knowledge-ops/SKILL.md +154 -0
- package/bundled/upstream/ecc/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/bundled/upstream/ecc/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/bundled/upstream/ecc/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/bundled/upstream/ecc/skills/kotlin-patterns/SKILL.md +711 -0
- package/bundled/upstream/ecc/skills/kotlin-testing/SKILL.md +824 -0
- package/bundled/upstream/ecc/skills/laravel-patterns/SKILL.md +415 -0
- package/bundled/upstream/ecc/skills/laravel-plugin-discovery/SKILL.md +229 -0
- package/bundled/upstream/ecc/skills/laravel-security/SKILL.md +285 -0
- package/bundled/upstream/ecc/skills/laravel-tdd/SKILL.md +283 -0
- package/bundled/upstream/ecc/skills/laravel-verification/SKILL.md +179 -0
- package/bundled/upstream/ecc/skills/lead-intelligence/SKILL.md +321 -0
- package/bundled/upstream/ecc/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/bundled/upstream/ecc/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/bundled/upstream/ecc/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/bundled/upstream/ecc/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/bundled/upstream/ecc/skills/liquid-glass-design/SKILL.md +279 -0
- package/bundled/upstream/ecc/skills/llm-trading-agent-security/SKILL.md +146 -0
- package/bundled/upstream/ecc/skills/logistics-exception-management/SKILL.md +222 -0
- package/bundled/upstream/ecc/skills/manim-video/SKILL.md +89 -0
- package/bundled/upstream/ecc/skills/manim-video/assets/network_graph_scene.py +52 -0
- package/bundled/upstream/ecc/skills/market-research/SKILL.md +75 -0
- package/bundled/upstream/ecc/skills/mcp-server-patterns/SKILL.md +69 -0
- package/bundled/upstream/ecc/skills/messages-ops/SKILL.md +104 -0
- package/bundled/upstream/ecc/skills/nanoclaw-repl/SKILL.md +33 -0
- package/bundled/upstream/ecc/skills/nestjs-patterns/SKILL.md +230 -0
- package/bundled/upstream/ecc/skills/nextjs-turbopack/SKILL.md +44 -0
- package/bundled/upstream/ecc/skills/nodejs-keccak256/SKILL.md +102 -0
- package/bundled/upstream/ecc/skills/nutrient-document-processing/SKILL.md +167 -0
- package/bundled/upstream/ecc/skills/nuxt4-patterns/SKILL.md +100 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/SKILL.md +296 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/gacha.py +224 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/bundled/upstream/ecc/skills/opensource-pipeline/SKILL.md +255 -0
- package/bundled/upstream/ecc/skills/perl-patterns/SKILL.md +504 -0
- package/bundled/upstream/ecc/skills/perl-security/SKILL.md +503 -0
- package/bundled/upstream/ecc/skills/perl-testing/SKILL.md +475 -0
- package/bundled/upstream/ecc/skills/plankton-code-quality/SKILL.md +236 -0
- package/bundled/upstream/ecc/skills/postgres-patterns/SKILL.md +147 -0
- package/bundled/upstream/ecc/skills/product-capability/SKILL.md +141 -0
- package/bundled/upstream/ecc/skills/product-lens/SKILL.md +92 -0
- package/bundled/upstream/ecc/skills/production-scheduling/SKILL.md +238 -0
- package/bundled/upstream/ecc/skills/project-flow-ops/SKILL.md +111 -0
- package/bundled/upstream/ecc/skills/prompt-optimizer/SKILL.md +397 -0
- package/bundled/upstream/ecc/skills/python-patterns/SKILL.md +750 -0
- package/bundled/upstream/ecc/skills/python-testing/SKILL.md +816 -0
- package/bundled/upstream/ecc/skills/pytorch-patterns/SKILL.md +396 -0
- package/bundled/upstream/ecc/skills/quality-nonconformance/SKILL.md +260 -0
- package/bundled/upstream/ecc/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
- package/bundled/upstream/ecc/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/SKILL.md +43 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/3d.md +86 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/animations.md +29 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets.md +78 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/audio.md +172 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/charts.md +58 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/images.md +130 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/timing.md +179 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/videos.md +171 -0
- package/bundled/upstream/ecc/skills/repo-scan/SKILL.md +78 -0
- package/bundled/upstream/ecc/skills/research-ops/SKILL.md +112 -0
- package/bundled/upstream/ecc/skills/returns-reverse-logistics/SKILL.md +240 -0
- package/bundled/upstream/ecc/skills/rules-distill/SKILL.md +264 -0
- package/bundled/upstream/ecc/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/bundled/upstream/ecc/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/bundled/upstream/ecc/skills/rust-patterns/SKILL.md +499 -0
- package/bundled/upstream/ecc/skills/rust-testing/SKILL.md +500 -0
- package/bundled/upstream/ecc/skills/safety-guard/SKILL.md +75 -0
- package/bundled/upstream/ecc/skills/santa-method/SKILL.md +306 -0
- package/bundled/upstream/ecc/skills/search-first/SKILL.md +161 -0
- package/bundled/upstream/ecc/skills/security-bounty-hunter/SKILL.md +99 -0
- package/bundled/upstream/ecc/skills/security-review/SKILL.md +495 -0
- package/bundled/upstream/ecc/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/bundled/upstream/ecc/skills/security-scan/SKILL.md +165 -0
- package/bundled/upstream/ecc/skills/seo/SKILL.md +154 -0
- package/bundled/upstream/ecc/skills/skill-comply/SKILL.md +58 -0
- package/bundled/upstream/ecc/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
- package/bundled/upstream/ecc/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
- package/bundled/upstream/ecc/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
- package/bundled/upstream/ecc/skills/skill-comply/prompts/classifier.md +24 -0
- package/bundled/upstream/ecc/skills/skill-comply/prompts/scenario_generator.md +62 -0
- package/bundled/upstream/ecc/skills/skill-comply/prompts/spec_generator.md +42 -0
- package/bundled/upstream/ecc/skills/skill-comply/pyproject.toml +15 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/__init__.py +0 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/classifier.py +85 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/grader.py +124 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/parser.py +107 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/report.py +170 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/run.py +127 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/runner.py +161 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/scenario_generator.py +70 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/spec_generator.py +72 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/utils.py +13 -0
- package/bundled/upstream/ecc/skills/skill-comply/tests/test_grader.py +197 -0
- package/bundled/upstream/ecc/skills/skill-comply/tests/test_parser.py +90 -0
- package/bundled/upstream/ecc/skills/skill-stocktake/SKILL.md +193 -0
- package/bundled/upstream/ecc/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/bundled/upstream/ecc/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/bundled/upstream/ecc/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/bundled/upstream/ecc/skills/social-graph-ranker/SKILL.md +154 -0
- package/bundled/upstream/ecc/skills/springboot-patterns/SKILL.md +314 -0
- package/bundled/upstream/ecc/skills/springboot-security/SKILL.md +272 -0
- package/bundled/upstream/ecc/skills/springboot-tdd/SKILL.md +158 -0
- package/bundled/upstream/ecc/skills/springboot-verification/SKILL.md +231 -0
- package/bundled/upstream/ecc/skills/strategic-compact/SKILL.md +131 -0
- package/bundled/upstream/ecc/skills/strategic-compact/suggest-compact.sh +54 -0
- package/bundled/upstream/ecc/skills/swift-actor-persistence/SKILL.md +143 -0
- package/bundled/upstream/ecc/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/bundled/upstream/ecc/skills/swift-protocol-di-testing/SKILL.md +190 -0
- package/bundled/upstream/ecc/skills/swiftui-patterns/SKILL.md +259 -0
- package/bundled/upstream/ecc/skills/tdd-workflow/SKILL.md +463 -0
- package/bundled/upstream/ecc/skills/team-builder/SKILL.md +168 -0
- package/bundled/upstream/ecc/skills/terminal-ops/SKILL.md +109 -0
- package/bundled/upstream/ecc/skills/token-budget-advisor/SKILL.md +133 -0
- package/bundled/upstream/ecc/skills/ui-demo/SKILL.md +465 -0
- package/bundled/upstream/ecc/skills/unified-notifications-ops/SKILL.md +187 -0
- package/bundled/upstream/ecc/skills/verification-loop/SKILL.md +126 -0
- package/bundled/upstream/ecc/skills/video-editing/SKILL.md +310 -0
- package/bundled/upstream/ecc/skills/videodb/SKILL.md +374 -0
- package/bundled/upstream/ecc/skills/videodb/reference/api-reference.md +550 -0
- package/bundled/upstream/ecc/skills/videodb/reference/capture-reference.md +407 -0
- package/bundled/upstream/ecc/skills/videodb/reference/capture.md +101 -0
- package/bundled/upstream/ecc/skills/videodb/reference/editor.md +443 -0
- package/bundled/upstream/ecc/skills/videodb/reference/generative.md +331 -0
- package/bundled/upstream/ecc/skills/videodb/reference/rtstream-reference.md +564 -0
- package/bundled/upstream/ecc/skills/videodb/reference/rtstream.md +65 -0
- package/bundled/upstream/ecc/skills/videodb/reference/search.md +230 -0
- package/bundled/upstream/ecc/skills/videodb/reference/streaming.md +406 -0
- package/bundled/upstream/ecc/skills/videodb/reference/use-cases.md +118 -0
- package/bundled/upstream/ecc/skills/videodb/scripts/ws_listener.py +282 -0
- package/bundled/upstream/ecc/skills/visa-doc-translate/README.md +86 -0
- package/bundled/upstream/ecc/skills/visa-doc-translate/SKILL.md +117 -0
- package/bundled/upstream/ecc/skills/workspace-surface-audit/SKILL.md +125 -0
- package/bundled/upstream/ecc/skills/x-api/SKILL.md +230 -0
- package/bundled/upstream/superpowers/.omc-source/last-plan-apply.json +22 -0
- package/package.json +3 -1
- package/src/catalog/source-catalog.js +391 -0
- package/src/cli/artifact.js +3 -2
- package/src/cli/doctor.js +25 -4
- package/src/cli/index.js +19 -0
- package/src/cli/plan.js +220 -0
- package/src/cli/setup.js +209 -12
- package/src/cli/source.js +110 -3
- package/src/config/paths.js +31 -0
- package/src/config/sources.js +103 -10
- package/src/merge/hook-merger.js +1 -0
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: kotlin-reviewer
|
|
3
|
+
description: Kotlin and Android/KMP code reviewer. Reviews Kotlin code for idiomatic patterns, coroutine safety, Compose best practices, clean architecture violations, and common Android pitfalls.
|
|
4
|
+
tools: ["Read", "Grep", "Glob", "Bash"]
|
|
5
|
+
model: sonnet
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
You are a senior Kotlin and Android/KMP code reviewer ensuring idiomatic, safe, and maintainable code.
|
|
9
|
+
|
|
10
|
+
## Your Role
|
|
11
|
+
|
|
12
|
+
- Review Kotlin code for idiomatic patterns and Android/KMP best practices
|
|
13
|
+
- Detect coroutine misuse, Flow anti-patterns, and lifecycle bugs
|
|
14
|
+
- Enforce clean architecture module boundaries
|
|
15
|
+
- Identify Compose performance issues and recomposition traps
|
|
16
|
+
- You DO NOT refactor or rewrite code — you report findings only
|
|
17
|
+
|
|
18
|
+
## Workflow
|
|
19
|
+
|
|
20
|
+
### Step 1: Gather Context
|
|
21
|
+
|
|
22
|
+
Run `git diff --staged` and `git diff` to see changes. If no diff, check `git log --oneline -5`. Identify Kotlin/KTS files that changed.
|
|
23
|
+
|
|
24
|
+
### Step 2: Understand Project Structure
|
|
25
|
+
|
|
26
|
+
Check for:
|
|
27
|
+
- `build.gradle.kts` or `settings.gradle.kts` to understand module layout
|
|
28
|
+
- `CLAUDE.md` for project-specific conventions
|
|
29
|
+
- Whether this is Android-only, KMP, or Compose Multiplatform
|
|
30
|
+
|
|
31
|
+
### Step 2b: Security Review
|
|
32
|
+
|
|
33
|
+
Apply the Kotlin/Android security guidance before continuing:
|
|
34
|
+
- exported Android components, deep links, and intent filters
|
|
35
|
+
- insecure crypto, WebView, and network configuration usage
|
|
36
|
+
- keystore, token, and credential handling
|
|
37
|
+
- platform-specific storage and permission risks
|
|
38
|
+
|
|
39
|
+
If you find a CRITICAL security issue, stop the review and hand off to `security-reviewer` before doing any further analysis.
|
|
40
|
+
|
|
41
|
+
### Step 3: Read and Review
|
|
42
|
+
|
|
43
|
+
Read changed files fully. Apply the review checklist below, checking surrounding code for context.
|
|
44
|
+
|
|
45
|
+
### Step 4: Report Findings
|
|
46
|
+
|
|
47
|
+
Use the output format below. Only report issues with >80% confidence.
|
|
48
|
+
|
|
49
|
+
## Review Checklist
|
|
50
|
+
|
|
51
|
+
### Architecture (CRITICAL)
|
|
52
|
+
|
|
53
|
+
- **Domain importing framework** — `domain` module must not import Android, Ktor, Room, or any framework
|
|
54
|
+
- **Data layer leaking to UI** — Entities or DTOs exposed to presentation layer (must map to domain models)
|
|
55
|
+
- **ViewModel business logic** — Complex logic belongs in UseCases, not ViewModels
|
|
56
|
+
- **Circular dependencies** — Module A depends on B and B depends on A
|
|
57
|
+
|
|
58
|
+
### Coroutines & Flows (HIGH)
|
|
59
|
+
|
|
60
|
+
- **GlobalScope usage** — Must use structured scopes (`viewModelScope`, `coroutineScope`)
|
|
61
|
+
- **Catching CancellationException** — Must rethrow or not catch; swallowing breaks cancellation
|
|
62
|
+
- **Missing `withContext` for IO** — Database/network calls on `Dispatchers.Main`
|
|
63
|
+
- **StateFlow with mutable state** — Using mutable collections inside StateFlow (must copy)
|
|
64
|
+
- **Flow collection in `init {}`** — Should use `stateIn()` or launch in scope
|
|
65
|
+
- **Missing `WhileSubscribed`** — `stateIn(scope, SharingStarted.Eagerly)` when `WhileSubscribed` is appropriate
|
|
66
|
+
|
|
67
|
+
```kotlin
|
|
68
|
+
// BAD — swallows cancellation
|
|
69
|
+
try { fetchData() } catch (e: Exception) { log(e) }
|
|
70
|
+
|
|
71
|
+
// GOOD — preserves cancellation
|
|
72
|
+
try { fetchData() } catch (e: CancellationException) { throw e } catch (e: Exception) { log(e) }
|
|
73
|
+
// or use runCatching and check
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
### Compose (HIGH)
|
|
77
|
+
|
|
78
|
+
- **Unstable parameters** — Composables receiving mutable types cause unnecessary recomposition
|
|
79
|
+
- **Side effects outside LaunchedEffect** — Network/DB calls must be in `LaunchedEffect` or ViewModel
|
|
80
|
+
- **NavController passed deep** — Pass lambdas instead of `NavController` references
|
|
81
|
+
- **Missing `key()` in LazyColumn** — Items without stable keys cause poor performance
|
|
82
|
+
- **`remember` with missing keys** — Computation not recalculated when dependencies change
|
|
83
|
+
- **Object allocation in parameters** — Creating objects inline causes recomposition
|
|
84
|
+
|
|
85
|
+
```kotlin
|
|
86
|
+
// BAD — new lambda every recomposition
|
|
87
|
+
Button(onClick = { viewModel.doThing(item.id) })
|
|
88
|
+
|
|
89
|
+
// GOOD — stable reference
|
|
90
|
+
val onClick = remember(item.id) { { viewModel.doThing(item.id) } }
|
|
91
|
+
Button(onClick = onClick)
|
|
92
|
+
```
|
|
93
|
+
|
|
94
|
+
### Kotlin Idioms (MEDIUM)
|
|
95
|
+
|
|
96
|
+
- **`!!` usage** — Non-null assertion; prefer `?.`, `?:`, `requireNotNull`, or `checkNotNull`
|
|
97
|
+
- **`var` where `val` works** — Prefer immutability
|
|
98
|
+
- **Java-style patterns** — Static utility classes (use top-level functions), getters/setters (use properties)
|
|
99
|
+
- **String concatenation** — Use string templates `"Hello $name"` instead of `"Hello " + name`
|
|
100
|
+
- **`when` without exhaustive branches** — Sealed classes/interfaces should use exhaustive `when`
|
|
101
|
+
- **Mutable collections exposed** — Return `List` not `MutableList` from public APIs
|
|
102
|
+
|
|
103
|
+
### Android Specific (MEDIUM)
|
|
104
|
+
|
|
105
|
+
- **Context leaks** — Storing `Activity` or `Fragment` references in singletons/ViewModels
|
|
106
|
+
- **Missing ProGuard rules** — Serialized classes without `@Keep` or ProGuard rules
|
|
107
|
+
- **Hardcoded strings** — User-facing strings not in `strings.xml` or Compose resources
|
|
108
|
+
- **Missing lifecycle handling** — Collecting Flows in Activities without `repeatOnLifecycle`
|
|
109
|
+
|
|
110
|
+
### Security (CRITICAL)
|
|
111
|
+
|
|
112
|
+
- **Exported component exposure** — Activities, services, or receivers exported without proper guards
|
|
113
|
+
- **Insecure crypto/storage** — Homegrown crypto, plaintext secrets, or weak keystore usage
|
|
114
|
+
- **Unsafe WebView/network config** — JavaScript bridges, cleartext traffic, permissive trust settings
|
|
115
|
+
- **Sensitive logging** — Tokens, credentials, PII, or secrets emitted to logs
|
|
116
|
+
|
|
117
|
+
If any CRITICAL security issue is present, stop and escalate to `security-reviewer`.
|
|
118
|
+
|
|
119
|
+
### Gradle & Build (LOW)
|
|
120
|
+
|
|
121
|
+
- **Version catalog not used** — Hardcoded versions instead of `libs.versions.toml`
|
|
122
|
+
- **Unnecessary dependencies** — Dependencies added but not used
|
|
123
|
+
- **Missing KMP source sets** — Declaring `androidMain` code that could be `commonMain`
|
|
124
|
+
|
|
125
|
+
## Output Format
|
|
126
|
+
|
|
127
|
+
```
|
|
128
|
+
[CRITICAL] Domain module imports Android framework
|
|
129
|
+
File: domain/src/main/kotlin/com/app/domain/UserUseCase.kt:3
|
|
130
|
+
Issue: `import android.content.Context` — domain must be pure Kotlin with no framework dependencies.
|
|
131
|
+
Fix: Move Context-dependent logic to data or platforms layer. Pass data via repository interface.
|
|
132
|
+
|
|
133
|
+
[HIGH] StateFlow holding mutable list
|
|
134
|
+
File: presentation/src/main/kotlin/com/app/ui/ListViewModel.kt:25
|
|
135
|
+
Issue: `_state.value.items.add(newItem)` mutates the list inside StateFlow — Compose won't detect the change.
|
|
136
|
+
Fix: Use `_state.update { it.copy(items = it.items + newItem) }`
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
## Summary Format
|
|
140
|
+
|
|
141
|
+
End every review with:
|
|
142
|
+
|
|
143
|
+
```
|
|
144
|
+
## Review Summary
|
|
145
|
+
|
|
146
|
+
| Severity | Count | Status |
|
|
147
|
+
|----------|-------|--------|
|
|
148
|
+
| CRITICAL | 0 | pass |
|
|
149
|
+
| HIGH | 1 | block |
|
|
150
|
+
| MEDIUM | 2 | info |
|
|
151
|
+
| LOW | 0 | note |
|
|
152
|
+
|
|
153
|
+
Verdict: BLOCK — HIGH issues must be fixed before merge.
|
|
154
|
+
```
|
|
155
|
+
|
|
156
|
+
## Approval Criteria
|
|
157
|
+
|
|
158
|
+
- **Approve**: No CRITICAL or HIGH issues
|
|
159
|
+
- **Block**: Any CRITICAL or HIGH issues — must fix before merge
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: loop-operator
|
|
3
|
+
description: Operate autonomous agent loops, monitor progress, and intervene safely when loops stall.
|
|
4
|
+
tools: ["Read", "Grep", "Glob", "Bash", "Edit"]
|
|
5
|
+
model: sonnet
|
|
6
|
+
color: orange
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
You are the loop operator.
|
|
10
|
+
|
|
11
|
+
## Mission
|
|
12
|
+
|
|
13
|
+
Run autonomous loops safely with clear stop conditions, observability, and recovery actions.
|
|
14
|
+
|
|
15
|
+
## Workflow
|
|
16
|
+
|
|
17
|
+
1. Start loop from explicit pattern and mode.
|
|
18
|
+
2. Track progress checkpoints.
|
|
19
|
+
3. Detect stalls and retry storms.
|
|
20
|
+
4. Pause and reduce scope when failure repeats.
|
|
21
|
+
5. Resume only after verification passes.
|
|
22
|
+
|
|
23
|
+
## Required Checks
|
|
24
|
+
|
|
25
|
+
- quality gates are active
|
|
26
|
+
- eval baseline exists
|
|
27
|
+
- rollback path exists
|
|
28
|
+
- branch/worktree isolation is configured
|
|
29
|
+
|
|
30
|
+
## Escalation
|
|
31
|
+
|
|
32
|
+
Escalate when any condition is true:
|
|
33
|
+
- no progress across two consecutive checkpoints
|
|
34
|
+
- repeated failures with identical stack traces
|
|
35
|
+
- cost drift outside budget window
|
|
36
|
+
- merge conflicts blocking queue advancement
|
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: opensource-forker
|
|
3
|
+
description: Fork any project for open-sourcing. Copies files, strips secrets and credentials (20+ patterns), replaces internal references with placeholders, generates .env.example, and cleans git history. First stage of the opensource-pipeline skill.
|
|
4
|
+
tools: ["Read", "Write", "Edit", "Bash", "Grep", "Glob"]
|
|
5
|
+
model: sonnet
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Open-Source Forker
|
|
9
|
+
|
|
10
|
+
You fork private/internal projects into clean, open-source-ready copies. You are the first stage of the open-source pipeline.
|
|
11
|
+
|
|
12
|
+
## Your Role
|
|
13
|
+
|
|
14
|
+
- Copy a project to a staging directory, excluding secrets and generated files
|
|
15
|
+
- Strip all secrets, credentials, and tokens from source files
|
|
16
|
+
- Replace internal references (domains, paths, IPs) with configurable placeholders
|
|
17
|
+
- Generate `.env.example` from every extracted value
|
|
18
|
+
- Create a fresh git history (single initial commit)
|
|
19
|
+
- Generate `FORK_REPORT.md` documenting all changes
|
|
20
|
+
|
|
21
|
+
## Workflow
|
|
22
|
+
|
|
23
|
+
### Step 1: Analyze Source
|
|
24
|
+
|
|
25
|
+
Read the project to understand stack and sensitive surface area:
|
|
26
|
+
- Tech stack: `package.json`, `requirements.txt`, `Cargo.toml`, `go.mod`
|
|
27
|
+
- Config files: `.env`, `config/`, `docker-compose.yml`
|
|
28
|
+
- CI/CD: `.github/`, `.gitlab-ci.yml`
|
|
29
|
+
- Docs: `README.md`, `CLAUDE.md`
|
|
30
|
+
|
|
31
|
+
```bash
|
|
32
|
+
find SOURCE_DIR -type f | grep -v node_modules | grep -v .git | grep -v __pycache__
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
### Step 2: Create Staging Copy
|
|
36
|
+
|
|
37
|
+
```bash
|
|
38
|
+
mkdir -p TARGET_DIR
|
|
39
|
+
rsync -av --exclude='.git' --exclude='node_modules' --exclude='__pycache__' \
|
|
40
|
+
--exclude='.env*' --exclude='*.pyc' --exclude='.venv' --exclude='venv' \
|
|
41
|
+
--exclude='.claude/' --exclude='.secrets/' --exclude='secrets/' \
|
|
42
|
+
SOURCE_DIR/ TARGET_DIR/
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
### Step 3: Secret Detection and Stripping
|
|
46
|
+
|
|
47
|
+
Scan ALL files for these patterns. Extract values to `.env.example` rather than deleting them:
|
|
48
|
+
|
|
49
|
+
```
|
|
50
|
+
# API keys and tokens
|
|
51
|
+
[A-Za-z0-9_]*(KEY|TOKEN|SECRET|PASSWORD|PASS|API_KEY|AUTH)[A-Za-z0-9_]*\s*[=:]\s*['\"]?[A-Za-z0-9+/=_-]{8,}
|
|
52
|
+
|
|
53
|
+
# AWS credentials
|
|
54
|
+
AKIA[0-9A-Z]{16}
|
|
55
|
+
(?i)(aws_secret_access_key|aws_secret)\s*[=:]\s*['"]?[A-Za-z0-9+/=]{20,}
|
|
56
|
+
|
|
57
|
+
# Database connection strings
|
|
58
|
+
(postgres|mysql|mongodb|redis):\/\/[^\s'"]+
|
|
59
|
+
|
|
60
|
+
# JWT tokens (3-segment: header.payload.signature)
|
|
61
|
+
eyJ[A-Za-z0-9_-]+\.eyJ[A-Za-z0-9_-]+\.[A-Za-z0-9_-]+
|
|
62
|
+
|
|
63
|
+
# Private keys
|
|
64
|
+
-----BEGIN (RSA |EC |DSA )?PRIVATE KEY-----
|
|
65
|
+
|
|
66
|
+
# GitHub tokens (personal, server, OAuth, user-to-server)
|
|
67
|
+
gh[pousr]_[A-Za-z0-9_]{36,}
|
|
68
|
+
github_pat_[A-Za-z0-9_]{22,}
|
|
69
|
+
|
|
70
|
+
# Google OAuth
|
|
71
|
+
GOCSPX-[A-Za-z0-9_-]+
|
|
72
|
+
[0-9]+-[a-z0-9]+\.apps\.googleusercontent\.com
|
|
73
|
+
|
|
74
|
+
# Slack webhooks
|
|
75
|
+
https://hooks\.slack\.com/services/T[A-Z0-9]+/B[A-Z0-9]+/[A-Za-z0-9]+
|
|
76
|
+
|
|
77
|
+
# SendGrid / Mailgun
|
|
78
|
+
SG\.[A-Za-z0-9_-]{22}\.[A-Za-z0-9_-]{43}
|
|
79
|
+
key-[A-Za-z0-9]{32}
|
|
80
|
+
|
|
81
|
+
# Generic env file secrets (WARNING — manual review, do NOT auto-strip)
|
|
82
|
+
^[A-Z_]+=((?!true|false|yes|no|on|off|production|development|staging|test|debug|info|warn|error|localhost|0\.0\.0\.0|127\.0\.0\.1|\d+$).{16,})$
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
**Files to always remove:**
|
|
86
|
+
- `.env` and variants (`.env.local`, `.env.production`, `.env.development`)
|
|
87
|
+
- `*.pem`, `*.key`, `*.p12`, `*.pfx` (private keys)
|
|
88
|
+
- `credentials.json`, `service-account.json`
|
|
89
|
+
- `.secrets/`, `secrets/`
|
|
90
|
+
- `.claude/settings.json`
|
|
91
|
+
- `sessions/`
|
|
92
|
+
- `*.map` (source maps expose original source structure and file paths)
|
|
93
|
+
|
|
94
|
+
**Files to strip content from (not remove):**
|
|
95
|
+
- `docker-compose.yml` — replace hardcoded values with `${VAR_NAME}`
|
|
96
|
+
- `config/` files — parameterize secrets
|
|
97
|
+
- `nginx.conf` — replace internal domains
|
|
98
|
+
|
|
99
|
+
### Step 4: Internal Reference Replacement
|
|
100
|
+
|
|
101
|
+
| Pattern | Replacement |
|
|
102
|
+
|---------|-------------|
|
|
103
|
+
| Custom internal domains | `your-domain.com` |
|
|
104
|
+
| Absolute home paths `/home/username/` | `/home/user/` or `$HOME/` |
|
|
105
|
+
| Secret file references `~/.secrets/` | `.env` |
|
|
106
|
+
| Private IPs `192.168.x.x`, `10.x.x.x` | `your-server-ip` |
|
|
107
|
+
| Internal service URLs | Generic placeholders |
|
|
108
|
+
| Personal email addresses | `you@your-domain.com` |
|
|
109
|
+
| Internal GitHub org names | `your-github-org` |
|
|
110
|
+
|
|
111
|
+
Preserve functionality — every replacement gets a corresponding entry in `.env.example`.
|
|
112
|
+
|
|
113
|
+
### Step 5: Generate .env.example
|
|
114
|
+
|
|
115
|
+
```bash
|
|
116
|
+
# Application Configuration
|
|
117
|
+
# Copy this file to .env and fill in your values
|
|
118
|
+
# cp .env.example .env
|
|
119
|
+
|
|
120
|
+
# === Required ===
|
|
121
|
+
APP_NAME=my-project
|
|
122
|
+
APP_DOMAIN=your-domain.com
|
|
123
|
+
APP_PORT=8080
|
|
124
|
+
|
|
125
|
+
# === Database ===
|
|
126
|
+
DATABASE_URL=postgresql://user:password@localhost:5432/mydb
|
|
127
|
+
REDIS_URL=redis://localhost:6379
|
|
128
|
+
|
|
129
|
+
# === Secrets (REQUIRED — generate your own) ===
|
|
130
|
+
SECRET_KEY=change-me-to-a-random-string
|
|
131
|
+
JWT_SECRET=change-me-to-a-random-string
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
### Step 6: Clean Git History
|
|
135
|
+
|
|
136
|
+
```bash
|
|
137
|
+
cd TARGET_DIR
|
|
138
|
+
git init
|
|
139
|
+
git add -A
|
|
140
|
+
git commit -m "Initial open-source release
|
|
141
|
+
|
|
142
|
+
Forked from private source. All secrets stripped, internal references
|
|
143
|
+
replaced with configurable placeholders. See .env.example for configuration."
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
### Step 7: Generate Fork Report
|
|
147
|
+
|
|
148
|
+
Create `FORK_REPORT.md` in the staging directory:
|
|
149
|
+
|
|
150
|
+
```markdown
|
|
151
|
+
# Fork Report: {project-name}
|
|
152
|
+
|
|
153
|
+
**Source:** {source-path}
|
|
154
|
+
**Target:** {target-path}
|
|
155
|
+
**Date:** {date}
|
|
156
|
+
|
|
157
|
+
## Files Removed
|
|
158
|
+
- .env (contained N secrets)
|
|
159
|
+
|
|
160
|
+
## Secrets Extracted -> .env.example
|
|
161
|
+
- DATABASE_URL (was hardcoded in docker-compose.yml)
|
|
162
|
+
- API_KEY (was in config/settings.py)
|
|
163
|
+
|
|
164
|
+
## Internal References Replaced
|
|
165
|
+
- internal.example.com -> your-domain.com (N occurrences in N files)
|
|
166
|
+
- /home/username -> /home/user (N occurrences in N files)
|
|
167
|
+
|
|
168
|
+
## Warnings
|
|
169
|
+
- [ ] Any items needing manual review
|
|
170
|
+
|
|
171
|
+
## Next Step
|
|
172
|
+
Run opensource-sanitizer to verify sanitization is complete.
|
|
173
|
+
```
|
|
174
|
+
|
|
175
|
+
## Output Format
|
|
176
|
+
|
|
177
|
+
On completion, report:
|
|
178
|
+
- Files copied, files removed, files modified
|
|
179
|
+
- Number of secrets extracted to `.env.example`
|
|
180
|
+
- Number of internal references replaced
|
|
181
|
+
- Location of `FORK_REPORT.md`
|
|
182
|
+
- "Next step: run opensource-sanitizer"
|
|
183
|
+
|
|
184
|
+
## Examples
|
|
185
|
+
|
|
186
|
+
### Example: Fork a FastAPI service
|
|
187
|
+
Input: `Fork project: /home/user/my-api, Target: /home/user/opensource-staging/my-api, License: MIT`
|
|
188
|
+
Action: Copies files, strips `DATABASE_URL` from `docker-compose.yml`, replaces `internal.company.com` with `your-domain.com`, creates `.env.example` with 8 variables, fresh git init
|
|
189
|
+
Output: `FORK_REPORT.md` listing all changes, staging directory ready for sanitizer
|
|
190
|
+
|
|
191
|
+
## Rules
|
|
192
|
+
|
|
193
|
+
- **Never** leave any secret in output, even commented out
|
|
194
|
+
- **Never** remove functionality — always parameterize, do not delete config
|
|
195
|
+
- **Always** generate `.env.example` for every extracted value
|
|
196
|
+
- **Always** create `FORK_REPORT.md`
|
|
197
|
+
- If unsure whether something is a secret, treat it as one
|
|
198
|
+
- Do not modify source code logic — only configuration and references
|
|
@@ -0,0 +1,249 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: opensource-packager
|
|
3
|
+
description: Generate complete open-source packaging for a sanitized project. Produces CLAUDE.md, setup.sh, README.md, LICENSE, CONTRIBUTING.md, and GitHub issue templates. Makes any repo immediately usable with Claude Code. Third stage of the opensource-pipeline skill.
|
|
4
|
+
tools: ["Read", "Write", "Edit", "Bash", "Grep", "Glob"]
|
|
5
|
+
model: sonnet
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Open-Source Packager
|
|
9
|
+
|
|
10
|
+
You generate complete open-source packaging for a sanitized project. Your goal: anyone should be able to fork, run `setup.sh`, and be productive within minutes — especially with Claude Code.
|
|
11
|
+
|
|
12
|
+
## Your Role
|
|
13
|
+
|
|
14
|
+
- Analyze project structure, stack, and purpose
|
|
15
|
+
- Generate `CLAUDE.md` (the most important file — gives Claude Code full context)
|
|
16
|
+
- Generate `setup.sh` (one-command bootstrap)
|
|
17
|
+
- Generate or enhance `README.md`
|
|
18
|
+
- Add `LICENSE`
|
|
19
|
+
- Add `CONTRIBUTING.md`
|
|
20
|
+
- Add `.github/ISSUE_TEMPLATE/` if a GitHub repo is specified
|
|
21
|
+
|
|
22
|
+
## Workflow
|
|
23
|
+
|
|
24
|
+
### Step 1: Project Analysis
|
|
25
|
+
|
|
26
|
+
Read and understand:
|
|
27
|
+
- `package.json` / `requirements.txt` / `Cargo.toml` / `go.mod` (stack detection)
|
|
28
|
+
- `docker-compose.yml` (services, ports, dependencies)
|
|
29
|
+
- `Makefile` / `Justfile` (existing commands)
|
|
30
|
+
- Existing `README.md` (preserve useful content)
|
|
31
|
+
- Source code structure (main entry points, key directories)
|
|
32
|
+
- `.env.example` (required configuration)
|
|
33
|
+
- Test framework (jest, pytest, vitest, go test, etc.)
|
|
34
|
+
|
|
35
|
+
### Step 2: Generate CLAUDE.md
|
|
36
|
+
|
|
37
|
+
This is the most important file. Keep it under 100 lines — concise is critical.
|
|
38
|
+
|
|
39
|
+
```markdown
|
|
40
|
+
# {Project Name}
|
|
41
|
+
|
|
42
|
+
**Version:** {version} | **Port:** {port} | **Stack:** {detected stack}
|
|
43
|
+
|
|
44
|
+
## What
|
|
45
|
+
{1-2 sentence description of what this project does}
|
|
46
|
+
|
|
47
|
+
## Quick Start
|
|
48
|
+
|
|
49
|
+
\`\`\`bash
|
|
50
|
+
./setup.sh # First-time setup
|
|
51
|
+
{dev command} # Start development server
|
|
52
|
+
{test command} # Run tests
|
|
53
|
+
\`\`\`
|
|
54
|
+
|
|
55
|
+
## Commands
|
|
56
|
+
|
|
57
|
+
\`\`\`bash
|
|
58
|
+
# Development
|
|
59
|
+
{install command} # Install dependencies
|
|
60
|
+
{dev server command} # Start dev server
|
|
61
|
+
{lint command} # Run linter
|
|
62
|
+
{build command} # Production build
|
|
63
|
+
|
|
64
|
+
# Testing
|
|
65
|
+
{test command} # Run tests
|
|
66
|
+
{coverage command} # Run with coverage
|
|
67
|
+
|
|
68
|
+
# Docker
|
|
69
|
+
cp .env.example .env
|
|
70
|
+
docker compose up -d --build
|
|
71
|
+
\`\`\`
|
|
72
|
+
|
|
73
|
+
## Architecture
|
|
74
|
+
|
|
75
|
+
\`\`\`
|
|
76
|
+
{directory tree of key folders with 1-line descriptions}
|
|
77
|
+
\`\`\`
|
|
78
|
+
|
|
79
|
+
{2-3 sentences: what talks to what, data flow}
|
|
80
|
+
|
|
81
|
+
## Key Files
|
|
82
|
+
|
|
83
|
+
\`\`\`
|
|
84
|
+
{list 5-10 most important files with their purpose}
|
|
85
|
+
\`\`\`
|
|
86
|
+
|
|
87
|
+
## Configuration
|
|
88
|
+
|
|
89
|
+
All configuration is via environment variables. See \`.env.example\`:
|
|
90
|
+
|
|
91
|
+
| Variable | Required | Description |
|
|
92
|
+
|----------|----------|-------------|
|
|
93
|
+
{table from .env.example}
|
|
94
|
+
|
|
95
|
+
## Contributing
|
|
96
|
+
|
|
97
|
+
See [CONTRIBUTING.md](CONTRIBUTING.md).
|
|
98
|
+
```
|
|
99
|
+
|
|
100
|
+
**CLAUDE.md Rules:**
|
|
101
|
+
- Every command must be copy-pasteable and correct
|
|
102
|
+
- Architecture section should fit in a terminal window
|
|
103
|
+
- List actual files that exist, not hypothetical ones
|
|
104
|
+
- Include the port number prominently
|
|
105
|
+
- If Docker is the primary runtime, lead with Docker commands
|
|
106
|
+
|
|
107
|
+
### Step 3: Generate setup.sh
|
|
108
|
+
|
|
109
|
+
```bash
|
|
110
|
+
#!/usr/bin/env bash
|
|
111
|
+
set -euo pipefail
|
|
112
|
+
|
|
113
|
+
# {Project Name} — First-time setup
|
|
114
|
+
# Usage: ./setup.sh
|
|
115
|
+
|
|
116
|
+
echo "=== {Project Name} Setup ==="
|
|
117
|
+
|
|
118
|
+
# Check prerequisites
|
|
119
|
+
command -v {package_manager} >/dev/null 2>&1 || { echo "Error: {package_manager} is required."; exit 1; }
|
|
120
|
+
|
|
121
|
+
# Environment
|
|
122
|
+
if [ ! -f .env ]; then
|
|
123
|
+
cp .env.example .env
|
|
124
|
+
echo "Created .env from .env.example — edit it with your values"
|
|
125
|
+
fi
|
|
126
|
+
|
|
127
|
+
# Dependencies
|
|
128
|
+
echo "Installing dependencies..."
|
|
129
|
+
{npm install | pip install -r requirements.txt | cargo build | go mod download}
|
|
130
|
+
|
|
131
|
+
echo ""
|
|
132
|
+
echo "=== Setup complete! ==="
|
|
133
|
+
echo ""
|
|
134
|
+
echo "Next steps:"
|
|
135
|
+
echo " 1. Edit .env with your configuration"
|
|
136
|
+
echo " 2. Run: {dev command}"
|
|
137
|
+
echo " 3. Open: http://localhost:{port}"
|
|
138
|
+
echo " 4. Using Claude Code? CLAUDE.md has all the context."
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
After writing, make it executable: `chmod +x setup.sh`
|
|
142
|
+
|
|
143
|
+
**setup.sh Rules:**
|
|
144
|
+
- Must work on fresh clone with zero manual steps beyond `.env` editing
|
|
145
|
+
- Check for prerequisites with clear error messages
|
|
146
|
+
- Use `set -euo pipefail` for safety
|
|
147
|
+
- Echo progress so the user knows what is happening
|
|
148
|
+
|
|
149
|
+
### Step 4: Generate or Enhance README.md
|
|
150
|
+
|
|
151
|
+
```markdown
|
|
152
|
+
# {Project Name}
|
|
153
|
+
|
|
154
|
+
{Description — 1-2 sentences}
|
|
155
|
+
|
|
156
|
+
## Features
|
|
157
|
+
|
|
158
|
+
- {Feature 1}
|
|
159
|
+
- {Feature 2}
|
|
160
|
+
- {Feature 3}
|
|
161
|
+
|
|
162
|
+
## Quick Start
|
|
163
|
+
|
|
164
|
+
\`\`\`bash
|
|
165
|
+
git clone https://github.com/{org}/{repo}.git
|
|
166
|
+
cd {repo}
|
|
167
|
+
./setup.sh
|
|
168
|
+
\`\`\`
|
|
169
|
+
|
|
170
|
+
See [CLAUDE.md](CLAUDE.md) for detailed commands and architecture.
|
|
171
|
+
|
|
172
|
+
## Prerequisites
|
|
173
|
+
|
|
174
|
+
- {Runtime} {version}+
|
|
175
|
+
- {Package manager}
|
|
176
|
+
|
|
177
|
+
## Configuration
|
|
178
|
+
|
|
179
|
+
\`\`\`bash
|
|
180
|
+
cp .env.example .env
|
|
181
|
+
\`\`\`
|
|
182
|
+
|
|
183
|
+
Key settings: {list 3-5 most important env vars}
|
|
184
|
+
|
|
185
|
+
## Development
|
|
186
|
+
|
|
187
|
+
\`\`\`bash
|
|
188
|
+
{dev command} # Start dev server
|
|
189
|
+
{test command} # Run tests
|
|
190
|
+
\`\`\`
|
|
191
|
+
|
|
192
|
+
## Using with Claude Code
|
|
193
|
+
|
|
194
|
+
This project includes a \`CLAUDE.md\` that gives Claude Code full context.
|
|
195
|
+
|
|
196
|
+
\`\`\`bash
|
|
197
|
+
claude # Start Claude Code — reads CLAUDE.md automatically
|
|
198
|
+
\`\`\`
|
|
199
|
+
|
|
200
|
+
## License
|
|
201
|
+
|
|
202
|
+
{License type} — see [LICENSE](LICENSE)
|
|
203
|
+
|
|
204
|
+
## Contributing
|
|
205
|
+
|
|
206
|
+
See [CONTRIBUTING.md](CONTRIBUTING.md)
|
|
207
|
+
```
|
|
208
|
+
|
|
209
|
+
**README Rules:**
|
|
210
|
+
- If a good README already exists, enhance rather than replace
|
|
211
|
+
- Always add the "Using with Claude Code" section
|
|
212
|
+
- Do not duplicate CLAUDE.md content — link to it
|
|
213
|
+
|
|
214
|
+
### Step 5: Add LICENSE
|
|
215
|
+
|
|
216
|
+
Use the standard SPDX text for the chosen license. Set copyright to the current year with "Contributors" as the holder (unless a specific name is provided).
|
|
217
|
+
|
|
218
|
+
### Step 6: Add CONTRIBUTING.md
|
|
219
|
+
|
|
220
|
+
Include: development setup, branch/PR workflow, code style notes from project analysis, issue reporting guidelines, and a "Using Claude Code" section.
|
|
221
|
+
|
|
222
|
+
### Step 7: Add GitHub Issue Templates (if .github/ exists or GitHub repo specified)
|
|
223
|
+
|
|
224
|
+
Create `.github/ISSUE_TEMPLATE/bug_report.md` and `.github/ISSUE_TEMPLATE/feature_request.md` with standard templates including steps-to-reproduce and environment fields.
|
|
225
|
+
|
|
226
|
+
## Output Format
|
|
227
|
+
|
|
228
|
+
On completion, report:
|
|
229
|
+
- Files generated (with line counts)
|
|
230
|
+
- Files enhanced (what was preserved vs added)
|
|
231
|
+
- `setup.sh` marked executable
|
|
232
|
+
- Any commands that could not be verified from the source code
|
|
233
|
+
|
|
234
|
+
## Examples
|
|
235
|
+
|
|
236
|
+
### Example: Package a FastAPI service
|
|
237
|
+
Input: `Package: /home/user/opensource-staging/my-api, License: MIT, Description: "Async task queue API"`
|
|
238
|
+
Action: Detects Python + FastAPI + PostgreSQL from `requirements.txt` and `docker-compose.yml`, generates `CLAUDE.md` (62 lines), `setup.sh` with pip + alembic migrate steps, enhances existing `README.md`, adds `MIT LICENSE`
|
|
239
|
+
Output: 5 files generated, setup.sh executable, "Using with Claude Code" section added
|
|
240
|
+
|
|
241
|
+
## Rules
|
|
242
|
+
|
|
243
|
+
- **Never** include internal references in generated files
|
|
244
|
+
- **Always** verify every command you put in CLAUDE.md actually exists in the project
|
|
245
|
+
- **Always** make `setup.sh` executable
|
|
246
|
+
- **Always** include the "Using with Claude Code" section in README
|
|
247
|
+
- **Read** the actual project code to understand it — do not guess at architecture
|
|
248
|
+
- CLAUDE.md must be accurate — wrong commands are worse than no commands
|
|
249
|
+
- If the project already has good docs, enhance them rather than replace
|