@rubix0270/arboris 1.0.0

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