@heytherevibin/skillforge 0.2.1

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 (402) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/CODE_OF_CONDUCT.md +34 -0
  3. package/CONTRIBUTING.md +38 -0
  4. package/LICENSE +21 -0
  5. package/README.md +337 -0
  6. package/RELEASING.md +93 -0
  7. package/SECURITY.md +31 -0
  8. package/STRATEGY.md +26 -0
  9. package/bin/cli.js +547 -0
  10. package/lib/packs.js +184 -0
  11. package/package.json +38 -0
  12. package/python/app/__init__.py +0 -0
  13. package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
  14. package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
  15. package/python/app/__pycache__/main.cpython-312.pyc +0 -0
  16. package/python/app/auth.py +63 -0
  17. package/python/app/cli.py +78 -0
  18. package/python/app/db_paths.py +26 -0
  19. package/python/app/events_cli.py +175 -0
  20. package/python/app/main.py +647 -0
  21. package/python/app/materialize.py +138 -0
  22. package/python/app/mcp_server.py +610 -0
  23. package/python/app/route_cli.py +117 -0
  24. package/python/requirements-dev.txt +1 -0
  25. package/python/requirements.txt +7 -0
  26. package/python/tests/test_db_paths.py +41 -0
  27. package/skills/accessibility/SKILL.md +145 -0
  28. package/skills/agent-architecture-audit/SKILL.md +256 -0
  29. package/skills/agent-eval/SKILL.md +144 -0
  30. package/skills/agent-harness-construction/SKILL.md +72 -0
  31. package/skills/agent-introspection-debugging/SKILL.md +152 -0
  32. package/skills/agent-payment-x402/SKILL.md +224 -0
  33. package/skills/agent-sort/SKILL.md +214 -0
  34. package/skills/agentic-engineering/SKILL.md +62 -0
  35. package/skills/agentic-os/SKILL.md +386 -0
  36. package/skills/ai-first-engineering/SKILL.md +50 -0
  37. package/skills/ai-regression-testing/SKILL.md +384 -0
  38. package/skills/android-clean-architecture/SKILL.md +338 -0
  39. package/skills/angular-developer/SKILL.md +153 -0
  40. package/skills/angular-developer/references/angular-animations.md +160 -0
  41. package/skills/angular-developer/references/angular-aria.md +410 -0
  42. package/skills/angular-developer/references/cli.md +86 -0
  43. package/skills/angular-developer/references/component-harnesses.md +59 -0
  44. package/skills/angular-developer/references/component-styling.md +91 -0
  45. package/skills/angular-developer/references/components.md +117 -0
  46. package/skills/angular-developer/references/creating-services.md +97 -0
  47. package/skills/angular-developer/references/data-resolvers.md +69 -0
  48. package/skills/angular-developer/references/define-routes.md +67 -0
  49. package/skills/angular-developer/references/defining-providers.md +72 -0
  50. package/skills/angular-developer/references/di-fundamentals.md +120 -0
  51. package/skills/angular-developer/references/e2e-testing.md +56 -0
  52. package/skills/angular-developer/references/effects.md +83 -0
  53. package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  54. package/skills/angular-developer/references/host-elements.md +80 -0
  55. package/skills/angular-developer/references/injection-context.md +63 -0
  56. package/skills/angular-developer/references/inputs.md +101 -0
  57. package/skills/angular-developer/references/linked-signal.md +59 -0
  58. package/skills/angular-developer/references/loading-strategies.md +61 -0
  59. package/skills/angular-developer/references/mcp.md +108 -0
  60. package/skills/angular-developer/references/navigate-to-routes.md +69 -0
  61. package/skills/angular-developer/references/outputs.md +86 -0
  62. package/skills/angular-developer/references/reactive-forms.md +122 -0
  63. package/skills/angular-developer/references/rendering-strategies.md +44 -0
  64. package/skills/angular-developer/references/resource.md +77 -0
  65. package/skills/angular-developer/references/route-animations.md +56 -0
  66. package/skills/angular-developer/references/route-guards.md +52 -0
  67. package/skills/angular-developer/references/router-lifecycle.md +45 -0
  68. package/skills/angular-developer/references/router-testing.md +87 -0
  69. package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  70. package/skills/angular-developer/references/signal-forms.md +795 -0
  71. package/skills/angular-developer/references/signals-overview.md +94 -0
  72. package/skills/angular-developer/references/tailwind-css.md +69 -0
  73. package/skills/angular-developer/references/template-driven-forms.md +114 -0
  74. package/skills/angular-developer/references/testing-fundamentals.md +65 -0
  75. package/skills/api-connector-builder/SKILL.md +120 -0
  76. package/skills/api-design/SKILL.md +522 -0
  77. package/skills/architecture-decision-records/SKILL.md +178 -0
  78. package/skills/article-writing/SKILL.md +78 -0
  79. package/skills/automation-audit-ops/SKILL.md +141 -0
  80. package/skills/autonomous-agent-harness/SKILL.md +272 -0
  81. package/skills/autonomous-loops/SKILL.md +609 -0
  82. package/skills/backend-patterns/SKILL.md +560 -0
  83. package/skills/benchmark/SKILL.md +92 -0
  84. package/skills/blueprint/SKILL.md +104 -0
  85. package/skills/browser-qa/SKILL.md +86 -0
  86. package/skills/bun-runtime/SKILL.md +83 -0
  87. package/skills/canary-watch/SKILL.md +98 -0
  88. package/skills/carrier-relationship-management/SKILL.md +211 -0
  89. package/skills/cisco-ios-patterns/SKILL.md +163 -0
  90. package/skills/ck/SKILL.md +147 -0
  91. package/skills/ck/commands/forget.mjs +44 -0
  92. package/skills/ck/commands/info.mjs +24 -0
  93. package/skills/ck/commands/init.mjs +143 -0
  94. package/skills/ck/commands/list.mjs +40 -0
  95. package/skills/ck/commands/migrate.mjs +202 -0
  96. package/skills/ck/commands/resume.mjs +36 -0
  97. package/skills/ck/commands/save.mjs +210 -0
  98. package/skills/ck/commands/shared.mjs +387 -0
  99. package/skills/ck/hooks/session-start.mjs +224 -0
  100. package/skills/claude-devfleet/SKILL.md +103 -0
  101. package/skills/click-path-audit/SKILL.md +244 -0
  102. package/skills/clickhouse-io/SKILL.md +438 -0
  103. package/skills/code-tour/SKILL.md +235 -0
  104. package/skills/codebase-onboarding/SKILL.md +232 -0
  105. package/skills/coding-standards/SKILL.md +548 -0
  106. package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
  107. package/skills/connections-optimizer/SKILL.md +188 -0
  108. package/skills/content-engine/SKILL.md +126 -0
  109. package/skills/content-hash-cache-pattern/SKILL.md +160 -0
  110. package/skills/context-budget/SKILL.md +134 -0
  111. package/skills/continuous-agent-loop/SKILL.md +44 -0
  112. package/skills/continuous-learning/SKILL.md +129 -0
  113. package/skills/continuous-learning/config.json +18 -0
  114. package/skills/continuous-learning/evaluate-session.sh +69 -0
  115. package/skills/continuous-learning-v2/SKILL.md +358 -0
  116. package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
  117. package/skills/continuous-learning-v2/agents/observer.md +198 -0
  118. package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  119. package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  120. package/skills/continuous-learning-v2/config.json +8 -0
  121. package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
  122. package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
  123. package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
  124. package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  125. package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  126. package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
  127. package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
  128. package/skills/cost-tracking/SKILL.md +147 -0
  129. package/skills/council/SKILL.md +202 -0
  130. package/skills/cpp-coding-standards/SKILL.md +722 -0
  131. package/skills/cpp-testing/SKILL.md +323 -0
  132. package/skills/crosspost/SKILL.md +110 -0
  133. package/skills/csharp-testing/SKILL.md +320 -0
  134. package/skills/customer-billing-ops/SKILL.md +139 -0
  135. package/skills/customs-trade-compliance/SKILL.md +262 -0
  136. package/skills/dart-flutter-patterns/SKILL.md +562 -0
  137. package/skills/dashboard-builder/SKILL.md +108 -0
  138. package/skills/data-scraper-agent/SKILL.md +764 -0
  139. package/skills/database-migrations/SKILL.md +428 -0
  140. package/skills/deep-research/SKILL.md +158 -0
  141. package/skills/defi-amm-security/SKILL.md +166 -0
  142. package/skills/deployment-patterns/SKILL.md +426 -0
  143. package/skills/design-system/SKILL.md +81 -0
  144. package/skills/django-celery/SKILL.md +456 -0
  145. package/skills/django-patterns/SKILL.md +733 -0
  146. package/skills/django-security/SKILL.md +592 -0
  147. package/skills/django-tdd/SKILL.md +728 -0
  148. package/skills/django-verification/SKILL.md +468 -0
  149. package/skills/dmux-workflows/SKILL.md +190 -0
  150. package/skills/docker-patterns/SKILL.md +363 -0
  151. package/skills/documentation-lookup/SKILL.md +89 -0
  152. package/skills/dotnet-patterns/SKILL.md +320 -0
  153. package/skills/e2e-testing/SKILL.md +325 -0
  154. package/skills/email-ops/SKILL.md +120 -0
  155. package/skills/energy-procurement/SKILL.md +227 -0
  156. package/skills/enterprise-agent-ops/SKILL.md +49 -0
  157. package/skills/error-handling/SKILL.md +375 -0
  158. package/skills/eval-harness/SKILL.md +269 -0
  159. package/skills/evm-token-decimals/SKILL.md +130 -0
  160. package/skills/exa-search/SKILL.md +106 -0
  161. package/skills/fal-ai-media/SKILL.md +287 -0
  162. package/skills/fastapi-patterns/SKILL.md +327 -0
  163. package/skills/finance-billing-ops/SKILL.md +126 -0
  164. package/skills/flox-environments/SKILL.md +496 -0
  165. package/skills/flutter-dart-code-review/SKILL.md +434 -0
  166. package/skills/foundation-models-on-device/SKILL.md +243 -0
  167. package/skills/frontend-design-direction/SKILL.md +92 -0
  168. package/skills/frontend-patterns/SKILL.md +641 -0
  169. package/skills/frontend-slides/SKILL.md +183 -0
  170. package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  171. package/skills/frontend-slides/animation-patterns.md +122 -0
  172. package/skills/frontend-slides/html-template.md +419 -0
  173. package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  174. package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  175. package/skills/frontend-slides/viewport-base.css +153 -0
  176. package/skills/fsharp-testing/SKILL.md +279 -0
  177. package/skills/gan-style-harness/SKILL.md +278 -0
  178. package/skills/gateguard/SKILL.md +125 -0
  179. package/skills/git-workflow/SKILL.md +714 -0
  180. package/skills/github-ops/SKILL.md +143 -0
  181. package/skills/golang-patterns/SKILL.md +673 -0
  182. package/skills/golang-testing/SKILL.md +719 -0
  183. package/skills/google-workspace-ops/SKILL.md +94 -0
  184. package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  185. package/skills/healthcare-emr-patterns/SKILL.md +159 -0
  186. package/skills/healthcare-eval-harness/SKILL.md +207 -0
  187. package/skills/healthcare-phi-compliance/SKILL.md +145 -0
  188. package/skills/hermes-imports/SKILL.md +87 -0
  189. package/skills/hexagonal-architecture/SKILL.md +275 -0
  190. package/skills/hipaa-compliance/SKILL.md +78 -0
  191. package/skills/homelab-network-readiness/SKILL.md +169 -0
  192. package/skills/homelab-network-setup/SKILL.md +129 -0
  193. package/skills/homelab-pihole-dns/SKILL.md +274 -0
  194. package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
  195. package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
  196. package/skills/hookify-rules/SKILL.md +128 -0
  197. package/skills/inventory-demand-planning/SKILL.md +246 -0
  198. package/skills/investor-materials/SKILL.md +95 -0
  199. package/skills/investor-outreach/SKILL.md +90 -0
  200. package/skills/ios-icon-gen/SKILL.md +157 -0
  201. package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  202. package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  203. package/skills/iterative-retrieval/SKILL.md +209 -0
  204. package/skills/java-coding-standards/SKILL.md +382 -0
  205. package/skills/jira-integration/SKILL.md +292 -0
  206. package/skills/jpa-patterns/SKILL.md +150 -0
  207. package/skills/knowledge-ops/SKILL.md +153 -0
  208. package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
  209. package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
  210. package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
  211. package/skills/kotlin-patterns/SKILL.md +710 -0
  212. package/skills/kotlin-testing/SKILL.md +823 -0
  213. package/skills/laravel-patterns/SKILL.md +414 -0
  214. package/skills/laravel-plugin-discovery/SKILL.md +228 -0
  215. package/skills/laravel-security/SKILL.md +284 -0
  216. package/skills/laravel-tdd/SKILL.md +282 -0
  217. package/skills/laravel-verification/SKILL.md +178 -0
  218. package/skills/lead-intelligence/SKILL.md +320 -0
  219. package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  220. package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  221. package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  222. package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  223. package/skills/liquid-glass-design/SKILL.md +279 -0
  224. package/skills/llm-trading-agent-security/SKILL.md +146 -0
  225. package/skills/logistics-exception-management/SKILL.md +221 -0
  226. package/skills/make-interfaces-feel-better/SKILL.md +151 -0
  227. package/skills/manim-video/SKILL.md +88 -0
  228. package/skills/manim-video/assets/network_graph_scene.py +52 -0
  229. package/skills/market-research/SKILL.md +74 -0
  230. package/skills/mcp-server-patterns/SKILL.md +68 -0
  231. package/skills/messages-ops/SKILL.md +103 -0
  232. package/skills/mle-workflow/SKILL.md +345 -0
  233. package/skills/motion-advanced/SKILL.md +596 -0
  234. package/skills/motion-foundations/SKILL.md +299 -0
  235. package/skills/motion-patterns/SKILL.md +435 -0
  236. package/skills/motion-ui/SKILL.md +574 -0
  237. package/skills/mysql-patterns/SKILL.md +411 -0
  238. package/skills/nanoclaw-repl/SKILL.md +32 -0
  239. package/skills/nestjs-patterns/SKILL.md +229 -0
  240. package/skills/netmiko-ssh-automation/SKILL.md +173 -0
  241. package/skills/network-bgp-diagnostics/SKILL.md +167 -0
  242. package/skills/network-config-validation/SKILL.md +210 -0
  243. package/skills/network-interface-health/SKILL.md +152 -0
  244. package/skills/nextjs-turbopack/SKILL.md +43 -0
  245. package/skills/nodejs-keccak256/SKILL.md +102 -0
  246. package/skills/nutrient-document-processing/SKILL.md +166 -0
  247. package/skills/nuxt4-patterns/SKILL.md +99 -0
  248. package/skills/openclaw-persona-forge/SKILL.md +288 -0
  249. package/skills/openclaw-persona-forge/gacha.py +224 -0
  250. package/skills/openclaw-persona-forge/gacha.sh +5 -0
  251. package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  252. package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  253. package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  254. package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  255. package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  256. package/skills/openclaw-persona-forge/references/output-template.md +166 -0
  257. package/skills/opensource-pipeline/SKILL.md +254 -0
  258. package/skills/perl-patterns/SKILL.md +503 -0
  259. package/skills/perl-security/SKILL.md +502 -0
  260. package/skills/perl-testing/SKILL.md +474 -0
  261. package/skills/plan-orchestrate/SKILL.md +253 -0
  262. package/skills/plankton-code-quality/SKILL.md +236 -0
  263. package/skills/postgres-patterns/SKILL.md +146 -0
  264. package/skills/product-capability/SKILL.md +140 -0
  265. package/skills/product-lens/SKILL.md +91 -0
  266. package/skills/production-audit/SKILL.md +206 -0
  267. package/skills/production-scheduling/SKILL.md +237 -0
  268. package/skills/project-flow-ops/SKILL.md +110 -0
  269. package/skills/prompt-optimizer/SKILL.md +398 -0
  270. package/skills/python-patterns/SKILL.md +749 -0
  271. package/skills/python-testing/SKILL.md +815 -0
  272. package/skills/pytorch-patterns/SKILL.md +395 -0
  273. package/skills/quality-nonconformance/SKILL.md +259 -0
  274. package/skills/quarkus-patterns/SKILL.md +721 -0
  275. package/skills/quarkus-security/SKILL.md +466 -0
  276. package/skills/quarkus-tdd/SKILL.md +810 -0
  277. package/skills/quarkus-verification/SKILL.md +478 -0
  278. package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
  279. package/skills/redis-patterns/SKILL.md +402 -0
  280. package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
  281. package/skills/remotion-video-creation/SKILL.md +43 -0
  282. package/skills/remotion-video-creation/rules/3d.md +86 -0
  283. package/skills/remotion-video-creation/rules/animations.md +29 -0
  284. package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  285. package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  286. package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  287. package/skills/remotion-video-creation/rules/assets.md +78 -0
  288. package/skills/remotion-video-creation/rules/audio.md +172 -0
  289. package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  290. package/skills/remotion-video-creation/rules/can-decode.md +75 -0
  291. package/skills/remotion-video-creation/rules/charts.md +58 -0
  292. package/skills/remotion-video-creation/rules/compositions.md +146 -0
  293. package/skills/remotion-video-creation/rules/display-captions.md +126 -0
  294. package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  295. package/skills/remotion-video-creation/rules/fonts.md +152 -0
  296. package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  297. package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  298. package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  299. package/skills/remotion-video-creation/rules/gifs.md +138 -0
  300. package/skills/remotion-video-creation/rules/images.md +130 -0
  301. package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  302. package/skills/remotion-video-creation/rules/lottie.md +67 -0
  303. package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  304. package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  305. package/skills/remotion-video-creation/rules/sequencing.md +106 -0
  306. package/skills/remotion-video-creation/rules/tailwind.md +11 -0
  307. package/skills/remotion-video-creation/rules/text-animations.md +20 -0
  308. package/skills/remotion-video-creation/rules/timing.md +179 -0
  309. package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  310. package/skills/remotion-video-creation/rules/transitions.md +122 -0
  311. package/skills/remotion-video-creation/rules/trimming.md +52 -0
  312. package/skills/remotion-video-creation/rules/videos.md +171 -0
  313. package/skills/repo-scan/SKILL.md +78 -0
  314. package/skills/research-ops/SKILL.md +111 -0
  315. package/skills/returns-reverse-logistics/SKILL.md +239 -0
  316. package/skills/rules-distill/SKILL.md +263 -0
  317. package/skills/rules-distill/scripts/scan-rules.sh +58 -0
  318. package/skills/rules-distill/scripts/scan-skills.sh +129 -0
  319. package/skills/rust-patterns/SKILL.md +498 -0
  320. package/skills/rust-testing/SKILL.md +499 -0
  321. package/skills/safety-guard/SKILL.md +74 -0
  322. package/skills/santa-method/SKILL.md +306 -0
  323. package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
  324. package/skills/scientific-db-uspto-database/SKILL.md +177 -0
  325. package/skills/scientific-pkg-gget/SKILL.md +166 -0
  326. package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
  327. package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  328. package/skills/search-first/SKILL.md +181 -0
  329. package/skills/security-bounty-hunter/SKILL.md +99 -0
  330. package/skills/security-review/SKILL.md +502 -0
  331. package/skills/security-review/cloud-infrastructure-security.md +361 -0
  332. package/skills/seo/SKILL.md +153 -0
  333. package/skills/skill-comply/SKILL.md +57 -0
  334. package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  335. package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  336. package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  337. package/skills/skill-comply/prompts/classifier.md +24 -0
  338. package/skills/skill-comply/prompts/scenario_generator.md +62 -0
  339. package/skills/skill-comply/prompts/spec_generator.md +42 -0
  340. package/skills/skill-comply/pyproject.toml +15 -0
  341. package/skills/skill-comply/scripts/__init__.py +0 -0
  342. package/skills/skill-comply/scripts/classifier.py +85 -0
  343. package/skills/skill-comply/scripts/grader.py +124 -0
  344. package/skills/skill-comply/scripts/parser.py +107 -0
  345. package/skills/skill-comply/scripts/report.py +170 -0
  346. package/skills/skill-comply/scripts/run.py +127 -0
  347. package/skills/skill-comply/scripts/runner.py +186 -0
  348. package/skills/skill-comply/scripts/scenario_generator.py +70 -0
  349. package/skills/skill-comply/scripts/spec_generator.py +72 -0
  350. package/skills/skill-comply/scripts/utils.py +13 -0
  351. package/skills/skill-comply/tests/test_grader.py +197 -0
  352. package/skills/skill-comply/tests/test_parser.py +90 -0
  353. package/skills/skill-comply/tests/test_runner.py +172 -0
  354. package/skills/skill-scout/SKILL.md +139 -0
  355. package/skills/skill-stocktake/SKILL.md +193 -0
  356. package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  357. package/skills/skill-stocktake/scripts/save-results.sh +56 -0
  358. package/skills/skill-stocktake/scripts/scan.sh +170 -0
  359. package/skills/social-graph-ranker/SKILL.md +153 -0
  360. package/skills/springboot-patterns/SKILL.md +313 -0
  361. package/skills/springboot-security/SKILL.md +271 -0
  362. package/skills/springboot-tdd/SKILL.md +157 -0
  363. package/skills/springboot-verification/SKILL.md +230 -0
  364. package/skills/strategic-compact/SKILL.md +129 -0
  365. package/skills/strategic-compact/suggest-compact.sh +54 -0
  366. package/skills/swift-actor-persistence/SKILL.md +142 -0
  367. package/skills/swift-concurrency-6-2/SKILL.md +216 -0
  368. package/skills/swift-protocol-di-testing/SKILL.md +189 -0
  369. package/skills/swiftui-patterns/SKILL.md +259 -0
  370. package/skills/tdd-workflow/SKILL.md +462 -0
  371. package/skills/team-builder/SKILL.md +166 -0
  372. package/skills/terminal-ops/SKILL.md +108 -0
  373. package/skills/tinystruct-patterns/SKILL.md +130 -0
  374. package/skills/tinystruct-patterns/references/architecture.md +77 -0
  375. package/skills/tinystruct-patterns/references/data-handling.md +35 -0
  376. package/skills/tinystruct-patterns/references/routing.md +57 -0
  377. package/skills/tinystruct-patterns/references/system-usage.md +74 -0
  378. package/skills/tinystruct-patterns/references/testing.md +59 -0
  379. package/skills/token-budget-advisor/SKILL.md +133 -0
  380. package/skills/ui-demo/SKILL.md +464 -0
  381. package/skills/ui-to-vue/SKILL.md +134 -0
  382. package/skills/unified-notifications-ops/SKILL.md +186 -0
  383. package/skills/verification-loop/SKILL.md +125 -0
  384. package/skills/video-editing/SKILL.md +309 -0
  385. package/skills/videodb/SKILL.md +373 -0
  386. package/skills/videodb/reference/api-reference.md +550 -0
  387. package/skills/videodb/reference/capture-reference.md +407 -0
  388. package/skills/videodb/reference/capture.md +101 -0
  389. package/skills/videodb/reference/editor.md +443 -0
  390. package/skills/videodb/reference/generative.md +331 -0
  391. package/skills/videodb/reference/rtstream-reference.md +564 -0
  392. package/skills/videodb/reference/rtstream.md +65 -0
  393. package/skills/videodb/reference/search.md +230 -0
  394. package/skills/videodb/reference/streaming.md +406 -0
  395. package/skills/videodb/reference/use-cases.md +118 -0
  396. package/skills/videodb/scripts/ws_listener.py +282 -0
  397. package/skills/visa-doc-translate/README.md +86 -0
  398. package/skills/visa-doc-translate/SKILL.md +117 -0
  399. package/skills/vite-patterns/SKILL.md +448 -0
  400. package/skills/windows-desktop-e2e/SKILL.md +787 -0
  401. package/skills/workspace-surface-audit/SKILL.md +124 -0
  402. package/skills/x-api/SKILL.md +233 -0
@@ -0,0 +1,58 @@
1
+ #!/usr/bin/env bash
2
+ # scan-rules.sh — enumerate rule files and extract H2 heading index
3
+ # Usage: scan-rules.sh [RULES_DIR]
4
+ # Output: JSON to stdout
5
+ #
6
+ # Environment:
7
+ # RULES_DISTILL_DIR Override ~/.claude/rules (for testing only)
8
+
9
+ set -euo pipefail
10
+
11
+ RULES_DIR="${RULES_DISTILL_DIR:-${1:-$HOME/.claude/rules}}"
12
+
13
+ if [[ ! -d "$RULES_DIR" ]]; then
14
+ jq -n --arg path "$RULES_DIR" '{"error":"rules directory not found","path":$path}' >&2
15
+ exit 1
16
+ fi
17
+
18
+ # Collect all .md files (excluding _archived/)
19
+ files=()
20
+ while IFS= read -r f; do
21
+ files+=("$f")
22
+ done < <(find "$RULES_DIR" -name '*.md' -not -path '*/_archived/*' -print | sort)
23
+
24
+ total=${#files[@]}
25
+
26
+ tmpdir=$(mktemp -d)
27
+ _rules_cleanup() { rm -rf "$tmpdir"; }
28
+ trap _rules_cleanup EXIT
29
+
30
+ for i in "${!files[@]}"; do
31
+ file="${files[$i]}"
32
+ rel_path="${file#"$HOME"/}"
33
+ rel_path="~/$rel_path"
34
+
35
+ # Extract H2 headings (## Title) into a JSON array via jq
36
+ headings_json=$({ grep -E '^## ' "$file" 2>/dev/null || true; } | sed 's/^## //' | jq -R . | jq -s '.')
37
+
38
+ # Get line count
39
+ line_count=$(wc -l < "$file" | tr -d ' ')
40
+
41
+ jq -n \
42
+ --arg path "$rel_path" \
43
+ --arg file "$(basename "$file")" \
44
+ --argjson lines "$line_count" \
45
+ --argjson headings "$headings_json" \
46
+ '{path:$path,file:$file,lines:$lines,headings:$headings}' \
47
+ > "$tmpdir/$i.json"
48
+ done
49
+
50
+ if [[ ${#files[@]} -eq 0 ]]; then
51
+ jq -n --arg dir "$RULES_DIR" '{rules_dir:$dir,total:0,rules:[]}'
52
+ else
53
+ jq -n \
54
+ --arg dir "$RULES_DIR" \
55
+ --argjson total "$total" \
56
+ --argjson rules "$(jq -s '.' "$tmpdir"/*.json)" \
57
+ '{rules_dir:$dir,total:$total,rules:$rules}'
58
+ fi
@@ -0,0 +1,129 @@
1
+ #!/usr/bin/env bash
2
+ # scan-skills.sh — enumerate skill files, extract frontmatter and UTC mtime
3
+ # Usage: scan-skills.sh [CWD_SKILLS_DIR]
4
+ # Output: JSON to stdout
5
+ #
6
+ # When CWD_SKILLS_DIR is omitted, defaults to $PWD/.claude/skills so the
7
+ # script always picks up project-level skills without relying on the caller.
8
+ #
9
+ # Environment:
10
+ # RULES_DISTILL_GLOBAL_DIR Override ~/.claude/skills (for testing only;
11
+ # do not set in production — intended for bats tests)
12
+ # RULES_DISTILL_PROJECT_DIR Override project dir detection (for testing only)
13
+
14
+ set -euo pipefail
15
+
16
+ GLOBAL_DIR="${RULES_DISTILL_GLOBAL_DIR:-$HOME/.claude/skills}"
17
+ CWD_SKILLS_DIR="${RULES_DISTILL_PROJECT_DIR:-${1:-$PWD/.claude/skills}}"
18
+ # Validate CWD_SKILLS_DIR looks like a .claude/skills path (defense-in-depth).
19
+ # Only warn when the path exists — a nonexistent path poses no traversal risk.
20
+ if [[ -n "$CWD_SKILLS_DIR" && -d "$CWD_SKILLS_DIR" && "$CWD_SKILLS_DIR" != */.claude/skills* ]]; then
21
+ echo "Warning: CWD_SKILLS_DIR does not look like a .claude/skills path: $CWD_SKILLS_DIR" >&2
22
+ fi
23
+
24
+ # Extract a frontmatter field (handles both quoted and unquoted single-line values).
25
+ # Does NOT support multi-line YAML blocks (| or >) or nested YAML keys.
26
+ extract_field() {
27
+ local file="$1" field="$2"
28
+ awk -v f="$field" '
29
+ BEGIN { fm=0 }
30
+ /^---$/ { fm++; next }
31
+ fm==1 {
32
+ n = length(f) + 2
33
+ if (substr($0, 1, n) == f ": ") {
34
+ val = substr($0, n+1)
35
+ gsub(/^"/, "", val)
36
+ gsub(/"$/, "", val)
37
+ print val
38
+ exit
39
+ }
40
+ }
41
+ fm>=2 { exit }
42
+ ' "$file"
43
+ }
44
+
45
+ # Get file mtime in UTC ISO8601 (portable: GNU and BSD)
46
+ get_mtime() {
47
+ local file="$1"
48
+ local secs
49
+ secs=$(stat -c %Y "$file" 2>/dev/null || stat -f %m "$file" 2>/dev/null) || return 1
50
+ date -u -d "@$secs" +%Y-%m-%dT%H:%M:%SZ 2>/dev/null ||
51
+ date -u -r "$secs" +%Y-%m-%dT%H:%M:%SZ
52
+ }
53
+
54
+ # Scan a directory and produce a JSON array of skill objects
55
+ scan_dir_to_json() {
56
+ local dir="$1"
57
+
58
+ local tmpdir
59
+ tmpdir=$(mktemp -d)
60
+ local _scan_tmpdir="$tmpdir"
61
+ _scan_cleanup() { rm -rf "$_scan_tmpdir"; }
62
+ trap _scan_cleanup RETURN
63
+
64
+ local i=0
65
+ while IFS= read -r file; do
66
+ local name desc mtime dp
67
+ name=$(extract_field "$file" "name")
68
+ desc=$(extract_field "$file" "description")
69
+ mtime=$(get_mtime "$file")
70
+ dp="${file/#$HOME/~}"
71
+
72
+ jq -n \
73
+ --arg path "$dp" \
74
+ --arg name "$name" \
75
+ --arg description "$desc" \
76
+ --arg mtime "$mtime" \
77
+ '{path:$path,name:$name,description:$description,mtime:$mtime}' \
78
+ > "$tmpdir/$i.json"
79
+ i=$((i+1))
80
+ done < <(find "$dir" -name "SKILL.md" -type f 2>/dev/null | sort)
81
+
82
+ if [[ $i -eq 0 ]]; then
83
+ echo "[]"
84
+ else
85
+ jq -s '.' "$tmpdir"/*.json
86
+ fi
87
+ }
88
+
89
+ # --- Main ---
90
+
91
+ global_found="false"
92
+ global_count=0
93
+ global_skills="[]"
94
+
95
+ if [[ -d "$GLOBAL_DIR" ]]; then
96
+ global_found="true"
97
+ global_skills=$(scan_dir_to_json "$GLOBAL_DIR")
98
+ global_count=$(echo "$global_skills" | jq 'length')
99
+ fi
100
+
101
+ project_found="false"
102
+ project_path=""
103
+ project_count=0
104
+ project_skills="[]"
105
+
106
+ if [[ -n "$CWD_SKILLS_DIR" && -d "$CWD_SKILLS_DIR" ]]; then
107
+ project_found="true"
108
+ project_path="$CWD_SKILLS_DIR"
109
+ project_skills=$(scan_dir_to_json "$CWD_SKILLS_DIR")
110
+ project_count=$(echo "$project_skills" | jq 'length')
111
+ fi
112
+
113
+ # Merge global + project skills into one array
114
+ all_skills=$(jq -s 'add' <(echo "$global_skills") <(echo "$project_skills"))
115
+
116
+ jq -n \
117
+ --arg global_found "$global_found" \
118
+ --argjson global_count "$global_count" \
119
+ --arg project_found "$project_found" \
120
+ --arg project_path "$project_path" \
121
+ --argjson project_count "$project_count" \
122
+ --argjson skills "$all_skills" \
123
+ '{
124
+ scan_summary: {
125
+ global: { found: ($global_found == "true"), count: $global_count },
126
+ project: { found: ($project_found == "true"), path: $project_path, count: $project_count }
127
+ },
128
+ skills: $skills
129
+ }'
@@ -0,0 +1,498 @@
1
+ ---
2
+ name: rust-patterns
3
+ description: Idiomatic Rust patterns, ownership, error handling, traits, concurrency, and best practices for building safe, performant applications.
4
+ ---
5
+
6
+ # Rust Development Patterns
7
+
8
+ Idiomatic Rust patterns and best practices for building safe, performant, and maintainable applications.
9
+
10
+ ## When to Use
11
+
12
+ - Writing new Rust code
13
+ - Reviewing Rust code
14
+ - Refactoring existing Rust code
15
+ - Designing crate structure and module layout
16
+
17
+ ## How It Works
18
+
19
+ This skill enforces idiomatic Rust conventions across six key areas: ownership and borrowing to prevent data races at compile time, `Result`/`?` error propagation with `thiserror` for libraries and `anyhow` for applications, enums and exhaustive pattern matching to make illegal states unrepresentable, traits and generics for zero-cost abstraction, safe concurrency via `Arc<Mutex<T>>`, channels, and async/await, and minimal `pub` surfaces organized by domain.
20
+
21
+ ## Core Principles
22
+
23
+ ### 1. Ownership and Borrowing
24
+
25
+ Rust's ownership system prevents data races and memory bugs at compile time.
26
+
27
+ ```rust
28
+ // Good: Pass references when you don't need ownership
29
+ fn process(data: &[u8]) -> usize {
30
+ data.len()
31
+ }
32
+
33
+ // Good: Take ownership only when you need to store or consume
34
+ fn store(data: Vec<u8>) -> Record {
35
+ Record { payload: data }
36
+ }
37
+
38
+ // Bad: Cloning unnecessarily to avoid borrow checker
39
+ fn process_bad(data: &Vec<u8>) -> usize {
40
+ let cloned = data.clone(); // Wasteful — just borrow
41
+ cloned.len()
42
+ }
43
+ ```
44
+
45
+ ### Use `Cow` for Flexible Ownership
46
+
47
+ ```rust
48
+ use std::borrow::Cow;
49
+
50
+ fn normalize(input: &str) -> Cow<'_, str> {
51
+ if input.contains(' ') {
52
+ Cow::Owned(input.replace(' ', "_"))
53
+ } else {
54
+ Cow::Borrowed(input) // Zero-cost when no mutation needed
55
+ }
56
+ }
57
+ ```
58
+
59
+ ## Error Handling
60
+
61
+ ### Use `Result` and `?` — Never `unwrap()` in Production
62
+
63
+ ```rust
64
+ // Good: Propagate errors with context
65
+ use anyhow::{Context, Result};
66
+
67
+ fn load_config(path: &str) -> Result<Config> {
68
+ let content = std::fs::read_to_string(path)
69
+ .with_context(|| format!("failed to read config from {path}"))?;
70
+ let config: Config = toml::from_str(&content)
71
+ .with_context(|| format!("failed to parse config from {path}"))?;
72
+ Ok(config)
73
+ }
74
+
75
+ // Bad: Panics on error
76
+ fn load_config_bad(path: &str) -> Config {
77
+ let content = std::fs::read_to_string(path).unwrap(); // Panics!
78
+ toml::from_str(&content).unwrap()
79
+ }
80
+ ```
81
+
82
+ ### Library Errors with `thiserror`, Application Errors with `anyhow`
83
+
84
+ ```rust
85
+ // Library code: structured, typed errors
86
+ use thiserror::Error;
87
+
88
+ #[derive(Debug, Error)]
89
+ pub enum StorageError {
90
+ #[error("record not found: {id}")]
91
+ NotFound { id: String },
92
+ #[error("connection failed")]
93
+ Connection(#[from] std::io::Error),
94
+ #[error("invalid data: {0}")]
95
+ InvalidData(String),
96
+ }
97
+
98
+ // Application code: flexible error handling
99
+ use anyhow::{bail, Result};
100
+
101
+ fn run() -> Result<()> {
102
+ let config = load_config("app.toml")?;
103
+ if config.workers == 0 {
104
+ bail!("worker count must be > 0");
105
+ }
106
+ Ok(())
107
+ }
108
+ ```
109
+
110
+ ### `Option` Combinators Over Nested Matching
111
+
112
+ ```rust
113
+ // Good: Combinator chain
114
+ fn find_user_email(users: &[User], id: u64) -> Option<String> {
115
+ users.iter()
116
+ .find(|u| u.id == id)
117
+ .map(|u| u.email.clone())
118
+ }
119
+
120
+ // Bad: Deeply nested matching
121
+ fn find_user_email_bad(users: &[User], id: u64) -> Option<String> {
122
+ match users.iter().find(|u| u.id == id) {
123
+ Some(user) => match &user.email {
124
+ email => Some(email.clone()),
125
+ },
126
+ None => None,
127
+ }
128
+ }
129
+ ```
130
+
131
+ ## Enums and Pattern Matching
132
+
133
+ ### Model States as Enums
134
+
135
+ ```rust
136
+ // Good: Impossible states are unrepresentable
137
+ enum ConnectionState {
138
+ Disconnected,
139
+ Connecting { attempt: u32 },
140
+ Connected { session_id: String },
141
+ Failed { reason: String, retries: u32 },
142
+ }
143
+
144
+ fn handle(state: &ConnectionState) {
145
+ match state {
146
+ ConnectionState::Disconnected => connect(),
147
+ ConnectionState::Connecting { attempt } if *attempt > 3 => abort(),
148
+ ConnectionState::Connecting { .. } => wait(),
149
+ ConnectionState::Connected { session_id } => use_session(session_id),
150
+ ConnectionState::Failed { retries, .. } if *retries < 5 => retry(),
151
+ ConnectionState::Failed { reason, .. } => log_failure(reason),
152
+ }
153
+ }
154
+ ```
155
+
156
+ ### Exhaustive Matching — No Catch-All for Business Logic
157
+
158
+ ```rust
159
+ // Good: Handle every variant explicitly
160
+ match command {
161
+ Command::Start => start_service(),
162
+ Command::Stop => stop_service(),
163
+ Command::Restart => restart_service(),
164
+ // Adding a new variant forces handling here
165
+ }
166
+
167
+ // Bad: Wildcard hides new variants
168
+ match command {
169
+ Command::Start => start_service(),
170
+ _ => {} // Silently ignores Stop, Restart, and future variants
171
+ }
172
+ ```
173
+
174
+ ## Traits and Generics
175
+
176
+ ### Accept Generics, Return Concrete Types
177
+
178
+ ```rust
179
+ // Good: Generic input, concrete output
180
+ fn read_all(reader: &mut impl Read) -> std::io::Result<Vec<u8>> {
181
+ let mut buf = Vec::new();
182
+ reader.read_to_end(&mut buf)?;
183
+ Ok(buf)
184
+ }
185
+
186
+ // Good: Trait bounds for multiple constraints
187
+ fn process<T: Display + Send + 'static>(item: T) -> String {
188
+ format!("processed: {item}")
189
+ }
190
+ ```
191
+
192
+ ### Trait Objects for Dynamic Dispatch
193
+
194
+ ```rust
195
+ // Use when you need heterogeneous collections or plugin systems
196
+ trait Handler: Send + Sync {
197
+ fn handle(&self, request: &Request) -> Response;
198
+ }
199
+
200
+ struct Router {
201
+ handlers: Vec<Box<dyn Handler>>,
202
+ }
203
+
204
+ // Use generics when you need performance (monomorphization)
205
+ fn fast_process<H: Handler>(handler: &H, request: &Request) -> Response {
206
+ handler.handle(request)
207
+ }
208
+ ```
209
+
210
+ ### Newtype Pattern for Type Safety
211
+
212
+ ```rust
213
+ // Good: Distinct types prevent mixing up arguments
214
+ struct UserId(u64);
215
+ struct OrderId(u64);
216
+
217
+ fn get_order(user: UserId, order: OrderId) -> Result<Order> {
218
+ // Can't accidentally swap user and order IDs
219
+ todo!()
220
+ }
221
+
222
+ // Bad: Easy to swap arguments
223
+ fn get_order_bad(user_id: u64, order_id: u64) -> Result<Order> {
224
+ todo!()
225
+ }
226
+ ```
227
+
228
+ ## Structs and Data Modeling
229
+
230
+ ### Builder Pattern for Complex Construction
231
+
232
+ ```rust
233
+ struct ServerConfig {
234
+ host: String,
235
+ port: u16,
236
+ max_connections: usize,
237
+ }
238
+
239
+ impl ServerConfig {
240
+ fn builder(host: impl Into<String>, port: u16) -> ServerConfigBuilder {
241
+ ServerConfigBuilder { host: host.into(), port, max_connections: 100 }
242
+ }
243
+ }
244
+
245
+ struct ServerConfigBuilder { host: String, port: u16, max_connections: usize }
246
+
247
+ impl ServerConfigBuilder {
248
+ fn max_connections(mut self, n: usize) -> Self { self.max_connections = n; self }
249
+ fn build(self) -> ServerConfig {
250
+ ServerConfig { host: self.host, port: self.port, max_connections: self.max_connections }
251
+ }
252
+ }
253
+
254
+ // Usage: ServerConfig::builder("localhost", 8080).max_connections(200).build()
255
+ ```
256
+
257
+ ## Iterators and Closures
258
+
259
+ ### Prefer Iterator Chains Over Manual Loops
260
+
261
+ ```rust
262
+ // Good: Declarative, lazy, composable
263
+ let active_emails: Vec<String> = users.iter()
264
+ .filter(|u| u.is_active)
265
+ .map(|u| u.email.clone())
266
+ .collect();
267
+
268
+ // Bad: Imperative accumulation
269
+ let mut active_emails = Vec::new();
270
+ for user in &users {
271
+ if user.is_active {
272
+ active_emails.push(user.email.clone());
273
+ }
274
+ }
275
+ ```
276
+
277
+ ### Use `collect()` with Type Annotation
278
+
279
+ ```rust
280
+ // Collect into different types
281
+ let names: Vec<_> = items.iter().map(|i| &i.name).collect();
282
+ let lookup: HashMap<_, _> = items.iter().map(|i| (i.id, i)).collect();
283
+ let combined: String = parts.iter().copied().collect();
284
+
285
+ // Collect Results — short-circuits on first error
286
+ let parsed: Result<Vec<i32>, _> = strings.iter().map(|s| s.parse()).collect();
287
+ ```
288
+
289
+ ## Concurrency
290
+
291
+ ### `Arc<Mutex<T>>` for Shared Mutable State
292
+
293
+ ```rust
294
+ use std::sync::{Arc, Mutex};
295
+
296
+ let counter = Arc::new(Mutex::new(0));
297
+ let handles: Vec<_> = (0..10).map(|_| {
298
+ let counter = Arc::clone(&counter);
299
+ std::thread::spawn(move || {
300
+ let mut num = counter.lock().expect("mutex poisoned");
301
+ *num += 1;
302
+ })
303
+ }).collect();
304
+
305
+ for handle in handles {
306
+ handle.join().expect("worker thread panicked");
307
+ }
308
+ ```
309
+
310
+ ### Channels for Message Passing
311
+
312
+ ```rust
313
+ use std::sync::mpsc;
314
+
315
+ let (tx, rx) = mpsc::sync_channel(16); // Bounded channel with backpressure
316
+
317
+ for i in 0..5 {
318
+ let tx = tx.clone();
319
+ std::thread::spawn(move || {
320
+ tx.send(format!("message {i}")).expect("receiver disconnected");
321
+ });
322
+ }
323
+ drop(tx); // Close sender so rx iterator terminates
324
+
325
+ for msg in rx {
326
+ println!("{msg}");
327
+ }
328
+ ```
329
+
330
+ ### Async with Tokio
331
+
332
+ ```rust
333
+ use tokio::time::Duration;
334
+
335
+ async fn fetch_with_timeout(url: &str) -> Result<String> {
336
+ let response = tokio::time::timeout(
337
+ Duration::from_secs(5),
338
+ reqwest::get(url),
339
+ )
340
+ .await
341
+ .context("request timed out")?
342
+ .context("request failed")?;
343
+
344
+ response.text().await.context("failed to read body")
345
+ }
346
+
347
+ // Spawn concurrent tasks
348
+ async fn fetch_all(urls: Vec<String>) -> Vec<Result<String>> {
349
+ let handles: Vec<_> = urls.into_iter()
350
+ .map(|url| tokio::spawn(async move {
351
+ fetch_with_timeout(&url).await
352
+ }))
353
+ .collect();
354
+
355
+ let mut results = Vec::with_capacity(handles.len());
356
+ for handle in handles {
357
+ results.push(handle.await.unwrap_or_else(|e| panic!("spawned task panicked: {e}")));
358
+ }
359
+ results
360
+ }
361
+ ```
362
+
363
+ ## Unsafe Code
364
+
365
+ ### When Unsafe Is Acceptable
366
+
367
+ ```rust
368
+ // Acceptable: FFI boundary with documented invariants (Rust 2024+)
369
+ /// # Safety
370
+ /// `ptr` must be a valid, aligned pointer to an initialized `Widget`.
371
+ unsafe fn widget_from_raw<'a>(ptr: *const Widget) -> &'a Widget {
372
+ // SAFETY: caller guarantees ptr is valid and aligned
373
+ unsafe { &*ptr }
374
+ }
375
+
376
+ // Acceptable: Performance-critical path with proof of correctness
377
+ // SAFETY: index is always < len due to the loop bound
378
+ unsafe { slice.get_unchecked(index) }
379
+ ```
380
+
381
+ ### When Unsafe Is NOT Acceptable
382
+
383
+ ```rust
384
+ // Bad: Using unsafe to bypass borrow checker
385
+ // Bad: Using unsafe for convenience
386
+ // Bad: Using unsafe without a Safety comment
387
+ // Bad: Transmuting between unrelated types
388
+ ```
389
+
390
+ ## Module System and Crate Structure
391
+
392
+ ### Organize by Domain, Not by Type
393
+
394
+ ```text
395
+ my_app/
396
+ ├── src/
397
+ │ ├── main.rs
398
+ │ ├── lib.rs
399
+ │ ├── auth/ # Domain module
400
+ │ │ ├── mod.rs
401
+ │ │ ├── token.rs
402
+ │ │ └── middleware.rs
403
+ │ ├── orders/ # Domain module
404
+ │ │ ├── mod.rs
405
+ │ │ ├── model.rs
406
+ │ │ └── service.rs
407
+ │ └── db/ # Infrastructure
408
+ │ ├── mod.rs
409
+ │ └── pool.rs
410
+ ├── tests/ # Integration tests
411
+ ├── benches/ # Benchmarks
412
+ └── Cargo.toml
413
+ ```
414
+
415
+ ### Visibility — Expose Minimally
416
+
417
+ ```rust
418
+ // Good: pub(crate) for internal sharing
419
+ pub(crate) fn validate_input(input: &str) -> bool {
420
+ !input.is_empty()
421
+ }
422
+
423
+ // Good: Re-export public API from lib.rs
424
+ pub mod auth;
425
+ pub use auth::AuthMiddleware;
426
+
427
+ // Bad: Making everything pub
428
+ pub fn internal_helper() {} // Should be pub(crate) or private
429
+ ```
430
+
431
+ ## Tooling Integration
432
+
433
+ ### Essential Commands
434
+
435
+ ```bash
436
+ # Build and check
437
+ cargo build
438
+ cargo check # Fast type checking without codegen
439
+ cargo clippy # Lints and suggestions
440
+ cargo fmt # Format code
441
+
442
+ # Testing
443
+ cargo test
444
+ cargo test -- --nocapture # Show println output
445
+ cargo test --lib # Unit tests only
446
+ cargo test --test integration # Integration tests only
447
+
448
+ # Dependencies
449
+ cargo audit # Security audit
450
+ cargo tree # Dependency tree
451
+ cargo update # Update dependencies
452
+
453
+ # Performance
454
+ cargo bench # Run benchmarks
455
+ ```
456
+
457
+ ## Quick Reference: Rust Idioms
458
+
459
+ | Idiom | Description |
460
+ |-------|-------------|
461
+ | Borrow, don't clone | Pass `&T` instead of cloning unless ownership is needed |
462
+ | Make illegal states unrepresentable | Use enums to model valid states only |
463
+ | `?` over `unwrap()` | Propagate errors, never panic in library/production code |
464
+ | Parse, don't validate | Convert unstructured data to typed structs at the boundary |
465
+ | Newtype for type safety | Wrap primitives in newtypes to prevent argument swaps |
466
+ | Prefer iterators over loops | Declarative chains are clearer and often faster |
467
+ | `#[must_use]` on Results | Ensure callers handle return values |
468
+ | `Cow` for flexible ownership | Avoid allocations when borrowing suffices |
469
+ | Exhaustive matching | No wildcard `_` for business-critical enums |
470
+ | Minimal `pub` surface | Use `pub(crate)` for internal APIs |
471
+
472
+ ## Anti-Patterns to Avoid
473
+
474
+ ```rust
475
+ // Bad: .unwrap() in production code
476
+ let value = map.get("key").unwrap();
477
+
478
+ // Bad: .clone() to satisfy borrow checker without understanding why
479
+ let data = expensive_data.clone();
480
+ process(&original, &data);
481
+
482
+ // Bad: Using String when &str suffices
483
+ fn greet(name: String) { /* should be &str */ }
484
+
485
+ // Bad: Box<dyn Error> in libraries (use thiserror instead)
486
+ fn parse(input: &str) -> Result<Data, Box<dyn std::error::Error>> { todo!() }
487
+
488
+ // Bad: Ignoring must_use warnings
489
+ let _ = validate(input); // Silently discarding a Result
490
+
491
+ // Bad: Blocking in async context
492
+ async fn bad_async() {
493
+ std::thread::sleep(Duration::from_secs(1)); // Blocks the executor!
494
+ // Use: tokio::time::sleep(Duration::from_secs(1)).await;
495
+ }
496
+ ```
497
+
498
+ **Remember**: If it compiles, it's probably correct — but only if you avoid `unwrap()`, minimize `unsafe`, and let the type system work for you.