@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,751 @@
1
+ ---
2
+ name: python-patterns
3
+ description: Pythonic idioms, PEP 8 standards, type hints, and best practices for building robust, efficient, and maintainable Python applications.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Python Development Patterns
9
+
10
+ Idiomatic Python patterns and best practices for building robust, efficient, and maintainable applications.
11
+
12
+ ## When to Activate
13
+
14
+ - Writing new Python code
15
+ - Reviewing Python code
16
+ - Refactoring existing Python code
17
+ - Designing Python packages/modules
18
+
19
+ ## Core Principles
20
+
21
+ ### 1. Readability Counts
22
+
23
+ Python prioritizes readability. Code should be obvious and easy to understand.
24
+
25
+ ```python
26
+ # Good: Clear and readable
27
+ def get_active_users(users: list[User]) -> list[User]:
28
+ """Return only active users from the provided list."""
29
+ return [user for user in users if user.is_active]
30
+
31
+
32
+ # Bad: Clever but confusing
33
+ def get_active_users(u):
34
+ return [x for x in u if x.a]
35
+ ```
36
+
37
+ ### 2. Explicit is Better Than Implicit
38
+
39
+ Avoid magic; be clear about what your code does.
40
+
41
+ ```python
42
+ # Good: Explicit configuration
43
+ import logging
44
+
45
+ logging.basicConfig(
46
+ level=logging.INFO,
47
+ format='%(asctime)s - %(name)s - %(levelname)s - %(message)s'
48
+ )
49
+
50
+ # Bad: Hidden side effects
51
+ import some_module
52
+ some_module.setup() # What does this do?
53
+ ```
54
+
55
+ ### 3. EAFP - Easier to Ask Forgiveness Than Permission
56
+
57
+ Python prefers exception handling over checking conditions.
58
+
59
+ ```python
60
+ # Good: EAFP style
61
+ def get_value(dictionary: dict, key: str, default_value: Any = None) -> Any:
62
+ try:
63
+ return dictionary[key]
64
+ except KeyError:
65
+ return default_value
66
+
67
+ # Bad: LBYL (Look Before You Leap) style
68
+ def get_value(dictionary: dict, key: str, default_value: Any = None) -> Any:
69
+ if key in dictionary:
70
+ return dictionary[key]
71
+ else:
72
+ return default_value
73
+ ```
74
+
75
+ ## Type Hints
76
+
77
+ ### Basic Type Annotations
78
+
79
+ ```python
80
+ from typing import Optional, List, Dict, Any
81
+
82
+ def process_user(
83
+ user_id: str,
84
+ data: Dict[str, Any],
85
+ active: bool = True
86
+ ) -> Optional[User]:
87
+ """Process a user and return the updated User or None."""
88
+ if not active:
89
+ return None
90
+ return User(user_id, data)
91
+ ```
92
+
93
+ ### Modern Type Hints (Python 3.9+)
94
+
95
+ ```python
96
+ # Python 3.9+ - Use built-in types
97
+ def process_items(items: list[str]) -> dict[str, int]:
98
+ return {item: len(item) for item in items}
99
+
100
+ # Python 3.8 and earlier - Use typing module
101
+ from typing import List, Dict
102
+
103
+ def process_items(items: List[str]) -> Dict[str, int]:
104
+ return {item: len(item) for item in items}
105
+ ```
106
+
107
+ ### Type Aliases and TypeVar
108
+
109
+ ```python
110
+ from typing import TypeVar, Union
111
+
112
+ # Type alias for complex types
113
+ JSON = Union[dict[str, Any], list[Any], str, int, float, bool, None]
114
+
115
+ def parse_json(data: str) -> JSON:
116
+ return json.loads(data)
117
+
118
+ # Generic types
119
+ T = TypeVar('T')
120
+
121
+ def first(items: list[T]) -> T | None:
122
+ """Return the first item or None if list is empty."""
123
+ return items[0] if items else None
124
+ ```
125
+
126
+ ### Protocol-Based Duck Typing
127
+
128
+ ```python
129
+ from typing import Protocol
130
+
131
+ class Renderable(Protocol):
132
+ def render(self) -> str:
133
+ """Render the object to a string."""
134
+
135
+ def render_all(items: list[Renderable]) -> str:
136
+ """Render all items that implement the Renderable protocol."""
137
+ return "\n".join(item.render() for item in items)
138
+ ```
139
+
140
+ ## Error Handling Patterns
141
+
142
+ ### Specific Exception Handling
143
+
144
+ ```python
145
+ # Good: Catch specific exceptions
146
+ def load_config(path: str) -> Config:
147
+ try:
148
+ with open(path) as f:
149
+ return Config.from_json(f.read())
150
+ except FileNotFoundError as e:
151
+ raise ConfigError(f"Config file not found: {path}") from e
152
+ except json.JSONDecodeError as e:
153
+ raise ConfigError(f"Invalid JSON in config: {path}") from e
154
+
155
+ # Bad: Bare except
156
+ def load_config(path: str) -> Config:
157
+ try:
158
+ with open(path) as f:
159
+ return Config.from_json(f.read())
160
+ except:
161
+ return None # Silent failure!
162
+ ```
163
+
164
+ ### Exception Chaining
165
+
166
+ ```python
167
+ def process_data(data: str) -> Result:
168
+ try:
169
+ parsed = json.loads(data)
170
+ except json.JSONDecodeError as e:
171
+ # Chain exceptions to preserve the traceback
172
+ raise ValueError(f"Failed to parse data: {data}") from e
173
+ ```
174
+
175
+ ### Custom Exception Hierarchy
176
+
177
+ ```python
178
+ class AppError(Exception):
179
+ """Base exception for all application errors."""
180
+ pass
181
+
182
+ class ValidationError(AppError):
183
+ """Raised when input validation fails."""
184
+ pass
185
+
186
+ class NotFoundError(AppError):
187
+ """Raised when a requested resource is not found."""
188
+ pass
189
+
190
+ # Usage
191
+ def get_user(user_id: str) -> User:
192
+ user = db.find_user(user_id)
193
+ if not user:
194
+ raise NotFoundError(f"User not found: {user_id}")
195
+ return user
196
+ ```
197
+
198
+ ## Context Managers
199
+
200
+ ### Resource Management
201
+
202
+ ```python
203
+ # Good: Using context managers
204
+ def process_file(path: str) -> str:
205
+ with open(path, 'r') as f:
206
+ return f.read()
207
+
208
+ # Bad: Manual resource management
209
+ def process_file(path: str) -> str:
210
+ f = open(path, 'r')
211
+ try:
212
+ return f.read()
213
+ finally:
214
+ f.close()
215
+ ```
216
+
217
+ ### Custom Context Managers
218
+
219
+ ```python
220
+ from contextlib import contextmanager
221
+
222
+ @contextmanager
223
+ def timer(name: str):
224
+ """Context manager to time a block of code."""
225
+ start = time.perf_counter()
226
+ yield
227
+ elapsed = time.perf_counter() - start
228
+ print(f"{name} took {elapsed:.4f} seconds")
229
+
230
+ # Usage
231
+ with timer("data processing"):
232
+ process_large_dataset()
233
+ ```
234
+
235
+ ### Context Manager Classes
236
+
237
+ ```python
238
+ class DatabaseTransaction:
239
+ def __init__(self, connection):
240
+ self.connection = connection
241
+
242
+ def __enter__(self):
243
+ self.connection.begin_transaction()
244
+ return self
245
+
246
+ def __exit__(self, exc_type, exc_val, exc_tb):
247
+ if exc_type is None:
248
+ self.connection.commit()
249
+ else:
250
+ self.connection.rollback()
251
+ return False # Don't suppress exceptions
252
+
253
+ # Usage
254
+ with DatabaseTransaction(conn):
255
+ user = conn.create_user(user_data)
256
+ conn.create_profile(user.id, profile_data)
257
+ ```
258
+
259
+ ## Comprehensions and Generators
260
+
261
+ ### List Comprehensions
262
+
263
+ ```python
264
+ # Good: List comprehension for simple transformations
265
+ names = [user.name for user in users if user.is_active]
266
+
267
+ # Bad: Manual loop
268
+ names = []
269
+ for user in users:
270
+ if user.is_active:
271
+ names.append(user.name)
272
+
273
+ # Complex comprehensions should be expanded
274
+ # Bad: Too complex
275
+ result = [x * 2 for x in items if x > 0 if x % 2 == 0]
276
+
277
+ # Good: Use a generator function
278
+ def filter_and_transform(items: Iterable[int]) -> list[int]:
279
+ result = []
280
+ for x in items:
281
+ if x > 0 and x % 2 == 0:
282
+ result.append(x * 2)
283
+ return result
284
+ ```
285
+
286
+ ### Generator Expressions
287
+
288
+ ```python
289
+ # Good: Generator for lazy evaluation
290
+ total = sum(x * x for x in range(1_000_000))
291
+
292
+ # Bad: Creates large intermediate list
293
+ total = sum([x * x for x in range(1_000_000)])
294
+ ```
295
+
296
+ ### Generator Functions
297
+
298
+ ```python
299
+ def read_large_file(path: str) -> Iterator[str]:
300
+ """Read a large file line by line."""
301
+ with open(path) as f:
302
+ for line in f:
303
+ yield line.strip()
304
+
305
+ # Usage
306
+ for line in read_large_file("huge.txt"):
307
+ process(line)
308
+ ```
309
+
310
+ ## Data Classes and Named Tuples
311
+
312
+ ### Data Classes
313
+
314
+ ```python
315
+ from dataclasses import dataclass, field
316
+ from datetime import datetime
317
+
318
+ @dataclass
319
+ class User:
320
+ """User entity with automatic __init__, __repr__, and __eq__."""
321
+ id: str
322
+ name: str
323
+ email: str
324
+ created_at: datetime = field(default_factory=datetime.now)
325
+ is_active: bool = True
326
+
327
+ # Usage
328
+ user = User(
329
+ id="123",
330
+ name="Alice",
331
+ email="alice@example.com"
332
+ )
333
+ ```
334
+
335
+ ### Data Classes with Validation
336
+
337
+ ```python
338
+ @dataclass
339
+ class User:
340
+ email: str
341
+ age: int
342
+
343
+ def __post_init__(self):
344
+ # Validate email format
345
+ if "@" not in self.email:
346
+ raise ValueError(f"Invalid email: {self.email}")
347
+ # Validate age range
348
+ if self.age < 0 or self.age > 150:
349
+ raise ValueError(f"Invalid age: {self.age}")
350
+ ```
351
+
352
+ ### Named Tuples
353
+
354
+ ```python
355
+ from typing import NamedTuple
356
+
357
+ class Point(NamedTuple):
358
+ """Immutable 2D point."""
359
+ x: float
360
+ y: float
361
+
362
+ def distance(self, other: 'Point') -> float:
363
+ return ((self.x - other.x) ** 2 + (self.y - other.y) ** 2) ** 0.5
364
+
365
+ # Usage
366
+ p1 = Point(0, 0)
367
+ p2 = Point(3, 4)
368
+ print(p1.distance(p2)) # 5.0
369
+ ```
370
+
371
+ ## Decorators
372
+
373
+ ### Function Decorators
374
+
375
+ ```python
376
+ import functools
377
+ import time
378
+
379
+ def timer(func: Callable) -> Callable:
380
+ """Decorator to time function execution."""
381
+ @functools.wraps(func)
382
+ def wrapper(*args, **kwargs):
383
+ start = time.perf_counter()
384
+ result = func(*args, **kwargs)
385
+ elapsed = time.perf_counter() - start
386
+ print(f"{func.__name__} took {elapsed:.4f}s")
387
+ return result
388
+ return wrapper
389
+
390
+ @timer
391
+ def slow_function():
392
+ time.sleep(1)
393
+
394
+ # slow_function() prints: slow_function took 1.0012s
395
+ ```
396
+
397
+ ### Parameterized Decorators
398
+
399
+ ```python
400
+ def repeat(times: int):
401
+ """Decorator to repeat a function multiple times."""
402
+ def decorator(func: Callable) -> Callable:
403
+ @functools.wraps(func)
404
+ def wrapper(*args, **kwargs):
405
+ results = []
406
+ for _ in range(times):
407
+ results.append(func(*args, **kwargs))
408
+ return results
409
+ return wrapper
410
+ return decorator
411
+
412
+ @repeat(times=3)
413
+ def greet(name: str) -> str:
414
+ return f"Hello, {name}!"
415
+
416
+ # greet("Alice") returns ["Hello, Alice!", "Hello, Alice!", "Hello, Alice!"]
417
+ ```
418
+
419
+ ### Class-Based Decorators
420
+
421
+ ```python
422
+ class CountCalls:
423
+ """Decorator that counts how many times a function is called."""
424
+ def __init__(self, func: Callable):
425
+ functools.update_wrapper(self, func)
426
+ self.func = func
427
+ self.count = 0
428
+
429
+ def __call__(self, *args, **kwargs):
430
+ self.count += 1
431
+ print(f"{self.func.__name__} has been called {self.count} times")
432
+ return self.func(*args, **kwargs)
433
+
434
+ @CountCalls
435
+ def process():
436
+ pass
437
+
438
+ # Each call to process() prints the call count
439
+ ```
440
+
441
+ ## Concurrency Patterns
442
+
443
+ ### Threading for I/O-Bound Tasks
444
+
445
+ ```python
446
+ import concurrent.futures
447
+ import threading
448
+
449
+ def fetch_url(url: str) -> str:
450
+ """Fetch a URL (I/O-bound operation)."""
451
+ import urllib.request
452
+ with urllib.request.urlopen(url) as response:
453
+ return response.read().decode()
454
+
455
+ def fetch_all_urls(urls: list[str]) -> dict[str, str]:
456
+ """Fetch multiple URLs concurrently using threads."""
457
+ with concurrent.futures.ThreadPoolExecutor(max_workers=10) as executor:
458
+ future_to_url = {executor.submit(fetch_url, url): url for url in urls}
459
+ results = {}
460
+ for future in concurrent.futures.as_completed(future_to_url):
461
+ url = future_to_url[future]
462
+ try:
463
+ results[url] = future.result()
464
+ except Exception as e:
465
+ results[url] = f"Error: {e}"
466
+ return results
467
+ ```
468
+
469
+ ### Multiprocessing for CPU-Bound Tasks
470
+
471
+ ```python
472
+ def process_data(data: list[int]) -> int:
473
+ """CPU-intensive computation."""
474
+ return sum(x ** 2 for x in data)
475
+
476
+ def process_all(datasets: list[list[int]]) -> list[int]:
477
+ """Process multiple datasets using multiple processes."""
478
+ with concurrent.futures.ProcessPoolExecutor() as executor:
479
+ results = list(executor.map(process_data, datasets))
480
+ return results
481
+ ```
482
+
483
+ ### Async/Await for Concurrent I/O
484
+
485
+ ```python
486
+ import asyncio
487
+
488
+ async def fetch_async(url: str) -> str:
489
+ """Fetch a URL asynchronously."""
490
+ import aiohttp
491
+ async with aiohttp.ClientSession() as session:
492
+ async with session.get(url) as response:
493
+ return await response.text()
494
+
495
+ async def fetch_all(urls: list[str]) -> dict[str, str]:
496
+ """Fetch multiple URLs concurrently."""
497
+ tasks = [fetch_async(url) for url in urls]
498
+ results = await asyncio.gather(*tasks, return_exceptions=True)
499
+ return dict(zip(urls, results))
500
+ ```
501
+
502
+ ## Package Organization
503
+
504
+ ### Standard Project Layout
505
+
506
+ ```
507
+ myproject/
508
+ ├── src/
509
+ │ └── mypackage/
510
+ │ ├── __init__.py
511
+ │ ├── main.py
512
+ │ ├── api/
513
+ │ │ ├── __init__.py
514
+ │ │ └── routes.py
515
+ │ ├── models/
516
+ │ │ ├── __init__.py
517
+ │ │ └── user.py
518
+ │ └── utils/
519
+ │ ├── __init__.py
520
+ │ └── helpers.py
521
+ ├── tests/
522
+ │ ├── __init__.py
523
+ │ ├── conftest.py
524
+ │ ├── test_api.py
525
+ │ └── test_models.py
526
+ ├── pyproject.toml
527
+ ├── README.md
528
+ └── .gitignore
529
+ ```
530
+
531
+ ### Import Conventions
532
+
533
+ ```python
534
+ # Good: Import order - stdlib, third-party, local
535
+ import os
536
+ import sys
537
+ from pathlib import Path
538
+
539
+ import requests
540
+ from fastapi import FastAPI
541
+
542
+ from mypackage.models import User
543
+ from mypackage.utils import format_name
544
+
545
+ # Good: Use isort for automatic import sorting
546
+ # pip install isort
547
+ ```
548
+
549
+ ### __init__.py for Package Exports
550
+
551
+ ```python
552
+ # mypackage/__init__.py
553
+ """mypackage - A sample Python package."""
554
+
555
+ __version__ = "1.0.0"
556
+
557
+ # Export main classes/functions at package level
558
+ from mypackage.models import User, Post
559
+ from mypackage.utils import format_name
560
+
561
+ __all__ = ["User", "Post", "format_name"]
562
+ ```
563
+
564
+ ## Memory and Performance
565
+
566
+ ### Using __slots__ for Memory Efficiency
567
+
568
+ ```python
569
+ # Bad: Regular class uses __dict__ (more memory)
570
+ class Point:
571
+ def __init__(self, x: float, y: float):
572
+ self.x = x
573
+ self.y = y
574
+
575
+ # Good: __slots__ reduces memory usage
576
+ class Point:
577
+ __slots__ = ['x', 'y']
578
+
579
+ def __init__(self, x: float, y: float):
580
+ self.x = x
581
+ self.y = y
582
+ ```
583
+
584
+ ### Generator for Large Data
585
+
586
+ ```python
587
+ # Bad: Returns full list in memory
588
+ def read_lines(path: str) -> list[str]:
589
+ with open(path) as f:
590
+ return [line.strip() for line in f]
591
+
592
+ # Good: Yields lines one at a time
593
+ def read_lines(path: str) -> Iterator[str]:
594
+ with open(path) as f:
595
+ for line in f:
596
+ yield line.strip()
597
+ ```
598
+
599
+ ### Avoid String Concatenation in Loops
600
+
601
+ ```python
602
+ # Bad: O(n²) due to string immutability
603
+ result = ""
604
+ for item in items:
605
+ result += str(item)
606
+
607
+ # Good: O(n) using join
608
+ result = "".join(str(item) for item in items)
609
+
610
+ # Good: Using StringIO for building
611
+ from io import StringIO
612
+
613
+ buffer = StringIO()
614
+ for item in items:
615
+ buffer.write(str(item))
616
+ result = buffer.getvalue()
617
+ ```
618
+
619
+ ## Python Tooling Integration
620
+
621
+ ### Essential Commands
622
+
623
+ ```bash
624
+ # Code formatting
625
+ black .
626
+ isort .
627
+
628
+ # Linting
629
+ ruff check .
630
+ pylint mypackage/
631
+
632
+ # Type checking
633
+ mypy .
634
+
635
+ # Testing
636
+ pytest --cov=mypackage --cov-report=html
637
+
638
+ # Security scanning
639
+ bandit -r .
640
+
641
+ # Dependency management
642
+ pip-audit
643
+ safety check
644
+ ```
645
+
646
+ ### pyproject.toml Configuration
647
+
648
+ ```toml
649
+ [project]
650
+ name = "mypackage"
651
+ version = "1.0.0"
652
+ requires-python = ">=3.9"
653
+ dependencies = [
654
+ "requests>=2.31.0",
655
+ "pydantic>=2.0.0",
656
+ ]
657
+
658
+ [project.optional-dependencies]
659
+ dev = [
660
+ "pytest>=7.4.0",
661
+ "pytest-cov>=4.1.0",
662
+ "black>=23.0.0",
663
+ "ruff>=0.1.0",
664
+ "mypy>=1.5.0",
665
+ ]
666
+
667
+ [tool.black]
668
+ line-length = 88
669
+ target-version = ['py39']
670
+
671
+ [tool.ruff]
672
+ line-length = 88
673
+ select = ["E", "F", "I", "N", "W"]
674
+
675
+ [tool.mypy]
676
+ python_version = "3.9"
677
+ warn_return_any = true
678
+ warn_unused_configs = true
679
+ disallow_untyped_defs = true
680
+
681
+ [tool.pytest.ini_options]
682
+ testpaths = ["tests"]
683
+ addopts = "--cov=mypackage --cov-report=term-missing"
684
+ ```
685
+
686
+ ## Quick Reference: Python Idioms
687
+
688
+ | Idiom | Description |
689
+ |-------|-------------|
690
+ | EAFP | Easier to Ask Forgiveness than Permission |
691
+ | Context managers | Use `with` for resource management |
692
+ | List comprehensions | For simple transformations |
693
+ | Generators | For lazy evaluation and large datasets |
694
+ | Type hints | Annotate function signatures |
695
+ | Dataclasses | For data containers with auto-generated methods |
696
+ | `__slots__` | For memory optimization |
697
+ | f-strings | For string formatting (Python 3.6+) |
698
+ | `pathlib.Path` | For path operations (Python 3.4+) |
699
+ | `enumerate` | For index-element pairs in loops |
700
+
701
+ ## Anti-Patterns to Avoid
702
+
703
+ ```python
704
+ # Bad: Mutable default arguments
705
+ def append_to(item, items=[]):
706
+ items.append(item)
707
+ return items
708
+
709
+ # Good: Use None and create new list
710
+ def append_to(item, items=None):
711
+ if items is None:
712
+ items = []
713
+ items.append(item)
714
+ return items
715
+
716
+ # Bad: Checking type with type()
717
+ if type(obj) == list:
718
+ process(obj)
719
+
720
+ # Good: Use isinstance
721
+ if isinstance(obj, list):
722
+ process(obj)
723
+
724
+ # Bad: Comparing to None with ==
725
+ if value == None:
726
+ process()
727
+
728
+ # Good: Use is
729
+ if value is None:
730
+ process()
731
+
732
+ # Bad: from module import *
733
+ from os.path import *
734
+
735
+ # Good: Explicit imports
736
+ from os.path import join, exists
737
+
738
+ # Bad: Bare except
739
+ try:
740
+ risky_operation()
741
+ except:
742
+ pass
743
+
744
+ # Good: Specific exception
745
+ try:
746
+ risky_operation()
747
+ except SpecificError as e:
748
+ logger.error(f"Operation failed: {e}")
749
+ ```
750
+
751
+ __Remember__: Python code should be readable, explicit, and follow the principle of least surprise. When in doubt, prioritize clarity over cleverness.