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
@@ -288,6 +288,13 @@
288
288
  if (e.target.closest('.project-delete-btn')) return;
289
289
  selectedProjectId = el.dataset.projectId || null;
290
290
  await refreshData();
291
+ if (ws && ws.readyState === WebSocket.OPEN) {
292
+ if (selectedProjectId) {
293
+ ws.send(JSON.stringify({ action: 'subscribe', projectId: selectedProjectId }));
294
+ } else {
295
+ ws.send(JSON.stringify({ action: 'unsubscribe' }));
296
+ }
297
+ }
291
298
  });
292
299
  });
293
300
 
@@ -926,7 +933,15 @@
926
933
  }
927
934
 
928
935
  // ── Utilities ──────────────────────────────
929
- function esc(str) { const d = document.createElement('div'); d.textContent = str; return d.innerHTML; }
936
+ function esc(str) {
937
+ if (str == null) return '';
938
+ return String(str)
939
+ .replace(/&/g, '&')
940
+ .replace(/</g, '&lt;')
941
+ .replace(/>/g, '&gt;')
942
+ .replace(/"/g, '&quot;')
943
+ .replace(/'/g, '&#39;');
944
+ }
930
945
  function formatTimeAgo(dateStr) {
931
946
  const ms = Date.now() - new Date(dateStr).getTime();
932
947
  const m = Math.floor(ms / 60000), h = Math.floor(ms / 3600000), d = Math.floor(ms / 86400000);
@@ -1250,6 +1265,41 @@
1250
1265
  }
1251
1266
  }
1252
1267
 
1268
+ // ── WebSocket Client ─────────────────────────
1269
+ let ws = null;
1270
+ let wsReconnectTimer = null;
1271
+
1272
+ function connectWs() {
1273
+ const protocol = location.protocol === 'https:' ? 'wss:' : 'ws:';
1274
+ ws = new WebSocket(`${protocol}//${location.host}/ws`);
1275
+
1276
+ ws.onopen = () => {
1277
+ console.log('WS connected');
1278
+ if (selectedProjectId) {
1279
+ ws.send(JSON.stringify({ action: 'subscribe', projectId: selectedProjectId }));
1280
+ }
1281
+ };
1282
+
1283
+ ws.onmessage = (event) => {
1284
+ const msg = JSON.parse(event.data);
1285
+ if (msg.type && msg.type.startsWith('task.')) {
1286
+ refreshData(true);
1287
+ }
1288
+ if (msg.type === 'activity.added') {
1289
+ refreshData(true);
1290
+ }
1291
+ };
1292
+
1293
+ ws.onclose = () => {
1294
+ console.log('WS disconnected, falling back to polling');
1295
+ ws = null;
1296
+ };
1297
+
1298
+ ws.onerror = () => {
1299
+ ws = null;
1300
+ };
1301
+ }
1302
+
1253
1303
  // ── Init ───────────────────────────────────────
1254
1304
  async function init() {
1255
1305
  try {
@@ -1261,6 +1311,7 @@
1261
1311
  updateSyncStatus('synced');
1262
1312
  updateAutoRefreshUI();
1263
1313
  startAutoRefresh();
1314
+ connectWs();
1264
1315
  } catch (err) {
1265
1316
  showToast('error', 'Failed to load: ' + err.message);
1266
1317
  updateSyncStatus('error');
@@ -0,0 +1,88 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Build/refresh skills-lock.json with sha256 + version for every skill.
4
+ *
5
+ * Usage:
6
+ * node scripts/build-skills-lock.mjs → rewrite skills-lock.json
7
+ * node scripts/build-skills-lock.mjs --check → exit 1 on drift, no write
8
+ */
9
+ import fs from 'fs';
10
+ import path from 'path';
11
+ import crypto from 'crypto';
12
+ import { fileURLToPath } from 'url';
13
+
14
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
15
+ const ROOT = path.resolve(__dirname, '..');
16
+ const SKILLS = path.join(ROOT, 'skills');
17
+ const LOCK = path.join(ROOT, 'skills-lock.json');
18
+
19
+ const args = new Set(process.argv.slice(2));
20
+ const checkOnly = args.has('--check');
21
+
22
+ function sha256(file) {
23
+ return crypto.createHash('sha256').update(fs.readFileSync(file)).digest('hex');
24
+ }
25
+
26
+ function parseFrontmatter(text) {
27
+ const m = text.match(/^---\n([\s\S]*?)\n---/);
28
+ if (!m) return {};
29
+ const out = {};
30
+ const v = m[1].match(/^version:\s*['"]?([\w.\-+]+)['"]?\s*$/m);
31
+ if (v) out.version = v[1];
32
+ const d = m[1].match(/^deprecated:\s*(true|false)\s*$/m);
33
+ if (d) out.deprecated = d[1] === 'true';
34
+ return out;
35
+ }
36
+
37
+ function buildLock() {
38
+ const skills = {};
39
+ if (fs.existsSync(SKILLS)) {
40
+ for (const name of fs.readdirSync(SKILLS).sort()) {
41
+ if (!name.startsWith('cm-')) continue;
42
+ const skillFile = path.join(SKILLS, name, 'SKILL.md');
43
+ if (!fs.existsSync(skillFile)) continue;
44
+ const text = fs.readFileSync(skillFile, 'utf8');
45
+ const fm = parseFrontmatter(text);
46
+ skills[name] = {
47
+ sha256: sha256(skillFile),
48
+ ...(fm.version ? { version: fm.version } : {}),
49
+ ...(fm.deprecated ? { deprecated: true } : {}),
50
+ };
51
+ }
52
+ }
53
+ return {
54
+ version: 2,
55
+ generated_at: new Date().toISOString(),
56
+ skills,
57
+ };
58
+ }
59
+
60
+ const next = buildLock();
61
+
62
+ if (checkOnly) {
63
+ if (!fs.existsSync(LOCK)) {
64
+ console.error('✗ skills-lock.json missing');
65
+ process.exit(1);
66
+ }
67
+ const prev = JSON.parse(fs.readFileSync(LOCK, 'utf8'));
68
+ const drift = [];
69
+ for (const [name, entry] of Object.entries(next.skills)) {
70
+ const before = prev.skills?.[name];
71
+ if (!before) drift.push(`+ ${name} (new)`);
72
+ else if (before.sha256 !== entry.sha256) drift.push(`Δ ${name} (hash drift)`);
73
+ }
74
+ for (const name of Object.keys(prev.skills ?? {})) {
75
+ if (!next.skills[name]) drift.push(`- ${name} (removed)`);
76
+ }
77
+ if (drift.length) {
78
+ console.error('✗ skills-lock drift:');
79
+ for (const line of drift) console.error(' ' + line);
80
+ console.error('Run `node scripts/build-skills-lock.mjs` to refresh.');
81
+ process.exit(1);
82
+ }
83
+ console.log(`✓ skills-lock OK (${Object.keys(next.skills).length} skills)`);
84
+ process.exit(0);
85
+ }
86
+
87
+ fs.writeFileSync(LOCK, JSON.stringify(next, null, 2) + '\n', 'utf8');
88
+ console.log(`✓ wrote skills-lock.json (${Object.keys(next.skills).length} skills)`);
@@ -1,46 +1,157 @@
1
1
  #!/usr/bin/env node
2
2
  /**
3
- * Generate SKILL.md from SKILL.md.tmpl + meta.json when present.
4
- * Usage: node scripts/build-skills.mjs [--check]
3
+ * Build / sync skills.
4
+ *
5
+ * Modes:
6
+ * 1. Template render — reads skills/<name>/SKILL.md.tmpl + meta.json,
7
+ * writes SKILL.md. Always runs.
8
+ * 2. Multi-platform sync — when --platforms is passed (or --all-platforms),
9
+ * mirrors ALL cm-* skill folders + _shared/ into per-platform install dirs.
10
+ *
11
+ * Usage:
12
+ * node scripts/build-skills.mjs # template only
13
+ * node scripts/build-skills.mjs --check # template + (when --platforms) drift check
14
+ * node scripts/build-skills.mjs --platforms cursor,codex,opencode
15
+ * node scripts/build-skills.mjs --all-platforms
5
16
  */
6
17
  import fs from 'fs';
7
18
  import path from 'path';
19
+ import crypto from 'crypto';
8
20
  import { fileURLToPath } from 'url';
9
21
 
10
22
  const __dirname = path.dirname(fileURLToPath(import.meta.url));
11
- const skillsRoot = path.join(__dirname, '..', 'skills');
12
- const check = process.argv.includes('--check');
23
+ const repoRoot = path.join(__dirname, '..');
24
+ const skillsRoot = path.join(repoRoot, 'skills');
25
+ const args = process.argv.slice(2);
26
+ const check = args.includes('--check');
27
+
28
+ function getFlag(name) {
29
+ const i = args.indexOf(`--${name}`);
30
+ if (i === -1) return null;
31
+ return args[i + 1] ?? '';
32
+ }
33
+
34
+ const platformsArg = getFlag('platforms');
35
+ const allPlatforms = args.includes('--all-platforms');
36
+
37
+ // All 14 supported platforms
38
+ const PLATFORM_DIRS = {
39
+ 'claude-code': path.join(repoRoot, '.claude', 'skills'),
40
+ 'claude-desktop': path.join(repoRoot, '.claude-desktop', 'skills'),
41
+ cursor: path.join(repoRoot, '.cursor-plugin', 'skills'),
42
+ windsurf: path.join(repoRoot, '.windsurf', 'skills'),
43
+ antigravity: path.join(repoRoot, '.gemini', 'skills'),
44
+ codex: path.join(repoRoot, '.codex', 'skills'),
45
+ opencode: path.join(repoRoot, '.opencode', 'skills'),
46
+ cline: path.join(repoRoot, '.cline', 'skills'),
47
+ kiro: path.join(repoRoot, '.kiro', 'skills'),
48
+ copilot: path.join(repoRoot, '.copilot', 'skills'),
49
+ aider: path.join(repoRoot, '.aider', 'skills'),
50
+ continue: path.join(repoRoot, '.continue', 'skills'),
51
+ 'amazon-q': path.join(repoRoot, '.amazonq', 'skills'),
52
+ amp: path.join(repoRoot, '.amp', 'skills'),
53
+ };
13
54
 
14
55
  function render(tmpl, vars) {
15
56
  return tmpl.replace(/\{\{(\w+)\}\}/g, (_, k) => (vars[k] != null ? String(vars[k]) : `{{${k}}}`));
16
57
  }
17
58
 
18
- let tmplCount = 0;
19
- if (!fs.existsSync(skillsRoot)) process.exit(0);
20
-
21
- for (const dir of fs.readdirSync(skillsRoot, { withFileTypes: true })) {
22
- if (!dir.isDirectory()) continue;
23
- const folder = path.join(skillsRoot, dir.name);
24
- const tmplPath = path.join(folder, 'SKILL.md.tmpl');
25
- const metaPath = path.join(folder, 'meta.json');
26
- const outPath = path.join(folder, 'SKILL.md');
27
- if (!fs.existsSync(tmplPath)) continue;
28
-
29
- tmplCount++;
30
- const tmpl = fs.readFileSync(tmplPath, 'utf8');
31
- let meta = {};
32
- if (fs.existsSync(metaPath)) {
33
- meta = JSON.parse(fs.readFileSync(metaPath, 'utf8'));
59
+ function sha256(buf) {
60
+ return crypto.createHash('sha256').update(buf).digest('hex');
61
+ }
62
+
63
+ function ensureDir(p) {
64
+ fs.mkdirSync(p, { recursive: true });
65
+ }
66
+
67
+ function copyFileIdempotent(src, dst) {
68
+ const srcBuf = fs.readFileSync(src);
69
+ if (fs.existsSync(dst)) {
70
+ const dstBuf = fs.readFileSync(dst);
71
+ if (sha256(srcBuf) === sha256(dstBuf)) return 'skipped';
34
72
  }
35
- const out = render(tmpl, meta);
36
- if (check) {
37
- const cur = fs.existsSync(outPath) ? fs.readFileSync(outPath, 'utf8') : '';
38
- if (cur !== out) {
39
- console.error(`check failed: ${outPath} out of date (run npm run build:skills)`);
40
- process.exit(2);
73
+ if (check) return 'drift';
74
+ ensureDir(path.dirname(dst));
75
+ fs.writeFileSync(dst, srcBuf);
76
+ return 'synced';
77
+ }
78
+
79
+ function copyDirShallow(srcDir, dstDir) {
80
+ const result = { synced: 0, skipped: 0, drift: 0 };
81
+ if (!fs.existsSync(srcDir)) return result;
82
+ ensureDir(dstDir);
83
+
84
+ const skillFile = path.join(srcDir, 'SKILL.md');
85
+ if (fs.existsSync(skillFile)) {
86
+ result[copyFileIdempotent(skillFile, path.join(dstDir, 'SKILL.md'))]++;
87
+ }
88
+
89
+ const refDir = path.join(srcDir, 'references');
90
+ if (fs.existsSync(refDir) && fs.statSync(refDir).isDirectory()) {
91
+ for (const entry of fs.readdirSync(refDir)) {
92
+ const s = path.join(refDir, entry);
93
+ if (fs.statSync(s).isFile()) {
94
+ result[copyFileIdempotent(s, path.join(dstDir, 'references', entry))]++;
95
+ }
96
+ }
97
+ }
98
+ return result;
99
+ }
100
+
101
+ // Copy _shared/ directory recursively
102
+ function copySharedHelpers(srcRoot, dstRoot) {
103
+ const sharedSrc = path.join(srcRoot, '_shared');
104
+ const sharedDst = path.join(dstRoot, '_shared');
105
+ if (!fs.existsSync(sharedSrc)) return { synced: 0, skipped: 0, drift: 0 };
106
+
107
+ const result = { synced: 0, skipped: 0, drift: 0 };
108
+ ensureDir(sharedDst);
109
+
110
+ for (const entry of fs.readdirSync(sharedSrc)) {
111
+ const srcFile = path.join(sharedSrc, entry);
112
+ const dstFile = path.join(sharedDst, entry);
113
+ if (fs.statSync(srcFile).isFile()) {
114
+ result[copyFileIdempotent(srcFile, dstFile)]++;
115
+ }
116
+ }
117
+ return result;
118
+ }
119
+
120
+ // Get ALL cm-* skills from skills/ directory
121
+ function getAllCmSkills() {
122
+ if (!fs.existsSync(skillsRoot)) return [];
123
+ return fs.readdirSync(skillsRoot, { withFileTypes: true })
124
+ .filter(d => d.isDirectory() && d.name.startsWith('cm-'))
125
+ .map(d => d.name);
126
+ }
127
+
128
+ // --- Mode 1: template render ---
129
+ let tmplCount = 0;
130
+ if (fs.existsSync(skillsRoot)) {
131
+ for (const dir of fs.readdirSync(skillsRoot, { withFileTypes: true })) {
132
+ if (!dir.isDirectory()) continue;
133
+ const folder = path.join(skillsRoot, dir.name);
134
+ const tmplPath = path.join(folder, 'SKILL.md.tmpl');
135
+ const metaPath = path.join(folder, 'meta.json');
136
+ const outPath = path.join(folder, 'SKILL.md');
137
+ if (!fs.existsSync(tmplPath)) continue;
138
+
139
+ tmplCount++;
140
+ const tmpl = fs.readFileSync(tmplPath, 'utf8');
141
+ let meta = {};
142
+ if (fs.existsSync(metaPath)) {
143
+ meta = JSON.parse(fs.readFileSync(metaPath, 'utf8'));
144
+ }
145
+ const out = render(tmpl, meta);
146
+ if (check) {
147
+ const cur = fs.existsSync(outPath) ? fs.readFileSync(outPath, 'utf8') : '';
148
+ if (cur !== out) {
149
+ console.error(`check failed: ${outPath} out of date (run npm run build:skills)`);
150
+ process.exit(2);
151
+ }
152
+ } else {
153
+ fs.writeFileSync(outPath, out, 'utf8');
41
154
  }
42
- } else {
43
- fs.writeFileSync(outPath, out, 'utf8');
44
155
  }
45
156
  }
46
157
 
@@ -49,3 +160,51 @@ if (tmplCount === 0) {
49
160
  } else {
50
161
  console.log(check ? `build-skills: --check OK (${tmplCount})` : `build-skills: wrote ${tmplCount} skill(s)`);
51
162
  }
163
+
164
+ // --- Mode 2: multi-platform sync ---
165
+ let platforms = [];
166
+ if (allPlatforms) platforms = Object.keys(PLATFORM_DIRS);
167
+ else if (platformsArg) {
168
+ platforms = platformsArg.split(',').map(s => s.trim()).filter(Boolean);
169
+ }
170
+
171
+ if (platforms.length > 0) {
172
+ // Get ALL cm-* skills (not just top 35)
173
+ const list = getAllCmSkills();
174
+ console.log(`build-skills: found ${list.length} cm-* skills to sync`);
175
+
176
+ for (const platform of platforms) {
177
+ const dst = PLATFORM_DIRS[platform];
178
+ if (!dst) {
179
+ console.error(`build-skills: unknown platform '${platform}' (valid: ${Object.keys(PLATFORM_DIRS).join(',')})`);
180
+ process.exit(2);
181
+ }
182
+
183
+ let synced = 0, skipped = 0, drift = 0, missing = 0;
184
+
185
+ // Sync _shared/ helpers
186
+ const sharedResult = copySharedHelpers(skillsRoot, dst);
187
+ synced += sharedResult.synced;
188
+ skipped += sharedResult.skipped;
189
+ drift += sharedResult.drift;
190
+
191
+ // Sync ALL cm-* skills
192
+ for (const name of list) {
193
+ const srcDir = path.join(skillsRoot, name);
194
+ if (!fs.existsSync(srcDir)) {
195
+ missing++;
196
+ console.warn(` ! ${platform}: skill '${name}' not found in skills/`);
197
+ continue;
198
+ }
199
+ const r = copyDirShallow(srcDir, path.join(dst, name));
200
+ synced += r.synced; skipped += r.skipped; drift += r.drift;
201
+ }
202
+
203
+ if (check && drift > 0) {
204
+ console.error(`build-skills: --check FAILED for ${platform} (drift=${drift})`);
205
+ process.exit(2);
206
+ }
207
+ const tag = check ? 'check' : 'sync';
208
+ console.log(`build-skills[${platform}] ${tag}: synced=${synced} skipped=${skipped} drift=${drift} missing=${missing} total=${list.length + 1}`);
209
+ }
210
+ }
@@ -0,0 +1,73 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Migrate a skill to v2 compressed format.
4
+ *
5
+ * - Adds frontmatter: `token_budget: <N>`, `compressed: true`, `deprecated: false`
6
+ * - Inserts `## TL;DR` block after the H1 if not present
7
+ * - Preserves the rest of the body verbatim
8
+ *
9
+ * Usage:
10
+ * node scripts/compress-skill.mjs <skill-name> <token_budget> "<tldr-line-1>" "<tldr-line-2>" ...
11
+ *
12
+ * Idempotent: skips skills already marked `compressed: true`.
13
+ */
14
+ import fs from 'fs';
15
+ import path from 'path';
16
+ import { fileURLToPath } from 'url';
17
+
18
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
19
+
20
+ const [, , name, budgetArg, ...tldrLines] = process.argv;
21
+ if (!name || !budgetArg || tldrLines.length === 0) {
22
+ console.error('Usage: compress-skill.mjs <skill-name> <token_budget> "<tldr-1>" ["<tldr-2>" ...]');
23
+ process.exit(1);
24
+ }
25
+ const budget = parseInt(budgetArg, 10);
26
+ if (Number.isNaN(budget) || budget < 100 || budget > 6000) {
27
+ console.error(`token_budget must be int 100..6000, got: ${budgetArg}`);
28
+ process.exit(1);
29
+ }
30
+
31
+ const file = path.join(__dirname, '..', 'skills', name, 'SKILL.md');
32
+ if (!fs.existsSync(file)) {
33
+ console.error(`✗ ${name}: SKILL.md not found`);
34
+ process.exit(1);
35
+ }
36
+
37
+ const original = fs.readFileSync(file, 'utf8');
38
+ if (/^compressed:\s*true/m.test(original)) {
39
+ console.log(`• ${name}: already compressed, skipping`);
40
+ process.exit(0);
41
+ }
42
+
43
+ const fmMatch = original.match(/^---\n([\s\S]*?)\n---\n([\s\S]*)$/);
44
+ if (!fmMatch) {
45
+ console.error(`✗ ${name}: missing YAML frontmatter`);
46
+ process.exit(1);
47
+ }
48
+ let fmText = fmMatch[1];
49
+ const body = fmMatch[2];
50
+
51
+ // Append fields if missing.
52
+ if (!/^token_budget:/m.test(fmText)) fmText += `\ntoken_budget: ${budget}`;
53
+ if (!/^compressed:/m.test(fmText)) fmText += `\ncompressed: true`;
54
+ if (!/^deprecated:/m.test(fmText)) fmText += `\ndeprecated: false`;
55
+
56
+ // Insert ## TL;DR after the H1 if absent.
57
+ let newBody = body;
58
+ if (!/^##\s+TL;DR\b/m.test(body)) {
59
+ const h1 = body.match(/^(#\s+[^\n]+\n)/m);
60
+ if (!h1) {
61
+ console.error(`✗ ${name}: missing H1`);
62
+ process.exit(1);
63
+ }
64
+ const tldrBlock =
65
+ `\n## TL;DR\n` +
66
+ tldrLines.map((l) => `- ${l}`).join('\n') +
67
+ `\n`;
68
+ newBody = body.replace(h1[0], h1[0] + tldrBlock);
69
+ }
70
+
71
+ const out = `---\n${fmText}\n---\n${newBody}`;
72
+ fs.writeFileSync(file, out, 'utf8');
73
+ console.log(`✓ ${name}: compressed (budget=${budget})`);
@@ -0,0 +1,72 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Deprecate a skill: archives original SKILL.md to SKILL.archive.md
4
+ * and replaces SKILL.md with a small redirect stub.
5
+ *
6
+ * Usage:
7
+ * node scripts/deprecate-skill.mjs <skill-name> <merged-into> [reason]
8
+ *
9
+ * Idempotent: skips if SKILL.md already has `deprecated: true`.
10
+ */
11
+ import fs from 'fs';
12
+ import path from 'path';
13
+ import { fileURLToPath } from 'url';
14
+
15
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
16
+
17
+ const [, , name, mergedInto, ...reasonParts] = process.argv;
18
+ if (!name || !mergedInto) {
19
+ console.error('Usage: deprecate-skill.mjs <skill-name> <merged-into> [reason]');
20
+ process.exit(1);
21
+ }
22
+ const reason = reasonParts.join(' ') || `consolidated into ${mergedInto}`;
23
+
24
+ const dir = path.join(__dirname, '..', 'skills', name);
25
+ const file = path.join(dir, 'SKILL.md');
26
+ const archive = path.join(dir, 'SKILL.archive.md');
27
+
28
+ if (!fs.existsSync(file)) {
29
+ console.error(`✗ ${name}: SKILL.md not found`);
30
+ process.exit(1);
31
+ }
32
+
33
+ const original = fs.readFileSync(file, 'utf8');
34
+ if (/^deprecated:\s*true/m.test(original)) {
35
+ console.log(`• ${name}: already deprecated, skipping`);
36
+ process.exit(0);
37
+ }
38
+
39
+ if (!fs.existsSync(archive)) {
40
+ fs.writeFileSync(archive, original, 'utf8');
41
+ }
42
+
43
+ const stub = `---
44
+ name: ${name}
45
+ description: "[Deprecated] ${reason}. Use \`${mergedInto}\` instead."
46
+ deprecated: true
47
+ merged_into: ${mergedInto}
48
+ ---
49
+
50
+ # ${name} — Deprecated
51
+
52
+ > ⚠️ This skill is deprecated as of CodyMaster v6.0.0 and will be removed in v6.1.0.
53
+ >
54
+ > **Use \`${mergedInto}\` instead.** ${reason}.
55
+ >
56
+ > See [docs/migration-v2.md](../../docs/migration-v2.md) for the full mapping.
57
+
58
+ The original content is preserved at [SKILL.archive.md](SKILL.archive.md) for reference.
59
+
60
+ ## Migration
61
+
62
+ \`\`\`bash
63
+ # Old: cm <use this skill>
64
+ # New (v6.0+): cm ${mergedInto.replace(/^cm-/, '')} <equivalent action>
65
+ \`\`\`
66
+
67
+ If you depend on a capability that didn't carry over, please file an issue:
68
+ https://github.com/tody-agent/codymaster/issues
69
+ `;
70
+
71
+ fs.writeFileSync(file, stub, 'utf8');
72
+ console.log(`✓ ${name} → deprecated, redirects to ${mergedInto}`);