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