@rubix0270/arboris 1.0.1 → 1.0.3

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 +8 -19
  2. package/run.mjs +10 -0
  3. package/dist/cli.mjs +0 -382
  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,675 +0,0 @@
1
- ---
2
- name: golang-patterns
3
- description: Idiomatic Go patterns, best practices, and conventions for building robust, efficient, and maintainable Go applications.
4
- metadata:
5
- origin: ECC
6
- ---
7
-
8
- # Go Development Patterns
9
-
10
- Idiomatic Go patterns and best practices for building robust, efficient, and maintainable applications.
11
-
12
- ## When to Activate
13
-
14
- - Writing new Go code
15
- - Reviewing Go code
16
- - Refactoring existing Go code
17
- - Designing Go packages/modules
18
-
19
- ## Core Principles
20
-
21
- ### 1. Simplicity and Clarity
22
-
23
- Go favors simplicity over cleverness. Code should be obvious and easy to read.
24
-
25
- ```go
26
- // Good: Clear and direct
27
- func GetUser(id string) (*User, error) {
28
- user, err := db.FindUser(id)
29
- if err != nil {
30
- return nil, fmt.Errorf("get user %s: %w", id, err)
31
- }
32
- return user, nil
33
- }
34
-
35
- // Bad: Overly clever
36
- func GetUser(id string) (*User, error) {
37
- return func() (*User, error) {
38
- if u, e := db.FindUser(id); e == nil {
39
- return u, nil
40
- } else {
41
- return nil, e
42
- }
43
- }()
44
- }
45
- ```
46
-
47
- ### 2. Make the Zero Value Useful
48
-
49
- Design types so their zero value is immediately usable without initialization.
50
-
51
- ```go
52
- // Good: Zero value is useful
53
- type Counter struct {
54
- mu sync.Mutex
55
- count int // zero value is 0, ready to use
56
- }
57
-
58
- func (c *Counter) Inc() {
59
- c.mu.Lock()
60
- c.count++
61
- c.mu.Unlock()
62
- }
63
-
64
- // Good: bytes.Buffer works with zero value
65
- var buf bytes.Buffer
66
- buf.WriteString("hello")
67
-
68
- // Bad: Requires initialization
69
- type BadCounter struct {
70
- counts map[string]int // nil map will panic
71
- }
72
- ```
73
-
74
- ### 3. Accept Interfaces, Return Structs
75
-
76
- Functions should accept interface parameters and return concrete types.
77
-
78
- ```go
79
- // Good: Accepts interface, returns concrete type
80
- func ProcessData(r io.Reader) (*Result, error) {
81
- data, err := io.ReadAll(r)
82
- if err != nil {
83
- return nil, err
84
- }
85
- return &Result{Data: data}, nil
86
- }
87
-
88
- // Bad: Returns interface (hides implementation details unnecessarily)
89
- func ProcessData(r io.Reader) (io.Reader, error) {
90
- // ...
91
- }
92
- ```
93
-
94
- ## Error Handling Patterns
95
-
96
- ### Error Wrapping with Context
97
-
98
- ```go
99
- // Good: Wrap errors with context
100
- func LoadConfig(path string) (*Config, error) {
101
- data, err := os.ReadFile(path)
102
- if err != nil {
103
- return nil, fmt.Errorf("load config %s: %w", path, err)
104
- }
105
-
106
- var cfg Config
107
- if err := json.Unmarshal(data, &cfg); err != nil {
108
- return nil, fmt.Errorf("parse config %s: %w", path, err)
109
- }
110
-
111
- return &cfg, nil
112
- }
113
- ```
114
-
115
- ### Custom Error Types
116
-
117
- ```go
118
- // Define domain-specific errors
119
- type ValidationError struct {
120
- Field string
121
- Message string
122
- }
123
-
124
- func (e *ValidationError) Error() string {
125
- return fmt.Sprintf("validation failed on %s: %s", e.Field, e.Message)
126
- }
127
-
128
- // Sentinel errors for common cases
129
- var (
130
- ErrNotFound = errors.New("resource not found")
131
- ErrUnauthorized = errors.New("unauthorized")
132
- ErrInvalidInput = errors.New("invalid input")
133
- )
134
- ```
135
-
136
- ### Error Checking with errors.Is and errors.As
137
-
138
- ```go
139
- func HandleError(err error) {
140
- // Check for specific error
141
- if errors.Is(err, sql.ErrNoRows) {
142
- log.Println("No records found")
143
- return
144
- }
145
-
146
- // Check for error type
147
- var validationErr *ValidationError
148
- if errors.As(err, &validationErr) {
149
- log.Printf("Validation error on field %s: %s",
150
- validationErr.Field, validationErr.Message)
151
- return
152
- }
153
-
154
- // Unknown error
155
- log.Printf("Unexpected error: %v", err)
156
- }
157
- ```
158
-
159
- ### Never Ignore Errors
160
-
161
- ```go
162
- // Bad: Ignoring error with blank identifier
163
- result, _ := doSomething()
164
-
165
- // Good: Handle or explicitly document why it's safe to ignore
166
- result, err := doSomething()
167
- if err != nil {
168
- return err
169
- }
170
-
171
- // Acceptable: When error truly doesn't matter (rare)
172
- _ = writer.Close() // Best-effort cleanup, error logged elsewhere
173
- ```
174
-
175
- ## Concurrency Patterns
176
-
177
- ### Worker Pool
178
-
179
- ```go
180
- func WorkerPool(jobs <-chan Job, results chan<- Result, numWorkers int) {
181
- var wg sync.WaitGroup
182
-
183
- for i := 0; i < numWorkers; i++ {
184
- wg.Add(1)
185
- go func() {
186
- defer wg.Done()
187
- for job := range jobs {
188
- results <- process(job)
189
- }
190
- }()
191
- }
192
-
193
- wg.Wait()
194
- close(results)
195
- }
196
- ```
197
-
198
- ### Context for Cancellation and Timeouts
199
-
200
- ```go
201
- func FetchWithTimeout(ctx context.Context, url string) ([]byte, error) {
202
- ctx, cancel := context.WithTimeout(ctx, 5*time.Second)
203
- defer cancel()
204
-
205
- req, err := http.NewRequestWithContext(ctx, "GET", url, nil)
206
- if err != nil {
207
- return nil, fmt.Errorf("create request: %w", err)
208
- }
209
-
210
- resp, err := http.DefaultClient.Do(req)
211
- if err != nil {
212
- return nil, fmt.Errorf("fetch %s: %w", url, err)
213
- }
214
- defer resp.Body.Close()
215
-
216
- return io.ReadAll(resp.Body)
217
- }
218
- ```
219
-
220
- ### Graceful Shutdown
221
-
222
- ```go
223
- func GracefulShutdown(server *http.Server) {
224
- quit := make(chan os.Signal, 1)
225
- signal.Notify(quit, syscall.SIGINT, syscall.SIGTERM)
226
-
227
- <-quit
228
- log.Println("Shutting down server...")
229
-
230
- ctx, cancel := context.WithTimeout(context.Background(), 30*time.Second)
231
- defer cancel()
232
-
233
- if err := server.Shutdown(ctx); err != nil {
234
- log.Fatalf("Server forced to shutdown: %v", err)
235
- }
236
-
237
- log.Println("Server exited")
238
- }
239
- ```
240
-
241
- ### errgroup for Coordinated Goroutines
242
-
243
- ```go
244
- import "golang.org/x/sync/errgroup"
245
-
246
- func FetchAll(ctx context.Context, urls []string) ([][]byte, error) {
247
- g, ctx := errgroup.WithContext(ctx)
248
- results := make([][]byte, len(urls))
249
-
250
- for i, url := range urls {
251
- i, url := i, url // Capture loop variables
252
- g.Go(func() error {
253
- data, err := FetchWithTimeout(ctx, url)
254
- if err != nil {
255
- return err
256
- }
257
- results[i] = data
258
- return nil
259
- })
260
- }
261
-
262
- if err := g.Wait(); err != nil {
263
- return nil, err
264
- }
265
- return results, nil
266
- }
267
- ```
268
-
269
- ### Avoiding Goroutine Leaks
270
-
271
- ```go
272
- // Bad: Goroutine leak if context is cancelled
273
- func leakyFetch(ctx context.Context, url string) <-chan []byte {
274
- ch := make(chan []byte)
275
- go func() {
276
- data, _ := fetch(url)
277
- ch <- data // Blocks forever if no receiver
278
- }()
279
- return ch
280
- }
281
-
282
- // Good: Properly handles cancellation
283
- func safeFetch(ctx context.Context, url string) <-chan []byte {
284
- ch := make(chan []byte, 1) // Buffered channel
285
- go func() {
286
- data, err := fetch(url)
287
- if err != nil {
288
- return
289
- }
290
- select {
291
- case ch <- data:
292
- case <-ctx.Done():
293
- }
294
- }()
295
- return ch
296
- }
297
- ```
298
-
299
- ## Interface Design
300
-
301
- ### Small, Focused Interfaces
302
-
303
- ```go
304
- // Good: Single-method interfaces
305
- type Reader interface {
306
- Read(p []byte) (n int, err error)
307
- }
308
-
309
- type Writer interface {
310
- Write(p []byte) (n int, err error)
311
- }
312
-
313
- type Closer interface {
314
- Close() error
315
- }
316
-
317
- // Compose interfaces as needed
318
- type ReadWriteCloser interface {
319
- Reader
320
- Writer
321
- Closer
322
- }
323
- ```
324
-
325
- ### Define Interfaces Where They're Used
326
-
327
- ```go
328
- // In the consumer package, not the provider
329
- package service
330
-
331
- // UserStore defines what this service needs
332
- type UserStore interface {
333
- GetUser(id string) (*User, error)
334
- SaveUser(user *User) error
335
- }
336
-
337
- type Service struct {
338
- store UserStore
339
- }
340
-
341
- // Concrete implementation can be in another package
342
- // It doesn't need to know about this interface
343
- ```
344
-
345
- ### Optional Behavior with Type Assertions
346
-
347
- ```go
348
- type Flusher interface {
349
- Flush() error
350
- }
351
-
352
- func WriteAndFlush(w io.Writer, data []byte) error {
353
- if _, err := w.Write(data); err != nil {
354
- return err
355
- }
356
-
357
- // Flush if supported
358
- if f, ok := w.(Flusher); ok {
359
- return f.Flush()
360
- }
361
- return nil
362
- }
363
- ```
364
-
365
- ## Package Organization
366
-
367
- ### Standard Project Layout
368
-
369
- ```text
370
- myproject/
371
- ├── cmd/
372
- │ └── myapp/
373
- │ └── main.go # Entry point
374
- ├── internal/
375
- │ ├── handler/ # HTTP handlers
376
- │ ├── service/ # Business logic
377
- │ ├── repository/ # Data access
378
- │ └── config/ # Configuration
379
- ├── pkg/
380
- │ └── client/ # Public API client
381
- ├── api/
382
- │ └── v1/ # API definitions (proto, OpenAPI)
383
- ├── testdata/ # Test fixtures
384
- ├── go.mod
385
- ├── go.sum
386
- └── Makefile
387
- ```
388
-
389
- ### Package Naming
390
-
391
- ```go
392
- // Good: Short, lowercase, no underscores
393
- package http
394
- package json
395
- package user
396
-
397
- // Bad: Verbose, mixed case, or redundant
398
- package httpHandler
399
- package json_parser
400
- package userService // Redundant 'Service' suffix
401
- ```
402
-
403
- ### Avoid Package-Level State
404
-
405
- ```go
406
- // Bad: Global mutable state
407
- var db *sql.DB
408
-
409
- func init() {
410
- db, _ = sql.Open("postgres", os.Getenv("DATABASE_URL"))
411
- }
412
-
413
- // Good: Dependency injection
414
- type Server struct {
415
- db *sql.DB
416
- }
417
-
418
- func NewServer(db *sql.DB) *Server {
419
- return &Server{db: db}
420
- }
421
- ```
422
-
423
- ## Struct Design
424
-
425
- ### Functional Options Pattern
426
-
427
- ```go
428
- type Server struct {
429
- addr string
430
- timeout time.Duration
431
- logger *log.Logger
432
- }
433
-
434
- type Option func(*Server)
435
-
436
- func WithTimeout(d time.Duration) Option {
437
- return func(s *Server) {
438
- s.timeout = d
439
- }
440
- }
441
-
442
- func WithLogger(l *log.Logger) Option {
443
- return func(s *Server) {
444
- s.logger = l
445
- }
446
- }
447
-
448
- func NewServer(addr string, opts ...Option) *Server {
449
- s := &Server{
450
- addr: addr,
451
- timeout: 30 * time.Second, // default
452
- logger: log.Default(), // default
453
- }
454
- for _, opt := range opts {
455
- opt(s)
456
- }
457
- return s
458
- }
459
-
460
- // Usage
461
- server := NewServer(":8080",
462
- WithTimeout(60*time.Second),
463
- WithLogger(customLogger),
464
- )
465
- ```
466
-
467
- ### Embedding for Composition
468
-
469
- ```go
470
- type Logger struct {
471
- prefix string
472
- }
473
-
474
- func (l *Logger) Log(msg string) {
475
- fmt.Printf("[%s] %s\n", l.prefix, msg)
476
- }
477
-
478
- type Server struct {
479
- *Logger // Embedding - Server gets Log method
480
- addr string
481
- }
482
-
483
- func NewServer(addr string) *Server {
484
- return &Server{
485
- Logger: &Logger{prefix: "SERVER"},
486
- addr: addr,
487
- }
488
- }
489
-
490
- // Usage
491
- s := NewServer(":8080")
492
- s.Log("Starting...") // Calls embedded Logger.Log
493
- ```
494
-
495
- ## Memory and Performance
496
-
497
- ### Preallocate Slices When Size is Known
498
-
499
- ```go
500
- // Bad: Grows slice multiple times
501
- func processItems(items []Item) []Result {
502
- var results []Result
503
- for _, item := range items {
504
- results = append(results, process(item))
505
- }
506
- return results
507
- }
508
-
509
- // Good: Single allocation
510
- func processItems(items []Item) []Result {
511
- results := make([]Result, 0, len(items))
512
- for _, item := range items {
513
- results = append(results, process(item))
514
- }
515
- return results
516
- }
517
- ```
518
-
519
- ### Use sync.Pool for Frequent Allocations
520
-
521
- ```go
522
- var bufferPool = sync.Pool{
523
- New: func() interface{} {
524
- return new(bytes.Buffer)
525
- },
526
- }
527
-
528
- func ProcessRequest(data []byte) []byte {
529
- buf := bufferPool.Get().(*bytes.Buffer)
530
- defer func() {
531
- buf.Reset()
532
- bufferPool.Put(buf)
533
- }()
534
-
535
- buf.Write(data)
536
- // Process...
537
- return buf.Bytes()
538
- }
539
- ```
540
-
541
- ### Avoid String Concatenation in Loops
542
-
543
- ```go
544
- // Bad: Creates many string allocations
545
- func join(parts []string) string {
546
- var result string
547
- for _, p := range parts {
548
- result += p + ","
549
- }
550
- return result
551
- }
552
-
553
- // Good: Single allocation with strings.Builder
554
- func join(parts []string) string {
555
- var sb strings.Builder
556
- for i, p := range parts {
557
- if i > 0 {
558
- sb.WriteString(",")
559
- }
560
- sb.WriteString(p)
561
- }
562
- return sb.String()
563
- }
564
-
565
- // Best: Use standard library
566
- func join(parts []string) string {
567
- return strings.Join(parts, ",")
568
- }
569
- ```
570
-
571
- ## Go Tooling Integration
572
-
573
- ### Essential Commands
574
-
575
- ```bash
576
- # Build and run
577
- go build ./...
578
- go run ./cmd/myapp
579
-
580
- # Testing
581
- go test ./...
582
- go test -race ./...
583
- go test -cover ./...
584
-
585
- # Static analysis
586
- go vet ./...
587
- staticcheck ./...
588
- golangci-lint run
589
-
590
- # Module management
591
- go mod tidy
592
- go mod verify
593
-
594
- # Formatting
595
- gofmt -w .
596
- goimports -w .
597
- ```
598
-
599
- ### Recommended Linter Configuration (.golangci.yml)
600
-
601
- ```yaml
602
- linters:
603
- enable:
604
- - errcheck
605
- - gosimple
606
- - govet
607
- - ineffassign
608
- - staticcheck
609
- - unused
610
- - gofmt
611
- - goimports
612
- - misspell
613
- - unconvert
614
- - unparam
615
-
616
- linters-settings:
617
- errcheck:
618
- check-type-assertions: true
619
- govet:
620
- check-shadowing: true
621
-
622
- issues:
623
- exclude-use-default: false
624
- ```
625
-
626
- ## Quick Reference: Go Idioms
627
-
628
- | Idiom | Description |
629
- |-------|-------------|
630
- | Accept interfaces, return structs | Functions accept interface params, return concrete types |
631
- | Errors are values | Treat errors as first-class values, not exceptions |
632
- | Don't communicate by sharing memory | Use channels for coordination between goroutines |
633
- | Make the zero value useful | Types should work without explicit initialization |
634
- | A little copying is better than a little dependency | Avoid unnecessary external dependencies |
635
- | Clear is better than clever | Prioritize readability over cleverness |
636
- | gofmt is no one's favorite but everyone's friend | Always format with gofmt/goimports |
637
- | Return early | Handle errors first, keep happy path unindented |
638
-
639
- ## Anti-Patterns to Avoid
640
-
641
- ```go
642
- // Bad: Naked returns in long functions
643
- func process() (result int, err error) {
644
- // ... 50 lines ...
645
- return // What is being returned?
646
- }
647
-
648
- // Bad: Using panic for control flow
649
- func GetUser(id string) *User {
650
- user, err := db.Find(id)
651
- if err != nil {
652
- panic(err) // Don't do this
653
- }
654
- return user
655
- }
656
-
657
- // Bad: Passing context in struct
658
- type Request struct {
659
- ctx context.Context // Context should be first param
660
- ID string
661
- }
662
-
663
- // Good: Context as first parameter
664
- func ProcessRequest(ctx context.Context, id string) error {
665
- // ...
666
- }
667
-
668
- // Bad: Mixing value and pointer receivers
669
- type Counter struct{ n int }
670
- func (c Counter) Value() int { return c.n } // Value receiver
671
- func (c *Counter) Increment() { c.n++ } // Pointer receiver
672
- // Pick one style and be consistent
673
- ```
674
-
675
- **Remember**: Go code should be boring in the best way - predictable, consistent, and easy to understand. When in doubt, keep it simple.