@rubix0270/arboris 1.0.2 → 1.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/package.json +25 -37
  2. package/run.mjs +10 -0
  3. package/dist/cli.mjs +0 -383
  4. package/manifest.json +0 -323
  5. package/prisma/skills/accessibility/SKILL.md +0 -147
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +0 -257
  7. package/prisma/skills/agent-eval/SKILL.md +0 -146
  8. package/prisma/skills/agent-harness-construction/SKILL.md +0 -74
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +0 -154
  10. package/prisma/skills/agent-payment-x402/SKILL.md +0 -225
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +0 -182
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +0 -87
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +0 -86
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +0 -71
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +0 -64
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +0 -408
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +0 -86
  18. package/prisma/skills/agent-sort/SKILL.md +0 -216
  19. package/prisma/skills/agentic-engineering/SKILL.md +0 -64
  20. package/prisma/skills/agentic-os/SKILL.md +0 -388
  21. package/prisma/skills/ai-first-engineering/SKILL.md +0 -52
  22. package/prisma/skills/ai-regression-testing/SKILL.md +0 -386
  23. package/prisma/skills/android-clean-architecture/SKILL.md +0 -340
  24. package/prisma/skills/angular-developer/SKILL.md +0 -155
  25. package/prisma/skills/angular-developer/references/angular-animations.md +0 -160
  26. package/prisma/skills/angular-developer/references/angular-aria.md +0 -410
  27. package/prisma/skills/angular-developer/references/cli.md +0 -86
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +0 -59
  29. package/prisma/skills/angular-developer/references/component-styling.md +0 -91
  30. package/prisma/skills/angular-developer/references/components.md +0 -117
  31. package/prisma/skills/angular-developer/references/creating-services.md +0 -97
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +0 -69
  33. package/prisma/skills/angular-developer/references/define-routes.md +0 -67
  34. package/prisma/skills/angular-developer/references/defining-providers.md +0 -72
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +0 -120
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +0 -56
  37. package/prisma/skills/angular-developer/references/effects.md +0 -83
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +0 -43
  39. package/prisma/skills/angular-developer/references/host-elements.md +0 -80
  40. package/prisma/skills/angular-developer/references/injection-context.md +0 -63
  41. package/prisma/skills/angular-developer/references/inputs.md +0 -101
  42. package/prisma/skills/angular-developer/references/linked-signal.md +0 -59
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +0 -61
  44. package/prisma/skills/angular-developer/references/mcp.md +0 -108
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +0 -69
  46. package/prisma/skills/angular-developer/references/outputs.md +0 -86
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +0 -122
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +0 -44
  49. package/prisma/skills/angular-developer/references/resource.md +0 -77
  50. package/prisma/skills/angular-developer/references/route-animations.md +0 -56
  51. package/prisma/skills/angular-developer/references/route-guards.md +0 -52
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +0 -45
  53. package/prisma/skills/angular-developer/references/router-testing.md +0 -87
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +0 -68
  55. package/prisma/skills/angular-developer/references/signal-forms.md +0 -795
  56. package/prisma/skills/angular-developer/references/signals-overview.md +0 -94
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +0 -69
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +0 -114
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +0 -65
  60. package/prisma/skills/api-connector-builder/SKILL.md +0 -121
  61. package/prisma/skills/api-design/SKILL.md +0 -524
  62. package/prisma/skills/architecture-decision-records/SKILL.md +0 -180
  63. package/prisma/skills/article-writing/SKILL.md +0 -80
  64. package/prisma/skills/automation-audit-ops/SKILL.md +0 -143
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +0 -274
  66. package/prisma/skills/autonomous-loops/SKILL.md +0 -611
  67. package/prisma/skills/backend-patterns/SKILL.md +0 -562
  68. package/prisma/skills/benchmark/SKILL.md +0 -94
  69. package/prisma/skills/benchmark-methodology/SKILL.md +0 -190
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +0 -70
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +0 -165
  72. package/prisma/skills/blueprint/SKILL.md +0 -106
  73. package/prisma/skills/brand-discovery/SKILL.md +0 -145
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +0 -40
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +0 -44
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +0 -52
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +0 -57
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +0 -59
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +0 -50
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +0 -49
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +0 -133
  82. package/prisma/skills/brand-voice/SKILL.md +0 -98
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +0 -55
  84. package/prisma/skills/browser-qa/SKILL.md +0 -105
  85. package/prisma/skills/bun-runtime/SKILL.md +0 -85
  86. package/prisma/skills/canary-watch/SKILL.md +0 -108
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +0 -212
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +0 -164
  89. package/prisma/skills/ck/SKILL.md +0 -148
  90. package/prisma/skills/ck/commands/forget.mjs +0 -44
  91. package/prisma/skills/ck/commands/info.mjs +0 -24
  92. package/prisma/skills/ck/commands/init.mjs +0 -143
  93. package/prisma/skills/ck/commands/list.mjs +0 -40
  94. package/prisma/skills/ck/commands/migrate.mjs +0 -202
  95. package/prisma/skills/ck/commands/resume.mjs +0 -36
  96. package/prisma/skills/ck/commands/save.mjs +0 -210
  97. package/prisma/skills/ck/commands/shared.mjs +0 -387
  98. package/prisma/skills/ck/hooks/session-start.mjs +0 -224
  99. package/prisma/skills/claude-devfleet/SKILL.md +0 -112
  100. package/prisma/skills/click-path-audit/SKILL.md +0 -245
  101. package/prisma/skills/clickhouse-io/SKILL.md +0 -440
  102. package/prisma/skills/code-tour/SKILL.md +0 -254
  103. package/prisma/skills/codebase-onboarding/SKILL.md +0 -234
  104. package/prisma/skills/codehealth-mcp/SKILL.md +0 -167
  105. package/prisma/skills/coding-standards/SKILL.md +0 -551
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +0 -214
  107. package/prisma/skills/competitive-report-structure/SKILL.md +0 -162
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +0 -300
  109. package/prisma/skills/config-gc/SKILL.md +0 -120
  110. package/prisma/skills/configure-ecc/SKILL.md +0 -385
  111. package/prisma/skills/connections-optimizer/SKILL.md +0 -190
  112. package/prisma/skills/content-engine/SKILL.md +0 -132
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +0 -162
  114. package/prisma/skills/context-budget/SKILL.md +0 -136
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +0 -46
  116. package/prisma/skills/continuous-learning/SKILL.md +0 -132
  117. package/prisma/skills/continuous-learning/config.json +0 -18
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +0 -69
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +0 -361
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +0 -359
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +0 -189
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +0 -150
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +0 -248
  124. package/prisma/skills/continuous-learning-v2/config.json +0 -8
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +0 -585
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +0 -322
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -1956
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +0 -31
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +0 -68
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -1421
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +0 -184
  132. package/prisma/skills/cost-tracking/SKILL.md +0 -97
  133. package/prisma/skills/council/SKILL.md +0 -204
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +0 -724
  135. package/prisma/skills/cpp-testing/SKILL.md +0 -325
  136. package/prisma/skills/crosspost/SKILL.md +0 -112
  137. package/prisma/skills/csharp-testing/SKILL.md +0 -322
  138. package/prisma/skills/customer-billing-ops/SKILL.md +0 -141
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +0 -263
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +0 -564
  141. package/prisma/skills/dashboard-builder/SKILL.md +0 -109
  142. package/prisma/skills/data-scraper-agent/SKILL.md +0 -765
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +0 -73
  144. package/prisma/skills/database-migrations/SKILL.md +0 -430
  145. package/prisma/skills/deep-research/SKILL.md +0 -160
  146. package/prisma/skills/defi-amm-security/SKILL.md +0 -167
  147. package/prisma/skills/delivery-gate/SKILL.md +0 -126
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +0 -220
  149. package/prisma/skills/deployment-patterns/SKILL.md +0 -428
  150. package/prisma/skills/design-system/SKILL.md +0 -83
  151. package/prisma/skills/django-celery/SKILL.md +0 -458
  152. package/prisma/skills/django-patterns/SKILL.md +0 -735
  153. package/prisma/skills/django-security/SKILL.md +0 -644
  154. package/prisma/skills/django-tdd/SKILL.md +0 -730
  155. package/prisma/skills/django-verification/SKILL.md +0 -470
  156. package/prisma/skills/dmux-workflows/SKILL.md +0 -192
  157. package/prisma/skills/docker-patterns/SKILL.md +0 -365
  158. package/prisma/skills/documentation-lookup/SKILL.md +0 -91
  159. package/prisma/skills/dotnet-patterns/SKILL.md +0 -322
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +0 -124
  161. package/prisma/skills/e2e-testing/SKILL.md +0 -327
  162. package/prisma/skills/ecc-guide/SKILL.md +0 -190
  163. package/prisma/skills/ecc-recipes/SKILL.md +0 -149
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +0 -161
  165. package/prisma/skills/email-ops/SKILL.md +0 -122
  166. package/prisma/skills/energy-procurement/SKILL.md +0 -228
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +0 -51
  168. package/prisma/skills/error-handling/SKILL.md +0 -377
  169. package/prisma/skills/eval-harness/SKILL.md +0 -271
  170. package/prisma/skills/evm-token-decimals/SKILL.md +0 -131
  171. package/prisma/skills/exa-search/SKILL.md +0 -108
  172. package/prisma/skills/fal-ai-media/SKILL.md +0 -289
  173. package/prisma/skills/fastapi-patterns/SKILL.md +0 -514
  174. package/prisma/skills/finance-billing-ops/SKILL.md +0 -128
  175. package/prisma/skills/flox-environments/SKILL.md +0 -497
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +0 -436
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +0 -243
  178. package/prisma/skills/frontend-a11y/SKILL.md +0 -446
  179. package/prisma/skills/frontend-design-direction/SKILL.md +0 -93
  180. package/prisma/skills/frontend-patterns/SKILL.md +0 -657
  181. package/prisma/skills/frontend-slides/SKILL.md +0 -185
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +0 -330
  183. package/prisma/skills/frontend-slides/animation-patterns.md +0 -122
  184. package/prisma/skills/frontend-slides/html-template.md +0 -419
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +0 -418
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +0 -96
  187. package/prisma/skills/frontend-slides/viewport-base.css +0 -153
  188. package/prisma/skills/fsharp-testing/SKILL.md +0 -281
  189. package/prisma/skills/gan-style-harness/SKILL.md +0 -279
  190. package/prisma/skills/gateguard/SKILL.md +0 -133
  191. package/prisma/skills/generating-python-installer/SKILL.md +0 -820
  192. package/prisma/skills/git-workflow/SKILL.md +0 -716
  193. package/prisma/skills/github-ops/SKILL.md +0 -145
  194. package/prisma/skills/golang-patterns/SKILL.md +0 -675
  195. package/prisma/skills/golang-testing/SKILL.md +0 -721
  196. package/prisma/skills/google-workspace-ops/SKILL.md +0 -96
  197. package/prisma/skills/growth-log/SKILL.md +0 -128
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +0 -246
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +0 -160
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +0 -208
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +0 -146
  202. package/prisma/skills/hermes-imports/SKILL.md +0 -89
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +0 -277
  204. package/prisma/skills/hipaa-compliance/SKILL.md +0 -79
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +0 -170
  206. package/prisma/skills/homelab-network-setup/SKILL.md +0 -130
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +0 -275
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +0 -312
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +0 -306
  210. package/prisma/skills/hookify-rules/SKILL.md +0 -128
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +0 -157
  212. package/prisma/skills/intent-driven-development/SKILL.md +0 -360
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +0 -247
  214. package/prisma/skills/investor-materials/SKILL.md +0 -97
  215. package/prisma/skills/investor-outreach/SKILL.md +0 -92
  216. package/prisma/skills/ios-icon-gen/SKILL.md +0 -158
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +0 -258
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +0 -235
  219. package/prisma/skills/iterative-retrieval/SKILL.md +0 -212
  220. package/prisma/skills/ito-basket-compare/SKILL.md +0 -64
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +0 -64
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +0 -61
  223. package/prisma/skills/ito-trade-planner/SKILL.md +0 -68
  224. package/prisma/skills/java-coding-standards/SKILL.md +0 -384
  225. package/prisma/skills/jira-integration/SKILL.md +0 -303
  226. package/prisma/skills/jpa-patterns/SKILL.md +0 -152
  227. package/prisma/skills/knowledge-ops/SKILL.md +0 -155
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +0 -285
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +0 -720
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +0 -690
  231. package/prisma/skills/kotlin-patterns/SKILL.md +0 -712
  232. package/prisma/skills/kotlin-testing/SKILL.md +0 -825
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +0 -756
  234. package/prisma/skills/laravel-patterns/SKILL.md +0 -416
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +0 -230
  236. package/prisma/skills/laravel-security/SKILL.md +0 -948
  237. package/prisma/skills/laravel-tdd/SKILL.md +0 -675
  238. package/prisma/skills/laravel-verification/SKILL.md +0 -180
  239. package/prisma/skills/latency-critical-systems/SKILL.md +0 -74
  240. package/prisma/skills/lead-intelligence/SKILL.md +0 -322
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +0 -85
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +0 -75
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +0 -98
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +0 -60
  245. package/prisma/skills/liquid-glass-design/SKILL.md +0 -279
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +0 -147
  247. package/prisma/skills/logistics-exception-management/SKILL.md +0 -222
  248. package/prisma/skills/loop-design-check/SKILL.md +0 -143
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +0 -77
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +0 -152
  251. package/prisma/skills/manim-video/SKILL.md +0 -90
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +0 -52
  253. package/prisma/skills/market-research/SKILL.md +0 -76
  254. package/prisma/skills/marketing-campaign/SKILL.md +0 -114
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +0 -70
  256. package/prisma/skills/messages-ops/SKILL.md +0 -105
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +0 -57
  258. package/prisma/skills/mle-workflow/SKILL.md +0 -347
  259. package/prisma/skills/motion-advanced/SKILL.md +0 -596
  260. package/prisma/skills/motion-foundations/SKILL.md +0 -299
  261. package/prisma/skills/motion-patterns/SKILL.md +0 -434
  262. package/prisma/skills/motion-ui/SKILL.md +0 -576
  263. package/prisma/skills/mysql-patterns/SKILL.md +0 -413
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +0 -34
  265. package/prisma/skills/nestjs-patterns/SKILL.md +0 -231
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +0 -174
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +0 -168
  268. package/prisma/skills/network-config-validation/SKILL.md +0 -211
  269. package/prisma/skills/network-interface-health/SKILL.md +0 -153
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +0 -58
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +0 -103
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +0 -168
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +0 -101
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +0 -289
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +0 -224
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +0 -5
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +0 -124
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +0 -53
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +0 -53
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +0 -48
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +0 -39
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +0 -166
  283. package/prisma/skills/opensource-pipeline/SKILL.md +0 -256
  284. package/prisma/skills/orch-add-feature/SKILL.md +0 -45
  285. package/prisma/skills/orch-build-mvp/SKILL.md +0 -49
  286. package/prisma/skills/orch-change-feature/SKILL.md +0 -43
  287. package/prisma/skills/orch-fix-defect/SKILL.md +0 -43
  288. package/prisma/skills/orch-pipeline/SKILL.md +0 -121
  289. package/prisma/skills/orch-refine-code/SKILL.md +0 -44
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +0 -73
  291. package/prisma/skills/perl-patterns/SKILL.md +0 -505
  292. package/prisma/skills/perl-security/SKILL.md +0 -504
  293. package/prisma/skills/perl-testing/SKILL.md +0 -476
  294. package/prisma/skills/plan-orchestrate/SKILL.md +0 -263
  295. package/prisma/skills/plankton-code-quality/SKILL.md +0 -237
  296. package/prisma/skills/postgres-patterns/SKILL.md +0 -148
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +0 -64
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +0 -61
  299. package/prisma/skills/prisma-patterns/SKILL.md +0 -401
  300. package/prisma/skills/product-capability/SKILL.md +0 -142
  301. package/prisma/skills/product-lens/SKILL.md +0 -93
  302. package/prisma/skills/production-audit/SKILL.md +0 -207
  303. package/prisma/skills/production-scheduling/SKILL.md +0 -238
  304. package/prisma/skills/project-flow-ops/SKILL.md +0 -112
  305. package/prisma/skills/prompt-optimizer/SKILL.md +0 -398
  306. package/prisma/skills/python-patterns/SKILL.md +0 -751
  307. package/prisma/skills/python-testing/SKILL.md +0 -817
  308. package/prisma/skills/pytorch-patterns/SKILL.md +0 -397
  309. package/prisma/skills/quality-nonconformance/SKILL.md +0 -260
  310. package/prisma/skills/quarkus-patterns/SKILL.md +0 -723
  311. package/prisma/skills/quarkus-security/SKILL.md +0 -468
  312. package/prisma/skills/quarkus-tdd/SKILL.md +0 -812
  313. package/prisma/skills/quarkus-verification/SKILL.md +0 -480
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +0 -68
  315. package/prisma/skills/react-native-patterns/SKILL.md +0 -326
  316. package/prisma/skills/react-patterns/SKILL.md +0 -342
  317. package/prisma/skills/react-performance/SKILL.md +0 -575
  318. package/prisma/skills/react-testing/SKILL.md +0 -424
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +0 -115
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +0 -80
  321. package/prisma/skills/redis-patterns/SKILL.md +0 -404
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +0 -221
  323. package/prisma/skills/remotion-video-creation/SKILL.md +0 -43
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +0 -86
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +0 -29
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +0 -173
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +0 -100
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +0 -108
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +0 -78
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +0 -172
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +0 -104
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +0 -75
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +0 -58
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +0 -146
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +0 -126
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +0 -229
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +0 -152
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +0 -58
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +0 -68
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +0 -58
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +0 -138
  342. package/prisma/skills/remotion-video-creation/rules/images.md +0 -130
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +0 -67
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +0 -67
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +0 -34
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +0 -143
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +0 -106
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +0 -11
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +0 -20
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +0 -179
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +0 -19
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +0 -122
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +0 -52
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +0 -171
  355. package/prisma/skills/repo-scan/SKILL.md +0 -79
  356. package/prisma/skills/research-ops/SKILL.md +0 -113
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +0 -240
  358. package/prisma/skills/rules-distill/SKILL.md +0 -265
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +0 -58
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +0 -129
  361. package/prisma/skills/rust-patterns/SKILL.md +0 -500
  362. package/prisma/skills/rust-testing/SKILL.md +0 -501
  363. package/prisma/skills/safety-guard/SKILL.md +0 -76
  364. package/prisma/skills/santa-method/SKILL.md +0 -307
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +0 -176
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +0 -178
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +0 -167
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +0 -193
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +0 -161
  370. package/prisma/skills/search-first/SKILL.md +0 -183
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +0 -100
  372. package/prisma/skills/security-review/SKILL.md +0 -504
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +0 -361
  374. package/prisma/skills/security-scan/SKILL.md +0 -166
  375. package/prisma/skills/seo/SKILL.md +0 -155
  376. package/prisma/skills/skill-comply/SKILL.md +0 -59
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +0 -5
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +0 -3
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +0 -44
  380. package/prisma/skills/skill-comply/prompts/classifier.md +0 -24
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +0 -62
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +0 -42
  383. package/prisma/skills/skill-comply/pyproject.toml +0 -15
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +0 -85
  386. package/prisma/skills/skill-comply/scripts/grader.py +0 -124
  387. package/prisma/skills/skill-comply/scripts/parser.py +0 -107
  388. package/prisma/skills/skill-comply/scripts/report.py +0 -170
  389. package/prisma/skills/skill-comply/scripts/run.py +0 -127
  390. package/prisma/skills/skill-comply/scripts/runner.py +0 -194
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +0 -70
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +0 -72
  393. package/prisma/skills/skill-comply/scripts/utils.py +0 -13
  394. package/prisma/skills/skill-comply/tests/test_grader.py +0 -197
  395. package/prisma/skills/skill-comply/tests/test_parser.py +0 -90
  396. package/prisma/skills/skill-comply/tests/test_runner.py +0 -172
  397. package/prisma/skills/skill-scout/SKILL.md +0 -141
  398. package/prisma/skills/skill-stocktake/SKILL.md +0 -195
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +0 -87
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +0 -56
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +0 -170
  402. package/prisma/skills/social-graph-ranker/SKILL.md +0 -155
  403. package/prisma/skills/social-publisher/SKILL.md +0 -130
  404. package/prisma/skills/springboot-patterns/SKILL.md +0 -315
  405. package/prisma/skills/springboot-security/SKILL.md +0 -273
  406. package/prisma/skills/springboot-tdd/SKILL.md +0 -159
  407. package/prisma/skills/springboot-verification/SKILL.md +0 -232
  408. package/prisma/skills/strategic-compact/SKILL.md +0 -136
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +0 -144
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +0 -216
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +0 -191
  412. package/prisma/skills/swiftui-patterns/SKILL.md +0 -259
  413. package/prisma/skills/taste/SKILL.md +0 -264
  414. package/prisma/skills/taste/references/genre-taxonomy.md +0 -87
  415. package/prisma/skills/tdd-workflow/SKILL.md +0 -583
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +0 -111
  417. package/prisma/skills/team-builder/SKILL.md +0 -169
  418. package/prisma/skills/terminal-ops/SKILL.md +0 -110
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +0 -279
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +0 -90
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +0 -60
  422. package/prisma/skills/tinystruct-patterns/references/database.md +0 -99
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +0 -64
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +0 -97
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +0 -72
  426. package/prisma/skills/token-budget-advisor/SKILL.md +0 -134
  427. package/prisma/skills/ui-demo/SKILL.md +0 -466
  428. package/prisma/skills/ui-to-vue/SKILL.md +0 -135
  429. package/prisma/skills/uncloud/SKILL.md +0 -344
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +0 -188
  431. package/prisma/skills/verification-loop/SKILL.md +0 -127
  432. package/prisma/skills/video-editing/SKILL.md +0 -311
  433. package/prisma/skills/videodb/SKILL.md +0 -375
  434. package/prisma/skills/videodb/reference/api-reference.md +0 -550
  435. package/prisma/skills/videodb/reference/capture-reference.md +0 -407
  436. package/prisma/skills/videodb/reference/capture.md +0 -101
  437. package/prisma/skills/videodb/reference/editor.md +0 -443
  438. package/prisma/skills/videodb/reference/generative.md +0 -331
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +0 -564
  440. package/prisma/skills/videodb/reference/rtstream.md +0 -65
  441. package/prisma/skills/videodb/reference/search.md +0 -230
  442. package/prisma/skills/videodb/reference/streaming.md +0 -406
  443. package/prisma/skills/videodb/reference/use-cases.md +0 -118
  444. package/prisma/skills/videodb/scripts/ws_listener.py +0 -282
  445. package/prisma/skills/visa-doc-translate/README.md +0 -86
  446. package/prisma/skills/visa-doc-translate/SKILL.md +0 -117
  447. package/prisma/skills/vite-patterns/SKILL.md +0 -450
  448. package/prisma/skills/vue-patterns/SKILL.md +0 -471
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +0 -888
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +0 -126
  451. package/prisma/skills/x-api/SKILL.md +0 -235
@@ -1,281 +0,0 @@
1
- ---
2
- name: fsharp-testing
3
- description: F# testing patterns with xUnit, FsUnit, Unquote, FsCheck property-based testing, integration tests, and test organization best practices.
4
- metadata:
5
- origin: ECC
6
- ---
7
-
8
- # F# Testing Patterns
9
-
10
- Comprehensive testing patterns for F# applications using xUnit, FsUnit, Unquote, FsCheck, and modern .NET testing practices.
11
-
12
- ## When to Activate
13
-
14
- - Writing new tests for F# code
15
- - Reviewing test quality and coverage
16
- - Setting up test infrastructure for F# projects
17
- - Debugging flaky or slow tests
18
-
19
- ## Test Framework Stack
20
-
21
- | Tool | Purpose |
22
- |---|---|
23
- | **xUnit** | Test framework (standard .NET ecosystem choice) |
24
- | **FsUnit.xUnit** | F#-friendly assertion syntax for xUnit |
25
- | **Unquote** | Assertion library using F# quotations for clear failure messages |
26
- | **FsCheck.xUnit** | Property-based testing integrated with xUnit |
27
- | **NSubstitute** | Mocking .NET dependencies |
28
- | **Testcontainers** | Real infrastructure in integration tests |
29
- | **WebApplicationFactory** | ASP.NET Core integration tests |
30
-
31
- ## Unit Tests with xUnit + FsUnit
32
-
33
- ### Basic Test Structure
34
-
35
- ```fsharp
36
- module OrderServiceTests
37
-
38
- open Xunit
39
- open FsUnit.Xunit
40
-
41
- [<Fact>]
42
- let ``create sets status to Pending`` () =
43
- let order = Order.create "cust-1" [ validItem ]
44
- order.Status |> should equal Pending
45
-
46
- [<Fact>]
47
- let ``confirm changes status to Confirmed`` () =
48
- let order = Order.create "cust-1" [ validItem ]
49
- let confirmed = Order.confirm order
50
- confirmed.Status |> should be (ofCase <@ Confirmed @>)
51
- ```
52
-
53
- ### Assertions with Unquote
54
-
55
- Unquote uses F# quotations so failure messages show the full expression that failed, not just "expected X got Y".
56
-
57
- ```fsharp
58
- module OrderValidationTests
59
-
60
- open Xunit
61
- open Swensen.Unquote
62
-
63
- [<Fact>]
64
- let ``PlaceOrder returns success when request is valid`` () =
65
- let request = { CustomerId = "cust-123"; Items = [ validItem ] }
66
- let result = OrderService.placeOrder request
67
- test <@ Result.isOk result @>
68
-
69
- [<Fact>]
70
- let ``order total sums item prices`` () =
71
- let items = [ { Sku = "A"; Quantity = 2; Price = 10m }
72
- { Sku = "B"; Quantity = 1; Price = 5m } ]
73
- let total = Order.calculateTotal items
74
- test <@ total = 25m @>
75
-
76
- [<Fact>]
77
- let ``validated email rejects empty input`` () =
78
- let result = ValidatedEmail.create ""
79
- test <@ Result.isError result @>
80
- ```
81
-
82
- ### Async Tests
83
-
84
- ```fsharp
85
- [<Fact>]
86
- let ``PlaceOrder returns success when request is valid`` () = task {
87
- let deps = createTestDeps ()
88
- let request = { CustomerId = "cust-123"; Items = [ validItem ] }
89
-
90
- let! result = OrderService.placeOrder deps request
91
-
92
- test <@ Result.isOk result @>
93
- }
94
-
95
- [<Fact>]
96
- let ``PlaceOrder returns error when items are empty`` () = task {
97
- let deps = createTestDeps ()
98
- let request = { CustomerId = "cust-123"; Items = [] }
99
-
100
- let! result = OrderService.placeOrder deps request
101
-
102
- test <@ Result.isError result @>
103
- }
104
- ```
105
-
106
- ### Parameterized Tests with Theory
107
-
108
- ```fsharp
109
- [<Theory>]
110
- [<InlineData("")>]
111
- [<InlineData(" ")>]
112
- let ``PlaceOrder rejects empty customer ID`` (customerId: string) =
113
- let request = { CustomerId = customerId; Items = [ validItem ] }
114
- let result = OrderService.placeOrder request
115
- result |> should be (ofCase <@ Error @>)
116
-
117
- [<Theory>]
118
- [<InlineData("", false)>]
119
- [<InlineData("a", false)>]
120
- [<InlineData("user@example.com", true)>]
121
- [<InlineData("user+tag@example.co.uk", true)>]
122
- let ``IsValidEmail returns expected result`` (email: string, expected: bool) =
123
- test <@ EmailValidator.isValid email = expected @>
124
- ```
125
-
126
- ## Property-Based Testing with FsCheck
127
-
128
- ### Using FsCheck.xUnit
129
-
130
- ```fsharp
131
- open FsCheck
132
- open FsCheck.Xunit
133
-
134
- [<Property>]
135
- let ``order total is always non-negative`` (items: NonEmptyList<PositiveInt * decimal>) =
136
- let orderItems =
137
- items.Get
138
- |> List.map (fun (qty, price) ->
139
- { Sku = "SKU"; Quantity = qty.Get; Price = abs price })
140
- let total = Order.calculateTotal orderItems
141
- total >= 0m
142
-
143
- [<Property>]
144
- let ``serialization roundtrips`` (order: Order) =
145
- let json = JsonSerializer.Serialize order
146
- let deserialized = JsonSerializer.Deserialize<Order> json
147
- deserialized = order
148
- ```
149
-
150
- ### Custom Generators
151
-
152
- ```fsharp
153
- type OrderGenerators =
154
- static member ValidEmail () =
155
- gen {
156
- let! user = Gen.elements [ "alice"; "bob"; "carol" ]
157
- let! domain = Gen.elements [ "example.com"; "test.org" ]
158
- return $"{user}@{domain}"
159
- }
160
- |> Arb.fromGen
161
-
162
- [<Property(Arbitrary = [| typeof<OrderGenerators> |])>]
163
- let ``valid emails pass validation`` (email: string) =
164
- EmailValidator.isValid email
165
- ```
166
-
167
- ## Mocking Dependencies
168
-
169
- ### Function Stubs (Preferred)
170
-
171
- ```fsharp
172
- let createTestDeps () =
173
- let mutable savedOrders = []
174
- { FindOrder = fun id -> task { return Map.tryFind id testData }
175
- SaveOrder = fun order -> task { savedOrders <- order :: savedOrders }
176
- SendNotification = fun _ -> Task.CompletedTask }
177
-
178
- [<Fact>]
179
- let ``PlaceOrder saves the confirmed order`` () = task {
180
- let mutable saved = []
181
- let deps =
182
- { createTestDeps () with
183
- SaveOrder = fun order -> task { saved <- order :: saved } }
184
-
185
- let! _ = OrderService.placeOrder deps validRequest
186
-
187
- test <@ saved.Length = 1 @>
188
- }
189
- ```
190
-
191
- ### NSubstitute for .NET Interfaces
192
-
193
- ```fsharp
194
- open NSubstitute
195
-
196
- [<Fact>]
197
- let ``calls repository with correct ID`` () = task {
198
- let repo = Substitute.For<IOrderRepository>()
199
- repo.FindByIdAsync(Arg.Any<Guid>(), Arg.Any<CancellationToken>())
200
- .Returns(Task.FromResult(Some testOrder))
201
-
202
- let service = OrderService(repo)
203
- let! _ = service.GetOrder(testOrder.Id, CancellationToken.None)
204
-
205
- do! repo.Received(1).FindByIdAsync(testOrder.Id, Arg.Any<CancellationToken>())
206
- }
207
- ```
208
-
209
- ## ASP.NET Core Integration Tests
210
-
211
- ```fsharp
212
- type OrderApiTests (factory: WebApplicationFactory<Program>) =
213
- interface IClassFixture<WebApplicationFactory<Program>>
214
-
215
- let client =
216
- factory.WithWebHostBuilder(fun builder ->
217
- builder.ConfigureServices(fun services ->
218
- services.RemoveAll<DbContextOptions<AppDbContext>>() |> ignore
219
- services.AddDbContext<AppDbContext>(fun options ->
220
- options.UseInMemoryDatabase("TestDb") |> ignore) |> ignore))
221
- .CreateClient()
222
-
223
- [<Fact>]
224
- member _.``GET order returns 404 when not found`` () = task {
225
- let! response = client.GetAsync($"/api/orders/{Guid.NewGuid()}")
226
- test <@ response.StatusCode = HttpStatusCode.NotFound @>
227
- }
228
- ```
229
-
230
- ## Test Organization
231
-
232
- ```
233
- tests/
234
- MyApp.Tests/
235
- Unit/
236
- OrderServiceTests.fs
237
- PaymentServiceTests.fs
238
- Integration/
239
- OrderApiTests.fs
240
- OrderRepositoryTests.fs
241
- Properties/
242
- OrderPropertyTests.fs
243
- Helpers/
244
- TestData.fs
245
- TestDeps.fs
246
- ```
247
-
248
- ## Common Anti-Patterns
249
-
250
- | Anti-Pattern | Fix |
251
- |---|---|
252
- | Testing implementation details | Test behavior and outcomes |
253
- | Mutable shared test state | Fresh state per test |
254
- | `Thread.Sleep` in async tests | Use `Task.Delay` with timeout, or polling helpers |
255
- | Asserting on `sprintf` output | Assert on typed values and pattern matches |
256
- | Ignoring `CancellationToken` | Always pass and verify cancellation |
257
- | Skipping property-based tests | Use FsCheck for any function with clear invariants |
258
-
259
- ## Related Skills
260
-
261
- - `dotnet-patterns` - Idiomatic .NET patterns, dependency injection, and architecture
262
- - `csharp-testing` - C# testing patterns (shared infrastructure like WebApplicationFactory and Testcontainers applies to F# too)
263
-
264
- ## Running Tests
265
-
266
- ```bash
267
- # Run all tests
268
- dotnet test
269
-
270
- # Run with coverage
271
- dotnet test --collect:"XPlat Code Coverage"
272
-
273
- # Run specific project
274
- dotnet test tests/MyApp.Tests/
275
-
276
- # Filter by test name
277
- dotnet test --filter "FullyQualifiedName~OrderService"
278
-
279
- # Watch mode during development
280
- dotnet watch test --project tests/MyApp.Tests/
281
- ```
@@ -1,279 +0,0 @@
1
- ---
2
- name: gan-style-harness
3
- description: "GAN-inspired Generator-Evaluator agent harness for building high-quality applications autonomously. Based on Anthropic's March 2026 harness design paper."
4
- metadata:
5
- origin: ECC-community
6
- tools: Read, Write, Edit, Bash, Grep, Glob, Task
7
- ---
8
-
9
- # GAN-Style Harness Skill
10
-
11
- > Inspired by [Anthropic's Harness Design for Long-Running Application Development](https://www.anthropic.com/engineering/harness-design-long-running-apps) (March 24, 2026)
12
-
13
- A multi-agent harness that separates **generation** from **evaluation**, creating an adversarial feedback loop that drives quality far beyond what a single agent can achieve.
14
-
15
- ## Core Insight
16
-
17
- > When asked to evaluate their own work, agents are pathological optimists — they praise mediocre output and talk themselves out of legitimate issues. But engineering a **separate evaluator** to be ruthlessly strict is far more tractable than teaching a generator to self-critique.
18
-
19
- This is the same dynamic as GANs (Generative Adversarial Networks): the Generator produces, the Evaluator critiques, and that feedback drives the next iteration.
20
-
21
- ## When to Use
22
-
23
- - Building complete applications from a one-line prompt
24
- - Frontend design tasks requiring high visual quality
25
- - Full-stack projects that need working features, not just code
26
- - Any task where "AI slop" aesthetics are unacceptable
27
- - Projects where you want to invest $50-200 for production-quality output
28
-
29
- ## When NOT to Use
30
-
31
- - Quick single-file fixes (use standard `claude -p`)
32
- - Tasks with tight budget constraints (<$10)
33
- - Simple refactoring (use de-sloppify pattern instead)
34
- - Tasks that are already well-specified with tests (use TDD workflow)
35
-
36
- ## Architecture
37
-
38
- ```
39
- ┌─────────────┐
40
- │ PLANNER │
41
- │ (Opus 4.6) │
42
- └──────┬──────┘
43
- │ Product Spec
44
- │ (features, sprints, design direction)
45
-
46
- ┌────────────────────────┐
47
- │ │
48
- │ GENERATOR-EVALUATOR │
49
- │ FEEDBACK LOOP │
50
- │ │
51
- │ ┌──────────┐ │
52
- │ │GENERATOR │--build-->│──┐
53
- │ │(Opus 4.6)│ │ │
54
- │ └────▲─────┘ │ │
55
- │ │ │ │ live app
56
- │ feedback │ │
57
- │ │ │ │
58
- │ ┌────┴─────┐ │ │
59
- │ │EVALUATOR │<-test----│──┘
60
- │ │(Opus 4.6)│ │
61
- │ │+Playwright│ │
62
- │ └──────────┘ │
63
- │ │
64
- │ 5-15 iterations │
65
- └────────────────────────┘
66
- ```
67
-
68
- ## The Three Agents
69
-
70
- ### 1. Planner Agent
71
-
72
- **Role:** Product manager — expands a brief prompt into a full product specification.
73
-
74
- **Key behaviors:**
75
- - Takes a one-line prompt and produces a 16-feature, multi-sprint specification
76
- - Defines user stories, technical requirements, and visual design direction
77
- - Is deliberately **ambitious** — conservative planning leads to underwhelming results
78
- - Produces evaluation criteria that the Evaluator will use later
79
-
80
- **Model:** Opus 4.6 (needs deep reasoning for spec expansion)
81
-
82
- ### 2. Generator Agent
83
-
84
- **Role:** Developer — implements features according to the spec.
85
-
86
- **Key behaviors:**
87
- - Works in structured sprints (or continuous mode with newer models)
88
- - Negotiates a "sprint contract" with the Evaluator before writing code
89
- - Uses full-stack tooling: React, FastAPI/Express, databases, CSS
90
- - Manages git for version control between iterations
91
- - Reads Evaluator feedback and incorporates it in next iteration
92
-
93
- **Model:** Opus 4.6 (needs strong coding capability)
94
-
95
- ### 3. Evaluator Agent
96
-
97
- **Role:** QA engineer — tests the live running application, not just code.
98
-
99
- **Key behaviors:**
100
- - Uses **Playwright MCP** to interact with the live application
101
- - Clicks through features, fills forms, tests API endpoints
102
- - Scores against four criteria (configurable):
103
- 1. **Design Quality** — Does it feel like a coherent whole?
104
- 2. **Originality** — Custom decisions vs. template/AI patterns?
105
- 3. **Craft** — Typography, spacing, animations, micro-interactions?
106
- 4. **Functionality** — Do all features actually work?
107
- - Returns structured feedback with scores and specific issues
108
- - Is engineered to be **ruthlessly strict** — never praises mediocre work
109
-
110
- **Model:** Opus 4.6 (needs strong judgment + tool use)
111
-
112
- ## Evaluation Criteria
113
-
114
- The default four criteria, each scored 1-10:
115
-
116
- ```markdown
117
- ## Evaluation Rubric
118
-
119
- ### Design Quality (weight: 0.3)
120
- - 1-3: Generic, template-like, "AI slop" aesthetics
121
- - 4-6: Competent but unremarkable, follows conventions
122
- - 7-8: Distinctive, cohesive visual identity
123
- - 9-10: Could pass for a professional designer's work
124
-
125
- ### Originality (weight: 0.2)
126
- - 1-3: Default colors, stock layouts, no personality
127
- - 4-6: Some custom choices, mostly standard patterns
128
- - 7-8: Clear creative vision, unique approach
129
- - 9-10: Surprising, delightful, genuinely novel
130
-
131
- ### Craft (weight: 0.3)
132
- - 1-3: Broken layouts, missing states, no animations
133
- - 4-6: Works but feels rough, inconsistent spacing
134
- - 7-8: Polished, smooth transitions, responsive
135
- - 9-10: Pixel-perfect, delightful micro-interactions
136
-
137
- ### Functionality (weight: 0.2)
138
- - 1-3: Core features broken or missing
139
- - 4-6: Happy path works, edge cases fail
140
- - 7-8: All features work, good error handling
141
- - 9-10: Bulletproof, handles every edge case
142
- ```
143
-
144
- ### Scoring
145
-
146
- - **Weighted score** = sum of (criterion_score * weight)
147
- - **Pass threshold** = 7.0 (configurable)
148
- - **Max iterations** = 15 (configurable, typically 5-15 sufficient)
149
-
150
- ## Usage
151
-
152
- ### Via Command
153
-
154
- ```bash
155
- # Full three-agent harness
156
- /project:gan-build "Build a project management app with Kanban boards, team collaboration, and dark mode"
157
-
158
- # With custom config
159
- /project:gan-build "Build a recipe sharing platform" --max-iterations 10 --pass-threshold 7.5
160
-
161
- # Frontend design mode (generator + evaluator only, no planner)
162
- /project:gan-design "Create a landing page for a crypto portfolio tracker"
163
- ```
164
-
165
- ### Via Shell Script
166
-
167
- ```bash
168
- # Basic usage
169
- ./scripts/gan-harness.sh "Build a music streaming dashboard"
170
-
171
- # With options
172
- GAN_MAX_ITERATIONS=10 \
173
- GAN_PASS_THRESHOLD=7.5 \
174
- GAN_EVAL_CRITERIA="functionality,performance,security" \
175
- ./scripts/gan-harness.sh "Build a REST API for task management"
176
- ```
177
-
178
- ### Via Claude Code (Manual)
179
-
180
- ```bash
181
- # Step 1: Plan
182
- claude -p --model opus "You are a Product Planner. Read PLANNER_PROMPT.md. Expand this brief into a full product spec: 'Build a Kanban board app'. Write spec to spec.md"
183
-
184
- # Step 2: Generate (iteration 1)
185
- claude -p --model opus "You are a Generator. Read spec.md. Implement Sprint 1. Start the dev server on port 3000."
186
-
187
- # Step 3: Evaluate (iteration 1)
188
- claude -p --model opus --allowedTools "Read,Bash,mcp__playwright__*" "You are an Evaluator. Read EVALUATOR_PROMPT.md. Test the live app at http://localhost:3000. Score against the rubric. Write feedback to feedback-001.md"
189
-
190
- # Step 4: Generate (iteration 2 — reads feedback)
191
- claude -p --model opus "You are a Generator. Read spec.md and feedback-001.md. Address all issues. Improve the scores."
192
-
193
- # Repeat steps 3-4 until pass threshold met
194
- ```
195
-
196
- ## Evolution Across Model Capabilities
197
-
198
- The harness should simplify as models improve. Following Anthropic's evolution:
199
-
200
- ### Stage 1 — Weaker Models (Sonnet-class)
201
- - Full sprint decomposition required
202
- - Context resets between sprints (avoid context anxiety)
203
- - 2-agent minimum: Initializer + Coding Agent
204
- - Heavy scaffolding compensates for model limitations
205
-
206
- ### Stage 2 — Capable Models (Opus 4.5-class)
207
- - Full 3-agent harness: Planner + Generator + Evaluator
208
- - Sprint contracts before each implementation phase
209
- - 10-sprint decomposition for complex apps
210
- - Context resets still useful but less critical
211
-
212
- ### Stage 3 — Frontier Models (Opus 4.6-class)
213
- - Simplified harness: single planning pass, continuous generation
214
- - Evaluation reduced to single end-pass (model is smarter)
215
- - No sprint structure needed
216
- - Automatic compaction handles context growth
217
-
218
- > **Key principle:** Every harness component encodes an assumption about what the model can't do alone. When models improve, re-test those assumptions. Strip away what's no longer needed.
219
-
220
- ## Configuration
221
-
222
- ### Environment Variables
223
-
224
- | Variable | Default | Description |
225
- |----------|---------|-------------|
226
- | `GAN_MAX_ITERATIONS` | `15` | Maximum generator-evaluator cycles |
227
- | `GAN_PASS_THRESHOLD` | `7.0` | Weighted score to pass (1-10) |
228
- | `GAN_PLANNER_MODEL` | `opus` | Model for planning agent |
229
- | `GAN_GENERATOR_MODEL` | `opus` | Model for generator agent |
230
- | `GAN_EVALUATOR_MODEL` | `opus` | Model for evaluator agent |
231
- | `GAN_EVAL_CRITERIA` | `design,originality,craft,functionality` | Comma-separated criteria |
232
- | `GAN_DEV_SERVER_PORT` | `3000` | Port for the live app |
233
- | `GAN_DEV_SERVER_CMD` | `npm run dev` | Command to start dev server |
234
- | `GAN_PROJECT_DIR` | `.` | Project working directory |
235
- | `GAN_SKIP_PLANNER` | `false` | Skip planner, use spec directly |
236
- | `GAN_EVAL_MODE` | `playwright` | `playwright`, `screenshot`, or `code-only` |
237
-
238
- ### Evaluation Modes
239
-
240
- | Mode | Tools | Best For |
241
- |------|-------|----------|
242
- | `playwright` | Browser MCP + live interaction | Full-stack apps with UI |
243
- | `screenshot` | Screenshot + visual analysis | Static sites, design-only |
244
- | `code-only` | Tests + linting + build | APIs, libraries, CLI tools |
245
-
246
- ## Anti-Patterns
247
-
248
- 1. **Evaluator too lenient** — If the evaluator passes everything on iteration 1, your rubric is too generous. Tighten scoring criteria and add explicit penalties for common AI patterns.
249
-
250
- 2. **Generator ignoring feedback** — Ensure feedback is passed as a file, not inline. The generator should read `feedback-NNN.md` at the start of each iteration.
251
-
252
- 3. **Infinite loops** — Always set `GAN_MAX_ITERATIONS`. If the generator can't improve past a score plateau after 3 iterations, stop and flag for human review.
253
-
254
- 4. **Evaluator testing superficially** — The evaluator must use Playwright to **interact** with the live app, not just screenshot it. Click buttons, fill forms, test error states.
255
-
256
- 5. **Evaluator praising its own fixes** — Never let the evaluator suggest fixes and then evaluate those fixes. The evaluator only critiques; the generator fixes.
257
-
258
- 6. **Context exhaustion** — For long sessions, use Claude Agent SDK's automatic compaction or reset context between major phases.
259
-
260
- ## Results: What to Expect
261
-
262
- Based on Anthropic's published results:
263
-
264
- | Metric | Solo Agent | GAN Harness | Improvement |
265
- |--------|-----------|-------------|-------------|
266
- | Time | 20 min | 4-6 hours | 12-18x longer |
267
- | Cost | $9 | $125-200 | 14-22x more |
268
- | Quality | Barely functional | Production-ready | Phase change |
269
- | Core features | Broken | All working | N/A |
270
- | Design | Generic AI slop | Distinctive, polished | N/A |
271
-
272
- **The tradeoff is clear:** ~20x more time and cost for a qualitative leap in output quality. This is for projects where quality matters.
273
-
274
- ## References
275
-
276
- - [Anthropic: Harness Design for Long-Running Apps](https://www.anthropic.com/engineering/harness-design-long-running-apps) — Original paper by Prithvi Rajasekaran
277
- - [Epsilla: The GAN-Style Agent Loop](https://www.epsilla.com/blogs/anthropic-harness-engineering-multi-agent-gan-architecture) — Architecture deconstruction
278
- - [Martin Fowler: Harness Engineering](https://martinfowler.com/articles/exploring-gen-ai/harness-engineering.html) — Broader industry context
279
- - [OpenAI: Harness Engineering](https://openai.com/index/harness-engineering/) — OpenAI's parallel work
@@ -1,133 +0,0 @@
1
- ---
2
- name: gateguard
3
- description: Fact-forcing gate that blocks Edit/Write/Bash (including MultiEdit) and demands concrete investigation (importers, data schemas, user instruction) before allowing the action. Measurably improves output quality by +2.25 points vs ungated agents.
4
- metadata:
5
- origin: community
6
- ---
7
-
8
- # GateGuard — Fact-Forcing Pre-Action Gate
9
-
10
- A PreToolUse hook that forces Claude to investigate before editing. Instead of self-evaluation ("are you sure?"), it demands concrete facts. The act of investigation creates awareness that self-evaluation never did.
11
-
12
- ## When to Activate
13
-
14
- - Working on any codebase where file edits affect multiple modules
15
- - Projects with data files that have specific schemas or date formats
16
- - Teams where AI-generated code must match existing patterns
17
- - Any workflow where Claude tends to guess instead of investigating
18
-
19
- ## Core Concept
20
-
21
- LLM self-evaluation doesn't work. Ask "did you violate any policies?" and the answer is always "no." This is verified experimentally.
22
-
23
- But asking "list every file that imports this module" forces the LLM to run Grep and Read. The investigation itself creates context that changes the output.
24
-
25
- **Three-stage gate:**
26
-
27
- ```
28
- 1. DENY — block the first Edit/Write/Bash attempt
29
- 2. FORCE — tell the model exactly which facts to gather
30
- 3. ALLOW — permit retry after facts are presented
31
- ```
32
-
33
- No competitor does all three. Most stop at deny.
34
-
35
- ## Evidence
36
-
37
- Two independent A/B tests, identical agents, same task:
38
-
39
- | Task | Gated | Ungated | Gap |
40
- | --- | --- | --- | --- |
41
- | Analytics module | 8.0/10 | 6.5/10 | +1.5 |
42
- | Webhook validator | 10.0/10 | 7.0/10 | +3.0 |
43
- | **Average** | **9.0** | **6.75** | **+2.25** |
44
-
45
- Both agents produce code that runs and passes tests. The difference is design depth.
46
-
47
- ## Gate Types
48
-
49
- ### Edit / MultiEdit Gate (first edit per file)
50
-
51
- MultiEdit is handled identically — each file in the batch is gated individually.
52
-
53
- ```
54
- Before editing {file_path}, present these facts:
55
-
56
- 1. List ALL files that import/require this file (search the tree — Glob/Grep, or find/grep via Bash)
57
- 2. List the public functions/classes affected by this change
58
- 3. If this file reads/writes data files, show field names, structure,
59
- and date format (use redacted or synthetic values, not raw production data)
60
- 4. Quote the user's current instruction verbatim
61
- ```
62
-
63
- ### Write Gate (first new file creation)
64
-
65
- ```
66
- Before creating {file_path}, present these facts:
67
-
68
- 1. Name the file(s) and line(s) that will call this new file
69
- 2. Confirm no existing file serves the same purpose (search the tree — Glob/Grep, or find/grep via Bash)
70
- 3. If this file reads/writes data files, show field names, structure,
71
- and date format (use redacted or synthetic values, not raw production data)
72
- 4. Quote the user's current instruction verbatim
73
- ```
74
-
75
- ### Destructive Bash Gate (every destructive command)
76
-
77
- Triggers on: `rm -rf`, `git reset --hard`, `git push --force`, `drop table`, etc.
78
-
79
- ```
80
- 1. List all files/data this command will modify or delete
81
- 2. Write a one-line rollback procedure
82
- 3. Quote the user's current instruction verbatim
83
- ```
84
-
85
- ### Routine Bash Gate (once per session)
86
-
87
- ```
88
- 1. The current user request in one sentence
89
- 2. What this specific command verifies or produces
90
- ```
91
-
92
- ## Quick Start
93
-
94
- ### Option A: Use the ECC hook (zero install)
95
-
96
- The hook at `scripts/hooks/gateguard-fact-force.js` is included in this plugin. Enable it via hooks.json.
97
-
98
- If GateGuard blocks setup or repair work, start the session with
99
- `ECC_GATEGUARD=off`. For hook-level control, keep using
100
- `ECC_DISABLED_HOOKS` with the GateGuard hook ID.
101
-
102
- In long sessions, only the first `GATEGUARD_FACT_FORCE_FULL_DENIALS`
103
- fact-force denials (default 3) emit the full four-fact block; later
104
- denials are condensed to a single line carrying the denial ordinal, so
105
- near-identical blocks cannot accumulate in the context window and
106
- amplify model repetition loops (#2142). Retrying the same file or
107
- command after presenting facts never re-triggers the gate.
108
-
109
- ### Option B: Full package with config
110
-
111
- ```bash
112
- pip install gateguard-ai
113
- gateguard init
114
- ```
115
-
116
- This adds `.gateguard.yml` for per-project configuration (custom messages, ignore paths, gate toggles).
117
-
118
- ## Anti-Patterns
119
-
120
- - **Don't use self-evaluation instead.** "Are you sure?" always gets "yes." This is experimentally verified.
121
- - **Don't skip the data schema check.** Both A/B test agents assumed ISO-8601 dates when real data used `%Y/%m/%d %H:%M`. Checking data structure (with redacted values) prevents this entire class of bugs.
122
- - **Don't gate every single Bash command.** Routine bash gates once per session. Destructive bash gates every time. This balance avoids slowdown while catching real risks.
123
-
124
- ## Best Practices
125
-
126
- - Let the gate fire naturally. Don't try to pre-answer the gate questions — the investigation itself is what improves quality.
127
- - Customize gate messages for your domain. If your project has specific conventions, add them to the gate prompts.
128
- - Use `.gateguard.yml` to ignore paths like `.venv/`, `node_modules/`, `.git/`.
129
-
130
- ## Related Skills
131
-
132
- - `safety-guard` — Runtime safety checks (complementary, not overlapping)
133
- - `code-reviewer` — Post-edit review (GateGuard is pre-edit investigation)