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,160 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.registerInstallCommands = registerInstallCommands;
16
+ const chalk_1 = __importDefault(require("chalk"));
17
+ const child_process_1 = require("child_process");
18
+ const path_1 = __importDefault(require("path"));
19
+ const fs_1 = __importDefault(require("fs"));
20
+ const engine_1 = require("../../install/engine");
21
+ const profiles_1 = require("../../install/profiles");
22
+ const repoRoot = path_1.default.join(__dirname, '..', '..', '..');
23
+ function registerInstallCommands(program) {
24
+ program
25
+ .command('install [platform]')
26
+ .description('Install CodyMaster skills to an AI coding platform')
27
+ .option('-p, --profile <name>', 'Skill profile: core | growth | design | knowledge | full', 'full')
28
+ .option('-s, --scope <scope>', 'Install scope for platforms that support it: user | project', 'user')
29
+ .option('--all', 'Install to every detected platform')
30
+ .option('--list', 'List supported platforms and exit')
31
+ .option('--sync', 'Sync skills to all platforms after install')
32
+ .option('--dry-run', 'Show what would change without writing any files')
33
+ .action((platform, opts) => __awaiter(this, void 0, void 0, function* () {
34
+ if (opts.list)
35
+ return printPlatforms();
36
+ const profile = String(opts.profile);
37
+ if (!(0, profiles_1.isValidProfile)(profile)) {
38
+ console.error(chalk_1.default.red(`Invalid profile: ${profile}`));
39
+ console.error(chalk_1.default.dim('Valid: core, growth, design, knowledge, full'));
40
+ process.exit(1);
41
+ }
42
+ if (opts.scope !== 'user' && opts.scope !== 'project') {
43
+ console.error(chalk_1.default.red(`Invalid scope: ${opts.scope} (expected user|project)`));
44
+ process.exit(1);
45
+ }
46
+ const installOpts = {
47
+ profile: profile,
48
+ scope: opts.scope,
49
+ dryRun: !!opts.dryRun,
50
+ };
51
+ let targets;
52
+ if (opts.all) {
53
+ targets = (0, engine_1.detectPlatforms)()
54
+ .filter((p) => p.installed)
55
+ .map((p) => p.platform.id);
56
+ if (targets.length === 0) {
57
+ console.error(chalk_1.default.red('No installed AI platforms detected.'));
58
+ console.error(chalk_1.default.dim("Pass a platform id explicitly: cm install claude-code"));
59
+ process.exit(1);
60
+ }
61
+ }
62
+ else if (platform) {
63
+ targets = [platform];
64
+ }
65
+ else {
66
+ printPlatforms();
67
+ console.log(chalk_1.default.dim('\nUsage: cm install <platform> [--profile core] [--scope user|project]'));
68
+ return;
69
+ }
70
+ console.log(chalk_1.default.bold(`\nInstalling profile=${profile} scope=${opts.scope}${opts.dryRun ? ' (dry-run)' : ''}`));
71
+ const results = yield (0, engine_1.installToMany)(targets, installOpts);
72
+ for (const r of results) {
73
+ console.log('');
74
+ console.log(chalk_1.default.bold.magenta(` ${r.platform}`));
75
+ console.log(chalk_1.default.dim(` → ${r.targetPath}`));
76
+ console.log(chalk_1.default.green(` ✓ ${r.installed.length} skills installed`) + chalk_1.default.dim(` (${r.skipped.length} skipped)`));
77
+ for (const h of r.postInstallHints)
78
+ console.log(chalk_1.default.cyan(` ℹ ${h}`));
79
+ }
80
+ // Auto-sync if --sync flag or --all flag
81
+ if ((opts.sync || opts.all) && !opts.dryRun) {
82
+ console.log(chalk_1.default.bold('\n Syncing skills to all platforms...'));
83
+ try {
84
+ (0, child_process_1.execSync)('node scripts/build-skills.mjs --all-platforms', {
85
+ stdio: 'inherit',
86
+ cwd: repoRoot,
87
+ timeout: 60000,
88
+ });
89
+ console.log(chalk_1.default.green(' ✅ Skills synced to all platforms'));
90
+ }
91
+ catch (error) {
92
+ console.log(chalk_1.default.yellow(' ⚠️ Sync failed (run `cm update --sync` manually)'));
93
+ }
94
+ }
95
+ console.log('');
96
+ }));
97
+ // ─── Doctor Command ─────────────────────────────────────────
98
+ program
99
+ .command('doctor')
100
+ .description('Check which AI platforms are installed and which have CodyMaster skills')
101
+ .option('--sync-check', 'Check skill sync status across platforms')
102
+ .action((opts) => {
103
+ console.log(chalk_1.default.bold('\nDetected platforms:\n'));
104
+ for (const d of (0, engine_1.detectPlatforms)()) {
105
+ const mark = d.installed ? chalk_1.default.green('●') : chalk_1.default.dim('○');
106
+ const detail = d.detail ? chalk_1.default.dim(` (${d.detail})`) : '';
107
+ console.log(` ${mark} ${d.platform.emoji} ${d.platform.name}${detail}`);
108
+ }
109
+ // Sync check
110
+ if (opts.syncCheck) {
111
+ console.log(chalk_1.default.bold('\n Sync Status:\n'));
112
+ checkSyncStatus();
113
+ }
114
+ console.log('');
115
+ });
116
+ }
117
+ function checkSyncStatus() {
118
+ const platforms = [
119
+ { name: 'claude-code', dir: '.claude/skills' },
120
+ { name: 'claude-desktop', dir: '.claude-desktop/skills' },
121
+ { name: 'cursor', dir: '.cursor-plugin/skills' },
122
+ { name: 'windsurf', dir: '.windsurf/skills' },
123
+ { name: 'antigravity', dir: '.gemini/skills' },
124
+ { name: 'codex', dir: '.codex/skills' },
125
+ { name: 'opencode', dir: '.opencode/skills' },
126
+ { name: 'cline', dir: '.cline/skills' },
127
+ { name: 'kiro', dir: '.kiro/skills' },
128
+ { name: 'copilot', dir: '.copilot/skills' },
129
+ { name: 'aider', dir: '.aider/skills' },
130
+ { name: 'continue', dir: '.continue/skills' },
131
+ { name: 'amazon-q', dir: '.amazonq/skills' },
132
+ { name: 'amp', dir: '.amp/skills' },
133
+ ];
134
+ let synced = 0;
135
+ let missing = 0;
136
+ for (const p of platforms) {
137
+ const fullPath = path_1.default.join(repoRoot, p.dir);
138
+ const hasShared = fs_1.default.existsSync(path_1.default.join(fullPath, '_shared', 'helpers.md'));
139
+ if (hasShared) {
140
+ synced++;
141
+ }
142
+ else {
143
+ missing++;
144
+ console.log(chalk_1.default.yellow(` ⚠ ${p.name}: _shared/helpers.md missing`));
145
+ }
146
+ }
147
+ if (missing === 0) {
148
+ console.log(chalk_1.default.green(` ✅ All ${synced} platforms synced`));
149
+ }
150
+ else {
151
+ console.log(chalk_1.default.dim(` ${synced} synced, ${missing} missing`));
152
+ console.log(chalk_1.default.dim(' Run `cm update --sync` to fix.'));
153
+ }
154
+ }
155
+ function printPlatforms() {
156
+ console.log(chalk_1.default.bold('\nSupported platforms:\n'));
157
+ for (const p of (0, engine_1.listPlatforms)()) {
158
+ console.log(` ${p.emoji} ${chalk_1.default.cyan(p.id.padEnd(16))} ${chalk_1.default.dim(p.name)}`);
159
+ }
160
+ }
@@ -0,0 +1,181 @@
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.syncLearnings = syncLearnings;
7
+ exports.registerLearnCommands = registerLearnCommands;
8
+ const chalk_1 = __importDefault(require("chalk"));
9
+ const path_1 = __importDefault(require("path"));
10
+ const os_1 = __importDefault(require("os"));
11
+ const fs_1 = __importDefault(require("fs"));
12
+ const child_process_1 = require("child_process");
13
+ const learnings_1 = require("../../learnings");
14
+ const VALID_TYPES = ['pitfall', 'preference', 'pattern', 'fact'];
15
+ function resolveProject(opts) {
16
+ var _a;
17
+ return path_1.default.resolve((_a = opts.project) !== null && _a !== void 0 ? _a : process.cwd());
18
+ }
19
+ function git(cwd, args) {
20
+ return (0, child_process_1.execFileSync)('git', args, { cwd, encoding: 'utf8', stdio: ['ignore', 'pipe', 'pipe'] });
21
+ }
22
+ function syncLearnings(projectPath, opts) {
23
+ var _a;
24
+ const syncDir = (_a = opts.syncDir) !== null && _a !== void 0 ? _a : path_1.default.join(os_1.default.homedir(), '.cm', 'learnings-sync');
25
+ const remoteFile = path_1.default.join(syncDir, 'learnings.jsonl');
26
+ if (!fs_1.default.existsSync(path_1.default.join(syncDir, '.git'))) {
27
+ fs_1.default.mkdirSync(path_1.default.dirname(syncDir), { recursive: true });
28
+ if (fs_1.default.existsSync(syncDir)) {
29
+ // Existing non-git dir — abort rather than wipe.
30
+ throw new Error(`${syncDir} exists but is not a git checkout`);
31
+ }
32
+ git(path_1.default.dirname(syncDir), ['clone', opts.remote, path_1.default.basename(syncDir)]);
33
+ // Ensure a local identity exists so commits succeed even when the host
34
+ // has no global git config (CI runners, fresh containers).
35
+ try {
36
+ git(syncDir, ['config', 'user.email', 'cm-learn-sync@codymaster.local']);
37
+ }
38
+ catch (_b) { }
39
+ try {
40
+ git(syncDir, ['config', 'user.name', 'cm-learn-sync']);
41
+ }
42
+ catch (_c) { }
43
+ }
44
+ else {
45
+ // Make sure we point at the requested remote, then refresh.
46
+ try {
47
+ git(syncDir, ['remote', 'set-url', 'origin', opts.remote]);
48
+ }
49
+ catch (_d) {
50
+ git(syncDir, ['remote', 'add', 'origin', opts.remote]);
51
+ }
52
+ try {
53
+ git(syncDir, ['pull', '--ff-only', 'origin', 'HEAD']);
54
+ }
55
+ catch (_e) {
56
+ // Empty repo / unborn HEAD — ignore; nothing to pull.
57
+ }
58
+ }
59
+ const localFile = (0, learnings_1.learningsPath)(projectPath);
60
+ const localBefore = (0, learnings_1.readLearningsFile)(localFile);
61
+ const remoteBefore = (0, learnings_1.readLearningsFile)(remoteFile);
62
+ const merged = (0, learnings_1.mergeLearnings)(localBefore, remoteBefore);
63
+ // Local: write merged set verbatim (keeps full fidelity for the user).
64
+ (0, learnings_1.writeLearningsFile)(localFile, merged);
65
+ const pulled = merged.length - localBefore.length;
66
+ if (opts.pullOnly) {
67
+ return { pulled, pushed: 0, localTotal: merged.length };
68
+ }
69
+ // Remote: write anonymized merge.
70
+ const anonMerged = (0, learnings_1.mergeLearnings)(remoteBefore, localBefore.map(learnings_1.anonymize));
71
+ (0, learnings_1.writeLearningsFile)(remoteFile, anonMerged);
72
+ const pushed = anonMerged.length - remoteBefore.length;
73
+ if (pushed > 0) {
74
+ git(syncDir, ['add', 'learnings.jsonl']);
75
+ try {
76
+ git(syncDir, ['commit', '-m', `learn: +${pushed} from ${path_1.default.basename(projectPath)}`]);
77
+ git(syncDir, ['push', 'origin', 'HEAD']);
78
+ }
79
+ catch (e) {
80
+ // Bubble up so the caller can decide; non-zero pushes left in local mirror are fine.
81
+ throw new Error(`git push failed: ${e.message}`);
82
+ }
83
+ }
84
+ return { pulled, pushed, localTotal: merged.length };
85
+ }
86
+ function registerLearnCommands(program) {
87
+ program
88
+ .command('learn <cmd> [args...]')
89
+ .description('Per-project learnings log (.cm/learnings.jsonl) — gstack-style notes')
90
+ .option('-p, --project <path>', 'Project path (default: cwd)')
91
+ .option('-t, --type <type>', 'pitfall | preference | pattern | fact', 'fact')
92
+ .option('-s, --scope <scope>', 'Scope tag (deploy, ui, test, ...)', 'general')
93
+ .option('--source <source>', 'Origin label (e.g. cm-retro-cli)', 'manual')
94
+ .option('--days <n>', 'For prune: max age in days', '180')
95
+ .option('--limit <n>', 'For list: max rows', '20')
96
+ .option('--filter-type <type>', 'For list: filter by type')
97
+ .option('--filter-scope <scope>', 'For list: filter by scope')
98
+ .option('--remote <url>', 'For sync: git remote URL of the shared learnings repo')
99
+ .option('--pull-only', 'For sync: pull + merge only, do not push back')
100
+ .option('--sync-dir <path>', 'For sync: working dir (default: ~/.cm/learnings-sync)')
101
+ .action((cmd, args, opts) => {
102
+ const project = resolveProject(opts);
103
+ switch (cmd) {
104
+ case 'add': {
105
+ const note = args.join(' ').trim();
106
+ if (!note) {
107
+ console.error(chalk_1.default.red('Usage: cm learn add "<note>" [--type ... --scope ...]'));
108
+ process.exitCode = 1;
109
+ return;
110
+ }
111
+ if (!VALID_TYPES.includes(opts.type)) {
112
+ console.error(chalk_1.default.red(`Invalid --type. Use one of: ${VALID_TYPES.join(', ')}`));
113
+ process.exitCode = 1;
114
+ return;
115
+ }
116
+ try {
117
+ const l = (0, learnings_1.addLearning)(project, {
118
+ type: opts.type,
119
+ scope: opts.scope,
120
+ note,
121
+ source: opts.source,
122
+ });
123
+ console.log(chalk_1.default.green(`✓ Learned [${l.type}/${l.scope}]: ${l.note}`));
124
+ }
125
+ catch (e) {
126
+ console.error(chalk_1.default.red(`✗ ${e.message}`));
127
+ process.exitCode = 1;
128
+ }
129
+ return;
130
+ }
131
+ case 'list':
132
+ case 'ls': {
133
+ const items = (0, learnings_1.listLearnings)(project, {
134
+ limit: parseInt(opts.limit, 10),
135
+ type: opts.filterType,
136
+ scope: opts.filterScope,
137
+ });
138
+ if (items.length === 0) {
139
+ console.log(chalk_1.default.dim('(no learnings yet)'));
140
+ return;
141
+ }
142
+ for (const l of items) {
143
+ const date = l.ts.slice(0, 10);
144
+ console.log(`${chalk_1.default.gray(date)} ${chalk_1.default.cyan(l.type.padEnd(10))} ${chalk_1.default.yellow(l.scope.padEnd(12))} ${l.note}`);
145
+ }
146
+ console.log(chalk_1.default.dim(`\n${items.length} learning(s)`));
147
+ return;
148
+ }
149
+ case 'prune': {
150
+ const days = parseInt(opts.days, 10);
151
+ const n = (0, learnings_1.pruneLearnings)(project, days);
152
+ console.log(chalk_1.default.green(`✓ Pruned ${n} learning(s) older than ${days} days`));
153
+ return;
154
+ }
155
+ case 'sync': {
156
+ if (!opts.remote) {
157
+ console.error(chalk_1.default.red('Usage: cm learn sync --remote <git-url> [--pull-only]'));
158
+ process.exitCode = 1;
159
+ return;
160
+ }
161
+ try {
162
+ const result = syncLearnings(project, {
163
+ remote: opts.remote,
164
+ pullOnly: !!opts.pullOnly,
165
+ syncDir: opts.syncDir,
166
+ });
167
+ console.log(chalk_1.default.green(`✓ sync ok — pulled=${result.pulled} pushed=${result.pushed} local=${result.localTotal}`));
168
+ }
169
+ catch (e) {
170
+ console.error(chalk_1.default.red(`✗ sync failed: ${e.message}`));
171
+ process.exitCode = 1;
172
+ }
173
+ return;
174
+ }
175
+ default:
176
+ console.error(chalk_1.default.red(`Unknown subcommand: ${cmd}`));
177
+ console.log(chalk_1.default.dim('Available: add, list, prune, sync'));
178
+ process.exitCode = 1;
179
+ }
180
+ });
181
+ }
@@ -0,0 +1,104 @@
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.registerMcpServeCommands = registerMcpServeCommands;
7
+ const child_process_1 = require("child_process");
8
+ const path_1 = __importDefault(require("path"));
9
+ const fs_1 = __importDefault(require("fs"));
10
+ const os_1 = __importDefault(require("os"));
11
+ const chalk_1 = __importDefault(require("chalk"));
12
+ function registerMcpServeCommands(program) {
13
+ program
14
+ .command('mcp-serve')
15
+ .description('Start CodyMaster MCP context server (stdio transport for Goose, Claude Desktop, etc.)')
16
+ .option('--project <path>', 'Project root directory (default: current working directory)')
17
+ .option('--print-config', 'Print Goose/Claude Desktop JSON config snippet and exit')
18
+ .option('--install-claude', 'Auto-install MCP servers into Claude Desktop / Cowork config')
19
+ .action((opts) => {
20
+ var _a;
21
+ const projectPath = path_1.default.resolve((_a = opts.project) !== null && _a !== void 0 ? _a : process.cwd());
22
+ if (opts.installClaude) {
23
+ let configPath = '';
24
+ if (process.platform === 'win32') {
25
+ configPath = path_1.default.join(process.env.APPDATA || '', 'Claude', 'claude_desktop_config.json');
26
+ }
27
+ else if (process.platform === 'darwin') {
28
+ configPath = path_1.default.join(os_1.default.homedir(), 'Library', 'Application Support', 'Claude', 'claude_desktop_config.json');
29
+ }
30
+ else {
31
+ console.error(chalk_1.default.red('Auto-install is currently only supported on Windows and macOS.'));
32
+ process.exit(1);
33
+ }
34
+ let config = {};
35
+ if (fs_1.default.existsSync(configPath)) {
36
+ try {
37
+ config = JSON.parse(fs_1.default.readFileSync(configPath, 'utf8'));
38
+ }
39
+ catch (e) {
40
+ console.error(chalk_1.default.red(`Failed to parse ${configPath}: ${e.message}`));
41
+ process.exit(1);
42
+ }
43
+ }
44
+ if (!config.mcpServers)
45
+ config.mcpServers = {};
46
+ const serverPath = path_1.default.join(__dirname, '..', '..', '..', 'dist', 'mcp-context-server.js');
47
+ const dashboardPath = path_1.default.join(__dirname, '..', '..', '..', 'scripts', 'mcp-bridge.js');
48
+ config.mcpServers['cm-context'] = {
49
+ command: process.execPath,
50
+ args: [serverPath, '--project', projectPath],
51
+ env: { 'CM_PROJECT_PATH': projectPath }
52
+ };
53
+ config.mcpServers['cm-dashboard'] = {
54
+ command: process.execPath,
55
+ args: [dashboardPath]
56
+ };
57
+ const configDir = path_1.default.dirname(configPath);
58
+ if (!fs_1.default.existsSync(configDir))
59
+ fs_1.default.mkdirSync(configDir, { recursive: true });
60
+ fs_1.default.writeFileSync(configPath, JSON.stringify(config, null, 2), 'utf8');
61
+ console.log(chalk_1.default.green(`🎉 Installed successfully into Claude Desktop: ${configPath}`));
62
+ process.exit(0);
63
+ }
64
+ if (opts.printConfig) {
65
+ const gooseConfig = {
66
+ id: 'codymaster',
67
+ name: 'CodyMaster Intelligence Layer',
68
+ type: 'stdio',
69
+ cmd: 'npx',
70
+ args: ['codymaster', 'mcp-serve', '--project', projectPath],
71
+ };
72
+ const claudeConfig = {
73
+ mcpServers: {
74
+ 'cm-context': {
75
+ command: process.execPath,
76
+ args: [
77
+ path_1.default.join(__dirname, '..', '..', '..', 'dist', 'mcp-context-server.js'),
78
+ '--project',
79
+ projectPath,
80
+ ],
81
+ },
82
+ },
83
+ };
84
+ console.log(chalk_1.default.bold('\nGoose config (add to ~/.config/goose/config.yaml extensions):'));
85
+ console.log(JSON.stringify(gooseConfig, null, 2));
86
+ console.log(chalk_1.default.bold('\nClaude Desktop config (add to mcpServers in claude_desktop_config.json):'));
87
+ console.log(JSON.stringify(claudeConfig.mcpServers, null, 2));
88
+ process.exit(0);
89
+ }
90
+ const serverPath = path_1.default.join(__dirname, '..', '..', '..', 'dist', 'mcp-context-server.js');
91
+ if (!fs_1.default.existsSync(serverPath)) {
92
+ console.error(chalk_1.default.red(`Error: MCP server not found at ${serverPath}`));
93
+ console.error(chalk_1.default.yellow('Run `npm run build` first to compile the server.'));
94
+ process.exit(1);
95
+ }
96
+ console.error(chalk_1.default.dim(`[CodyMaster] Starting MCP server for project: ${projectPath}`));
97
+ const child = (0, child_process_1.spawn)(process.execPath, [serverPath, '--project', projectPath], {
98
+ stdio: 'inherit',
99
+ });
100
+ child.on('exit', (code) => process.exit(code !== null && code !== void 0 ? code : 0));
101
+ process.on('SIGINT', () => child.kill('SIGINT'));
102
+ process.on('SIGTERM', () => child.kill('SIGTERM'));
103
+ });
104
+ }
@@ -0,0 +1,138 @@
1
+ "use strict";
2
+ /**
3
+ * cm parallel — Execute tasks in parallel using Gemini CLI
4
+ *
5
+ * TRIZ Principle #1 (Segmentation):
6
+ * Split task into independent subtasks, run in parallel.
7
+ *
8
+ * TRIZ Principle #15 (Dynamicity):
9
+ * Adapt batch size based on task complexity.
10
+ */
11
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
12
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
13
+ return new (P || (P = Promise))(function (resolve, reject) {
14
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
15
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
16
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
17
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
18
+ });
19
+ };
20
+ var __importDefault = (this && this.__importDefault) || function (mod) {
21
+ return (mod && mod.__esModule) ? mod : { "default": mod };
22
+ };
23
+ Object.defineProperty(exports, "__esModule", { value: true });
24
+ exports.registerParallelCommands = registerParallelCommands;
25
+ const child_process_1 = require("child_process");
26
+ const chalk_1 = __importDefault(require("chalk"));
27
+ const box_1 = require("../../ui/box");
28
+ function registerParallelCommands(program) {
29
+ program
30
+ .command('parallel <task>')
31
+ .description('Execute task in parallel using Gemini CLI')
32
+ .option('-n, --count <n>', 'Number of parallel instances', '3')
33
+ .option('-c, --context <files>', 'Context files to include (comma-separated)')
34
+ .option('-m, --model <model>', 'Gemini model to use', 'gemini-2.0-flash')
35
+ .option('--timeout <ms>', 'Timeout per instance in milliseconds', '120000')
36
+ .action((task, opts) => __awaiter(this, void 0, void 0, function* () {
37
+ const count = parseInt(opts.count, 10);
38
+ const timeout = parseInt(opts.timeout, 10);
39
+ console.log((0, box_1.renderCommandHeader)('Parallel Execution', '⚡'));
40
+ console.log(chalk_1.default.dim(` Task: ${task}`));
41
+ console.log(chalk_1.default.dim(` Instances: ${count}`));
42
+ console.log(chalk_1.default.dim(` Model: ${opts.model}`));
43
+ console.log('');
44
+ // Check if gemini CLI is available
45
+ const geminiAvailable = yield checkGeminiCli();
46
+ if (!geminiAvailable) {
47
+ console.log(chalk_1.default.yellow('⚠ Gemini CLI not found. Falling back to single-agent execution.'));
48
+ console.log(chalk_1.default.dim('Install: npm install -g @anthropic-ai/gemini-cli'));
49
+ console.log('');
50
+ yield executeSingleAgent(task, opts);
51
+ return;
52
+ }
53
+ // Execute in parallel
54
+ const results = yield executeParallel(task, count, opts);
55
+ // Display results
56
+ console.log(chalk_1.default.bold('\n📊 Results:\n'));
57
+ for (const result of results) {
58
+ const status = result.exitCode === 0 ? chalk_1.default.green('✅') : chalk_1.default.red('❌');
59
+ console.log(` ${status} Instance ${result.instance}: exit=${result.exitCode}`);
60
+ if (result.output) {
61
+ console.log(chalk_1.default.dim(` ${result.output.slice(0, 100)}...`));
62
+ }
63
+ }
64
+ // Summary
65
+ const passed = results.filter(r => r.exitCode === 0).length;
66
+ const failed = results.filter(r => r.exitCode !== 0).length;
67
+ console.log('');
68
+ console.log(chalk_1.default.bold(` Summary: ${chalk_1.default.green(`${passed} passed`)} / ${chalk_1.default.red(`${failed} failed`)}`));
69
+ }));
70
+ }
71
+ function checkGeminiCli() {
72
+ return __awaiter(this, void 0, void 0, function* () {
73
+ return new Promise((resolve) => {
74
+ const proc = (0, child_process_1.spawn)('which', ['gemini'], { stdio: 'pipe' });
75
+ proc.on('close', (code) => resolve(code === 0));
76
+ proc.on('error', () => resolve(false));
77
+ });
78
+ });
79
+ }
80
+ function executeParallel(task, count, opts) {
81
+ return __awaiter(this, void 0, void 0, function* () {
82
+ const results = [];
83
+ const promises = [];
84
+ for (let i = 1; i <= count; i++) {
85
+ promises.push(executeInstance(task, i, opts));
86
+ }
87
+ return Promise.all(promises);
88
+ });
89
+ }
90
+ function executeInstance(task, instance, opts) {
91
+ return __awaiter(this, void 0, void 0, function* () {
92
+ return new Promise((resolve) => {
93
+ const args = [
94
+ '-p', `Instance ${instance}: ${task}`,
95
+ '--model', opts.model,
96
+ ];
97
+ if (opts.context) {
98
+ args.push('--context', opts.context);
99
+ }
100
+ const proc = (0, child_process_1.spawn)('gemini', args, {
101
+ stdio: ['pipe', 'pipe', 'pipe'],
102
+ timeout: parseInt(opts.timeout, 10),
103
+ });
104
+ let output = '';
105
+ let error = '';
106
+ proc.stdout.on('data', (data) => {
107
+ output += data.toString();
108
+ });
109
+ proc.stderr.on('data', (data) => {
110
+ error += data.toString();
111
+ });
112
+ proc.on('close', (code) => {
113
+ resolve({
114
+ instance,
115
+ exitCode: code,
116
+ output: output.trim(),
117
+ error: error.trim(),
118
+ });
119
+ });
120
+ proc.on('error', (err) => {
121
+ resolve({
122
+ instance,
123
+ exitCode: 1,
124
+ output: '',
125
+ error: err.message,
126
+ });
127
+ });
128
+ });
129
+ });
130
+ }
131
+ function executeSingleAgent(task, opts) {
132
+ return __awaiter(this, void 0, void 0, function* () {
133
+ console.log(chalk_1.default.dim(' Executing with single agent...'));
134
+ // Fallback: just print the task for the AI agent to handle
135
+ console.log(chalk_1.default.bold(` Task: ${task}`));
136
+ console.log(chalk_1.default.dim(' (Single-agent mode — use Gemini CLI for parallel execution)'));
137
+ });
138
+ }