@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,503 @@
1
+ ---
2
+ name: perl-patterns
3
+ description: Modern Perl 5.36+ idioms, best practices, and conventions for building robust, maintainable Perl applications.
4
+ ---
5
+
6
+ # Modern Perl Development Patterns
7
+
8
+ Idiomatic Perl 5.36+ patterns and best practices for building robust, maintainable applications.
9
+
10
+ ## When to Activate
11
+
12
+ - Writing new Perl code or modules
13
+ - Reviewing Perl code for idiom compliance
14
+ - Refactoring legacy Perl to modern standards
15
+ - Designing Perl module architecture
16
+ - Migrating pre-5.36 code to modern Perl
17
+
18
+ ## How It Works
19
+
20
+ Apply these patterns as a bias toward modern Perl 5.36+ defaults: signatures, explicit modules, focused error handling, and testable boundaries. The examples below are meant to be copied as starting points, then tightened for the actual app, dependency stack, and deployment model in front of you.
21
+
22
+ ## Core Principles
23
+
24
+ ### 1. Use `v5.36` Pragma
25
+
26
+ A single `use v5.36` replaces the old boilerplate and enables strict, warnings, and subroutine signatures.
27
+
28
+ ```perl
29
+ # Good: Modern preamble
30
+ use v5.36;
31
+
32
+ sub greet($name) {
33
+ say "Hello, $name!";
34
+ }
35
+
36
+ # Bad: Legacy boilerplate
37
+ use strict;
38
+ use warnings;
39
+ use feature 'say', 'signatures';
40
+ no warnings 'experimental::signatures';
41
+
42
+ sub greet {
43
+ my ($name) = @_;
44
+ say "Hello, $name!";
45
+ }
46
+ ```
47
+
48
+ ### 2. Subroutine Signatures
49
+
50
+ Use signatures for clarity and automatic arity checking.
51
+
52
+ ```perl
53
+ use v5.36;
54
+
55
+ # Good: Signatures with defaults
56
+ sub connect_db($host, $port = 5432, $timeout = 30) {
57
+ # $host is required, others have defaults
58
+ return DBI->connect("dbi:Pg:host=$host;port=$port", undef, undef, {
59
+ RaiseError => 1,
60
+ PrintError => 0,
61
+ });
62
+ }
63
+
64
+ # Good: Slurpy parameter for variable args
65
+ sub log_message($level, @details) {
66
+ say "[$level] " . join(' ', @details);
67
+ }
68
+
69
+ # Bad: Manual argument unpacking
70
+ sub connect_db {
71
+ my ($host, $port, $timeout) = @_;
72
+ $port //= 5432;
73
+ $timeout //= 30;
74
+ # ...
75
+ }
76
+ ```
77
+
78
+ ### 3. Context Sensitivity
79
+
80
+ Understand scalar vs list context — a core Perl concept.
81
+
82
+ ```perl
83
+ use v5.36;
84
+
85
+ my @items = (1, 2, 3, 4, 5);
86
+
87
+ my @copy = @items; # List context: all elements
88
+ my $count = @items; # Scalar context: count (5)
89
+ say "Items: " . scalar @items; # Force scalar context
90
+ ```
91
+
92
+ ### 4. Postfix Dereferencing
93
+
94
+ Use postfix dereference syntax for readability with nested structures.
95
+
96
+ ```perl
97
+ use v5.36;
98
+
99
+ my $data = {
100
+ users => [
101
+ { name => 'Alice', roles => ['admin', 'user'] },
102
+ { name => 'Bob', roles => ['user'] },
103
+ ],
104
+ };
105
+
106
+ # Good: Postfix dereferencing
107
+ my @users = $data->{users}->@*;
108
+ my @roles = $data->{users}[0]{roles}->@*;
109
+ my %first = $data->{users}[0]->%*;
110
+
111
+ # Bad: Circumfix dereferencing (harder to read in chains)
112
+ my @users = @{ $data->{users} };
113
+ my @roles = @{ $data->{users}[0]{roles} };
114
+ ```
115
+
116
+ ### 5. The `isa` Operator (5.32+)
117
+
118
+ Infix type-check — replaces `blessed($o) && $o->isa('X')`.
119
+
120
+ ```perl
121
+ use v5.36;
122
+ if ($obj isa 'My::Class') { $obj->do_something }
123
+ ```
124
+
125
+ ## Error Handling
126
+
127
+ ### eval/die Pattern
128
+
129
+ ```perl
130
+ use v5.36;
131
+
132
+ sub parse_config($path) {
133
+ my $content = eval { path($path)->slurp_utf8 };
134
+ die "Config error: $@" if $@;
135
+ return decode_json($content);
136
+ }
137
+ ```
138
+
139
+ ### Try::Tiny (Reliable Exception Handling)
140
+
141
+ ```perl
142
+ use v5.36;
143
+ use Try::Tiny;
144
+
145
+ sub fetch_user($id) {
146
+ my $user = try {
147
+ $db->resultset('User')->find($id)
148
+ // die "User $id not found\n";
149
+ }
150
+ catch {
151
+ warn "Failed to fetch user $id: $_";
152
+ undef;
153
+ };
154
+ return $user;
155
+ }
156
+ ```
157
+
158
+ ### Native try/catch (5.40+)
159
+
160
+ ```perl
161
+ use v5.40;
162
+
163
+ sub divide($x, $y) {
164
+ try {
165
+ die "Division by zero" if $y == 0;
166
+ return $x / $y;
167
+ }
168
+ catch ($e) {
169
+ warn "Error: $e";
170
+ return;
171
+ }
172
+ }
173
+ ```
174
+
175
+ ## Modern OO with Moo
176
+
177
+ Prefer Moo for lightweight, modern OO. Use Moose only when its metaprotocol is needed.
178
+
179
+ ```perl
180
+ # Good: Moo class
181
+ package User;
182
+ use Moo;
183
+ use Types::Standard qw(Str Int ArrayRef);
184
+ use namespace::autoclean;
185
+
186
+ has name => (is => 'ro', isa => Str, required => 1);
187
+ has email => (is => 'ro', isa => Str, required => 1);
188
+ has age => (is => 'ro', isa => Int, default => sub { 0 });
189
+ has roles => (is => 'ro', isa => ArrayRef[Str], default => sub { [] });
190
+
191
+ sub is_admin($self) {
192
+ return grep { $_ eq 'admin' } $self->roles->@*;
193
+ }
194
+
195
+ sub greet($self) {
196
+ return "Hello, I'm " . $self->name;
197
+ }
198
+
199
+ 1;
200
+
201
+ # Usage
202
+ my $user = User->new(
203
+ name => 'Alice',
204
+ email => 'alice@example.com',
205
+ roles => ['admin', 'user'],
206
+ );
207
+
208
+ # Bad: Blessed hashref (no validation, no accessors)
209
+ package User;
210
+ sub new {
211
+ my ($class, %args) = @_;
212
+ return bless \%args, $class;
213
+ }
214
+ sub name { return $_[0]->{name} }
215
+ 1;
216
+ ```
217
+
218
+ ### Moo Roles
219
+
220
+ ```perl
221
+ package Role::Serializable;
222
+ use Moo::Role;
223
+ use JSON::MaybeXS qw(encode_json);
224
+ requires 'TO_HASH';
225
+ sub to_json($self) { encode_json($self->TO_HASH) }
226
+ 1;
227
+
228
+ package User;
229
+ use Moo;
230
+ with 'Role::Serializable';
231
+ has name => (is => 'ro', required => 1);
232
+ has email => (is => 'ro', required => 1);
233
+ sub TO_HASH($self) { { name => $self->name, email => $self->email } }
234
+ 1;
235
+ ```
236
+
237
+ ### Native `class` Keyword (5.38+, Corinna)
238
+
239
+ ```perl
240
+ use v5.38;
241
+ use feature 'class';
242
+ no warnings 'experimental::class';
243
+
244
+ class Point {
245
+ field $x :param;
246
+ field $y :param;
247
+ method magnitude() { sqrt($x**2 + $y**2) }
248
+ }
249
+
250
+ my $p = Point->new(x => 3, y => 4);
251
+ say $p->magnitude; # 5
252
+ ```
253
+
254
+ ## Regular Expressions
255
+
256
+ ### Named Captures and `/x` Flag
257
+
258
+ ```perl
259
+ use v5.36;
260
+
261
+ # Good: Named captures with /x for readability
262
+ my $log_re = qr{
263
+ ^ (?<timestamp> \d{4}-\d{2}-\d{2} \s \d{2}:\d{2}:\d{2} )
264
+ \s+ \[ (?<level> \w+ ) \]
265
+ \s+ (?<message> .+ ) $
266
+ }x;
267
+
268
+ if ($line =~ $log_re) {
269
+ say "Time: $+{timestamp}, Level: $+{level}";
270
+ say "Message: $+{message}";
271
+ }
272
+
273
+ # Bad: Positional captures (hard to maintain)
274
+ if ($line =~ /^(\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2})\s+\[(\w+)\]\s+(.+)$/) {
275
+ say "Time: $1, Level: $2";
276
+ }
277
+ ```
278
+
279
+ ### Precompiled Patterns
280
+
281
+ ```perl
282
+ use v5.36;
283
+
284
+ # Good: Compile once, use many
285
+ my $email_re = qr/^[A-Za-z0-9._%+-]+\@[A-Za-z0-9.-]+\.[A-Za-z]{2,}$/;
286
+
287
+ sub validate_emails(@emails) {
288
+ return grep { $_ =~ $email_re } @emails;
289
+ }
290
+ ```
291
+
292
+ ## Data Structures
293
+
294
+ ### References and Safe Deep Access
295
+
296
+ ```perl
297
+ use v5.36;
298
+
299
+ # Hash and array references
300
+ my $config = {
301
+ database => {
302
+ host => 'localhost',
303
+ port => 5432,
304
+ options => ['utf8', 'sslmode=require'],
305
+ },
306
+ };
307
+
308
+ # Safe deep access (returns undef if any level missing)
309
+ my $port = $config->{database}{port}; # 5432
310
+ my $missing = $config->{cache}{host}; # undef, no error
311
+
312
+ # Hash slices
313
+ my %subset;
314
+ @subset{qw(host port)} = @{$config->{database}}{qw(host port)};
315
+
316
+ # Array slices
317
+ my @first_two = $config->{database}{options}->@[0, 1];
318
+
319
+ # Multi-variable for loop (experimental in 5.36, stable in 5.40)
320
+ use feature 'for_list';
321
+ no warnings 'experimental::for_list';
322
+ for my ($key, $val) (%$config) {
323
+ say "$key => $val";
324
+ }
325
+ ```
326
+
327
+ ## File I/O
328
+
329
+ ### Three-Argument Open
330
+
331
+ ```perl
332
+ use v5.36;
333
+
334
+ # Good: Three-arg open with autodie (core module, eliminates 'or die')
335
+ use autodie;
336
+
337
+ sub read_file($path) {
338
+ open my $fh, '<:encoding(UTF-8)', $path;
339
+ local $/;
340
+ my $content = <$fh>;
341
+ close $fh;
342
+ return $content;
343
+ }
344
+
345
+ # Bad: Two-arg open (shell injection risk, see perl-security)
346
+ open FH, $path; # NEVER do this
347
+ open FH, "< $path"; # Still bad — user data in mode string
348
+ ```
349
+
350
+ ### Path::Tiny for File Operations
351
+
352
+ ```perl
353
+ use v5.36;
354
+ use Path::Tiny;
355
+
356
+ my $file = path('config', 'app.json');
357
+ my $content = $file->slurp_utf8;
358
+ $file->spew_utf8($new_content);
359
+
360
+ # Iterate directory
361
+ for my $child (path('src')->children(qr/\.pl$/)) {
362
+ say $child->basename;
363
+ }
364
+ ```
365
+
366
+ ## Module Organization
367
+
368
+ ### Standard Project Layout
369
+
370
+ ```text
371
+ MyApp/
372
+ ├── lib/
373
+ │ └── MyApp/
374
+ │ ├── App.pm # Main module
375
+ │ ├── Config.pm # Configuration
376
+ │ ├── DB.pm # Database layer
377
+ │ └── Util.pm # Utilities
378
+ ├── bin/
379
+ │ └── myapp # Entry-point script
380
+ ├── t/
381
+ │ ├── 00-load.t # Compilation tests
382
+ │ ├── unit/ # Unit tests
383
+ │ └── integration/ # Integration tests
384
+ ├── cpanfile # Dependencies
385
+ ├── Makefile.PL # Build system
386
+ └── .perlcriticrc # Linting config
387
+ ```
388
+
389
+ ### Exporter Patterns
390
+
391
+ ```perl
392
+ package MyApp::Util;
393
+ use v5.36;
394
+ use Exporter 'import';
395
+
396
+ our @EXPORT_OK = qw(trim);
397
+ our %EXPORT_TAGS = (all => \@EXPORT_OK);
398
+
399
+ sub trim($str) { $str =~ s/^\s+|\s+$//gr }
400
+
401
+ 1;
402
+ ```
403
+
404
+ ## Tooling
405
+
406
+ ### perltidy Configuration (.perltidyrc)
407
+
408
+ ```text
409
+ -i=4 # 4-space indent
410
+ -l=100 # 100-char line length
411
+ -ci=4 # continuation indent
412
+ -ce # cuddled else
413
+ -bar # opening brace on same line
414
+ -nolq # don't outdent long quoted strings
415
+ ```
416
+
417
+ ### perlcritic Configuration (.perlcriticrc)
418
+
419
+ ```ini
420
+ severity = 3
421
+ theme = core + pbp + security
422
+
423
+ [InputOutput::RequireCheckedSyscalls]
424
+ functions = :builtins
425
+ exclude_functions = say print
426
+
427
+ [Subroutines::ProhibitExplicitReturnUndef]
428
+ severity = 4
429
+
430
+ [ValuesAndExpressions::ProhibitMagicNumbers]
431
+ allowed_values = 0 1 2 -1
432
+ ```
433
+
434
+ ### Dependency Management (cpanfile + carton)
435
+
436
+ ```bash
437
+ cpanm App::cpanminus Carton # Install tools
438
+ carton install # Install deps from cpanfile
439
+ carton exec -- perl bin/myapp # Run with local deps
440
+ ```
441
+
442
+ ```perl
443
+ # cpanfile
444
+ requires 'Moo', '>= 2.005';
445
+ requires 'Path::Tiny';
446
+ requires 'JSON::MaybeXS';
447
+ requires 'Try::Tiny';
448
+
449
+ on test => sub {
450
+ requires 'Test2::V0';
451
+ requires 'Test::MockModule';
452
+ };
453
+ ```
454
+
455
+ ## Quick Reference: Modern Perl Idioms
456
+
457
+ | Legacy Pattern | Modern Replacement |
458
+ |---|---|
459
+ | `use strict; use warnings;` | `use v5.36;` |
460
+ | `my ($x, $y) = @_;` | `sub foo($x, $y) { ... }` |
461
+ | `@{ $ref }` | `$ref->@*` |
462
+ | `%{ $ref }` | `$ref->%*` |
463
+ | `open FH, "< $file"` | `open my $fh, '<:encoding(UTF-8)', $file` |
464
+ | `blessed hashref` | `Moo` class with types |
465
+ | `$1, $2, $3` | `$+{name}` (named captures) |
466
+ | `eval { }; if ($@)` | `Try::Tiny` or native `try/catch` (5.40+) |
467
+ | `BEGIN { require Exporter; }` | `use Exporter 'import';` |
468
+ | Manual file ops | `Path::Tiny` |
469
+ | `blessed($o) && $o->isa('X')` | `$o isa 'X'` (5.32+) |
470
+ | `builtin::true / false` | `use builtin 'true', 'false';` (5.36+, experimental) |
471
+
472
+ ## Anti-Patterns
473
+
474
+ ```perl
475
+ # 1. Two-arg open (security risk)
476
+ open FH, $filename; # NEVER
477
+
478
+ # 2. Indirect object syntax (ambiguous parsing)
479
+ my $obj = new Foo(bar => 1); # Bad
480
+ my $obj = Foo->new(bar => 1); # Good
481
+
482
+ # 3. Excessive reliance on $_
483
+ map { process($_) } grep { validate($_) } @items; # Hard to follow
484
+ my @valid = grep { validate($_) } @items; # Better: break it up
485
+ my @results = map { process($_) } @valid;
486
+
487
+ # 4. Disabling strict refs
488
+ no strict 'refs'; # Almost always wrong
489
+ ${"My::Package::$var"} = $value; # Use a hash instead
490
+
491
+ # 5. Global variables as configuration
492
+ our $TIMEOUT = 30; # Bad: mutable global
493
+ use constant TIMEOUT => 30; # Better: constant
494
+ # Best: Moo attribute with default
495
+
496
+ # 6. String eval for module loading
497
+ eval "require $module"; # Bad: code injection risk
498
+ eval "use $module"; # Bad
499
+ use Module::Runtime 'require_module'; # Good: safe module loading
500
+ require_module($module);
501
+ ```
502
+
503
+ **Remember**: Modern Perl is clean, readable, and safe. Let `use v5.36` handle the boilerplate, use Moo for objects, and prefer CPAN's battle-tested modules over hand-rolled solutions.