codymaster 4.8.0 → 7.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (416) hide show
  1. package/CHANGELOG.md +331 -7
  2. package/README.md +226 -296
  3. package/dist/advisory-handoff.js +89 -0
  4. package/dist/advisory-report.js +105 -0
  5. package/dist/agent/antigravity.js +152 -0
  6. package/dist/agent/backend.js +2 -0
  7. package/dist/agent/claude.js +196 -0
  8. package/dist/agent/codex.js +204 -0
  9. package/dist/agent/copilot.js +284 -0
  10. package/dist/agent/cursor.js +211 -0
  11. package/dist/agent/factory.js +30 -0
  12. package/dist/agent/gemini.js +142 -0
  13. package/dist/agent/opencode.js +205 -0
  14. package/dist/agent/spawn-helper.js +237 -0
  15. package/dist/agent/version.js +25 -0
  16. package/dist/browse/adapter-factory.js +69 -0
  17. package/dist/browse/adapters/agent-browser-adapter.js +305 -0
  18. package/dist/browse/adapters/playwright-adapter.js +309 -0
  19. package/dist/browse/adapters/types.js +6 -0
  20. package/dist/browse/error-collector.js +132 -0
  21. package/dist/browse/event-log.js +109 -0
  22. package/dist/browse/index.js +17 -0
  23. package/dist/browse-server.js +204 -120
  24. package/dist/cli/command-registry.js +20 -0
  25. package/dist/cli/commands/bench.js +69 -0
  26. package/dist/cli/commands/brain.js +108 -0
  27. package/dist/cli/commands/dashboard.js +76 -2
  28. package/dist/cli/commands/engineering.js +326 -4
  29. package/dist/cli/commands/evolve.js +123 -0
  30. package/dist/cli/commands/install.js +160 -0
  31. package/dist/cli/commands/learn.js +181 -0
  32. package/dist/cli/commands/mcp-serve.js +104 -0
  33. package/dist/cli/commands/parallel.js +138 -0
  34. package/dist/cli/commands/quality.js +105 -0
  35. package/dist/cli/commands/stack.js +49 -0
  36. package/dist/cli/commands/update.js +159 -0
  37. package/dist/cli/update-check.js +94 -10
  38. package/dist/cm-config.js +0 -18
  39. package/dist/codybench/judges/automated.js +31 -0
  40. package/dist/codybench/runners/claude-code.js +32 -0
  41. package/dist/codybench/suites/memory-retention.js +85 -0
  42. package/dist/codybench/suites/tdd-regression.js +35 -0
  43. package/dist/codybench/suites/token-efficiency.js +55 -0
  44. package/dist/codybench/types.js +2 -0
  45. package/dist/context-db.js +157 -0
  46. package/dist/continuity.js +5 -7
  47. package/dist/dashboard.js +47 -6
  48. package/dist/data.js +35 -0
  49. package/dist/execution/tdd-gate.js +113 -0
  50. package/dist/execution-analyzer.js +138 -0
  51. package/dist/executor/cancel.js +34 -0
  52. package/dist/executor/gc.js +74 -0
  53. package/dist/executor/index.js +14 -0
  54. package/dist/executor/runner.js +70 -0
  55. package/dist/executor/workdir.js +31 -0
  56. package/dist/handoff/contracts.js +22 -0
  57. package/dist/handoff/index.js +18 -0
  58. package/dist/handoff/io.js +121 -0
  59. package/dist/index.js +7 -3
  60. package/dist/indexer/skills-lib.js +533 -0
  61. package/dist/indexer/skills-map.js +1374 -0
  62. package/dist/indexer/skills.js +16 -0
  63. package/dist/indexer/stack-detect.js +219 -0
  64. package/dist/install/copy.js +98 -0
  65. package/dist/install/engine.js +42 -0
  66. package/dist/install/paths.js +70 -0
  67. package/dist/install/platforms/_simple.js +85 -0
  68. package/dist/install/platforms/antigravity.js +91 -0
  69. package/dist/install/platforms/claude-code.js +107 -0
  70. package/dist/install/platforms/cursor.js +77 -0
  71. package/dist/install/platforms/index.js +27 -0
  72. package/dist/install/platforms/simple.js +163 -0
  73. package/dist/install/profiles.js +75 -0
  74. package/dist/install/types.js +2 -0
  75. package/dist/learning-promoter.js +246 -0
  76. package/dist/learnings.js +208 -0
  77. package/dist/mcp-context-server.js +230 -1
  78. package/dist/middleware/metrics.js +30 -0
  79. package/dist/middleware/security-headers.js +14 -0
  80. package/dist/realtime/event-bus.js +29 -0
  81. package/dist/realtime/ws-hub.js +91 -0
  82. package/dist/schemas/task-schema.js +48 -0
  83. package/dist/schemas/validate.js +18 -0
  84. package/dist/skill-chain.js +63 -1
  85. package/dist/skill-evolver.js +456 -0
  86. package/dist/skill-execution-cache.js +254 -0
  87. package/dist/skills-lock.js +96 -0
  88. package/dist/smart-brain-router.js +184 -0
  89. package/dist/sprint-pipeline.js +26 -0
  90. package/dist/storage/index.js +21 -0
  91. package/dist/storage/repos/activity-repo.js +46 -0
  92. package/dist/storage/repos/message-repo.js +39 -0
  93. package/dist/storage/repos/project-repo.js +56 -0
  94. package/dist/storage/repos/task-repo.js +142 -0
  95. package/dist/storage/services/project-service.js +49 -0
  96. package/dist/storage/services/task-service.js +97 -0
  97. package/dist/storage/sqlite.js +113 -0
  98. package/dist/storage-backend.js +10 -8
  99. package/dist/tier-classify.js +131 -0
  100. package/dist/token-budget.js +88 -0
  101. package/dist/ui/onboarding.js +51 -15
  102. package/dist/utils/cli-utils.js +7 -2
  103. package/dist/utils/design-taste.js +108 -0
  104. package/dist/utils/output-compress.js +143 -0
  105. package/dist/vibecoding-index.js +126 -0
  106. package/package.json +20 -6
  107. package/public/dashboard/app.js +52 -1
  108. package/scripts/build-skills-lock.mjs +88 -0
  109. package/scripts/build-skills.mjs +187 -28
  110. package/scripts/compress-skill.mjs +73 -0
  111. package/scripts/deprecate-skill.mjs +72 -0
  112. package/scripts/install.sh +170 -0
  113. package/scripts/mcp-bridge.js +2 -2
  114. package/scripts/postinstall.js +53 -335
  115. package/scripts/update-changelog.sh +88 -0
  116. package/scripts/validate-skills.mjs +101 -4
  117. package/skills/CLAUDE.md +0 -5
  118. package/skills/_shared/SKILL_TEMPLATE.md +62 -0
  119. package/skills/_shared/helpers.md +2 -8
  120. package/skills/cm-autopilot/scripts/autopilot.py +19 -2
  121. package/skills/cm-brainstorm-idea/SKILL.md +9 -0
  122. package/skills/cm-browse/SKILL.md +6 -0
  123. package/skills/cm-clean-code/SKILL.md +20 -0
  124. package/skills/cm-code-review/SKILL.md +21 -0
  125. package/skills/cm-codeintell/SKILL.md +9 -0
  126. package/skills/cm-conductor-worktrees/SKILL.archive.md +28 -0
  127. package/skills/cm-conductor-worktrees/SKILL.md +20 -18
  128. package/skills/cm-continuity/SKILL.md +41 -33
  129. package/skills/cm-dashboard/SKILL.archive.md +15 -0
  130. package/skills/cm-dashboard/SKILL.md +20 -9
  131. package/skills/cm-dashboard/ui/app.js +9 -1
  132. package/skills/cm-debugging/SKILL.md +9 -0
  133. package/skills/cm-design-studio/SKILL.archive.md +34 -0
  134. package/skills/cm-design-studio/SKILL.md +20 -24
  135. package/skills/cm-design-system/SKILL.md +1 -0
  136. package/skills/cm-ecosystem-roadmap/SKILL.md +4 -0
  137. package/skills/cm-engineering-meta/SKILL.archive.md +73 -0
  138. package/skills/cm-engineering-meta/SKILL.md +19 -62
  139. package/skills/cm-execution/SKILL.md +98 -0
  140. package/skills/cm-git-worktrees/SKILL.archive.md +157 -0
  141. package/skills/cm-git-worktrees/SKILL.md +15 -146
  142. package/skills/cm-guardian-runtime/SKILL.md +5 -1
  143. package/skills/cm-identity-guard/SKILL.md +8 -0
  144. package/skills/cm-mcp-engineering/SKILL.md +4 -0
  145. package/skills/cm-planning/SKILL.md +63 -92
  146. package/skills/cm-post-deploy-canary/SKILL.archive.md +22 -0
  147. package/skills/cm-post-deploy-canary/SKILL.md +20 -12
  148. package/skills/cm-project-bootstrap/SKILL.md +11 -0
  149. package/skills/cm-qa-visual-cli/SKILL.archive.md +22 -0
  150. package/skills/cm-qa-visual-cli/SKILL.md +19 -11
  151. package/skills/cm-quality-gate/SKILL.md +38 -0
  152. package/skills/cm-retro-cli/SKILL.md +4 -0
  153. package/skills/cm-safe-deploy/SKILL.md +9 -0
  154. package/skills/cm-second-opinion-cli/SKILL.archive.md +23 -0
  155. package/skills/cm-second-opinion-cli/SKILL.md +20 -13
  156. package/skills/cm-secret-shield/SKILL.archive.md +580 -0
  157. package/skills/cm-secret-shield/SKILL.md +15 -569
  158. package/skills/cm-security-gate/SKILL.archive.md +239 -0
  159. package/skills/cm-security-gate/SKILL.md +16 -228
  160. package/skills/cm-skill-chain/SKILL.md +25 -4
  161. package/skills/cm-skill-evolution/SKILL.md +83 -0
  162. package/skills/cm-skill-health/SKILL.archive.md +83 -0
  163. package/skills/cm-skill-health/SKILL.md +26 -0
  164. package/skills/cm-skill-index/SKILL.md +19 -3
  165. package/skills/cm-skill-mastery/SKILL.archive.md +156 -0
  166. package/skills/cm-skill-mastery/SKILL.md +16 -146
  167. package/skills/cm-skill-search/SKILL.archive.md +49 -0
  168. package/skills/cm-skill-search/SKILL.md +26 -0
  169. package/skills/cm-skill-share/SKILL.archive.md +58 -0
  170. package/skills/cm-skill-share/SKILL.md +26 -0
  171. package/skills/cm-sprint-bus/SKILL.md +13 -0
  172. package/skills/cm-start/SKILL.md +17 -10
  173. package/skills/cm-tdd/SKILL.md +21 -2
  174. package/skills/cm-terminal/SKILL.md +15 -0
  175. package/skills/cm-test-gate/SKILL.archive.md +245 -0
  176. package/skills/cm-test-gate/SKILL.md +15 -234
  177. package/skills/cm-ui-preview/SKILL.archive.md +153 -0
  178. package/skills/cm-ui-preview/SKILL.md +16 -143
  179. package/skills/cm-ux-master/cli/uxmaster/commands/mcp.py +1 -1
  180. package/skills/cm-ux-master/mcp/mcp-config.json +1 -1
  181. package/skills/cm-ux-master/mcp/server.py +2 -2
  182. package/skills/profiles/design.txt +1 -1
  183. package/skills/profiles/full.txt +4 -10
  184. package/skills/profiles/growth.txt +8 -8
  185. package/skills/profiles/knowledge.txt +1 -1
  186. package/skills/profiles/top35.json +41 -0
  187. package/adapters/antigravity.js +0 -15
  188. package/adapters/claude-code.js +0 -17
  189. package/adapters/cursor.js +0 -16
  190. package/install.sh +0 -1125
  191. package/scripts/viking-demo.ts +0 -105
  192. package/skills/cm-ads-tracker/SKILL.md +0 -401
  193. package/skills/cm-ads-tracker/evals/evals.json +0 -55
  194. package/skills/cm-ads-tracker/references/gtm-architecture.md +0 -321
  195. package/skills/cm-ads-tracker/references/industry-events.md +0 -294
  196. package/skills/cm-ads-tracker/references/platforms-api.md +0 -238
  197. package/skills/cm-ads-tracker/templates/capi-payload.md +0 -79
  198. package/skills/cm-ads-tracker/templates/datalayer-push.js +0 -104
  199. package/skills/cm-ads-tracker/templates/gtm-variables.js +0 -56
  200. package/skills/cm-auto-publisher/SKILL.md +0 -81
  201. package/skills/cm-booking-calendar/SKILL.md +0 -521
  202. package/skills/cm-booking-calendar/references/industry-patterns.md +0 -527
  203. package/skills/cm-booking-calendar/templates/booking-form.css +0 -626
  204. package/skills/cm-booking-calendar/templates/booking-form.html +0 -477
  205. package/skills/cm-booking-calendar/templates/calendar-engine.js +0 -419
  206. package/skills/cm-booking-calendar/templates/calendar-export.js +0 -395
  207. package/skills/cm-booking-calendar/templates/reminder-config.js +0 -629
  208. package/skills/cm-content-factory/.content-factory-state.json +0 -132
  209. package/skills/cm-content-factory/.git 2/logs/refs/heads/main +0 -1
  210. package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +0 -1
  211. package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
  212. package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
  213. package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
  214. package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
  215. package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
  216. package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
  217. package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
  218. package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
  219. package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
  220. package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
  221. package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
  222. package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
  223. package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
  224. package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
  225. package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
  226. package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
  227. package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
  228. package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
  229. package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
  230. package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
  231. package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
  232. package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
  233. package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
  234. package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
  235. package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
  236. package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
  237. package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
  238. package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
  239. package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
  240. package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
  241. package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
  242. package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
  243. package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
  244. package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
  245. package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
  246. package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
  247. package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
  248. package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
  249. package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
  250. package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
  251. package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
  252. package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
  253. package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
  254. package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +0 -5
  255. package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
  256. package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
  257. package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
  258. package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
  259. package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
  260. package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
  261. package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
  262. package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
  263. package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
  264. package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
  265. package/skills/cm-content-factory/.git 2/refs/heads/main +0 -1
  266. package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +0 -1
  267. package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +0 -76
  268. package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +0 -1
  269. package/skills/cm-content-factory/AGENTS.md +0 -61
  270. package/skills/cm-content-factory/CLAUDE.md +0 -63
  271. package/skills/cm-content-factory/CURSOR.md +0 -43
  272. package/skills/cm-content-factory/Content Factory.zip +0 -0
  273. package/skills/cm-content-factory/SKILL.md +0 -416
  274. package/skills/cm-content-factory/cf +0 -313
  275. package/skills/cm-content-factory/config.schema.json +0 -397
  276. package/skills/cm-content-factory/dashboard/app.js +0 -556
  277. package/skills/cm-content-factory/dashboard/index.html +0 -397
  278. package/skills/cm-content-factory/dashboard/style.css +0 -1211
  279. package/skills/cm-content-factory/examples/01-real-estate.config.json +0 -146
  280. package/skills/cm-content-factory/examples/02-personal-finance.config.json +0 -146
  281. package/skills/cm-content-factory/examples/03-health-wellness.config.json +0 -147
  282. package/skills/cm-content-factory/examples/04-saas-software.config.json +0 -147
  283. package/skills/cm-content-factory/examples/05-legal-services.config.json +0 -147
  284. package/skills/cm-content-factory/examples/06-insurance.config.json +0 -146
  285. package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +0 -146
  286. package/skills/cm-content-factory/examples/08-online-education.config.json +0 -147
  287. package/skills/cm-content-factory/examples/09-crypto-defi.config.json +0 -147
  288. package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +0 -147
  289. package/skills/cm-content-factory/examples/11-home-services.config.json +0 -146
  290. package/skills/cm-content-factory/examples/12-dental-clinic.config.json +0 -147
  291. package/skills/cm-content-factory/examples/13-pet-care.config.json +0 -147
  292. package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +0 -147
  293. package/skills/cm-content-factory/examples/15-ai-automation.config.json +0 -147
  294. package/skills/cm-content-factory/examples/16-wedding-events.config.json +0 -147
  295. package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +0 -148
  296. package/skills/cm-content-factory/examples/18-cybersecurity.config.json +0 -147
  297. package/skills/cm-content-factory/examples/19-food-restaurant.config.json +0 -148
  298. package/skills/cm-content-factory/examples/20-solar-energy.config.json +0 -147
  299. package/skills/cm-content-factory/examples/fitness-blog.config.json +0 -116
  300. package/skills/cm-content-factory/examples/tech-blog.config.json +0 -107
  301. package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +0 -72
  302. package/skills/cm-content-factory/extensions/hooks.py +0 -126
  303. package/skills/cm-content-factory/extensions/openclaw_adapter.py +0 -132
  304. package/skills/cm-content-factory/landing/docs/content/changelog.md +0 -36
  305. package/skills/cm-content-factory/landing/docs/content/deployment.md +0 -46
  306. package/skills/cm-content-factory/landing/docs/content/execution-flow.md +0 -67
  307. package/skills/cm-content-factory/landing/docs/content/openspace.md +0 -27
  308. package/skills/cm-content-factory/landing/docs/content/openviking.md +0 -33
  309. package/skills/cm-content-factory/landing/docs/content/use-cases.md +0 -26
  310. package/skills/cm-content-factory/landing/docs/content/v5-intro.md +0 -28
  311. package/skills/cm-content-factory/landing/docs/index.html +0 -240
  312. package/skills/cm-content-factory/landing/index.html +0 -680
  313. package/skills/cm-content-factory/landing/script.js +0 -143
  314. package/skills/cm-content-factory/landing/style.css +0 -1216
  315. package/skills/cm-content-factory/landing/translations.js +0 -508
  316. package/skills/cm-content-factory/logs/events.jsonl +0 -11
  317. package/skills/cm-content-factory/profiles/_template.profile.json +0 -231
  318. package/skills/cm-content-factory/profiles/finance.profile.json +0 -278
  319. package/skills/cm-content-factory/profiles/legal.profile.json +0 -263
  320. package/skills/cm-content-factory/profiles/medical-research.profile.json +0 -321
  321. package/skills/cm-content-factory/profiles/technology.profile.json +0 -275
  322. package/skills/cm-content-factory/scripts/agent_dispatcher.py +0 -266
  323. package/skills/cm-content-factory/scripts/audit.py +0 -106
  324. package/skills/cm-content-factory/scripts/dashboard_server.py +0 -225
  325. package/skills/cm-content-factory/scripts/deploy.py +0 -146
  326. package/skills/cm-content-factory/scripts/extract.py +0 -132
  327. package/skills/cm-content-factory/scripts/landing_generator.py +0 -459
  328. package/skills/cm-content-factory/scripts/memory.py +0 -521
  329. package/skills/cm-content-factory/scripts/monetize.py +0 -239
  330. package/skills/cm-content-factory/scripts/pipeline.py +0 -357
  331. package/skills/cm-content-factory/scripts/plan.py +0 -163
  332. package/skills/cm-content-factory/scripts/publish.py +0 -145
  333. package/skills/cm-content-factory/scripts/research.py +0 -337
  334. package/skills/cm-content-factory/scripts/scaffold.py +0 -464
  335. package/skills/cm-content-factory/scripts/scoreboard.py +0 -336
  336. package/skills/cm-content-factory/scripts/seo.py +0 -90
  337. package/skills/cm-content-factory/scripts/state_manager.py +0 -320
  338. package/skills/cm-content-factory/scripts/token_manager.py +0 -268
  339. package/skills/cm-content-factory/scripts/validate.py +0 -221
  340. package/skills/cm-content-factory/scripts/wizard.py +0 -329
  341. package/skills/cm-content-factory/scripts/write.py +0 -93
  342. package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
  343. package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +0 -90
  344. package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +0 -54
  345. package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +0 -38
  346. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +0 -65
  347. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +0 -48
  348. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +0 -39
  349. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +0 -42
  350. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +0 -51
  351. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +0 -52
  352. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +0 -86
  353. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +0 -80
  354. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +0 -58
  355. package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +0 -102
  356. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +0 -45
  357. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +0 -29
  358. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +0 -55
  359. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +0 -29
  360. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +0 -41
  361. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +0 -40
  362. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +0 -56
  363. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +0 -46
  364. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +0 -45
  365. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +0 -45
  366. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +0 -108
  367. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +0 -22
  368. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +0 -52
  369. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +0 -58
  370. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +0 -92
  371. package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +0 -575
  372. package/skills/cm-content-factory/tests/conftest.py +0 -66
  373. package/skills/cm-content-factory/tests/test_agent_dispatcher.py +0 -125
  374. package/skills/cm-content-factory/tests/test_memory.py +0 -128
  375. package/skills/cm-content-factory/tests/test_pipeline.py +0 -107
  376. package/skills/cm-content-factory/tests/test_research.py +0 -56
  377. package/skills/cm-content-factory/tests/test_state_manager.py +0 -131
  378. package/skills/cm-content-factory/tests/test_token_manager.py +0 -110
  379. package/skills/cm-content-factory/tests/test_wizard.py +0 -121
  380. package/skills/cm-cro-methodology/SKILL.md +0 -290
  381. package/skills/cm-cro-methodology/references/COPYWRITING.md +0 -178
  382. package/skills/cm-cro-methodology/references/OBJECTIONS.md +0 -135
  383. package/skills/cm-cro-methodology/references/PERSUASION.md +0 -158
  384. package/skills/cm-cro-methodology/references/RESEARCH.md +0 -220
  385. package/skills/cm-cro-methodology/references/funnel-analysis.md +0 -365
  386. package/skills/cm-cro-methodology/references/testing-methodology.md +0 -330
  387. package/skills/cm-google-form/SKILL.md +0 -266
  388. package/skills/cm-google-form/templates/apps-script.js +0 -55
  389. package/skills/cm-google-form/templates/form-markup.html +0 -110
  390. package/skills/cm-google-form/templates/form-submit.js +0 -201
  391. package/skills/cm-google-form/templates/toast.css +0 -152
  392. package/skills/cm-growth-hacking/SKILL.md +0 -282
  393. package/skills/cm-growth-hacking/bottom-sheet-engine.md +0 -261
  394. package/skills/cm-growth-hacking/calendar-integration.md +0 -264
  395. package/skills/cm-growth-hacking/references/engagement-patterns.md +0 -346
  396. package/skills/cm-growth-hacking/templates/bottom-sheet.css +0 -528
  397. package/skills/cm-growth-hacking/templates/bottom-sheet.js +0 -269
  398. package/skills/cm-growth-hacking/templates/calendar-cta.js +0 -213
  399. package/skills/cm-growth-hacking/templates/tracking-events.js +0 -211
  400. package/skills/cm-growth-hacking/templates/trigger-manager.js +0 -254
  401. package/skills/cm-growth-hacking/tracking-events.md +0 -246
  402. package/skills/cm-growth-hacking/trigger-system.md +0 -342
  403. package/skills/cm-jtbd/SKILL.md +0 -98
  404. package/skills/cm-notebooklm/SKILL.md +0 -156
  405. package/skills/cm-notebooklm/references/command_reference.md +0 -94
  406. package/skills/cm-notebooklm/references/workflows.md +0 -60
  407. package/skills/cm-notebooklm/resources/knowledge_sources.md +0 -106
  408. package/skills/cm-notebooklm/scripts/brain-sync.sh +0 -453
  409. package/skills/cm-notebooklm/scripts/graduate_wisdom.py +0 -101
  410. package/skills/cm-readit/SKILL.md +0 -289
  411. package/skills/cm-readit/audio-player.md +0 -206
  412. package/skills/cm-readit/examples/blog-reader.js +0 -352
  413. package/skills/cm-readit/examples/voice-cro.js +0 -390
  414. package/skills/cm-readit/tts-engine.md +0 -262
  415. package/skills/cm-readit/ui-patterns.md +0 -362
  416. package/skills/cm-readit/voice-cro.md +0 -223
@@ -0,0 +1,456 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.SkillEvolver = void 0;
7
+ exports.formatEvolutionResult = formatEvolutionResult;
8
+ exports.formatEvolutionHistory = formatEvolutionHistory;
9
+ const crypto_1 = __importDefault(require("crypto"));
10
+ const fs_1 = __importDefault(require("fs"));
11
+ const path_1 = __importDefault(require("path"));
12
+ const storage_backend_1 = require("./storage-backend");
13
+ // ─── Constants ──────────────────────────────────────────────────────────────
14
+ const BACKUP_DIR = '.cm/skill-backups';
15
+ const MAX_EVOLUTION_DEPTH = 5; // Anti-loop: max generations
16
+ const MIN_FIX_CONFIDENCE = 0.70;
17
+ const MIN_DERIVED_CONFIDENCE = 0.75;
18
+ const MIN_CAPTURED_CONFIDENCE = 0.80;
19
+ // ─── Skill Evolver ──────────────────────────────────────────────────────────
20
+ // TRIZ #15 Dynamization — skills transform based on environment feedback
21
+ /**
22
+ * SkillEvolver — Executes evolution actions recommended by the ExecutionAnalyzer.
23
+ *
24
+ * Three modes:
25
+ * FIX — In-place repair of degraded skills (patch SKILL.md)
26
+ * DERIVED — Create specialized variant of an existing skill
27
+ * CAPTURED — Generate a new skill from successful reasoning patterns
28
+ *
29
+ * Safety: Always creates backups before mutations. Anti-loop protection
30
+ * prevents runaway evolution chains.
31
+ */
32
+ class SkillEvolver {
33
+ constructor(projectPath, backend) {
34
+ this.projectPath = projectPath;
35
+ this.backend = backend !== null && backend !== void 0 ? backend : (0, storage_backend_1.getBackend)(projectPath);
36
+ this.backend.initialize();
37
+ this.skillsDir = this.findSkillsDir();
38
+ this.backupDir = path_1.default.join(projectPath, BACKUP_DIR);
39
+ }
40
+ // ─── Public API ─────────────────────────────────────────────────────────
41
+ /**
42
+ * Evolve a skill based on an advisory handoff.
43
+ */
44
+ evolveFromAdvisory(handoff) {
45
+ var _a;
46
+ const mode = handoff.recommendation.action;
47
+ const skill = handoff.skill.name;
48
+ const confidence = (_a = handoff.recommendation.confidence) !== null && _a !== void 0 ? _a : 0;
49
+ if (!skill) {
50
+ return { success: false, mode: mode !== null && mode !== void 0 ? mode : 'FIX', skill: '', error: 'No target skill in advisory handoff.' };
51
+ }
52
+ if (!mode || mode === 'NONE') {
53
+ return { success: false, mode: 'FIX', skill, error: 'No evolution action recommended.' };
54
+ }
55
+ return this.evolve(mode, skill, confidence, handoff.source.analysis_id);
56
+ }
57
+ /**
58
+ * Execute a specific evolution mode on a skill.
59
+ */
60
+ evolve(mode, skill, confidence, sourceAnalysisId) {
61
+ // Anti-loop protection
62
+ const record = this.getSkillRecord(skill);
63
+ if (record && record.generation >= MAX_EVOLUTION_DEPTH) {
64
+ return {
65
+ success: false, mode, skill,
66
+ error: `Anti-loop: ${skill} has reached max evolution depth (${MAX_EVOLUTION_DEPTH}). Manual review required.`,
67
+ };
68
+ }
69
+ // Confidence threshold check
70
+ const minConfidence = this.getMinConfidence(mode);
71
+ if (confidence < minConfidence) {
72
+ return {
73
+ success: false, mode, skill,
74
+ error: `Confidence ${(confidence * 100).toFixed(0)}% is below ${mode} threshold of ${(minConfidence * 100).toFixed(0)}%.`,
75
+ };
76
+ }
77
+ switch (mode) {
78
+ case 'FIX':
79
+ return this.executeFix(skill, confidence, sourceAnalysisId);
80
+ case 'DERIVED':
81
+ return this.executeDerived(skill, confidence, sourceAnalysisId);
82
+ case 'CAPTURED':
83
+ return this.executeCaptured(skill, confidence, sourceAnalysisId);
84
+ }
85
+ }
86
+ /**
87
+ * Get evolution history for a skill.
88
+ */
89
+ getHistory(skill, limit = 20) {
90
+ return this.loadHistory(skill, limit);
91
+ }
92
+ /**
93
+ * Get the skill record (lineage tracking).
94
+ */
95
+ getSkillRecord(skill) {
96
+ return this.loadSkillRecord(skill);
97
+ }
98
+ /**
99
+ * List all skill records.
100
+ */
101
+ listSkillRecords(limit = 50) {
102
+ return this.loadAllSkillRecords(limit);
103
+ }
104
+ /**
105
+ * Rollback a skill to its pre-evolution state.
106
+ */
107
+ rollback(skill) {
108
+ const backupPath = this.getLatestBackup(skill);
109
+ if (!backupPath) {
110
+ return { success: false, mode: 'FIX', skill, error: `No backup found for ${skill}.` };
111
+ }
112
+ const skillMdPath = this.getSkillPath(skill);
113
+ if (!skillMdPath) {
114
+ return { success: false, mode: 'FIX', skill, error: `Skill ${skill} not found.` };
115
+ }
116
+ try {
117
+ const backupContent = fs_1.default.readFileSync(backupPath, 'utf-8');
118
+ fs_1.default.writeFileSync(skillMdPath, backupContent, 'utf-8');
119
+ return { success: true, mode: 'FIX', skill, backupPath, patchApplied: 'Rolled back to backup.' };
120
+ }
121
+ catch (err) {
122
+ return { success: false, mode: 'FIX', skill, error: `Rollback failed: ${err}` };
123
+ }
124
+ }
125
+ // ─── Evolution Modes ──────────────────────────────────────────────────────
126
+ /**
127
+ * FIX mode — In-place repair of a degraded skill.
128
+ * Appends learnings from failed executions to the skill's SKILL.md.
129
+ */
130
+ executeFix(skill, confidence, sourceAnalysisId) {
131
+ const skillPath = this.getSkillPath(skill);
132
+ if (!skillPath) {
133
+ return { success: false, mode: 'FIX', skill, error: `Skill ${skill} not found at expected path.` };
134
+ }
135
+ // Read current content
136
+ let content;
137
+ try {
138
+ content = fs_1.default.readFileSync(skillPath, 'utf-8');
139
+ }
140
+ catch (_a) {
141
+ return { success: false, mode: 'FIX', skill, error: `Cannot read ${skillPath}` };
142
+ }
143
+ // Create backup before mutation
144
+ const backupPath = this.createBackup(skill, content);
145
+ // Build the fix patch from execution analysis
146
+ const analyses = this.backend.getExecutionAnalyses(10);
147
+ const relevantAnalysis = sourceAnalysisId
148
+ ? analyses.find(a => a.id === sourceAnalysisId)
149
+ : analyses.find(a => a.recommended_action === 'FIX' && a.skill_judgments.some(j => j.skill === skill));
150
+ if (!relevantAnalysis) {
151
+ return { success: false, mode: 'FIX', skill, backupPath, error: 'No relevant analysis found for fix.' };
152
+ }
153
+ const fixPatch = this.buildFixPatch(skill, relevantAnalysis);
154
+ const beforeHash = this.hashContent(content);
155
+ // Apply the fix (append learnings section)
156
+ const updatedContent = content + '\n' + fixPatch;
157
+ fs_1.default.writeFileSync(skillPath, updatedContent, 'utf-8');
158
+ const afterHash = this.hashContent(updatedContent);
159
+ // Record evolution
160
+ this.recordEvolution(skill, 'FIX', sourceAnalysisId, beforeHash, afterHash, fixPatch, confidence);
161
+ this.upsertSkillRecord(skill, 'fix');
162
+ return { success: true, mode: 'FIX', skill, backupPath, patchApplied: fixPatch };
163
+ }
164
+ /**
165
+ * DERIVED mode — Create a specialized variant of an existing skill.
166
+ * Copies the skill and adds specialization notes.
167
+ */
168
+ executeDerived(skill, confidence, sourceAnalysisId) {
169
+ var _a;
170
+ const skillPath = this.getSkillPath(skill);
171
+ if (!skillPath) {
172
+ return { success: false, mode: 'DERIVED', skill, error: `Parent skill ${skill} not found.` };
173
+ }
174
+ let content;
175
+ try {
176
+ content = fs_1.default.readFileSync(skillPath, 'utf-8');
177
+ }
178
+ catch (_b) {
179
+ return { success: false, mode: 'DERIVED', skill, error: `Cannot read ${skillPath}` };
180
+ }
181
+ // Generate derived skill name
182
+ const record = this.getSkillRecord(skill);
183
+ const gen = ((_a = record === null || record === void 0 ? void 0 : record.generation) !== null && _a !== void 0 ? _a : 0) + 1;
184
+ const derivedName = `${skill}-v${gen}`;
185
+ const derivedDir = path_1.default.join(this.skillsDir, derivedName);
186
+ if (fs_1.default.existsSync(derivedDir)) {
187
+ return { success: false, mode: 'DERIVED', skill, error: `Derived skill ${derivedName} already exists.` };
188
+ }
189
+ // Get specialization context from analysis
190
+ const analyses = this.backend.getExecutionAnalyses(10);
191
+ const analysis = sourceAnalysisId
192
+ ? analyses.find(a => a.id === sourceAnalysisId)
193
+ : analyses.find(a => a.recommended_action === 'DERIVED');
194
+ const specialization = analysis
195
+ ? `\n\n## Derived Specialization (gen ${gen})\n\n> Auto-derived from ${skill} based on execution analysis.\n> Analysis: ${analysis.summary}\n> Fallback patterns addressed: ${analysis.skill_judgments.filter(j => j.fallback_used).map(j => j.note || j.skill).join(', ') || 'N/A'}\n`
196
+ : `\n\n## Derived Specialization (gen ${gen})\n\n> Auto-derived from ${skill}.\n`;
197
+ const derivedContent = content + specialization;
198
+ const beforeHash = this.hashContent(content);
199
+ const afterHash = this.hashContent(derivedContent);
200
+ // Create derived skill directory and file
201
+ fs_1.default.mkdirSync(derivedDir, { recursive: true });
202
+ fs_1.default.writeFileSync(path_1.default.join(derivedDir, 'SKILL.md'), derivedContent, 'utf-8');
203
+ // Record evolution
204
+ this.recordEvolution(derivedName, 'DERIVED', sourceAnalysisId, beforeHash, afterHash, `Derived from ${skill} (gen ${gen})`, confidence);
205
+ this.upsertSkillRecord(derivedName, 'derived', skill, gen);
206
+ return { success: true, mode: 'DERIVED', skill: derivedName, patchApplied: `Derived from ${skill}` };
207
+ }
208
+ /**
209
+ * CAPTURED mode — Generate a new skill from successful reasoning patterns.
210
+ * Creates a minimal SKILL.md scaffold capturing the successful approach.
211
+ */
212
+ executeCaptured(skill, confidence, sourceAnalysisId) {
213
+ var _a;
214
+ const analyses = this.backend.getExecutionAnalyses(10);
215
+ const analysis = sourceAnalysisId
216
+ ? analyses.find(a => a.id === sourceAnalysisId)
217
+ : analyses.find(a => a.recommended_action === 'CAPTURED');
218
+ if (!analysis) {
219
+ return { success: false, mode: 'CAPTURED', skill, error: 'No analysis with CAPTURED recommendation found.' };
220
+ }
221
+ const capturedName = `cm-captured-${Date.now()}`;
222
+ const capturedDir = path_1.default.join(this.skillsDir, capturedName);
223
+ const skillContent = [
224
+ '---',
225
+ `name: ${capturedName}`,
226
+ `description: Auto-captured skill from successful task execution`,
227
+ '---',
228
+ '',
229
+ `# ${capturedName}`,
230
+ '',
231
+ `> Auto-captured on ${new Date().toISOString()}`,
232
+ `> Source: ${analysis.task_title}`,
233
+ `> Confidence: ${(confidence * 100).toFixed(0)}%`,
234
+ '',
235
+ '## Context',
236
+ '',
237
+ analysis.summary,
238
+ '',
239
+ '## Approach',
240
+ '',
241
+ `The following skill chain was NOT used but the task completed successfully:`,
242
+ `- Selected skills: ${((_a = analysis.selected_skills) !== null && _a !== void 0 ? _a : []).join(', ') || 'none'}`,
243
+ '',
244
+ '## When to Apply',
245
+ '',
246
+ `Apply this skill when facing tasks similar to: "${analysis.task_title}"`,
247
+ '',
248
+ '## Steps',
249
+ '',
250
+ '1. [TODO: Extract specific steps from the captured pattern]',
251
+ '2. [TODO: Document the reasoning that led to success]',
252
+ '',
253
+ ].join('\n');
254
+ const afterHash = this.hashContent(skillContent);
255
+ fs_1.default.mkdirSync(capturedDir, { recursive: true });
256
+ fs_1.default.writeFileSync(path_1.default.join(capturedDir, 'SKILL.md'), skillContent, 'utf-8');
257
+ this.recordEvolution(capturedName, 'CAPTURED', sourceAnalysisId, '', afterHash, `Captured from: ${analysis.task_title}`, confidence);
258
+ this.upsertSkillRecord(capturedName, 'captured', undefined, 0);
259
+ return { success: true, mode: 'CAPTURED', skill: capturedName, patchApplied: `Captured from task: ${analysis.task_title}` };
260
+ }
261
+ // ─── Helpers ──────────────────────────────────────────────────────────────
262
+ findSkillsDir() {
263
+ // Check common skill locations
264
+ const candidates = [
265
+ path_1.default.join(this.projectPath, 'skills'),
266
+ path_1.default.join(this.projectPath, '.agent', 'skills'),
267
+ ];
268
+ for (const dir of candidates) {
269
+ if (fs_1.default.existsSync(dir))
270
+ return dir;
271
+ }
272
+ // Default to skills/ (will be created if needed)
273
+ return path_1.default.join(this.projectPath, 'skills');
274
+ }
275
+ getSkillPath(skill) {
276
+ const candidates = [
277
+ path_1.default.join(this.skillsDir, skill, 'SKILL.md'),
278
+ path_1.default.join(this.projectPath, '.agent', 'skills', skill, 'SKILL.md'),
279
+ ];
280
+ for (const p of candidates) {
281
+ if (fs_1.default.existsSync(p))
282
+ return p;
283
+ }
284
+ return null;
285
+ }
286
+ createBackup(skill, content) {
287
+ const backupSkillDir = path_1.default.join(this.backupDir, skill);
288
+ fs_1.default.mkdirSync(backupSkillDir, { recursive: true });
289
+ const timestamp = new Date().toISOString().replace(/[:.]/g, '-');
290
+ const backupPath = path_1.default.join(backupSkillDir, `SKILL-${timestamp}.md`);
291
+ fs_1.default.writeFileSync(backupPath, content, 'utf-8');
292
+ return backupPath;
293
+ }
294
+ getLatestBackup(skill) {
295
+ const backupSkillDir = path_1.default.join(this.backupDir, skill);
296
+ if (!fs_1.default.existsSync(backupSkillDir))
297
+ return null;
298
+ const files = fs_1.default.readdirSync(backupSkillDir)
299
+ .filter(f => f.startsWith('SKILL-') && f.endsWith('.md'))
300
+ .sort()
301
+ .reverse();
302
+ return files.length > 0 ? path_1.default.join(backupSkillDir, files[0]) : null;
303
+ }
304
+ buildFixPatch(skill, analysis) {
305
+ const judgment = analysis.skill_judgments.find(j => j.skill === skill);
306
+ const lines = [
307
+ '',
308
+ `## Evolution Fix (${new Date().toISOString().split('T')[0]})`,
309
+ '',
310
+ `> Auto-applied by SkillEvolver based on execution analysis.`,
311
+ `> Analysis: ${analysis.id.slice(0, 8)}`,
312
+ `> Task: ${analysis.task_title}`,
313
+ `> Status: ${analysis.status}`,
314
+ ];
315
+ if (judgment === null || judgment === void 0 ? void 0 : judgment.note) {
316
+ lines.push(`> Note: ${judgment.note}`);
317
+ }
318
+ if (analysis.retro_summary) {
319
+ lines.push('', '### Learnings Applied', '', analysis.retro_summary);
320
+ }
321
+ lines.push('', `### Corrective Action`, '', `- Review and address the failure pattern from: "${analysis.task_title}"`);
322
+ return lines.join('\n');
323
+ }
324
+ hashContent(content) {
325
+ return crypto_1.default.createHash('sha256').update(content).digest('hex').slice(0, 16);
326
+ }
327
+ getMinConfidence(mode) {
328
+ switch (mode) {
329
+ case 'FIX': return MIN_FIX_CONFIDENCE;
330
+ case 'DERIVED': return MIN_DERIVED_CONFIDENCE;
331
+ case 'CAPTURED': return MIN_CAPTURED_CONFIDENCE;
332
+ }
333
+ }
334
+ // ─── Persistence (file-based for simplicity, can migrate to SQLite later) ─
335
+ recordEvolution(skill, mode, sourceAnalysisId, beforeHash, afterHash, patchSummary, confidence) {
336
+ const historyDir = path_1.default.join(this.projectPath, '.cm', 'evolution');
337
+ fs_1.default.mkdirSync(historyDir, { recursive: true });
338
+ const entry = {
339
+ id: crypto_1.default.randomUUID(),
340
+ skill_name: skill,
341
+ mode,
342
+ source_analysis_id: sourceAnalysisId,
343
+ before_hash: beforeHash,
344
+ after_hash: afterHash,
345
+ patch_summary: patchSummary,
346
+ confidence,
347
+ created_at: new Date().toISOString(),
348
+ };
349
+ const historyFile = path_1.default.join(historyDir, 'history.jsonl');
350
+ fs_1.default.appendFileSync(historyFile, JSON.stringify(entry) + '\n');
351
+ }
352
+ loadHistory(skill, limit = 20) {
353
+ const historyFile = path_1.default.join(this.projectPath, '.cm', 'evolution', 'history.jsonl');
354
+ if (!fs_1.default.existsSync(historyFile))
355
+ return [];
356
+ const lines = fs_1.default.readFileSync(historyFile, 'utf-8').trim().split('\n').filter(Boolean);
357
+ let entries = [];
358
+ for (const line of lines) {
359
+ try {
360
+ entries.push(JSON.parse(line));
361
+ }
362
+ catch ( /* skip malformed */_a) { /* skip malformed */ }
363
+ }
364
+ if (skill)
365
+ entries = entries.filter(e => e.skill_name === skill);
366
+ return entries.slice(-limit).reverse();
367
+ }
368
+ upsertSkillRecord(skill, origin, parentSkill, generation) {
369
+ var _a, _b, _c, _d, _e, _f;
370
+ const recordsDir = path_1.default.join(this.projectPath, '.cm', 'evolution');
371
+ fs_1.default.mkdirSync(recordsDir, { recursive: true });
372
+ const recordsFile = path_1.default.join(recordsDir, 'records.json');
373
+ let records = {};
374
+ if (fs_1.default.existsSync(recordsFile)) {
375
+ try {
376
+ records = JSON.parse(fs_1.default.readFileSync(recordsFile, 'utf-8'));
377
+ }
378
+ catch ( /* fresh */_g) { /* fresh */ }
379
+ }
380
+ const existing = records[skill];
381
+ const now = new Date().toISOString();
382
+ records[skill] = {
383
+ id: (_a = existing === null || existing === void 0 ? void 0 : existing.id) !== null && _a !== void 0 ? _a : crypto_1.default.randomUUID(),
384
+ skill_name: skill,
385
+ origin: (_b = existing === null || existing === void 0 ? void 0 : existing.origin) !== null && _b !== void 0 ? _b : origin,
386
+ parent_skill: parentSkill !== null && parentSkill !== void 0 ? parentSkill : existing === null || existing === void 0 ? void 0 : existing.parent_skill,
387
+ generation: generation !== null && generation !== void 0 ? generation : ((_c = existing === null || existing === void 0 ? void 0 : existing.generation) !== null && _c !== void 0 ? _c : 0),
388
+ version: `${((_d = existing === null || existing === void 0 ? void 0 : existing.evolution_count) !== null && _d !== void 0 ? _d : 0) + 1}.0.0`,
389
+ created_at: (_e = existing === null || existing === void 0 ? void 0 : existing.created_at) !== null && _e !== void 0 ? _e : now,
390
+ updated_at: now,
391
+ evolution_count: ((_f = existing === null || existing === void 0 ? void 0 : existing.evolution_count) !== null && _f !== void 0 ? _f : 0) + 1,
392
+ last_evolution_mode: origin.toUpperCase(),
393
+ };
394
+ fs_1.default.writeFileSync(recordsFile, JSON.stringify(records, null, 2));
395
+ }
396
+ loadSkillRecord(skill) {
397
+ var _a;
398
+ const recordsFile = path_1.default.join(this.projectPath, '.cm', 'evolution', 'records.json');
399
+ if (!fs_1.default.existsSync(recordsFile))
400
+ return null;
401
+ try {
402
+ const records = JSON.parse(fs_1.default.readFileSync(recordsFile, 'utf-8'));
403
+ return (_a = records[skill]) !== null && _a !== void 0 ? _a : null;
404
+ }
405
+ catch (_b) {
406
+ return null;
407
+ }
408
+ }
409
+ loadAllSkillRecords(limit) {
410
+ const recordsFile = path_1.default.join(this.projectPath, '.cm', 'evolution', 'records.json');
411
+ if (!fs_1.default.existsSync(recordsFile))
412
+ return [];
413
+ try {
414
+ const records = JSON.parse(fs_1.default.readFileSync(recordsFile, 'utf-8'));
415
+ return Object.values(records).slice(0, limit);
416
+ }
417
+ catch (_a) {
418
+ return [];
419
+ }
420
+ }
421
+ }
422
+ exports.SkillEvolver = SkillEvolver;
423
+ // ─── Display Helpers ─────────────────────────────────────────────────────────
424
+ function formatEvolutionResult(result) {
425
+ const icon = result.success ? '✅' : '❌';
426
+ const lines = [
427
+ `${icon} Skill Evolution — ${result.mode}`,
428
+ '─'.repeat(50),
429
+ `Skill: ${result.skill}`,
430
+ `Result: ${result.success ? 'Success' : 'Failed'}`,
431
+ ];
432
+ if (result.backupPath)
433
+ lines.push(`Backup: ${result.backupPath}`);
434
+ if (result.patchApplied)
435
+ lines.push(`Patch: ${result.patchApplied.split('\n')[0]}...`);
436
+ if (result.error)
437
+ lines.push(`Error: ${result.error}`);
438
+ return lines.join('\n');
439
+ }
440
+ function formatEvolutionHistory(history) {
441
+ if (history.length === 0)
442
+ return 'No evolution history recorded.';
443
+ const lines = [
444
+ '🧬 Evolution History',
445
+ '─'.repeat(70),
446
+ `${'Date'.padEnd(12)} ${'Skill'.padEnd(25)} ${'Mode'.padEnd(10)} ${'Conf'.padEnd(6)} Summary`,
447
+ '─'.repeat(70),
448
+ ];
449
+ for (const entry of history) {
450
+ const date = entry.created_at.split('T')[0];
451
+ const conf = (entry.confidence * 100).toFixed(0) + '%';
452
+ const summary = entry.patch_summary.split('\n')[0].slice(0, 30);
453
+ lines.push(`${date.padEnd(12)} ${entry.skill_name.padEnd(25)} ${entry.mode.padEnd(10)} ${conf.padEnd(6)} ${summary}`);
454
+ }
455
+ return lines.join('\n');
456
+ }