@rubix0270/arboris 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/README.md +151 -0
  2. package/cli/manifest.json +323 -0
  3. package/dist/cli.mjs +376 -0
  4. package/package.json +81 -0
  5. package/prisma/skills/accessibility/SKILL.md +147 -0
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  7. package/prisma/skills/agent-eval/SKILL.md +146 -0
  8. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  10. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  18. package/prisma/skills/agent-sort/SKILL.md +216 -0
  19. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  20. package/prisma/skills/agentic-os/SKILL.md +388 -0
  21. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  22. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  23. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  24. package/prisma/skills/angular-developer/SKILL.md +155 -0
  25. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  26. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  27. package/prisma/skills/angular-developer/references/cli.md +86 -0
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  29. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  30. package/prisma/skills/angular-developer/references/components.md +117 -0
  31. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  33. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  34. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  37. package/prisma/skills/angular-developer/references/effects.md +83 -0
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  39. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  40. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  41. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  42. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  44. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  46. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  49. package/prisma/skills/angular-developer/references/resource.md +77 -0
  50. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  51. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  53. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  55. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  56. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  60. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  61. package/prisma/skills/api-design/SKILL.md +524 -0
  62. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  63. package/prisma/skills/article-writing/SKILL.md +80 -0
  64. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  66. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  67. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  68. package/prisma/skills/benchmark/SKILL.md +94 -0
  69. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  72. package/prisma/skills/blueprint/SKILL.md +106 -0
  73. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  82. package/prisma/skills/brand-voice/SKILL.md +98 -0
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  84. package/prisma/skills/browser-qa/SKILL.md +105 -0
  85. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  86. package/prisma/skills/canary-watch/SKILL.md +108 -0
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  89. package/prisma/skills/ck/SKILL.md +148 -0
  90. package/prisma/skills/ck/commands/forget.mjs +44 -0
  91. package/prisma/skills/ck/commands/info.mjs +24 -0
  92. package/prisma/skills/ck/commands/init.mjs +143 -0
  93. package/prisma/skills/ck/commands/list.mjs +40 -0
  94. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  95. package/prisma/skills/ck/commands/resume.mjs +36 -0
  96. package/prisma/skills/ck/commands/save.mjs +210 -0
  97. package/prisma/skills/ck/commands/shared.mjs +387 -0
  98. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  99. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  100. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  101. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  102. package/prisma/skills/code-tour/SKILL.md +254 -0
  103. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  104. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  105. package/prisma/skills/coding-standards/SKILL.md +551 -0
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  107. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  109. package/prisma/skills/config-gc/SKILL.md +120 -0
  110. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  111. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  112. package/prisma/skills/content-engine/SKILL.md +132 -0
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  114. package/prisma/skills/context-budget/SKILL.md +136 -0
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  116. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  117. package/prisma/skills/continuous-learning/config.json +18 -0
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  124. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  132. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  133. package/prisma/skills/council/SKILL.md +204 -0
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  135. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  136. package/prisma/skills/crosspost/SKILL.md +112 -0
  137. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  138. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  141. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  142. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  144. package/prisma/skills/database-migrations/SKILL.md +430 -0
  145. package/prisma/skills/deep-research/SKILL.md +160 -0
  146. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  147. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  149. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  150. package/prisma/skills/design-system/SKILL.md +83 -0
  151. package/prisma/skills/django-celery/SKILL.md +458 -0
  152. package/prisma/skills/django-patterns/SKILL.md +735 -0
  153. package/prisma/skills/django-security/SKILL.md +644 -0
  154. package/prisma/skills/django-tdd/SKILL.md +730 -0
  155. package/prisma/skills/django-verification/SKILL.md +470 -0
  156. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  157. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  158. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  159. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  161. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  162. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  163. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  165. package/prisma/skills/email-ops/SKILL.md +122 -0
  166. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  168. package/prisma/skills/error-handling/SKILL.md +377 -0
  169. package/prisma/skills/eval-harness/SKILL.md +271 -0
  170. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  171. package/prisma/skills/exa-search/SKILL.md +108 -0
  172. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  173. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  174. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  175. package/prisma/skills/flox-environments/SKILL.md +497 -0
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  178. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  179. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  180. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  181. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  183. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  184. package/prisma/skills/frontend-slides/html-template.md +419 -0
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  187. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  188. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  189. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  190. package/prisma/skills/gateguard/SKILL.md +133 -0
  191. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  192. package/prisma/skills/git-workflow/SKILL.md +716 -0
  193. package/prisma/skills/github-ops/SKILL.md +145 -0
  194. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  195. package/prisma/skills/golang-testing/SKILL.md +721 -0
  196. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  197. package/prisma/skills/growth-log/SKILL.md +128 -0
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  202. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  204. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  206. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  210. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  212. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  214. package/prisma/skills/investor-materials/SKILL.md +97 -0
  215. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  216. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  219. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  220. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  223. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  224. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  225. package/prisma/skills/jira-integration/SKILL.md +303 -0
  226. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  227. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  231. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  232. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  234. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  236. package/prisma/skills/laravel-security/SKILL.md +948 -0
  237. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  238. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  239. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  240. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  245. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  247. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  248. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  251. package/prisma/skills/manim-video/SKILL.md +90 -0
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  253. package/prisma/skills/market-research/SKILL.md +76 -0
  254. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  256. package/prisma/skills/messages-ops/SKILL.md +105 -0
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  258. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  259. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  260. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  261. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  262. package/prisma/skills/motion-ui/SKILL.md +576 -0
  263. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  265. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  268. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  269. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  283. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  284. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  285. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  286. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  287. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  288. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  289. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  291. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  292. package/prisma/skills/perl-security/SKILL.md +504 -0
  293. package/prisma/skills/perl-testing/SKILL.md +476 -0
  294. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  295. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  296. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  299. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  300. package/prisma/skills/product-capability/SKILL.md +142 -0
  301. package/prisma/skills/product-lens/SKILL.md +93 -0
  302. package/prisma/skills/production-audit/SKILL.md +207 -0
  303. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  304. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  305. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  306. package/prisma/skills/python-patterns/SKILL.md +751 -0
  307. package/prisma/skills/python-testing/SKILL.md +817 -0
  308. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  309. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  310. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  311. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  312. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  313. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  315. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  316. package/prisma/skills/react-patterns/SKILL.md +342 -0
  317. package/prisma/skills/react-performance/SKILL.md +575 -0
  318. package/prisma/skills/react-testing/SKILL.md +424 -0
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  321. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  323. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  342. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  355. package/prisma/skills/repo-scan/SKILL.md +79 -0
  356. package/prisma/skills/research-ops/SKILL.md +113 -0
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  358. package/prisma/skills/rules-distill/SKILL.md +265 -0
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  361. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  362. package/prisma/skills/rust-testing/SKILL.md +501 -0
  363. package/prisma/skills/safety-guard/SKILL.md +76 -0
  364. package/prisma/skills/santa-method/SKILL.md +307 -0
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  370. package/prisma/skills/search-first/SKILL.md +183 -0
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  372. package/prisma/skills/security-review/SKILL.md +504 -0
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  374. package/prisma/skills/security-scan/SKILL.md +166 -0
  375. package/prisma/skills/seo/SKILL.md +155 -0
  376. package/prisma/skills/skill-comply/SKILL.md +59 -0
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  380. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  383. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  386. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  387. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  388. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  389. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  390. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  393. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  394. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  395. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  396. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  397. package/prisma/skills/skill-scout/SKILL.md +141 -0
  398. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  402. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  403. package/prisma/skills/social-publisher/SKILL.md +130 -0
  404. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  405. package/prisma/skills/springboot-security/SKILL.md +273 -0
  406. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  407. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  408. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  412. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  413. package/prisma/skills/taste/SKILL.md +264 -0
  414. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  415. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  417. package/prisma/skills/team-builder/SKILL.md +169 -0
  418. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  422. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  426. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  427. package/prisma/skills/ui-demo/SKILL.md +466 -0
  428. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  429. package/prisma/skills/uncloud/SKILL.md +344 -0
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  431. package/prisma/skills/verification-loop/SKILL.md +127 -0
  432. package/prisma/skills/video-editing/SKILL.md +311 -0
  433. package/prisma/skills/videodb/SKILL.md +375 -0
  434. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  435. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  436. package/prisma/skills/videodb/reference/capture.md +101 -0
  437. package/prisma/skills/videodb/reference/editor.md +443 -0
  438. package/prisma/skills/videodb/reference/generative.md +331 -0
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  440. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  441. package/prisma/skills/videodb/reference/search.md +230 -0
  442. package/prisma/skills/videodb/reference/streaming.md +406 -0
  443. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  444. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  445. package/prisma/skills/visa-doc-translate/README.md +86 -0
  446. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  447. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  448. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  451. package/prisma/skills/x-api/SKILL.md +235 -0
@@ -0,0 +1,159 @@
1
+ ---
2
+ name: springboot-tdd
3
+ description: Test-driven development for Spring Boot using JUnit 5, Mockito, MockMvc, Testcontainers, and JaCoCo. Use when adding features, fixing bugs, or refactoring.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Spring Boot TDD Workflow
9
+
10
+ TDD guidance for Spring Boot services with 80%+ coverage (unit + integration).
11
+
12
+ ## When to Use
13
+
14
+ - New features or endpoints
15
+ - Bug fixes or refactors
16
+ - Adding data access logic or security rules
17
+
18
+ ## Workflow
19
+
20
+ 1) Write tests first (they should fail)
21
+ 2) Implement minimal code to pass
22
+ 3) Refactor with tests green
23
+ 4) Enforce coverage (JaCoCo)
24
+
25
+ ## Unit Tests (JUnit 5 + Mockito)
26
+
27
+ ```java
28
+ @ExtendWith(MockitoExtension.class)
29
+ class MarketServiceTest {
30
+ @Mock MarketRepository repo;
31
+ @InjectMocks MarketService service;
32
+
33
+ @Test
34
+ void createsMarket() {
35
+ CreateMarketRequest req = new CreateMarketRequest("name", "desc", Instant.now(), List.of("cat"));
36
+ when(repo.save(any())).thenAnswer(inv -> inv.getArgument(0));
37
+
38
+ Market result = service.create(req);
39
+
40
+ assertThat(result.name()).isEqualTo("name");
41
+ verify(repo).save(any());
42
+ }
43
+ }
44
+ ```
45
+
46
+ Patterns:
47
+ - Arrange-Act-Assert
48
+ - Avoid partial mocks; prefer explicit stubbing
49
+ - Use `@ParameterizedTest` for variants
50
+
51
+ ## Web Layer Tests (MockMvc)
52
+
53
+ ```java
54
+ @WebMvcTest(MarketController.class)
55
+ class MarketControllerTest {
56
+ @Autowired MockMvc mockMvc;
57
+ @MockBean MarketService marketService;
58
+
59
+ @Test
60
+ void returnsMarkets() throws Exception {
61
+ when(marketService.list(any())).thenReturn(Page.empty());
62
+
63
+ mockMvc.perform(get("/api/markets"))
64
+ .andExpect(status().isOk())
65
+ .andExpect(jsonPath("$.content").isArray());
66
+ }
67
+ }
68
+ ```
69
+
70
+ ## Integration Tests (SpringBootTest)
71
+
72
+ ```java
73
+ @SpringBootTest
74
+ @AutoConfigureMockMvc
75
+ @ActiveProfiles("test")
76
+ class MarketIntegrationTest {
77
+ @Autowired MockMvc mockMvc;
78
+
79
+ @Test
80
+ void createsMarket() throws Exception {
81
+ mockMvc.perform(post("/api/markets")
82
+ .contentType(MediaType.APPLICATION_JSON)
83
+ .content("""
84
+ {"name":"Test","description":"Desc","endDate":"2030-01-01T00:00:00Z","categories":["general"]}
85
+ """))
86
+ .andExpect(status().isCreated());
87
+ }
88
+ }
89
+ ```
90
+
91
+ ## Persistence Tests (DataJpaTest)
92
+
93
+ ```java
94
+ @DataJpaTest
95
+ @AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)
96
+ @Import(TestContainersConfig.class)
97
+ class MarketRepositoryTest {
98
+ @Autowired MarketRepository repo;
99
+
100
+ @Test
101
+ void savesAndFinds() {
102
+ MarketEntity entity = new MarketEntity();
103
+ entity.setName("Test");
104
+ repo.save(entity);
105
+
106
+ Optional<MarketEntity> found = repo.findByName("Test");
107
+ assertThat(found).isPresent();
108
+ }
109
+ }
110
+ ```
111
+
112
+ ## Testcontainers
113
+
114
+ - Use reusable containers for Postgres/Redis to mirror production
115
+ - Wire via `@DynamicPropertySource` to inject JDBC URLs into Spring context
116
+
117
+ ## Coverage (JaCoCo)
118
+
119
+ Maven snippet:
120
+ ```xml
121
+ <plugin>
122
+ <groupId>org.jacoco</groupId>
123
+ <artifactId>jacoco-maven-plugin</artifactId>
124
+ <version>0.8.14</version>
125
+ <executions>
126
+ <execution>
127
+ <goals><goal>prepare-agent</goal></goals>
128
+ </execution>
129
+ <execution>
130
+ <id>report</id>
131
+ <phase>verify</phase>
132
+ <goals><goal>report</goal></goals>
133
+ </execution>
134
+ </executions>
135
+ </plugin>
136
+ ```
137
+
138
+ ## Assertions
139
+
140
+ - Prefer AssertJ (`assertThat`) for readability
141
+ - For JSON responses, use `jsonPath`
142
+ - For exceptions: `assertThatThrownBy(...)`
143
+
144
+ ## Test Data Builders
145
+
146
+ ```java
147
+ class MarketBuilder {
148
+ private String name = "Test";
149
+ MarketBuilder withName(String name) { this.name = name; return this; }
150
+ Market build() { return new Market(null, name, MarketStatus.ACTIVE); }
151
+ }
152
+ ```
153
+
154
+ ## CI Commands
155
+
156
+ - Maven: `mvn -T 4 test` or `mvn verify`
157
+ - Gradle: `./gradlew test jacocoTestReport`
158
+
159
+ **Remember**: Keep tests fast, isolated, and deterministic. Test behavior, not implementation details.
@@ -0,0 +1,232 @@
1
+ ---
2
+ name: springboot-verification
3
+ description: "Verification loop for Spring Boot projects: build, static analysis, tests with coverage, security scans, and diff review before release or PR."
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Spring Boot Verification Loop
9
+
10
+ Run before PRs, after major changes, and pre-deploy.
11
+
12
+ ## When to Activate
13
+
14
+ - Before opening a pull request for a Spring Boot service
15
+ - After major refactoring or dependency upgrades
16
+ - Pre-deployment verification for staging or production
17
+ - Running full build → lint → test → security scan pipeline
18
+ - Validating test coverage meets thresholds
19
+
20
+ ## Phase 1: Build
21
+
22
+ ```bash
23
+ mvn -T 4 clean verify -DskipTests
24
+ # or
25
+ ./gradlew clean assemble -x test
26
+ ```
27
+
28
+ If build fails, stop and fix.
29
+
30
+ ## Phase 2: Static Analysis
31
+
32
+ Maven (common plugins):
33
+ ```bash
34
+ mvn -T 4 spotbugs:check pmd:check checkstyle:check
35
+ ```
36
+
37
+ Gradle (if configured):
38
+ ```bash
39
+ ./gradlew checkstyleMain pmdMain spotbugsMain
40
+ ```
41
+
42
+ ## Phase 3: Tests + Coverage
43
+
44
+ ```bash
45
+ mvn -T 4 test
46
+ mvn jacoco:report # verify 80%+ coverage
47
+ # or
48
+ ./gradlew test jacocoTestReport
49
+ ```
50
+
51
+ Report:
52
+ - Total tests, passed/failed
53
+ - Coverage % (lines/branches)
54
+
55
+ ### Unit Tests
56
+
57
+ Test service logic in isolation with mocked dependencies:
58
+
59
+ ```java
60
+ @ExtendWith(MockitoExtension.class)
61
+ class UserServiceTest {
62
+
63
+ @Mock private UserRepository userRepository;
64
+ @InjectMocks private UserService userService;
65
+
66
+ @Test
67
+ void createUser_validInput_returnsUser() {
68
+ var dto = new CreateUserDto("Alice", "alice@example.com");
69
+ var expected = new User(1L, "Alice", "alice@example.com");
70
+ when(userRepository.save(any(User.class))).thenReturn(expected);
71
+
72
+ var result = userService.create(dto);
73
+
74
+ assertThat(result.name()).isEqualTo("Alice");
75
+ verify(userRepository).save(any(User.class));
76
+ }
77
+
78
+ @Test
79
+ void createUser_duplicateEmail_throwsException() {
80
+ var dto = new CreateUserDto("Alice", "existing@example.com");
81
+ when(userRepository.existsByEmail(dto.email())).thenReturn(true);
82
+
83
+ assertThatThrownBy(() -> userService.create(dto))
84
+ .isInstanceOf(DuplicateEmailException.class);
85
+ }
86
+ }
87
+ ```
88
+
89
+ ### Integration Tests with Testcontainers
90
+
91
+ Test against a real database instead of H2:
92
+
93
+ ```java
94
+ @SpringBootTest
95
+ @Testcontainers
96
+ class UserRepositoryIntegrationTest {
97
+
98
+ @Container
99
+ static PostgreSQLContainer<?> postgres = new PostgreSQLContainer<>("postgres:16-alpine")
100
+ .withDatabaseName("testdb");
101
+
102
+ @DynamicPropertySource
103
+ static void configureProperties(DynamicPropertyRegistry registry) {
104
+ registry.add("spring.datasource.url", postgres::getJdbcUrl);
105
+ registry.add("spring.datasource.username", postgres::getUsername);
106
+ registry.add("spring.datasource.password", postgres::getPassword);
107
+ }
108
+
109
+ @Autowired private UserRepository userRepository;
110
+
111
+ @Test
112
+ void findByEmail_existingUser_returnsUser() {
113
+ userRepository.save(new User("Alice", "alice@example.com"));
114
+
115
+ var found = userRepository.findByEmail("alice@example.com");
116
+
117
+ assertThat(found).isPresent();
118
+ assertThat(found.get().getName()).isEqualTo("Alice");
119
+ }
120
+ }
121
+ ```
122
+
123
+ ### API Tests with MockMvc
124
+
125
+ Test controller layer with full Spring context:
126
+
127
+ ```java
128
+ @WebMvcTest(UserController.class)
129
+ class UserControllerTest {
130
+
131
+ @Autowired private MockMvc mockMvc;
132
+ @MockBean private UserService userService;
133
+
134
+ @Test
135
+ void createUser_validInput_returns201() throws Exception {
136
+ var user = new UserDto(1L, "Alice", "alice@example.com");
137
+ when(userService.create(any())).thenReturn(user);
138
+
139
+ mockMvc.perform(post("/api/users")
140
+ .contentType(MediaType.APPLICATION_JSON)
141
+ .content("""
142
+ {"name": "Alice", "email": "alice@example.com"}
143
+ """))
144
+ .andExpect(status().isCreated())
145
+ .andExpect(jsonPath("$.name").value("Alice"));
146
+ }
147
+
148
+ @Test
149
+ void createUser_invalidEmail_returns400() throws Exception {
150
+ mockMvc.perform(post("/api/users")
151
+ .contentType(MediaType.APPLICATION_JSON)
152
+ .content("""
153
+ {"name": "Alice", "email": "not-an-email"}
154
+ """))
155
+ .andExpect(status().isBadRequest());
156
+ }
157
+ }
158
+ ```
159
+
160
+ ## Phase 4: Security Scan
161
+
162
+ ```bash
163
+ # Dependency CVEs
164
+ mvn org.owasp:dependency-check-maven:check
165
+ # or
166
+ ./gradlew dependencyCheckAnalyze
167
+
168
+ # Secrets in source
169
+ grep -rn "password\s*=\s*\"" src/ --include="*.java" --include="*.yml" --include="*.properties"
170
+ grep -rn "sk-\|api_key\|secret" src/ --include="*.java" --include="*.yml"
171
+
172
+ # Secrets (git history)
173
+ git secrets --scan # if configured
174
+ ```
175
+
176
+ ### Common Security Findings
177
+
178
+ ```
179
+ # Check for System.out.println (use logger instead)
180
+ grep -rn "System\.out\.print" src/main/ --include="*.java"
181
+
182
+ # Check for raw exception messages in responses
183
+ grep -rn "e\.getMessage()" src/main/ --include="*.java"
184
+
185
+ # Check for wildcard CORS
186
+ grep -rn "allowedOrigins.*\*" src/main/ --include="*.java"
187
+ ```
188
+
189
+ ## Phase 5: Lint/Format (optional gate)
190
+
191
+ ```bash
192
+ mvn spotless:apply # if using Spotless plugin
193
+ ./gradlew spotlessApply
194
+ ```
195
+
196
+ ## Phase 6: Diff Review
197
+
198
+ ```bash
199
+ git diff --stat
200
+ git diff
201
+ ```
202
+
203
+ Checklist:
204
+ - No debugging logs left (`System.out`, `log.debug` without guards)
205
+ - Meaningful errors and HTTP statuses
206
+ - Transactions and validation present where needed
207
+ - Config changes documented
208
+
209
+ ## Output Template
210
+
211
+ ```
212
+ VERIFICATION REPORT
213
+ ===================
214
+ Build: [PASS/FAIL]
215
+ Static: [PASS/FAIL] (spotbugs/pmd/checkstyle)
216
+ Tests: [PASS/FAIL] (X/Y passed, Z% coverage)
217
+ Security: [PASS/FAIL] (CVE findings: N)
218
+ Diff: [X files changed]
219
+
220
+ Overall: [READY / NOT READY]
221
+
222
+ Issues to Fix:
223
+ 1. ...
224
+ 2. ...
225
+ ```
226
+
227
+ ## Continuous Mode
228
+
229
+ - Re-run phases on significant changes or every 30–60 minutes in long sessions
230
+ - Keep a short loop: `mvn -T 4 test` + spotbugs for quick feedback
231
+
232
+ **Remember**: Fast feedback beats late surprises. Keep the gate strict—treat warnings as defects in production systems.
@@ -0,0 +1,136 @@
1
+ ---
2
+ name: strategic-compact
3
+ description: Suggests manual context compaction at logical intervals to preserve context through task phases rather than arbitrary auto-compaction.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Strategic Compact Skill
9
+
10
+ Suggests manual `/compact` at strategic points in your workflow rather than relying on arbitrary auto-compaction.
11
+
12
+ ## When to Activate
13
+
14
+ - Running long sessions that approach context limits (200K+ tokens)
15
+ - Working on multi-phase tasks (research → plan → implement → test)
16
+ - Switching between unrelated tasks within the same session
17
+ - After completing a major milestone and starting new work
18
+ - When responses slow down or become less coherent (context pressure)
19
+
20
+ ## Why Strategic Compaction?
21
+
22
+ Auto-compaction triggers at arbitrary points:
23
+ - Often mid-task, losing important context
24
+ - No awareness of logical task boundaries
25
+ - Can interrupt complex multi-step operations
26
+
27
+ Strategic compaction at logical boundaries:
28
+ - **After exploration, before execution** — Compact research context, keep implementation plan
29
+ - **After completing a milestone** — Fresh start for next phase
30
+ - **Before major context shifts** — Clear exploration context before different task
31
+
32
+ ## How It Works
33
+
34
+ The `suggest-compact.js` script runs on PreToolUse (Edit/Write) and combines two signals:
35
+
36
+ 1. **Context size (primary)** — Reads the latest `usage` record from the session transcript (`transcript_path` in the hook payload) and sums `input_tokens + cache_read_input_tokens + cache_creation_input_tokens` (the true context size of the turn). Suggests `/compact` at a window-scaled threshold — 160k tokens on a 200k window, 250k on a 1M window (detected from a `[1m]` model marker, or inferred when observed tokens already exceed 200k) — and re-reminds after every additional 60k tokens of context growth
37
+ 2. **Tool-call count (secondary)** — Counts tool invocations in session; suggests at a configurable threshold (default: 50 calls), then every 25 calls after
38
+
39
+ Tool count alone is a weak proxy for window pressure: a few large file reads or MCP responses can fill the window in very few calls, while many tiny calls can cross 50 with a near-empty window. The context-size signal fires when it actually matters.
40
+
41
+ ## Hook Setup
42
+
43
+ Add to your `~/.claude/settings.json`:
44
+
45
+ ```json
46
+ {
47
+ "hooks": {
48
+ "PreToolUse": [
49
+ {
50
+ "matcher": "Edit",
51
+ "hooks": [{ "type": "command", "command": "node ~/.claude/scripts/hooks/suggest-compact.js" }]
52
+ },
53
+ {
54
+ "matcher": "Write",
55
+ "hooks": [{ "type": "command", "command": "node ~/.claude/scripts/hooks/suggest-compact.js" }]
56
+ }
57
+ ]
58
+ }
59
+ }
60
+ ```
61
+
62
+ ## Configuration
63
+
64
+ Environment variables:
65
+ - `COMPACT_THRESHOLD` — Tool calls before first suggestion (default: 50)
66
+ - `COMPACT_CONTEXT_THRESHOLD` — Context tokens before the context-size suggestion (default: 160000 on a 200k window, 250000 on a 1M window; `0` disables the context signal)
67
+ - `COMPACT_CONTEXT_INTERVAL` — Additional context tokens before the suggestion repeats (default: 60000)
68
+ - `COMPACT_STATE_TTL_DAYS` — Days before stale per-session state files in the temp dir are swept (default: 14)
69
+
70
+ ## Compaction Decision Guide
71
+
72
+ Use this table to decide when to compact:
73
+
74
+ | Phase Transition | Compact? | Why |
75
+ |-----------------|----------|-----|
76
+ | Research → Planning | Yes | Research context is bulky; plan is the distilled output |
77
+ | Planning → Implementation | Yes | Plan is in TodoWrite or a file; free up context for code |
78
+ | Implementation → Testing | Maybe | Keep if tests reference recent code; compact if switching focus |
79
+ | Debugging → Next feature | Yes | Debug traces pollute context for unrelated work |
80
+ | Mid-implementation | No | Losing variable names, file paths, and partial state is costly |
81
+ | After a failed approach | Yes | Clear the dead-end reasoning before trying a new approach |
82
+
83
+ ## What Survives Compaction
84
+
85
+ Understanding what persists helps you compact with confidence:
86
+
87
+ | Persists | Lost |
88
+ |----------|------|
89
+ | CLAUDE.md instructions | Intermediate reasoning and analysis |
90
+ | TodoWrite task list | File contents you previously read |
91
+ | Memory files (`~/.claude/memory/`) | Multi-step conversation context |
92
+ | Git state (commits, branches) | Tool call history and counts |
93
+ | Files on disk | Nuanced user preferences stated verbally |
94
+
95
+ ## Best Practices
96
+
97
+ 1. **Compact after planning** — Once plan is finalized in TodoWrite, compact to start fresh
98
+ 2. **Compact after debugging** — Clear error-resolution context before continuing
99
+ 3. **Don't compact mid-implementation** — Preserve context for related changes
100
+ 4. **Read the suggestion** — The hook tells you *when*, you decide *if*
101
+ 5. **Write before compacting** — Save important context to files or memory before compacting
102
+ 6. **Use `/compact` with a summary** — Add a custom message: `/compact Focus on implementing auth middleware next`
103
+
104
+ ## Token Optimization Patterns
105
+
106
+ ### Trigger-Table Lazy Loading
107
+ Instead of loading full skill content at session start, use a trigger table that maps keywords to skill paths. Skills load only when triggered, reducing baseline context by 50%+:
108
+
109
+ | Trigger | Skill | Load When |
110
+ |---------|-------|-----------|
111
+ | "test", "tdd", "coverage" | tdd-workflow | User mentions testing |
112
+ | "security", "auth", "xss" | security-review | Security-related work |
113
+ | "deploy", "ci/cd" | deployment-patterns | Deployment context |
114
+
115
+ ### Context Composition Awareness
116
+ Monitor what's consuming your context window:
117
+ - **CLAUDE.md files** — Always loaded, keep lean
118
+ - **Loaded skills** — Each skill adds 1-5K tokens
119
+ - **Conversation history** — Grows with each exchange
120
+ - **Tool results** — File reads, search results add bulk
121
+
122
+ ### Duplicate Instruction Detection
123
+ Common sources of duplicate context:
124
+ - Same rules in both `~/.claude/rules/` and project `.claude/rules/`
125
+ - Skills that repeat CLAUDE.md instructions
126
+ - Multiple skills covering overlapping domains
127
+
128
+ ### Context Optimization Tools
129
+ - `token-optimizer` MCP — Automated 95%+ token reduction via content deduplication
130
+ - `context-mode` — Context virtualization (315KB to 5.4KB demonstrated)
131
+
132
+ ## Related
133
+
134
+ - [The Longform Guide](https://x.com/affaanmustafa/status/2014040193557471352) — Token optimization section
135
+ - Memory persistence hooks — For state that survives compaction
136
+ - `continuous-learning` skill — Extracts patterns before session ends
@@ -0,0 +1,144 @@
1
+ ---
2
+ name: swift-actor-persistence
3
+ description: Thread-safe data persistence in Swift using actors — in-memory cache with file-backed storage, eliminating data races by design.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Swift Actors for Thread-Safe Persistence
9
+
10
+ Patterns for building thread-safe data persistence layers using Swift actors. Combines in-memory caching with file-backed storage, leveraging the actor model to eliminate data races at compile time.
11
+
12
+ ## When to Activate
13
+
14
+ - Building a data persistence layer in Swift 5.5+
15
+ - Need thread-safe access to shared mutable state
16
+ - Want to eliminate manual synchronization (locks, DispatchQueues)
17
+ - Building offline-first apps with local storage
18
+
19
+ ## Core Pattern
20
+
21
+ ### Actor-Based Repository
22
+
23
+ The actor model guarantees serialized access — no data races, enforced by the compiler.
24
+
25
+ ```swift
26
+ public actor LocalRepository<T: Codable & Identifiable> where T.ID == String {
27
+ private var cache: [String: T] = [:]
28
+ private let fileURL: URL
29
+
30
+ public init(directory: URL = .documentsDirectory, filename: String = "data.json") {
31
+ self.fileURL = directory.appendingPathComponent(filename)
32
+ // Synchronous load during init (actor isolation not yet active)
33
+ self.cache = Self.loadSynchronously(from: fileURL)
34
+ }
35
+
36
+ // MARK: - Public API
37
+
38
+ public func save(_ item: T) throws {
39
+ cache[item.id] = item
40
+ try persistToFile()
41
+ }
42
+
43
+ public func delete(_ id: String) throws {
44
+ cache[id] = nil
45
+ try persistToFile()
46
+ }
47
+
48
+ public func find(by id: String) -> T? {
49
+ cache[id]
50
+ }
51
+
52
+ public func loadAll() -> [T] {
53
+ Array(cache.values)
54
+ }
55
+
56
+ // MARK: - Private
57
+
58
+ private func persistToFile() throws {
59
+ let data = try JSONEncoder().encode(Array(cache.values))
60
+ try data.write(to: fileURL, options: .atomic)
61
+ }
62
+
63
+ private static func loadSynchronously(from url: URL) -> [String: T] {
64
+ guard let data = try? Data(contentsOf: url),
65
+ let items = try? JSONDecoder().decode([T].self, from: data) else {
66
+ return [:]
67
+ }
68
+ return Dictionary(uniqueKeysWithValues: items.map { ($0.id, $0) })
69
+ }
70
+ }
71
+ ```
72
+
73
+ ### Usage
74
+
75
+ All calls are automatically async due to actor isolation:
76
+
77
+ ```swift
78
+ let repository = LocalRepository<Question>()
79
+
80
+ // Read — fast O(1) lookup from in-memory cache
81
+ let question = await repository.find(by: "q-001")
82
+ let allQuestions = await repository.loadAll()
83
+
84
+ // Write — updates cache and persists to file atomically
85
+ try await repository.save(newQuestion)
86
+ try await repository.delete("q-001")
87
+ ```
88
+
89
+ ### Combining with @Observable ViewModel
90
+
91
+ ```swift
92
+ @Observable
93
+ final class QuestionListViewModel {
94
+ private(set) var questions: [Question] = []
95
+ private let repository: LocalRepository<Question>
96
+
97
+ init(repository: LocalRepository<Question> = LocalRepository()) {
98
+ self.repository = repository
99
+ }
100
+
101
+ func load() async {
102
+ questions = await repository.loadAll()
103
+ }
104
+
105
+ func add(_ question: Question) async throws {
106
+ try await repository.save(question)
107
+ questions = await repository.loadAll()
108
+ }
109
+ }
110
+ ```
111
+
112
+ ## Key Design Decisions
113
+
114
+ | Decision | Rationale |
115
+ |----------|-----------|
116
+ | Actor (not class + lock) | Compiler-enforced thread safety, no manual synchronization |
117
+ | In-memory cache + file persistence | Fast reads from cache, durable writes to disk |
118
+ | Synchronous init loading | Avoids async initialization complexity |
119
+ | Dictionary keyed by ID | O(1) lookups by identifier |
120
+ | Generic over `Codable & Identifiable` | Reusable across any model type |
121
+ | Atomic file writes (`.atomic`) | Prevents partial writes on crash |
122
+
123
+ ## Best Practices
124
+
125
+ - **Use `Sendable` types** for all data crossing actor boundaries
126
+ - **Keep the actor's public API minimal** — only expose domain operations, not persistence details
127
+ - **Use `.atomic` writes** to prevent data corruption if the app crashes mid-write
128
+ - **Load synchronously in `init`** — async initializers add complexity with minimal benefit for local files
129
+ - **Combine with `@Observable`** ViewModels for reactive UI updates
130
+
131
+ ## Anti-Patterns to Avoid
132
+
133
+ - Using `DispatchQueue` or `NSLock` instead of actors for new Swift concurrency code
134
+ - Exposing the internal cache dictionary to external callers
135
+ - Making the file URL configurable without validation
136
+ - Forgetting that all actor method calls are `await` — callers must handle async context
137
+ - Using `nonisolated` to bypass actor isolation (defeats the purpose)
138
+
139
+ ## When to Use
140
+
141
+ - Local data storage in iOS/macOS apps (user data, settings, cached content)
142
+ - Offline-first architectures that sync to a server later
143
+ - Any shared mutable state that multiple parts of the app access concurrently
144
+ - Replacing legacy `DispatchQueue`-based thread safety with modern Swift concurrency