claudecode-omc 5.5.2 → 5.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +63 -0
- 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,151 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: jpa-patterns
|
|
3
|
+
description: JPA/Hibernate patterns for entity design, relationships, query optimization, transactions, auditing, indexing, pagination, and pooling in Spring Boot.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# JPA/Hibernate Patterns
|
|
8
|
+
|
|
9
|
+
Use for data modeling, repositories, and performance tuning in Spring Boot.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- Designing JPA entities and table mappings
|
|
14
|
+
- Defining relationships (@OneToMany, @ManyToOne, @ManyToMany)
|
|
15
|
+
- Optimizing queries (N+1 prevention, fetch strategies, projections)
|
|
16
|
+
- Configuring transactions, auditing, or soft deletes
|
|
17
|
+
- Setting up pagination, sorting, or custom repository methods
|
|
18
|
+
- Tuning connection pooling (HikariCP) or second-level caching
|
|
19
|
+
|
|
20
|
+
## Entity Design
|
|
21
|
+
|
|
22
|
+
```java
|
|
23
|
+
@Entity
|
|
24
|
+
@Table(name = "markets", indexes = {
|
|
25
|
+
@Index(name = "idx_markets_slug", columnList = "slug", unique = true)
|
|
26
|
+
})
|
|
27
|
+
@EntityListeners(AuditingEntityListener.class)
|
|
28
|
+
public class MarketEntity {
|
|
29
|
+
@Id @GeneratedValue(strategy = GenerationType.IDENTITY)
|
|
30
|
+
private Long id;
|
|
31
|
+
|
|
32
|
+
@Column(nullable = false, length = 200)
|
|
33
|
+
private String name;
|
|
34
|
+
|
|
35
|
+
@Column(nullable = false, unique = true, length = 120)
|
|
36
|
+
private String slug;
|
|
37
|
+
|
|
38
|
+
@Enumerated(EnumType.STRING)
|
|
39
|
+
private MarketStatus status = MarketStatus.ACTIVE;
|
|
40
|
+
|
|
41
|
+
@CreatedDate private Instant createdAt;
|
|
42
|
+
@LastModifiedDate private Instant updatedAt;
|
|
43
|
+
}
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
Enable auditing:
|
|
47
|
+
```java
|
|
48
|
+
@Configuration
|
|
49
|
+
@EnableJpaAuditing
|
|
50
|
+
class JpaConfig {}
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
## Relationships and N+1 Prevention
|
|
54
|
+
|
|
55
|
+
```java
|
|
56
|
+
@OneToMany(mappedBy = "market", cascade = CascadeType.ALL, orphanRemoval = true)
|
|
57
|
+
private List<PositionEntity> positions = new ArrayList<>();
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
- Default to lazy loading; use `JOIN FETCH` in queries when needed
|
|
61
|
+
- Avoid `EAGER` on collections; use DTO projections for read paths
|
|
62
|
+
|
|
63
|
+
```java
|
|
64
|
+
@Query("select m from MarketEntity m left join fetch m.positions where m.id = :id")
|
|
65
|
+
Optional<MarketEntity> findWithPositions(@Param("id") Long id);
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
## Repository Patterns
|
|
69
|
+
|
|
70
|
+
```java
|
|
71
|
+
public interface MarketRepository extends JpaRepository<MarketEntity, Long> {
|
|
72
|
+
Optional<MarketEntity> findBySlug(String slug);
|
|
73
|
+
|
|
74
|
+
@Query("select m from MarketEntity m where m.status = :status")
|
|
75
|
+
Page<MarketEntity> findByStatus(@Param("status") MarketStatus status, Pageable pageable);
|
|
76
|
+
}
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
- Use projections for lightweight queries:
|
|
80
|
+
```java
|
|
81
|
+
public interface MarketSummary {
|
|
82
|
+
Long getId();
|
|
83
|
+
String getName();
|
|
84
|
+
MarketStatus getStatus();
|
|
85
|
+
}
|
|
86
|
+
Page<MarketSummary> findAllBy(Pageable pageable);
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
## Transactions
|
|
90
|
+
|
|
91
|
+
- Annotate service methods with `@Transactional`
|
|
92
|
+
- Use `@Transactional(readOnly = true)` for read paths to optimize
|
|
93
|
+
- Choose propagation carefully; avoid long-running transactions
|
|
94
|
+
|
|
95
|
+
```java
|
|
96
|
+
@Transactional
|
|
97
|
+
public Market updateStatus(Long id, MarketStatus status) {
|
|
98
|
+
MarketEntity entity = repo.findById(id)
|
|
99
|
+
.orElseThrow(() -> new EntityNotFoundException("Market"));
|
|
100
|
+
entity.setStatus(status);
|
|
101
|
+
return Market.from(entity);
|
|
102
|
+
}
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
## Pagination
|
|
106
|
+
|
|
107
|
+
```java
|
|
108
|
+
PageRequest page = PageRequest.of(pageNumber, pageSize, Sort.by("createdAt").descending());
|
|
109
|
+
Page<MarketEntity> markets = repo.findByStatus(MarketStatus.ACTIVE, page);
|
|
110
|
+
```
|
|
111
|
+
|
|
112
|
+
For cursor-like pagination, include `id > :lastId` in JPQL with ordering.
|
|
113
|
+
|
|
114
|
+
## Indexing and Performance
|
|
115
|
+
|
|
116
|
+
- Add indexes for common filters (`status`, `slug`, foreign keys)
|
|
117
|
+
- Use composite indexes matching query patterns (`status, created_at`)
|
|
118
|
+
- Avoid `select *`; project only needed columns
|
|
119
|
+
- Batch writes with `saveAll` and `hibernate.jdbc.batch_size`
|
|
120
|
+
|
|
121
|
+
## Connection Pooling (HikariCP)
|
|
122
|
+
|
|
123
|
+
Recommended properties:
|
|
124
|
+
```
|
|
125
|
+
spring.datasource.hikari.maximum-pool-size=20
|
|
126
|
+
spring.datasource.hikari.minimum-idle=5
|
|
127
|
+
spring.datasource.hikari.connection-timeout=30000
|
|
128
|
+
spring.datasource.hikari.validation-timeout=5000
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
For PostgreSQL LOB handling, add:
|
|
132
|
+
```
|
|
133
|
+
spring.jpa.properties.hibernate.jdbc.lob.non_contextual_creation=true
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
## Caching
|
|
137
|
+
|
|
138
|
+
- 1st-level cache is per EntityManager; avoid keeping entities across transactions
|
|
139
|
+
- For read-heavy entities, consider second-level cache cautiously; validate eviction strategy
|
|
140
|
+
|
|
141
|
+
## Migrations
|
|
142
|
+
|
|
143
|
+
- Use Flyway or Liquibase; never rely on Hibernate auto DDL in production
|
|
144
|
+
- Keep migrations idempotent and additive; avoid dropping columns without plan
|
|
145
|
+
|
|
146
|
+
## Testing Data Access
|
|
147
|
+
|
|
148
|
+
- Prefer `@DataJpaTest` with Testcontainers to mirror production
|
|
149
|
+
- Assert SQL efficiency using logs: set `logging.level.org.hibernate.SQL=DEBUG` and `logging.level.org.hibernate.orm.jdbc.bind=TRACE` for parameter values
|
|
150
|
+
|
|
151
|
+
**Remember**: Keep entities lean, queries intentional, and transactions short. Prevent N+1 with fetch strategies and projections, and index for your read/write paths.
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: knowledge-ops
|
|
3
|
+
description: Knowledge base management, ingestion, sync, and retrieval across multiple storage layers (local files, MCP memory, vector stores, Git repos). Use when the user wants to save, organize, sync, deduplicate, or search across their knowledge systems.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Knowledge Operations
|
|
8
|
+
|
|
9
|
+
Manage a multi-layered knowledge system for ingesting, organizing, syncing, and retrieving knowledge across multiple stores.
|
|
10
|
+
|
|
11
|
+
Prefer the live workspace model:
|
|
12
|
+
- code work lives in the real cloned repos
|
|
13
|
+
- active execution context lives in GitHub, Linear, and repo-local working-context files
|
|
14
|
+
- broader human-facing notes can live in a non-repo context/archive folder
|
|
15
|
+
- durable cross-machine memory belongs in the knowledge base, not in a shadow repo workspace
|
|
16
|
+
|
|
17
|
+
## When to Activate
|
|
18
|
+
|
|
19
|
+
- User wants to save information to their knowledge base
|
|
20
|
+
- Ingesting documents, conversations, or data into structured storage
|
|
21
|
+
- Syncing knowledge across systems (local files, MCP memory, Supabase, Git repos)
|
|
22
|
+
- Deduplicating or organizing existing knowledge
|
|
23
|
+
- User says "save this to KB", "sync knowledge", "what do I know about X", "ingest this", "update the knowledge base"
|
|
24
|
+
- Any knowledge management task beyond simple memory recall
|
|
25
|
+
|
|
26
|
+
## Knowledge Architecture
|
|
27
|
+
|
|
28
|
+
### Layer 1: Active execution truth
|
|
29
|
+
- **Sources:** GitHub issues, PRs, discussions, release notes, Linear issues/projects/docs
|
|
30
|
+
- **Use for:** the current operational state of the work
|
|
31
|
+
- **Rule:** if something affects an active engineering plan, roadmap, rollout, or release, prefer putting it here first
|
|
32
|
+
|
|
33
|
+
### Layer 2: Claude Code Memory (Quick Access)
|
|
34
|
+
- **Path:** `~/.claude/projects/*/memory/`
|
|
35
|
+
- **Format:** Markdown files with frontmatter
|
|
36
|
+
- **Types:** user preferences, feedback, project context, reference
|
|
37
|
+
- **Use for:** quick-access context that persists across conversations
|
|
38
|
+
- **Automatically loaded at session start**
|
|
39
|
+
|
|
40
|
+
### Layer 3: MCP Memory Server (Structured Knowledge Graph)
|
|
41
|
+
- **Access:** MCP memory tools (create_entities, create_relations, add_observations, search_nodes)
|
|
42
|
+
- **Use for:** Semantic search across all stored memories, relationship mapping
|
|
43
|
+
- **Cross-session persistence with queryable graph structure**
|
|
44
|
+
|
|
45
|
+
### Layer 4: Knowledge base repo / durable document store
|
|
46
|
+
- **Use for:** curated durable notes, session exports, synthesized research, operator memory, long-form docs
|
|
47
|
+
- **Rule:** this is the preferred durable store for cross-machine context when the content is not repo-owned code
|
|
48
|
+
|
|
49
|
+
### Layer 5: External Data Store (Supabase, PostgreSQL, etc.)
|
|
50
|
+
- **Use for:** Structured data, large document storage, full-text search
|
|
51
|
+
- **Good for:** Documents too large for memory files, data needing SQL queries
|
|
52
|
+
|
|
53
|
+
### Layer 6: Local context/archive folder
|
|
54
|
+
- **Use for:** human-facing notes, archived gameplans, local media organization, temporary non-code docs
|
|
55
|
+
- **Rule:** writable for information storage, but not a shadow code workspace
|
|
56
|
+
- **Do not use for:** active code changes or repo truth that should live upstream
|
|
57
|
+
|
|
58
|
+
## Ingestion Workflow
|
|
59
|
+
|
|
60
|
+
When new knowledge needs to be captured:
|
|
61
|
+
|
|
62
|
+
### 1. Classify
|
|
63
|
+
What type of knowledge is it?
|
|
64
|
+
- Business decision -> memory file (project type) + MCP memory
|
|
65
|
+
- Active roadmap / release / implementation state -> GitHub + Linear first
|
|
66
|
+
- Personal preference -> memory file (user/feedback type)
|
|
67
|
+
- Reference info -> memory file (reference type) + MCP memory
|
|
68
|
+
- Large document -> external data store + summary in memory
|
|
69
|
+
- Conversation/session -> knowledge base repo + short summary in memory
|
|
70
|
+
|
|
71
|
+
### 2. Deduplicate
|
|
72
|
+
Check if this knowledge already exists:
|
|
73
|
+
- Search memory files for existing entries
|
|
74
|
+
- Query MCP memory with relevant terms
|
|
75
|
+
- Check whether the information already exists in GitHub or Linear before creating another local note
|
|
76
|
+
- Do not create duplicates. Update existing entries instead.
|
|
77
|
+
|
|
78
|
+
### 3. Store
|
|
79
|
+
Write to appropriate layer(s):
|
|
80
|
+
- Always update Claude Code memory for quick access
|
|
81
|
+
- Use MCP memory for semantic searchability and relationship mapping
|
|
82
|
+
- Update GitHub / Linear first when the information changes live project truth
|
|
83
|
+
- Commit to the knowledge base repo for durable long-form additions
|
|
84
|
+
|
|
85
|
+
### 4. Index
|
|
86
|
+
Update any relevant indexes or summary files.
|
|
87
|
+
|
|
88
|
+
## Sync Operations
|
|
89
|
+
|
|
90
|
+
### Conversation Sync
|
|
91
|
+
Periodically sync conversation history into the knowledge base:
|
|
92
|
+
- Sources: Claude session files, Codex sessions, other agent sessions
|
|
93
|
+
- Destination: knowledge base repo
|
|
94
|
+
- Generate a session index for quick browsing
|
|
95
|
+
- Commit and push
|
|
96
|
+
|
|
97
|
+
### Workspace State Sync
|
|
98
|
+
Mirror important workspace configuration and scripts to the knowledge base:
|
|
99
|
+
- Generate directory maps
|
|
100
|
+
- Redact sensitive config before committing
|
|
101
|
+
- Track changes over time
|
|
102
|
+
- Do not treat the knowledge base or archive folder as the live code workspace
|
|
103
|
+
|
|
104
|
+
### GitHub / Linear Sync
|
|
105
|
+
When the information affects active execution:
|
|
106
|
+
- update the relevant GitHub issue, PR, discussion, release notes, or roadmap thread
|
|
107
|
+
- attach supporting docs to Linear when the work needs durable planning context
|
|
108
|
+
- only mirror a local note afterwards if it still adds value
|
|
109
|
+
|
|
110
|
+
### Cross-Source Knowledge Sync
|
|
111
|
+
Pull knowledge from multiple sources into one place:
|
|
112
|
+
- Claude/ChatGPT/Grok conversation exports
|
|
113
|
+
- Browser bookmarks
|
|
114
|
+
- GitHub activity events
|
|
115
|
+
- Write status summary, commit and push
|
|
116
|
+
|
|
117
|
+
## Memory Patterns
|
|
118
|
+
|
|
119
|
+
```
|
|
120
|
+
# Short-term: current session context
|
|
121
|
+
Use TodoWrite for in-session task tracking
|
|
122
|
+
|
|
123
|
+
# Medium-term: project memory files
|
|
124
|
+
Write to ~/.claude/projects/*/memory/ for cross-session recall
|
|
125
|
+
|
|
126
|
+
# Long-term: GitHub / Linear / KB
|
|
127
|
+
Put active execution truth in GitHub + Linear
|
|
128
|
+
Put durable synthesized context in the knowledge base repo
|
|
129
|
+
|
|
130
|
+
# Semantic layer: MCP knowledge graph
|
|
131
|
+
Use mcp__memory__create_entities for permanent structured data
|
|
132
|
+
Use mcp__memory__create_relations for relationship mapping
|
|
133
|
+
Use mcp__memory__add_observations for new facts about known entities
|
|
134
|
+
Use mcp__memory__search_nodes to find existing knowledge
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
## Best Practices
|
|
138
|
+
|
|
139
|
+
- Keep memory files concise. Archive old data rather than letting files grow unbounded.
|
|
140
|
+
- Use frontmatter (YAML) for metadata on all knowledge files.
|
|
141
|
+
- Deduplicate before storing. Search first, then create or update.
|
|
142
|
+
- Prefer one canonical home per fact set. Avoid parallel copies of the same plan across local notes, repo files, and tracker docs.
|
|
143
|
+
- Redact sensitive information (API keys, passwords) before committing to Git.
|
|
144
|
+
- Use consistent naming conventions for knowledge files (lowercase-kebab-case).
|
|
145
|
+
- Tag entries with topics/categories for easier retrieval.
|
|
146
|
+
|
|
147
|
+
## Quality Gate
|
|
148
|
+
|
|
149
|
+
Before completing any knowledge operation:
|
|
150
|
+
- no duplicate entries created
|
|
151
|
+
- sensitive data redacted from any Git-tracked files
|
|
152
|
+
- indexes and summaries updated
|
|
153
|
+
- appropriate storage layer chosen for the data type
|
|
154
|
+
- cross-references added where relevant
|
|
@@ -0,0 +1,284 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: kotlin-coroutines-flows
|
|
3
|
+
description: Kotlin Coroutines and Flow patterns for Android and KMP — structured concurrency, Flow operators, StateFlow, error handling, and testing.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Kotlin Coroutines & Flows
|
|
8
|
+
|
|
9
|
+
Patterns for structured concurrency, Flow-based reactive streams, and coroutine testing in Android and Kotlin Multiplatform projects.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- Writing async code with Kotlin coroutines
|
|
14
|
+
- Using Flow, StateFlow, or SharedFlow for reactive data
|
|
15
|
+
- Handling concurrent operations (parallel loading, debounce, retry)
|
|
16
|
+
- Testing coroutines and Flows
|
|
17
|
+
- Managing coroutine scopes and cancellation
|
|
18
|
+
|
|
19
|
+
## Structured Concurrency
|
|
20
|
+
|
|
21
|
+
### Scope Hierarchy
|
|
22
|
+
|
|
23
|
+
```
|
|
24
|
+
Application
|
|
25
|
+
└── viewModelScope (ViewModel)
|
|
26
|
+
└── coroutineScope { } (structured child)
|
|
27
|
+
├── async { } (concurrent task)
|
|
28
|
+
└── async { } (concurrent task)
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
Always use structured concurrency — never `GlobalScope`:
|
|
32
|
+
|
|
33
|
+
```kotlin
|
|
34
|
+
// BAD
|
|
35
|
+
GlobalScope.launch { fetchData() }
|
|
36
|
+
|
|
37
|
+
// GOOD — scoped to ViewModel lifecycle
|
|
38
|
+
viewModelScope.launch { fetchData() }
|
|
39
|
+
|
|
40
|
+
// GOOD — scoped to composable lifecycle
|
|
41
|
+
LaunchedEffect(key) { fetchData() }
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
### Parallel Decomposition
|
|
45
|
+
|
|
46
|
+
Use `coroutineScope` + `async` for parallel work:
|
|
47
|
+
|
|
48
|
+
```kotlin
|
|
49
|
+
suspend fun loadDashboard(): Dashboard = coroutineScope {
|
|
50
|
+
val items = async { itemRepository.getRecent() }
|
|
51
|
+
val stats = async { statsRepository.getToday() }
|
|
52
|
+
val profile = async { userRepository.getCurrent() }
|
|
53
|
+
Dashboard(
|
|
54
|
+
items = items.await(),
|
|
55
|
+
stats = stats.await(),
|
|
56
|
+
profile = profile.await()
|
|
57
|
+
)
|
|
58
|
+
}
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
### SupervisorScope
|
|
62
|
+
|
|
63
|
+
Use `supervisorScope` when child failures should not cancel siblings:
|
|
64
|
+
|
|
65
|
+
```kotlin
|
|
66
|
+
suspend fun syncAll() = supervisorScope {
|
|
67
|
+
launch { syncItems() } // failure here won't cancel syncStats
|
|
68
|
+
launch { syncStats() }
|
|
69
|
+
launch { syncSettings() }
|
|
70
|
+
}
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
## Flow Patterns
|
|
74
|
+
|
|
75
|
+
### Cold Flow — One-Shot to Stream Conversion
|
|
76
|
+
|
|
77
|
+
```kotlin
|
|
78
|
+
fun observeItems(): Flow<List<Item>> = flow {
|
|
79
|
+
// Re-emits whenever the database changes
|
|
80
|
+
itemDao.observeAll()
|
|
81
|
+
.map { entities -> entities.map { it.toDomain() } }
|
|
82
|
+
.collect { emit(it) }
|
|
83
|
+
}
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
### StateFlow for UI State
|
|
87
|
+
|
|
88
|
+
```kotlin
|
|
89
|
+
class DashboardViewModel(
|
|
90
|
+
observeProgress: ObserveUserProgressUseCase
|
|
91
|
+
) : ViewModel() {
|
|
92
|
+
val progress: StateFlow<UserProgress> = observeProgress()
|
|
93
|
+
.stateIn(
|
|
94
|
+
scope = viewModelScope,
|
|
95
|
+
started = SharingStarted.WhileSubscribed(5_000),
|
|
96
|
+
initialValue = UserProgress.EMPTY
|
|
97
|
+
)
|
|
98
|
+
}
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
`WhileSubscribed(5_000)` keeps the upstream active for 5 seconds after the last subscriber leaves — survives configuration changes without restarting.
|
|
102
|
+
|
|
103
|
+
### Combining Multiple Flows
|
|
104
|
+
|
|
105
|
+
```kotlin
|
|
106
|
+
val uiState: StateFlow<HomeState> = combine(
|
|
107
|
+
itemRepository.observeItems(),
|
|
108
|
+
settingsRepository.observeTheme(),
|
|
109
|
+
userRepository.observeProfile()
|
|
110
|
+
) { items, theme, profile ->
|
|
111
|
+
HomeState(items = items, theme = theme, profile = profile)
|
|
112
|
+
}.stateIn(viewModelScope, SharingStarted.WhileSubscribed(5_000), HomeState())
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
### Flow Operators
|
|
116
|
+
|
|
117
|
+
```kotlin
|
|
118
|
+
// Debounce search input
|
|
119
|
+
searchQuery
|
|
120
|
+
.debounce(300)
|
|
121
|
+
.distinctUntilChanged()
|
|
122
|
+
.flatMapLatest { query -> repository.search(query) }
|
|
123
|
+
.catch { emit(emptyList()) }
|
|
124
|
+
.collect { results -> _state.update { it.copy(results = results) } }
|
|
125
|
+
|
|
126
|
+
// Retry with exponential backoff
|
|
127
|
+
fun fetchWithRetry(): Flow<Data> = flow { emit(api.fetch()) }
|
|
128
|
+
.retryWhen { cause, attempt ->
|
|
129
|
+
if (cause is IOException && attempt < 3) {
|
|
130
|
+
delay(1000L * (1 shl attempt.toInt()))
|
|
131
|
+
true
|
|
132
|
+
} else {
|
|
133
|
+
false
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
### SharedFlow for One-Time Events
|
|
139
|
+
|
|
140
|
+
```kotlin
|
|
141
|
+
class ItemListViewModel : ViewModel() {
|
|
142
|
+
private val _effects = MutableSharedFlow<Effect>()
|
|
143
|
+
val effects: SharedFlow<Effect> = _effects.asSharedFlow()
|
|
144
|
+
|
|
145
|
+
sealed interface Effect {
|
|
146
|
+
data class ShowSnackbar(val message: String) : Effect
|
|
147
|
+
data class NavigateTo(val route: String) : Effect
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
private fun deleteItem(id: String) {
|
|
151
|
+
viewModelScope.launch {
|
|
152
|
+
repository.delete(id)
|
|
153
|
+
_effects.emit(Effect.ShowSnackbar("Item deleted"))
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
// Collect in Composable
|
|
159
|
+
LaunchedEffect(Unit) {
|
|
160
|
+
viewModel.effects.collect { effect ->
|
|
161
|
+
when (effect) {
|
|
162
|
+
is Effect.ShowSnackbar -> snackbarHostState.showSnackbar(effect.message)
|
|
163
|
+
is Effect.NavigateTo -> navController.navigate(effect.route)
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
```
|
|
168
|
+
|
|
169
|
+
## Dispatchers
|
|
170
|
+
|
|
171
|
+
```kotlin
|
|
172
|
+
// CPU-intensive work
|
|
173
|
+
withContext(Dispatchers.Default) { parseJson(largePayload) }
|
|
174
|
+
|
|
175
|
+
// IO-bound work
|
|
176
|
+
withContext(Dispatchers.IO) { database.query() }
|
|
177
|
+
|
|
178
|
+
// Main thread (UI) — default in viewModelScope
|
|
179
|
+
withContext(Dispatchers.Main) { updateUi() }
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
In KMP, use `Dispatchers.Default` and `Dispatchers.Main` (available on all platforms). `Dispatchers.IO` is JVM/Android only — use `Dispatchers.Default` on other platforms or provide via DI.
|
|
183
|
+
|
|
184
|
+
## Cancellation
|
|
185
|
+
|
|
186
|
+
### Cooperative Cancellation
|
|
187
|
+
|
|
188
|
+
Long-running loops must check for cancellation:
|
|
189
|
+
|
|
190
|
+
```kotlin
|
|
191
|
+
suspend fun processItems(items: List<Item>) = coroutineScope {
|
|
192
|
+
for (item in items) {
|
|
193
|
+
ensureActive() // throws CancellationException if cancelled
|
|
194
|
+
process(item)
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
```
|
|
198
|
+
|
|
199
|
+
### Cleanup with try/finally
|
|
200
|
+
|
|
201
|
+
```kotlin
|
|
202
|
+
viewModelScope.launch {
|
|
203
|
+
try {
|
|
204
|
+
_state.update { it.copy(isLoading = true) }
|
|
205
|
+
val data = repository.fetch()
|
|
206
|
+
_state.update { it.copy(data = data) }
|
|
207
|
+
} finally {
|
|
208
|
+
_state.update { it.copy(isLoading = false) } // always runs, even on cancellation
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
## Testing
|
|
214
|
+
|
|
215
|
+
### Testing StateFlow with Turbine
|
|
216
|
+
|
|
217
|
+
```kotlin
|
|
218
|
+
@Test
|
|
219
|
+
fun `search updates item list`() = runTest {
|
|
220
|
+
val fakeRepository = FakeItemRepository().apply { emit(testItems) }
|
|
221
|
+
val viewModel = ItemListViewModel(GetItemsUseCase(fakeRepository))
|
|
222
|
+
|
|
223
|
+
viewModel.state.test {
|
|
224
|
+
assertEquals(ItemListState(), awaitItem()) // initial
|
|
225
|
+
|
|
226
|
+
viewModel.onSearch("query")
|
|
227
|
+
val loading = awaitItem()
|
|
228
|
+
assertTrue(loading.isLoading)
|
|
229
|
+
|
|
230
|
+
val loaded = awaitItem()
|
|
231
|
+
assertFalse(loaded.isLoading)
|
|
232
|
+
assertEquals(1, loaded.items.size)
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
```
|
|
236
|
+
|
|
237
|
+
### Testing with TestDispatcher
|
|
238
|
+
|
|
239
|
+
```kotlin
|
|
240
|
+
@Test
|
|
241
|
+
fun `parallel load completes correctly`() = runTest {
|
|
242
|
+
val viewModel = DashboardViewModel(
|
|
243
|
+
itemRepo = FakeItemRepo(),
|
|
244
|
+
statsRepo = FakeStatsRepo()
|
|
245
|
+
)
|
|
246
|
+
|
|
247
|
+
viewModel.load()
|
|
248
|
+
advanceUntilIdle()
|
|
249
|
+
|
|
250
|
+
val state = viewModel.state.value
|
|
251
|
+
assertNotNull(state.items)
|
|
252
|
+
assertNotNull(state.stats)
|
|
253
|
+
}
|
|
254
|
+
```
|
|
255
|
+
|
|
256
|
+
### Faking Flows
|
|
257
|
+
|
|
258
|
+
```kotlin
|
|
259
|
+
class FakeItemRepository : ItemRepository {
|
|
260
|
+
private val _items = MutableStateFlow<List<Item>>(emptyList())
|
|
261
|
+
|
|
262
|
+
override fun observeItems(): Flow<List<Item>> = _items
|
|
263
|
+
|
|
264
|
+
fun emit(items: List<Item>) { _items.value = items }
|
|
265
|
+
|
|
266
|
+
override suspend fun getItemsByCategory(category: String): Result<List<Item>> {
|
|
267
|
+
return Result.success(_items.value.filter { it.category == category })
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
```
|
|
271
|
+
|
|
272
|
+
## Anti-Patterns to Avoid
|
|
273
|
+
|
|
274
|
+
- Using `GlobalScope` — leaks coroutines, no structured cancellation
|
|
275
|
+
- Collecting Flows in `init {}` without a scope — use `viewModelScope.launch`
|
|
276
|
+
- Using `MutableStateFlow` with mutable collections — always use immutable copies: `_state.update { it.copy(list = it.list + newItem) }`
|
|
277
|
+
- Catching `CancellationException` — let it propagate for proper cancellation
|
|
278
|
+
- Using `flowOn(Dispatchers.Main)` to collect — collection dispatcher is the caller's dispatcher
|
|
279
|
+
- Creating `Flow` in `@Composable` without `remember` — recreates the flow every recomposition
|
|
280
|
+
|
|
281
|
+
## References
|
|
282
|
+
|
|
283
|
+
See skill: `compose-multiplatform-patterns` for UI consumption of Flows.
|
|
284
|
+
See skill: `android-clean-architecture` for where coroutines fit in layers.
|