claude-code-pilot 2.0.0 → 3.0.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 (455) hide show
  1. package/bin/install.js +267 -250
  2. package/manifest.json +5 -18
  3. package/package.json +5 -7
  4. package/src/agents/build-error-resolver.md +114 -0
  5. package/src/agents/ccp-advisor-researcher.md +104 -0
  6. package/src/agents/ccp-assumptions-analyzer.md +105 -0
  7. package/{gsd/agents/gsd-codebase-mapper.md → src/agents/ccp-codebase-mapper.md} +7 -7
  8. package/{gsd/agents/gsd-debugger.md → src/agents/ccp-debugger.md} +125 -8
  9. package/{gsd/agents/gsd-executor.md → src/agents/ccp-executor.md} +31 -20
  10. package/{gsd/agents/gsd-integration-checker.md → src/agents/ccp-integration-checker.md} +2 -2
  11. package/{gsd/agents/gsd-nyquist-auditor.md → src/agents/ccp-nyquist-auditor.md} +3 -3
  12. package/{gsd/agents/gsd-phase-researcher.md → src/agents/ccp-phase-researcher.md} +127 -13
  13. package/{gsd/agents/gsd-plan-checker.md → src/agents/ccp-plan-checker.md} +57 -21
  14. package/{gsd/agents/gsd-planner.md → src/agents/ccp-planner.md} +61 -23
  15. package/{gsd/agents/gsd-project-researcher.md → src/agents/ccp-project-researcher.md} +33 -6
  16. package/{gsd/agents/gsd-research-synthesizer.md → src/agents/ccp-research-synthesizer.md} +11 -11
  17. package/{gsd/agents/gsd-roadmapper.md → src/agents/ccp-roadmapper.md} +39 -10
  18. package/src/agents/ccp-ui-auditor.md +439 -0
  19. package/src/agents/ccp-ui-checker.md +300 -0
  20. package/src/agents/ccp-ui-researcher.md +357 -0
  21. package/{gsd/agents/gsd-verifier.md → src/agents/ccp-verifier.md} +81 -15
  22. package/src/agents/cpp-build-resolver.md +90 -0
  23. package/src/agents/cpp-reviewer.md +72 -0
  24. package/src/agents/database-reviewer.md +91 -0
  25. package/src/agents/docs-lookup.md +68 -0
  26. package/src/agents/flutter-reviewer.md +243 -0
  27. package/src/agents/go-build-resolver.md +94 -0
  28. package/src/agents/go-reviewer.md +76 -0
  29. package/src/agents/java-build-resolver.md +153 -0
  30. package/src/agents/java-reviewer.md +92 -0
  31. package/src/agents/kotlin-build-resolver.md +118 -0
  32. package/src/agents/kotlin-reviewer.md +159 -0
  33. package/src/agents/planner.md +212 -0
  34. package/src/agents/python-reviewer.md +98 -0
  35. package/src/agents/pytorch-build-resolver.md +120 -0
  36. package/src/agents/refactor-cleaner.md +85 -0
  37. package/src/agents/rust-build-resolver.md +148 -0
  38. package/src/agents/rust-reviewer.md +94 -0
  39. package/src/agents/typescript-reviewer.md +112 -0
  40. package/src/available-rules/README.md +80 -0
  41. package/src/available-rules/cpp/coding-style.md +44 -0
  42. package/src/available-rules/cpp/hooks.md +39 -0
  43. package/src/available-rules/cpp/patterns.md +51 -0
  44. package/src/available-rules/cpp/security.md +51 -0
  45. package/src/available-rules/cpp/testing.md +44 -0
  46. package/src/available-rules/csharp/coding-style.md +72 -0
  47. package/src/available-rules/csharp/hooks.md +25 -0
  48. package/src/available-rules/csharp/patterns.md +50 -0
  49. package/src/available-rules/csharp/security.md +58 -0
  50. package/src/available-rules/csharp/testing.md +46 -0
  51. package/src/available-rules/java/coding-style.md +114 -0
  52. package/src/available-rules/java/hooks.md +18 -0
  53. package/src/available-rules/java/patterns.md +146 -0
  54. package/src/available-rules/java/security.md +100 -0
  55. package/src/available-rules/java/testing.md +131 -0
  56. package/src/available-rules/kotlin/hooks.md +17 -0
  57. package/src/available-rules/rust/coding-style.md +151 -0
  58. package/src/available-rules/rust/hooks.md +16 -0
  59. package/src/available-rules/rust/patterns.md +168 -0
  60. package/src/available-rules/rust/security.md +141 -0
  61. package/src/available-rules/rust/testing.md +154 -0
  62. package/src/commands/aside.md +164 -0
  63. package/src/commands/build-fix.md +62 -0
  64. package/src/commands/ccp/add-backlog.md +76 -0
  65. package/{gsd/commands-gsd → src/commands/ccp}/add-phase.md +3 -3
  66. package/{gsd/commands-gsd → src/commands/ccp}/add-tests.md +5 -5
  67. package/{gsd/commands-gsd → src/commands/ccp}/add-todo.md +4 -4
  68. package/{gsd/commands-gsd → src/commands/ccp}/audit-milestone.md +3 -3
  69. package/src/commands/ccp/audit-uat.md +24 -0
  70. package/src/commands/ccp/autonomous.md +41 -0
  71. package/{gsd/commands-gsd → src/commands/ccp}/check-todos.md +3 -3
  72. package/{gsd/commands-gsd → src/commands/ccp}/cleanup.md +3 -3
  73. package/{gsd/commands-gsd → src/commands/ccp}/complete-milestone.md +9 -9
  74. package/{gsd/commands-gsd → src/commands/ccp}/debug.md +14 -9
  75. package/src/commands/ccp/discuss-phase.md +64 -0
  76. package/src/commands/ccp/do.md +30 -0
  77. package/src/commands/ccp/execute-phase.md +59 -0
  78. package/src/commands/ccp/fast.md +30 -0
  79. package/src/commands/ccp/forensics.md +56 -0
  80. package/{gsd/commands-gsd → src/commands/ccp}/health.md +3 -3
  81. package/{gsd/commands-gsd → src/commands/ccp}/help.md +5 -5
  82. package/{gsd/commands-gsd → src/commands/ccp}/insert-phase.md +3 -3
  83. package/{gsd/commands-gsd → src/commands/ccp}/list-phase-assumptions.md +2 -2
  84. package/src/commands/ccp/manager.md +39 -0
  85. package/{gsd/commands-gsd → src/commands/ccp}/map-codebase.md +7 -7
  86. package/src/commands/ccp/milestone-summary.md +51 -0
  87. package/{gsd/commands-gsd → src/commands/ccp}/new-milestone.md +8 -8
  88. package/{gsd/commands-gsd → src/commands/ccp}/new-project.md +8 -8
  89. package/src/commands/ccp/next.md +24 -0
  90. package/src/commands/ccp/note.md +34 -0
  91. package/{gsd/commands-gsd → src/commands/ccp}/pause-work.md +3 -3
  92. package/{gsd/commands-gsd → src/commands/ccp}/plan-milestone-gaps.md +5 -5
  93. package/{gsd/commands-gsd → src/commands/ccp}/plan-phase.md +9 -7
  94. package/src/commands/ccp/plant-seed.md +28 -0
  95. package/src/commands/ccp/pr-branch.md +25 -0
  96. package/{gsd/commands-gsd → src/commands/ccp}/progress.md +3 -3
  97. package/{gsd/commands-gsd → src/commands/ccp}/quick.md +10 -8
  98. package/{gsd/commands-gsd → src/commands/ccp}/remove-phase.md +3 -3
  99. package/{gsd/commands-gsd → src/commands/ccp}/research-phase.md +17 -12
  100. package/{gsd/commands-gsd → src/commands/ccp}/resume-work.md +3 -3
  101. package/src/commands/ccp/review-backlog.md +61 -0
  102. package/src/commands/ccp/session-report.md +19 -0
  103. package/src/commands/ccp/set-profile.md +12 -0
  104. package/{gsd/commands-gsd → src/commands/ccp}/settings.md +5 -5
  105. package/src/commands/ccp/ship.md +23 -0
  106. package/src/commands/ccp/stats.md +18 -0
  107. package/src/commands/ccp/thread.md +127 -0
  108. package/src/commands/ccp/ui-phase.md +34 -0
  109. package/src/commands/ccp/ui-review.md +32 -0
  110. package/{gsd/commands-gsd → src/commands/ccp}/update.md +5 -5
  111. package/{gsd/commands-gsd → src/commands/ccp}/validate-phase.md +3 -3
  112. package/{gsd/commands-gsd → src/commands/ccp}/verify-work.md +5 -5
  113. package/src/commands/code-review.md +40 -0
  114. package/src/commands/context-budget.md +29 -0
  115. package/src/commands/cpp-build.md +173 -0
  116. package/src/commands/cpp-review.md +132 -0
  117. package/src/commands/cpp-test.md +251 -0
  118. package/src/commands/docs.md +31 -0
  119. package/src/commands/e2e.md +364 -0
  120. package/src/commands/eval.md +120 -0
  121. package/{ecc → src}/commands/evolve.md +2 -2
  122. package/src/commands/go-build.md +183 -0
  123. package/src/commands/go-review.md +148 -0
  124. package/src/commands/go-test.md +268 -0
  125. package/src/commands/gradle-build.md +70 -0
  126. package/src/commands/harness-audit.md +71 -0
  127. package/src/commands/kotlin-build.md +174 -0
  128. package/src/commands/kotlin-review.md +140 -0
  129. package/src/commands/kotlin-test.md +312 -0
  130. package/src/commands/orchestrate.md +231 -0
  131. package/src/commands/plan.md +114 -0
  132. package/src/commands/prompt-optimize.md +38 -0
  133. package/src/commands/prune.md +25 -0
  134. package/src/commands/python-review.md +297 -0
  135. package/{ecc → src}/commands/quality-gate.md +1 -1
  136. package/src/commands/refactor-clean.md +80 -0
  137. package/src/commands/rules-distill.md +11 -0
  138. package/src/commands/rust-build.md +187 -0
  139. package/src/commands/rust-review.md +142 -0
  140. package/src/commands/rust-test.md +308 -0
  141. package/{ecc → src}/commands/sessions.md +10 -10
  142. package/src/commands/setup-pm.md +80 -0
  143. package/{kit → src}/commands/setup.md +45 -19
  144. package/src/commands/skill-create.md +172 -0
  145. package/src/commands/skill-health.md +51 -0
  146. package/src/commands/tdd.md +328 -0
  147. package/src/commands/test-coverage.md +69 -0
  148. package/src/commands/update-codemaps.md +72 -0
  149. package/src/commands/update-docs.md +84 -0
  150. package/{gsd/hooks/gsd-context-monitor.js → src/hooks/ccp-context-monitor.js} +3 -3
  151. package/src/hooks/ccp-prompt-guard.js +96 -0
  152. package/{gsd/hooks/gsd-statusline.js → src/hooks/ccp-statusline.js} +7 -7
  153. package/src/hooks/ccp-workflow-guard.js +94 -0
  154. package/src/hooks/config-protection.js +141 -0
  155. package/{kit → src}/hooks/kit-check-update.js +7 -4
  156. package/src/hooks/mcp-health-check.js +620 -0
  157. package/{ecc/scripts → src}/hooks/run-with-flags-shell.sh +1 -1
  158. package/{ecc/scripts → src}/hooks/run-with-flags.js +74 -13
  159. package/src/hooks/session-end-marker.js +29 -0
  160. package/{ecc/scripts → src}/hooks/session-end.js +83 -40
  161. package/{ecc/scripts → src}/hooks/session-start.js +75 -9
  162. package/{ecc/scripts → src}/lib/hook-flags.js +8 -4
  163. package/{ecc/scripts → src}/lib/project-detect.js +2 -1
  164. package/{ecc/scripts → src}/lib/session-manager.d.ts +5 -1
  165. package/{ecc/scripts → src}/lib/session-manager.js +202 -92
  166. package/{ecc/scripts → src}/lib/utils.d.ts +23 -1
  167. package/{ecc/scripts → src}/lib/utils.js +91 -3
  168. package/{gsd/get-shit-done/bin/gsd-tools.cjs → src/pilot/bin/ccp-tools.cjs} +257 -86
  169. package/{gsd/get-shit-done → src/pilot}/bin/lib/commands.cjs +1 -1
  170. package/src/pilot/bin/lib/config.cjs +444 -0
  171. package/src/pilot/bin/lib/core.cjs +1190 -0
  172. package/src/pilot/bin/lib/init.cjs +1281 -0
  173. package/src/pilot/bin/lib/model-profiles.cjs +67 -0
  174. package/{gsd/get-shit-done → src/pilot}/bin/lib/phase.cjs +2 -2
  175. package/src/pilot/bin/lib/security.cjs +382 -0
  176. package/{gsd/get-shit-done → src/pilot}/bin/lib/state.cjs +1 -1
  177. package/src/pilot/bin/lib/uat.cjs +282 -0
  178. package/{gsd/get-shit-done → src/pilot}/bin/lib/verify.cjs +10 -10
  179. package/{gsd/get-shit-done → src/pilot}/references/continuation-format.md +16 -16
  180. package/{gsd/get-shit-done → src/pilot}/references/decimal-phase-calculation.md +5 -5
  181. package/{gsd/get-shit-done → src/pilot}/references/git-integration.md +5 -5
  182. package/{gsd/get-shit-done → src/pilot}/references/git-planning-commit.md +4 -4
  183. package/src/pilot/references/mcp-servers.json +153 -0
  184. package/{gsd/get-shit-done → src/pilot}/references/model-profile-resolution.md +2 -2
  185. package/{gsd/get-shit-done → src/pilot}/references/model-profiles.md +20 -20
  186. package/{gsd/get-shit-done → src/pilot}/references/phase-argument-parsing.md +4 -4
  187. package/{gsd/get-shit-done → src/pilot}/references/planning-config.md +15 -15
  188. package/{gsd/get-shit-done → src/pilot}/references/ui-brand.md +5 -5
  189. package/{gsd/get-shit-done → src/pilot}/references/verification-patterns.md +1 -1
  190. package/{gsd/get-shit-done → src/pilot}/templates/DEBUG.md +1 -1
  191. package/{gsd/get-shit-done → src/pilot}/templates/UAT.md +3 -3
  192. package/src/pilot/templates/UI-SPEC.md +100 -0
  193. package/{gsd/get-shit-done → src/pilot}/templates/VALIDATION.md +1 -1
  194. package/src/pilot/templates/claude-md.md +122 -0
  195. package/{gsd/get-shit-done → src/pilot}/templates/codebase/architecture.md +2 -2
  196. package/{gsd/get-shit-done → src/pilot}/templates/codebase/structure.md +13 -13
  197. package/{gsd/get-shit-done → src/pilot}/templates/context.md +4 -4
  198. package/src/pilot/templates/copilot-instructions.md +7 -0
  199. package/{gsd/get-shit-done → src/pilot}/templates/debug-subagent-prompt.md +4 -4
  200. package/src/pilot/templates/dev-preferences.md +21 -0
  201. package/{gsd/get-shit-done → src/pilot}/templates/discovery.md +2 -2
  202. package/src/pilot/templates/discussion-log.md +63 -0
  203. package/{gsd/get-shit-done → src/pilot}/templates/phase-prompt.md +12 -12
  204. package/{gsd/get-shit-done → src/pilot}/templates/planner-subagent-prompt.md +7 -7
  205. package/{gsd/get-shit-done → src/pilot}/templates/project.md +1 -1
  206. package/{gsd/get-shit-done → src/pilot}/templates/research.md +2 -2
  207. package/{gsd/get-shit-done → src/pilot}/templates/state.md +2 -2
  208. package/{gsd/get-shit-done → src/pilot}/templates/summary-complex.md +1 -1
  209. package/{gsd/get-shit-done → src/pilot}/workflows/add-phase.md +11 -11
  210. package/{gsd/get-shit-done → src/pilot}/workflows/add-tests.md +15 -15
  211. package/{gsd/get-shit-done → src/pilot}/workflows/add-todo.md +7 -7
  212. package/{gsd/get-shit-done → src/pilot}/workflows/audit-milestone.md +24 -16
  213. package/src/pilot/workflows/audit-uat.md +109 -0
  214. package/src/pilot/workflows/autonomous.md +891 -0
  215. package/{gsd/get-shit-done → src/pilot}/workflows/check-todos.md +10 -10
  216. package/{gsd/get-shit-done → src/pilot}/workflows/cleanup.md +3 -3
  217. package/{gsd/get-shit-done → src/pilot}/workflows/complete-milestone.md +19 -16
  218. package/{gsd/get-shit-done → src/pilot}/workflows/diagnose-issues.md +9 -4
  219. package/{gsd/get-shit-done → src/pilot}/workflows/discovery-phase.md +8 -8
  220. package/src/pilot/workflows/discuss-phase-assumptions.md +653 -0
  221. package/{gsd/get-shit-done → src/pilot}/workflows/discuss-phase.md +407 -49
  222. package/src/pilot/workflows/do.md +104 -0
  223. package/src/pilot/workflows/execute-phase.md +821 -0
  224. package/{gsd/get-shit-done → src/pilot}/workflows/execute-plan.md +79 -28
  225. package/src/pilot/workflows/fast.md +105 -0
  226. package/src/pilot/workflows/forensics.md +265 -0
  227. package/{gsd/get-shit-done → src/pilot}/workflows/health.md +34 -11
  228. package/src/pilot/workflows/help.md +775 -0
  229. package/{gsd/get-shit-done → src/pilot}/workflows/insert-phase.md +10 -10
  230. package/{gsd/get-shit-done → src/pilot}/workflows/list-phase-assumptions.md +4 -4
  231. package/src/pilot/workflows/manager.md +362 -0
  232. package/{gsd/get-shit-done → src/pilot}/workflows/map-codebase.md +27 -17
  233. package/src/pilot/workflows/milestone-summary.md +223 -0
  234. package/{gsd/get-shit-done → src/pilot}/workflows/new-milestone.md +135 -33
  235. package/{gsd/get-shit-done → src/pilot}/workflows/new-project.md +152 -79
  236. package/src/pilot/workflows/next.md +97 -0
  237. package/src/pilot/workflows/node-repair.md +92 -0
  238. package/src/pilot/workflows/note.md +156 -0
  239. package/src/pilot/workflows/pause-work.md +177 -0
  240. package/{gsd/get-shit-done → src/pilot}/workflows/plan-milestone-gaps.md +10 -11
  241. package/src/pilot/workflows/plan-phase.md +859 -0
  242. package/src/pilot/workflows/plant-seed.md +169 -0
  243. package/src/pilot/workflows/pr-branch.md +129 -0
  244. package/{gsd/get-shit-done → src/pilot}/workflows/progress.md +95 -34
  245. package/{gsd/get-shit-done → src/pilot}/workflows/quick.md +33 -21
  246. package/{gsd/get-shit-done → src/pilot}/workflows/remove-phase.md +14 -14
  247. package/{gsd/get-shit-done → src/pilot}/workflows/research-phase.md +18 -10
  248. package/{gsd/get-shit-done → src/pilot}/workflows/resume-project.md +37 -18
  249. package/src/pilot/workflows/session-report.md +146 -0
  250. package/{gsd/get-shit-done → src/pilot}/workflows/set-profile.md +7 -7
  251. package/{gsd/get-shit-done → src/pilot}/workflows/settings.md +75 -22
  252. package/src/pilot/workflows/ship.md +228 -0
  253. package/src/pilot/workflows/stats.md +60 -0
  254. package/{gsd/get-shit-done → src/pilot}/workflows/transition.md +57 -17
  255. package/src/pilot/workflows/ui-phase.md +302 -0
  256. package/src/pilot/workflows/ui-review.md +165 -0
  257. package/{gsd/get-shit-done → src/pilot}/workflows/update.md +88 -58
  258. package/{gsd/get-shit-done → src/pilot}/workflows/validate-phase.md +24 -17
  259. package/{gsd/get-shit-done → src/pilot}/workflows/verify-phase.md +26 -15
  260. package/{gsd/get-shit-done → src/pilot}/workflows/verify-work.md +89 -37
  261. package/{ecc → src}/rules/common/agents.md +1 -0
  262. package/{ecc → src}/rules/common/coding-style.md +21 -0
  263. package/src/skills/agentic-engineering/SKILL.md +63 -0
  264. package/src/skills/ai-first-engineering/SKILL.md +51 -0
  265. package/src/skills/ai-regression-testing/SKILL.md +385 -0
  266. package/src/skills/api-design/SKILL.md +523 -0
  267. package/src/skills/architecture-decision-records/SKILL.md +179 -0
  268. package/src/skills/backend-patterns/SKILL.md +598 -0
  269. package/src/skills/benchmark/SKILL.md +87 -0
  270. package/src/skills/blueprint/SKILL.md +90 -0
  271. package/src/skills/browser-qa/SKILL.md +81 -0
  272. package/src/skills/claude-api/SKILL.md +337 -0
  273. package/src/skills/codebase-onboarding/SKILL.md +233 -0
  274. package/src/skills/coding-standards/SKILL.md +530 -0
  275. package/src/skills/context-budget/SKILL.md +135 -0
  276. package/{ecc → src}/skills/continuous-learning-v2/SKILL.md +2 -2
  277. package/{ecc → src}/skills/continuous-learning-v2/agents/observer-loop.sh +1 -1
  278. package/src/skills/cpp-coding-standards/SKILL.md +723 -0
  279. package/src/skills/cpp-testing/SKILL.md +324 -0
  280. package/src/skills/database-migrations/SKILL.md +429 -0
  281. package/src/skills/deep-research/SKILL.md +155 -0
  282. package/src/skills/deployment-patterns/SKILL.md +427 -0
  283. package/src/skills/django-patterns/SKILL.md +734 -0
  284. package/src/skills/django-security/SKILL.md +593 -0
  285. package/src/skills/django-tdd/SKILL.md +729 -0
  286. package/src/skills/django-verification/SKILL.md +469 -0
  287. package/src/skills/docker-patterns/SKILL.md +364 -0
  288. package/src/skills/documentation-lookup/SKILL.md +90 -0
  289. package/src/skills/e2e-testing/SKILL.md +326 -0
  290. package/src/skills/exa-search/SKILL.md +103 -0
  291. package/src/skills/frontend-patterns/SKILL.md +642 -0
  292. package/src/skills/golang-patterns/SKILL.md +674 -0
  293. package/src/skills/golang-testing/SKILL.md +720 -0
  294. package/src/skills/java-coding-standards/SKILL.md +147 -0
  295. package/src/skills/jpa-patterns/SKILL.md +151 -0
  296. package/src/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  297. package/src/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  298. package/src/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  299. package/src/skills/kotlin-patterns/SKILL.md +711 -0
  300. package/src/skills/kotlin-testing/SKILL.md +824 -0
  301. package/src/skills/laravel-patterns/SKILL.md +415 -0
  302. package/src/skills/laravel-security/SKILL.md +285 -0
  303. package/src/skills/laravel-tdd/SKILL.md +283 -0
  304. package/src/skills/laravel-verification/SKILL.md +179 -0
  305. package/src/skills/mcp-server-patterns/SKILL.md +67 -0
  306. package/src/skills/perl-patterns/SKILL.md +504 -0
  307. package/src/skills/perl-testing/SKILL.md +475 -0
  308. package/src/skills/postgres-patterns/SKILL.md +147 -0
  309. package/src/skills/prompt-optimizer/SKILL.md +397 -0
  310. package/src/skills/python-patterns/SKILL.md +750 -0
  311. package/src/skills/python-testing/SKILL.md +816 -0
  312. package/src/skills/rust-patterns/SKILL.md +499 -0
  313. package/src/skills/rust-testing/SKILL.md +500 -0
  314. package/src/skills/safety-guard/SKILL.md +69 -0
  315. package/src/skills/search-first/SKILL.md +161 -0
  316. package/src/skills/security-review/SKILL.md +495 -0
  317. package/src/skills/security-review/cloud-infrastructure-security.md +361 -0
  318. package/src/skills/security-scan/SKILL.md +165 -0
  319. package/src/skills/springboot-patterns/SKILL.md +314 -0
  320. package/src/skills/springboot-security/SKILL.md +272 -0
  321. package/src/skills/springboot-tdd/SKILL.md +158 -0
  322. package/src/skills/springboot-verification/SKILL.md +231 -0
  323. package/src/skills/tdd-workflow/SKILL.md +410 -0
  324. package/ecc/scripts/hooks/session-end-marker.js +0 -15
  325. package/gsd/LICENSE +0 -21
  326. package/gsd/commands-gsd/discuss-phase.md +0 -90
  327. package/gsd/commands-gsd/execute-phase.md +0 -41
  328. package/gsd/commands-gsd/join-discord.md +0 -18
  329. package/gsd/commands-gsd/reapply-patches.md +0 -123
  330. package/gsd/commands-gsd/set-profile.md +0 -34
  331. package/gsd/get-shit-done/bin/lib/config.cjs +0 -169
  332. package/gsd/get-shit-done/bin/lib/core.cjs +0 -492
  333. package/gsd/get-shit-done/bin/lib/init.cjs +0 -710
  334. package/gsd/get-shit-done/workflows/execute-phase.md +0 -459
  335. package/gsd/get-shit-done/workflows/help.md +0 -489
  336. package/gsd/get-shit-done/workflows/pause-work.md +0 -122
  337. package/gsd/get-shit-done/workflows/plan-phase.md +0 -560
  338. package/gsd/hooks/gsd-check-update.js +0 -81
  339. package/kit/CLAUDE.md +0 -43
  340. package/kit/commands/kit/update.md +0 -46
  341. package/kit/mcp.json +0 -10
  342. package/kit/rules/code-style.md +0 -24
  343. /package/{ecc → src}/agents/architect.md +0 -0
  344. /package/{ecc → src}/agents/code-reviewer.md +0 -0
  345. /package/{ecc → src}/agents/doc-updater.md +0 -0
  346. /package/{ecc → src}/agents/e2e-runner.md +0 -0
  347. /package/{ecc → src}/agents/security-reviewer.md +0 -0
  348. /package/{ecc → src}/agents/tdd-guide.md +0 -0
  349. /package/{ecc/rules → src/available-rules}/golang/coding-style.md +0 -0
  350. /package/{ecc/rules → src/available-rules}/golang/hooks.md +0 -0
  351. /package/{ecc/rules → src/available-rules}/golang/patterns.md +0 -0
  352. /package/{ecc/rules → src/available-rules}/golang/security.md +0 -0
  353. /package/{ecc/rules → src/available-rules}/golang/testing.md +0 -0
  354. /package/{ecc/rules → src/available-rules}/kotlin/coding-style.md +0 -0
  355. /package/{ecc/rules → src/available-rules}/kotlin/patterns.md +0 -0
  356. /package/{ecc/rules → src/available-rules}/kotlin/security.md +0 -0
  357. /package/{ecc/rules → src/available-rules}/kotlin/testing.md +0 -0
  358. /package/{ecc/rules → src/available-rules}/perl/coding-style.md +0 -0
  359. /package/{ecc/rules → src/available-rules}/perl/hooks.md +0 -0
  360. /package/{ecc/rules → src/available-rules}/perl/patterns.md +0 -0
  361. /package/{ecc/rules → src/available-rules}/perl/security.md +0 -0
  362. /package/{ecc/rules → src/available-rules}/perl/testing.md +0 -0
  363. /package/{ecc/rules → src/available-rules}/php/coding-style.md +0 -0
  364. /package/{ecc/rules → src/available-rules}/php/hooks.md +0 -0
  365. /package/{ecc/rules → src/available-rules}/php/patterns.md +0 -0
  366. /package/{ecc/rules → src/available-rules}/php/security.md +0 -0
  367. /package/{ecc/rules → src/available-rules}/php/testing.md +0 -0
  368. /package/{ecc/rules → src/available-rules}/python/coding-style.md +0 -0
  369. /package/{ecc/rules → src/available-rules}/python/hooks.md +0 -0
  370. /package/{ecc/rules → src/available-rules}/python/patterns.md +0 -0
  371. /package/{ecc/rules → src/available-rules}/python/security.md +0 -0
  372. /package/{ecc/rules → src/available-rules}/python/testing.md +0 -0
  373. /package/{ecc/rules → src/available-rules}/swift/coding-style.md +0 -0
  374. /package/{ecc/rules → src/available-rules}/swift/hooks.md +0 -0
  375. /package/{ecc/rules → src/available-rules}/swift/patterns.md +0 -0
  376. /package/{ecc/rules → src/available-rules}/swift/security.md +0 -0
  377. /package/{ecc/rules → src/available-rules}/swift/testing.md +0 -0
  378. /package/{ecc/rules → src/available-rules}/typescript/coding-style.md +0 -0
  379. /package/{ecc/rules → src/available-rules}/typescript/hooks.md +0 -0
  380. /package/{ecc/rules → src/available-rules}/typescript/patterns.md +0 -0
  381. /package/{ecc/rules → src/available-rules}/typescript/security.md +0 -0
  382. /package/{ecc/rules → src/available-rules}/typescript/testing.md +0 -0
  383. /package/{ecc → src}/commands/checkpoint.md +0 -0
  384. /package/{ecc → src}/commands/learn.md +0 -0
  385. /package/{ecc → src}/commands/model-route.md +0 -0
  386. /package/{ecc → src}/commands/resume-session.md +0 -0
  387. /package/{ecc → src}/commands/save-session.md +0 -0
  388. /package/{kit → src}/commands/setup-refresh.md +0 -0
  389. /package/{kit → src}/commands/tool-guide.md +0 -0
  390. /package/{ecc → src}/commands/verify.md +0 -0
  391. /package/{ecc → src}/contexts/dev.md +0 -0
  392. /package/{ecc → src}/contexts/research.md +0 -0
  393. /package/{ecc → src}/contexts/review.md +0 -0
  394. /package/{ecc → src}/examples/CLAUDE.md +0 -0
  395. /package/{ecc → src}/examples/django-api-CLAUDE.md +0 -0
  396. /package/{ecc → src}/examples/go-microservice-CLAUDE.md +0 -0
  397. /package/{ecc → src}/examples/rust-api-CLAUDE.md +0 -0
  398. /package/{ecc → src}/examples/saas-nextjs-CLAUDE.md +0 -0
  399. /package/{ecc → src}/examples/user-CLAUDE.md +0 -0
  400. /package/{ecc/scripts → src}/hooks/check-hook-enabled.js +0 -0
  401. /package/{ecc/scripts → src}/hooks/evaluate-session.js +0 -0
  402. /package/{ecc/scripts → src}/hooks/pre-compact.js +0 -0
  403. /package/{ecc/scripts → src}/hooks/suggest-compact.js +0 -0
  404. /package/{ecc/scripts → src}/lib/package-manager.d.ts +0 -0
  405. /package/{ecc/scripts → src}/lib/package-manager.js +0 -0
  406. /package/{ecc/scripts → src}/lib/resolve-formatter.js +0 -0
  407. /package/{ecc/scripts → src}/lib/session-aliases.d.ts +0 -0
  408. /package/{ecc/scripts → src}/lib/session-aliases.js +0 -0
  409. /package/{ecc/scripts → src}/lib/shell-split.js +0 -0
  410. /package/{gsd/get-shit-done → src/pilot}/bin/lib/frontmatter.cjs +0 -0
  411. /package/{gsd/get-shit-done → src/pilot}/bin/lib/milestone.cjs +0 -0
  412. /package/{gsd/get-shit-done → src/pilot}/bin/lib/roadmap.cjs +0 -0
  413. /package/{gsd/get-shit-done → src/pilot}/bin/lib/template.cjs +0 -0
  414. /package/{gsd/get-shit-done → src/pilot}/references/checkpoints.md +0 -0
  415. /package/{gsd/get-shit-done → src/pilot}/references/questioning.md +0 -0
  416. /package/{gsd/get-shit-done → src/pilot}/references/tdd.md +0 -0
  417. /package/{gsd/get-shit-done → src/pilot}/templates/codebase/concerns.md +0 -0
  418. /package/{gsd/get-shit-done → src/pilot}/templates/codebase/conventions.md +0 -0
  419. /package/{gsd/get-shit-done → src/pilot}/templates/codebase/integrations.md +0 -0
  420. /package/{gsd/get-shit-done → src/pilot}/templates/codebase/stack.md +0 -0
  421. /package/{gsd/get-shit-done → src/pilot}/templates/codebase/testing.md +0 -0
  422. /package/{gsd/get-shit-done → src/pilot}/templates/config.json +0 -0
  423. /package/{gsd/get-shit-done → src/pilot}/templates/continue-here.md +0 -0
  424. /package/{gsd/get-shit-done → src/pilot}/templates/milestone-archive.md +0 -0
  425. /package/{gsd/get-shit-done → src/pilot}/templates/milestone.md +0 -0
  426. /package/{gsd/get-shit-done → src/pilot}/templates/requirements.md +0 -0
  427. /package/{gsd/get-shit-done → src/pilot}/templates/research-project/ARCHITECTURE.md +0 -0
  428. /package/{gsd/get-shit-done → src/pilot}/templates/research-project/FEATURES.md +0 -0
  429. /package/{gsd/get-shit-done → src/pilot}/templates/research-project/PITFALLS.md +0 -0
  430. /package/{gsd/get-shit-done → src/pilot}/templates/research-project/STACK.md +0 -0
  431. /package/{gsd/get-shit-done → src/pilot}/templates/research-project/SUMMARY.md +0 -0
  432. /package/{gsd/get-shit-done → src/pilot}/templates/retrospective.md +0 -0
  433. /package/{gsd/get-shit-done → src/pilot}/templates/roadmap.md +0 -0
  434. /package/{gsd/get-shit-done → src/pilot}/templates/summary-minimal.md +0 -0
  435. /package/{gsd/get-shit-done → src/pilot}/templates/summary-standard.md +0 -0
  436. /package/{gsd/get-shit-done → src/pilot}/templates/summary.md +0 -0
  437. /package/{gsd/get-shit-done → src/pilot}/templates/user-setup.md +0 -0
  438. /package/{gsd/get-shit-done → src/pilot}/templates/verification-report.md +0 -0
  439. /package/{ecc → src}/rules/common/development-workflow.md +0 -0
  440. /package/{ecc → src}/rules/common/git-workflow.md +0 -0
  441. /package/{ecc → src}/rules/common/hooks.md +0 -0
  442. /package/{ecc → src}/rules/common/patterns.md +0 -0
  443. /package/{ecc → src}/rules/common/performance.md +0 -0
  444. /package/{ecc → src}/rules/common/security.md +0 -0
  445. /package/{ecc → src}/rules/common/testing.md +0 -0
  446. /package/{ecc → src}/skills/continuous-learning-v2/agents/observer.md +0 -0
  447. /package/{ecc → src}/skills/continuous-learning-v2/agents/start-observer.sh +0 -0
  448. /package/{ecc → src}/skills/continuous-learning-v2/config.json +0 -0
  449. /package/{ecc → src}/skills/continuous-learning-v2/hooks/observe.sh +0 -0
  450. /package/{ecc → src}/skills/continuous-learning-v2/scripts/detect-project.sh +0 -0
  451. /package/{ecc → src}/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -0
  452. /package/{ecc → src}/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -0
  453. /package/{ecc → src}/skills/strategic-compact/SKILL.md +0 -0
  454. /package/{ecc → src}/skills/strategic-compact/suggest-compact.sh +0 -0
  455. /package/{ecc/skills/verification-loop-SKILL.md → src/skills/verification-loop/SKILL.md} +0 -0
@@ -0,0 +1,147 @@
1
+ ---
2
+ name: java-coding-standards
3
+ description: "Java coding standards for Spring Boot services: naming, immutability, Optional usage, streams, exceptions, generics, and project layout."
4
+ origin: ECC
5
+ ---
6
+
7
+ # Java Coding Standards
8
+
9
+ Standards for readable, maintainable Java (17+) code in Spring Boot services.
10
+
11
+ ## When to Activate
12
+
13
+ - Writing or reviewing Java code in Spring Boot projects
14
+ - Enforcing naming, immutability, or exception handling conventions
15
+ - Working with records, sealed classes, or pattern matching (Java 17+)
16
+ - Reviewing use of Optional, streams, or generics
17
+ - Structuring packages and project layout
18
+
19
+ ## Core Principles
20
+
21
+ - Prefer clarity over cleverness
22
+ - Immutable by default; minimize shared mutable state
23
+ - Fail fast with meaningful exceptions
24
+ - Consistent naming and package structure
25
+
26
+ ## Naming
27
+
28
+ ```java
29
+ // ✅ Classes/Records: PascalCase
30
+ public class MarketService {}
31
+ public record Money(BigDecimal amount, Currency currency) {}
32
+
33
+ // ✅ Methods/fields: camelCase
34
+ private final MarketRepository marketRepository;
35
+ public Market findBySlug(String slug) {}
36
+
37
+ // ✅ Constants: UPPER_SNAKE_CASE
38
+ private static final int MAX_PAGE_SIZE = 100;
39
+ ```
40
+
41
+ ## Immutability
42
+
43
+ ```java
44
+ // ✅ Favor records and final fields
45
+ public record MarketDto(Long id, String name, MarketStatus status) {}
46
+
47
+ public class Market {
48
+ private final Long id;
49
+ private final String name;
50
+ // getters only, no setters
51
+ }
52
+ ```
53
+
54
+ ## Optional Usage
55
+
56
+ ```java
57
+ // ✅ Return Optional from find* methods
58
+ Optional<Market> market = marketRepository.findBySlug(slug);
59
+
60
+ // ✅ Map/flatMap instead of get()
61
+ return market
62
+ .map(MarketResponse::from)
63
+ .orElseThrow(() -> new EntityNotFoundException("Market not found"));
64
+ ```
65
+
66
+ ## Streams Best Practices
67
+
68
+ ```java
69
+ // ✅ Use streams for transformations, keep pipelines short
70
+ List<String> names = markets.stream()
71
+ .map(Market::name)
72
+ .filter(Objects::nonNull)
73
+ .toList();
74
+
75
+ // ❌ Avoid complex nested streams; prefer loops for clarity
76
+ ```
77
+
78
+ ## Exceptions
79
+
80
+ - Use unchecked exceptions for domain errors; wrap technical exceptions with context
81
+ - Create domain-specific exceptions (e.g., `MarketNotFoundException`)
82
+ - Avoid broad `catch (Exception ex)` unless rethrowing/logging centrally
83
+
84
+ ```java
85
+ throw new MarketNotFoundException(slug);
86
+ ```
87
+
88
+ ## Generics and Type Safety
89
+
90
+ - Avoid raw types; declare generic parameters
91
+ - Prefer bounded generics for reusable utilities
92
+
93
+ ```java
94
+ public <T extends Identifiable> Map<Long, T> indexById(Collection<T> items) { ... }
95
+ ```
96
+
97
+ ## Project Structure (Maven/Gradle)
98
+
99
+ ```
100
+ src/main/java/com/example/app/
101
+ config/
102
+ controller/
103
+ service/
104
+ repository/
105
+ domain/
106
+ dto/
107
+ util/
108
+ src/main/resources/
109
+ application.yml
110
+ src/test/java/... (mirrors main)
111
+ ```
112
+
113
+ ## Formatting and Style
114
+
115
+ - Use 2 or 4 spaces consistently (project standard)
116
+ - One public top-level type per file
117
+ - Keep methods short and focused; extract helpers
118
+ - Order members: constants, fields, constructors, public methods, protected, private
119
+
120
+ ## Code Smells to Avoid
121
+
122
+ - Long parameter lists → use DTO/builders
123
+ - Deep nesting → early returns
124
+ - Magic numbers → named constants
125
+ - Static mutable state → prefer dependency injection
126
+ - Silent catch blocks → log and act or rethrow
127
+
128
+ ## Logging
129
+
130
+ ```java
131
+ private static final Logger log = LoggerFactory.getLogger(MarketService.class);
132
+ log.info("fetch_market slug={}", slug);
133
+ log.error("failed_fetch_market slug={}", slug, ex);
134
+ ```
135
+
136
+ ## Null Handling
137
+
138
+ - Accept `@Nullable` only when unavoidable; otherwise use `@NonNull`
139
+ - Use Bean Validation (`@NotNull`, `@NotBlank`) on inputs
140
+
141
+ ## Testing Expectations
142
+
143
+ - JUnit 5 + AssertJ for fluent assertions
144
+ - Mockito for mocking; avoid partial mocks where possible
145
+ - Favor deterministic tests; no hidden sleeps
146
+
147
+ **Remember**: Keep code intentional, typed, and observable. Optimize for maintainability over micro-optimizations unless proven necessary.
@@ -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,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.