compact-agent 1.10.1 → 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 (697) hide show
  1. package/bin/ecc-hooks.cjs +110 -0
  2. package/dist/ecc.d.ts +11 -0
  3. package/dist/ecc.js +142 -27
  4. package/dist/ecc.js.map +1 -1
  5. package/dist/index.js +47 -7
  6. package/dist/index.js.map +1 -1
  7. package/package.json +1 -1
  8. package/resources/ecc/agents/a11y-architect.md +149 -0
  9. package/resources/ecc/agents/architect.md +11 -3
  10. package/resources/ecc/agents/build-error-resolver.md +11 -4
  11. package/resources/ecc/agents/chief-of-staff.md +11 -4
  12. package/resources/ecc/agents/code-architect.md +80 -0
  13. package/resources/ecc/agents/code-explorer.md +78 -0
  14. package/resources/ecc/agents/code-reviewer.md +89 -4
  15. package/resources/ecc/agents/code-simplifier.md +56 -0
  16. package/resources/ecc/agents/comment-analyzer.md +54 -0
  17. package/resources/ecc/agents/conversation-analyzer.md +61 -0
  18. package/resources/ecc/agents/cpp-build-resolver.md +99 -0
  19. package/resources/ecc/agents/cpp-reviewer.md +81 -0
  20. package/resources/ecc/agents/csharp-reviewer.md +110 -0
  21. package/resources/ecc/agents/dart-build-resolver.md +210 -0
  22. package/resources/ecc/agents/database-reviewer.md +11 -3
  23. package/resources/ecc/agents/django-build-resolver.md +252 -0
  24. package/resources/ecc/agents/django-reviewer.md +169 -0
  25. package/resources/ecc/agents/doc-updater.md +11 -3
  26. package/resources/ecc/agents/docs-lookup.md +77 -0
  27. package/resources/ecc/agents/e2e-runner.md +11 -4
  28. package/resources/ecc/agents/fastapi-reviewer.md +79 -0
  29. package/resources/ecc/agents/flutter-reviewer.md +252 -0
  30. package/resources/ecc/agents/fsharp-reviewer.md +109 -0
  31. package/resources/ecc/agents/gan-evaluator.md +218 -0
  32. package/resources/ecc/agents/gan-generator.md +140 -0
  33. package/resources/ecc/agents/gan-planner.md +108 -0
  34. package/resources/ecc/agents/go-build-resolver.md +11 -4
  35. package/resources/ecc/agents/go-reviewer.md +11 -3
  36. package/resources/ecc/agents/harmonyos-app-resolver.md +182 -0
  37. package/resources/ecc/agents/harness-optimizer.md +12 -2
  38. package/resources/ecc/agents/healthcare-reviewer.md +92 -0
  39. package/resources/ecc/agents/homelab-architect.md +107 -0
  40. package/resources/ecc/agents/java-build-resolver.md +275 -0
  41. package/resources/ecc/agents/java-reviewer.md +190 -0
  42. package/resources/ecc/agents/kotlin-build-resolver.md +127 -0
  43. package/resources/ecc/agents/kotlin-reviewer.md +168 -0
  44. package/resources/ecc/agents/loop-operator.md +12 -3
  45. package/resources/ecc/agents/mle-reviewer.md +162 -0
  46. package/resources/ecc/agents/network-architect.md +106 -0
  47. package/resources/ecc/agents/network-config-reviewer.md +106 -0
  48. package/resources/ecc/agents/network-troubleshooter.md +128 -0
  49. package/resources/ecc/agents/opensource-forker.md +207 -0
  50. package/resources/ecc/agents/opensource-packager.md +258 -0
  51. package/resources/ecc/agents/opensource-sanitizer.md +197 -0
  52. package/resources/ecc/agents/performance-optimizer.md +455 -0
  53. package/resources/ecc/agents/planner.md +11 -2
  54. package/resources/ecc/agents/pr-test-analyzer.md +54 -0
  55. package/resources/ecc/agents/python-reviewer.md +11 -3
  56. package/resources/ecc/agents/pytorch-build-resolver.md +129 -0
  57. package/resources/ecc/agents/refactor-cleaner.md +11 -4
  58. package/resources/ecc/agents/rust-build-resolver.md +157 -0
  59. package/resources/ecc/agents/rust-reviewer.md +103 -0
  60. package/resources/ecc/agents/security-reviewer.md +11 -3
  61. package/resources/ecc/agents/seo-specialist.md +71 -0
  62. package/resources/ecc/agents/silent-failure-hunter.md +59 -0
  63. package/resources/ecc/agents/swift-build-resolver.md +170 -0
  64. package/resources/ecc/agents/swift-reviewer.md +116 -0
  65. package/resources/ecc/agents/tdd-guide.md +11 -4
  66. package/resources/ecc/agents/type-design-analyzer.md +50 -0
  67. package/resources/ecc/agents/typescript-reviewer.md +121 -0
  68. package/resources/ecc/commands/aside.md +164 -0
  69. package/resources/ecc/commands/auto-update.md +28 -0
  70. package/resources/ecc/commands/build-fix.md +66 -0
  71. package/resources/ecc/commands/checkpoint.md +78 -0
  72. package/resources/ecc/commands/code-review.md +289 -0
  73. package/resources/ecc/commands/cost-report.md +107 -0
  74. package/resources/ecc/commands/cpp-build.md +173 -0
  75. package/resources/ecc/commands/cpp-review.md +132 -0
  76. package/resources/ecc/commands/cpp-test.md +251 -0
  77. package/resources/ecc/commands/ecc-guide.md +93 -0
  78. package/resources/ecc/commands/evolve.md +178 -0
  79. package/resources/ecc/commands/fastapi-review.md +39 -0
  80. package/resources/ecc/commands/feature-dev.md +49 -0
  81. package/resources/ecc/commands/flutter-build.md +164 -0
  82. package/resources/ecc/commands/flutter-review.md +116 -0
  83. package/resources/ecc/commands/flutter-test.md +144 -0
  84. package/resources/ecc/commands/gan-build.md +103 -0
  85. package/resources/ecc/commands/gan-design.md +39 -0
  86. package/resources/ecc/commands/go-build.md +183 -0
  87. package/resources/ecc/commands/go-review.md +148 -0
  88. package/resources/ecc/commands/go-test.md +268 -0
  89. package/resources/ecc/commands/gradle-build.md +70 -0
  90. package/resources/ecc/commands/harness-audit.md +77 -0
  91. package/resources/ecc/commands/hookify-configure.md +14 -0
  92. package/resources/ecc/commands/hookify-help.md +46 -0
  93. package/resources/ecc/commands/hookify-list.md +21 -0
  94. package/resources/ecc/commands/hookify.md +50 -0
  95. package/resources/ecc/commands/instinct-export.md +66 -0
  96. package/resources/ecc/commands/instinct-import.md +114 -0
  97. package/resources/ecc/commands/instinct-status.md +59 -0
  98. package/resources/ecc/commands/jira.md +106 -0
  99. package/resources/ecc/commands/kotlin-build.md +174 -0
  100. package/resources/ecc/commands/kotlin-review.md +140 -0
  101. package/resources/ecc/commands/kotlin-test.md +312 -0
  102. package/resources/ecc/commands/learn-eval.md +116 -0
  103. package/resources/ecc/commands/learn.md +74 -0
  104. package/resources/ecc/commands/loop-start.md +36 -0
  105. package/resources/ecc/commands/loop-status.md +77 -0
  106. package/resources/ecc/commands/model-route.md +30 -0
  107. package/resources/ecc/commands/multi-backend.md +162 -0
  108. package/resources/ecc/commands/multi-execute.md +319 -0
  109. package/resources/ecc/commands/multi-frontend.md +162 -0
  110. package/resources/ecc/commands/multi-plan.md +272 -0
  111. package/resources/ecc/commands/multi-workflow.md +195 -0
  112. package/resources/ecc/commands/plan-prd.md +160 -0
  113. package/resources/ecc/commands/plan.md +200 -0
  114. package/resources/ecc/commands/pm2.md +276 -0
  115. package/resources/ecc/commands/pr.md +184 -0
  116. package/resources/ecc/commands/project-init.md +86 -0
  117. package/resources/ecc/commands/projects.md +39 -0
  118. package/resources/ecc/commands/promote.md +41 -0
  119. package/resources/ecc/commands/prp-commit.md +112 -0
  120. package/resources/ecc/commands/prp-implement.md +385 -0
  121. package/resources/ecc/commands/prp-plan.md +502 -0
  122. package/resources/ecc/commands/prp-pr.md +184 -0
  123. package/resources/ecc/commands/prp-prd.md +447 -0
  124. package/resources/ecc/commands/prune.md +31 -0
  125. package/resources/ecc/commands/python-review.md +297 -0
  126. package/resources/ecc/commands/quality-gate.md +33 -0
  127. package/resources/ecc/commands/refactor-clean.md +84 -0
  128. package/resources/ecc/commands/resume-session.md +156 -0
  129. package/resources/ecc/commands/review-pr.md +37 -0
  130. package/resources/ecc/commands/rust-build.md +187 -0
  131. package/resources/ecc/commands/rust-review.md +142 -0
  132. package/resources/ecc/commands/rust-test.md +308 -0
  133. package/resources/ecc/commands/santa-loop.md +175 -0
  134. package/resources/ecc/commands/save-session.md +275 -0
  135. package/resources/ecc/commands/security-scan.md +92 -0
  136. package/resources/ecc/commands/sessions.md +339 -0
  137. package/resources/ecc/commands/setup-pm.md +80 -0
  138. package/resources/ecc/commands/skill-create.md +174 -0
  139. package/resources/ecc/commands/skill-health.md +54 -0
  140. package/resources/ecc/commands/test-coverage.md +73 -0
  141. package/resources/ecc/commands/update-codemaps.md +76 -0
  142. package/resources/ecc/commands/update-docs.md +88 -0
  143. package/resources/ecc/rules/README.md +120 -0
  144. package/resources/ecc/rules/angular/coding-style.md +182 -0
  145. package/resources/ecc/rules/angular/hooks.md +25 -0
  146. package/resources/ecc/rules/angular/patterns.md +249 -0
  147. package/resources/ecc/rules/angular/security.md +87 -0
  148. package/resources/ecc/rules/angular/testing.md +164 -0
  149. package/resources/ecc/rules/arkts/coding-style.md +153 -0
  150. package/resources/ecc/rules/arkts/hooks.md +135 -0
  151. package/resources/ecc/rules/arkts/patterns.md +236 -0
  152. package/resources/ecc/rules/arkts/security.md +141 -0
  153. package/resources/ecc/rules/arkts/testing.md +126 -0
  154. package/resources/ecc/rules/{common-agents.md → common/agents.md} +2 -4
  155. package/resources/ecc/rules/common/code-review.md +124 -0
  156. package/resources/ecc/rules/{common-coding-style.md → common/coding-style.md} +42 -4
  157. package/resources/ecc/rules/common/development-workflow.md +44 -0
  158. package/resources/ecc/rules/{common-git-workflow.md → common/git-workflow.md} +1 -5
  159. package/resources/ecc/rules/{common-hooks.md → common/hooks.md} +0 -4
  160. package/resources/ecc/rules/{common-patterns.md → common/patterns.md} +0 -4
  161. package/resources/ecc/rules/{common-performance.md → common/performance.md} +0 -4
  162. package/resources/ecc/rules/{common-security.md → common/security.md} +0 -4
  163. package/resources/ecc/rules/{common-testing.md → common/testing.md} +28 -4
  164. package/resources/ecc/rules/cpp/coding-style.md +44 -0
  165. package/resources/ecc/rules/cpp/hooks.md +39 -0
  166. package/resources/ecc/rules/cpp/patterns.md +51 -0
  167. package/resources/ecc/rules/cpp/security.md +51 -0
  168. package/resources/ecc/rules/cpp/testing.md +44 -0
  169. package/resources/ecc/rules/csharp/coding-style.md +72 -0
  170. package/resources/ecc/rules/csharp/hooks.md +25 -0
  171. package/resources/ecc/rules/csharp/patterns.md +50 -0
  172. package/resources/ecc/rules/csharp/security.md +58 -0
  173. package/resources/ecc/rules/csharp/testing.md +46 -0
  174. package/resources/ecc/rules/dart/coding-style.md +159 -0
  175. package/resources/ecc/rules/dart/hooks.md +66 -0
  176. package/resources/ecc/rules/dart/patterns.md +261 -0
  177. package/resources/ecc/rules/dart/security.md +135 -0
  178. package/resources/ecc/rules/dart/testing.md +215 -0
  179. package/resources/ecc/rules/fsharp/coding-style.md +112 -0
  180. package/resources/ecc/rules/fsharp/hooks.md +26 -0
  181. package/resources/ecc/rules/fsharp/patterns.md +111 -0
  182. package/resources/ecc/rules/fsharp/security.md +76 -0
  183. package/resources/ecc/rules/fsharp/testing.md +62 -0
  184. package/resources/ecc/rules/{golang-coding-style.md → golang/coding-style.md} +6 -5
  185. package/resources/ecc/rules/{golang-hooks.md → golang/hooks.md} +5 -4
  186. package/resources/ecc/rules/{golang-patterns.md → golang/patterns.md} +5 -4
  187. package/resources/ecc/rules/{golang-security.md → golang/security.md} +5 -4
  188. package/resources/ecc/rules/{golang-testing.md → golang/testing.md} +5 -4
  189. package/resources/ecc/rules/java/coding-style.md +114 -0
  190. package/resources/ecc/rules/java/hooks.md +18 -0
  191. package/resources/ecc/rules/java/patterns.md +147 -0
  192. package/resources/ecc/rules/java/security.md +101 -0
  193. package/resources/ecc/rules/java/testing.md +133 -0
  194. package/resources/ecc/rules/kotlin/coding-style.md +86 -0
  195. package/resources/ecc/rules/{kotlin-hooks.md → kotlin/hooks.md} +5 -4
  196. package/resources/ecc/rules/kotlin/patterns.md +146 -0
  197. package/resources/ecc/rules/kotlin/security.md +82 -0
  198. package/resources/ecc/rules/kotlin/testing.md +128 -0
  199. package/resources/ecc/rules/perl/coding-style.md +46 -0
  200. package/resources/ecc/rules/perl/hooks.md +22 -0
  201. package/resources/ecc/rules/perl/patterns.md +76 -0
  202. package/resources/ecc/rules/perl/security.md +69 -0
  203. package/resources/ecc/rules/perl/testing.md +54 -0
  204. package/resources/ecc/rules/php/coding-style.md +40 -0
  205. package/resources/ecc/rules/{php-hooks.md → php/hooks.md} +7 -4
  206. package/resources/ecc/rules/php/patterns.md +33 -0
  207. package/resources/ecc/rules/php/security.md +37 -0
  208. package/resources/ecc/rules/php/testing.md +39 -0
  209. package/resources/ecc/rules/{python-coding-style.md → python/coding-style.md} +4 -4
  210. package/resources/ecc/rules/python/fastapi.md +58 -0
  211. package/resources/ecc/rules/{python-hooks.md → python/hooks.md} +4 -4
  212. package/resources/ecc/rules/{python-patterns.md → python/patterns.md} +4 -4
  213. package/resources/ecc/rules/{python-security.md → python/security.md} +4 -4
  214. package/resources/ecc/rules/{python-testing.md → python/testing.md} +4 -4
  215. package/resources/ecc/rules/ruby/coding-style.md +46 -0
  216. package/resources/ecc/rules/ruby/hooks.md +37 -0
  217. package/resources/ecc/rules/ruby/patterns.md +44 -0
  218. package/resources/ecc/rules/ruby/security.md +51 -0
  219. package/resources/ecc/rules/ruby/testing.md +51 -0
  220. package/resources/ecc/rules/rust/coding-style.md +151 -0
  221. package/resources/ecc/rules/rust/hooks.md +16 -0
  222. package/resources/ecc/rules/rust/patterns.md +168 -0
  223. package/resources/ecc/rules/rust/security.md +141 -0
  224. package/resources/ecc/rules/rust/testing.md +154 -0
  225. package/resources/ecc/rules/{swift-coding-style.md → swift/coding-style.md} +6 -6
  226. package/resources/ecc/rules/swift/hooks.md +20 -0
  227. package/resources/ecc/rules/{swift-patterns.md → swift/patterns.md} +5 -5
  228. package/resources/ecc/rules/{swift-security.md → swift/security.md} +7 -7
  229. package/resources/ecc/rules/{swift-testing.md → swift/testing.md} +5 -5
  230. package/resources/ecc/rules/typescript/coding-style.md +199 -0
  231. package/resources/ecc/rules/{typescript-hooks.md → typescript/hooks.md} +6 -4
  232. package/resources/ecc/rules/{typescript-patterns.md → typescript/patterns.md} +6 -4
  233. package/resources/ecc/rules/{typescript-security.md → typescript/security.md} +6 -4
  234. package/resources/ecc/rules/typescript/testing.md +18 -0
  235. package/resources/ecc/rules/web/coding-style.md +96 -0
  236. package/resources/ecc/rules/web/design-quality.md +63 -0
  237. package/resources/ecc/rules/web/hooks.md +129 -0
  238. package/resources/ecc/rules/web/patterns.md +79 -0
  239. package/resources/ecc/rules/web/performance.md +64 -0
  240. package/resources/ecc/rules/web/security.md +57 -0
  241. package/resources/ecc/rules/web/testing.md +55 -0
  242. package/resources/ecc/rules/zh/README.md +108 -0
  243. package/resources/ecc/rules/zh/agents.md +50 -0
  244. package/resources/ecc/rules/zh/code-review.md +124 -0
  245. package/resources/ecc/rules/zh/coding-style.md +48 -0
  246. package/resources/ecc/rules/zh/development-workflow.md +44 -0
  247. package/resources/ecc/rules/zh/git-workflow.md +24 -0
  248. package/resources/ecc/rules/zh/hooks.md +30 -0
  249. package/resources/ecc/rules/zh/patterns.md +31 -0
  250. package/resources/ecc/rules/zh/performance.md +55 -0
  251. package/resources/ecc/rules/zh/security.md +29 -0
  252. package/resources/ecc/rules/zh/testing.md +29 -0
  253. package/resources/ecc/skills/accessibility/SKILL.md +146 -0
  254. package/resources/ecc/skills/agent-architecture-audit/SKILL.md +256 -0
  255. package/resources/ecc/skills/agent-eval/SKILL.md +145 -0
  256. package/resources/ecc/skills/agent-harness-construction/SKILL.md +73 -0
  257. package/resources/ecc/skills/agent-introspection-debugging/SKILL.md +1 -0
  258. package/resources/ecc/skills/agent-payment-x402/SKILL.md +224 -0
  259. package/resources/ecc/skills/agent-sort/SKILL.md +1 -0
  260. package/resources/ecc/skills/agentic-engineering/SKILL.md +63 -0
  261. package/resources/ecc/skills/agentic-os/SKILL.md +387 -0
  262. package/resources/ecc/skills/ai-first-engineering/SKILL.md +51 -0
  263. package/resources/ecc/skills/ai-regression-testing/SKILL.md +385 -0
  264. package/resources/ecc/skills/android-clean-architecture/SKILL.md +339 -0
  265. package/resources/ecc/skills/angular-developer/SKILL.md +154 -0
  266. package/resources/ecc/skills/angular-developer/references/angular-animations.md +160 -0
  267. package/resources/ecc/skills/angular-developer/references/angular-aria.md +410 -0
  268. package/resources/ecc/skills/angular-developer/references/cli.md +86 -0
  269. package/resources/ecc/skills/angular-developer/references/component-harnesses.md +59 -0
  270. package/resources/ecc/skills/angular-developer/references/component-styling.md +91 -0
  271. package/resources/ecc/skills/angular-developer/references/components.md +117 -0
  272. package/resources/ecc/skills/angular-developer/references/creating-services.md +97 -0
  273. package/resources/ecc/skills/angular-developer/references/data-resolvers.md +69 -0
  274. package/resources/ecc/skills/angular-developer/references/define-routes.md +67 -0
  275. package/resources/ecc/skills/angular-developer/references/defining-providers.md +72 -0
  276. package/resources/ecc/skills/angular-developer/references/di-fundamentals.md +120 -0
  277. package/resources/ecc/skills/angular-developer/references/e2e-testing.md +56 -0
  278. package/resources/ecc/skills/angular-developer/references/effects.md +83 -0
  279. package/resources/ecc/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  280. package/resources/ecc/skills/angular-developer/references/host-elements.md +80 -0
  281. package/resources/ecc/skills/angular-developer/references/injection-context.md +63 -0
  282. package/resources/ecc/skills/angular-developer/references/inputs.md +101 -0
  283. package/resources/ecc/skills/angular-developer/references/linked-signal.md +59 -0
  284. package/resources/ecc/skills/angular-developer/references/loading-strategies.md +61 -0
  285. package/resources/ecc/skills/angular-developer/references/mcp.md +108 -0
  286. package/resources/ecc/skills/angular-developer/references/navigate-to-routes.md +69 -0
  287. package/resources/ecc/skills/angular-developer/references/outputs.md +86 -0
  288. package/resources/ecc/skills/angular-developer/references/reactive-forms.md +122 -0
  289. package/resources/ecc/skills/angular-developer/references/rendering-strategies.md +44 -0
  290. package/resources/ecc/skills/angular-developer/references/resource.md +77 -0
  291. package/resources/ecc/skills/angular-developer/references/route-animations.md +56 -0
  292. package/resources/ecc/skills/angular-developer/references/route-guards.md +52 -0
  293. package/resources/ecc/skills/angular-developer/references/router-lifecycle.md +45 -0
  294. package/resources/ecc/skills/angular-developer/references/router-testing.md +87 -0
  295. package/resources/ecc/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  296. package/resources/ecc/skills/angular-developer/references/signal-forms.md +795 -0
  297. package/resources/ecc/skills/angular-developer/references/signals-overview.md +94 -0
  298. package/resources/ecc/skills/angular-developer/references/tailwind-css.md +69 -0
  299. package/resources/ecc/skills/angular-developer/references/template-driven-forms.md +114 -0
  300. package/resources/ecc/skills/angular-developer/references/testing-fundamentals.md +65 -0
  301. package/resources/ecc/skills/api-connector-builder/SKILL.md +120 -0
  302. package/resources/ecc/skills/api-design/SKILL.md +1 -0
  303. package/resources/ecc/skills/architecture-decision-records/SKILL.md +179 -0
  304. package/resources/ecc/skills/article-writing/SKILL.md +1 -0
  305. package/resources/ecc/skills/automation-audit-ops/SKILL.md +142 -0
  306. package/resources/ecc/skills/autonomous-agent-harness/SKILL.md +273 -0
  307. package/resources/ecc/skills/autonomous-loops/SKILL.md +610 -0
  308. package/resources/ecc/skills/backend-patterns/SKILL.md +8 -44
  309. package/resources/ecc/skills/benchmark/SKILL.md +93 -0
  310. package/resources/ecc/skills/blueprint/SKILL.md +105 -0
  311. package/resources/ecc/skills/brand-voice/SKILL.md +1 -0
  312. package/resources/ecc/skills/browser-qa/SKILL.md +87 -0
  313. package/resources/ecc/skills/bun-runtime/SKILL.md +1 -0
  314. package/resources/ecc/skills/canary-watch/SKILL.md +99 -0
  315. package/resources/ecc/skills/carrier-relationship-management/SKILL.md +212 -0
  316. package/resources/ecc/skills/cisco-ios-patterns/SKILL.md +163 -0
  317. package/resources/ecc/skills/ck/SKILL.md +147 -0
  318. package/resources/ecc/skills/ck/commands/forget.mjs +44 -0
  319. package/resources/ecc/skills/ck/commands/info.mjs +24 -0
  320. package/resources/ecc/skills/ck/commands/init.mjs +143 -0
  321. package/resources/ecc/skills/ck/commands/list.mjs +40 -0
  322. package/resources/ecc/skills/ck/commands/migrate.mjs +202 -0
  323. package/resources/ecc/skills/ck/commands/resume.mjs +36 -0
  324. package/resources/ecc/skills/ck/commands/save.mjs +210 -0
  325. package/resources/ecc/skills/ck/commands/shared.mjs +387 -0
  326. package/resources/ecc/skills/ck/hooks/session-start.mjs +224 -0
  327. package/resources/ecc/skills/claude-devfleet/SKILL.md +103 -0
  328. package/resources/ecc/skills/click-path-audit/SKILL.md +244 -0
  329. package/resources/ecc/skills/clickhouse-io/SKILL.md +439 -0
  330. package/resources/ecc/skills/code-tour/SKILL.md +236 -0
  331. package/resources/ecc/skills/codebase-onboarding/SKILL.md +233 -0
  332. package/resources/ecc/skills/coding-standards/SKILL.md +1 -0
  333. package/resources/ecc/skills/compose-multiplatform-patterns/SKILL.md +299 -0
  334. package/resources/ecc/skills/configure-ecc/SKILL.md +384 -0
  335. package/resources/ecc/skills/connections-optimizer/SKILL.md +189 -0
  336. package/resources/ecc/skills/content-engine/SKILL.md +1 -0
  337. package/resources/ecc/skills/content-hash-cache-pattern/SKILL.md +161 -0
  338. package/resources/ecc/skills/context-budget/SKILL.md +135 -0
  339. package/resources/ecc/skills/continuous-agent-loop/SKILL.md +45 -0
  340. package/resources/ecc/skills/continuous-learning/SKILL.md +131 -0
  341. package/resources/ecc/skills/continuous-learning/config.json +18 -0
  342. package/resources/ecc/skills/continuous-learning/evaluate-session.sh +69 -0
  343. package/resources/ecc/skills/continuous-learning-v2/SKILL.md +360 -0
  344. package/resources/ecc/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
  345. package/resources/ecc/skills/continuous-learning-v2/agents/observer.md +198 -0
  346. package/resources/ecc/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  347. package/resources/ecc/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  348. package/resources/ecc/skills/continuous-learning-v2/config.json +8 -0
  349. package/resources/ecc/skills/continuous-learning-v2/hooks/observe.sh +476 -0
  350. package/resources/ecc/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
  351. package/resources/ecc/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
  352. package/resources/ecc/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  353. package/resources/ecc/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  354. package/resources/ecc/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
  355. package/resources/ecc/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  356. package/resources/ecc/skills/cost-tracking/SKILL.md +147 -0
  357. package/resources/ecc/skills/council/SKILL.md +203 -0
  358. package/resources/ecc/skills/cpp-coding-standards/SKILL.md +723 -0
  359. package/resources/ecc/skills/cpp-testing/SKILL.md +324 -0
  360. package/resources/ecc/skills/crosspost/SKILL.md +1 -0
  361. package/resources/ecc/skills/csharp-testing/SKILL.md +321 -0
  362. package/resources/ecc/skills/customer-billing-ops/SKILL.md +140 -0
  363. package/resources/ecc/skills/customs-trade-compliance/SKILL.md +263 -0
  364. package/resources/ecc/skills/dart-flutter-patterns/SKILL.md +563 -0
  365. package/resources/ecc/skills/dashboard-builder/SKILL.md +108 -0
  366. package/resources/ecc/skills/data-scraper-agent/SKILL.md +764 -0
  367. package/resources/ecc/skills/database-migrations/SKILL.md +429 -0
  368. package/resources/ecc/skills/deep-research/SKILL.md +5 -0
  369. package/resources/ecc/skills/defi-amm-security/SKILL.md +166 -0
  370. package/resources/ecc/skills/deployment-patterns/SKILL.md +427 -0
  371. package/resources/ecc/skills/design-system/SKILL.md +82 -0
  372. package/resources/ecc/skills/django-celery/SKILL.md +457 -0
  373. package/resources/ecc/skills/django-patterns/SKILL.md +734 -0
  374. package/resources/ecc/skills/django-security/SKILL.md +593 -0
  375. package/resources/ecc/skills/django-tdd/SKILL.md +729 -0
  376. package/resources/ecc/skills/django-verification/SKILL.md +469 -0
  377. package/resources/ecc/skills/dmux-workflows/SKILL.md +52 -4
  378. package/resources/ecc/skills/docker-patterns/SKILL.md +364 -0
  379. package/resources/ecc/skills/documentation-lookup/SKILL.md +1 -0
  380. package/resources/ecc/skills/dotnet-patterns/SKILL.md +321 -0
  381. package/resources/ecc/skills/e2e-testing/SKILL.md +1 -0
  382. package/resources/ecc/skills/ecc-guide/SKILL.md +189 -0
  383. package/resources/ecc/skills/ecc-tools-cost-audit/SKILL.md +160 -0
  384. package/resources/ecc/skills/email-ops/SKILL.md +121 -0
  385. package/resources/ecc/skills/energy-procurement/SKILL.md +228 -0
  386. package/resources/ecc/skills/enterprise-agent-ops/SKILL.md +50 -0
  387. package/resources/ecc/skills/error-handling/SKILL.md +376 -0
  388. package/resources/ecc/skills/eval-harness/SKILL.md +36 -1
  389. package/resources/ecc/skills/evm-token-decimals/SKILL.md +130 -0
  390. package/resources/ecc/skills/exa-search/SKILL.md +18 -80
  391. package/resources/ecc/skills/fal-ai-media/SKILL.md +32 -20
  392. package/resources/ecc/skills/fastapi-patterns/SKILL.md +327 -0
  393. package/resources/ecc/skills/finance-billing-ops/SKILL.md +127 -0
  394. package/resources/ecc/skills/flox-environments/SKILL.md +496 -0
  395. package/resources/ecc/skills/flutter-dart-code-review/SKILL.md +435 -0
  396. package/resources/ecc/skills/foundation-models-on-device/SKILL.md +243 -0
  397. package/resources/ecc/skills/frontend-design-direction/SKILL.md +92 -0
  398. package/resources/ecc/skills/frontend-patterns/SKILL.md +1 -6
  399. package/resources/ecc/skills/frontend-slides/SKILL.md +2 -1
  400. package/resources/ecc/skills/frontend-slides/animation-patterns.md +122 -0
  401. package/resources/ecc/skills/frontend-slides/html-template.md +419 -0
  402. package/resources/ecc/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  403. package/resources/ecc/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  404. package/resources/ecc/skills/frontend-slides/viewport-base.css +153 -0
  405. package/resources/ecc/skills/fsharp-testing/SKILL.md +280 -0
  406. package/resources/ecc/skills/gan-style-harness/SKILL.md +278 -0
  407. package/resources/ecc/skills/gateguard/SKILL.md +125 -0
  408. package/resources/ecc/skills/git-workflow/SKILL.md +715 -0
  409. package/resources/ecc/skills/github-ops/SKILL.md +144 -0
  410. package/resources/ecc/skills/golang-patterns/SKILL.md +674 -0
  411. package/resources/ecc/skills/golang-testing/SKILL.md +720 -0
  412. package/resources/ecc/skills/google-workspace-ops/SKILL.md +95 -0
  413. package/resources/ecc/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  414. package/resources/ecc/skills/healthcare-emr-patterns/SKILL.md +159 -0
  415. package/resources/ecc/skills/healthcare-eval-harness/SKILL.md +207 -0
  416. package/resources/ecc/skills/healthcare-phi-compliance/SKILL.md +145 -0
  417. package/resources/ecc/skills/hermes-imports/SKILL.md +88 -0
  418. package/resources/ecc/skills/hexagonal-architecture/SKILL.md +276 -0
  419. package/resources/ecc/skills/hipaa-compliance/SKILL.md +78 -0
  420. package/resources/ecc/skills/homelab-network-readiness/SKILL.md +169 -0
  421. package/resources/ecc/skills/homelab-network-setup/SKILL.md +129 -0
  422. package/resources/ecc/skills/homelab-pihole-dns/SKILL.md +274 -0
  423. package/resources/ecc/skills/homelab-vlan-segmentation/SKILL.md +311 -0
  424. package/resources/ecc/skills/homelab-wireguard-vpn/SKILL.md +305 -0
  425. package/resources/ecc/skills/hookify-rules/SKILL.md +128 -0
  426. package/resources/ecc/skills/inventory-demand-planning/SKILL.md +247 -0
  427. package/resources/ecc/skills/investor-materials/SKILL.md +1 -0
  428. package/resources/ecc/skills/investor-outreach/SKILL.md +1 -0
  429. package/resources/ecc/skills/ios-icon-gen/SKILL.md +157 -0
  430. package/resources/ecc/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  431. package/resources/ecc/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  432. package/resources/ecc/skills/iterative-retrieval/SKILL.md +211 -0
  433. package/resources/ecc/skills/java-coding-standards/SKILL.md +383 -0
  434. package/resources/ecc/skills/jira-integration/SKILL.md +293 -0
  435. package/resources/ecc/skills/jpa-patterns/SKILL.md +151 -0
  436. package/resources/ecc/skills/knowledge-ops/SKILL.md +154 -0
  437. package/resources/ecc/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  438. package/resources/ecc/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  439. package/resources/ecc/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  440. package/resources/ecc/skills/kotlin-patterns/SKILL.md +711 -0
  441. package/resources/ecc/skills/kotlin-testing/SKILL.md +824 -0
  442. package/resources/ecc/skills/laravel-patterns/SKILL.md +415 -0
  443. package/resources/ecc/skills/laravel-plugin-discovery/SKILL.md +229 -0
  444. package/resources/ecc/skills/laravel-security/SKILL.md +285 -0
  445. package/resources/ecc/skills/laravel-tdd/SKILL.md +283 -0
  446. package/resources/ecc/skills/laravel-verification/SKILL.md +179 -0
  447. package/resources/ecc/skills/lead-intelligence/SKILL.md +321 -0
  448. package/resources/ecc/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  449. package/resources/ecc/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  450. package/resources/ecc/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  451. package/resources/ecc/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  452. package/resources/ecc/skills/liquid-glass-design/SKILL.md +279 -0
  453. package/resources/ecc/skills/llm-trading-agent-security/SKILL.md +146 -0
  454. package/resources/ecc/skills/logistics-exception-management/SKILL.md +222 -0
  455. package/resources/ecc/skills/make-interfaces-feel-better/SKILL.md +151 -0
  456. package/resources/ecc/skills/manim-video/SKILL.md +89 -0
  457. package/resources/ecc/skills/manim-video/assets/network_graph_scene.py +52 -0
  458. package/resources/ecc/skills/market-research/SKILL.md +1 -0
  459. package/resources/ecc/skills/mcp-server-patterns/SKILL.md +3 -0
  460. package/resources/ecc/skills/messages-ops/SKILL.md +104 -0
  461. package/resources/ecc/skills/mle-workflow/SKILL.md +1 -1
  462. package/resources/ecc/skills/motion-advanced/SKILL.md +596 -0
  463. package/resources/ecc/skills/motion-foundations/SKILL.md +299 -0
  464. package/resources/ecc/skills/motion-patterns/SKILL.md +435 -0
  465. package/resources/ecc/skills/motion-ui/SKILL.md +575 -0
  466. package/resources/ecc/skills/mysql-patterns/SKILL.md +412 -0
  467. package/resources/ecc/skills/nanoclaw-repl/SKILL.md +33 -0
  468. package/resources/ecc/skills/nestjs-patterns/SKILL.md +230 -0
  469. package/resources/ecc/skills/netmiko-ssh-automation/SKILL.md +173 -0
  470. package/resources/ecc/skills/network-bgp-diagnostics/SKILL.md +167 -0
  471. package/resources/ecc/skills/network-config-validation/SKILL.md +210 -0
  472. package/resources/ecc/skills/network-interface-health/SKILL.md +152 -0
  473. package/resources/ecc/skills/nextjs-turbopack/SKILL.md +1 -0
  474. package/resources/ecc/skills/nodejs-keccak256/SKILL.md +102 -0
  475. package/resources/ecc/skills/nutrient-document-processing/SKILL.md +167 -0
  476. package/resources/ecc/skills/nuxt4-patterns/SKILL.md +100 -0
  477. package/resources/ecc/skills/openclaw-persona-forge/SKILL.md +288 -0
  478. package/resources/ecc/skills/openclaw-persona-forge/gacha.py +224 -0
  479. package/resources/ecc/skills/openclaw-persona-forge/gacha.sh +5 -0
  480. package/resources/ecc/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  481. package/resources/ecc/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  482. package/resources/ecc/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  483. package/resources/ecc/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  484. package/resources/ecc/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  485. package/resources/ecc/skills/openclaw-persona-forge/references/output-template.md +166 -0
  486. package/resources/ecc/skills/opensource-pipeline/SKILL.md +255 -0
  487. package/resources/ecc/skills/perl-patterns/SKILL.md +504 -0
  488. package/resources/ecc/skills/perl-security/SKILL.md +503 -0
  489. package/resources/ecc/skills/perl-testing/SKILL.md +475 -0
  490. package/resources/ecc/skills/plan-orchestrate/SKILL.md +262 -0
  491. package/resources/ecc/skills/plankton-code-quality/SKILL.md +236 -0
  492. package/resources/ecc/skills/postgres-patterns/SKILL.md +147 -0
  493. package/resources/ecc/skills/product-capability/SKILL.md +1 -0
  494. package/resources/ecc/skills/product-lens/SKILL.md +92 -0
  495. package/resources/ecc/skills/production-audit/SKILL.md +206 -0
  496. package/resources/ecc/skills/production-scheduling/SKILL.md +238 -0
  497. package/resources/ecc/skills/project-flow-ops/SKILL.md +111 -0
  498. package/resources/ecc/skills/prompt-optimizer/SKILL.md +398 -0
  499. package/resources/ecc/skills/python-patterns/SKILL.md +750 -0
  500. package/resources/ecc/skills/python-testing/SKILL.md +816 -0
  501. package/resources/ecc/skills/pytorch-patterns/SKILL.md +396 -0
  502. package/resources/ecc/skills/quality-nonconformance/SKILL.md +260 -0
  503. package/resources/ecc/skills/quarkus-patterns/SKILL.md +722 -0
  504. package/resources/ecc/skills/quarkus-security/SKILL.md +467 -0
  505. package/resources/ecc/skills/quarkus-tdd/SKILL.md +811 -0
  506. package/resources/ecc/skills/quarkus-verification/SKILL.md +479 -0
  507. package/resources/ecc/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
  508. package/resources/ecc/skills/redis-patterns/SKILL.md +403 -0
  509. package/resources/ecc/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  510. package/resources/ecc/skills/remotion-video-creation/SKILL.md +43 -0
  511. package/resources/ecc/skills/remotion-video-creation/rules/3d.md +86 -0
  512. package/resources/ecc/skills/remotion-video-creation/rules/animations.md +29 -0
  513. package/resources/ecc/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  514. package/resources/ecc/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  515. package/resources/ecc/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  516. package/resources/ecc/skills/remotion-video-creation/rules/assets.md +78 -0
  517. package/resources/ecc/skills/remotion-video-creation/rules/audio.md +172 -0
  518. package/resources/ecc/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  519. package/resources/ecc/skills/remotion-video-creation/rules/can-decode.md +75 -0
  520. package/resources/ecc/skills/remotion-video-creation/rules/charts.md +58 -0
  521. package/resources/ecc/skills/remotion-video-creation/rules/compositions.md +146 -0
  522. package/resources/ecc/skills/remotion-video-creation/rules/display-captions.md +126 -0
  523. package/resources/ecc/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  524. package/resources/ecc/skills/remotion-video-creation/rules/fonts.md +152 -0
  525. package/resources/ecc/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  526. package/resources/ecc/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  527. package/resources/ecc/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  528. package/resources/ecc/skills/remotion-video-creation/rules/gifs.md +138 -0
  529. package/resources/ecc/skills/remotion-video-creation/rules/images.md +130 -0
  530. package/resources/ecc/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  531. package/resources/ecc/skills/remotion-video-creation/rules/lottie.md +67 -0
  532. package/resources/ecc/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  533. package/resources/ecc/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  534. package/resources/ecc/skills/remotion-video-creation/rules/sequencing.md +106 -0
  535. package/resources/ecc/skills/remotion-video-creation/rules/tailwind.md +11 -0
  536. package/resources/ecc/skills/remotion-video-creation/rules/text-animations.md +20 -0
  537. package/resources/ecc/skills/remotion-video-creation/rules/timing.md +179 -0
  538. package/resources/ecc/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  539. package/resources/ecc/skills/remotion-video-creation/rules/transitions.md +122 -0
  540. package/resources/ecc/skills/remotion-video-creation/rules/trimming.md +52 -0
  541. package/resources/ecc/skills/remotion-video-creation/rules/videos.md +171 -0
  542. package/resources/ecc/skills/repo-scan/SKILL.md +78 -0
  543. package/resources/ecc/skills/research-ops/SKILL.md +112 -0
  544. package/resources/ecc/skills/returns-reverse-logistics/SKILL.md +240 -0
  545. package/resources/ecc/skills/rules-distill/SKILL.md +264 -0
  546. package/resources/ecc/skills/rules-distill/scripts/scan-rules.sh +58 -0
  547. package/resources/ecc/skills/rules-distill/scripts/scan-skills.sh +129 -0
  548. package/resources/ecc/skills/rust-patterns/SKILL.md +499 -0
  549. package/resources/ecc/skills/rust-testing/SKILL.md +500 -0
  550. package/resources/ecc/skills/safety-guard/SKILL.md +75 -0
  551. package/resources/ecc/skills/santa-method/SKILL.md +306 -0
  552. package/resources/ecc/skills/scientific-db-pubmed-database/SKILL.md +175 -0
  553. package/resources/ecc/skills/scientific-db-uspto-database/SKILL.md +177 -0
  554. package/resources/ecc/skills/scientific-pkg-gget/SKILL.md +166 -0
  555. package/resources/ecc/skills/scientific-thinking-literature-review/SKILL.md +192 -0
  556. package/resources/ecc/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  557. package/resources/ecc/skills/search-first/SKILL.md +182 -0
  558. package/resources/ecc/skills/security-bounty-hunter/SKILL.md +99 -0
  559. package/resources/ecc/skills/security-review/SKILL.md +11 -2
  560. package/resources/ecc/skills/security-review/cloud-infrastructure-security.md +361 -0
  561. package/resources/ecc/skills/security-scan/SKILL.md +165 -0
  562. package/resources/ecc/skills/seo/SKILL.md +154 -0
  563. package/resources/ecc/skills/skill-comply/SKILL.md +58 -0
  564. package/resources/ecc/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  565. package/resources/ecc/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  566. package/resources/ecc/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  567. package/resources/ecc/skills/skill-comply/prompts/classifier.md +24 -0
  568. package/resources/ecc/skills/skill-comply/prompts/scenario_generator.md +62 -0
  569. package/resources/ecc/skills/skill-comply/prompts/spec_generator.md +42 -0
  570. package/resources/ecc/skills/skill-comply/pyproject.toml +15 -0
  571. package/resources/ecc/skills/skill-comply/scripts/__init__.py +0 -0
  572. package/resources/ecc/skills/skill-comply/scripts/classifier.py +85 -0
  573. package/resources/ecc/skills/skill-comply/scripts/grader.py +124 -0
  574. package/resources/ecc/skills/skill-comply/scripts/parser.py +107 -0
  575. package/resources/ecc/skills/skill-comply/scripts/report.py +170 -0
  576. package/resources/ecc/skills/skill-comply/scripts/run.py +127 -0
  577. package/resources/ecc/skills/skill-comply/scripts/runner.py +186 -0
  578. package/resources/ecc/skills/skill-comply/scripts/scenario_generator.py +70 -0
  579. package/resources/ecc/skills/skill-comply/scripts/spec_generator.py +72 -0
  580. package/resources/ecc/skills/skill-comply/scripts/utils.py +13 -0
  581. package/resources/ecc/skills/skill-comply/tests/test_grader.py +197 -0
  582. package/resources/ecc/skills/skill-comply/tests/test_parser.py +90 -0
  583. package/resources/ecc/skills/skill-comply/tests/test_runner.py +172 -0
  584. package/resources/ecc/skills/skill-scout/SKILL.md +140 -0
  585. package/resources/ecc/skills/skill-stocktake/SKILL.md +194 -0
  586. package/resources/ecc/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  587. package/resources/ecc/skills/skill-stocktake/scripts/save-results.sh +56 -0
  588. package/resources/ecc/skills/skill-stocktake/scripts/scan.sh +170 -0
  589. package/resources/ecc/skills/social-graph-ranker/SKILL.md +154 -0
  590. package/resources/ecc/skills/springboot-patterns/SKILL.md +314 -0
  591. package/resources/ecc/skills/springboot-security/SKILL.md +272 -0
  592. package/resources/ecc/skills/springboot-tdd/SKILL.md +158 -0
  593. package/resources/ecc/skills/springboot-verification/SKILL.md +231 -0
  594. package/resources/ecc/skills/strategic-compact/SKILL.md +31 -2
  595. package/resources/ecc/skills/strategic-compact/suggest-compact.sh +54 -0
  596. package/resources/ecc/skills/swift-actor-persistence/SKILL.md +143 -0
  597. package/resources/ecc/skills/swift-concurrency-6-2/SKILL.md +216 -0
  598. package/resources/ecc/skills/swift-protocol-di-testing/SKILL.md +190 -0
  599. package/resources/ecc/skills/swiftui-patterns/SKILL.md +259 -0
  600. package/resources/ecc/skills/tdd-workflow/SKILL.md +54 -0
  601. package/resources/ecc/skills/team-builder/SKILL.md +168 -0
  602. package/resources/ecc/skills/terminal-ops/SKILL.md +109 -0
  603. package/resources/ecc/skills/tinystruct-patterns/SKILL.md +131 -0
  604. package/resources/ecc/skills/tinystruct-patterns/references/architecture.md +77 -0
  605. package/resources/ecc/skills/tinystruct-patterns/references/data-handling.md +35 -0
  606. package/resources/ecc/skills/tinystruct-patterns/references/routing.md +57 -0
  607. package/resources/ecc/skills/tinystruct-patterns/references/system-usage.md +74 -0
  608. package/resources/ecc/skills/tinystruct-patterns/references/testing.md +59 -0
  609. package/resources/ecc/skills/token-budget-advisor/SKILL.md +133 -0
  610. package/resources/ecc/skills/ui-demo/SKILL.md +465 -0
  611. package/resources/ecc/skills/ui-to-vue/SKILL.md +134 -0
  612. package/resources/ecc/skills/unified-notifications-ops/SKILL.md +187 -0
  613. package/resources/ecc/skills/verification-loop/SKILL.md +1 -0
  614. package/resources/ecc/skills/video-editing/SKILL.md +4 -1
  615. package/resources/ecc/skills/videodb/SKILL.md +374 -0
  616. package/resources/ecc/skills/videodb/reference/api-reference.md +550 -0
  617. package/resources/ecc/skills/videodb/reference/capture-reference.md +407 -0
  618. package/resources/ecc/skills/videodb/reference/capture.md +101 -0
  619. package/resources/ecc/skills/videodb/reference/editor.md +443 -0
  620. package/resources/ecc/skills/videodb/reference/generative.md +331 -0
  621. package/resources/ecc/skills/videodb/reference/rtstream-reference.md +564 -0
  622. package/resources/ecc/skills/videodb/reference/rtstream.md +65 -0
  623. package/resources/ecc/skills/videodb/reference/search.md +230 -0
  624. package/resources/ecc/skills/videodb/reference/streaming.md +406 -0
  625. package/resources/ecc/skills/videodb/reference/use-cases.md +118 -0
  626. package/resources/ecc/skills/videodb/scripts/ws_listener.py +282 -0
  627. package/resources/ecc/skills/visa-doc-translate/README.md +86 -0
  628. package/resources/ecc/skills/visa-doc-translate/SKILL.md +117 -0
  629. package/resources/ecc/skills/vite-patterns/SKILL.md +449 -0
  630. package/resources/ecc/skills/windows-desktop-e2e/SKILL.md +788 -0
  631. package/resources/ecc/skills/workspace-surface-audit/SKILL.md +125 -0
  632. package/resources/ecc/skills/x-api/SKILL.md +5 -0
  633. package/resources/ecc/agents/architect.json +0 -16
  634. package/resources/ecc/agents/build-error-resolver.json +0 -17
  635. package/resources/ecc/agents/chief-of-staff.json +0 -17
  636. package/resources/ecc/agents/code-reviewer.json +0 -16
  637. package/resources/ecc/agents/database-reviewer.json +0 -16
  638. package/resources/ecc/agents/doc-updater.json +0 -16
  639. package/resources/ecc/agents/e2e-runner.json +0 -17
  640. package/resources/ecc/agents/go-build-resolver.json +0 -17
  641. package/resources/ecc/agents/go-reviewer.json +0 -16
  642. package/resources/ecc/agents/harness-optimizer.json +0 -15
  643. package/resources/ecc/agents/loop-operator.json +0 -16
  644. package/resources/ecc/agents/planner.json +0 -15
  645. package/resources/ecc/agents/python-reviewer.json +0 -16
  646. package/resources/ecc/agents/refactor-cleaner.json +0 -17
  647. package/resources/ecc/agents/security-reviewer.json +0 -16
  648. package/resources/ecc/agents/tdd-guide.json +0 -17
  649. package/resources/ecc/commands/add-language-rules.md +0 -39
  650. package/resources/ecc/commands/database-migration.md +0 -36
  651. package/resources/ecc/commands/feature-development.md +0 -38
  652. package/resources/ecc/rules/common-development-workflow.md +0 -33
  653. package/resources/ecc/rules/kotlin-coding-style.md +0 -39
  654. package/resources/ecc/rules/kotlin-patterns.md +0 -50
  655. package/resources/ecc/rules/kotlin-security.md +0 -58
  656. package/resources/ecc/rules/kotlin-testing.md +0 -38
  657. package/resources/ecc/rules/php-coding-style.md +0 -25
  658. package/resources/ecc/rules/php-patterns.md +0 -23
  659. package/resources/ecc/rules/php-security.md +0 -24
  660. package/resources/ecc/rules/php-testing.md +0 -26
  661. package/resources/ecc/rules/swift-hooks.md +0 -20
  662. package/resources/ecc/rules/typescript-coding-style.md +0 -63
  663. package/resources/ecc/rules/typescript-testing.md +0 -16
  664. package/resources/ecc/skills/agent-introspection-debugging/agents/openai.yaml +0 -7
  665. package/resources/ecc/skills/agent-sort/agents/openai.yaml +0 -7
  666. package/resources/ecc/skills/api-design/agents/openai.yaml +0 -7
  667. package/resources/ecc/skills/article-writing/agents/openai.yaml +0 -7
  668. package/resources/ecc/skills/backend-patterns/agents/openai.yaml +0 -7
  669. package/resources/ecc/skills/brand-voice/agents/openai.yaml +0 -7
  670. package/resources/ecc/skills/bun-runtime/agents/openai.yaml +0 -7
  671. package/resources/ecc/skills/coding-standards/agents/openai.yaml +0 -7
  672. package/resources/ecc/skills/content-engine/agents/openai.yaml +0 -7
  673. package/resources/ecc/skills/crosspost/agents/openai.yaml +0 -7
  674. package/resources/ecc/skills/deep-research/agents/openai.yaml +0 -7
  675. package/resources/ecc/skills/dmux-workflows/agents/openai.yaml +0 -7
  676. package/resources/ecc/skills/documentation-lookup/agents/openai.yaml +0 -7
  677. package/resources/ecc/skills/e2e-testing/agents/openai.yaml +0 -7
  678. package/resources/ecc/skills/eval-harness/agents/openai.yaml +0 -7
  679. package/resources/ecc/skills/everything-claude-code/SKILL.md +0 -442
  680. package/resources/ecc/skills/everything-claude-code/agents/openai.yaml +0 -7
  681. package/resources/ecc/skills/exa-search/agents/openai.yaml +0 -7
  682. package/resources/ecc/skills/fal-ai-media/agents/openai.yaml +0 -7
  683. package/resources/ecc/skills/frontend-patterns/agents/openai.yaml +0 -7
  684. package/resources/ecc/skills/frontend-slides/agents/openai.yaml +0 -7
  685. package/resources/ecc/skills/investor-materials/agents/openai.yaml +0 -7
  686. package/resources/ecc/skills/investor-outreach/agents/openai.yaml +0 -7
  687. package/resources/ecc/skills/market-research/agents/openai.yaml +0 -7
  688. package/resources/ecc/skills/mcp-server-patterns/agents/openai.yaml +0 -7
  689. package/resources/ecc/skills/mle-workflow/agents/openai.yaml +0 -7
  690. package/resources/ecc/skills/nextjs-turbopack/agents/openai.yaml +0 -7
  691. package/resources/ecc/skills/product-capability/agents/openai.yaml +0 -7
  692. package/resources/ecc/skills/security-review/agents/openai.yaml +0 -7
  693. package/resources/ecc/skills/strategic-compact/agents/openai.yaml +0 -7
  694. package/resources/ecc/skills/tdd-workflow/agents/openai.yaml +0 -7
  695. package/resources/ecc/skills/verification-loop/agents/openai.yaml +0 -7
  696. package/resources/ecc/skills/video-editing/agents/openai.yaml +0 -7
  697. package/resources/ecc/skills/x-api/agents/openai.yaml +0 -7
@@ -1,6 +1,7 @@
1
1
  ---
2
2
  name: tdd-workflow
3
3
  description: Use this skill when writing new features, fixing bugs, or refactoring code. Enforces test-driven development with 80%+ coverage including unit, integration, and E2E tests.
4
+ origin: ECC
4
5
  ---
5
6
 
6
7
  # Test-Driven Development Workflow
@@ -46,6 +47,19 @@ ALWAYS write tests first, then implement code to make tests pass.
46
47
  - Browser automation
47
48
  - UI interactions
48
49
 
50
+ ### 4. Git Checkpoints
51
+ - If the repository is under Git, create a checkpoint commit after each TDD stage
52
+ - Do not squash or rewrite these checkpoint commits until the workflow is complete
53
+ - Each checkpoint commit message must describe the stage and the exact evidence captured
54
+ - Count only commits created on the current active branch for the current task
55
+ - Do not treat commits from other branches, earlier unrelated work, or distant branch history as valid checkpoint evidence
56
+ - Before treating a checkpoint as satisfied, verify that the commit is reachable from the current `HEAD` on the active branch and belongs to the current task sequence
57
+ - The preferred compact workflow is:
58
+ - one commit for failing test added and RED validated
59
+ - one commit for minimal fix applied and GREEN validated
60
+ - one optional commit for refactor complete
61
+ - Separate evidence-only commits are not required if the test commit clearly corresponds to RED and the fix commit clearly corresponds to GREEN
62
+
49
63
  ## TDD Workflow Steps
50
64
 
51
65
  ### Step 1: Write User Journeys
@@ -86,6 +100,29 @@ npm test
86
100
  # Tests should fail - we haven't implemented yet
87
101
  ```
88
102
 
103
+ This step is mandatory and is the RED gate for all production changes.
104
+
105
+ Before modifying business logic or other production code, you must verify a valid RED state via one of these paths:
106
+ - Runtime RED:
107
+ - The relevant test target compiles successfully
108
+ - The new or changed test is actually executed
109
+ - The result is RED
110
+ - Compile-time RED:
111
+ - The new test newly instantiates, references, or exercises the buggy code path
112
+ - The compile failure is itself the intended RED signal
113
+ - In either case, the failure is caused by the intended business-logic bug, undefined behavior, or missing implementation
114
+ - The failure is not caused only by unrelated syntax errors, broken test setup, missing dependencies, or unrelated regressions
115
+
116
+ A test that was only written but not compiled and executed does not count as RED.
117
+
118
+ Do not edit production code until this RED state is confirmed.
119
+
120
+ If the repository is under Git, create a checkpoint commit immediately after this stage is validated.
121
+ Recommended commit message format:
122
+ - `test: add reproducer for <feature or bug>`
123
+ - This commit may also serve as the RED validation checkpoint if the reproducer was compiled and executed and failed for the intended reason
124
+ - Verify that this checkpoint commit is on the current active branch before continuing
125
+
89
126
  ### Step 4: Implement Code
90
127
  Write minimal code to make tests pass:
91
128
 
@@ -96,12 +133,24 @@ export async function searchMarkets(query: string) {
96
133
  }
97
134
  ```
98
135
 
136
+ If the repository is under Git, stage the minimal fix now but defer the checkpoint commit until GREEN is validated in Step 5.
137
+
99
138
  ### Step 5: Run Tests Again
100
139
  ```bash
101
140
  npm test
102
141
  # Tests should now pass
103
142
  ```
104
143
 
144
+ Rerun the same relevant test target after the fix and confirm the previously failing test is now GREEN.
145
+
146
+ Only after a valid GREEN result may you proceed to refactor.
147
+
148
+ If the repository is under Git, create a checkpoint commit immediately after GREEN is validated.
149
+ Recommended commit message format:
150
+ - `fix: <feature or bug>`
151
+ - The fix commit may also serve as the GREEN validation checkpoint if the same relevant test target was rerun and passed
152
+ - Verify that this checkpoint commit is on the current active branch before continuing
153
+
105
154
  ### Step 6: Refactor
106
155
  Improve code quality while keeping tests green:
107
156
  - Remove duplication
@@ -109,6 +158,11 @@ Improve code quality while keeping tests green:
109
158
  - Optimize performance
110
159
  - Enhance readability
111
160
 
161
+ If the repository is under Git, create a checkpoint commit immediately after refactoring is complete and tests remain green.
162
+ Recommended commit message format:
163
+ - `refactor: clean up after <feature or bug> implementation`
164
+ - Verify that this checkpoint commit is on the current active branch before considering the TDD cycle complete
165
+
112
166
  ### Step 7: Verify Coverage
113
167
  ```bash
114
168
  npm run test:coverage
@@ -0,0 +1,168 @@
1
+ ---
2
+ name: team-builder
3
+ description: Interactive agent picker for composing and dispatching parallel teams
4
+ origin: community
5
+ ---
6
+
7
+ # Team Builder
8
+
9
+ Interactive menu for browsing and composing agent teams on demand. Works with flat or domain-subdirectory agent collections.
10
+
11
+ ## When to Use
12
+
13
+ - You have multiple agent personas (markdown files) and want to pick which ones to use for a task
14
+ - You want to compose an ad-hoc team from different domains (e.g., Security + SEO + Architecture)
15
+ - You want to browse what agents are available before deciding
16
+
17
+ ## Prerequisites
18
+
19
+ Agent files must be markdown files containing a persona prompt (identity, rules, workflow, deliverables). The first `# Heading` is used as the agent name and the first paragraph as the description.
20
+
21
+ Both flat and subdirectory layouts are supported:
22
+
23
+ **Subdirectory layout** — domain is inferred from the folder name:
24
+
25
+ ```
26
+ agents/
27
+ ├── engineering/
28
+ │ ├── security-engineer.md
29
+ │ └── software-architect.md
30
+ ├── marketing/
31
+ │ └── seo-specialist.md
32
+ └── sales/
33
+ └── discovery-coach.md
34
+ ```
35
+
36
+ **Flat layout** — domain inferred from shared filename prefixes. A prefix counts as a domain when 2+ files share it. Files with unique prefixes go to "General". Note: the algorithm splits at the first `-`, so multi-word domains (e.g., `product-management`) should use the subdirectory layout instead:
37
+
38
+ ```
39
+ agents/
40
+ ├── engineering-security-engineer.md
41
+ ├── engineering-software-architect.md
42
+ ├── marketing-seo-specialist.md
43
+ ├── marketing-content-strategist.md
44
+ ├── sales-discovery-coach.md
45
+ └── sales-outbound-strategist.md
46
+ ```
47
+
48
+ ## Configuration
49
+
50
+ Agents are discovered via two methods, merged and deduplicated by agent name:
51
+
52
+ 1. **`claude agents` command** (primary) — run `claude agents` to get all agents known to the CLI, including user agents, plugin agents (e.g. `everything-claude-code:architect`), and built-in agents. This automatically covers ECC marketplace installs without any path configuration.
53
+ 2. **File glob** (fallback, for reading agent content) — agent markdown files are read from:
54
+ - `./agents/**/*.md` + `./agents/*.md` — project-local agents
55
+ - `~/.claude/agents/**/*.md` + `~/.claude/agents/*.md` — global user agents
56
+
57
+ Earlier sources take precedence when names collide: user agents > plugin agents > built-in agents. A custom path can be used instead if the user specifies one.
58
+
59
+ ## How It Works
60
+
61
+ ### Step 1: Discover Available Agents
62
+
63
+ Run `claude agents` to get the full agent list. Parse each line:
64
+ - **Plugin agents** are prefixed with `plugin-name:` (e.g., `everything-claude-code:security-reviewer`). Use the part after `:` as the agent name and the plugin name as the domain.
65
+ - **User agents** have no prefix. Read the corresponding markdown file from `~/.claude/agents/` or `./agents/` to extract the name and description.
66
+ - **Built-in agents** (e.g., `Explore`, `Plan`) are skipped unless the user explicitly asks to include them.
67
+
68
+ For user agents loaded from markdown files:
69
+ - **Subdirectory layout:** extract the domain from the parent folder name
70
+ - **Flat layout:** collect all filename prefixes (text before the first `-`). A prefix qualifies as a domain only if it appears in 2 or more filenames (e.g., `engineering-security-engineer.md` and `engineering-software-architect.md` both start with `engineering` → Engineering domain). Files with unique prefixes (e.g., `code-reviewer.md`, `tdd-guide.md`) are grouped under "General"
71
+ - Extract the agent name from the first `# Heading`. If no heading is found, derive the name from the filename (strip `.md`, replace hyphens with spaces, title-case)
72
+ - Extract a one-line summary from the first paragraph after the heading
73
+
74
+ If no agents are found after running `claude agents` and probing file locations, inform the user: "No agents found. Run `claude agents` to verify your setup." Then stop.
75
+
76
+ ### Step 2: Present Domain Menu
77
+
78
+ ```
79
+ Available agent domains:
80
+ 1. Engineering — Software Architect, Security Engineer
81
+ 2. Marketing — SEO Specialist
82
+ 3. Sales — Discovery Coach, Outbound Strategist
83
+
84
+ Pick domains or name specific agents (e.g., "1,3" or "security + seo"):
85
+ ```
86
+
87
+ - Skip domains with zero agents (empty directories)
88
+ - Show agent count per domain
89
+
90
+ ### Step 3: Handle Selection
91
+
92
+ Accept flexible input:
93
+ - Numbers: "1,3" selects all agents from Engineering and Sales
94
+ - Names: "security + seo" fuzzy-matches against discovered agents
95
+ - "all from engineering" selects every agent in that domain
96
+
97
+ If more than 5 agents are selected, list them alphabetically and ask the user to narrow down: "You selected N agents (max 5). Pick which to keep, or say 'first 5' to use the first five alphabetically."
98
+
99
+ Confirm selection:
100
+ ```
101
+ Selected: Security Engineer + SEO Specialist
102
+ What should they work on? (describe the task):
103
+ ```
104
+
105
+ ### Step 4: Spawn Agents in Parallel
106
+
107
+ 1. Read each selected agent's markdown file
108
+ 2. Prompt for the task description if not already provided
109
+ 3. Spawn all agents in parallel using the Agent tool:
110
+ - `subagent_type: "general-purpose"`
111
+ - `prompt: "{agent file content}\n\nTask: {task description}"`
112
+ - Each agent runs independently — no inter-agent communication needed
113
+ 4. If an agent fails (error, timeout, or empty output), note the failure inline (e.g., "Security Engineer: failed — [reason]") and continue with results from agents that succeeded
114
+
115
+ ### Step 5: Synthesize Results
116
+
117
+ Collect all outputs and present a unified report:
118
+ - Results grouped by agent
119
+ - Synthesis section highlighting:
120
+ - Agreements across agents
121
+ - Conflicts or tensions between recommendations
122
+ - Recommended next steps
123
+
124
+ If only 1 agent was selected, skip synthesis and present the output directly.
125
+
126
+ ## Rules
127
+
128
+ - **Dynamic discovery only.** Never hardcode agent lists. New files in the directory auto-appear in the menu.
129
+ - **Max 5 agents per team.** More than 5 produces diminishing returns and excessive token usage. Enforce at selection time.
130
+ - **Parallel dispatch.** All agents run simultaneously — use the Agent tool's parallel invocation pattern.
131
+ - **Parallel Agent calls, not TeamCreate.** This skill uses parallel Agent tool calls for independent work. TeamCreate (a Claude Code tool for multi-agent dialogue) is only needed when agents must debate or respond to each other.
132
+
133
+ ## Examples
134
+
135
+ ```
136
+ User: team builder
137
+
138
+ Claude:
139
+ Available agent domains:
140
+ 1. Engineering (2) — Software Architect, Security Engineer
141
+ 2. Marketing (1) — SEO Specialist
142
+ 3. Sales (4) — Discovery Coach, Outbound Strategist, Proposal Strategist, Sales Engineer
143
+ 4. Support (1) — Executive Summary
144
+
145
+ Pick domains or name specific agents:
146
+
147
+ User: security + seo
148
+
149
+ Claude:
150
+ Selected: Security Engineer + SEO Specialist
151
+ What should they work on?
152
+
153
+ User: Review my Next.js e-commerce site before launch
154
+
155
+ [Both agents spawn in parallel, each applying their specialty to the codebase]
156
+
157
+ Claude:
158
+ ## Security Engineer Findings
159
+ - [findings...]
160
+
161
+ ## SEO Specialist Findings
162
+ - [findings...]
163
+
164
+ ## Synthesis
165
+ Both agents agree on: [...]
166
+ Tension: Security recommends CSP that blocks inline styles, SEO needs inline schema markup. Resolution: [...]
167
+ Next steps: [...]
168
+ ```
@@ -0,0 +1,109 @@
1
+ ---
2
+ name: terminal-ops
3
+ description: Evidence-first repo execution workflow for ECC. Use when the user wants a command run, a repo checked, a CI failure debugged, or a narrow fix pushed with exact proof of what was executed and verified.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Terminal Ops
8
+
9
+ Use this when the user wants real repo execution: run commands, inspect git state, debug CI or builds, make a narrow fix, and report exactly what changed and what was verified.
10
+
11
+ This skill is intentionally narrower than general coding guidance. It is an operator workflow for evidence-first terminal execution.
12
+
13
+ ## Skill Stack
14
+
15
+ Pull these ECC-native skills into the workflow when relevant:
16
+
17
+ - `verification-loop` for exact proving steps after changes
18
+ - `tdd-workflow` when the right fix needs regression coverage
19
+ - `security-review` when secrets, auth, or external inputs are involved
20
+ - `github-ops` when the task depends on CI runs, PR state, or release status
21
+ - `knowledge-ops` when the verified outcome needs to be captured into durable project context
22
+
23
+ ## When to Use
24
+
25
+ - user says "fix", "debug", "run this", "check the repo", or "push it"
26
+ - the task depends on command output, git state, test results, or a verified local fix
27
+ - the answer must distinguish changed locally, verified locally, committed, and pushed
28
+
29
+ ## Guardrails
30
+
31
+ - inspect before editing
32
+ - stay read-only if the user asked for audit/review only
33
+ - prefer repo-local scripts and helpers over improvised ad hoc wrappers
34
+ - do not claim fixed until the proving command was rerun
35
+ - do not claim pushed unless the branch actually moved upstream
36
+
37
+ ## Workflow
38
+
39
+ ### 1. Resolve the working surface
40
+
41
+ Settle:
42
+
43
+ - exact repo path
44
+ - branch
45
+ - local diff state
46
+ - requested mode:
47
+ - inspect
48
+ - fix
49
+ - verify
50
+ - push
51
+
52
+ ### 2. Read the failing surface first
53
+
54
+ Before changing anything:
55
+
56
+ - inspect the error
57
+ - inspect the file or test
58
+ - inspect git state
59
+ - use any already-supplied logs or context before re-reading blindly
60
+
61
+ ### 3. Keep the fix narrow
62
+
63
+ Solve one dominant failure at a time:
64
+
65
+ - use the smallest useful proving command first
66
+ - only escalate to a bigger build/test pass after the local failure is addressed
67
+ - if a command keeps failing with the same signature, stop broad retries and narrow scope
68
+
69
+ ### 4. Report exact execution state
70
+
71
+ Use exact status words:
72
+
73
+ - inspected
74
+ - changed locally
75
+ - verified locally
76
+ - committed
77
+ - pushed
78
+ - blocked
79
+
80
+ ## Output Format
81
+
82
+ ```text
83
+ SURFACE
84
+ - repo
85
+ - branch
86
+ - requested mode
87
+
88
+ EVIDENCE
89
+ - failing command / diff / test
90
+
91
+ ACTION
92
+ - what changed
93
+
94
+ STATUS
95
+ - inspected / changed locally / verified locally / committed / pushed / blocked
96
+ ```
97
+
98
+ ## Pitfalls
99
+
100
+ - do not work from stale memory when the live repo state can be read
101
+ - do not widen a narrow fix into repo-wide churn
102
+ - do not use destructive git commands
103
+ - do not ignore unrelated local work
104
+
105
+ ## Verification
106
+
107
+ - the response names the proving command or test
108
+ - git-related work names the repo path and branch
109
+ - any push claim includes the target branch and exact result
@@ -0,0 +1,131 @@
1
+ ---
2
+ name: tinystruct-patterns
3
+ description: Use when developing application modules or microservices with the tinystruct Java framework. Covers routing, context management, JSON handling with Builder, and CLI/HTTP dual-mode patterns.
4
+ origin: ECC
5
+ ---
6
+
7
+ # tinystruct Development Patterns
8
+
9
+ Architecture and implementation patterns for building modules with the **tinystruct** Java framework – a lightweight system where CLI and HTTP are equal citizens.
10
+
11
+ ## When to Use
12
+
13
+ - Creating new `Application` modules by extending `AbstractApplication`.
14
+ - Defining routes and command-line actions using `@Action`.
15
+ - Handling per-request state via `Context`.
16
+ - Performing JSON serialization using the native `Builder` component.
17
+ - Configuring database connections or system settings in `application.properties`.
18
+ - Generating or re-generating the standard `bin/dispatcher` entry point via `ApplicationManager.init()`.
19
+ - Debugging routing conflicts (Actions) or CLI argument parsing.
20
+
21
+ ## How It Works
22
+
23
+ The tinystruct framework treats any method annotated with `@Action` as a routable endpoint for both terminal and web environments. Applications are created by extending `AbstractApplication`, which provides core lifecycle hooks like `init()` and access to the request `Context`.
24
+
25
+ Routing is handled by the `ActionRegistry`, which automatically maps path segments to method arguments and injects dependencies. For data-only services, the native `Builder` component should be used for JSON serialization to maintain a zero-dependency footprint. The framework also includes a utility in `ApplicationManager` to bootstrap the project's execution environment by generating the `bin/dispatcher` script.
26
+
27
+ ## Examples
28
+
29
+ ### Basic Application (MyService)
30
+ ```java
31
+ public class MyService extends AbstractApplication {
32
+ @Override
33
+ public void init() {
34
+ this.setTemplateRequired(false); // Disable .view lookup for data/API apps
35
+ }
36
+
37
+ @Override public String version() { return "1.0.0"; }
38
+
39
+ @Action("greet")
40
+ public String greet() {
41
+ return "Hello from tinystruct!";
42
+ }
43
+ }
44
+ ```
45
+
46
+ ### Parameterized Routing (getUser)
47
+ ```java
48
+ // Handles /api/user/123 (Web) or "bin/dispatcher api/user/123" (CLI)
49
+ @Action("api/user/(\\d+)")
50
+ public String getUser(int userId) {
51
+ return "User ID: " + userId;
52
+ }
53
+ ```
54
+
55
+ ### HTTP Mode Disambiguation (login)
56
+ ```java
57
+ @Action(value = "login", mode = Mode.HTTP_POST)
58
+ public boolean doLogin() {
59
+ // Process login logic
60
+ return true;
61
+ }
62
+ ```
63
+
64
+ ### Native JSON Data Handling (getData)
65
+ ```java
66
+ @Action("api/data")
67
+ public Builder getData() throws ApplicationException {
68
+ Builder builder = new Builder();
69
+ builder.put("status", "success");
70
+ Builder nested = new Builder();
71
+ nested.put("id", 1);
72
+ nested.put("name", "James");
73
+ builder.put("data", nested);
74
+ return builder;
75
+ }
76
+ ```
77
+
78
+ ## Configuration
79
+
80
+ Settings are managed in `src/main/resources/application.properties`.
81
+
82
+ ```properties
83
+ # Database
84
+ driver=org.h2.Driver
85
+ database.url=jdbc:h2:~/mydb
86
+
87
+ # App specific
88
+ my.service.endpoint=https://api.example.com
89
+ ```
90
+
91
+ ## Testing Patterns
92
+
93
+ Use JUnit 5 to test actions by verifying they are registered in the `ActionRegistry`.
94
+
95
+ ```java
96
+ @Test
97
+ void testActionRegistration() {
98
+ Application app = new MyService();
99
+ app.init();
100
+
101
+ ActionRegistry registry = ActionRegistry.getInstance();
102
+ assertNotNull(registry.get("greet"));
103
+ }
104
+ ```
105
+
106
+ ## Red Flags & Anti-patterns
107
+
108
+ | Symptom | Correct Pattern |
109
+ |---|---|
110
+ | Importing `com.google.gson` or `com.fasterxml.jackson` | Use `org.tinystruct.data.component.Builder`. |
111
+ | `FileNotFoundException` for `.view` files | Call `setTemplateRequired(false)` in `init()` for API-only apps. |
112
+ | Annotating `private` methods with `@Action` | Actions must be `public` to be registered by the framework. |
113
+ | Hardcoding `main(String[] args)` in apps | Use `bin/dispatcher` as the entry point for all modules. |
114
+ | Manual `ActionRegistry` registration | Prefer the `@Action` annotation for automatic discovery. |
115
+
116
+ ## Technical Reference
117
+
118
+ Detailed guides are available in the `references/` directory:
119
+
120
+ - [Architecture & Config](references/architecture.md) — Abstractions, Package Map, Properties
121
+ - [Routing & @Action](references/routing.md) — Annotation details, Modes, Parameters
122
+ - [Data Handling](references/data-handling.md) — Using the native `Builder` for JSON
123
+ - [System & Usage](references/system-usage.md) — Context, Sessions, Events, CLI usage
124
+ - [Testing Patterns](references/testing.md) — JUnit 5 integration and ActionRegistry testing
125
+
126
+ ## Reference Source Files (Internal)
127
+
128
+ - `src/main/java/org/tinystruct/AbstractApplication.java` — Core base class
129
+ - `src/main/java/org/tinystruct/system/annotation/Action.java` — Annotation & Modes
130
+ - `src/main/java/org/tinystruct/application/ActionRegistry.java` — Routing Engine
131
+ - `src/main/java/org/tinystruct/data/component/Builder.java` — JSON/Data Serializer
@@ -0,0 +1,77 @@
1
+ # tinystruct Architecture and Configuration
2
+
3
+ ## When to Use
4
+
5
+ Choose **tinystruct** when you need a lightweight, high-performance Java framework that treats CLI and HTTP as equal citizens. It is ideal for building microservices, command-line utilities, and data-driven applications where a small footprint and zero-dependency JSON handling are required. Use it when you want to write logic once and expose it via both a terminal and a web server without modification.
6
+
7
+ ## How It Works
8
+
9
+ ### Core Architecture
10
+
11
+ The framework operates on a singleton `ActionRegistry` that maps URL patterns (or command strings) to `Action` objects. When a request arrives, the system resolves the path and invokes the corresponding method handle.
12
+
13
+ #### Key Abstractions
14
+
15
+ | Class/Interface | Role |
16
+ |---|---|
17
+ | `AbstractApplication` | Base class for all tinystruct applications. Extend this. |
18
+ | `@Action` annotation | Maps a method to a URI path (web) or command name (CLI). The single routing primitive. |
19
+ | `ActionRegistry` | Singleton that maps URL patterns to `Action` objects via regex. Never instantiate directly. |
20
+ | `Action` | Wraps a `MethodHandle` + regex pattern + priority + `Mode` for dispatch. |
21
+ | `Context` | Per-request state store. Access via `getContext()`. Holds CLI args and HTTP request/response. |
22
+ | `Dispatcher` | CLI entry point (`bin/dispatcher`). Reads `--import` to load applications. |
23
+ | `HttpServer` | Built-in Netty-based HTTP server. Start with `bin/dispatcher start --import org.tinystruct.system.HttpServer`. |
24
+
25
+ ### Package Map
26
+
27
+ ```
28
+ org.tinystruct/
29
+ ├── AbstractApplication.java ← extend this
30
+ ├── Application.java ← interface
31
+ ├── ApplicationException.java ← checked exception
32
+ ├── ApplicationRuntimeException.java ← unchecked exception
33
+ ├── application/
34
+ │ ├── Action.java ← runtime action wrapper
35
+ │ ├── ActionRegistry.java ← singleton route registry
36
+ │ └── Context.java ← request context
37
+ ├── system/
38
+ │ ├── annotation/Action.java ← @Action annotation + Mode enum
39
+ │ ├── Dispatcher.java ← CLI dispatcher
40
+ │ ├── HttpServer.java ← built-in HTTP server
41
+ │ ├── EventDispatcher.java ← event bus
42
+ │ └── Settings.java ← reads application.properties
43
+ ├── data/component/Builder.java ← JSON serialization (use instead of Gson/Jackson)
44
+ └── http/ ← Request, Response, Constants
45
+ ```
46
+
47
+ ### Template Behavior and Dispatch Flow
48
+
49
+ By default, the framework assumes a view template is required. If `templateRequired` is `true`, `toString()` looks for a `.view` file in `src/main/resources/themes/<ClassName>.view`. Use `getContext()` to manage state and `setVariable("name", value)` to pass data to templates, which use `[%name%]` for interpolation.
50
+
51
+ ## Examples
52
+
53
+ ### Minimal Application Initialization
54
+ ```java
55
+ @Override
56
+ public void init() {
57
+ this.setTemplateRequired(false); // Skip .view template lookup for data-only apps
58
+ }
59
+ ```
60
+
61
+ ### Action Definition and CLI Invocation
62
+ ```java
63
+ @Action("hello")
64
+ public String hello() {
65
+ return "Hello, tinystruct!";
66
+ }
67
+ ```
68
+ **Execution via Dispatcher:**
69
+ ```bash
70
+ bin/dispatcher hello
71
+ ```
72
+
73
+ ### Configuration Access
74
+ Located at `src/main/resources/application.properties`:
75
+ ```java
76
+ String port = this.getConfiguration("server.port");
77
+ ```
@@ -0,0 +1,35 @@
1
+ # tinystruct Data Handling (JSON)
2
+
3
+ ## When to Use
4
+
5
+ Prefer `org.tinystruct.data.component.Builder` in scenarios where you need a lightweight, high-performance JSON solution with **zero external dependencies**. It is specifically designed to keep your tinystruct applications lean and fast, making it the ideal choice for microservices and CLI tools where including heavy libraries like Jackson or Gson would be overkill.
6
+
7
+ ## How It Works
8
+
9
+ The `Builder` class provides a simple key-value interface for both creating and reading JSON structures. It integrates directly with `AbstractApplication` result handling; when an action method returns a `Builder` object, the framework automatically serializes it to the response stream. This prevents the need for manual string conversion and ensures consistent data formatting across your application modules.
10
+
11
+ ## Examples
12
+
13
+ ### Serialization
14
+ ```java
15
+ import org.tinystruct.data.component.Builder;
16
+
17
+ // Create and populate
18
+ Builder response = new Builder();
19
+ response.put("status", "success");
20
+ response.put("count", 42);
21
+ response.put("data", someList);
22
+
23
+ return response; // {"status":"success","count":42,...}
24
+ ```
25
+
26
+ ### Parsing
27
+ ```java
28
+ import org.tinystruct.data.component.Builder;
29
+
30
+ // Parse a JSON string
31
+ Builder parsed = new Builder();
32
+ parsed.parse(jsonString);
33
+
34
+ String status = parsed.get("status").toString();
35
+ ```
@@ -0,0 +1,57 @@
1
+ # tinystruct @Action Routing Reference
2
+
3
+ ## When to Use
4
+
5
+ Use the `@Action` annotation in your applications to define routes for both CLI commands and HTTP endpoints. It is appropriate whenever you need to map logic to a specific path, handle parameterized requests (e.g., retrieving a resource by ID), or restrict execution to specific HTTP methods (GET, POST, etc.) while maintaining a consistent command structure across environments.
6
+
7
+ ## How It Works
8
+
9
+ The `ActionRegistry` parses `@Action` annotations to build a routing table. For parameterized methods, the framework automatically maps Java parameter types (int, String, etc.) to corresponding regex segments to generate an internal matching pattern. For instance, `getUser(int id)` generates a regex targeting digits, while `search(String query)` targets generic path segments.
10
+
11
+ When a request is dispatched, the `ActionRegistry` automatically injects dependencies like `Request` and `Response` into the action method if they are specified as parameters, drawing them directly from the current request's `Context`. Execution is further filtered by the `Mode` value, allowing a single path to invoke different logic depending on whether the trigger was a terminal command or a specific type of HTTP request.
12
+
13
+ ### Mode Values
14
+
15
+ | Mode | When it triggers |
16
+ |---|---|
17
+ | `DEFAULT` | Both CLI and HTTP (GET, POST, etc.) |
18
+ | `CLI` | CLI dispatcher only |
19
+ | `HTTP_GET` | HTTP GET only |
20
+ | `HTTP_POST` | HTTP POST only |
21
+ | `HTTP_PUT` | HTTP PUT only |
22
+ | `HTTP_DELETE` | HTTP DELETE only |
23
+ | `HTTP_PATCH` | HTTP PATCH only |
24
+
25
+ ## Examples
26
+
27
+ ### Basic Action Declaration
28
+ ```java
29
+ @Action(
30
+ value = "path/subpath", // required: URI segment or CLI command
31
+ description = "What it does", // shown in --help output
32
+ mode = Mode.HTTP_POST, // default: Mode.DEFAULT (both CLI + HTTP)
33
+ options = {}, // CLI option flags
34
+ example = "curl -X POST http://localhost:8080/path/subpath/42"
35
+ )
36
+ public String myAction(int id) { ... }
37
+ ```
38
+
39
+ ### Parameterized Paths (Regex Generation)
40
+ ```java
41
+ @Action("user/{id}")
42
+ public String getUser(int id) { ... }
43
+ // → pattern: ^/?user/(-?\d+)$
44
+
45
+ @Action("search")
46
+ public String search(String query) { ... }
47
+ // → pattern: ^/?search/([^/]+)$
48
+ ```
49
+
50
+ ### Request and Response Injection
51
+ ```java
52
+ @Action(value = "upload", mode = Mode.HTTP_POST)
53
+ public String upload(Request<?, ?> req, Response<?, ?> res) throws ApplicationException {
54
+ // req.getParameter("file"), res.setHeader(...), etc.
55
+ return "ok";
56
+ }
57
+ ```