compact-agent 1.10.0 → 1.11.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 (708) hide show
  1. package/bin/ecc-hooks.cjs +110 -0
  2. package/dist/config.js +10 -1
  3. package/dist/config.js.map +1 -1
  4. package/dist/ecc.d.ts +11 -0
  5. package/dist/ecc.js +142 -27
  6. package/dist/ecc.js.map +1 -1
  7. package/dist/index.js +90 -9
  8. package/dist/index.js.map +1 -1
  9. package/dist/mempalace/index.d.ts +11 -0
  10. package/dist/mempalace/index.js +26 -1
  11. package/dist/mempalace/index.js.map +1 -1
  12. package/dist/system-prompt.js +2 -2
  13. package/dist/system-prompt.js.map +1 -1
  14. package/dist/tools/index.js +8 -2
  15. package/dist/tools/index.js.map +1 -1
  16. package/dist/types.d.ts +6 -0
  17. package/dist/types.js.map +1 -1
  18. package/package.json +1 -1
  19. package/resources/ecc/agents/a11y-architect.md +149 -0
  20. package/resources/ecc/agents/architect.md +11 -3
  21. package/resources/ecc/agents/build-error-resolver.md +11 -4
  22. package/resources/ecc/agents/chief-of-staff.md +11 -4
  23. package/resources/ecc/agents/code-architect.md +80 -0
  24. package/resources/ecc/agents/code-explorer.md +78 -0
  25. package/resources/ecc/agents/code-reviewer.md +89 -4
  26. package/resources/ecc/agents/code-simplifier.md +56 -0
  27. package/resources/ecc/agents/comment-analyzer.md +54 -0
  28. package/resources/ecc/agents/conversation-analyzer.md +61 -0
  29. package/resources/ecc/agents/cpp-build-resolver.md +99 -0
  30. package/resources/ecc/agents/cpp-reviewer.md +81 -0
  31. package/resources/ecc/agents/csharp-reviewer.md +110 -0
  32. package/resources/ecc/agents/dart-build-resolver.md +210 -0
  33. package/resources/ecc/agents/database-reviewer.md +11 -3
  34. package/resources/ecc/agents/django-build-resolver.md +252 -0
  35. package/resources/ecc/agents/django-reviewer.md +169 -0
  36. package/resources/ecc/agents/doc-updater.md +11 -3
  37. package/resources/ecc/agents/docs-lookup.md +77 -0
  38. package/resources/ecc/agents/e2e-runner.md +11 -4
  39. package/resources/ecc/agents/fastapi-reviewer.md +79 -0
  40. package/resources/ecc/agents/flutter-reviewer.md +252 -0
  41. package/resources/ecc/agents/fsharp-reviewer.md +109 -0
  42. package/resources/ecc/agents/gan-evaluator.md +218 -0
  43. package/resources/ecc/agents/gan-generator.md +140 -0
  44. package/resources/ecc/agents/gan-planner.md +108 -0
  45. package/resources/ecc/agents/go-build-resolver.md +11 -4
  46. package/resources/ecc/agents/go-reviewer.md +11 -3
  47. package/resources/ecc/agents/harmonyos-app-resolver.md +182 -0
  48. package/resources/ecc/agents/harness-optimizer.md +12 -2
  49. package/resources/ecc/agents/healthcare-reviewer.md +92 -0
  50. package/resources/ecc/agents/homelab-architect.md +107 -0
  51. package/resources/ecc/agents/java-build-resolver.md +275 -0
  52. package/resources/ecc/agents/java-reviewer.md +190 -0
  53. package/resources/ecc/agents/kotlin-build-resolver.md +127 -0
  54. package/resources/ecc/agents/kotlin-reviewer.md +168 -0
  55. package/resources/ecc/agents/loop-operator.md +12 -3
  56. package/resources/ecc/agents/mle-reviewer.md +162 -0
  57. package/resources/ecc/agents/network-architect.md +106 -0
  58. package/resources/ecc/agents/network-config-reviewer.md +106 -0
  59. package/resources/ecc/agents/network-troubleshooter.md +128 -0
  60. package/resources/ecc/agents/opensource-forker.md +207 -0
  61. package/resources/ecc/agents/opensource-packager.md +258 -0
  62. package/resources/ecc/agents/opensource-sanitizer.md +197 -0
  63. package/resources/ecc/agents/performance-optimizer.md +455 -0
  64. package/resources/ecc/agents/planner.md +11 -2
  65. package/resources/ecc/agents/pr-test-analyzer.md +54 -0
  66. package/resources/ecc/agents/python-reviewer.md +11 -3
  67. package/resources/ecc/agents/pytorch-build-resolver.md +129 -0
  68. package/resources/ecc/agents/refactor-cleaner.md +11 -4
  69. package/resources/ecc/agents/rust-build-resolver.md +157 -0
  70. package/resources/ecc/agents/rust-reviewer.md +103 -0
  71. package/resources/ecc/agents/security-reviewer.md +11 -3
  72. package/resources/ecc/agents/seo-specialist.md +71 -0
  73. package/resources/ecc/agents/silent-failure-hunter.md +59 -0
  74. package/resources/ecc/agents/swift-build-resolver.md +170 -0
  75. package/resources/ecc/agents/swift-reviewer.md +116 -0
  76. package/resources/ecc/agents/tdd-guide.md +11 -4
  77. package/resources/ecc/agents/type-design-analyzer.md +50 -0
  78. package/resources/ecc/agents/typescript-reviewer.md +121 -0
  79. package/resources/ecc/commands/aside.md +164 -0
  80. package/resources/ecc/commands/auto-update.md +28 -0
  81. package/resources/ecc/commands/build-fix.md +66 -0
  82. package/resources/ecc/commands/checkpoint.md +78 -0
  83. package/resources/ecc/commands/code-review.md +289 -0
  84. package/resources/ecc/commands/cost-report.md +107 -0
  85. package/resources/ecc/commands/cpp-build.md +173 -0
  86. package/resources/ecc/commands/cpp-review.md +132 -0
  87. package/resources/ecc/commands/cpp-test.md +251 -0
  88. package/resources/ecc/commands/ecc-guide.md +93 -0
  89. package/resources/ecc/commands/evolve.md +178 -0
  90. package/resources/ecc/commands/fastapi-review.md +39 -0
  91. package/resources/ecc/commands/feature-dev.md +49 -0
  92. package/resources/ecc/commands/flutter-build.md +164 -0
  93. package/resources/ecc/commands/flutter-review.md +116 -0
  94. package/resources/ecc/commands/flutter-test.md +144 -0
  95. package/resources/ecc/commands/gan-build.md +103 -0
  96. package/resources/ecc/commands/gan-design.md +39 -0
  97. package/resources/ecc/commands/go-build.md +183 -0
  98. package/resources/ecc/commands/go-review.md +148 -0
  99. package/resources/ecc/commands/go-test.md +268 -0
  100. package/resources/ecc/commands/gradle-build.md +70 -0
  101. package/resources/ecc/commands/harness-audit.md +77 -0
  102. package/resources/ecc/commands/hookify-configure.md +14 -0
  103. package/resources/ecc/commands/hookify-help.md +46 -0
  104. package/resources/ecc/commands/hookify-list.md +21 -0
  105. package/resources/ecc/commands/hookify.md +50 -0
  106. package/resources/ecc/commands/instinct-export.md +66 -0
  107. package/resources/ecc/commands/instinct-import.md +114 -0
  108. package/resources/ecc/commands/instinct-status.md +59 -0
  109. package/resources/ecc/commands/jira.md +106 -0
  110. package/resources/ecc/commands/kotlin-build.md +174 -0
  111. package/resources/ecc/commands/kotlin-review.md +140 -0
  112. package/resources/ecc/commands/kotlin-test.md +312 -0
  113. package/resources/ecc/commands/learn-eval.md +116 -0
  114. package/resources/ecc/commands/learn.md +74 -0
  115. package/resources/ecc/commands/loop-start.md +36 -0
  116. package/resources/ecc/commands/loop-status.md +77 -0
  117. package/resources/ecc/commands/model-route.md +30 -0
  118. package/resources/ecc/commands/multi-backend.md +162 -0
  119. package/resources/ecc/commands/multi-execute.md +319 -0
  120. package/resources/ecc/commands/multi-frontend.md +162 -0
  121. package/resources/ecc/commands/multi-plan.md +272 -0
  122. package/resources/ecc/commands/multi-workflow.md +195 -0
  123. package/resources/ecc/commands/plan-prd.md +160 -0
  124. package/resources/ecc/commands/plan.md +200 -0
  125. package/resources/ecc/commands/pm2.md +276 -0
  126. package/resources/ecc/commands/pr.md +184 -0
  127. package/resources/ecc/commands/project-init.md +86 -0
  128. package/resources/ecc/commands/projects.md +39 -0
  129. package/resources/ecc/commands/promote.md +41 -0
  130. package/resources/ecc/commands/prp-commit.md +112 -0
  131. package/resources/ecc/commands/prp-implement.md +385 -0
  132. package/resources/ecc/commands/prp-plan.md +502 -0
  133. package/resources/ecc/commands/prp-pr.md +184 -0
  134. package/resources/ecc/commands/prp-prd.md +447 -0
  135. package/resources/ecc/commands/prune.md +31 -0
  136. package/resources/ecc/commands/python-review.md +297 -0
  137. package/resources/ecc/commands/quality-gate.md +33 -0
  138. package/resources/ecc/commands/refactor-clean.md +84 -0
  139. package/resources/ecc/commands/resume-session.md +156 -0
  140. package/resources/ecc/commands/review-pr.md +37 -0
  141. package/resources/ecc/commands/rust-build.md +187 -0
  142. package/resources/ecc/commands/rust-review.md +142 -0
  143. package/resources/ecc/commands/rust-test.md +308 -0
  144. package/resources/ecc/commands/santa-loop.md +175 -0
  145. package/resources/ecc/commands/save-session.md +275 -0
  146. package/resources/ecc/commands/security-scan.md +92 -0
  147. package/resources/ecc/commands/sessions.md +339 -0
  148. package/resources/ecc/commands/setup-pm.md +80 -0
  149. package/resources/ecc/commands/skill-create.md +174 -0
  150. package/resources/ecc/commands/skill-health.md +54 -0
  151. package/resources/ecc/commands/test-coverage.md +73 -0
  152. package/resources/ecc/commands/update-codemaps.md +76 -0
  153. package/resources/ecc/commands/update-docs.md +88 -0
  154. package/resources/ecc/rules/README.md +120 -0
  155. package/resources/ecc/rules/angular/coding-style.md +182 -0
  156. package/resources/ecc/rules/angular/hooks.md +25 -0
  157. package/resources/ecc/rules/angular/patterns.md +249 -0
  158. package/resources/ecc/rules/angular/security.md +87 -0
  159. package/resources/ecc/rules/angular/testing.md +164 -0
  160. package/resources/ecc/rules/arkts/coding-style.md +153 -0
  161. package/resources/ecc/rules/arkts/hooks.md +135 -0
  162. package/resources/ecc/rules/arkts/patterns.md +236 -0
  163. package/resources/ecc/rules/arkts/security.md +141 -0
  164. package/resources/ecc/rules/arkts/testing.md +126 -0
  165. package/resources/ecc/rules/{common-agents.md → common/agents.md} +2 -4
  166. package/resources/ecc/rules/common/code-review.md +124 -0
  167. package/resources/ecc/rules/{common-coding-style.md → common/coding-style.md} +42 -4
  168. package/resources/ecc/rules/common/development-workflow.md +44 -0
  169. package/resources/ecc/rules/{common-git-workflow.md → common/git-workflow.md} +1 -5
  170. package/resources/ecc/rules/{common-hooks.md → common/hooks.md} +0 -4
  171. package/resources/ecc/rules/{common-patterns.md → common/patterns.md} +0 -4
  172. package/resources/ecc/rules/{common-performance.md → common/performance.md} +0 -4
  173. package/resources/ecc/rules/{common-security.md → common/security.md} +0 -4
  174. package/resources/ecc/rules/{common-testing.md → common/testing.md} +28 -4
  175. package/resources/ecc/rules/cpp/coding-style.md +44 -0
  176. package/resources/ecc/rules/cpp/hooks.md +39 -0
  177. package/resources/ecc/rules/cpp/patterns.md +51 -0
  178. package/resources/ecc/rules/cpp/security.md +51 -0
  179. package/resources/ecc/rules/cpp/testing.md +44 -0
  180. package/resources/ecc/rules/csharp/coding-style.md +72 -0
  181. package/resources/ecc/rules/csharp/hooks.md +25 -0
  182. package/resources/ecc/rules/csharp/patterns.md +50 -0
  183. package/resources/ecc/rules/csharp/security.md +58 -0
  184. package/resources/ecc/rules/csharp/testing.md +46 -0
  185. package/resources/ecc/rules/dart/coding-style.md +159 -0
  186. package/resources/ecc/rules/dart/hooks.md +66 -0
  187. package/resources/ecc/rules/dart/patterns.md +261 -0
  188. package/resources/ecc/rules/dart/security.md +135 -0
  189. package/resources/ecc/rules/dart/testing.md +215 -0
  190. package/resources/ecc/rules/fsharp/coding-style.md +112 -0
  191. package/resources/ecc/rules/fsharp/hooks.md +26 -0
  192. package/resources/ecc/rules/fsharp/patterns.md +111 -0
  193. package/resources/ecc/rules/fsharp/security.md +76 -0
  194. package/resources/ecc/rules/fsharp/testing.md +62 -0
  195. package/resources/ecc/rules/{golang-coding-style.md → golang/coding-style.md} +6 -5
  196. package/resources/ecc/rules/{golang-hooks.md → golang/hooks.md} +5 -4
  197. package/resources/ecc/rules/{golang-patterns.md → golang/patterns.md} +5 -4
  198. package/resources/ecc/rules/{golang-security.md → golang/security.md} +5 -4
  199. package/resources/ecc/rules/{golang-testing.md → golang/testing.md} +5 -4
  200. package/resources/ecc/rules/java/coding-style.md +114 -0
  201. package/resources/ecc/rules/java/hooks.md +18 -0
  202. package/resources/ecc/rules/java/patterns.md +147 -0
  203. package/resources/ecc/rules/java/security.md +101 -0
  204. package/resources/ecc/rules/java/testing.md +133 -0
  205. package/resources/ecc/rules/kotlin/coding-style.md +86 -0
  206. package/resources/ecc/rules/{kotlin-hooks.md → kotlin/hooks.md} +5 -4
  207. package/resources/ecc/rules/kotlin/patterns.md +146 -0
  208. package/resources/ecc/rules/kotlin/security.md +82 -0
  209. package/resources/ecc/rules/kotlin/testing.md +128 -0
  210. package/resources/ecc/rules/perl/coding-style.md +46 -0
  211. package/resources/ecc/rules/perl/hooks.md +22 -0
  212. package/resources/ecc/rules/perl/patterns.md +76 -0
  213. package/resources/ecc/rules/perl/security.md +69 -0
  214. package/resources/ecc/rules/perl/testing.md +54 -0
  215. package/resources/ecc/rules/php/coding-style.md +40 -0
  216. package/resources/ecc/rules/{php-hooks.md → php/hooks.md} +7 -4
  217. package/resources/ecc/rules/php/patterns.md +33 -0
  218. package/resources/ecc/rules/php/security.md +37 -0
  219. package/resources/ecc/rules/php/testing.md +39 -0
  220. package/resources/ecc/rules/{python-coding-style.md → python/coding-style.md} +4 -4
  221. package/resources/ecc/rules/python/fastapi.md +58 -0
  222. package/resources/ecc/rules/{python-hooks.md → python/hooks.md} +4 -4
  223. package/resources/ecc/rules/{python-patterns.md → python/patterns.md} +4 -4
  224. package/resources/ecc/rules/{python-security.md → python/security.md} +4 -4
  225. package/resources/ecc/rules/{python-testing.md → python/testing.md} +4 -4
  226. package/resources/ecc/rules/ruby/coding-style.md +46 -0
  227. package/resources/ecc/rules/ruby/hooks.md +37 -0
  228. package/resources/ecc/rules/ruby/patterns.md +44 -0
  229. package/resources/ecc/rules/ruby/security.md +51 -0
  230. package/resources/ecc/rules/ruby/testing.md +51 -0
  231. package/resources/ecc/rules/rust/coding-style.md +151 -0
  232. package/resources/ecc/rules/rust/hooks.md +16 -0
  233. package/resources/ecc/rules/rust/patterns.md +168 -0
  234. package/resources/ecc/rules/rust/security.md +141 -0
  235. package/resources/ecc/rules/rust/testing.md +154 -0
  236. package/resources/ecc/rules/{swift-coding-style.md → swift/coding-style.md} +6 -6
  237. package/resources/ecc/rules/swift/hooks.md +20 -0
  238. package/resources/ecc/rules/{swift-patterns.md → swift/patterns.md} +5 -5
  239. package/resources/ecc/rules/{swift-security.md → swift/security.md} +7 -7
  240. package/resources/ecc/rules/{swift-testing.md → swift/testing.md} +5 -5
  241. package/resources/ecc/rules/typescript/coding-style.md +199 -0
  242. package/resources/ecc/rules/{typescript-hooks.md → typescript/hooks.md} +6 -4
  243. package/resources/ecc/rules/{typescript-patterns.md → typescript/patterns.md} +6 -4
  244. package/resources/ecc/rules/{typescript-security.md → typescript/security.md} +6 -4
  245. package/resources/ecc/rules/typescript/testing.md +18 -0
  246. package/resources/ecc/rules/web/coding-style.md +96 -0
  247. package/resources/ecc/rules/web/design-quality.md +63 -0
  248. package/resources/ecc/rules/web/hooks.md +129 -0
  249. package/resources/ecc/rules/web/patterns.md +79 -0
  250. package/resources/ecc/rules/web/performance.md +64 -0
  251. package/resources/ecc/rules/web/security.md +57 -0
  252. package/resources/ecc/rules/web/testing.md +55 -0
  253. package/resources/ecc/rules/zh/README.md +108 -0
  254. package/resources/ecc/rules/zh/agents.md +50 -0
  255. package/resources/ecc/rules/zh/code-review.md +124 -0
  256. package/resources/ecc/rules/zh/coding-style.md +48 -0
  257. package/resources/ecc/rules/zh/development-workflow.md +44 -0
  258. package/resources/ecc/rules/zh/git-workflow.md +24 -0
  259. package/resources/ecc/rules/zh/hooks.md +30 -0
  260. package/resources/ecc/rules/zh/patterns.md +31 -0
  261. package/resources/ecc/rules/zh/performance.md +55 -0
  262. package/resources/ecc/rules/zh/security.md +29 -0
  263. package/resources/ecc/rules/zh/testing.md +29 -0
  264. package/resources/ecc/skills/accessibility/SKILL.md +146 -0
  265. package/resources/ecc/skills/agent-architecture-audit/SKILL.md +256 -0
  266. package/resources/ecc/skills/agent-eval/SKILL.md +145 -0
  267. package/resources/ecc/skills/agent-harness-construction/SKILL.md +73 -0
  268. package/resources/ecc/skills/agent-introspection-debugging/SKILL.md +1 -0
  269. package/resources/ecc/skills/agent-payment-x402/SKILL.md +224 -0
  270. package/resources/ecc/skills/agent-sort/SKILL.md +1 -0
  271. package/resources/ecc/skills/agentic-engineering/SKILL.md +63 -0
  272. package/resources/ecc/skills/agentic-os/SKILL.md +387 -0
  273. package/resources/ecc/skills/ai-first-engineering/SKILL.md +51 -0
  274. package/resources/ecc/skills/ai-regression-testing/SKILL.md +385 -0
  275. package/resources/ecc/skills/android-clean-architecture/SKILL.md +339 -0
  276. package/resources/ecc/skills/angular-developer/SKILL.md +154 -0
  277. package/resources/ecc/skills/angular-developer/references/angular-animations.md +160 -0
  278. package/resources/ecc/skills/angular-developer/references/angular-aria.md +410 -0
  279. package/resources/ecc/skills/angular-developer/references/cli.md +86 -0
  280. package/resources/ecc/skills/angular-developer/references/component-harnesses.md +59 -0
  281. package/resources/ecc/skills/angular-developer/references/component-styling.md +91 -0
  282. package/resources/ecc/skills/angular-developer/references/components.md +117 -0
  283. package/resources/ecc/skills/angular-developer/references/creating-services.md +97 -0
  284. package/resources/ecc/skills/angular-developer/references/data-resolvers.md +69 -0
  285. package/resources/ecc/skills/angular-developer/references/define-routes.md +67 -0
  286. package/resources/ecc/skills/angular-developer/references/defining-providers.md +72 -0
  287. package/resources/ecc/skills/angular-developer/references/di-fundamentals.md +120 -0
  288. package/resources/ecc/skills/angular-developer/references/e2e-testing.md +56 -0
  289. package/resources/ecc/skills/angular-developer/references/effects.md +83 -0
  290. package/resources/ecc/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  291. package/resources/ecc/skills/angular-developer/references/host-elements.md +80 -0
  292. package/resources/ecc/skills/angular-developer/references/injection-context.md +63 -0
  293. package/resources/ecc/skills/angular-developer/references/inputs.md +101 -0
  294. package/resources/ecc/skills/angular-developer/references/linked-signal.md +59 -0
  295. package/resources/ecc/skills/angular-developer/references/loading-strategies.md +61 -0
  296. package/resources/ecc/skills/angular-developer/references/mcp.md +108 -0
  297. package/resources/ecc/skills/angular-developer/references/navigate-to-routes.md +69 -0
  298. package/resources/ecc/skills/angular-developer/references/outputs.md +86 -0
  299. package/resources/ecc/skills/angular-developer/references/reactive-forms.md +122 -0
  300. package/resources/ecc/skills/angular-developer/references/rendering-strategies.md +44 -0
  301. package/resources/ecc/skills/angular-developer/references/resource.md +77 -0
  302. package/resources/ecc/skills/angular-developer/references/route-animations.md +56 -0
  303. package/resources/ecc/skills/angular-developer/references/route-guards.md +52 -0
  304. package/resources/ecc/skills/angular-developer/references/router-lifecycle.md +45 -0
  305. package/resources/ecc/skills/angular-developer/references/router-testing.md +87 -0
  306. package/resources/ecc/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  307. package/resources/ecc/skills/angular-developer/references/signal-forms.md +795 -0
  308. package/resources/ecc/skills/angular-developer/references/signals-overview.md +94 -0
  309. package/resources/ecc/skills/angular-developer/references/tailwind-css.md +69 -0
  310. package/resources/ecc/skills/angular-developer/references/template-driven-forms.md +114 -0
  311. package/resources/ecc/skills/angular-developer/references/testing-fundamentals.md +65 -0
  312. package/resources/ecc/skills/api-connector-builder/SKILL.md +120 -0
  313. package/resources/ecc/skills/api-design/SKILL.md +1 -0
  314. package/resources/ecc/skills/architecture-decision-records/SKILL.md +179 -0
  315. package/resources/ecc/skills/article-writing/SKILL.md +1 -0
  316. package/resources/ecc/skills/automation-audit-ops/SKILL.md +142 -0
  317. package/resources/ecc/skills/autonomous-agent-harness/SKILL.md +273 -0
  318. package/resources/ecc/skills/autonomous-loops/SKILL.md +610 -0
  319. package/resources/ecc/skills/backend-patterns/SKILL.md +8 -44
  320. package/resources/ecc/skills/benchmark/SKILL.md +93 -0
  321. package/resources/ecc/skills/blueprint/SKILL.md +105 -0
  322. package/resources/ecc/skills/brand-voice/SKILL.md +1 -0
  323. package/resources/ecc/skills/browser-qa/SKILL.md +87 -0
  324. package/resources/ecc/skills/bun-runtime/SKILL.md +1 -0
  325. package/resources/ecc/skills/canary-watch/SKILL.md +99 -0
  326. package/resources/ecc/skills/carrier-relationship-management/SKILL.md +212 -0
  327. package/resources/ecc/skills/cisco-ios-patterns/SKILL.md +163 -0
  328. package/resources/ecc/skills/ck/SKILL.md +147 -0
  329. package/resources/ecc/skills/ck/commands/forget.mjs +44 -0
  330. package/resources/ecc/skills/ck/commands/info.mjs +24 -0
  331. package/resources/ecc/skills/ck/commands/init.mjs +143 -0
  332. package/resources/ecc/skills/ck/commands/list.mjs +40 -0
  333. package/resources/ecc/skills/ck/commands/migrate.mjs +202 -0
  334. package/resources/ecc/skills/ck/commands/resume.mjs +36 -0
  335. package/resources/ecc/skills/ck/commands/save.mjs +210 -0
  336. package/resources/ecc/skills/ck/commands/shared.mjs +387 -0
  337. package/resources/ecc/skills/ck/hooks/session-start.mjs +224 -0
  338. package/resources/ecc/skills/claude-devfleet/SKILL.md +103 -0
  339. package/resources/ecc/skills/click-path-audit/SKILL.md +244 -0
  340. package/resources/ecc/skills/clickhouse-io/SKILL.md +439 -0
  341. package/resources/ecc/skills/code-tour/SKILL.md +236 -0
  342. package/resources/ecc/skills/codebase-onboarding/SKILL.md +233 -0
  343. package/resources/ecc/skills/coding-standards/SKILL.md +1 -0
  344. package/resources/ecc/skills/compose-multiplatform-patterns/SKILL.md +299 -0
  345. package/resources/ecc/skills/configure-ecc/SKILL.md +384 -0
  346. package/resources/ecc/skills/connections-optimizer/SKILL.md +189 -0
  347. package/resources/ecc/skills/content-engine/SKILL.md +1 -0
  348. package/resources/ecc/skills/content-hash-cache-pattern/SKILL.md +161 -0
  349. package/resources/ecc/skills/context-budget/SKILL.md +135 -0
  350. package/resources/ecc/skills/continuous-agent-loop/SKILL.md +45 -0
  351. package/resources/ecc/skills/continuous-learning/SKILL.md +131 -0
  352. package/resources/ecc/skills/continuous-learning/config.json +18 -0
  353. package/resources/ecc/skills/continuous-learning/evaluate-session.sh +69 -0
  354. package/resources/ecc/skills/continuous-learning-v2/SKILL.md +360 -0
  355. package/resources/ecc/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
  356. package/resources/ecc/skills/continuous-learning-v2/agents/observer.md +198 -0
  357. package/resources/ecc/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  358. package/resources/ecc/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  359. package/resources/ecc/skills/continuous-learning-v2/config.json +8 -0
  360. package/resources/ecc/skills/continuous-learning-v2/hooks/observe.sh +476 -0
  361. package/resources/ecc/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
  362. package/resources/ecc/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
  363. package/resources/ecc/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  364. package/resources/ecc/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  365. package/resources/ecc/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
  366. package/resources/ecc/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  367. package/resources/ecc/skills/cost-tracking/SKILL.md +147 -0
  368. package/resources/ecc/skills/council/SKILL.md +203 -0
  369. package/resources/ecc/skills/cpp-coding-standards/SKILL.md +723 -0
  370. package/resources/ecc/skills/cpp-testing/SKILL.md +324 -0
  371. package/resources/ecc/skills/crosspost/SKILL.md +1 -0
  372. package/resources/ecc/skills/csharp-testing/SKILL.md +321 -0
  373. package/resources/ecc/skills/customer-billing-ops/SKILL.md +140 -0
  374. package/resources/ecc/skills/customs-trade-compliance/SKILL.md +263 -0
  375. package/resources/ecc/skills/dart-flutter-patterns/SKILL.md +563 -0
  376. package/resources/ecc/skills/dashboard-builder/SKILL.md +108 -0
  377. package/resources/ecc/skills/data-scraper-agent/SKILL.md +764 -0
  378. package/resources/ecc/skills/database-migrations/SKILL.md +429 -0
  379. package/resources/ecc/skills/deep-research/SKILL.md +5 -0
  380. package/resources/ecc/skills/defi-amm-security/SKILL.md +166 -0
  381. package/resources/ecc/skills/deployment-patterns/SKILL.md +427 -0
  382. package/resources/ecc/skills/design-system/SKILL.md +82 -0
  383. package/resources/ecc/skills/django-celery/SKILL.md +457 -0
  384. package/resources/ecc/skills/django-patterns/SKILL.md +734 -0
  385. package/resources/ecc/skills/django-security/SKILL.md +593 -0
  386. package/resources/ecc/skills/django-tdd/SKILL.md +729 -0
  387. package/resources/ecc/skills/django-verification/SKILL.md +469 -0
  388. package/resources/ecc/skills/dmux-workflows/SKILL.md +52 -4
  389. package/resources/ecc/skills/docker-patterns/SKILL.md +364 -0
  390. package/resources/ecc/skills/documentation-lookup/SKILL.md +1 -0
  391. package/resources/ecc/skills/dotnet-patterns/SKILL.md +321 -0
  392. package/resources/ecc/skills/e2e-testing/SKILL.md +1 -0
  393. package/resources/ecc/skills/ecc-guide/SKILL.md +189 -0
  394. package/resources/ecc/skills/ecc-tools-cost-audit/SKILL.md +160 -0
  395. package/resources/ecc/skills/email-ops/SKILL.md +121 -0
  396. package/resources/ecc/skills/energy-procurement/SKILL.md +228 -0
  397. package/resources/ecc/skills/enterprise-agent-ops/SKILL.md +50 -0
  398. package/resources/ecc/skills/error-handling/SKILL.md +376 -0
  399. package/resources/ecc/skills/eval-harness/SKILL.md +36 -1
  400. package/resources/ecc/skills/evm-token-decimals/SKILL.md +130 -0
  401. package/resources/ecc/skills/exa-search/SKILL.md +18 -80
  402. package/resources/ecc/skills/fal-ai-media/SKILL.md +32 -20
  403. package/resources/ecc/skills/fastapi-patterns/SKILL.md +327 -0
  404. package/resources/ecc/skills/finance-billing-ops/SKILL.md +127 -0
  405. package/resources/ecc/skills/flox-environments/SKILL.md +496 -0
  406. package/resources/ecc/skills/flutter-dart-code-review/SKILL.md +435 -0
  407. package/resources/ecc/skills/foundation-models-on-device/SKILL.md +243 -0
  408. package/resources/ecc/skills/frontend-design-direction/SKILL.md +92 -0
  409. package/resources/ecc/skills/frontend-patterns/SKILL.md +1 -6
  410. package/resources/ecc/skills/frontend-slides/SKILL.md +2 -1
  411. package/resources/ecc/skills/frontend-slides/animation-patterns.md +122 -0
  412. package/resources/ecc/skills/frontend-slides/html-template.md +419 -0
  413. package/resources/ecc/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  414. package/resources/ecc/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  415. package/resources/ecc/skills/frontend-slides/viewport-base.css +153 -0
  416. package/resources/ecc/skills/fsharp-testing/SKILL.md +280 -0
  417. package/resources/ecc/skills/gan-style-harness/SKILL.md +278 -0
  418. package/resources/ecc/skills/gateguard/SKILL.md +125 -0
  419. package/resources/ecc/skills/git-workflow/SKILL.md +715 -0
  420. package/resources/ecc/skills/github-ops/SKILL.md +144 -0
  421. package/resources/ecc/skills/golang-patterns/SKILL.md +674 -0
  422. package/resources/ecc/skills/golang-testing/SKILL.md +720 -0
  423. package/resources/ecc/skills/google-workspace-ops/SKILL.md +95 -0
  424. package/resources/ecc/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  425. package/resources/ecc/skills/healthcare-emr-patterns/SKILL.md +159 -0
  426. package/resources/ecc/skills/healthcare-eval-harness/SKILL.md +207 -0
  427. package/resources/ecc/skills/healthcare-phi-compliance/SKILL.md +145 -0
  428. package/resources/ecc/skills/hermes-imports/SKILL.md +88 -0
  429. package/resources/ecc/skills/hexagonal-architecture/SKILL.md +276 -0
  430. package/resources/ecc/skills/hipaa-compliance/SKILL.md +78 -0
  431. package/resources/ecc/skills/homelab-network-readiness/SKILL.md +169 -0
  432. package/resources/ecc/skills/homelab-network-setup/SKILL.md +129 -0
  433. package/resources/ecc/skills/homelab-pihole-dns/SKILL.md +274 -0
  434. package/resources/ecc/skills/homelab-vlan-segmentation/SKILL.md +311 -0
  435. package/resources/ecc/skills/homelab-wireguard-vpn/SKILL.md +305 -0
  436. package/resources/ecc/skills/hookify-rules/SKILL.md +128 -0
  437. package/resources/ecc/skills/inventory-demand-planning/SKILL.md +247 -0
  438. package/resources/ecc/skills/investor-materials/SKILL.md +1 -0
  439. package/resources/ecc/skills/investor-outreach/SKILL.md +1 -0
  440. package/resources/ecc/skills/ios-icon-gen/SKILL.md +157 -0
  441. package/resources/ecc/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  442. package/resources/ecc/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  443. package/resources/ecc/skills/iterative-retrieval/SKILL.md +211 -0
  444. package/resources/ecc/skills/java-coding-standards/SKILL.md +383 -0
  445. package/resources/ecc/skills/jira-integration/SKILL.md +293 -0
  446. package/resources/ecc/skills/jpa-patterns/SKILL.md +151 -0
  447. package/resources/ecc/skills/knowledge-ops/SKILL.md +154 -0
  448. package/resources/ecc/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  449. package/resources/ecc/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  450. package/resources/ecc/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  451. package/resources/ecc/skills/kotlin-patterns/SKILL.md +711 -0
  452. package/resources/ecc/skills/kotlin-testing/SKILL.md +824 -0
  453. package/resources/ecc/skills/laravel-patterns/SKILL.md +415 -0
  454. package/resources/ecc/skills/laravel-plugin-discovery/SKILL.md +229 -0
  455. package/resources/ecc/skills/laravel-security/SKILL.md +285 -0
  456. package/resources/ecc/skills/laravel-tdd/SKILL.md +283 -0
  457. package/resources/ecc/skills/laravel-verification/SKILL.md +179 -0
  458. package/resources/ecc/skills/lead-intelligence/SKILL.md +321 -0
  459. package/resources/ecc/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  460. package/resources/ecc/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  461. package/resources/ecc/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  462. package/resources/ecc/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  463. package/resources/ecc/skills/liquid-glass-design/SKILL.md +279 -0
  464. package/resources/ecc/skills/llm-trading-agent-security/SKILL.md +146 -0
  465. package/resources/ecc/skills/logistics-exception-management/SKILL.md +222 -0
  466. package/resources/ecc/skills/make-interfaces-feel-better/SKILL.md +151 -0
  467. package/resources/ecc/skills/manim-video/SKILL.md +89 -0
  468. package/resources/ecc/skills/manim-video/assets/network_graph_scene.py +52 -0
  469. package/resources/ecc/skills/market-research/SKILL.md +1 -0
  470. package/resources/ecc/skills/mcp-server-patterns/SKILL.md +3 -0
  471. package/resources/ecc/skills/messages-ops/SKILL.md +104 -0
  472. package/resources/ecc/skills/mle-workflow/SKILL.md +1 -1
  473. package/resources/ecc/skills/motion-advanced/SKILL.md +596 -0
  474. package/resources/ecc/skills/motion-foundations/SKILL.md +299 -0
  475. package/resources/ecc/skills/motion-patterns/SKILL.md +435 -0
  476. package/resources/ecc/skills/motion-ui/SKILL.md +575 -0
  477. package/resources/ecc/skills/mysql-patterns/SKILL.md +412 -0
  478. package/resources/ecc/skills/nanoclaw-repl/SKILL.md +33 -0
  479. package/resources/ecc/skills/nestjs-patterns/SKILL.md +230 -0
  480. package/resources/ecc/skills/netmiko-ssh-automation/SKILL.md +173 -0
  481. package/resources/ecc/skills/network-bgp-diagnostics/SKILL.md +167 -0
  482. package/resources/ecc/skills/network-config-validation/SKILL.md +210 -0
  483. package/resources/ecc/skills/network-interface-health/SKILL.md +152 -0
  484. package/resources/ecc/skills/nextjs-turbopack/SKILL.md +1 -0
  485. package/resources/ecc/skills/nodejs-keccak256/SKILL.md +102 -0
  486. package/resources/ecc/skills/nutrient-document-processing/SKILL.md +167 -0
  487. package/resources/ecc/skills/nuxt4-patterns/SKILL.md +100 -0
  488. package/resources/ecc/skills/openclaw-persona-forge/SKILL.md +288 -0
  489. package/resources/ecc/skills/openclaw-persona-forge/gacha.py +224 -0
  490. package/resources/ecc/skills/openclaw-persona-forge/gacha.sh +5 -0
  491. package/resources/ecc/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  492. package/resources/ecc/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  493. package/resources/ecc/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  494. package/resources/ecc/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  495. package/resources/ecc/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  496. package/resources/ecc/skills/openclaw-persona-forge/references/output-template.md +166 -0
  497. package/resources/ecc/skills/opensource-pipeline/SKILL.md +255 -0
  498. package/resources/ecc/skills/perl-patterns/SKILL.md +504 -0
  499. package/resources/ecc/skills/perl-security/SKILL.md +503 -0
  500. package/resources/ecc/skills/perl-testing/SKILL.md +475 -0
  501. package/resources/ecc/skills/plan-orchestrate/SKILL.md +262 -0
  502. package/resources/ecc/skills/plankton-code-quality/SKILL.md +236 -0
  503. package/resources/ecc/skills/postgres-patterns/SKILL.md +147 -0
  504. package/resources/ecc/skills/product-capability/SKILL.md +1 -0
  505. package/resources/ecc/skills/product-lens/SKILL.md +92 -0
  506. package/resources/ecc/skills/production-audit/SKILL.md +206 -0
  507. package/resources/ecc/skills/production-scheduling/SKILL.md +238 -0
  508. package/resources/ecc/skills/project-flow-ops/SKILL.md +111 -0
  509. package/resources/ecc/skills/prompt-optimizer/SKILL.md +398 -0
  510. package/resources/ecc/skills/python-patterns/SKILL.md +750 -0
  511. package/resources/ecc/skills/python-testing/SKILL.md +816 -0
  512. package/resources/ecc/skills/pytorch-patterns/SKILL.md +396 -0
  513. package/resources/ecc/skills/quality-nonconformance/SKILL.md +260 -0
  514. package/resources/ecc/skills/quarkus-patterns/SKILL.md +722 -0
  515. package/resources/ecc/skills/quarkus-security/SKILL.md +467 -0
  516. package/resources/ecc/skills/quarkus-tdd/SKILL.md +811 -0
  517. package/resources/ecc/skills/quarkus-verification/SKILL.md +479 -0
  518. package/resources/ecc/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
  519. package/resources/ecc/skills/redis-patterns/SKILL.md +403 -0
  520. package/resources/ecc/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  521. package/resources/ecc/skills/remotion-video-creation/SKILL.md +43 -0
  522. package/resources/ecc/skills/remotion-video-creation/rules/3d.md +86 -0
  523. package/resources/ecc/skills/remotion-video-creation/rules/animations.md +29 -0
  524. package/resources/ecc/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  525. package/resources/ecc/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  526. package/resources/ecc/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  527. package/resources/ecc/skills/remotion-video-creation/rules/assets.md +78 -0
  528. package/resources/ecc/skills/remotion-video-creation/rules/audio.md +172 -0
  529. package/resources/ecc/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  530. package/resources/ecc/skills/remotion-video-creation/rules/can-decode.md +75 -0
  531. package/resources/ecc/skills/remotion-video-creation/rules/charts.md +58 -0
  532. package/resources/ecc/skills/remotion-video-creation/rules/compositions.md +146 -0
  533. package/resources/ecc/skills/remotion-video-creation/rules/display-captions.md +126 -0
  534. package/resources/ecc/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  535. package/resources/ecc/skills/remotion-video-creation/rules/fonts.md +152 -0
  536. package/resources/ecc/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  537. package/resources/ecc/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  538. package/resources/ecc/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  539. package/resources/ecc/skills/remotion-video-creation/rules/gifs.md +138 -0
  540. package/resources/ecc/skills/remotion-video-creation/rules/images.md +130 -0
  541. package/resources/ecc/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  542. package/resources/ecc/skills/remotion-video-creation/rules/lottie.md +67 -0
  543. package/resources/ecc/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  544. package/resources/ecc/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  545. package/resources/ecc/skills/remotion-video-creation/rules/sequencing.md +106 -0
  546. package/resources/ecc/skills/remotion-video-creation/rules/tailwind.md +11 -0
  547. package/resources/ecc/skills/remotion-video-creation/rules/text-animations.md +20 -0
  548. package/resources/ecc/skills/remotion-video-creation/rules/timing.md +179 -0
  549. package/resources/ecc/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  550. package/resources/ecc/skills/remotion-video-creation/rules/transitions.md +122 -0
  551. package/resources/ecc/skills/remotion-video-creation/rules/trimming.md +52 -0
  552. package/resources/ecc/skills/remotion-video-creation/rules/videos.md +171 -0
  553. package/resources/ecc/skills/repo-scan/SKILL.md +78 -0
  554. package/resources/ecc/skills/research-ops/SKILL.md +112 -0
  555. package/resources/ecc/skills/returns-reverse-logistics/SKILL.md +240 -0
  556. package/resources/ecc/skills/rules-distill/SKILL.md +264 -0
  557. package/resources/ecc/skills/rules-distill/scripts/scan-rules.sh +58 -0
  558. package/resources/ecc/skills/rules-distill/scripts/scan-skills.sh +129 -0
  559. package/resources/ecc/skills/rust-patterns/SKILL.md +499 -0
  560. package/resources/ecc/skills/rust-testing/SKILL.md +500 -0
  561. package/resources/ecc/skills/safety-guard/SKILL.md +75 -0
  562. package/resources/ecc/skills/santa-method/SKILL.md +306 -0
  563. package/resources/ecc/skills/scientific-db-pubmed-database/SKILL.md +175 -0
  564. package/resources/ecc/skills/scientific-db-uspto-database/SKILL.md +177 -0
  565. package/resources/ecc/skills/scientific-pkg-gget/SKILL.md +166 -0
  566. package/resources/ecc/skills/scientific-thinking-literature-review/SKILL.md +192 -0
  567. package/resources/ecc/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  568. package/resources/ecc/skills/search-first/SKILL.md +182 -0
  569. package/resources/ecc/skills/security-bounty-hunter/SKILL.md +99 -0
  570. package/resources/ecc/skills/security-review/SKILL.md +11 -2
  571. package/resources/ecc/skills/security-review/cloud-infrastructure-security.md +361 -0
  572. package/resources/ecc/skills/security-scan/SKILL.md +165 -0
  573. package/resources/ecc/skills/seo/SKILL.md +154 -0
  574. package/resources/ecc/skills/skill-comply/SKILL.md +58 -0
  575. package/resources/ecc/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  576. package/resources/ecc/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  577. package/resources/ecc/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  578. package/resources/ecc/skills/skill-comply/prompts/classifier.md +24 -0
  579. package/resources/ecc/skills/skill-comply/prompts/scenario_generator.md +62 -0
  580. package/resources/ecc/skills/skill-comply/prompts/spec_generator.md +42 -0
  581. package/resources/ecc/skills/skill-comply/pyproject.toml +15 -0
  582. package/resources/ecc/skills/skill-comply/scripts/__init__.py +0 -0
  583. package/resources/ecc/skills/skill-comply/scripts/classifier.py +85 -0
  584. package/resources/ecc/skills/skill-comply/scripts/grader.py +124 -0
  585. package/resources/ecc/skills/skill-comply/scripts/parser.py +107 -0
  586. package/resources/ecc/skills/skill-comply/scripts/report.py +170 -0
  587. package/resources/ecc/skills/skill-comply/scripts/run.py +127 -0
  588. package/resources/ecc/skills/skill-comply/scripts/runner.py +186 -0
  589. package/resources/ecc/skills/skill-comply/scripts/scenario_generator.py +70 -0
  590. package/resources/ecc/skills/skill-comply/scripts/spec_generator.py +72 -0
  591. package/resources/ecc/skills/skill-comply/scripts/utils.py +13 -0
  592. package/resources/ecc/skills/skill-comply/tests/test_grader.py +197 -0
  593. package/resources/ecc/skills/skill-comply/tests/test_parser.py +90 -0
  594. package/resources/ecc/skills/skill-comply/tests/test_runner.py +172 -0
  595. package/resources/ecc/skills/skill-scout/SKILL.md +140 -0
  596. package/resources/ecc/skills/skill-stocktake/SKILL.md +194 -0
  597. package/resources/ecc/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  598. package/resources/ecc/skills/skill-stocktake/scripts/save-results.sh +56 -0
  599. package/resources/ecc/skills/skill-stocktake/scripts/scan.sh +170 -0
  600. package/resources/ecc/skills/social-graph-ranker/SKILL.md +154 -0
  601. package/resources/ecc/skills/springboot-patterns/SKILL.md +314 -0
  602. package/resources/ecc/skills/springboot-security/SKILL.md +272 -0
  603. package/resources/ecc/skills/springboot-tdd/SKILL.md +158 -0
  604. package/resources/ecc/skills/springboot-verification/SKILL.md +231 -0
  605. package/resources/ecc/skills/strategic-compact/SKILL.md +31 -2
  606. package/resources/ecc/skills/strategic-compact/suggest-compact.sh +54 -0
  607. package/resources/ecc/skills/swift-actor-persistence/SKILL.md +143 -0
  608. package/resources/ecc/skills/swift-concurrency-6-2/SKILL.md +216 -0
  609. package/resources/ecc/skills/swift-protocol-di-testing/SKILL.md +190 -0
  610. package/resources/ecc/skills/swiftui-patterns/SKILL.md +259 -0
  611. package/resources/ecc/skills/tdd-workflow/SKILL.md +54 -0
  612. package/resources/ecc/skills/team-builder/SKILL.md +168 -0
  613. package/resources/ecc/skills/terminal-ops/SKILL.md +109 -0
  614. package/resources/ecc/skills/tinystruct-patterns/SKILL.md +131 -0
  615. package/resources/ecc/skills/tinystruct-patterns/references/architecture.md +77 -0
  616. package/resources/ecc/skills/tinystruct-patterns/references/data-handling.md +35 -0
  617. package/resources/ecc/skills/tinystruct-patterns/references/routing.md +57 -0
  618. package/resources/ecc/skills/tinystruct-patterns/references/system-usage.md +74 -0
  619. package/resources/ecc/skills/tinystruct-patterns/references/testing.md +59 -0
  620. package/resources/ecc/skills/token-budget-advisor/SKILL.md +133 -0
  621. package/resources/ecc/skills/ui-demo/SKILL.md +465 -0
  622. package/resources/ecc/skills/ui-to-vue/SKILL.md +134 -0
  623. package/resources/ecc/skills/unified-notifications-ops/SKILL.md +187 -0
  624. package/resources/ecc/skills/verification-loop/SKILL.md +1 -0
  625. package/resources/ecc/skills/video-editing/SKILL.md +4 -1
  626. package/resources/ecc/skills/videodb/SKILL.md +374 -0
  627. package/resources/ecc/skills/videodb/reference/api-reference.md +550 -0
  628. package/resources/ecc/skills/videodb/reference/capture-reference.md +407 -0
  629. package/resources/ecc/skills/videodb/reference/capture.md +101 -0
  630. package/resources/ecc/skills/videodb/reference/editor.md +443 -0
  631. package/resources/ecc/skills/videodb/reference/generative.md +331 -0
  632. package/resources/ecc/skills/videodb/reference/rtstream-reference.md +564 -0
  633. package/resources/ecc/skills/videodb/reference/rtstream.md +65 -0
  634. package/resources/ecc/skills/videodb/reference/search.md +230 -0
  635. package/resources/ecc/skills/videodb/reference/streaming.md +406 -0
  636. package/resources/ecc/skills/videodb/reference/use-cases.md +118 -0
  637. package/resources/ecc/skills/videodb/scripts/ws_listener.py +282 -0
  638. package/resources/ecc/skills/visa-doc-translate/README.md +86 -0
  639. package/resources/ecc/skills/visa-doc-translate/SKILL.md +117 -0
  640. package/resources/ecc/skills/vite-patterns/SKILL.md +449 -0
  641. package/resources/ecc/skills/windows-desktop-e2e/SKILL.md +788 -0
  642. package/resources/ecc/skills/workspace-surface-audit/SKILL.md +125 -0
  643. package/resources/ecc/skills/x-api/SKILL.md +5 -0
  644. package/resources/ecc/agents/architect.json +0 -16
  645. package/resources/ecc/agents/build-error-resolver.json +0 -17
  646. package/resources/ecc/agents/chief-of-staff.json +0 -17
  647. package/resources/ecc/agents/code-reviewer.json +0 -16
  648. package/resources/ecc/agents/database-reviewer.json +0 -16
  649. package/resources/ecc/agents/doc-updater.json +0 -16
  650. package/resources/ecc/agents/e2e-runner.json +0 -17
  651. package/resources/ecc/agents/go-build-resolver.json +0 -17
  652. package/resources/ecc/agents/go-reviewer.json +0 -16
  653. package/resources/ecc/agents/harness-optimizer.json +0 -15
  654. package/resources/ecc/agents/loop-operator.json +0 -16
  655. package/resources/ecc/agents/planner.json +0 -15
  656. package/resources/ecc/agents/python-reviewer.json +0 -16
  657. package/resources/ecc/agents/refactor-cleaner.json +0 -17
  658. package/resources/ecc/agents/security-reviewer.json +0 -16
  659. package/resources/ecc/agents/tdd-guide.json +0 -17
  660. package/resources/ecc/commands/add-language-rules.md +0 -39
  661. package/resources/ecc/commands/database-migration.md +0 -36
  662. package/resources/ecc/commands/feature-development.md +0 -38
  663. package/resources/ecc/rules/common-development-workflow.md +0 -33
  664. package/resources/ecc/rules/kotlin-coding-style.md +0 -39
  665. package/resources/ecc/rules/kotlin-patterns.md +0 -50
  666. package/resources/ecc/rules/kotlin-security.md +0 -58
  667. package/resources/ecc/rules/kotlin-testing.md +0 -38
  668. package/resources/ecc/rules/php-coding-style.md +0 -25
  669. package/resources/ecc/rules/php-patterns.md +0 -23
  670. package/resources/ecc/rules/php-security.md +0 -24
  671. package/resources/ecc/rules/php-testing.md +0 -26
  672. package/resources/ecc/rules/swift-hooks.md +0 -20
  673. package/resources/ecc/rules/typescript-coding-style.md +0 -63
  674. package/resources/ecc/rules/typescript-testing.md +0 -16
  675. package/resources/ecc/skills/agent-introspection-debugging/agents/openai.yaml +0 -7
  676. package/resources/ecc/skills/agent-sort/agents/openai.yaml +0 -7
  677. package/resources/ecc/skills/api-design/agents/openai.yaml +0 -7
  678. package/resources/ecc/skills/article-writing/agents/openai.yaml +0 -7
  679. package/resources/ecc/skills/backend-patterns/agents/openai.yaml +0 -7
  680. package/resources/ecc/skills/brand-voice/agents/openai.yaml +0 -7
  681. package/resources/ecc/skills/bun-runtime/agents/openai.yaml +0 -7
  682. package/resources/ecc/skills/coding-standards/agents/openai.yaml +0 -7
  683. package/resources/ecc/skills/content-engine/agents/openai.yaml +0 -7
  684. package/resources/ecc/skills/crosspost/agents/openai.yaml +0 -7
  685. package/resources/ecc/skills/deep-research/agents/openai.yaml +0 -7
  686. package/resources/ecc/skills/dmux-workflows/agents/openai.yaml +0 -7
  687. package/resources/ecc/skills/documentation-lookup/agents/openai.yaml +0 -7
  688. package/resources/ecc/skills/e2e-testing/agents/openai.yaml +0 -7
  689. package/resources/ecc/skills/eval-harness/agents/openai.yaml +0 -7
  690. package/resources/ecc/skills/everything-claude-code/SKILL.md +0 -442
  691. package/resources/ecc/skills/everything-claude-code/agents/openai.yaml +0 -7
  692. package/resources/ecc/skills/exa-search/agents/openai.yaml +0 -7
  693. package/resources/ecc/skills/fal-ai-media/agents/openai.yaml +0 -7
  694. package/resources/ecc/skills/frontend-patterns/agents/openai.yaml +0 -7
  695. package/resources/ecc/skills/frontend-slides/agents/openai.yaml +0 -7
  696. package/resources/ecc/skills/investor-materials/agents/openai.yaml +0 -7
  697. package/resources/ecc/skills/investor-outreach/agents/openai.yaml +0 -7
  698. package/resources/ecc/skills/market-research/agents/openai.yaml +0 -7
  699. package/resources/ecc/skills/mcp-server-patterns/agents/openai.yaml +0 -7
  700. package/resources/ecc/skills/mle-workflow/agents/openai.yaml +0 -7
  701. package/resources/ecc/skills/nextjs-turbopack/agents/openai.yaml +0 -7
  702. package/resources/ecc/skills/product-capability/agents/openai.yaml +0 -7
  703. package/resources/ecc/skills/security-review/agents/openai.yaml +0 -7
  704. package/resources/ecc/skills/strategic-compact/agents/openai.yaml +0 -7
  705. package/resources/ecc/skills/tdd-workflow/agents/openai.yaml +0 -7
  706. package/resources/ecc/skills/verification-loop/agents/openai.yaml +0 -7
  707. package/resources/ecc/skills/video-editing/agents/openai.yaml +0 -7
  708. package/resources/ecc/skills/x-api/agents/openai.yaml +0 -7
@@ -0,0 +1,107 @@
1
+ """Parse observation traces (JSONL) and compliance specs (YAML)."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import json
6
+ from dataclasses import dataclass
7
+ from pathlib import Path
8
+
9
+ import yaml
10
+
11
+
12
+ @dataclass(frozen=True)
13
+ class ObservationEvent:
14
+ timestamp: str
15
+ event: str
16
+ tool: str
17
+ session: str
18
+ input: str
19
+ output: str
20
+
21
+
22
+ @dataclass(frozen=True)
23
+ class Detector:
24
+ description: str
25
+ after_step: str | None = None
26
+ before_step: str | None = None
27
+
28
+
29
+ @dataclass(frozen=True)
30
+ class Step:
31
+ id: str
32
+ description: str
33
+ required: bool
34
+ detector: Detector
35
+
36
+
37
+ @dataclass(frozen=True)
38
+ class ComplianceSpec:
39
+ id: str
40
+ name: str
41
+ source_rule: str
42
+ version: str
43
+ steps: tuple[Step, ...]
44
+ threshold_promote_to_hook: float
45
+
46
+
47
+ def parse_trace(path: Path) -> list[ObservationEvent]:
48
+ """Parse a JSONL observation trace file into sorted events."""
49
+ if not path.is_file():
50
+ raise FileNotFoundError(f"Trace file not found: {path}")
51
+
52
+ text = path.read_text().strip()
53
+ if not text:
54
+ return []
55
+
56
+ events: list[ObservationEvent] = []
57
+ for i, line in enumerate(text.splitlines(), 1):
58
+ try:
59
+ raw = json.loads(line)
60
+ except json.JSONDecodeError as e:
61
+ raise ValueError(f"Invalid JSON at line {i}: {e}") from e
62
+ try:
63
+ events.append(ObservationEvent(
64
+ timestamp=raw["timestamp"],
65
+ event=raw["event"],
66
+ tool=raw["tool"],
67
+ session=raw["session"],
68
+ input=raw.get("input", ""),
69
+ output=raw.get("output", ""),
70
+ ))
71
+ except KeyError as e:
72
+ raise ValueError(f"Missing required field {e} at line {i}") from e
73
+
74
+ return sorted(events, key=lambda e: e.timestamp)
75
+
76
+
77
+ def parse_spec(path: Path) -> ComplianceSpec:
78
+ """Parse a YAML compliance spec file."""
79
+ if not path.is_file():
80
+ raise FileNotFoundError(f"Spec file not found: {path}")
81
+ raw = yaml.safe_load(path.read_text())
82
+
83
+ steps: list[Step] = []
84
+ for s in raw["steps"]:
85
+ d = s["detector"]
86
+ steps.append(Step(
87
+ id=s["id"],
88
+ description=s["description"],
89
+ required=s["required"],
90
+ detector=Detector(
91
+ description=d["description"],
92
+ after_step=d.get("after_step"),
93
+ before_step=d.get("before_step"),
94
+ ),
95
+ ))
96
+
97
+ if "scoring" not in raw:
98
+ raise KeyError("Missing 'scoring' section in compliance spec")
99
+
100
+ return ComplianceSpec(
101
+ id=raw["id"],
102
+ name=raw["name"],
103
+ source_rule=raw["source_rule"],
104
+ version=raw["version"],
105
+ steps=tuple(steps),
106
+ threshold_promote_to_hook=raw["scoring"]["threshold_promote_to_hook"],
107
+ )
@@ -0,0 +1,170 @@
1
+ """Generate Markdown compliance reports."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from datetime import datetime, timezone
6
+ from pathlib import Path
7
+
8
+ from scripts.grader import ComplianceResult
9
+ from scripts.parser import ComplianceSpec, ObservationEvent
10
+ from scripts.scenario_generator import Scenario
11
+
12
+
13
+ def generate_report(
14
+ skill_path: Path,
15
+ spec: ComplianceSpec,
16
+ results: list[tuple[str, ComplianceResult, list[ObservationEvent]]],
17
+ scenarios: list[Scenario] | None = None,
18
+ ) -> str:
19
+ """Generate a Markdown compliance report.
20
+
21
+ Args:
22
+ skill_path: Path to the skill file that was tested.
23
+ spec: The compliance spec used for grading.
24
+ results: List of (scenario_level_name, ComplianceResult, observations) tuples.
25
+ scenarios: Original scenario definitions with prompts.
26
+ """
27
+ now = datetime.now(timezone.utc).strftime("%Y-%m-%dT%H:%M:%SZ")
28
+ overall = _overall_compliance(results)
29
+ threshold = spec.threshold_promote_to_hook
30
+
31
+ lines: list[str] = []
32
+ lines.append(f"# skill-comply Report: {skill_path.name}")
33
+ lines.append(f"Generated: {now}")
34
+ lines.append("")
35
+
36
+ # Summary
37
+ lines.append("## Summary")
38
+ lines.append("")
39
+ lines.append(f"| Metric | Value |")
40
+ lines.append(f"|--------|-------|")
41
+ lines.append(f"| Skill | `{skill_path}` |")
42
+ lines.append(f"| Spec | {spec.id} |")
43
+ lines.append(f"| Scenarios | {len(results)} |")
44
+ lines.append(f"| Overall Compliance | {overall:.0%} |")
45
+ lines.append(f"| Threshold | {threshold:.0%} |")
46
+
47
+ promote_steps = _steps_to_promote(spec, results, threshold)
48
+ if promote_steps:
49
+ step_names = ", ".join(promote_steps)
50
+ lines.append(f"| Recommendation | **Promote {step_names} to hooks** |")
51
+ else:
52
+ lines.append(f"| Recommendation | All steps above threshold — no hook promotion needed |")
53
+ lines.append("")
54
+
55
+ # Expected Behavioral Sequence
56
+ lines.append("## Expected Behavioral Sequence")
57
+ lines.append("")
58
+ lines.append("| # | Step | Required | Description |")
59
+ lines.append("|---|------|----------|-------------|")
60
+ for i, step in enumerate(spec.steps, 1):
61
+ req = "Yes" if step.required else "No"
62
+ lines.append(f"| {i} | {step.id} | {req} | {step.detector.description} |")
63
+ lines.append("")
64
+
65
+ # Scenario Results
66
+ lines.append("## Scenario Results")
67
+ lines.append("")
68
+ lines.append("| Scenario | Compliance | Failed Steps |")
69
+ lines.append("|----------|-----------|----------------|")
70
+ for level_name, result, _obs in results:
71
+ failed = [s.step_id for s in result.steps if not s.detected
72
+ and any(sp.id == s.step_id and sp.required for sp in spec.steps)]
73
+ failed_str = ", ".join(failed) if failed else "—"
74
+ lines.append(f"| {level_name} | {result.compliance_rate:.0%} | {failed_str} |")
75
+ lines.append("")
76
+
77
+ # Scenario Prompts
78
+ if scenarios:
79
+ lines.append("## Scenario Prompts")
80
+ lines.append("")
81
+ for s in scenarios:
82
+ lines.append(f"### {s.level_name} (Level {s.level})")
83
+ lines.append("")
84
+ for prompt_line in s.prompt.splitlines():
85
+ lines.append(f"> {prompt_line}")
86
+ lines.append("")
87
+
88
+ # Hook Promotion Recommendations (optional/advanced)
89
+ if promote_steps:
90
+ lines.append("## Advanced: Hook Promotion Recommendations (optional)")
91
+ lines.append("")
92
+ for step_id in promote_steps:
93
+ rate = _step_compliance_rate(step_id, results)
94
+ step = next(s for s in spec.steps if s.id == step_id)
95
+ lines.append(
96
+ f"- **{step_id}** (compliance {rate:.0%}): {step.description}"
97
+ )
98
+ lines.append("")
99
+
100
+ # Per-scenario details with timeline
101
+ lines.append("## Detail")
102
+ lines.append("")
103
+ for level_name, result, observations in results:
104
+ lines.append(f"### {level_name} (Compliance: {result.compliance_rate:.0%})")
105
+ lines.append("")
106
+ lines.append("| Step | Required | Detected | Reason |")
107
+ lines.append("|------|----------|----------|--------|")
108
+ for sr in result.steps:
109
+ req = "Yes" if any(
110
+ sp.id == sr.step_id and sp.required for sp in spec.steps
111
+ ) else "No"
112
+ det = "YES" if sr.detected else "NO"
113
+ reason = sr.failure_reason or "—"
114
+ lines.append(f"| {sr.step_id} | {req} | {det} | {reason} |")
115
+ lines.append("")
116
+
117
+ # Timeline: show what the agent actually did
118
+ if observations:
119
+ # Build reverse index: event_index → step_id
120
+ index_to_step: dict[int, str] = {}
121
+ for step_id, indices in result.classification.items():
122
+ for idx in indices:
123
+ index_to_step[idx] = step_id
124
+
125
+ lines.append(f"**Tool Call Timeline ({len(observations)} calls)**")
126
+ lines.append("")
127
+ lines.append("| # | Tool | Input | Output | Classified As |")
128
+ lines.append("|---|------|-------|--------|------|")
129
+ for i, obs in enumerate(observations):
130
+ step_label = index_to_step.get(i, "—")
131
+ input_summary = obs.input[:100].replace("|", "\\|").replace("\n", " ")
132
+ output_summary = obs.output[:50].replace("|", "\\|").replace("\n", " ")
133
+ lines.append(
134
+ f"| {i} | {obs.tool} | {input_summary} | {output_summary} | {step_label} |"
135
+ )
136
+ lines.append("")
137
+
138
+ return "\n".join(lines)
139
+
140
+
141
+ def _overall_compliance(results: list[tuple[str, ComplianceResult, list[ObservationEvent]]]) -> float:
142
+ if not results:
143
+ return 0.0
144
+ return sum(r.compliance_rate for _, r, _obs in results) / len(results)
145
+
146
+
147
+ def _step_compliance_rate(
148
+ step_id: str,
149
+ results: list[tuple[str, ComplianceResult, list[ObservationEvent]]],
150
+ ) -> float:
151
+ detected = sum(
152
+ 1 for _, r, _obs in results
153
+ for s in r.steps if s.step_id == step_id and s.detected
154
+ )
155
+ return detected / len(results) if results else 0.0
156
+
157
+
158
+ def _steps_to_promote(
159
+ spec: ComplianceSpec,
160
+ results: list[tuple[str, ComplianceResult, list[ObservationEvent]]],
161
+ threshold: float,
162
+ ) -> list[str]:
163
+ promote = []
164
+ for step in spec.steps:
165
+ if not step.required:
166
+ continue
167
+ rate = _step_compliance_rate(step.id, results)
168
+ if rate < threshold:
169
+ promote.append(step.id)
170
+ return promote
@@ -0,0 +1,127 @@
1
+ """CLI entry point for skill-comply."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import argparse
6
+ import logging
7
+ import sys
8
+ from pathlib import Path
9
+ from typing import Any
10
+
11
+ import yaml
12
+
13
+ from scripts.grader import grade
14
+ from scripts.report import generate_report
15
+ from scripts.runner import run_scenario
16
+ from scripts.scenario_generator import generate_scenarios
17
+ from scripts.spec_generator import generate_spec
18
+
19
+ logger = logging.getLogger(__name__)
20
+
21
+
22
+ def main() -> None:
23
+ logging.basicConfig(level=logging.INFO, format="%(message)s")
24
+
25
+ parser = argparse.ArgumentParser(
26
+ description="skill-comply: Measure skill compliance rates",
27
+ )
28
+ parser.add_argument(
29
+ "skill",
30
+ type=Path,
31
+ help="Path to skill/rule file to test",
32
+ )
33
+ parser.add_argument(
34
+ "--model",
35
+ default="sonnet",
36
+ help="Model for scenario execution (default: sonnet)",
37
+ )
38
+ parser.add_argument(
39
+ "--gen-model",
40
+ default="haiku",
41
+ help="Model for spec/scenario generation (default: haiku)",
42
+ )
43
+ parser.add_argument(
44
+ "--dry-run",
45
+ action="store_true",
46
+ help="Generate spec and scenarios without executing",
47
+ )
48
+ parser.add_argument(
49
+ "--output",
50
+ type=Path,
51
+ default=None,
52
+ help="Output report path (default: results/<skill-name>.md)",
53
+ )
54
+
55
+ args = parser.parse_args()
56
+
57
+ if not args.skill.is_file():
58
+ logger.error("Error: Skill file not found: %s", args.skill)
59
+ sys.exit(1)
60
+
61
+ results_dir = Path(__file__).parent.parent / "results"
62
+ results_dir.mkdir(exist_ok=True)
63
+
64
+ # Step 1: Generate compliance spec
65
+ logger.info("[1/4] Generating compliance spec from %s...", args.skill.name)
66
+ spec = generate_spec(args.skill, model=args.gen_model)
67
+ logger.info(" %d steps extracted", len(spec.steps))
68
+
69
+ # Step 2: Generate scenarios
70
+ spec_yaml = yaml.dump({
71
+ "steps": [
72
+ {"id": s.id, "description": s.description, "required": s.required}
73
+ for s in spec.steps
74
+ ]
75
+ })
76
+ logger.info("[2/4] Generating scenarios (3 prompt strictness levels)...")
77
+ scenarios = generate_scenarios(args.skill, spec_yaml, model=args.gen_model)
78
+ logger.info(" %d scenarios generated", len(scenarios))
79
+
80
+ for s in scenarios:
81
+ logger.info(" - %s: %s", s.level_name, s.description[:60])
82
+
83
+ if args.dry_run:
84
+ logger.info("\n[dry-run] Spec and scenarios generated. Skipping execution.")
85
+ logger.info("\nSpec: %s (%d steps)", spec.id, len(spec.steps))
86
+ for step in spec.steps:
87
+ marker = "*" if step.required else " "
88
+ logger.info(" [%s] %s: %s", marker, step.id, step.description)
89
+ return
90
+
91
+ # Step 3: Execute scenarios
92
+ logger.info("[3/4] Executing scenarios (model=%s)...", args.model)
93
+ graded_results: list[tuple[str, Any, list[Any]]] = []
94
+
95
+ for scenario in scenarios:
96
+ logger.info(" Running %s...", scenario.level_name)
97
+ run = run_scenario(scenario, model=args.model)
98
+ result = grade(spec, list(run.observations))
99
+ graded_results.append((scenario.level_name, result, list(run.observations)))
100
+ logger.info(" %s: %.0f%%", scenario.level_name, result.compliance_rate * 100)
101
+
102
+ # Step 4: Generate report
103
+ skill_name = args.skill.parent.name if args.skill.stem == "SKILL" else args.skill.stem
104
+ output_path = args.output or results_dir / f"{skill_name}.md"
105
+ logger.info("[4/4] Generating report...")
106
+
107
+ report = generate_report(args.skill, spec, graded_results, scenarios=scenarios)
108
+ output_path.parent.mkdir(parents=True, exist_ok=True)
109
+ output_path.write_text(report)
110
+ logger.info(" Report saved to %s", output_path)
111
+
112
+ # Summary
113
+ if not graded_results:
114
+ logger.warning("No scenarios were executed.")
115
+ return
116
+ overall = sum(r.compliance_rate for _, r, _obs in graded_results) / len(graded_results)
117
+ logger.info("\n%s", "=" * 50)
118
+ logger.info("Overall Compliance: %.0f%%", overall * 100)
119
+ if overall < spec.threshold_promote_to_hook:
120
+ logger.info(
121
+ "Recommendation: Some steps have low compliance. "
122
+ "Consider promoting them to hooks. See the report for details."
123
+ )
124
+
125
+
126
+ if __name__ == "__main__":
127
+ main()
@@ -0,0 +1,186 @@
1
+ """Run scenarios via claude -p and parse tool calls from stream-json output."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import json
6
+ import re
7
+ import shlex
8
+ import shutil
9
+ import subprocess
10
+ from dataclasses import dataclass
11
+ from pathlib import Path
12
+
13
+ from scripts.parser import ObservationEvent
14
+ from scripts.scenario_generator import Scenario
15
+
16
+ SANDBOX_BASE = Path("/tmp/skill-comply-sandbox")
17
+ ALLOWED_MODELS = frozenset({"haiku", "sonnet", "opus"})
18
+ # Shell builtins cannot be invoked via subprocess.run; cwd is already
19
+ # controlled by the cwd= keyword. Scenarios that include these in
20
+ # setup_commands (a common shell-style convention) must be tolerated.
21
+ SHELL_BUILTINS = frozenset({"cd", "pushd", "popd"})
22
+
23
+
24
+ @dataclass(frozen=True)
25
+ class ScenarioRun:
26
+ scenario: Scenario
27
+ observations: tuple[ObservationEvent, ...]
28
+ sandbox_dir: Path
29
+
30
+
31
+ def run_scenario(
32
+ scenario: Scenario,
33
+ model: str = "sonnet",
34
+ max_turns: int = 30,
35
+ timeout: int = 300,
36
+ ) -> ScenarioRun:
37
+ """Execute a scenario and extract tool calls from stream-json output."""
38
+ if model not in ALLOWED_MODELS:
39
+ raise ValueError(f"Unknown model: {model!r}. Allowed: {ALLOWED_MODELS}")
40
+
41
+ sandbox_dir = _safe_sandbox_dir(scenario.id)
42
+ _setup_sandbox(sandbox_dir, scenario)
43
+
44
+ result = subprocess.run(
45
+ [
46
+ "claude", "-p", scenario.prompt,
47
+ "--model", model,
48
+ "--max-turns", str(max_turns),
49
+ "--add-dir", str(sandbox_dir),
50
+ "--allowedTools", "Read,Write,Edit,Bash,Glob,Grep",
51
+ "--output-format", "stream-json",
52
+ "--verbose",
53
+ ],
54
+ capture_output=True,
55
+ text=True,
56
+ timeout=timeout,
57
+ cwd=sandbox_dir,
58
+ )
59
+
60
+ # claude -p returns rc=1 when --max-turns is reached, but the stream-json
61
+ # output is still complete and parseable. Treat this graceful termination
62
+ # as non-fatal so scenarios that hit the turn cap still produce usable
63
+ # observations.
64
+ nonfatal_max_turns = (
65
+ result.returncode == 1
66
+ and '"terminal_reason":"max_turns"' in result.stdout
67
+ )
68
+ if result.returncode != 0 and not nonfatal_max_turns:
69
+ # Include both stderr and stdout tails. claude -p often surfaces the
70
+ # actual failure context (model error JSON, partial stream-json) on
71
+ # stdout, while stderr carries generic transport / auth messages.
72
+ # Showing both dramatically reduces "rc=N: <empty>" debugging dead-ends.
73
+ raise RuntimeError(
74
+ f"claude -p failed (rc={result.returncode}): "
75
+ f"stderr={result.stderr[:500]!r} stdout_tail={result.stdout[-500:]!r}"
76
+ )
77
+
78
+ observations = _parse_stream_json(result.stdout)
79
+
80
+ return ScenarioRun(
81
+ scenario=scenario,
82
+ observations=tuple(observations),
83
+ sandbox_dir=sandbox_dir,
84
+ )
85
+
86
+
87
+ def _safe_sandbox_dir(scenario_id: str) -> Path:
88
+ """Sanitize scenario ID and ensure path stays within sandbox base."""
89
+ safe_id = re.sub(r"[^a-zA-Z0-9\-_]", "_", scenario_id)
90
+ path = SANDBOX_BASE / safe_id
91
+ # Validate path stays within sandbox base (raises ValueError on traversal)
92
+ path.resolve().relative_to(SANDBOX_BASE.resolve())
93
+ return path
94
+
95
+
96
+ def _setup_sandbox(sandbox_dir: Path, scenario: Scenario) -> None:
97
+ """Create sandbox directory and run setup commands."""
98
+ if sandbox_dir.exists():
99
+ shutil.rmtree(sandbox_dir)
100
+ sandbox_dir.mkdir(parents=True)
101
+
102
+ subprocess.run(["git", "init"], cwd=sandbox_dir, capture_output=True)
103
+
104
+ for cmd in scenario.setup_commands:
105
+ parts = shlex.split(cmd)
106
+ if not parts or parts[0] in SHELL_BUILTINS:
107
+ # Shell builtins (cd/pushd/popd) cannot run as subprocess; skip.
108
+ continue
109
+ try:
110
+ subprocess.run(parts, cwd=sandbox_dir, capture_output=True)
111
+ except FileNotFoundError:
112
+ # Setup tool not installed in this environment; skip rather than
113
+ # crash the whole scenario. The compliance run continues.
114
+ continue
115
+
116
+
117
+ def _parse_stream_json(stdout: str) -> list[ObservationEvent]:
118
+ """Parse claude -p stream-json output into ObservationEvents.
119
+
120
+ Stream-json format:
121
+ - type=assistant with content[].type=tool_use → tool call (name, input)
122
+ - type=user with content[].type=tool_result → tool result (output)
123
+ """
124
+ events: list[ObservationEvent] = []
125
+ pending: dict[str, dict] = {}
126
+ event_counter = 0
127
+
128
+ for line in stdout.strip().splitlines():
129
+ try:
130
+ msg = json.loads(line)
131
+ except json.JSONDecodeError:
132
+ continue
133
+
134
+ msg_type = msg.get("type")
135
+
136
+ if msg_type == "assistant":
137
+ content = msg.get("message", {}).get("content", [])
138
+ for block in content:
139
+ if block.get("type") == "tool_use":
140
+ tool_use_id = block.get("id", "")
141
+ tool_input = block.get("input", {})
142
+ input_str = (
143
+ json.dumps(tool_input)[:5000]
144
+ if isinstance(tool_input, dict)
145
+ else str(tool_input)[:5000]
146
+ )
147
+ pending[tool_use_id] = {
148
+ "tool": block.get("name", "unknown"),
149
+ "input": input_str,
150
+ "order": event_counter,
151
+ }
152
+ event_counter += 1
153
+
154
+ elif msg_type == "user":
155
+ content = msg.get("message", {}).get("content", [])
156
+ if isinstance(content, list):
157
+ for block in content:
158
+ tool_use_id = block.get("tool_use_id", "")
159
+ if tool_use_id in pending:
160
+ info = pending.pop(tool_use_id)
161
+ output_content = block.get("content", "")
162
+ if isinstance(output_content, list):
163
+ output_str = json.dumps(output_content)[:5000]
164
+ else:
165
+ output_str = str(output_content)[:5000]
166
+
167
+ events.append(ObservationEvent(
168
+ timestamp=f"T{info['order']:04d}",
169
+ event="tool_complete",
170
+ tool=info["tool"],
171
+ session=msg.get("session_id", "unknown"),
172
+ input=info["input"],
173
+ output=output_str,
174
+ ))
175
+
176
+ for _tool_use_id, info in pending.items():
177
+ events.append(ObservationEvent(
178
+ timestamp=f"T{info['order']:04d}",
179
+ event="tool_complete",
180
+ tool=info["tool"],
181
+ session="unknown",
182
+ input=info["input"],
183
+ output="",
184
+ ))
185
+
186
+ return sorted(events, key=lambda e: e.timestamp)
@@ -0,0 +1,70 @@
1
+ """Generate pressure scenarios from skill + spec using LLM."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import subprocess
6
+ from dataclasses import dataclass
7
+ from pathlib import Path
8
+
9
+ import yaml
10
+
11
+ from scripts.utils import extract_yaml
12
+
13
+ PROMPTS_DIR = Path(__file__).parent.parent / "prompts"
14
+
15
+
16
+ @dataclass(frozen=True)
17
+ class Scenario:
18
+ id: str
19
+ level: int
20
+ level_name: str
21
+ description: str
22
+ prompt: str
23
+ setup_commands: tuple[str, ...]
24
+
25
+
26
+ def generate_scenarios(
27
+ skill_path: Path,
28
+ spec_yaml: str,
29
+ model: str = "haiku",
30
+ ) -> list[Scenario]:
31
+ """Generate 3 scenarios with decreasing prompt strictness.
32
+
33
+ Calls claude -p with the scenario_generator prompt, parses YAML output.
34
+ """
35
+ skill_content = skill_path.read_text()
36
+ prompt_template = (PROMPTS_DIR / "scenario_generator.md").read_text()
37
+ prompt = (
38
+ prompt_template
39
+ .replace("{skill_content}", skill_content)
40
+ .replace("{spec_yaml}", spec_yaml)
41
+ )
42
+
43
+ result = subprocess.run(
44
+ ["claude", "-p", prompt, "--model", model, "--output-format", "text"],
45
+ capture_output=True,
46
+ text=True,
47
+ timeout=120,
48
+ )
49
+
50
+ if result.returncode != 0:
51
+ raise RuntimeError(f"claude -p failed: {result.stderr}")
52
+
53
+ if not result.stdout.strip():
54
+ raise RuntimeError("claude -p returned empty output")
55
+
56
+ raw_yaml = extract_yaml(result.stdout)
57
+ parsed = yaml.safe_load(raw_yaml)
58
+
59
+ scenarios: list[Scenario] = []
60
+ for s in parsed["scenarios"]:
61
+ scenarios.append(Scenario(
62
+ id=s["id"],
63
+ level=s["level"],
64
+ level_name=s["level_name"],
65
+ description=s["description"],
66
+ prompt=s["prompt"].strip(),
67
+ setup_commands=tuple(s.get("setup_commands", [])),
68
+ ))
69
+
70
+ return sorted(scenarios, key=lambda s: s.level)