@heyai-rules/pilo-masterkit 1.2.2 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (594) hide show
  1. package/.agent/agents/architect.md +211 -211
  2. package/.agent/agents/build-error-resolver.md +114 -114
  3. package/.agent/agents/chief-of-staff.md +151 -151
  4. package/.agent/agents/code-reviewer.md +237 -237
  5. package/.agent/agents/cpp-build-resolver.md +90 -90
  6. package/.agent/agents/cpp-reviewer.md +72 -72
  7. package/.agent/agents/csharp-reviewer.md +101 -0
  8. package/.agent/agents/dart-build-resolver.md +201 -0
  9. package/.agent/agents/database-reviewer.md +91 -91
  10. package/.agent/agents/doc-updater.md +107 -107
  11. package/.agent/agents/docs-lookup.md +68 -68
  12. package/.agent/agents/e2e-runner.md +107 -107
  13. package/.agent/agents/flutter-reviewer.md +243 -243
  14. package/.agent/agents/gan-evaluator.md +209 -0
  15. package/.agent/agents/gan-generator.md +131 -0
  16. package/.agent/agents/gan-planner.md +99 -0
  17. package/.agent/agents/go-build-resolver.md +94 -94
  18. package/.agent/agents/go-reviewer.md +76 -76
  19. package/.agent/agents/harness-optimizer.md +35 -35
  20. package/.agent/agents/healthcare-reviewer.md +83 -0
  21. package/.agent/agents/java-build-resolver.md +153 -153
  22. package/.agent/agents/java-reviewer.md +92 -92
  23. package/.agent/agents/kotlin-build-resolver.md +118 -118
  24. package/.agent/agents/kotlin-reviewer.md +159 -159
  25. package/.agent/agents/loop-operator.md +36 -36
  26. package/.agent/agents/opensource-forker.md +198 -0
  27. package/.agent/agents/opensource-packager.md +249 -0
  28. package/.agent/agents/opensource-sanitizer.md +188 -0
  29. package/.agent/agents/performance-optimizer.md +392 -133
  30. package/.agent/agents/personas/athena-agent/agent.json +10 -0
  31. package/.agent/agents/personas/athena-agent/athena-backend-logic-architecture-profile.md +189 -0
  32. package/.agent/agents/personas/athena-agent/context-files/agents.md +55 -0
  33. package/.agent/agents/personas/athena-agent/context-files/identity.md +23 -0
  34. package/.agent/agents/personas/athena-agent/context-files/soul.md +51 -0
  35. package/.agent/agents/personas/athena-agent/context-files/user-predefined.md +15 -0
  36. package/.agent/agents/personas/athena-agent/user-context-files/system/bootstrap.md +37 -0
  37. package/.agent/agents/personas/athena-agent/user-context-files/system/user.md +45 -0
  38. package/.agent/agents/personas/da-vinci-agent/agent.json +10 -0
  39. package/.agent/agents/personas/da-vinci-agent/context-files/agents.md +55 -0
  40. package/.agent/agents/personas/da-vinci-agent/context-files/identity.md +23 -0
  41. package/.agent/agents/personas/da-vinci-agent/context-files/soul.md +51 -0
  42. package/.agent/agents/personas/da-vinci-agent/context-files/user-predefined.md +15 -0
  43. package/.agent/agents/personas/da-vinci-agent/da-vinci-frontend-ui-ux-design-profile.md +189 -0
  44. package/.agent/agents/personas/da-vinci-agent/user-context-files/system/bootstrap.md +37 -0
  45. package/.agent/agents/personas/da-vinci-agent/user-context-files/system/user.md +45 -0
  46. package/.agent/agents/personas/duong-tang-agent/agent.json +10 -0
  47. package/.agent/agents/personas/duong-tang-agent/context-files/agents.md +55 -0
  48. package/.agent/agents/personas/duong-tang-agent/context-files/identity.md +23 -0
  49. package/.agent/agents/personas/duong-tang-agent/context-files/soul.md +51 -0
  50. package/.agent/agents/personas/duong-tang-agent/context-files/user-predefined.md +15 -0
  51. package/.agent/agents/personas/duong-tang-agent/tang-monk-quality-testing-documentation-profile.md +189 -0
  52. package/.agent/agents/personas/duong-tang-agent/user-context-files/system/bootstrap.md +37 -0
  53. package/.agent/agents/personas/duong-tang-agent/user-context-files/system/user.md +45 -0
  54. package/.agent/agents/personas/gia-cat-luong-agent/agent.json +10 -0
  55. package/.agent/agents/personas/gia-cat-luong-agent/context-files/agents.md +55 -0
  56. package/.agent/agents/personas/gia-cat-luong-agent/context-files/identity.md +23 -0
  57. package/.agent/agents/personas/gia-cat-luong-agent/context-files/soul.md +51 -0
  58. package/.agent/agents/personas/gia-cat-luong-agent/context-files/user-predefined.md +15 -0
  59. package/.agent/agents/personas/gia-cat-luong-agent/kongming-research-strategy-analysis-profile.md +189 -0
  60. package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/bootstrap.md +37 -0
  61. package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/user.md +45 -0
  62. package/.agent/agents/personas/mihata-agent/agent.json +10 -0
  63. package/.agent/agents/personas/mihata-agent/context-files/agents.md +55 -0
  64. package/.agent/agents/personas/mihata-agent/context-files/identity.md +23 -0
  65. package/.agent/agents/personas/mihata-agent/context-files/soul.md +51 -0
  66. package/.agent/agents/personas/mihata-agent/context-files/user-predefined.md +15 -0
  67. package/.agent/agents/personas/mihata-agent/mihata-multi-agent-orchestration-profile.md +189 -0
  68. package/.agent/agents/personas/mihata-agent/user-context-files/system/bootstrap.md +37 -0
  69. package/.agent/agents/personas/mihata-agent/user-context-files/system/user.md +45 -0
  70. package/.agent/agents/personas/tesla-agent/agent.json +10 -0
  71. package/.agent/agents/personas/tesla-agent/context-files/agents.md +55 -0
  72. package/.agent/agents/personas/tesla-agent/context-files/identity.md +23 -0
  73. package/.agent/agents/personas/tesla-agent/context-files/soul.md +51 -0
  74. package/.agent/agents/personas/tesla-agent/context-files/user-predefined.md +15 -0
  75. package/.agent/agents/personas/tesla-agent/tesla-fullstack-system-optimization-profile.md +189 -0
  76. package/.agent/agents/personas/tesla-agent/user-context-files/system/bootstrap.md +37 -0
  77. package/.agent/agents/personas/tesla-agent/user-context-files/system/user.md +45 -0
  78. package/.agent/agents/personas/tu-ma-y-agent/agent.json +10 -0
  79. package/.agent/agents/personas/tu-ma-y-agent/context-files/agents.md +55 -0
  80. package/.agent/agents/personas/tu-ma-y-agent/context-files/identity.md +23 -0
  81. package/.agent/agents/personas/tu-ma-y-agent/context-files/soul.md +51 -0
  82. package/.agent/agents/personas/tu-ma-y-agent/context-files/user-predefined.md +15 -0
  83. package/.agent/agents/personas/tu-ma-y-agent/simayi-feasibility-risk-control-profile.md +189 -0
  84. package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/bootstrap.md +37 -0
  85. package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/user.md +45 -0
  86. package/.agent/agents/personas/venti-agent/agent.json +10 -0
  87. package/.agent/agents/personas/venti-agent/context-files/agents.md +55 -0
  88. package/.agent/agents/personas/venti-agent/context-files/identity.md +23 -0
  89. package/.agent/agents/personas/venti-agent/context-files/soul.md +51 -0
  90. package/.agent/agents/personas/venti-agent/context-files/user-predefined.md +15 -0
  91. package/.agent/agents/personas/venti-agent/user-context-files/system/bootstrap.md +37 -0
  92. package/.agent/agents/personas/venti-agent/user-context-files/system/user.md +45 -0
  93. package/.agent/agents/personas/venti-agent/venti-learning-communication-mentoring-profile.md +189 -0
  94. package/.agent/agents/planner.md +212 -212
  95. package/.agent/agents/python-reviewer.md +98 -98
  96. package/.agent/agents/pytorch-build-resolver.md +120 -120
  97. package/.agent/agents/refactor-cleaner.md +85 -85
  98. package/.agent/agents/rust-build-resolver.md +148 -148
  99. package/.agent/agents/rust-reviewer.md +94 -94
  100. package/.agent/agents/security-reviewer.md +108 -108
  101. package/.agent/agents/tdd-guide.md +91 -91
  102. package/.agent/agents/typescript-reviewer.md +112 -112
  103. package/.agent/contexts/dev.md +20 -0
  104. package/.agent/contexts/research.md +26 -0
  105. package/.agent/contexts/review.md +22 -0
  106. package/.agent/hooks/hooks.json +395 -0
  107. package/.agent/hooks/readme.md +222 -0
  108. package/.agent/mcp-configs/mcp-servers.json +181 -0
  109. package/.agent/rules/common/agents.md +50 -0
  110. package/.agent/rules/common/code-review.md +124 -0
  111. package/.agent/rules/common/coding-style.md +48 -0
  112. package/.agent/rules/common/development-workflow.md +44 -0
  113. package/.agent/rules/common/git-workflow.md +24 -0
  114. package/.agent/rules/common/hooks.md +30 -0
  115. package/.agent/rules/common/patterns.md +31 -0
  116. package/.agent/rules/common/performance.md +55 -0
  117. package/.agent/rules/common/security.md +29 -0
  118. package/.agent/rules/common/testing.md +29 -0
  119. package/.agent/rules/cpp/coding-style.md +44 -0
  120. package/.agent/rules/cpp/hooks.md +39 -0
  121. package/.agent/rules/cpp/patterns.md +51 -0
  122. package/.agent/rules/cpp/security.md +51 -0
  123. package/.agent/rules/cpp/testing.md +44 -0
  124. package/.agent/rules/csharp/coding-style.md +72 -0
  125. package/.agent/rules/csharp/hooks.md +25 -0
  126. package/.agent/rules/csharp/patterns.md +50 -0
  127. package/.agent/rules/csharp/security.md +58 -0
  128. package/.agent/rules/csharp/testing.md +46 -0
  129. package/.agent/rules/dart/coding-style.md +159 -0
  130. package/.agent/rules/dart/hooks.md +66 -0
  131. package/.agent/rules/dart/patterns.md +261 -0
  132. package/.agent/rules/dart/security.md +135 -0
  133. package/.agent/rules/dart/testing.md +215 -0
  134. package/.agent/rules/golang/coding-style.md +32 -0
  135. package/.agent/rules/golang/hooks.md +17 -0
  136. package/.agent/rules/golang/patterns.md +45 -0
  137. package/.agent/rules/golang/security.md +34 -0
  138. package/.agent/rules/golang/testing.md +31 -0
  139. package/.agent/rules/java/coding-style.md +114 -0
  140. package/.agent/rules/java/hooks.md +18 -0
  141. package/.agent/rules/java/patterns.md +146 -0
  142. package/.agent/rules/java/security.md +100 -0
  143. package/.agent/rules/java/testing.md +131 -0
  144. package/.agent/rules/kotlin/coding-style.md +86 -0
  145. package/.agent/rules/kotlin/hooks.md +17 -0
  146. package/.agent/rules/kotlin/patterns.md +146 -0
  147. package/.agent/rules/kotlin/security.md +82 -0
  148. package/.agent/rules/kotlin/testing.md +128 -0
  149. package/.agent/rules/perl/coding-style.md +46 -0
  150. package/.agent/rules/perl/hooks.md +22 -0
  151. package/.agent/rules/perl/patterns.md +76 -0
  152. package/.agent/rules/perl/security.md +69 -0
  153. package/.agent/rules/perl/testing.md +54 -0
  154. package/.agent/rules/php/coding-style.md +40 -0
  155. package/.agent/rules/php/hooks.md +24 -0
  156. package/.agent/rules/php/patterns.md +33 -0
  157. package/.agent/rules/php/security.md +37 -0
  158. package/.agent/rules/php/testing.md +39 -0
  159. package/.agent/rules/python/coding-style.md +42 -0
  160. package/.agent/rules/python/hooks.md +19 -0
  161. package/.agent/rules/python/patterns.md +39 -0
  162. package/.agent/rules/python/security.md +30 -0
  163. package/.agent/rules/python/testing.md +38 -0
  164. package/.agent/rules/readme.md +111 -0
  165. package/.agent/rules/rust/coding-style.md +151 -0
  166. package/.agent/rules/rust/hooks.md +16 -0
  167. package/.agent/rules/rust/patterns.md +168 -0
  168. package/.agent/rules/rust/security.md +141 -0
  169. package/.agent/rules/rust/testing.md +154 -0
  170. package/.agent/rules/swift/coding-style.md +47 -0
  171. package/.agent/rules/swift/hooks.md +20 -0
  172. package/.agent/rules/swift/patterns.md +66 -0
  173. package/.agent/rules/swift/security.md +33 -0
  174. package/.agent/rules/swift/testing.md +45 -0
  175. package/.agent/rules/typescript/coding-style.md +199 -0
  176. package/.agent/rules/typescript/hooks.md +22 -0
  177. package/.agent/rules/typescript/patterns.md +52 -0
  178. package/.agent/rules/typescript/security.md +28 -0
  179. package/.agent/rules/typescript/testing.md +18 -0
  180. package/.agent/rules/web/coding-style.md +96 -0
  181. package/.agent/rules/web/design-quality.md +63 -0
  182. package/.agent/rules/web/hooks.md +120 -0
  183. package/.agent/rules/web/patterns.md +79 -0
  184. package/.agent/rules/web/performance.md +64 -0
  185. package/.agent/rules/web/security.md +57 -0
  186. package/.agent/rules/web/testing.md +55 -0
  187. package/.agent/rules/zh/agents.md +50 -0
  188. package/.agent/rules/zh/code-review.md +124 -0
  189. package/.agent/rules/zh/coding-style.md +48 -0
  190. package/.agent/rules/zh/development-workflow.md +44 -0
  191. package/.agent/rules/zh/git-workflow.md +24 -0
  192. package/.agent/rules/zh/hooks.md +30 -0
  193. package/.agent/rules/zh/patterns.md +31 -0
  194. package/.agent/rules/zh/performance.md +55 -0
  195. package/.agent/rules/zh/readme.md +108 -0
  196. package/.agent/rules/zh/security.md +29 -0
  197. package/.agent/rules/zh/testing.md +29 -0
  198. package/.agent/skills/agent-eval/SKILL.md +145 -0
  199. package/.agent/skills/agent-harness-construction/SKILL.md +73 -0
  200. package/.agent/skills/agent-payment-x402/SKILL.md +178 -0
  201. package/.agent/skills/agentic-engineering/SKILL.md +63 -0
  202. package/.agent/skills/ai-first-engineering/SKILL.md +51 -0
  203. package/.agent/skills/ai-regression-testing/SKILL.md +385 -0
  204. package/.agent/skills/android-clean-architecture/SKILL.md +339 -0
  205. package/.agent/skills/api-design/SKILL.md +523 -0
  206. package/.agent/skills/architecture-decision-records/SKILL.md +179 -0
  207. package/.agent/skills/article-writing/SKILL.md +79 -0
  208. package/.agent/skills/autonomous-agent-harness/SKILL.md +267 -0
  209. package/.agent/skills/autonomous-loops/SKILL.md +610 -0
  210. package/.agent/skills/backend-patterns/SKILL.md +598 -0
  211. package/.agent/skills/benchmark/SKILL.md +93 -0
  212. package/.agent/skills/blueprint/SKILL.md +105 -0
  213. package/.agent/skills/brand-voice/SKILL.md +97 -0
  214. package/.agent/skills/brand-voice/references/voice-profile-schema.md +55 -0
  215. package/.agent/skills/browser-qa/SKILL.md +87 -0
  216. package/.agent/skills/bun-runtime/SKILL.md +84 -0
  217. package/.agent/skills/canary-watch/SKILL.md +99 -0
  218. package/.agent/skills/carrier-relationship-management/SKILL.md +212 -0
  219. package/.agent/skills/ck/SKILL.md +147 -0
  220. package/.agent/skills/ck/commands/forget.mjs +44 -0
  221. package/.agent/skills/ck/commands/info.mjs +24 -0
  222. package/.agent/skills/ck/commands/init.mjs +143 -0
  223. package/.agent/skills/ck/commands/list.mjs +40 -0
  224. package/.agent/skills/ck/commands/migrate.mjs +202 -0
  225. package/.agent/skills/ck/commands/resume.mjs +36 -0
  226. package/.agent/skills/ck/commands/save.mjs +210 -0
  227. package/.agent/skills/ck/commands/shared.mjs +387 -0
  228. package/.agent/skills/ck/hooks/session-start.mjs +224 -0
  229. package/.agent/skills/claude-api/SKILL.md +337 -0
  230. package/.agent/skills/claude-devfleet/SKILL.md +103 -0
  231. package/.agent/skills/click-path-audit/SKILL.md +244 -0
  232. package/.agent/skills/clickhouse-io/SKILL.md +439 -0
  233. package/.agent/skills/codebase-onboarding/SKILL.md +233 -0
  234. package/.agent/skills/coding-standards/SKILL.md +530 -0
  235. package/.agent/skills/compose-multiplatform-patterns/SKILL.md +299 -0
  236. package/.agent/skills/configure-ecc/SKILL.md +367 -0
  237. package/.agent/skills/connections-optimizer/SKILL.md +189 -0
  238. package/.agent/skills/content-engine/SKILL.md +131 -0
  239. package/.agent/skills/content-hash-cache-pattern/SKILL.md +161 -0
  240. package/.agent/skills/context-budget/SKILL.md +135 -0
  241. package/.agent/skills/continuous-agent-loop/SKILL.md +45 -0
  242. package/.agent/skills/continuous-learning/SKILL.md +119 -0
  243. package/.agent/skills/continuous-learning/config.json +18 -0
  244. package/.agent/skills/continuous-learning/evaluate-session.sh +69 -0
  245. package/.agent/skills/continuous-learning-v2/SKILL.md +365 -0
  246. package/.agent/skills/continuous-learning-v2/agents/observer-loop.sh +271 -0
  247. package/.agent/skills/continuous-learning-v2/agents/observer.md +198 -0
  248. package/.agent/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  249. package/.agent/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
  250. package/.agent/skills/continuous-learning-v2/config.json +8 -0
  251. package/.agent/skills/continuous-learning-v2/hooks/observe.sh +428 -0
  252. package/.agent/skills/continuous-learning-v2/scripts/detect-project.sh +228 -0
  253. package/.agent/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
  254. package/.agent/skills/continuous-learning-v2/scripts/test-parse-instinct.py +984 -0
  255. package/.agent/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  256. package/.agent/skills/cpp-coding-standards/SKILL.md +723 -0
  257. package/.agent/skills/cpp-testing/SKILL.md +324 -0
  258. package/.agent/skills/crosspost/SKILL.md +111 -0
  259. package/.agent/skills/csharp-testing/SKILL.md +321 -0
  260. package/.agent/skills/customer-billing-ops/SKILL.md +140 -0
  261. package/.agent/skills/customs-trade-compliance/SKILL.md +263 -0
  262. package/.agent/skills/dart-flutter-patterns/SKILL.md +563 -0
  263. package/.agent/skills/data-scraper-agent/SKILL.md +764 -0
  264. package/.agent/skills/database-migrations/SKILL.md +429 -0
  265. package/.agent/skills/deep-research/SKILL.md +155 -0
  266. package/.agent/skills/deployment-patterns/SKILL.md +427 -0
  267. package/.agent/skills/design-system/SKILL.md +82 -0
  268. package/.agent/skills/django-patterns/SKILL.md +734 -0
  269. package/.agent/skills/django-security/SKILL.md +593 -0
  270. package/.agent/skills/django-tdd/SKILL.md +729 -0
  271. package/.agent/skills/django-verification/SKILL.md +469 -0
  272. package/.agent/skills/dmux-workflows/SKILL.md +191 -0
  273. package/.agent/skills/docker-patterns/SKILL.md +364 -0
  274. package/.agent/skills/documentation-lookup/SKILL.md +90 -0
  275. package/.agent/skills/dotnet-patterns/SKILL.md +321 -0
  276. package/.agent/skills/e2e-testing/SKILL.md +326 -0
  277. package/.agent/skills/energy-procurement/SKILL.md +228 -0
  278. package/.agent/skills/enterprise-agent-ops/SKILL.md +50 -0
  279. package/.agent/skills/eval-harness/SKILL.md +270 -0
  280. package/.agent/skills/exa-search/SKILL.md +103 -0
  281. package/.agent/skills/fal-ai-media/SKILL.md +284 -0
  282. package/.agent/skills/flutter-dart-code-review/SKILL.md +435 -0
  283. package/.agent/skills/foundation-models-on-device/SKILL.md +243 -0
  284. package/.agent/skills/frontend-patterns/SKILL.md +642 -0
  285. package/.agent/skills/frontend-slides/SKILL.md +184 -0
  286. package/.agent/skills/frontend-slides/style-presets.md +330 -0
  287. package/.agent/skills/gan-style-harness/SKILL.md +278 -0
  288. package/.agent/skills/git-workflow/SKILL.md +715 -0
  289. package/.agent/skills/golang-patterns/SKILL.md +674 -0
  290. package/.agent/skills/golang-testing/SKILL.md +720 -0
  291. package/.agent/skills/google-workspace-ops/SKILL.md +95 -0
  292. package/.agent/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  293. package/.agent/skills/healthcare-emr-patterns/SKILL.md +159 -0
  294. package/.agent/skills/healthcare-eval-harness/SKILL.md +207 -0
  295. package/.agent/skills/healthcare-phi-compliance/SKILL.md +145 -0
  296. package/.agent/skills/hexagonal-architecture/SKILL.md +276 -0
  297. package/.agent/skills/inventory-demand-planning/SKILL.md +247 -0
  298. package/.agent/skills/investor-materials/SKILL.md +96 -0
  299. package/.agent/skills/investor-outreach/SKILL.md +91 -0
  300. package/.agent/skills/iterative-retrieval/SKILL.md +211 -0
  301. package/.agent/skills/java-coding-standards/SKILL.md +147 -0
  302. package/.agent/skills/jira-integration/SKILL.md +293 -0
  303. package/.agent/skills/jpa-patterns/SKILL.md +151 -0
  304. package/.agent/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  305. package/.agent/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  306. package/.agent/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  307. package/.agent/skills/kotlin-patterns/SKILL.md +711 -0
  308. package/.agent/skills/kotlin-testing/SKILL.md +824 -0
  309. package/.agent/skills/laravel-patterns/SKILL.md +415 -0
  310. package/.agent/skills/laravel-plugin-discovery/SKILL.md +229 -0
  311. package/.agent/skills/laravel-security/SKILL.md +285 -0
  312. package/.agent/skills/laravel-tdd/SKILL.md +283 -0
  313. package/.agent/skills/laravel-verification/SKILL.md +179 -0
  314. package/.agent/skills/lead-intelligence/SKILL.md +321 -0
  315. package/.agent/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  316. package/.agent/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  317. package/.agent/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  318. package/.agent/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  319. package/.agent/skills/liquid-glass-design/SKILL.md +279 -0
  320. package/.agent/skills/logistics-exception-management/SKILL.md +222 -0
  321. package/.agent/skills/manim-video/SKILL.md +89 -0
  322. package/.agent/skills/manim-video/assets/network-graph-scene.py +52 -0
  323. package/.agent/skills/market-research/SKILL.md +75 -0
  324. package/.agent/skills/mcp-builder/SKILL.md +173 -113
  325. package/.agent/skills/mcp-builder/license.txt +202 -0
  326. package/.agent/skills/mcp-builder/reference/evaluation.md +602 -0
  327. package/.agent/skills/mcp-builder/reference/mcp-best-practices.md +249 -0
  328. package/.agent/skills/mcp-builder/reference/node-mcp-server.md +970 -0
  329. package/.agent/skills/mcp-builder/reference/python-mcp-server.md +719 -0
  330. package/.agent/skills/mcp-builder/scripts/connections.py +151 -0
  331. package/.agent/skills/mcp-builder/scripts/evaluation.py +373 -0
  332. package/.agent/skills/mcp-builder/scripts/example-evaluation.xml +22 -0
  333. package/.agent/skills/mcp-builder/scripts/requirements.txt +2 -0
  334. package/.agent/skills/mcp-server-patterns/SKILL.md +67 -0
  335. package/.agent/skills/nanoclaw-repl/SKILL.md +33 -0
  336. package/.agent/skills/nestjs-patterns/SKILL.md +230 -0
  337. package/.agent/skills/nextjs-turbopack/SKILL.md +44 -0
  338. package/.agent/skills/nutrient-document-processing/SKILL.md +167 -0
  339. package/.agent/skills/nuxt4-patterns/SKILL.md +100 -0
  340. package/.agent/skills/openclaw-persona-forge/SKILL.md +296 -0
  341. package/.agent/skills/openclaw-persona-forge/gacha.py +224 -0
  342. package/.agent/skills/openclaw-persona-forge/gacha.sh +5 -0
  343. package/.agent/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  344. package/.agent/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  345. package/.agent/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  346. package/.agent/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  347. package/.agent/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  348. package/.agent/skills/openclaw-persona-forge/references/output-template.md +166 -0
  349. package/.agent/skills/opensource-pipeline/SKILL.md +255 -0
  350. package/.agent/skills/perl-patterns/SKILL.md +504 -0
  351. package/.agent/skills/perl-security/SKILL.md +503 -0
  352. package/.agent/skills/perl-testing/SKILL.md +475 -0
  353. package/.agent/skills/plankton-code-quality/SKILL.md +236 -0
  354. package/.agent/skills/postgres-patterns/SKILL.md +147 -0
  355. package/.agent/skills/product-lens/SKILL.md +85 -0
  356. package/.agent/skills/production-scheduling/SKILL.md +238 -0
  357. package/.agent/skills/project-flow-ops/SKILL.md +111 -0
  358. package/.agent/skills/project-guidelines-example/SKILL.md +349 -0
  359. package/.agent/skills/prompt-optimizer/SKILL.md +397 -0
  360. package/.agent/skills/python-patterns/SKILL.md +622 -313
  361. package/.agent/skills/python-testing/SKILL.md +816 -0
  362. package/.agent/skills/pytorch-patterns/SKILL.md +396 -0
  363. package/.agent/skills/quality-nonconformance/SKILL.md +260 -0
  364. package/.agent/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
  365. package/.agent/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  366. package/.agent/skills/remotion-video-creation/SKILL.md +43 -0
  367. package/.agent/skills/remotion-video-creation/rules/3d.md +86 -0
  368. package/.agent/skills/remotion-video-creation/rules/animations.md +29 -0
  369. package/.agent/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  370. package/.agent/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  371. package/.agent/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  372. package/.agent/skills/remotion-video-creation/rules/assets.md +78 -0
  373. package/.agent/skills/remotion-video-creation/rules/audio.md +172 -0
  374. package/.agent/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  375. package/.agent/skills/remotion-video-creation/rules/can-decode.md +75 -0
  376. package/.agent/skills/remotion-video-creation/rules/charts.md +58 -0
  377. package/.agent/skills/remotion-video-creation/rules/compositions.md +146 -0
  378. package/.agent/skills/remotion-video-creation/rules/display-captions.md +126 -0
  379. package/.agent/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  380. package/.agent/skills/remotion-video-creation/rules/fonts.md +152 -0
  381. package/.agent/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  382. package/.agent/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  383. package/.agent/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  384. package/.agent/skills/remotion-video-creation/rules/gifs.md +138 -0
  385. package/.agent/skills/remotion-video-creation/rules/images.md +130 -0
  386. package/.agent/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  387. package/.agent/skills/remotion-video-creation/rules/lottie.md +67 -0
  388. package/.agent/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  389. package/.agent/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  390. package/.agent/skills/remotion-video-creation/rules/sequencing.md +106 -0
  391. package/.agent/skills/remotion-video-creation/rules/tailwind.md +11 -0
  392. package/.agent/skills/remotion-video-creation/rules/text-animations.md +20 -0
  393. package/.agent/skills/remotion-video-creation/rules/timing.md +179 -0
  394. package/.agent/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  395. package/.agent/skills/remotion-video-creation/rules/transitions.md +122 -0
  396. package/.agent/skills/remotion-video-creation/rules/trimming.md +52 -0
  397. package/.agent/skills/remotion-video-creation/rules/videos.md +171 -0
  398. package/.agent/skills/repo-scan/SKILL.md +78 -0
  399. package/.agent/skills/returns-reverse-logistics/SKILL.md +240 -0
  400. package/.agent/skills/rules-distill/SKILL.md +264 -0
  401. package/.agent/skills/rules-distill/scripts/scan-rules.sh +58 -0
  402. package/.agent/skills/rules-distill/scripts/scan-skills.sh +129 -0
  403. package/.agent/skills/rust-patterns/SKILL.md +499 -0
  404. package/.agent/skills/rust-testing/SKILL.md +500 -0
  405. package/.agent/skills/safety-guard/SKILL.md +75 -0
  406. package/.agent/skills/santa-method/SKILL.md +306 -0
  407. package/.agent/skills/search-first/SKILL.md +161 -0
  408. package/.agent/skills/security-review/SKILL.md +495 -0
  409. package/.agent/skills/security-review/cloud-infrastructure-security.md +361 -0
  410. package/.agent/skills/security-scan/SKILL.md +165 -0
  411. package/.agent/skills/skill-comply/SKILL.md +58 -0
  412. package/.agent/skills/skill-comply/fixtures/compliant-trace.jsonl +5 -0
  413. package/.agent/skills/skill-comply/fixtures/noncompliant-trace.jsonl +3 -0
  414. package/.agent/skills/skill-comply/fixtures/tdd-spec.yaml +44 -0
  415. package/.agent/skills/skill-comply/prompts/classifier.md +24 -0
  416. package/.agent/skills/skill-comply/prompts/scenario-generator.md +62 -0
  417. package/.agent/skills/skill-comply/prompts/spec-generator.md +42 -0
  418. package/.agent/skills/skill-comply/pyproject.toml +15 -0
  419. package/.agent/skills/skill-comply/scripts/classifier.py +85 -0
  420. package/.agent/skills/skill-comply/scripts/grader.py +122 -0
  421. package/.agent/skills/skill-comply/scripts/init.py +0 -0
  422. package/.agent/skills/skill-comply/scripts/parser.py +107 -0
  423. package/.agent/skills/skill-comply/scripts/report.py +170 -0
  424. package/.agent/skills/skill-comply/scripts/run.py +127 -0
  425. package/.agent/skills/skill-comply/scripts/runner.py +161 -0
  426. package/.agent/skills/skill-comply/scripts/scenario-generator.py +70 -0
  427. package/.agent/skills/skill-comply/scripts/spec-generator.py +72 -0
  428. package/.agent/skills/skill-comply/scripts/utils.py +13 -0
  429. package/.agent/skills/skill-comply/tests/test-grader.py +137 -0
  430. package/.agent/skills/skill-comply/tests/test-parser.py +90 -0
  431. package/.agent/skills/skill-creator/SKILL.md +485 -0
  432. package/.agent/skills/skill-creator/agents/analyzer.md +274 -0
  433. package/.agent/skills/skill-creator/agents/comparator.md +202 -0
  434. package/.agent/skills/skill-creator/agents/grader.md +223 -0
  435. package/.agent/skills/skill-creator/assets/eval-review.html +146 -0
  436. package/.agent/skills/skill-creator/eval-viewer/generate-review.py +471 -0
  437. package/.agent/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  438. package/.agent/skills/skill-creator/license.txt +202 -0
  439. package/.agent/skills/skill-creator/references/schemas.md +430 -0
  440. package/.agent/skills/skill-creator/scripts/aggregate-benchmark.py +401 -0
  441. package/.agent/skills/skill-creator/scripts/generate-report.py +326 -0
  442. package/.agent/skills/skill-creator/scripts/improve-description.py +247 -0
  443. package/.agent/skills/skill-creator/scripts/init.py +0 -0
  444. package/.agent/skills/skill-creator/scripts/package-skill.py +136 -0
  445. package/.agent/skills/skill-creator/scripts/quick-validate.py +103 -0
  446. package/.agent/skills/skill-creator/scripts/run-eval.py +310 -0
  447. package/.agent/skills/skill-creator/scripts/run-loop.py +328 -0
  448. package/.agent/skills/skill-creator/scripts/utils.py +47 -0
  449. package/.agent/skills/skill-stocktake/SKILL.md +193 -0
  450. package/.agent/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  451. package/.agent/skills/skill-stocktake/scripts/save-results.sh +56 -0
  452. package/.agent/skills/skill-stocktake/scripts/scan.sh +170 -0
  453. package/.agent/skills/social-graph-ranker/SKILL.md +154 -0
  454. package/.agent/skills/springboot-patterns/SKILL.md +314 -0
  455. package/.agent/skills/springboot-security/SKILL.md +272 -0
  456. package/.agent/skills/springboot-tdd/SKILL.md +158 -0
  457. package/.agent/skills/springboot-verification/SKILL.md +231 -0
  458. package/.agent/skills/strategic-compact/SKILL.md +131 -0
  459. package/.agent/skills/strategic-compact/suggest-compact.sh +54 -0
  460. package/.agent/skills/swift-actor-persistence/SKILL.md +143 -0
  461. package/.agent/skills/swift-concurrency-6-2/SKILL.md +216 -0
  462. package/.agent/skills/swift-protocol-di-testing/SKILL.md +190 -0
  463. package/.agent/skills/swiftui-patterns/SKILL.md +259 -0
  464. package/.agent/skills/tdd-workflow/SKILL.md +412 -98
  465. package/.agent/skills/team-builder/SKILL.md +168 -0
  466. package/.agent/skills/token-budget-advisor/SKILL.md +133 -0
  467. package/.agent/skills/ui-demo/SKILL.md +465 -0
  468. package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -26
  469. package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -97
  470. package/.agent/skills/ui-ux-pro-max/data/landing.csv +28 -28
  471. package/.agent/skills/ui-ux-pro-max/data/products.csv +96 -96
  472. package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
  473. package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
  474. package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
  475. package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
  476. package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
  477. package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
  478. package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
  479. package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
  480. package/.agent/skills/ui-ux-pro-max/data/styles.csv +68 -68
  481. package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
  482. package/.agent/skills/ui-ux-pro-max/scripts/search.py +114 -114
  483. package/.agent/skills/verification-loop/SKILL.md +126 -0
  484. package/.agent/skills/video-editing/SKILL.md +310 -0
  485. package/.agent/skills/videodb/SKILL.md +374 -0
  486. package/.agent/skills/videodb/reference/api-reference.md +550 -0
  487. package/.agent/skills/videodb/reference/capture-reference.md +407 -0
  488. package/.agent/skills/videodb/reference/capture.md +101 -0
  489. package/.agent/skills/videodb/reference/editor.md +443 -0
  490. package/.agent/skills/videodb/reference/generative.md +331 -0
  491. package/.agent/skills/videodb/reference/rtstream-reference.md +564 -0
  492. package/.agent/skills/videodb/reference/rtstream.md +65 -0
  493. package/.agent/skills/videodb/reference/search.md +230 -0
  494. package/.agent/skills/videodb/reference/streaming.md +406 -0
  495. package/.agent/skills/videodb/reference/use-cases.md +118 -0
  496. package/.agent/skills/videodb/scripts/ws-listener.py +282 -0
  497. package/.agent/skills/visa-doc-translate/SKILL.md +117 -0
  498. package/.agent/skills/visa-doc-translate/readme.md +86 -0
  499. package/.agent/skills/workspace-surface-audit/SKILL.md +125 -0
  500. package/.agent/skills/x-api/SKILL.md +230 -0
  501. package/.agent/tasks/two-track-merge-contract.md +29 -0
  502. package/.agent/workflows/aside.md +164 -164
  503. package/.agent/workflows/build-fix.md +62 -62
  504. package/.agent/workflows/checkpoint.md +74 -74
  505. package/.agent/workflows/claw.md +23 -51
  506. package/.agent/workflows/clean-memory.md +34 -0
  507. package/.agent/workflows/code-review.md +289 -40
  508. package/.agent/workflows/context-budget.md +23 -29
  509. package/.agent/workflows/cpp-build.md +173 -173
  510. package/.agent/workflows/cpp-review.md +132 -132
  511. package/.agent/workflows/cpp-test.md +251 -251
  512. package/.agent/workflows/devfleet.md +23 -92
  513. package/.agent/workflows/docs.md +23 -31
  514. package/.agent/workflows/e2e.md +268 -365
  515. package/.agent/workflows/eval.md +23 -120
  516. package/.agent/workflows/evolve.md +178 -178
  517. package/.agent/workflows/flutter-build.md +164 -0
  518. package/.agent/workflows/flutter-review.md +116 -0
  519. package/.agent/workflows/flutter-test.md +144 -0
  520. package/.agent/workflows/gan-build.md +99 -0
  521. package/.agent/workflows/gan-design.md +35 -0
  522. package/.agent/workflows/go-build.md +183 -183
  523. package/.agent/workflows/go-review.md +148 -148
  524. package/.agent/workflows/go-test.md +268 -268
  525. package/.agent/workflows/gradle-build.md +70 -70
  526. package/.agent/workflows/harness-audit.md +73 -71
  527. package/.agent/workflows/instinct-export.md +66 -66
  528. package/.agent/workflows/instinct-import.md +114 -114
  529. package/.agent/workflows/instinct-status.md +59 -59
  530. package/.agent/workflows/jira.md +106 -0
  531. package/.agent/workflows/kotlin-build.md +174 -174
  532. package/.agent/workflows/kotlin-review.md +140 -140
  533. package/.agent/workflows/kotlin-test.md +312 -312
  534. package/.agent/workflows/learn-eval.md +116 -116
  535. package/.agent/workflows/learn.md +70 -70
  536. package/.agent/workflows/loop-start.md +32 -32
  537. package/.agent/workflows/loop-status.md +24 -24
  538. package/.agent/workflows/model-route.md +26 -26
  539. package/.agent/workflows/multi-backend.md +158 -158
  540. package/.agent/workflows/multi-execute.md +315 -315
  541. package/.agent/workflows/multi-frontend.md +158 -158
  542. package/.agent/workflows/multi-plan.md +268 -268
  543. package/.agent/workflows/multi-workflow.md +191 -191
  544. package/.agent/workflows/orchestrate.md +135 -231
  545. package/.agent/workflows/plan.md +117 -115
  546. package/.agent/workflows/pm2.md +272 -272
  547. package/.agent/workflows/projects.md +39 -39
  548. package/.agent/workflows/promote.md +41 -41
  549. package/.agent/workflows/prompt-optimize.md +23 -38
  550. package/.agent/workflows/prp-commit.md +112 -0
  551. package/.agent/workflows/prp-implement.md +385 -0
  552. package/.agent/workflows/prp-plan.md +502 -0
  553. package/.agent/workflows/prp-pr.md +184 -0
  554. package/.agent/workflows/prp-prd.md +447 -0
  555. package/.agent/workflows/prune.md +31 -31
  556. package/.agent/workflows/python-review.md +297 -297
  557. package/.agent/workflows/quality-gate.md +29 -29
  558. package/.agent/workflows/refactor-clean.md +80 -80
  559. package/.agent/workflows/resume-session.md +156 -156
  560. package/.agent/workflows/rules-distill.md +20 -11
  561. package/.agent/workflows/rust-build.md +187 -187
  562. package/.agent/workflows/rust-review.md +142 -142
  563. package/.agent/workflows/rust-test.md +308 -308
  564. package/.agent/workflows/santa-loop.md +175 -0
  565. package/.agent/workflows/save-session.md +275 -275
  566. package/.agent/workflows/sessions.md +333 -333
  567. package/.agent/workflows/setup-pm.md +80 -80
  568. package/.agent/workflows/skill-create.md +174 -174
  569. package/.agent/workflows/skill-health.md +54 -54
  570. package/.agent/workflows/tdd.md +231 -328
  571. package/.agent/workflows/test-coverage.md +69 -69
  572. package/.agent/workflows/update-codemaps.md +72 -72
  573. package/.agent/workflows/update-docs.md +84 -84
  574. package/.agent/workflows/verify.md +23 -59
  575. package/LICENSE +176 -176
  576. package/README.md +28 -20
  577. package/RELEASE.md +32 -36
  578. package/package.json +87 -79
  579. package/scripts/release-check.js +55 -55
  580. package/src/bin/cli.js +399 -53
  581. package/src/lib/installer.js +360 -114
  582. package/src/lib/manifests/stacks.js +122 -0
  583. package/src/lib/slash-commands.js +28 -0
  584. package/src/templates/claude/CLAUDE.en.md +42 -0
  585. package/src/templates/claude/CLAUDE.md +42 -0
  586. package/src/templates/claude/CLAUDE.vi.md +42 -0
  587. package/src/templates/codex/AGENTS.en.md +40 -0
  588. package/src/templates/codex/AGENTS.md +40 -0
  589. package/src/templates/codex/AGENTS.vi.md +40 -0
  590. package/src/templates/cursor/pilo-masterkit.mdc +20 -0
  591. package/src/templates/gemini/GEMINI.en.md +56 -0
  592. package/src/templates/gemini/GEMINI.md +56 -0
  593. package/src/templates/gemini/GEMINI.vi.md +56 -0
  594. package/src/templates/github/copilot-instructions.md +16 -0
@@ -0,0 +1,711 @@
1
+ ---
2
+ name: kotlin-patterns
3
+ description: Idiomatic Kotlin patterns, best practices, and conventions for building robust, efficient, and maintainable Kotlin applications with coroutines, null safety, and DSL builders.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Kotlin Development Patterns
8
+
9
+ Idiomatic Kotlin patterns and best practices for building robust, efficient, and maintainable applications.
10
+
11
+ ## When to Use
12
+
13
+ - Writing new Kotlin code
14
+ - Reviewing Kotlin code
15
+ - Refactoring existing Kotlin code
16
+ - Designing Kotlin modules or libraries
17
+ - Configuring Gradle Kotlin DSL builds
18
+
19
+ ## How It Works
20
+
21
+ This skill enforces idiomatic Kotlin conventions across seven key areas: null safety using the type system and safe-call operators, immutability via `val` and `copy()` on data classes, sealed classes and interfaces for exhaustive type hierarchies, structured concurrency with coroutines and `Flow`, extension functions for adding behaviour without inheritance, type-safe DSL builders using `@DslMarker` and lambda receivers, and Gradle Kotlin DSL for build configuration.
22
+
23
+ ## Examples
24
+
25
+ **Null safety with Elvis operator:**
26
+ ```kotlin
27
+ fun getUserEmail(userId: String): String {
28
+ val user = userRepository.findById(userId)
29
+ return user?.email ?: "unknown@example.com"
30
+ }
31
+ ```
32
+
33
+ **Sealed class for exhaustive results:**
34
+ ```kotlin
35
+ sealed class Result<out T> {
36
+ data class Success<T>(val data: T) : Result<T>()
37
+ data class Failure(val error: AppError) : Result<Nothing>()
38
+ data object Loading : Result<Nothing>()
39
+ }
40
+ ```
41
+
42
+ **Structured concurrency with async/await:**
43
+ ```kotlin
44
+ suspend fun fetchUserWithPosts(userId: String): UserProfile =
45
+ coroutineScope {
46
+ val user = async { userService.getUser(userId) }
47
+ val posts = async { postService.getUserPosts(userId) }
48
+ UserProfile(user = user.await(), posts = posts.await())
49
+ }
50
+ ```
51
+
52
+ ## Core Principles
53
+
54
+ ### 1. Null Safety
55
+
56
+ Kotlin's type system distinguishes nullable and non-nullable types. Leverage it fully.
57
+
58
+ ```kotlin
59
+ // Good: Use non-nullable types by default
60
+ fun getUser(id: String): User {
61
+ return userRepository.findById(id)
62
+ ?: throw UserNotFoundException("User $id not found")
63
+ }
64
+
65
+ // Good: Safe calls and Elvis operator
66
+ fun getUserEmail(userId: String): String {
67
+ val user = userRepository.findById(userId)
68
+ return user?.email ?: "unknown@example.com"
69
+ }
70
+
71
+ // Bad: Force-unwrapping nullable types
72
+ fun getUserEmail(userId: String): String {
73
+ val user = userRepository.findById(userId)
74
+ return user!!.email // Throws NPE if null
75
+ }
76
+ ```
77
+
78
+ ### 2. Immutability by Default
79
+
80
+ Prefer `val` over `var`, immutable collections over mutable ones.
81
+
82
+ ```kotlin
83
+ // Good: Immutable data
84
+ data class User(
85
+ val id: String,
86
+ val name: String,
87
+ val email: String,
88
+ )
89
+
90
+ // Good: Transform with copy()
91
+ fun updateEmail(user: User, newEmail: String): User =
92
+ user.copy(email = newEmail)
93
+
94
+ // Good: Immutable collections
95
+ val users: List<User> = listOf(user1, user2)
96
+ val filtered = users.filter { it.email.isNotBlank() }
97
+
98
+ // Bad: Mutable state
99
+ var currentUser: User? = null // Avoid mutable global state
100
+ val mutableUsers = mutableListOf<User>() // Avoid unless truly needed
101
+ ```
102
+
103
+ ### 3. Expression Bodies and Single-Expression Functions
104
+
105
+ Use expression bodies for concise, readable functions.
106
+
107
+ ```kotlin
108
+ // Good: Expression body
109
+ fun isAdult(age: Int): Boolean = age >= 18
110
+
111
+ fun formatFullName(first: String, last: String): String =
112
+ "$first $last".trim()
113
+
114
+ fun User.displayName(): String =
115
+ name.ifBlank { email.substringBefore('@') }
116
+
117
+ // Good: When as expression
118
+ fun statusMessage(code: Int): String = when (code) {
119
+ 200 -> "OK"
120
+ 404 -> "Not Found"
121
+ 500 -> "Internal Server Error"
122
+ else -> "Unknown status: $code"
123
+ }
124
+
125
+ // Bad: Unnecessary block body
126
+ fun isAdult(age: Int): Boolean {
127
+ return age >= 18
128
+ }
129
+ ```
130
+
131
+ ### 4. Data Classes for Value Objects
132
+
133
+ Use data classes for types that primarily hold data.
134
+
135
+ ```kotlin
136
+ // Good: Data class with copy, equals, hashCode, toString
137
+ data class CreateUserRequest(
138
+ val name: String,
139
+ val email: String,
140
+ val role: Role = Role.USER,
141
+ )
142
+
143
+ // Good: Value class for type safety (zero overhead at runtime)
144
+ @JvmInline
145
+ value class UserId(val value: String) {
146
+ init {
147
+ require(value.isNotBlank()) { "UserId cannot be blank" }
148
+ }
149
+ }
150
+
151
+ @JvmInline
152
+ value class Email(val value: String) {
153
+ init {
154
+ require('@' in value) { "Invalid email: $value" }
155
+ }
156
+ }
157
+
158
+ fun getUser(id: UserId): User = userRepository.findById(id)
159
+ ```
160
+
161
+ ## Sealed Classes and Interfaces
162
+
163
+ ### Modeling Restricted Hierarchies
164
+
165
+ ```kotlin
166
+ // Good: Sealed class for exhaustive when
167
+ sealed class Result<out T> {
168
+ data class Success<T>(val data: T) : Result<T>()
169
+ data class Failure(val error: AppError) : Result<Nothing>()
170
+ data object Loading : Result<Nothing>()
171
+ }
172
+
173
+ fun <T> Result<T>.getOrNull(): T? = when (this) {
174
+ is Result.Success -> data
175
+ is Result.Failure -> null
176
+ is Result.Loading -> null
177
+ }
178
+
179
+ fun <T> Result<T>.getOrThrow(): T = when (this) {
180
+ is Result.Success -> data
181
+ is Result.Failure -> throw error.toException()
182
+ is Result.Loading -> throw IllegalStateException("Still loading")
183
+ }
184
+ ```
185
+
186
+ ### Sealed Interfaces for API Responses
187
+
188
+ ```kotlin
189
+ sealed interface ApiError {
190
+ val message: String
191
+
192
+ data class NotFound(override val message: String) : ApiError
193
+ data class Unauthorized(override val message: String) : ApiError
194
+ data class Validation(
195
+ override val message: String,
196
+ val field: String,
197
+ ) : ApiError
198
+ data class Internal(
199
+ override val message: String,
200
+ val cause: Throwable? = null,
201
+ ) : ApiError
202
+ }
203
+
204
+ fun ApiError.toStatusCode(): Int = when (this) {
205
+ is ApiError.NotFound -> 404
206
+ is ApiError.Unauthorized -> 401
207
+ is ApiError.Validation -> 422
208
+ is ApiError.Internal -> 500
209
+ }
210
+ ```
211
+
212
+ ## Scope Functions
213
+
214
+ ### When to Use Each
215
+
216
+ ```kotlin
217
+ // let: Transform nullable or scoped result
218
+ val length: Int? = name?.let { it.trim().length }
219
+
220
+ // apply: Configure an object (returns the object)
221
+ val user = User().apply {
222
+ name = "Alice"
223
+ email = "alice@example.com"
224
+ }
225
+
226
+ // also: Side effects (returns the object)
227
+ val user = createUser(request).also { logger.info("Created user: ${it.id}") }
228
+
229
+ // run: Execute a block with receiver (returns result)
230
+ val result = connection.run {
231
+ prepareStatement(sql)
232
+ executeQuery()
233
+ }
234
+
235
+ // with: Non-extension form of run
236
+ val csv = with(StringBuilder()) {
237
+ appendLine("name,email")
238
+ users.forEach { appendLine("${it.name},${it.email}") }
239
+ toString()
240
+ }
241
+ ```
242
+
243
+ ### Anti-Patterns
244
+
245
+ ```kotlin
246
+ // Bad: Nesting scope functions
247
+ user?.let { u ->
248
+ u.address?.let { addr ->
249
+ addr.city?.let { city ->
250
+ println(city) // Hard to read
251
+ }
252
+ }
253
+ }
254
+
255
+ // Good: Chain safe calls instead
256
+ val city = user?.address?.city
257
+ city?.let { println(it) }
258
+ ```
259
+
260
+ ## Extension Functions
261
+
262
+ ### Adding Functionality Without Inheritance
263
+
264
+ ```kotlin
265
+ // Good: Domain-specific extensions
266
+ fun String.toSlug(): String =
267
+ lowercase()
268
+ .replace(Regex("[^a-z0-9\\s-]"), "")
269
+ .replace(Regex("\\s+"), "-")
270
+ .trim('-')
271
+
272
+ fun Instant.toLocalDate(zone: ZoneId = ZoneId.systemDefault()): LocalDate =
273
+ atZone(zone).toLocalDate()
274
+
275
+ // Good: Collection extensions
276
+ fun <T> List<T>.second(): T = this[1]
277
+
278
+ fun <T> List<T>.secondOrNull(): T? = getOrNull(1)
279
+
280
+ // Good: Scoped extensions (not polluting global namespace)
281
+ class UserService {
282
+ private fun User.isActive(): Boolean =
283
+ status == Status.ACTIVE && lastLogin.isAfter(Instant.now().minus(30, ChronoUnit.DAYS))
284
+
285
+ fun getActiveUsers(): List<User> = userRepository.findAll().filter { it.isActive() }
286
+ }
287
+ ```
288
+
289
+ ## Coroutines
290
+
291
+ ### Structured Concurrency
292
+
293
+ ```kotlin
294
+ // Good: Structured concurrency with coroutineScope
295
+ suspend fun fetchUserWithPosts(userId: String): UserProfile =
296
+ coroutineScope {
297
+ val userDeferred = async { userService.getUser(userId) }
298
+ val postsDeferred = async { postService.getUserPosts(userId) }
299
+
300
+ UserProfile(
301
+ user = userDeferred.await(),
302
+ posts = postsDeferred.await(),
303
+ )
304
+ }
305
+
306
+ // Good: supervisorScope when children can fail independently
307
+ suspend fun fetchDashboard(userId: String): Dashboard =
308
+ supervisorScope {
309
+ val user = async { userService.getUser(userId) }
310
+ val notifications = async { notificationService.getRecent(userId) }
311
+ val recommendations = async { recommendationService.getFor(userId) }
312
+
313
+ Dashboard(
314
+ user = user.await(),
315
+ notifications = try {
316
+ notifications.await()
317
+ } catch (e: CancellationException) {
318
+ throw e
319
+ } catch (e: Exception) {
320
+ emptyList()
321
+ },
322
+ recommendations = try {
323
+ recommendations.await()
324
+ } catch (e: CancellationException) {
325
+ throw e
326
+ } catch (e: Exception) {
327
+ emptyList()
328
+ },
329
+ )
330
+ }
331
+ ```
332
+
333
+ ### Flow for Reactive Streams
334
+
335
+ ```kotlin
336
+ // Good: Cold flow with proper error handling
337
+ fun observeUsers(): Flow<List<User>> = flow {
338
+ while (currentCoroutineContext().isActive) {
339
+ val users = userRepository.findAll()
340
+ emit(users)
341
+ delay(5.seconds)
342
+ }
343
+ }.catch { e ->
344
+ logger.error("Error observing users", e)
345
+ emit(emptyList())
346
+ }
347
+
348
+ // Good: Flow operators
349
+ fun searchUsers(query: Flow<String>): Flow<List<User>> =
350
+ query
351
+ .debounce(300.milliseconds)
352
+ .distinctUntilChanged()
353
+ .filter { it.length >= 2 }
354
+ .mapLatest { q -> userRepository.search(q) }
355
+ .catch { emit(emptyList()) }
356
+ ```
357
+
358
+ ### Cancellation and Cleanup
359
+
360
+ ```kotlin
361
+ // Good: Respect cancellation
362
+ suspend fun processItems(items: List<Item>) {
363
+ items.forEach { item ->
364
+ ensureActive() // Check cancellation before expensive work
365
+ processItem(item)
366
+ }
367
+ }
368
+
369
+ // Good: Cleanup with try/finally
370
+ suspend fun acquireAndProcess() {
371
+ val resource = acquireResource()
372
+ try {
373
+ resource.process()
374
+ } finally {
375
+ withContext(NonCancellable) {
376
+ resource.release() // Always release, even on cancellation
377
+ }
378
+ }
379
+ }
380
+ ```
381
+
382
+ ## Delegation
383
+
384
+ ### Property Delegation
385
+
386
+ ```kotlin
387
+ // Lazy initialization
388
+ val expensiveData: List<User> by lazy {
389
+ userRepository.findAll()
390
+ }
391
+
392
+ // Observable property
393
+ var name: String by Delegates.observable("initial") { _, old, new ->
394
+ logger.info("Name changed from '$old' to '$new'")
395
+ }
396
+
397
+ // Map-backed properties
398
+ class Config(private val map: Map<String, Any?>) {
399
+ val host: String by map
400
+ val port: Int by map
401
+ val debug: Boolean by map
402
+ }
403
+
404
+ val config = Config(mapOf("host" to "localhost", "port" to 8080, "debug" to true))
405
+ ```
406
+
407
+ ### Interface Delegation
408
+
409
+ ```kotlin
410
+ // Good: Delegate interface implementation
411
+ class LoggingUserRepository(
412
+ private val delegate: UserRepository,
413
+ private val logger: Logger,
414
+ ) : UserRepository by delegate {
415
+ // Only override what you need to add logging to
416
+ override suspend fun findById(id: String): User? {
417
+ logger.info("Finding user by id: $id")
418
+ return delegate.findById(id).also {
419
+ logger.info("Found user: ${it?.name ?: "null"}")
420
+ }
421
+ }
422
+ }
423
+ ```
424
+
425
+ ## DSL Builders
426
+
427
+ ### Type-Safe Builders
428
+
429
+ ```kotlin
430
+ // Good: DSL with @DslMarker
431
+ @DslMarker
432
+ annotation class HtmlDsl
433
+
434
+ @HtmlDsl
435
+ class HTML {
436
+ private val children = mutableListOf<Element>()
437
+
438
+ fun head(init: Head.() -> Unit) {
439
+ children += Head().apply(init)
440
+ }
441
+
442
+ fun body(init: Body.() -> Unit) {
443
+ children += Body().apply(init)
444
+ }
445
+
446
+ override fun toString(): String = children.joinToString("\n")
447
+ }
448
+
449
+ fun html(init: HTML.() -> Unit): HTML = HTML().apply(init)
450
+
451
+ // Usage
452
+ val page = html {
453
+ head { title("My Page") }
454
+ body {
455
+ h1("Welcome")
456
+ p("Hello, World!")
457
+ }
458
+ }
459
+ ```
460
+
461
+ ### Configuration DSL
462
+
463
+ ```kotlin
464
+ data class ServerConfig(
465
+ val host: String = "0.0.0.0",
466
+ val port: Int = 8080,
467
+ val ssl: SslConfig? = null,
468
+ val database: DatabaseConfig? = null,
469
+ )
470
+
471
+ data class SslConfig(val certPath: String, val keyPath: String)
472
+ data class DatabaseConfig(val url: String, val maxPoolSize: Int = 10)
473
+
474
+ class ServerConfigBuilder {
475
+ var host: String = "0.0.0.0"
476
+ var port: Int = 8080
477
+ private var ssl: SslConfig? = null
478
+ private var database: DatabaseConfig? = null
479
+
480
+ fun ssl(certPath: String, keyPath: String) {
481
+ ssl = SslConfig(certPath, keyPath)
482
+ }
483
+
484
+ fun database(url: String, maxPoolSize: Int = 10) {
485
+ database = DatabaseConfig(url, maxPoolSize)
486
+ }
487
+
488
+ fun build(): ServerConfig = ServerConfig(host, port, ssl, database)
489
+ }
490
+
491
+ fun serverConfig(init: ServerConfigBuilder.() -> Unit): ServerConfig =
492
+ ServerConfigBuilder().apply(init).build()
493
+
494
+ // Usage
495
+ val config = serverConfig {
496
+ host = "0.0.0.0"
497
+ port = 443
498
+ ssl("/certs/cert.pem", "/certs/key.pem")
499
+ database("jdbc:postgresql://localhost:5432/mydb", maxPoolSize = 20)
500
+ }
501
+ ```
502
+
503
+ ## Sequences for Lazy Evaluation
504
+
505
+ ```kotlin
506
+ // Good: Use sequences for large collections with multiple operations
507
+ val result = users.asSequence()
508
+ .filter { it.isActive }
509
+ .map { it.email }
510
+ .filter { it.endsWith("@company.com") }
511
+ .take(10)
512
+ .toList()
513
+
514
+ // Good: Generate infinite sequences
515
+ val fibonacci: Sequence<Long> = sequence {
516
+ var a = 0L
517
+ var b = 1L
518
+ while (true) {
519
+ yield(a)
520
+ val next = a + b
521
+ a = b
522
+ b = next
523
+ }
524
+ }
525
+
526
+ val first20 = fibonacci.take(20).toList()
527
+ ```
528
+
529
+ ## Gradle Kotlin DSL
530
+
531
+ ### build.gradle.kts Configuration
532
+
533
+ ```kotlin
534
+ // Check for latest versions: https://kotlinlang.org/docs/releases.html
535
+ plugins {
536
+ kotlin("jvm") version "2.3.10"
537
+ kotlin("plugin.serialization") version "2.3.10"
538
+ id("io.ktor.plugin") version "3.4.0"
539
+ id("org.jetbrains.kotlinx.kover") version "0.9.7"
540
+ id("io.gitlab.arturbosch.detekt") version "1.23.8"
541
+ }
542
+
543
+ group = "com.example"
544
+ version = "1.0.0"
545
+
546
+ kotlin {
547
+ jvmToolchain(21)
548
+ }
549
+
550
+ dependencies {
551
+ // Ktor
552
+ implementation("io.ktor:ktor-server-core:3.4.0")
553
+ implementation("io.ktor:ktor-server-netty:3.4.0")
554
+ implementation("io.ktor:ktor-server-content-negotiation:3.4.0")
555
+ implementation("io.ktor:ktor-serialization-kotlinx-json:3.4.0")
556
+
557
+ // Exposed
558
+ implementation("org.jetbrains.exposed:exposed-core:1.0.0")
559
+ implementation("org.jetbrains.exposed:exposed-dao:1.0.0")
560
+ implementation("org.jetbrains.exposed:exposed-jdbc:1.0.0")
561
+ implementation("org.jetbrains.exposed:exposed-kotlin-datetime:1.0.0")
562
+
563
+ // Koin
564
+ implementation("io.insert-koin:koin-ktor:4.2.0")
565
+
566
+ // Coroutines
567
+ implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:1.10.2")
568
+
569
+ // Testing
570
+ testImplementation("io.kotest:kotest-runner-junit5:6.1.4")
571
+ testImplementation("io.kotest:kotest-assertions-core:6.1.4")
572
+ testImplementation("io.kotest:kotest-property:6.1.4")
573
+ testImplementation("io.mockk:mockk:1.14.9")
574
+ testImplementation("io.ktor:ktor-server-test-host:3.4.0")
575
+ testImplementation("org.jetbrains.kotlinx:kotlinx-coroutines-test:1.10.2")
576
+ }
577
+
578
+ tasks.withType<Test> {
579
+ useJUnitPlatform()
580
+ }
581
+
582
+ detekt {
583
+ config.setFrom(files("config/detekt/detekt.yml"))
584
+ buildUponDefaultConfig = true
585
+ }
586
+ ```
587
+
588
+ ## Error Handling Patterns
589
+
590
+ ### Result Type for Domain Operations
591
+
592
+ ```kotlin
593
+ // Good: Use Kotlin's Result or a custom sealed class
594
+ suspend fun createUser(request: CreateUserRequest): Result<User> = runCatching {
595
+ require(request.name.isNotBlank()) { "Name cannot be blank" }
596
+ require('@' in request.email) { "Invalid email format" }
597
+
598
+ val user = User(
599
+ id = UserId(UUID.randomUUID().toString()),
600
+ name = request.name,
601
+ email = Email(request.email),
602
+ )
603
+ userRepository.save(user)
604
+ user
605
+ }
606
+
607
+ // Good: Chain results
608
+ val displayName = createUser(request)
609
+ .map { it.name }
610
+ .getOrElse { "Unknown" }
611
+ ```
612
+
613
+ ### require, check, error
614
+
615
+ ```kotlin
616
+ // Good: Preconditions with clear messages
617
+ fun withdraw(account: Account, amount: Money): Account {
618
+ require(amount.value > 0) { "Amount must be positive: $amount" }
619
+ check(account.balance >= amount) { "Insufficient balance: ${account.balance} < $amount" }
620
+
621
+ return account.copy(balance = account.balance - amount)
622
+ }
623
+ ```
624
+
625
+ ## Collection Operations
626
+
627
+ ### Idiomatic Collection Processing
628
+
629
+ ```kotlin
630
+ // Good: Chained operations
631
+ val activeAdminEmails: List<String> = users
632
+ .filter { it.role == Role.ADMIN && it.isActive }
633
+ .sortedBy { it.name }
634
+ .map { it.email }
635
+
636
+ // Good: Grouping and aggregation
637
+ val usersByRole: Map<Role, List<User>> = users.groupBy { it.role }
638
+
639
+ val oldestByRole: Map<Role, User?> = users.groupBy { it.role }
640
+ .mapValues { (_, users) -> users.minByOrNull { it.createdAt } }
641
+
642
+ // Good: Associate for map creation
643
+ val usersById: Map<UserId, User> = users.associateBy { it.id }
644
+
645
+ // Good: Partition for splitting
646
+ val (active, inactive) = users.partition { it.isActive }
647
+ ```
648
+
649
+ ## Quick Reference: Kotlin Idioms
650
+
651
+ | Idiom | Description |
652
+ |-------|-------------|
653
+ | `val` over `var` | Prefer immutable variables |
654
+ | `data class` | For value objects with equals/hashCode/copy |
655
+ | `sealed class/interface` | For restricted type hierarchies |
656
+ | `value class` | For type-safe wrappers with zero overhead |
657
+ | Expression `when` | Exhaustive pattern matching |
658
+ | Safe call `?.` | Null-safe member access |
659
+ | Elvis `?:` | Default value for nullables |
660
+ | `let`/`apply`/`also`/`run`/`with` | Scope functions for clean code |
661
+ | Extension functions | Add behavior without inheritance |
662
+ | `copy()` | Immutable updates on data classes |
663
+ | `require`/`check` | Precondition assertions |
664
+ | Coroutine `async`/`await` | Structured concurrent execution |
665
+ | `Flow` | Cold reactive streams |
666
+ | `sequence` | Lazy evaluation |
667
+ | Delegation `by` | Reuse implementation without inheritance |
668
+
669
+ ## Anti-Patterns to Avoid
670
+
671
+ ```kotlin
672
+ // Bad: Force-unwrapping nullable types
673
+ val name = user!!.name
674
+
675
+ // Bad: Platform type leakage from Java
676
+ fun getLength(s: String) = s.length // Safe
677
+ fun getLength(s: String?) = s?.length ?: 0 // Handle nulls from Java
678
+
679
+ // Bad: Mutable data classes
680
+ data class MutableUser(var name: String, var email: String)
681
+
682
+ // Bad: Using exceptions for control flow
683
+ try {
684
+ val user = findUser(id)
685
+ } catch (e: NotFoundException) {
686
+ // Don't use exceptions for expected cases
687
+ }
688
+
689
+ // Good: Use nullable return or Result
690
+ val user: User? = findUserOrNull(id)
691
+
692
+ // Bad: Ignoring coroutine scope
693
+ GlobalScope.launch { /* Avoid GlobalScope */ }
694
+
695
+ // Good: Use structured concurrency
696
+ coroutineScope {
697
+ launch { /* Properly scoped */ }
698
+ }
699
+
700
+ // Bad: Deeply nested scope functions
701
+ user?.let { u ->
702
+ u.address?.let { a ->
703
+ a.city?.let { c -> process(c) }
704
+ }
705
+ }
706
+
707
+ // Good: Direct null-safe chain
708
+ user?.address?.city?.let { process(it) }
709
+ ```
710
+
711
+ **Remember**: Kotlin code should be concise but readable. Leverage the type system for safety, prefer immutability, and use coroutines for concurrency. When in doubt, let the compiler help you.