@rubix0270/arboris 1.0.2 → 1.0.4

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/package.json +25 -37
  2. package/run.mjs +10 -0
  3. package/dist/cli.mjs +0 -383
  4. package/manifest.json +0 -323
  5. package/prisma/skills/accessibility/SKILL.md +0 -147
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +0 -257
  7. package/prisma/skills/agent-eval/SKILL.md +0 -146
  8. package/prisma/skills/agent-harness-construction/SKILL.md +0 -74
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +0 -154
  10. package/prisma/skills/agent-payment-x402/SKILL.md +0 -225
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +0 -182
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +0 -87
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +0 -86
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +0 -71
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +0 -64
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +0 -408
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +0 -86
  18. package/prisma/skills/agent-sort/SKILL.md +0 -216
  19. package/prisma/skills/agentic-engineering/SKILL.md +0 -64
  20. package/prisma/skills/agentic-os/SKILL.md +0 -388
  21. package/prisma/skills/ai-first-engineering/SKILL.md +0 -52
  22. package/prisma/skills/ai-regression-testing/SKILL.md +0 -386
  23. package/prisma/skills/android-clean-architecture/SKILL.md +0 -340
  24. package/prisma/skills/angular-developer/SKILL.md +0 -155
  25. package/prisma/skills/angular-developer/references/angular-animations.md +0 -160
  26. package/prisma/skills/angular-developer/references/angular-aria.md +0 -410
  27. package/prisma/skills/angular-developer/references/cli.md +0 -86
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +0 -59
  29. package/prisma/skills/angular-developer/references/component-styling.md +0 -91
  30. package/prisma/skills/angular-developer/references/components.md +0 -117
  31. package/prisma/skills/angular-developer/references/creating-services.md +0 -97
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +0 -69
  33. package/prisma/skills/angular-developer/references/define-routes.md +0 -67
  34. package/prisma/skills/angular-developer/references/defining-providers.md +0 -72
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +0 -120
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +0 -56
  37. package/prisma/skills/angular-developer/references/effects.md +0 -83
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +0 -43
  39. package/prisma/skills/angular-developer/references/host-elements.md +0 -80
  40. package/prisma/skills/angular-developer/references/injection-context.md +0 -63
  41. package/prisma/skills/angular-developer/references/inputs.md +0 -101
  42. package/prisma/skills/angular-developer/references/linked-signal.md +0 -59
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +0 -61
  44. package/prisma/skills/angular-developer/references/mcp.md +0 -108
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +0 -69
  46. package/prisma/skills/angular-developer/references/outputs.md +0 -86
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +0 -122
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +0 -44
  49. package/prisma/skills/angular-developer/references/resource.md +0 -77
  50. package/prisma/skills/angular-developer/references/route-animations.md +0 -56
  51. package/prisma/skills/angular-developer/references/route-guards.md +0 -52
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +0 -45
  53. package/prisma/skills/angular-developer/references/router-testing.md +0 -87
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +0 -68
  55. package/prisma/skills/angular-developer/references/signal-forms.md +0 -795
  56. package/prisma/skills/angular-developer/references/signals-overview.md +0 -94
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +0 -69
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +0 -114
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +0 -65
  60. package/prisma/skills/api-connector-builder/SKILL.md +0 -121
  61. package/prisma/skills/api-design/SKILL.md +0 -524
  62. package/prisma/skills/architecture-decision-records/SKILL.md +0 -180
  63. package/prisma/skills/article-writing/SKILL.md +0 -80
  64. package/prisma/skills/automation-audit-ops/SKILL.md +0 -143
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +0 -274
  66. package/prisma/skills/autonomous-loops/SKILL.md +0 -611
  67. package/prisma/skills/backend-patterns/SKILL.md +0 -562
  68. package/prisma/skills/benchmark/SKILL.md +0 -94
  69. package/prisma/skills/benchmark-methodology/SKILL.md +0 -190
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +0 -70
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +0 -165
  72. package/prisma/skills/blueprint/SKILL.md +0 -106
  73. package/prisma/skills/brand-discovery/SKILL.md +0 -145
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +0 -40
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +0 -44
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +0 -52
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +0 -57
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +0 -59
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +0 -50
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +0 -49
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +0 -133
  82. package/prisma/skills/brand-voice/SKILL.md +0 -98
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +0 -55
  84. package/prisma/skills/browser-qa/SKILL.md +0 -105
  85. package/prisma/skills/bun-runtime/SKILL.md +0 -85
  86. package/prisma/skills/canary-watch/SKILL.md +0 -108
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +0 -212
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +0 -164
  89. package/prisma/skills/ck/SKILL.md +0 -148
  90. package/prisma/skills/ck/commands/forget.mjs +0 -44
  91. package/prisma/skills/ck/commands/info.mjs +0 -24
  92. package/prisma/skills/ck/commands/init.mjs +0 -143
  93. package/prisma/skills/ck/commands/list.mjs +0 -40
  94. package/prisma/skills/ck/commands/migrate.mjs +0 -202
  95. package/prisma/skills/ck/commands/resume.mjs +0 -36
  96. package/prisma/skills/ck/commands/save.mjs +0 -210
  97. package/prisma/skills/ck/commands/shared.mjs +0 -387
  98. package/prisma/skills/ck/hooks/session-start.mjs +0 -224
  99. package/prisma/skills/claude-devfleet/SKILL.md +0 -112
  100. package/prisma/skills/click-path-audit/SKILL.md +0 -245
  101. package/prisma/skills/clickhouse-io/SKILL.md +0 -440
  102. package/prisma/skills/code-tour/SKILL.md +0 -254
  103. package/prisma/skills/codebase-onboarding/SKILL.md +0 -234
  104. package/prisma/skills/codehealth-mcp/SKILL.md +0 -167
  105. package/prisma/skills/coding-standards/SKILL.md +0 -551
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +0 -214
  107. package/prisma/skills/competitive-report-structure/SKILL.md +0 -162
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +0 -300
  109. package/prisma/skills/config-gc/SKILL.md +0 -120
  110. package/prisma/skills/configure-ecc/SKILL.md +0 -385
  111. package/prisma/skills/connections-optimizer/SKILL.md +0 -190
  112. package/prisma/skills/content-engine/SKILL.md +0 -132
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +0 -162
  114. package/prisma/skills/context-budget/SKILL.md +0 -136
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +0 -46
  116. package/prisma/skills/continuous-learning/SKILL.md +0 -132
  117. package/prisma/skills/continuous-learning/config.json +0 -18
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +0 -69
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +0 -361
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +0 -359
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +0 -189
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +0 -150
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +0 -248
  124. package/prisma/skills/continuous-learning-v2/config.json +0 -8
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +0 -585
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +0 -322
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -1956
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +0 -31
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +0 -68
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -1421
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +0 -184
  132. package/prisma/skills/cost-tracking/SKILL.md +0 -97
  133. package/prisma/skills/council/SKILL.md +0 -204
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +0 -724
  135. package/prisma/skills/cpp-testing/SKILL.md +0 -325
  136. package/prisma/skills/crosspost/SKILL.md +0 -112
  137. package/prisma/skills/csharp-testing/SKILL.md +0 -322
  138. package/prisma/skills/customer-billing-ops/SKILL.md +0 -141
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +0 -263
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +0 -564
  141. package/prisma/skills/dashboard-builder/SKILL.md +0 -109
  142. package/prisma/skills/data-scraper-agent/SKILL.md +0 -765
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +0 -73
  144. package/prisma/skills/database-migrations/SKILL.md +0 -430
  145. package/prisma/skills/deep-research/SKILL.md +0 -160
  146. package/prisma/skills/defi-amm-security/SKILL.md +0 -167
  147. package/prisma/skills/delivery-gate/SKILL.md +0 -126
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +0 -220
  149. package/prisma/skills/deployment-patterns/SKILL.md +0 -428
  150. package/prisma/skills/design-system/SKILL.md +0 -83
  151. package/prisma/skills/django-celery/SKILL.md +0 -458
  152. package/prisma/skills/django-patterns/SKILL.md +0 -735
  153. package/prisma/skills/django-security/SKILL.md +0 -644
  154. package/prisma/skills/django-tdd/SKILL.md +0 -730
  155. package/prisma/skills/django-verification/SKILL.md +0 -470
  156. package/prisma/skills/dmux-workflows/SKILL.md +0 -192
  157. package/prisma/skills/docker-patterns/SKILL.md +0 -365
  158. package/prisma/skills/documentation-lookup/SKILL.md +0 -91
  159. package/prisma/skills/dotnet-patterns/SKILL.md +0 -322
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +0 -124
  161. package/prisma/skills/e2e-testing/SKILL.md +0 -327
  162. package/prisma/skills/ecc-guide/SKILL.md +0 -190
  163. package/prisma/skills/ecc-recipes/SKILL.md +0 -149
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +0 -161
  165. package/prisma/skills/email-ops/SKILL.md +0 -122
  166. package/prisma/skills/energy-procurement/SKILL.md +0 -228
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +0 -51
  168. package/prisma/skills/error-handling/SKILL.md +0 -377
  169. package/prisma/skills/eval-harness/SKILL.md +0 -271
  170. package/prisma/skills/evm-token-decimals/SKILL.md +0 -131
  171. package/prisma/skills/exa-search/SKILL.md +0 -108
  172. package/prisma/skills/fal-ai-media/SKILL.md +0 -289
  173. package/prisma/skills/fastapi-patterns/SKILL.md +0 -514
  174. package/prisma/skills/finance-billing-ops/SKILL.md +0 -128
  175. package/prisma/skills/flox-environments/SKILL.md +0 -497
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +0 -436
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +0 -243
  178. package/prisma/skills/frontend-a11y/SKILL.md +0 -446
  179. package/prisma/skills/frontend-design-direction/SKILL.md +0 -93
  180. package/prisma/skills/frontend-patterns/SKILL.md +0 -657
  181. package/prisma/skills/frontend-slides/SKILL.md +0 -185
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +0 -330
  183. package/prisma/skills/frontend-slides/animation-patterns.md +0 -122
  184. package/prisma/skills/frontend-slides/html-template.md +0 -419
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +0 -418
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +0 -96
  187. package/prisma/skills/frontend-slides/viewport-base.css +0 -153
  188. package/prisma/skills/fsharp-testing/SKILL.md +0 -281
  189. package/prisma/skills/gan-style-harness/SKILL.md +0 -279
  190. package/prisma/skills/gateguard/SKILL.md +0 -133
  191. package/prisma/skills/generating-python-installer/SKILL.md +0 -820
  192. package/prisma/skills/git-workflow/SKILL.md +0 -716
  193. package/prisma/skills/github-ops/SKILL.md +0 -145
  194. package/prisma/skills/golang-patterns/SKILL.md +0 -675
  195. package/prisma/skills/golang-testing/SKILL.md +0 -721
  196. package/prisma/skills/google-workspace-ops/SKILL.md +0 -96
  197. package/prisma/skills/growth-log/SKILL.md +0 -128
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +0 -246
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +0 -160
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +0 -208
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +0 -146
  202. package/prisma/skills/hermes-imports/SKILL.md +0 -89
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +0 -277
  204. package/prisma/skills/hipaa-compliance/SKILL.md +0 -79
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +0 -170
  206. package/prisma/skills/homelab-network-setup/SKILL.md +0 -130
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +0 -275
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +0 -312
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +0 -306
  210. package/prisma/skills/hookify-rules/SKILL.md +0 -128
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +0 -157
  212. package/prisma/skills/intent-driven-development/SKILL.md +0 -360
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +0 -247
  214. package/prisma/skills/investor-materials/SKILL.md +0 -97
  215. package/prisma/skills/investor-outreach/SKILL.md +0 -92
  216. package/prisma/skills/ios-icon-gen/SKILL.md +0 -158
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +0 -258
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +0 -235
  219. package/prisma/skills/iterative-retrieval/SKILL.md +0 -212
  220. package/prisma/skills/ito-basket-compare/SKILL.md +0 -64
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +0 -64
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +0 -61
  223. package/prisma/skills/ito-trade-planner/SKILL.md +0 -68
  224. package/prisma/skills/java-coding-standards/SKILL.md +0 -384
  225. package/prisma/skills/jira-integration/SKILL.md +0 -303
  226. package/prisma/skills/jpa-patterns/SKILL.md +0 -152
  227. package/prisma/skills/knowledge-ops/SKILL.md +0 -155
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +0 -285
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +0 -720
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +0 -690
  231. package/prisma/skills/kotlin-patterns/SKILL.md +0 -712
  232. package/prisma/skills/kotlin-testing/SKILL.md +0 -825
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +0 -756
  234. package/prisma/skills/laravel-patterns/SKILL.md +0 -416
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +0 -230
  236. package/prisma/skills/laravel-security/SKILL.md +0 -948
  237. package/prisma/skills/laravel-tdd/SKILL.md +0 -675
  238. package/prisma/skills/laravel-verification/SKILL.md +0 -180
  239. package/prisma/skills/latency-critical-systems/SKILL.md +0 -74
  240. package/prisma/skills/lead-intelligence/SKILL.md +0 -322
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +0 -85
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +0 -75
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +0 -98
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +0 -60
  245. package/prisma/skills/liquid-glass-design/SKILL.md +0 -279
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +0 -147
  247. package/prisma/skills/logistics-exception-management/SKILL.md +0 -222
  248. package/prisma/skills/loop-design-check/SKILL.md +0 -143
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +0 -77
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +0 -152
  251. package/prisma/skills/manim-video/SKILL.md +0 -90
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +0 -52
  253. package/prisma/skills/market-research/SKILL.md +0 -76
  254. package/prisma/skills/marketing-campaign/SKILL.md +0 -114
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +0 -70
  256. package/prisma/skills/messages-ops/SKILL.md +0 -105
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +0 -57
  258. package/prisma/skills/mle-workflow/SKILL.md +0 -347
  259. package/prisma/skills/motion-advanced/SKILL.md +0 -596
  260. package/prisma/skills/motion-foundations/SKILL.md +0 -299
  261. package/prisma/skills/motion-patterns/SKILL.md +0 -434
  262. package/prisma/skills/motion-ui/SKILL.md +0 -576
  263. package/prisma/skills/mysql-patterns/SKILL.md +0 -413
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +0 -34
  265. package/prisma/skills/nestjs-patterns/SKILL.md +0 -231
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +0 -174
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +0 -168
  268. package/prisma/skills/network-config-validation/SKILL.md +0 -211
  269. package/prisma/skills/network-interface-health/SKILL.md +0 -153
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +0 -58
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +0 -103
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +0 -168
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +0 -101
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +0 -289
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +0 -224
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +0 -5
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +0 -124
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +0 -53
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +0 -53
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +0 -48
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +0 -39
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +0 -166
  283. package/prisma/skills/opensource-pipeline/SKILL.md +0 -256
  284. package/prisma/skills/orch-add-feature/SKILL.md +0 -45
  285. package/prisma/skills/orch-build-mvp/SKILL.md +0 -49
  286. package/prisma/skills/orch-change-feature/SKILL.md +0 -43
  287. package/prisma/skills/orch-fix-defect/SKILL.md +0 -43
  288. package/prisma/skills/orch-pipeline/SKILL.md +0 -121
  289. package/prisma/skills/orch-refine-code/SKILL.md +0 -44
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +0 -73
  291. package/prisma/skills/perl-patterns/SKILL.md +0 -505
  292. package/prisma/skills/perl-security/SKILL.md +0 -504
  293. package/prisma/skills/perl-testing/SKILL.md +0 -476
  294. package/prisma/skills/plan-orchestrate/SKILL.md +0 -263
  295. package/prisma/skills/plankton-code-quality/SKILL.md +0 -237
  296. package/prisma/skills/postgres-patterns/SKILL.md +0 -148
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +0 -64
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +0 -61
  299. package/prisma/skills/prisma-patterns/SKILL.md +0 -401
  300. package/prisma/skills/product-capability/SKILL.md +0 -142
  301. package/prisma/skills/product-lens/SKILL.md +0 -93
  302. package/prisma/skills/production-audit/SKILL.md +0 -207
  303. package/prisma/skills/production-scheduling/SKILL.md +0 -238
  304. package/prisma/skills/project-flow-ops/SKILL.md +0 -112
  305. package/prisma/skills/prompt-optimizer/SKILL.md +0 -398
  306. package/prisma/skills/python-patterns/SKILL.md +0 -751
  307. package/prisma/skills/python-testing/SKILL.md +0 -817
  308. package/prisma/skills/pytorch-patterns/SKILL.md +0 -397
  309. package/prisma/skills/quality-nonconformance/SKILL.md +0 -260
  310. package/prisma/skills/quarkus-patterns/SKILL.md +0 -723
  311. package/prisma/skills/quarkus-security/SKILL.md +0 -468
  312. package/prisma/skills/quarkus-tdd/SKILL.md +0 -812
  313. package/prisma/skills/quarkus-verification/SKILL.md +0 -480
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +0 -68
  315. package/prisma/skills/react-native-patterns/SKILL.md +0 -326
  316. package/prisma/skills/react-patterns/SKILL.md +0 -342
  317. package/prisma/skills/react-performance/SKILL.md +0 -575
  318. package/prisma/skills/react-testing/SKILL.md +0 -424
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +0 -115
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +0 -80
  321. package/prisma/skills/redis-patterns/SKILL.md +0 -404
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +0 -221
  323. package/prisma/skills/remotion-video-creation/SKILL.md +0 -43
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +0 -86
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +0 -29
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +0 -173
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +0 -100
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +0 -108
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +0 -78
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +0 -172
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +0 -104
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +0 -75
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +0 -58
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +0 -146
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +0 -126
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +0 -229
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +0 -152
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +0 -58
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +0 -68
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +0 -58
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +0 -138
  342. package/prisma/skills/remotion-video-creation/rules/images.md +0 -130
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +0 -67
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +0 -67
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +0 -34
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +0 -143
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +0 -106
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +0 -11
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +0 -20
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +0 -179
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +0 -19
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +0 -122
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +0 -52
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +0 -171
  355. package/prisma/skills/repo-scan/SKILL.md +0 -79
  356. package/prisma/skills/research-ops/SKILL.md +0 -113
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +0 -240
  358. package/prisma/skills/rules-distill/SKILL.md +0 -265
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +0 -58
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +0 -129
  361. package/prisma/skills/rust-patterns/SKILL.md +0 -500
  362. package/prisma/skills/rust-testing/SKILL.md +0 -501
  363. package/prisma/skills/safety-guard/SKILL.md +0 -76
  364. package/prisma/skills/santa-method/SKILL.md +0 -307
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +0 -176
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +0 -178
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +0 -167
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +0 -193
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +0 -161
  370. package/prisma/skills/search-first/SKILL.md +0 -183
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +0 -100
  372. package/prisma/skills/security-review/SKILL.md +0 -504
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +0 -361
  374. package/prisma/skills/security-scan/SKILL.md +0 -166
  375. package/prisma/skills/seo/SKILL.md +0 -155
  376. package/prisma/skills/skill-comply/SKILL.md +0 -59
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +0 -5
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +0 -3
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +0 -44
  380. package/prisma/skills/skill-comply/prompts/classifier.md +0 -24
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +0 -62
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +0 -42
  383. package/prisma/skills/skill-comply/pyproject.toml +0 -15
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +0 -85
  386. package/prisma/skills/skill-comply/scripts/grader.py +0 -124
  387. package/prisma/skills/skill-comply/scripts/parser.py +0 -107
  388. package/prisma/skills/skill-comply/scripts/report.py +0 -170
  389. package/prisma/skills/skill-comply/scripts/run.py +0 -127
  390. package/prisma/skills/skill-comply/scripts/runner.py +0 -194
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +0 -70
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +0 -72
  393. package/prisma/skills/skill-comply/scripts/utils.py +0 -13
  394. package/prisma/skills/skill-comply/tests/test_grader.py +0 -197
  395. package/prisma/skills/skill-comply/tests/test_parser.py +0 -90
  396. package/prisma/skills/skill-comply/tests/test_runner.py +0 -172
  397. package/prisma/skills/skill-scout/SKILL.md +0 -141
  398. package/prisma/skills/skill-stocktake/SKILL.md +0 -195
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +0 -87
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +0 -56
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +0 -170
  402. package/prisma/skills/social-graph-ranker/SKILL.md +0 -155
  403. package/prisma/skills/social-publisher/SKILL.md +0 -130
  404. package/prisma/skills/springboot-patterns/SKILL.md +0 -315
  405. package/prisma/skills/springboot-security/SKILL.md +0 -273
  406. package/prisma/skills/springboot-tdd/SKILL.md +0 -159
  407. package/prisma/skills/springboot-verification/SKILL.md +0 -232
  408. package/prisma/skills/strategic-compact/SKILL.md +0 -136
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +0 -144
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +0 -216
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +0 -191
  412. package/prisma/skills/swiftui-patterns/SKILL.md +0 -259
  413. package/prisma/skills/taste/SKILL.md +0 -264
  414. package/prisma/skills/taste/references/genre-taxonomy.md +0 -87
  415. package/prisma/skills/tdd-workflow/SKILL.md +0 -583
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +0 -111
  417. package/prisma/skills/team-builder/SKILL.md +0 -169
  418. package/prisma/skills/terminal-ops/SKILL.md +0 -110
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +0 -279
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +0 -90
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +0 -60
  422. package/prisma/skills/tinystruct-patterns/references/database.md +0 -99
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +0 -64
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +0 -97
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +0 -72
  426. package/prisma/skills/token-budget-advisor/SKILL.md +0 -134
  427. package/prisma/skills/ui-demo/SKILL.md +0 -466
  428. package/prisma/skills/ui-to-vue/SKILL.md +0 -135
  429. package/prisma/skills/uncloud/SKILL.md +0 -344
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +0 -188
  431. package/prisma/skills/verification-loop/SKILL.md +0 -127
  432. package/prisma/skills/video-editing/SKILL.md +0 -311
  433. package/prisma/skills/videodb/SKILL.md +0 -375
  434. package/prisma/skills/videodb/reference/api-reference.md +0 -550
  435. package/prisma/skills/videodb/reference/capture-reference.md +0 -407
  436. package/prisma/skills/videodb/reference/capture.md +0 -101
  437. package/prisma/skills/videodb/reference/editor.md +0 -443
  438. package/prisma/skills/videodb/reference/generative.md +0 -331
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +0 -564
  440. package/prisma/skills/videodb/reference/rtstream.md +0 -65
  441. package/prisma/skills/videodb/reference/search.md +0 -230
  442. package/prisma/skills/videodb/reference/streaming.md +0 -406
  443. package/prisma/skills/videodb/reference/use-cases.md +0 -118
  444. package/prisma/skills/videodb/scripts/ws_listener.py +0 -282
  445. package/prisma/skills/visa-doc-translate/README.md +0 -86
  446. package/prisma/skills/visa-doc-translate/SKILL.md +0 -117
  447. package/prisma/skills/vite-patterns/SKILL.md +0 -450
  448. package/prisma/skills/vue-patterns/SKILL.md +0 -471
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +0 -888
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +0 -126
  451. package/prisma/skills/x-api/SKILL.md +0 -235
@@ -1,712 +0,0 @@
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.