claudecode-omc 5.5.2 → 5.6.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (438) hide show
  1. package/.local/skills/de-ai-writing/SKILL.md +243 -0
  2. package/.local/skills/de-ai-writing/references/chinese-patterns.md +152 -0
  3. package/.local/skills/de-ai-writing/references/chinese-signals.md +121 -0
  4. package/.local/skills/de-ai-writing/references/domain-playbooks.md +120 -0
  5. package/.local/skills/de-ai-writing/references/wikipedia-signs.md +196 -0
  6. package/README.md +102 -10
  7. package/bundled/manifest.json +3 -2
  8. package/bundled/upstream/ecc/.omc-source/bundle.json +23 -0
  9. package/bundled/upstream/ecc/.omc-source/last-plan-apply.json +439 -0
  10. package/bundled/upstream/ecc/.omc-source/manifests/.claude-plugin/marketplace.json +47 -0
  11. package/bundled/upstream/ecc/agents/a11y-architect.md +141 -0
  12. package/bundled/upstream/ecc/agents/architect.md +211 -0
  13. package/bundled/upstream/ecc/agents/build-error-resolver.md +114 -0
  14. package/bundled/upstream/ecc/agents/chief-of-staff.md +151 -0
  15. package/bundled/upstream/ecc/agents/code-architect.md +71 -0
  16. package/bundled/upstream/ecc/agents/code-explorer.md +69 -0
  17. package/bundled/upstream/ecc/agents/code-reviewer.md +237 -0
  18. package/bundled/upstream/ecc/agents/code-simplifier.md +47 -0
  19. package/bundled/upstream/ecc/agents/comment-analyzer.md +45 -0
  20. package/bundled/upstream/ecc/agents/conversation-analyzer.md +52 -0
  21. package/bundled/upstream/ecc/agents/cpp-build-resolver.md +90 -0
  22. package/bundled/upstream/ecc/agents/cpp-reviewer.md +72 -0
  23. package/bundled/upstream/ecc/agents/csharp-reviewer.md +101 -0
  24. package/bundled/upstream/ecc/agents/dart-build-resolver.md +201 -0
  25. package/bundled/upstream/ecc/agents/database-reviewer.md +91 -0
  26. package/bundled/upstream/ecc/agents/doc-updater.md +107 -0
  27. package/bundled/upstream/ecc/agents/docs-lookup.md +68 -0
  28. package/bundled/upstream/ecc/agents/e2e-runner.md +107 -0
  29. package/bundled/upstream/ecc/agents/flutter-reviewer.md +243 -0
  30. package/bundled/upstream/ecc/agents/gan-evaluator.md +209 -0
  31. package/bundled/upstream/ecc/agents/gan-generator.md +131 -0
  32. package/bundled/upstream/ecc/agents/gan-planner.md +99 -0
  33. package/bundled/upstream/ecc/agents/go-build-resolver.md +94 -0
  34. package/bundled/upstream/ecc/agents/go-reviewer.md +76 -0
  35. package/bundled/upstream/ecc/agents/harness-optimizer.md +35 -0
  36. package/bundled/upstream/ecc/agents/healthcare-reviewer.md +83 -0
  37. package/bundled/upstream/ecc/agents/java-build-resolver.md +153 -0
  38. package/bundled/upstream/ecc/agents/java-reviewer.md +92 -0
  39. package/bundled/upstream/ecc/agents/kotlin-build-resolver.md +118 -0
  40. package/bundled/upstream/ecc/agents/kotlin-reviewer.md +159 -0
  41. package/bundled/upstream/ecc/agents/loop-operator.md +36 -0
  42. package/bundled/upstream/ecc/agents/opensource-forker.md +198 -0
  43. package/bundled/upstream/ecc/agents/opensource-packager.md +249 -0
  44. package/bundled/upstream/ecc/agents/opensource-sanitizer.md +188 -0
  45. package/bundled/upstream/ecc/agents/performance-optimizer.md +446 -0
  46. package/bundled/upstream/ecc/agents/planner.md +212 -0
  47. package/bundled/upstream/ecc/agents/pr-test-analyzer.md +45 -0
  48. package/bundled/upstream/ecc/agents/python-reviewer.md +98 -0
  49. package/bundled/upstream/ecc/agents/pytorch-build-resolver.md +120 -0
  50. package/bundled/upstream/ecc/agents/refactor-cleaner.md +85 -0
  51. package/bundled/upstream/ecc/agents/rust-build-resolver.md +148 -0
  52. package/bundled/upstream/ecc/agents/rust-reviewer.md +94 -0
  53. package/bundled/upstream/ecc/agents/security-reviewer.md +108 -0
  54. package/bundled/upstream/ecc/agents/seo-specialist.md +62 -0
  55. package/bundled/upstream/ecc/agents/silent-failure-hunter.md +50 -0
  56. package/bundled/upstream/ecc/agents/tdd-guide.md +91 -0
  57. package/bundled/upstream/ecc/agents/type-design-analyzer.md +41 -0
  58. package/bundled/upstream/ecc/agents/typescript-reviewer.md +112 -0
  59. package/bundled/upstream/ecc/commands/agent-sort.md +23 -0
  60. package/bundled/upstream/ecc/commands/aside.md +164 -0
  61. package/bundled/upstream/ecc/commands/build-fix.md +62 -0
  62. package/bundled/upstream/ecc/commands/checkpoint.md +74 -0
  63. package/bundled/upstream/ecc/commands/claw.md +23 -0
  64. package/bundled/upstream/ecc/commands/code-review.md +289 -0
  65. package/bundled/upstream/ecc/commands/context-budget.md +23 -0
  66. package/bundled/upstream/ecc/commands/cpp-build.md +173 -0
  67. package/bundled/upstream/ecc/commands/cpp-review.md +132 -0
  68. package/bundled/upstream/ecc/commands/cpp-test.md +251 -0
  69. package/bundled/upstream/ecc/commands/devfleet.md +23 -0
  70. package/bundled/upstream/ecc/commands/docs.md +23 -0
  71. package/bundled/upstream/ecc/commands/e2e.md +268 -0
  72. package/bundled/upstream/ecc/commands/eval.md +23 -0
  73. package/bundled/upstream/ecc/commands/evolve.md +178 -0
  74. package/bundled/upstream/ecc/commands/feature-dev.md +49 -0
  75. package/bundled/upstream/ecc/commands/flutter-build.md +164 -0
  76. package/bundled/upstream/ecc/commands/flutter-review.md +116 -0
  77. package/bundled/upstream/ecc/commands/flutter-test.md +144 -0
  78. package/bundled/upstream/ecc/commands/gan-build.md +99 -0
  79. package/bundled/upstream/ecc/commands/gan-design.md +35 -0
  80. package/bundled/upstream/ecc/commands/go-build.md +183 -0
  81. package/bundled/upstream/ecc/commands/go-review.md +148 -0
  82. package/bundled/upstream/ecc/commands/go-test.md +268 -0
  83. package/bundled/upstream/ecc/commands/gradle-build.md +70 -0
  84. package/bundled/upstream/ecc/commands/harness-audit.md +73 -0
  85. package/bundled/upstream/ecc/commands/hookify-configure.md +14 -0
  86. package/bundled/upstream/ecc/commands/hookify-help.md +46 -0
  87. package/bundled/upstream/ecc/commands/hookify-list.md +21 -0
  88. package/bundled/upstream/ecc/commands/hookify.md +50 -0
  89. package/bundled/upstream/ecc/commands/instinct-export.md +66 -0
  90. package/bundled/upstream/ecc/commands/instinct-import.md +114 -0
  91. package/bundled/upstream/ecc/commands/instinct-status.md +59 -0
  92. package/bundled/upstream/ecc/commands/jira.md +106 -0
  93. package/bundled/upstream/ecc/commands/kotlin-build.md +174 -0
  94. package/bundled/upstream/ecc/commands/kotlin-review.md +140 -0
  95. package/bundled/upstream/ecc/commands/kotlin-test.md +312 -0
  96. package/bundled/upstream/ecc/commands/learn-eval.md +116 -0
  97. package/bundled/upstream/ecc/commands/learn.md +70 -0
  98. package/bundled/upstream/ecc/commands/loop-start.md +32 -0
  99. package/bundled/upstream/ecc/commands/loop-status.md +24 -0
  100. package/bundled/upstream/ecc/commands/model-route.md +26 -0
  101. package/bundled/upstream/ecc/commands/multi-backend.md +158 -0
  102. package/bundled/upstream/ecc/commands/multi-execute.md +315 -0
  103. package/bundled/upstream/ecc/commands/multi-frontend.md +158 -0
  104. package/bundled/upstream/ecc/commands/multi-plan.md +268 -0
  105. package/bundled/upstream/ecc/commands/multi-workflow.md +191 -0
  106. package/bundled/upstream/ecc/commands/orchestrate.md +135 -0
  107. package/bundled/upstream/ecc/commands/plan.md +117 -0
  108. package/bundled/upstream/ecc/commands/pm2.md +272 -0
  109. package/bundled/upstream/ecc/commands/projects.md +39 -0
  110. package/bundled/upstream/ecc/commands/promote.md +41 -0
  111. package/bundled/upstream/ecc/commands/prompt-optimize.md +23 -0
  112. package/bundled/upstream/ecc/commands/prp-commit.md +112 -0
  113. package/bundled/upstream/ecc/commands/prp-implement.md +385 -0
  114. package/bundled/upstream/ecc/commands/prp-plan.md +502 -0
  115. package/bundled/upstream/ecc/commands/prp-pr.md +184 -0
  116. package/bundled/upstream/ecc/commands/prp-prd.md +447 -0
  117. package/bundled/upstream/ecc/commands/prune.md +31 -0
  118. package/bundled/upstream/ecc/commands/python-review.md +297 -0
  119. package/bundled/upstream/ecc/commands/quality-gate.md +29 -0
  120. package/bundled/upstream/ecc/commands/refactor-clean.md +80 -0
  121. package/bundled/upstream/ecc/commands/resume-session.md +156 -0
  122. package/bundled/upstream/ecc/commands/review-pr.md +37 -0
  123. package/bundled/upstream/ecc/commands/rules-distill.md +20 -0
  124. package/bundled/upstream/ecc/commands/rust-build.md +187 -0
  125. package/bundled/upstream/ecc/commands/rust-review.md +142 -0
  126. package/bundled/upstream/ecc/commands/rust-test.md +308 -0
  127. package/bundled/upstream/ecc/commands/santa-loop.md +175 -0
  128. package/bundled/upstream/ecc/commands/save-session.md +275 -0
  129. package/bundled/upstream/ecc/commands/sessions.md +339 -0
  130. package/bundled/upstream/ecc/commands/setup-pm.md +80 -0
  131. package/bundled/upstream/ecc/commands/skill-create.md +174 -0
  132. package/bundled/upstream/ecc/commands/skill-health.md +54 -0
  133. package/bundled/upstream/ecc/commands/tdd.md +231 -0
  134. package/bundled/upstream/ecc/commands/test-coverage.md +69 -0
  135. package/bundled/upstream/ecc/commands/update-codemaps.md +72 -0
  136. package/bundled/upstream/ecc/commands/update-docs.md +84 -0
  137. package/bundled/upstream/ecc/commands/verify.md +23 -0
  138. package/bundled/upstream/ecc/hooks/README.md +237 -0
  139. package/bundled/upstream/ecc/hooks/hooks.json +330 -0
  140. package/bundled/upstream/ecc/skills/accessibility/SKILL.md +146 -0
  141. package/bundled/upstream/ecc/skills/agent-eval/SKILL.md +145 -0
  142. package/bundled/upstream/ecc/skills/agent-harness-construction/SKILL.md +73 -0
  143. package/bundled/upstream/ecc/skills/agent-introspection-debugging/SKILL.md +153 -0
  144. package/bundled/upstream/ecc/skills/agent-payment-x402/SKILL.md +178 -0
  145. package/bundled/upstream/ecc/skills/agent-sort/SKILL.md +215 -0
  146. package/bundled/upstream/ecc/skills/agentic-engineering/SKILL.md +63 -0
  147. package/bundled/upstream/ecc/skills/ai-first-engineering/SKILL.md +51 -0
  148. package/bundled/upstream/ecc/skills/ai-regression-testing/SKILL.md +385 -0
  149. package/bundled/upstream/ecc/skills/android-clean-architecture/SKILL.md +339 -0
  150. package/bundled/upstream/ecc/skills/api-connector-builder/SKILL.md +120 -0
  151. package/bundled/upstream/ecc/skills/api-design/SKILL.md +523 -0
  152. package/bundled/upstream/ecc/skills/architecture-decision-records/SKILL.md +179 -0
  153. package/bundled/upstream/ecc/skills/article-writing/SKILL.md +79 -0
  154. package/bundled/upstream/ecc/skills/automation-audit-ops/SKILL.md +142 -0
  155. package/bundled/upstream/ecc/skills/autonomous-agent-harness/SKILL.md +267 -0
  156. package/bundled/upstream/ecc/skills/autonomous-loops/SKILL.md +610 -0
  157. package/bundled/upstream/ecc/skills/backend-patterns/SKILL.md +598 -0
  158. package/bundled/upstream/ecc/skills/benchmark/SKILL.md +93 -0
  159. package/bundled/upstream/ecc/skills/blueprint/SKILL.md +105 -0
  160. package/bundled/upstream/ecc/skills/brand-voice/SKILL.md +97 -0
  161. package/bundled/upstream/ecc/skills/brand-voice/references/voice-profile-schema.md +55 -0
  162. package/bundled/upstream/ecc/skills/browser-qa/SKILL.md +87 -0
  163. package/bundled/upstream/ecc/skills/bun-runtime/SKILL.md +84 -0
  164. package/bundled/upstream/ecc/skills/canary-watch/SKILL.md +99 -0
  165. package/bundled/upstream/ecc/skills/carrier-relationship-management/SKILL.md +212 -0
  166. package/bundled/upstream/ecc/skills/ck/SKILL.md +147 -0
  167. package/bundled/upstream/ecc/skills/ck/commands/forget.mjs +44 -0
  168. package/bundled/upstream/ecc/skills/ck/commands/info.mjs +24 -0
  169. package/bundled/upstream/ecc/skills/ck/commands/init.mjs +143 -0
  170. package/bundled/upstream/ecc/skills/ck/commands/list.mjs +40 -0
  171. package/bundled/upstream/ecc/skills/ck/commands/migrate.mjs +202 -0
  172. package/bundled/upstream/ecc/skills/ck/commands/resume.mjs +36 -0
  173. package/bundled/upstream/ecc/skills/ck/commands/save.mjs +210 -0
  174. package/bundled/upstream/ecc/skills/ck/commands/shared.mjs +387 -0
  175. package/bundled/upstream/ecc/skills/ck/hooks/session-start.mjs +224 -0
  176. package/bundled/upstream/ecc/skills/claude-api/SKILL.md +337 -0
  177. package/bundled/upstream/ecc/skills/claude-devfleet/SKILL.md +103 -0
  178. package/bundled/upstream/ecc/skills/click-path-audit/SKILL.md +244 -0
  179. package/bundled/upstream/ecc/skills/clickhouse-io/SKILL.md +439 -0
  180. package/bundled/upstream/ecc/skills/code-tour/SKILL.md +236 -0
  181. package/bundled/upstream/ecc/skills/codebase-onboarding/SKILL.md +233 -0
  182. package/bundled/upstream/ecc/skills/coding-standards/SKILL.md +549 -0
  183. package/bundled/upstream/ecc/skills/compose-multiplatform-patterns/SKILL.md +299 -0
  184. package/bundled/upstream/ecc/skills/configure-ecc/SKILL.md +367 -0
  185. package/bundled/upstream/ecc/skills/connections-optimizer/SKILL.md +189 -0
  186. package/bundled/upstream/ecc/skills/content-engine/SKILL.md +131 -0
  187. package/bundled/upstream/ecc/skills/content-hash-cache-pattern/SKILL.md +161 -0
  188. package/bundled/upstream/ecc/skills/context-budget/SKILL.md +135 -0
  189. package/bundled/upstream/ecc/skills/continuous-agent-loop/SKILL.md +45 -0
  190. package/bundled/upstream/ecc/skills/continuous-learning/SKILL.md +123 -0
  191. package/bundled/upstream/ecc/skills/continuous-learning/config.json +18 -0
  192. package/bundled/upstream/ecc/skills/continuous-learning/evaluate-session.sh +69 -0
  193. package/bundled/upstream/ecc/skills/continuous-learning-v2/SKILL.md +346 -0
  194. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/observer-loop.sh +282 -0
  195. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/observer.md +198 -0
  196. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  197. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
  198. package/bundled/upstream/ecc/skills/continuous-learning-v2/config.json +8 -0
  199. package/bundled/upstream/ecc/skills/continuous-learning-v2/hooks/observe.sh +460 -0
  200. package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/detect-project.sh +243 -0
  201. package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
  202. package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/test_parse_instinct.py +984 -0
  203. package/bundled/upstream/ecc/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  204. package/bundled/upstream/ecc/skills/council/SKILL.md +203 -0
  205. package/bundled/upstream/ecc/skills/cpp-coding-standards/SKILL.md +723 -0
  206. package/bundled/upstream/ecc/skills/cpp-testing/SKILL.md +324 -0
  207. package/bundled/upstream/ecc/skills/crosspost/SKILL.md +111 -0
  208. package/bundled/upstream/ecc/skills/csharp-testing/SKILL.md +321 -0
  209. package/bundled/upstream/ecc/skills/customer-billing-ops/SKILL.md +140 -0
  210. package/bundled/upstream/ecc/skills/customs-trade-compliance/SKILL.md +263 -0
  211. package/bundled/upstream/ecc/skills/dart-flutter-patterns/SKILL.md +563 -0
  212. package/bundled/upstream/ecc/skills/dashboard-builder/SKILL.md +108 -0
  213. package/bundled/upstream/ecc/skills/data-scraper-agent/SKILL.md +764 -0
  214. package/bundled/upstream/ecc/skills/database-migrations/SKILL.md +429 -0
  215. package/bundled/upstream/ecc/skills/deep-research/SKILL.md +155 -0
  216. package/bundled/upstream/ecc/skills/defi-amm-security/SKILL.md +160 -0
  217. package/bundled/upstream/ecc/skills/deployment-patterns/SKILL.md +427 -0
  218. package/bundled/upstream/ecc/skills/design-system/SKILL.md +82 -0
  219. package/bundled/upstream/ecc/skills/django-patterns/SKILL.md +734 -0
  220. package/bundled/upstream/ecc/skills/django-security/SKILL.md +593 -0
  221. package/bundled/upstream/ecc/skills/django-tdd/SKILL.md +729 -0
  222. package/bundled/upstream/ecc/skills/django-verification/SKILL.md +469 -0
  223. package/bundled/upstream/ecc/skills/dmux-workflows/SKILL.md +191 -0
  224. package/bundled/upstream/ecc/skills/docker-patterns/SKILL.md +364 -0
  225. package/bundled/upstream/ecc/skills/documentation-lookup/SKILL.md +90 -0
  226. package/bundled/upstream/ecc/skills/dotnet-patterns/SKILL.md +321 -0
  227. package/bundled/upstream/ecc/skills/e2e-testing/SKILL.md +326 -0
  228. package/bundled/upstream/ecc/skills/ecc-tools-cost-audit/SKILL.md +160 -0
  229. package/bundled/upstream/ecc/skills/email-ops/SKILL.md +121 -0
  230. package/bundled/upstream/ecc/skills/energy-procurement/SKILL.md +228 -0
  231. package/bundled/upstream/ecc/skills/enterprise-agent-ops/SKILL.md +50 -0
  232. package/bundled/upstream/ecc/skills/eval-harness/SKILL.md +270 -0
  233. package/bundled/upstream/ecc/skills/evm-token-decimals/SKILL.md +130 -0
  234. package/bundled/upstream/ecc/skills/exa-search/SKILL.md +103 -0
  235. package/bundled/upstream/ecc/skills/fal-ai-media/SKILL.md +284 -0
  236. package/bundled/upstream/ecc/skills/finance-billing-ops/SKILL.md +127 -0
  237. package/bundled/upstream/ecc/skills/flutter-dart-code-review/SKILL.md +435 -0
  238. package/bundled/upstream/ecc/skills/foundation-models-on-device/SKILL.md +243 -0
  239. package/bundled/upstream/ecc/skills/frontend-design/SKILL.md +145 -0
  240. package/bundled/upstream/ecc/skills/frontend-patterns/SKILL.md +642 -0
  241. package/bundled/upstream/ecc/skills/frontend-slides/SKILL.md +184 -0
  242. package/bundled/upstream/ecc/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  243. package/bundled/upstream/ecc/skills/gan-style-harness/SKILL.md +278 -0
  244. package/bundled/upstream/ecc/skills/gateguard/SKILL.md +121 -0
  245. package/bundled/upstream/ecc/skills/git-workflow/SKILL.md +715 -0
  246. package/bundled/upstream/ecc/skills/github-ops/SKILL.md +144 -0
  247. package/bundled/upstream/ecc/skills/golang-patterns/SKILL.md +674 -0
  248. package/bundled/upstream/ecc/skills/golang-testing/SKILL.md +720 -0
  249. package/bundled/upstream/ecc/skills/google-workspace-ops/SKILL.md +95 -0
  250. package/bundled/upstream/ecc/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  251. package/bundled/upstream/ecc/skills/healthcare-emr-patterns/SKILL.md +159 -0
  252. package/bundled/upstream/ecc/skills/healthcare-eval-harness/SKILL.md +207 -0
  253. package/bundled/upstream/ecc/skills/healthcare-phi-compliance/SKILL.md +145 -0
  254. package/bundled/upstream/ecc/skills/hexagonal-architecture/SKILL.md +276 -0
  255. package/bundled/upstream/ecc/skills/hipaa-compliance/SKILL.md +78 -0
  256. package/bundled/upstream/ecc/skills/hookify-rules/SKILL.md +128 -0
  257. package/bundled/upstream/ecc/skills/inventory-demand-planning/SKILL.md +247 -0
  258. package/bundled/upstream/ecc/skills/investor-materials/SKILL.md +96 -0
  259. package/bundled/upstream/ecc/skills/investor-outreach/SKILL.md +91 -0
  260. package/bundled/upstream/ecc/skills/iterative-retrieval/SKILL.md +211 -0
  261. package/bundled/upstream/ecc/skills/java-coding-standards/SKILL.md +147 -0
  262. package/bundled/upstream/ecc/skills/jira-integration/SKILL.md +293 -0
  263. package/bundled/upstream/ecc/skills/jpa-patterns/SKILL.md +151 -0
  264. package/bundled/upstream/ecc/skills/knowledge-ops/SKILL.md +154 -0
  265. package/bundled/upstream/ecc/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  266. package/bundled/upstream/ecc/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  267. package/bundled/upstream/ecc/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  268. package/bundled/upstream/ecc/skills/kotlin-patterns/SKILL.md +711 -0
  269. package/bundled/upstream/ecc/skills/kotlin-testing/SKILL.md +824 -0
  270. package/bundled/upstream/ecc/skills/laravel-patterns/SKILL.md +415 -0
  271. package/bundled/upstream/ecc/skills/laravel-plugin-discovery/SKILL.md +229 -0
  272. package/bundled/upstream/ecc/skills/laravel-security/SKILL.md +285 -0
  273. package/bundled/upstream/ecc/skills/laravel-tdd/SKILL.md +283 -0
  274. package/bundled/upstream/ecc/skills/laravel-verification/SKILL.md +179 -0
  275. package/bundled/upstream/ecc/skills/lead-intelligence/SKILL.md +321 -0
  276. package/bundled/upstream/ecc/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  277. package/bundled/upstream/ecc/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  278. package/bundled/upstream/ecc/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  279. package/bundled/upstream/ecc/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  280. package/bundled/upstream/ecc/skills/liquid-glass-design/SKILL.md +279 -0
  281. package/bundled/upstream/ecc/skills/llm-trading-agent-security/SKILL.md +146 -0
  282. package/bundled/upstream/ecc/skills/logistics-exception-management/SKILL.md +222 -0
  283. package/bundled/upstream/ecc/skills/manim-video/SKILL.md +89 -0
  284. package/bundled/upstream/ecc/skills/manim-video/assets/network_graph_scene.py +52 -0
  285. package/bundled/upstream/ecc/skills/market-research/SKILL.md +75 -0
  286. package/bundled/upstream/ecc/skills/mcp-server-patterns/SKILL.md +69 -0
  287. package/bundled/upstream/ecc/skills/messages-ops/SKILL.md +104 -0
  288. package/bundled/upstream/ecc/skills/nanoclaw-repl/SKILL.md +33 -0
  289. package/bundled/upstream/ecc/skills/nestjs-patterns/SKILL.md +230 -0
  290. package/bundled/upstream/ecc/skills/nextjs-turbopack/SKILL.md +44 -0
  291. package/bundled/upstream/ecc/skills/nodejs-keccak256/SKILL.md +102 -0
  292. package/bundled/upstream/ecc/skills/nutrient-document-processing/SKILL.md +167 -0
  293. package/bundled/upstream/ecc/skills/nuxt4-patterns/SKILL.md +100 -0
  294. package/bundled/upstream/ecc/skills/openclaw-persona-forge/SKILL.md +296 -0
  295. package/bundled/upstream/ecc/skills/openclaw-persona-forge/gacha.py +224 -0
  296. package/bundled/upstream/ecc/skills/openclaw-persona-forge/gacha.sh +5 -0
  297. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  298. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  299. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  300. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  301. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  302. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/output-template.md +166 -0
  303. package/bundled/upstream/ecc/skills/opensource-pipeline/SKILL.md +255 -0
  304. package/bundled/upstream/ecc/skills/perl-patterns/SKILL.md +504 -0
  305. package/bundled/upstream/ecc/skills/perl-security/SKILL.md +503 -0
  306. package/bundled/upstream/ecc/skills/perl-testing/SKILL.md +475 -0
  307. package/bundled/upstream/ecc/skills/plankton-code-quality/SKILL.md +236 -0
  308. package/bundled/upstream/ecc/skills/postgres-patterns/SKILL.md +147 -0
  309. package/bundled/upstream/ecc/skills/product-capability/SKILL.md +141 -0
  310. package/bundled/upstream/ecc/skills/product-lens/SKILL.md +92 -0
  311. package/bundled/upstream/ecc/skills/production-scheduling/SKILL.md +238 -0
  312. package/bundled/upstream/ecc/skills/project-flow-ops/SKILL.md +111 -0
  313. package/bundled/upstream/ecc/skills/prompt-optimizer/SKILL.md +397 -0
  314. package/bundled/upstream/ecc/skills/python-patterns/SKILL.md +750 -0
  315. package/bundled/upstream/ecc/skills/python-testing/SKILL.md +816 -0
  316. package/bundled/upstream/ecc/skills/pytorch-patterns/SKILL.md +396 -0
  317. package/bundled/upstream/ecc/skills/quality-nonconformance/SKILL.md +260 -0
  318. package/bundled/upstream/ecc/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
  319. package/bundled/upstream/ecc/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  320. package/bundled/upstream/ecc/skills/remotion-video-creation/SKILL.md +43 -0
  321. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/3d.md +86 -0
  322. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/animations.md +29 -0
  323. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  324. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  325. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  326. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets.md +78 -0
  327. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/audio.md +172 -0
  328. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  329. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/can-decode.md +75 -0
  330. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/charts.md +58 -0
  331. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/compositions.md +146 -0
  332. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/display-captions.md +126 -0
  333. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  334. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/fonts.md +152 -0
  335. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  336. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  337. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  338. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/gifs.md +138 -0
  339. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/images.md +130 -0
  340. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  341. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/lottie.md +67 -0
  342. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  343. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  344. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/sequencing.md +106 -0
  345. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/tailwind.md +11 -0
  346. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/text-animations.md +20 -0
  347. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/timing.md +179 -0
  348. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  349. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/transitions.md +122 -0
  350. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/trimming.md +52 -0
  351. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/videos.md +171 -0
  352. package/bundled/upstream/ecc/skills/repo-scan/SKILL.md +78 -0
  353. package/bundled/upstream/ecc/skills/research-ops/SKILL.md +112 -0
  354. package/bundled/upstream/ecc/skills/returns-reverse-logistics/SKILL.md +240 -0
  355. package/bundled/upstream/ecc/skills/rules-distill/SKILL.md +264 -0
  356. package/bundled/upstream/ecc/skills/rules-distill/scripts/scan-rules.sh +58 -0
  357. package/bundled/upstream/ecc/skills/rules-distill/scripts/scan-skills.sh +129 -0
  358. package/bundled/upstream/ecc/skills/rust-patterns/SKILL.md +499 -0
  359. package/bundled/upstream/ecc/skills/rust-testing/SKILL.md +500 -0
  360. package/bundled/upstream/ecc/skills/safety-guard/SKILL.md +75 -0
  361. package/bundled/upstream/ecc/skills/santa-method/SKILL.md +306 -0
  362. package/bundled/upstream/ecc/skills/search-first/SKILL.md +161 -0
  363. package/bundled/upstream/ecc/skills/security-bounty-hunter/SKILL.md +99 -0
  364. package/bundled/upstream/ecc/skills/security-review/SKILL.md +495 -0
  365. package/bundled/upstream/ecc/skills/security-review/cloud-infrastructure-security.md +361 -0
  366. package/bundled/upstream/ecc/skills/security-scan/SKILL.md +165 -0
  367. package/bundled/upstream/ecc/skills/seo/SKILL.md +154 -0
  368. package/bundled/upstream/ecc/skills/skill-comply/SKILL.md +58 -0
  369. package/bundled/upstream/ecc/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  370. package/bundled/upstream/ecc/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  371. package/bundled/upstream/ecc/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  372. package/bundled/upstream/ecc/skills/skill-comply/prompts/classifier.md +24 -0
  373. package/bundled/upstream/ecc/skills/skill-comply/prompts/scenario_generator.md +62 -0
  374. package/bundled/upstream/ecc/skills/skill-comply/prompts/spec_generator.md +42 -0
  375. package/bundled/upstream/ecc/skills/skill-comply/pyproject.toml +15 -0
  376. package/bundled/upstream/ecc/skills/skill-comply/scripts/__init__.py +0 -0
  377. package/bundled/upstream/ecc/skills/skill-comply/scripts/classifier.py +85 -0
  378. package/bundled/upstream/ecc/skills/skill-comply/scripts/grader.py +124 -0
  379. package/bundled/upstream/ecc/skills/skill-comply/scripts/parser.py +107 -0
  380. package/bundled/upstream/ecc/skills/skill-comply/scripts/report.py +170 -0
  381. package/bundled/upstream/ecc/skills/skill-comply/scripts/run.py +127 -0
  382. package/bundled/upstream/ecc/skills/skill-comply/scripts/runner.py +161 -0
  383. package/bundled/upstream/ecc/skills/skill-comply/scripts/scenario_generator.py +70 -0
  384. package/bundled/upstream/ecc/skills/skill-comply/scripts/spec_generator.py +72 -0
  385. package/bundled/upstream/ecc/skills/skill-comply/scripts/utils.py +13 -0
  386. package/bundled/upstream/ecc/skills/skill-comply/tests/test_grader.py +197 -0
  387. package/bundled/upstream/ecc/skills/skill-comply/tests/test_parser.py +90 -0
  388. package/bundled/upstream/ecc/skills/skill-stocktake/SKILL.md +193 -0
  389. package/bundled/upstream/ecc/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  390. package/bundled/upstream/ecc/skills/skill-stocktake/scripts/save-results.sh +56 -0
  391. package/bundled/upstream/ecc/skills/skill-stocktake/scripts/scan.sh +170 -0
  392. package/bundled/upstream/ecc/skills/social-graph-ranker/SKILL.md +154 -0
  393. package/bundled/upstream/ecc/skills/springboot-patterns/SKILL.md +314 -0
  394. package/bundled/upstream/ecc/skills/springboot-security/SKILL.md +272 -0
  395. package/bundled/upstream/ecc/skills/springboot-tdd/SKILL.md +158 -0
  396. package/bundled/upstream/ecc/skills/springboot-verification/SKILL.md +231 -0
  397. package/bundled/upstream/ecc/skills/strategic-compact/SKILL.md +131 -0
  398. package/bundled/upstream/ecc/skills/strategic-compact/suggest-compact.sh +54 -0
  399. package/bundled/upstream/ecc/skills/swift-actor-persistence/SKILL.md +143 -0
  400. package/bundled/upstream/ecc/skills/swift-concurrency-6-2/SKILL.md +216 -0
  401. package/bundled/upstream/ecc/skills/swift-protocol-di-testing/SKILL.md +190 -0
  402. package/bundled/upstream/ecc/skills/swiftui-patterns/SKILL.md +259 -0
  403. package/bundled/upstream/ecc/skills/tdd-workflow/SKILL.md +463 -0
  404. package/bundled/upstream/ecc/skills/team-builder/SKILL.md +168 -0
  405. package/bundled/upstream/ecc/skills/terminal-ops/SKILL.md +109 -0
  406. package/bundled/upstream/ecc/skills/token-budget-advisor/SKILL.md +133 -0
  407. package/bundled/upstream/ecc/skills/ui-demo/SKILL.md +465 -0
  408. package/bundled/upstream/ecc/skills/unified-notifications-ops/SKILL.md +187 -0
  409. package/bundled/upstream/ecc/skills/verification-loop/SKILL.md +126 -0
  410. package/bundled/upstream/ecc/skills/video-editing/SKILL.md +310 -0
  411. package/bundled/upstream/ecc/skills/videodb/SKILL.md +374 -0
  412. package/bundled/upstream/ecc/skills/videodb/reference/api-reference.md +550 -0
  413. package/bundled/upstream/ecc/skills/videodb/reference/capture-reference.md +407 -0
  414. package/bundled/upstream/ecc/skills/videodb/reference/capture.md +101 -0
  415. package/bundled/upstream/ecc/skills/videodb/reference/editor.md +443 -0
  416. package/bundled/upstream/ecc/skills/videodb/reference/generative.md +331 -0
  417. package/bundled/upstream/ecc/skills/videodb/reference/rtstream-reference.md +564 -0
  418. package/bundled/upstream/ecc/skills/videodb/reference/rtstream.md +65 -0
  419. package/bundled/upstream/ecc/skills/videodb/reference/search.md +230 -0
  420. package/bundled/upstream/ecc/skills/videodb/reference/streaming.md +406 -0
  421. package/bundled/upstream/ecc/skills/videodb/reference/use-cases.md +118 -0
  422. package/bundled/upstream/ecc/skills/videodb/scripts/ws_listener.py +282 -0
  423. package/bundled/upstream/ecc/skills/visa-doc-translate/README.md +86 -0
  424. package/bundled/upstream/ecc/skills/visa-doc-translate/SKILL.md +117 -0
  425. package/bundled/upstream/ecc/skills/workspace-surface-audit/SKILL.md +125 -0
  426. package/bundled/upstream/ecc/skills/x-api/SKILL.md +230 -0
  427. package/bundled/upstream/superpowers/.omc-source/last-plan-apply.json +22 -0
  428. package/package.json +3 -1
  429. package/src/catalog/source-catalog.js +391 -0
  430. package/src/cli/artifact.js +3 -2
  431. package/src/cli/doctor.js +25 -4
  432. package/src/cli/index.js +19 -0
  433. package/src/cli/plan.js +220 -0
  434. package/src/cli/setup.js +209 -12
  435. package/src/cli/source.js +110 -3
  436. package/src/config/paths.js +31 -0
  437. package/src/config/sources.js +103 -10
  438. package/src/merge/hook-merger.js +1 -0
@@ -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,161 @@
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
+
19
+
20
+ @dataclass(frozen=True)
21
+ class ScenarioRun:
22
+ scenario: Scenario
23
+ observations: tuple[ObservationEvent, ...]
24
+ sandbox_dir: Path
25
+
26
+
27
+ def run_scenario(
28
+ scenario: Scenario,
29
+ model: str = "sonnet",
30
+ max_turns: int = 30,
31
+ timeout: int = 300,
32
+ ) -> ScenarioRun:
33
+ """Execute a scenario and extract tool calls from stream-json output."""
34
+ if model not in ALLOWED_MODELS:
35
+ raise ValueError(f"Unknown model: {model!r}. Allowed: {ALLOWED_MODELS}")
36
+
37
+ sandbox_dir = _safe_sandbox_dir(scenario.id)
38
+ _setup_sandbox(sandbox_dir, scenario)
39
+
40
+ result = subprocess.run(
41
+ [
42
+ "claude", "-p", scenario.prompt,
43
+ "--model", model,
44
+ "--max-turns", str(max_turns),
45
+ "--add-dir", str(sandbox_dir),
46
+ "--allowedTools", "Read,Write,Edit,Bash,Glob,Grep",
47
+ "--output-format", "stream-json",
48
+ "--verbose",
49
+ ],
50
+ capture_output=True,
51
+ text=True,
52
+ timeout=timeout,
53
+ cwd=sandbox_dir,
54
+ )
55
+
56
+ if result.returncode != 0:
57
+ raise RuntimeError(
58
+ f"claude -p failed (rc={result.returncode}): {result.stderr[:500]}"
59
+ )
60
+
61
+ observations = _parse_stream_json(result.stdout)
62
+
63
+ return ScenarioRun(
64
+ scenario=scenario,
65
+ observations=tuple(observations),
66
+ sandbox_dir=sandbox_dir,
67
+ )
68
+
69
+
70
+ def _safe_sandbox_dir(scenario_id: str) -> Path:
71
+ """Sanitize scenario ID and ensure path stays within sandbox base."""
72
+ safe_id = re.sub(r"[^a-zA-Z0-9\-_]", "_", scenario_id)
73
+ path = SANDBOX_BASE / safe_id
74
+ # Validate path stays within sandbox base (raises ValueError on traversal)
75
+ path.resolve().relative_to(SANDBOX_BASE.resolve())
76
+ return path
77
+
78
+
79
+ def _setup_sandbox(sandbox_dir: Path, scenario: Scenario) -> None:
80
+ """Create sandbox directory and run setup commands."""
81
+ if sandbox_dir.exists():
82
+ shutil.rmtree(sandbox_dir)
83
+ sandbox_dir.mkdir(parents=True)
84
+
85
+ subprocess.run(["git", "init"], cwd=sandbox_dir, capture_output=True)
86
+
87
+ for cmd in scenario.setup_commands:
88
+ parts = shlex.split(cmd)
89
+ subprocess.run(parts, cwd=sandbox_dir, capture_output=True)
90
+
91
+
92
+ def _parse_stream_json(stdout: str) -> list[ObservationEvent]:
93
+ """Parse claude -p stream-json output into ObservationEvents.
94
+
95
+ Stream-json format:
96
+ - type=assistant with content[].type=tool_use → tool call (name, input)
97
+ - type=user with content[].type=tool_result → tool result (output)
98
+ """
99
+ events: list[ObservationEvent] = []
100
+ pending: dict[str, dict] = {}
101
+ event_counter = 0
102
+
103
+ for line in stdout.strip().splitlines():
104
+ try:
105
+ msg = json.loads(line)
106
+ except json.JSONDecodeError:
107
+ continue
108
+
109
+ msg_type = msg.get("type")
110
+
111
+ if msg_type == "assistant":
112
+ content = msg.get("message", {}).get("content", [])
113
+ for block in content:
114
+ if block.get("type") == "tool_use":
115
+ tool_use_id = block.get("id", "")
116
+ tool_input = block.get("input", {})
117
+ input_str = (
118
+ json.dumps(tool_input)[:5000]
119
+ if isinstance(tool_input, dict)
120
+ else str(tool_input)[:5000]
121
+ )
122
+ pending[tool_use_id] = {
123
+ "tool": block.get("name", "unknown"),
124
+ "input": input_str,
125
+ "order": event_counter,
126
+ }
127
+ event_counter += 1
128
+
129
+ elif msg_type == "user":
130
+ content = msg.get("message", {}).get("content", [])
131
+ if isinstance(content, list):
132
+ for block in content:
133
+ tool_use_id = block.get("tool_use_id", "")
134
+ if tool_use_id in pending:
135
+ info = pending.pop(tool_use_id)
136
+ output_content = block.get("content", "")
137
+ if isinstance(output_content, list):
138
+ output_str = json.dumps(output_content)[:5000]
139
+ else:
140
+ output_str = str(output_content)[:5000]
141
+
142
+ events.append(ObservationEvent(
143
+ timestamp=f"T{info['order']:04d}",
144
+ event="tool_complete",
145
+ tool=info["tool"],
146
+ session=msg.get("session_id", "unknown"),
147
+ input=info["input"],
148
+ output=output_str,
149
+ ))
150
+
151
+ for _tool_use_id, info in pending.items():
152
+ events.append(ObservationEvent(
153
+ timestamp=f"T{info['order']:04d}",
154
+ event="tool_complete",
155
+ tool=info["tool"],
156
+ session="unknown",
157
+ input=info["input"],
158
+ output="",
159
+ ))
160
+
161
+ 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)
@@ -0,0 +1,72 @@
1
+ """Generate compliance specs from skill files using LLM."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import subprocess
6
+ import tempfile
7
+ from pathlib import Path
8
+
9
+ import yaml
10
+
11
+ from scripts.parser import ComplianceSpec, parse_spec
12
+ from scripts.utils import extract_yaml
13
+
14
+ PROMPTS_DIR = Path(__file__).parent.parent / "prompts"
15
+
16
+
17
+ def generate_spec(
18
+ skill_path: Path,
19
+ model: str = "haiku",
20
+ max_retries: int = 2,
21
+ ) -> ComplianceSpec:
22
+ """Generate a compliance spec from a skill/rule file.
23
+
24
+ Calls claude -p with the spec_generator prompt, parses YAML output.
25
+ Retries on YAML parse errors with error feedback.
26
+ """
27
+ skill_content = skill_path.read_text()
28
+ prompt_template = (PROMPTS_DIR / "spec_generator.md").read_text()
29
+ base_prompt = prompt_template.replace("{skill_content}", skill_content)
30
+
31
+ last_error: Exception | None = None
32
+
33
+ for attempt in range(max_retries + 1):
34
+ prompt = base_prompt
35
+ if attempt > 0 and last_error is not None:
36
+ prompt += (
37
+ f"\n\nPREVIOUS ATTEMPT FAILED with YAML parse error:\n"
38
+ f"{last_error}\n\n"
39
+ f"Please fix the YAML. Remember to quote all string values "
40
+ f"that contain colons, e.g.: description: \"Use type: description format\""
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
+ raw_yaml = extract_yaml(result.stdout)
54
+
55
+ tmp_path = None
56
+ with tempfile.NamedTemporaryFile(
57
+ mode="w", suffix=".yaml", delete=False,
58
+ ) as f:
59
+ f.write(raw_yaml)
60
+ tmp_path = Path(f.name)
61
+
62
+ try:
63
+ return parse_spec(tmp_path)
64
+ except (yaml.YAMLError, KeyError, TypeError) as e:
65
+ last_error = e
66
+ if attempt == max_retries:
67
+ raise
68
+ finally:
69
+ if tmp_path is not None:
70
+ tmp_path.unlink(missing_ok=True)
71
+
72
+ raise RuntimeError("unreachable")
@@ -0,0 +1,13 @@
1
+ """Shared utilities for skill-comply scripts."""
2
+
3
+ from __future__ import annotations
4
+
5
+
6
+ def extract_yaml(text: str) -> str:
7
+ """Extract YAML from LLM output, stripping markdown fences if present."""
8
+ lines = text.strip().splitlines()
9
+ if lines and lines[0].startswith("```"):
10
+ lines = lines[1:]
11
+ if lines and lines[-1].startswith("```"):
12
+ lines = lines[:-1]
13
+ return "\n".join(lines)