@rubix0270/arboris 1.0.2 → 1.0.3

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