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.
Files changed (433) hide show
  1. package/README.md +63 -0
  2. package/bundled/manifest.json +3 -2
  3. package/bundled/upstream/ecc/.omc-source/bundle.json +23 -0
  4. package/bundled/upstream/ecc/.omc-source/last-plan-apply.json +439 -0
  5. package/bundled/upstream/ecc/.omc-source/manifests/.claude-plugin/marketplace.json +47 -0
  6. package/bundled/upstream/ecc/agents/a11y-architect.md +141 -0
  7. package/bundled/upstream/ecc/agents/architect.md +211 -0
  8. package/bundled/upstream/ecc/agents/build-error-resolver.md +114 -0
  9. package/bundled/upstream/ecc/agents/chief-of-staff.md +151 -0
  10. package/bundled/upstream/ecc/agents/code-architect.md +71 -0
  11. package/bundled/upstream/ecc/agents/code-explorer.md +69 -0
  12. package/bundled/upstream/ecc/agents/code-reviewer.md +237 -0
  13. package/bundled/upstream/ecc/agents/code-simplifier.md +47 -0
  14. package/bundled/upstream/ecc/agents/comment-analyzer.md +45 -0
  15. package/bundled/upstream/ecc/agents/conversation-analyzer.md +52 -0
  16. package/bundled/upstream/ecc/agents/cpp-build-resolver.md +90 -0
  17. package/bundled/upstream/ecc/agents/cpp-reviewer.md +72 -0
  18. package/bundled/upstream/ecc/agents/csharp-reviewer.md +101 -0
  19. package/bundled/upstream/ecc/agents/dart-build-resolver.md +201 -0
  20. package/bundled/upstream/ecc/agents/database-reviewer.md +91 -0
  21. package/bundled/upstream/ecc/agents/doc-updater.md +107 -0
  22. package/bundled/upstream/ecc/agents/docs-lookup.md +68 -0
  23. package/bundled/upstream/ecc/agents/e2e-runner.md +107 -0
  24. package/bundled/upstream/ecc/agents/flutter-reviewer.md +243 -0
  25. package/bundled/upstream/ecc/agents/gan-evaluator.md +209 -0
  26. package/bundled/upstream/ecc/agents/gan-generator.md +131 -0
  27. package/bundled/upstream/ecc/agents/gan-planner.md +99 -0
  28. package/bundled/upstream/ecc/agents/go-build-resolver.md +94 -0
  29. package/bundled/upstream/ecc/agents/go-reviewer.md +76 -0
  30. package/bundled/upstream/ecc/agents/harness-optimizer.md +35 -0
  31. package/bundled/upstream/ecc/agents/healthcare-reviewer.md +83 -0
  32. package/bundled/upstream/ecc/agents/java-build-resolver.md +153 -0
  33. package/bundled/upstream/ecc/agents/java-reviewer.md +92 -0
  34. package/bundled/upstream/ecc/agents/kotlin-build-resolver.md +118 -0
  35. package/bundled/upstream/ecc/agents/kotlin-reviewer.md +159 -0
  36. package/bundled/upstream/ecc/agents/loop-operator.md +36 -0
  37. package/bundled/upstream/ecc/agents/opensource-forker.md +198 -0
  38. package/bundled/upstream/ecc/agents/opensource-packager.md +249 -0
  39. package/bundled/upstream/ecc/agents/opensource-sanitizer.md +188 -0
  40. package/bundled/upstream/ecc/agents/performance-optimizer.md +446 -0
  41. package/bundled/upstream/ecc/agents/planner.md +212 -0
  42. package/bundled/upstream/ecc/agents/pr-test-analyzer.md +45 -0
  43. package/bundled/upstream/ecc/agents/python-reviewer.md +98 -0
  44. package/bundled/upstream/ecc/agents/pytorch-build-resolver.md +120 -0
  45. package/bundled/upstream/ecc/agents/refactor-cleaner.md +85 -0
  46. package/bundled/upstream/ecc/agents/rust-build-resolver.md +148 -0
  47. package/bundled/upstream/ecc/agents/rust-reviewer.md +94 -0
  48. package/bundled/upstream/ecc/agents/security-reviewer.md +108 -0
  49. package/bundled/upstream/ecc/agents/seo-specialist.md +62 -0
  50. package/bundled/upstream/ecc/agents/silent-failure-hunter.md +50 -0
  51. package/bundled/upstream/ecc/agents/tdd-guide.md +91 -0
  52. package/bundled/upstream/ecc/agents/type-design-analyzer.md +41 -0
  53. package/bundled/upstream/ecc/agents/typescript-reviewer.md +112 -0
  54. package/bundled/upstream/ecc/commands/agent-sort.md +23 -0
  55. package/bundled/upstream/ecc/commands/aside.md +164 -0
  56. package/bundled/upstream/ecc/commands/build-fix.md +62 -0
  57. package/bundled/upstream/ecc/commands/checkpoint.md +74 -0
  58. package/bundled/upstream/ecc/commands/claw.md +23 -0
  59. package/bundled/upstream/ecc/commands/code-review.md +289 -0
  60. package/bundled/upstream/ecc/commands/context-budget.md +23 -0
  61. package/bundled/upstream/ecc/commands/cpp-build.md +173 -0
  62. package/bundled/upstream/ecc/commands/cpp-review.md +132 -0
  63. package/bundled/upstream/ecc/commands/cpp-test.md +251 -0
  64. package/bundled/upstream/ecc/commands/devfleet.md +23 -0
  65. package/bundled/upstream/ecc/commands/docs.md +23 -0
  66. package/bundled/upstream/ecc/commands/e2e.md +268 -0
  67. package/bundled/upstream/ecc/commands/eval.md +23 -0
  68. package/bundled/upstream/ecc/commands/evolve.md +178 -0
  69. package/bundled/upstream/ecc/commands/feature-dev.md +49 -0
  70. package/bundled/upstream/ecc/commands/flutter-build.md +164 -0
  71. package/bundled/upstream/ecc/commands/flutter-review.md +116 -0
  72. package/bundled/upstream/ecc/commands/flutter-test.md +144 -0
  73. package/bundled/upstream/ecc/commands/gan-build.md +99 -0
  74. package/bundled/upstream/ecc/commands/gan-design.md +35 -0
  75. package/bundled/upstream/ecc/commands/go-build.md +183 -0
  76. package/bundled/upstream/ecc/commands/go-review.md +148 -0
  77. package/bundled/upstream/ecc/commands/go-test.md +268 -0
  78. package/bundled/upstream/ecc/commands/gradle-build.md +70 -0
  79. package/bundled/upstream/ecc/commands/harness-audit.md +73 -0
  80. package/bundled/upstream/ecc/commands/hookify-configure.md +14 -0
  81. package/bundled/upstream/ecc/commands/hookify-help.md +46 -0
  82. package/bundled/upstream/ecc/commands/hookify-list.md +21 -0
  83. package/bundled/upstream/ecc/commands/hookify.md +50 -0
  84. package/bundled/upstream/ecc/commands/instinct-export.md +66 -0
  85. package/bundled/upstream/ecc/commands/instinct-import.md +114 -0
  86. package/bundled/upstream/ecc/commands/instinct-status.md +59 -0
  87. package/bundled/upstream/ecc/commands/jira.md +106 -0
  88. package/bundled/upstream/ecc/commands/kotlin-build.md +174 -0
  89. package/bundled/upstream/ecc/commands/kotlin-review.md +140 -0
  90. package/bundled/upstream/ecc/commands/kotlin-test.md +312 -0
  91. package/bundled/upstream/ecc/commands/learn-eval.md +116 -0
  92. package/bundled/upstream/ecc/commands/learn.md +70 -0
  93. package/bundled/upstream/ecc/commands/loop-start.md +32 -0
  94. package/bundled/upstream/ecc/commands/loop-status.md +24 -0
  95. package/bundled/upstream/ecc/commands/model-route.md +26 -0
  96. package/bundled/upstream/ecc/commands/multi-backend.md +158 -0
  97. package/bundled/upstream/ecc/commands/multi-execute.md +315 -0
  98. package/bundled/upstream/ecc/commands/multi-frontend.md +158 -0
  99. package/bundled/upstream/ecc/commands/multi-plan.md +268 -0
  100. package/bundled/upstream/ecc/commands/multi-workflow.md +191 -0
  101. package/bundled/upstream/ecc/commands/orchestrate.md +135 -0
  102. package/bundled/upstream/ecc/commands/plan.md +117 -0
  103. package/bundled/upstream/ecc/commands/pm2.md +272 -0
  104. package/bundled/upstream/ecc/commands/projects.md +39 -0
  105. package/bundled/upstream/ecc/commands/promote.md +41 -0
  106. package/bundled/upstream/ecc/commands/prompt-optimize.md +23 -0
  107. package/bundled/upstream/ecc/commands/prp-commit.md +112 -0
  108. package/bundled/upstream/ecc/commands/prp-implement.md +385 -0
  109. package/bundled/upstream/ecc/commands/prp-plan.md +502 -0
  110. package/bundled/upstream/ecc/commands/prp-pr.md +184 -0
  111. package/bundled/upstream/ecc/commands/prp-prd.md +447 -0
  112. package/bundled/upstream/ecc/commands/prune.md +31 -0
  113. package/bundled/upstream/ecc/commands/python-review.md +297 -0
  114. package/bundled/upstream/ecc/commands/quality-gate.md +29 -0
  115. package/bundled/upstream/ecc/commands/refactor-clean.md +80 -0
  116. package/bundled/upstream/ecc/commands/resume-session.md +156 -0
  117. package/bundled/upstream/ecc/commands/review-pr.md +37 -0
  118. package/bundled/upstream/ecc/commands/rules-distill.md +20 -0
  119. package/bundled/upstream/ecc/commands/rust-build.md +187 -0
  120. package/bundled/upstream/ecc/commands/rust-review.md +142 -0
  121. package/bundled/upstream/ecc/commands/rust-test.md +308 -0
  122. package/bundled/upstream/ecc/commands/santa-loop.md +175 -0
  123. package/bundled/upstream/ecc/commands/save-session.md +275 -0
  124. package/bundled/upstream/ecc/commands/sessions.md +339 -0
  125. package/bundled/upstream/ecc/commands/setup-pm.md +80 -0
  126. package/bundled/upstream/ecc/commands/skill-create.md +174 -0
  127. package/bundled/upstream/ecc/commands/skill-health.md +54 -0
  128. package/bundled/upstream/ecc/commands/tdd.md +231 -0
  129. package/bundled/upstream/ecc/commands/test-coverage.md +69 -0
  130. package/bundled/upstream/ecc/commands/update-codemaps.md +72 -0
  131. package/bundled/upstream/ecc/commands/update-docs.md +84 -0
  132. package/bundled/upstream/ecc/commands/verify.md +23 -0
  133. package/bundled/upstream/ecc/hooks/README.md +237 -0
  134. package/bundled/upstream/ecc/hooks/hooks.json +330 -0
  135. package/bundled/upstream/ecc/skills/accessibility/SKILL.md +146 -0
  136. package/bundled/upstream/ecc/skills/agent-eval/SKILL.md +145 -0
  137. package/bundled/upstream/ecc/skills/agent-harness-construction/SKILL.md +73 -0
  138. package/bundled/upstream/ecc/skills/agent-introspection-debugging/SKILL.md +153 -0
  139. package/bundled/upstream/ecc/skills/agent-payment-x402/SKILL.md +178 -0
  140. package/bundled/upstream/ecc/skills/agent-sort/SKILL.md +215 -0
  141. package/bundled/upstream/ecc/skills/agentic-engineering/SKILL.md +63 -0
  142. package/bundled/upstream/ecc/skills/ai-first-engineering/SKILL.md +51 -0
  143. package/bundled/upstream/ecc/skills/ai-regression-testing/SKILL.md +385 -0
  144. package/bundled/upstream/ecc/skills/android-clean-architecture/SKILL.md +339 -0
  145. package/bundled/upstream/ecc/skills/api-connector-builder/SKILL.md +120 -0
  146. package/bundled/upstream/ecc/skills/api-design/SKILL.md +523 -0
  147. package/bundled/upstream/ecc/skills/architecture-decision-records/SKILL.md +179 -0
  148. package/bundled/upstream/ecc/skills/article-writing/SKILL.md +79 -0
  149. package/bundled/upstream/ecc/skills/automation-audit-ops/SKILL.md +142 -0
  150. package/bundled/upstream/ecc/skills/autonomous-agent-harness/SKILL.md +267 -0
  151. package/bundled/upstream/ecc/skills/autonomous-loops/SKILL.md +610 -0
  152. package/bundled/upstream/ecc/skills/backend-patterns/SKILL.md +598 -0
  153. package/bundled/upstream/ecc/skills/benchmark/SKILL.md +93 -0
  154. package/bundled/upstream/ecc/skills/blueprint/SKILL.md +105 -0
  155. package/bundled/upstream/ecc/skills/brand-voice/SKILL.md +97 -0
  156. package/bundled/upstream/ecc/skills/brand-voice/references/voice-profile-schema.md +55 -0
  157. package/bundled/upstream/ecc/skills/browser-qa/SKILL.md +87 -0
  158. package/bundled/upstream/ecc/skills/bun-runtime/SKILL.md +84 -0
  159. package/bundled/upstream/ecc/skills/canary-watch/SKILL.md +99 -0
  160. package/bundled/upstream/ecc/skills/carrier-relationship-management/SKILL.md +212 -0
  161. package/bundled/upstream/ecc/skills/ck/SKILL.md +147 -0
  162. package/bundled/upstream/ecc/skills/ck/commands/forget.mjs +44 -0
  163. package/bundled/upstream/ecc/skills/ck/commands/info.mjs +24 -0
  164. package/bundled/upstream/ecc/skills/ck/commands/init.mjs +143 -0
  165. package/bundled/upstream/ecc/skills/ck/commands/list.mjs +40 -0
  166. package/bundled/upstream/ecc/skills/ck/commands/migrate.mjs +202 -0
  167. package/bundled/upstream/ecc/skills/ck/commands/resume.mjs +36 -0
  168. package/bundled/upstream/ecc/skills/ck/commands/save.mjs +210 -0
  169. package/bundled/upstream/ecc/skills/ck/commands/shared.mjs +387 -0
  170. package/bundled/upstream/ecc/skills/ck/hooks/session-start.mjs +224 -0
  171. package/bundled/upstream/ecc/skills/claude-api/SKILL.md +337 -0
  172. package/bundled/upstream/ecc/skills/claude-devfleet/SKILL.md +103 -0
  173. package/bundled/upstream/ecc/skills/click-path-audit/SKILL.md +244 -0
  174. package/bundled/upstream/ecc/skills/clickhouse-io/SKILL.md +439 -0
  175. package/bundled/upstream/ecc/skills/code-tour/SKILL.md +236 -0
  176. package/bundled/upstream/ecc/skills/codebase-onboarding/SKILL.md +233 -0
  177. package/bundled/upstream/ecc/skills/coding-standards/SKILL.md +549 -0
  178. package/bundled/upstream/ecc/skills/compose-multiplatform-patterns/SKILL.md +299 -0
  179. package/bundled/upstream/ecc/skills/configure-ecc/SKILL.md +367 -0
  180. package/bundled/upstream/ecc/skills/connections-optimizer/SKILL.md +189 -0
  181. package/bundled/upstream/ecc/skills/content-engine/SKILL.md +131 -0
  182. package/bundled/upstream/ecc/skills/content-hash-cache-pattern/SKILL.md +161 -0
  183. package/bundled/upstream/ecc/skills/context-budget/SKILL.md +135 -0
  184. package/bundled/upstream/ecc/skills/continuous-agent-loop/SKILL.md +45 -0
  185. package/bundled/upstream/ecc/skills/continuous-learning/SKILL.md +123 -0
  186. package/bundled/upstream/ecc/skills/continuous-learning/config.json +18 -0
  187. package/bundled/upstream/ecc/skills/continuous-learning/evaluate-session.sh +69 -0
  188. package/bundled/upstream/ecc/skills/continuous-learning-v2/SKILL.md +346 -0
  189. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/observer-loop.sh +282 -0
  190. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/observer.md +198 -0
  191. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  192. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
  193. package/bundled/upstream/ecc/skills/continuous-learning-v2/config.json +8 -0
  194. package/bundled/upstream/ecc/skills/continuous-learning-v2/hooks/observe.sh +460 -0
  195. package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/detect-project.sh +243 -0
  196. package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
  197. package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/test_parse_instinct.py +984 -0
  198. package/bundled/upstream/ecc/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  199. package/bundled/upstream/ecc/skills/council/SKILL.md +203 -0
  200. package/bundled/upstream/ecc/skills/cpp-coding-standards/SKILL.md +723 -0
  201. package/bundled/upstream/ecc/skills/cpp-testing/SKILL.md +324 -0
  202. package/bundled/upstream/ecc/skills/crosspost/SKILL.md +111 -0
  203. package/bundled/upstream/ecc/skills/csharp-testing/SKILL.md +321 -0
  204. package/bundled/upstream/ecc/skills/customer-billing-ops/SKILL.md +140 -0
  205. package/bundled/upstream/ecc/skills/customs-trade-compliance/SKILL.md +263 -0
  206. package/bundled/upstream/ecc/skills/dart-flutter-patterns/SKILL.md +563 -0
  207. package/bundled/upstream/ecc/skills/dashboard-builder/SKILL.md +108 -0
  208. package/bundled/upstream/ecc/skills/data-scraper-agent/SKILL.md +764 -0
  209. package/bundled/upstream/ecc/skills/database-migrations/SKILL.md +429 -0
  210. package/bundled/upstream/ecc/skills/deep-research/SKILL.md +155 -0
  211. package/bundled/upstream/ecc/skills/defi-amm-security/SKILL.md +160 -0
  212. package/bundled/upstream/ecc/skills/deployment-patterns/SKILL.md +427 -0
  213. package/bundled/upstream/ecc/skills/design-system/SKILL.md +82 -0
  214. package/bundled/upstream/ecc/skills/django-patterns/SKILL.md +734 -0
  215. package/bundled/upstream/ecc/skills/django-security/SKILL.md +593 -0
  216. package/bundled/upstream/ecc/skills/django-tdd/SKILL.md +729 -0
  217. package/bundled/upstream/ecc/skills/django-verification/SKILL.md +469 -0
  218. package/bundled/upstream/ecc/skills/dmux-workflows/SKILL.md +191 -0
  219. package/bundled/upstream/ecc/skills/docker-patterns/SKILL.md +364 -0
  220. package/bundled/upstream/ecc/skills/documentation-lookup/SKILL.md +90 -0
  221. package/bundled/upstream/ecc/skills/dotnet-patterns/SKILL.md +321 -0
  222. package/bundled/upstream/ecc/skills/e2e-testing/SKILL.md +326 -0
  223. package/bundled/upstream/ecc/skills/ecc-tools-cost-audit/SKILL.md +160 -0
  224. package/bundled/upstream/ecc/skills/email-ops/SKILL.md +121 -0
  225. package/bundled/upstream/ecc/skills/energy-procurement/SKILL.md +228 -0
  226. package/bundled/upstream/ecc/skills/enterprise-agent-ops/SKILL.md +50 -0
  227. package/bundled/upstream/ecc/skills/eval-harness/SKILL.md +270 -0
  228. package/bundled/upstream/ecc/skills/evm-token-decimals/SKILL.md +130 -0
  229. package/bundled/upstream/ecc/skills/exa-search/SKILL.md +103 -0
  230. package/bundled/upstream/ecc/skills/fal-ai-media/SKILL.md +284 -0
  231. package/bundled/upstream/ecc/skills/finance-billing-ops/SKILL.md +127 -0
  232. package/bundled/upstream/ecc/skills/flutter-dart-code-review/SKILL.md +435 -0
  233. package/bundled/upstream/ecc/skills/foundation-models-on-device/SKILL.md +243 -0
  234. package/bundled/upstream/ecc/skills/frontend-design/SKILL.md +145 -0
  235. package/bundled/upstream/ecc/skills/frontend-patterns/SKILL.md +642 -0
  236. package/bundled/upstream/ecc/skills/frontend-slides/SKILL.md +184 -0
  237. package/bundled/upstream/ecc/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  238. package/bundled/upstream/ecc/skills/gan-style-harness/SKILL.md +278 -0
  239. package/bundled/upstream/ecc/skills/gateguard/SKILL.md +121 -0
  240. package/bundled/upstream/ecc/skills/git-workflow/SKILL.md +715 -0
  241. package/bundled/upstream/ecc/skills/github-ops/SKILL.md +144 -0
  242. package/bundled/upstream/ecc/skills/golang-patterns/SKILL.md +674 -0
  243. package/bundled/upstream/ecc/skills/golang-testing/SKILL.md +720 -0
  244. package/bundled/upstream/ecc/skills/google-workspace-ops/SKILL.md +95 -0
  245. package/bundled/upstream/ecc/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  246. package/bundled/upstream/ecc/skills/healthcare-emr-patterns/SKILL.md +159 -0
  247. package/bundled/upstream/ecc/skills/healthcare-eval-harness/SKILL.md +207 -0
  248. package/bundled/upstream/ecc/skills/healthcare-phi-compliance/SKILL.md +145 -0
  249. package/bundled/upstream/ecc/skills/hexagonal-architecture/SKILL.md +276 -0
  250. package/bundled/upstream/ecc/skills/hipaa-compliance/SKILL.md +78 -0
  251. package/bundled/upstream/ecc/skills/hookify-rules/SKILL.md +128 -0
  252. package/bundled/upstream/ecc/skills/inventory-demand-planning/SKILL.md +247 -0
  253. package/bundled/upstream/ecc/skills/investor-materials/SKILL.md +96 -0
  254. package/bundled/upstream/ecc/skills/investor-outreach/SKILL.md +91 -0
  255. package/bundled/upstream/ecc/skills/iterative-retrieval/SKILL.md +211 -0
  256. package/bundled/upstream/ecc/skills/java-coding-standards/SKILL.md +147 -0
  257. package/bundled/upstream/ecc/skills/jira-integration/SKILL.md +293 -0
  258. package/bundled/upstream/ecc/skills/jpa-patterns/SKILL.md +151 -0
  259. package/bundled/upstream/ecc/skills/knowledge-ops/SKILL.md +154 -0
  260. package/bundled/upstream/ecc/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  261. package/bundled/upstream/ecc/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  262. package/bundled/upstream/ecc/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  263. package/bundled/upstream/ecc/skills/kotlin-patterns/SKILL.md +711 -0
  264. package/bundled/upstream/ecc/skills/kotlin-testing/SKILL.md +824 -0
  265. package/bundled/upstream/ecc/skills/laravel-patterns/SKILL.md +415 -0
  266. package/bundled/upstream/ecc/skills/laravel-plugin-discovery/SKILL.md +229 -0
  267. package/bundled/upstream/ecc/skills/laravel-security/SKILL.md +285 -0
  268. package/bundled/upstream/ecc/skills/laravel-tdd/SKILL.md +283 -0
  269. package/bundled/upstream/ecc/skills/laravel-verification/SKILL.md +179 -0
  270. package/bundled/upstream/ecc/skills/lead-intelligence/SKILL.md +321 -0
  271. package/bundled/upstream/ecc/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  272. package/bundled/upstream/ecc/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  273. package/bundled/upstream/ecc/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  274. package/bundled/upstream/ecc/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  275. package/bundled/upstream/ecc/skills/liquid-glass-design/SKILL.md +279 -0
  276. package/bundled/upstream/ecc/skills/llm-trading-agent-security/SKILL.md +146 -0
  277. package/bundled/upstream/ecc/skills/logistics-exception-management/SKILL.md +222 -0
  278. package/bundled/upstream/ecc/skills/manim-video/SKILL.md +89 -0
  279. package/bundled/upstream/ecc/skills/manim-video/assets/network_graph_scene.py +52 -0
  280. package/bundled/upstream/ecc/skills/market-research/SKILL.md +75 -0
  281. package/bundled/upstream/ecc/skills/mcp-server-patterns/SKILL.md +69 -0
  282. package/bundled/upstream/ecc/skills/messages-ops/SKILL.md +104 -0
  283. package/bundled/upstream/ecc/skills/nanoclaw-repl/SKILL.md +33 -0
  284. package/bundled/upstream/ecc/skills/nestjs-patterns/SKILL.md +230 -0
  285. package/bundled/upstream/ecc/skills/nextjs-turbopack/SKILL.md +44 -0
  286. package/bundled/upstream/ecc/skills/nodejs-keccak256/SKILL.md +102 -0
  287. package/bundled/upstream/ecc/skills/nutrient-document-processing/SKILL.md +167 -0
  288. package/bundled/upstream/ecc/skills/nuxt4-patterns/SKILL.md +100 -0
  289. package/bundled/upstream/ecc/skills/openclaw-persona-forge/SKILL.md +296 -0
  290. package/bundled/upstream/ecc/skills/openclaw-persona-forge/gacha.py +224 -0
  291. package/bundled/upstream/ecc/skills/openclaw-persona-forge/gacha.sh +5 -0
  292. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  293. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  294. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  295. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  296. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  297. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/output-template.md +166 -0
  298. package/bundled/upstream/ecc/skills/opensource-pipeline/SKILL.md +255 -0
  299. package/bundled/upstream/ecc/skills/perl-patterns/SKILL.md +504 -0
  300. package/bundled/upstream/ecc/skills/perl-security/SKILL.md +503 -0
  301. package/bundled/upstream/ecc/skills/perl-testing/SKILL.md +475 -0
  302. package/bundled/upstream/ecc/skills/plankton-code-quality/SKILL.md +236 -0
  303. package/bundled/upstream/ecc/skills/postgres-patterns/SKILL.md +147 -0
  304. package/bundled/upstream/ecc/skills/product-capability/SKILL.md +141 -0
  305. package/bundled/upstream/ecc/skills/product-lens/SKILL.md +92 -0
  306. package/bundled/upstream/ecc/skills/production-scheduling/SKILL.md +238 -0
  307. package/bundled/upstream/ecc/skills/project-flow-ops/SKILL.md +111 -0
  308. package/bundled/upstream/ecc/skills/prompt-optimizer/SKILL.md +397 -0
  309. package/bundled/upstream/ecc/skills/python-patterns/SKILL.md +750 -0
  310. package/bundled/upstream/ecc/skills/python-testing/SKILL.md +816 -0
  311. package/bundled/upstream/ecc/skills/pytorch-patterns/SKILL.md +396 -0
  312. package/bundled/upstream/ecc/skills/quality-nonconformance/SKILL.md +260 -0
  313. package/bundled/upstream/ecc/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
  314. package/bundled/upstream/ecc/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  315. package/bundled/upstream/ecc/skills/remotion-video-creation/SKILL.md +43 -0
  316. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/3d.md +86 -0
  317. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/animations.md +29 -0
  318. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  319. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  320. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  321. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets.md +78 -0
  322. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/audio.md +172 -0
  323. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  324. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/can-decode.md +75 -0
  325. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/charts.md +58 -0
  326. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/compositions.md +146 -0
  327. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/display-captions.md +126 -0
  328. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  329. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/fonts.md +152 -0
  330. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  331. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  332. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  333. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/gifs.md +138 -0
  334. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/images.md +130 -0
  335. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  336. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/lottie.md +67 -0
  337. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  338. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  339. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/sequencing.md +106 -0
  340. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/tailwind.md +11 -0
  341. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/text-animations.md +20 -0
  342. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/timing.md +179 -0
  343. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  344. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/transitions.md +122 -0
  345. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/trimming.md +52 -0
  346. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/videos.md +171 -0
  347. package/bundled/upstream/ecc/skills/repo-scan/SKILL.md +78 -0
  348. package/bundled/upstream/ecc/skills/research-ops/SKILL.md +112 -0
  349. package/bundled/upstream/ecc/skills/returns-reverse-logistics/SKILL.md +240 -0
  350. package/bundled/upstream/ecc/skills/rules-distill/SKILL.md +264 -0
  351. package/bundled/upstream/ecc/skills/rules-distill/scripts/scan-rules.sh +58 -0
  352. package/bundled/upstream/ecc/skills/rules-distill/scripts/scan-skills.sh +129 -0
  353. package/bundled/upstream/ecc/skills/rust-patterns/SKILL.md +499 -0
  354. package/bundled/upstream/ecc/skills/rust-testing/SKILL.md +500 -0
  355. package/bundled/upstream/ecc/skills/safety-guard/SKILL.md +75 -0
  356. package/bundled/upstream/ecc/skills/santa-method/SKILL.md +306 -0
  357. package/bundled/upstream/ecc/skills/search-first/SKILL.md +161 -0
  358. package/bundled/upstream/ecc/skills/security-bounty-hunter/SKILL.md +99 -0
  359. package/bundled/upstream/ecc/skills/security-review/SKILL.md +495 -0
  360. package/bundled/upstream/ecc/skills/security-review/cloud-infrastructure-security.md +361 -0
  361. package/bundled/upstream/ecc/skills/security-scan/SKILL.md +165 -0
  362. package/bundled/upstream/ecc/skills/seo/SKILL.md +154 -0
  363. package/bundled/upstream/ecc/skills/skill-comply/SKILL.md +58 -0
  364. package/bundled/upstream/ecc/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  365. package/bundled/upstream/ecc/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  366. package/bundled/upstream/ecc/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  367. package/bundled/upstream/ecc/skills/skill-comply/prompts/classifier.md +24 -0
  368. package/bundled/upstream/ecc/skills/skill-comply/prompts/scenario_generator.md +62 -0
  369. package/bundled/upstream/ecc/skills/skill-comply/prompts/spec_generator.md +42 -0
  370. package/bundled/upstream/ecc/skills/skill-comply/pyproject.toml +15 -0
  371. package/bundled/upstream/ecc/skills/skill-comply/scripts/__init__.py +0 -0
  372. package/bundled/upstream/ecc/skills/skill-comply/scripts/classifier.py +85 -0
  373. package/bundled/upstream/ecc/skills/skill-comply/scripts/grader.py +124 -0
  374. package/bundled/upstream/ecc/skills/skill-comply/scripts/parser.py +107 -0
  375. package/bundled/upstream/ecc/skills/skill-comply/scripts/report.py +170 -0
  376. package/bundled/upstream/ecc/skills/skill-comply/scripts/run.py +127 -0
  377. package/bundled/upstream/ecc/skills/skill-comply/scripts/runner.py +161 -0
  378. package/bundled/upstream/ecc/skills/skill-comply/scripts/scenario_generator.py +70 -0
  379. package/bundled/upstream/ecc/skills/skill-comply/scripts/spec_generator.py +72 -0
  380. package/bundled/upstream/ecc/skills/skill-comply/scripts/utils.py +13 -0
  381. package/bundled/upstream/ecc/skills/skill-comply/tests/test_grader.py +197 -0
  382. package/bundled/upstream/ecc/skills/skill-comply/tests/test_parser.py +90 -0
  383. package/bundled/upstream/ecc/skills/skill-stocktake/SKILL.md +193 -0
  384. package/bundled/upstream/ecc/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  385. package/bundled/upstream/ecc/skills/skill-stocktake/scripts/save-results.sh +56 -0
  386. package/bundled/upstream/ecc/skills/skill-stocktake/scripts/scan.sh +170 -0
  387. package/bundled/upstream/ecc/skills/social-graph-ranker/SKILL.md +154 -0
  388. package/bundled/upstream/ecc/skills/springboot-patterns/SKILL.md +314 -0
  389. package/bundled/upstream/ecc/skills/springboot-security/SKILL.md +272 -0
  390. package/bundled/upstream/ecc/skills/springboot-tdd/SKILL.md +158 -0
  391. package/bundled/upstream/ecc/skills/springboot-verification/SKILL.md +231 -0
  392. package/bundled/upstream/ecc/skills/strategic-compact/SKILL.md +131 -0
  393. package/bundled/upstream/ecc/skills/strategic-compact/suggest-compact.sh +54 -0
  394. package/bundled/upstream/ecc/skills/swift-actor-persistence/SKILL.md +143 -0
  395. package/bundled/upstream/ecc/skills/swift-concurrency-6-2/SKILL.md +216 -0
  396. package/bundled/upstream/ecc/skills/swift-protocol-di-testing/SKILL.md +190 -0
  397. package/bundled/upstream/ecc/skills/swiftui-patterns/SKILL.md +259 -0
  398. package/bundled/upstream/ecc/skills/tdd-workflow/SKILL.md +463 -0
  399. package/bundled/upstream/ecc/skills/team-builder/SKILL.md +168 -0
  400. package/bundled/upstream/ecc/skills/terminal-ops/SKILL.md +109 -0
  401. package/bundled/upstream/ecc/skills/token-budget-advisor/SKILL.md +133 -0
  402. package/bundled/upstream/ecc/skills/ui-demo/SKILL.md +465 -0
  403. package/bundled/upstream/ecc/skills/unified-notifications-ops/SKILL.md +187 -0
  404. package/bundled/upstream/ecc/skills/verification-loop/SKILL.md +126 -0
  405. package/bundled/upstream/ecc/skills/video-editing/SKILL.md +310 -0
  406. package/bundled/upstream/ecc/skills/videodb/SKILL.md +374 -0
  407. package/bundled/upstream/ecc/skills/videodb/reference/api-reference.md +550 -0
  408. package/bundled/upstream/ecc/skills/videodb/reference/capture-reference.md +407 -0
  409. package/bundled/upstream/ecc/skills/videodb/reference/capture.md +101 -0
  410. package/bundled/upstream/ecc/skills/videodb/reference/editor.md +443 -0
  411. package/bundled/upstream/ecc/skills/videodb/reference/generative.md +331 -0
  412. package/bundled/upstream/ecc/skills/videodb/reference/rtstream-reference.md +564 -0
  413. package/bundled/upstream/ecc/skills/videodb/reference/rtstream.md +65 -0
  414. package/bundled/upstream/ecc/skills/videodb/reference/search.md +230 -0
  415. package/bundled/upstream/ecc/skills/videodb/reference/streaming.md +406 -0
  416. package/bundled/upstream/ecc/skills/videodb/reference/use-cases.md +118 -0
  417. package/bundled/upstream/ecc/skills/videodb/scripts/ws_listener.py +282 -0
  418. package/bundled/upstream/ecc/skills/visa-doc-translate/README.md +86 -0
  419. package/bundled/upstream/ecc/skills/visa-doc-translate/SKILL.md +117 -0
  420. package/bundled/upstream/ecc/skills/workspace-surface-audit/SKILL.md +125 -0
  421. package/bundled/upstream/ecc/skills/x-api/SKILL.md +230 -0
  422. package/bundled/upstream/superpowers/.omc-source/last-plan-apply.json +22 -0
  423. package/package.json +3 -1
  424. package/src/catalog/source-catalog.js +391 -0
  425. package/src/cli/artifact.js +3 -2
  426. package/src/cli/doctor.js +25 -4
  427. package/src/cli/index.js +19 -0
  428. package/src/cli/plan.js +220 -0
  429. package/src/cli/setup.js +209 -12
  430. package/src/cli/source.js +110 -3
  431. package/src/config/paths.js +31 -0
  432. package/src/config/sources.js +103 -10
  433. 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.