macro-agent 0.1.1 → 0.1.2

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 (406) hide show
  1. package/.sudocode/issues.jsonl +28 -0
  2. package/.sudocode/specs.jsonl +4 -0
  3. package/CLAUDE.md +9 -3
  4. package/dist/agent/agent-manager.d.ts.map +1 -1
  5. package/dist/agent/agent-manager.js +111 -48
  6. package/dist/agent/agent-manager.js.map +1 -1
  7. package/dist/agent/types.d.ts +7 -0
  8. package/dist/agent/types.d.ts.map +1 -1
  9. package/dist/agent/types.js.map +1 -1
  10. package/dist/api/server.d.ts +5 -1
  11. package/dist/api/server.d.ts.map +1 -1
  12. package/dist/api/server.js +100 -3
  13. package/dist/api/server.js.map +1 -1
  14. package/dist/api/types.d.ts +1 -1
  15. package/dist/api/types.d.ts.map +1 -1
  16. package/dist/cli/acp.d.ts.map +1 -1
  17. package/dist/cli/acp.js +71 -1
  18. package/dist/cli/acp.js.map +1 -1
  19. package/dist/cli/index.js +5 -1
  20. package/dist/cli/index.js.map +1 -1
  21. package/dist/cli/mcp.js +27 -8
  22. package/dist/cli/mcp.js.map +1 -1
  23. package/dist/config/project-config.d.ts +13 -2
  24. package/dist/config/project-config.d.ts.map +1 -1
  25. package/dist/config/project-config.js +12 -2
  26. package/dist/config/project-config.js.map +1 -1
  27. package/dist/index.d.ts +1 -0
  28. package/dist/index.d.ts.map +1 -1
  29. package/dist/index.js +2 -0
  30. package/dist/index.js.map +1 -1
  31. package/dist/lifecycle/handlers/index.d.ts +7 -3
  32. package/dist/lifecycle/handlers/index.d.ts.map +1 -1
  33. package/dist/lifecycle/handlers/index.js +25 -8
  34. package/dist/lifecycle/handlers/index.js.map +1 -1
  35. package/dist/lifecycle/types.d.ts +2 -0
  36. package/dist/lifecycle/types.d.ts.map +1 -1
  37. package/dist/lifecycle/types.js.map +1 -1
  38. package/dist/map/adapter/extensions/index.d.ts +4 -1
  39. package/dist/map/adapter/extensions/index.d.ts.map +1 -1
  40. package/dist/map/adapter/extensions/index.js +27 -0
  41. package/dist/map/adapter/extensions/index.js.map +1 -1
  42. package/dist/map/adapter/extensions/streams.d.ts +95 -0
  43. package/dist/map/adapter/extensions/streams.d.ts.map +1 -0
  44. package/dist/map/adapter/extensions/streams.js +515 -0
  45. package/dist/map/adapter/extensions/streams.js.map +1 -0
  46. package/dist/map/adapter/index.d.ts +1 -1
  47. package/dist/map/adapter/index.d.ts.map +1 -1
  48. package/dist/map/adapter/index.js +3 -1
  49. package/dist/map/adapter/index.js.map +1 -1
  50. package/dist/map/adapter/types.d.ts +1 -1
  51. package/dist/map/adapter/types.d.ts.map +1 -1
  52. package/dist/mcp/mcp-server.d.ts +2 -0
  53. package/dist/mcp/mcp-server.d.ts.map +1 -1
  54. package/dist/mcp/mcp-server.js +12 -3
  55. package/dist/mcp/mcp-server.js.map +1 -1
  56. package/dist/mcp/tools/done.d.ts.map +1 -1
  57. package/dist/mcp/tools/done.js +18 -0
  58. package/dist/mcp/tools/done.js.map +1 -1
  59. package/dist/roles/builtin/coordinator.d.ts.map +1 -1
  60. package/dist/roles/builtin/coordinator.js +2 -1
  61. package/dist/roles/builtin/coordinator.js.map +1 -1
  62. package/dist/roles/builtin/integrator.d.ts.map +1 -1
  63. package/dist/roles/builtin/integrator.js +2 -1
  64. package/dist/roles/builtin/integrator.js.map +1 -1
  65. package/dist/roles/builtin/worker.d.ts.map +1 -1
  66. package/dist/roles/builtin/worker.js +3 -1
  67. package/dist/roles/builtin/worker.js.map +1 -1
  68. package/dist/roles/capabilities.d.ts +6 -0
  69. package/dist/roles/capabilities.d.ts.map +1 -1
  70. package/dist/roles/capabilities.js +10 -0
  71. package/dist/roles/capabilities.js.map +1 -1
  72. package/dist/roles/config-loader.d.ts +1 -1
  73. package/dist/roles/config-loader.d.ts.map +1 -1
  74. package/dist/roles/config-loader.js +3 -2
  75. package/dist/roles/config-loader.js.map +1 -1
  76. package/dist/roles/types.d.ts +3 -1
  77. package/dist/roles/types.d.ts.map +1 -1
  78. package/dist/server/combined-server.d.ts +8 -1
  79. package/dist/server/combined-server.d.ts.map +1 -1
  80. package/dist/server/combined-server.js +6 -2
  81. package/dist/server/combined-server.js.map +1 -1
  82. package/dist/store/event-store.d.ts.map +1 -1
  83. package/dist/store/event-store.js +12 -5
  84. package/dist/store/event-store.js.map +1 -1
  85. package/dist/store/instance.d.ts +1 -1
  86. package/dist/store/instance.d.ts.map +1 -1
  87. package/dist/store/instance.js +2 -2
  88. package/dist/store/instance.js.map +1 -1
  89. package/dist/store/types/agents.d.ts +5 -0
  90. package/dist/store/types/agents.d.ts.map +1 -1
  91. package/dist/task/backend/opentasks/daemon-manager.d.ts.map +1 -1
  92. package/dist/task/backend/opentasks/daemon-manager.js +1 -1
  93. package/dist/task/backend/opentasks/daemon-manager.js.map +1 -1
  94. package/dist/teams/index.d.ts +3 -1
  95. package/dist/teams/index.d.ts.map +1 -1
  96. package/dist/teams/index.js +2 -0
  97. package/dist/teams/index.js.map +1 -1
  98. package/dist/teams/seed-defaults.d.ts +20 -0
  99. package/dist/teams/seed-defaults.d.ts.map +1 -0
  100. package/dist/teams/seed-defaults.js +71 -0
  101. package/dist/teams/seed-defaults.js.map +1 -0
  102. package/dist/teams/team-loader.d.ts +6 -2
  103. package/dist/teams/team-loader.d.ts.map +1 -1
  104. package/dist/teams/team-loader.js +154 -162
  105. package/dist/teams/team-loader.js.map +1 -1
  106. package/dist/teams/team-manager.d.ts +112 -0
  107. package/dist/teams/team-manager.d.ts.map +1 -0
  108. package/dist/teams/team-manager.js +305 -0
  109. package/dist/teams/team-manager.js.map +1 -0
  110. package/dist/teams/team-runtime.d.ts +125 -19
  111. package/dist/teams/team-runtime.d.ts.map +1 -1
  112. package/dist/teams/team-runtime.js +527 -119
  113. package/dist/teams/team-runtime.js.map +1 -1
  114. package/dist/teams/types.d.ts +41 -151
  115. package/dist/teams/types.d.ts.map +1 -1
  116. package/dist/teams/types.js +2 -3
  117. package/dist/teams/types.js.map +1 -1
  118. package/docs/teams.md +73 -0
  119. package/package.json +2 -1
  120. package/references/minimem/.claude/settings.json +7 -0
  121. package/references/minimem/.sudocode/issues.jsonl +18 -0
  122. package/references/minimem/.sudocode/specs.jsonl +1 -0
  123. package/references/minimem/CLAUDE.md +310 -0
  124. package/references/minimem/README.md +562 -0
  125. package/references/minimem/claude-plugin/.claude-plugin/plugin.json +10 -0
  126. package/references/minimem/claude-plugin/.mcp.json +7 -0
  127. package/references/minimem/claude-plugin/README.md +158 -0
  128. package/references/minimem/claude-plugin/commands/recall.md +47 -0
  129. package/references/minimem/claude-plugin/commands/remember.md +41 -0
  130. package/references/minimem/claude-plugin/hooks/__tests__/hooks.test.ts +272 -0
  131. package/references/minimem/claude-plugin/hooks/hooks.json +27 -0
  132. package/references/minimem/claude-plugin/hooks/session-end.sh +86 -0
  133. package/references/minimem/claude-plugin/hooks/session-start.sh +85 -0
  134. package/references/minimem/claude-plugin/skills/memory/SKILL.md +108 -0
  135. package/references/minimem/media/banner.png +0 -0
  136. package/references/minimem/package-lock.json +5373 -0
  137. package/references/minimem/package.json +72 -0
  138. package/references/minimem/scripts/postbuild.js +35 -0
  139. package/references/minimem/src/__tests__/edge-cases.test.ts +371 -0
  140. package/references/minimem/src/__tests__/errors.test.ts +265 -0
  141. package/references/minimem/src/__tests__/helpers.ts +199 -0
  142. package/references/minimem/src/__tests__/internal.test.ts +407 -0
  143. package/references/minimem/src/__tests__/knowledge.test.ts +287 -0
  144. package/references/minimem/src/__tests__/minimem.integration.test.ts +1127 -0
  145. package/references/minimem/src/__tests__/session.test.ts +190 -0
  146. package/references/minimem/src/cli/__tests__/commands.test.ts +759 -0
  147. package/references/minimem/src/cli/commands/__tests__/conflicts.test.ts +141 -0
  148. package/references/minimem/src/cli/commands/append.ts +76 -0
  149. package/references/minimem/src/cli/commands/config.ts +262 -0
  150. package/references/minimem/src/cli/commands/conflicts.ts +413 -0
  151. package/references/minimem/src/cli/commands/daemon.ts +169 -0
  152. package/references/minimem/src/cli/commands/index.ts +12 -0
  153. package/references/minimem/src/cli/commands/init.ts +88 -0
  154. package/references/minimem/src/cli/commands/mcp.ts +177 -0
  155. package/references/minimem/src/cli/commands/push-pull.ts +213 -0
  156. package/references/minimem/src/cli/commands/search.ts +158 -0
  157. package/references/minimem/src/cli/commands/status.ts +84 -0
  158. package/references/minimem/src/cli/commands/sync-init.ts +290 -0
  159. package/references/minimem/src/cli/commands/sync.ts +70 -0
  160. package/references/minimem/src/cli/commands/upsert.ts +197 -0
  161. package/references/minimem/src/cli/config.ts +584 -0
  162. package/references/minimem/src/cli/index.ts +264 -0
  163. package/references/minimem/src/cli/shared.ts +161 -0
  164. package/references/minimem/src/cli/sync/__tests__/central.test.ts +152 -0
  165. package/references/minimem/src/cli/sync/__tests__/conflicts.test.ts +209 -0
  166. package/references/minimem/src/cli/sync/__tests__/daemon.test.ts +118 -0
  167. package/references/minimem/src/cli/sync/__tests__/detection.test.ts +207 -0
  168. package/references/minimem/src/cli/sync/__tests__/integration.test.ts +476 -0
  169. package/references/minimem/src/cli/sync/__tests__/registry.test.ts +363 -0
  170. package/references/minimem/src/cli/sync/__tests__/state.test.ts +255 -0
  171. package/references/minimem/src/cli/sync/__tests__/validation.test.ts +193 -0
  172. package/references/minimem/src/cli/sync/__tests__/watcher.test.ts +178 -0
  173. package/references/minimem/src/cli/sync/central.ts +292 -0
  174. package/references/minimem/src/cli/sync/conflicts.ts +204 -0
  175. package/references/minimem/src/cli/sync/daemon.ts +407 -0
  176. package/references/minimem/src/cli/sync/detection.ts +138 -0
  177. package/references/minimem/src/cli/sync/index.ts +107 -0
  178. package/references/minimem/src/cli/sync/operations.ts +373 -0
  179. package/references/minimem/src/cli/sync/registry.ts +279 -0
  180. package/references/minimem/src/cli/sync/state.ts +355 -0
  181. package/references/minimem/src/cli/sync/validation.ts +206 -0
  182. package/references/minimem/src/cli/sync/watcher.ts +234 -0
  183. package/references/minimem/src/cli/version.ts +34 -0
  184. package/references/minimem/src/core/index.ts +9 -0
  185. package/references/minimem/src/core/indexer.ts +628 -0
  186. package/references/minimem/src/core/searcher.ts +221 -0
  187. package/references/minimem/src/db/schema.ts +183 -0
  188. package/references/minimem/src/db/sqlite-vec.ts +24 -0
  189. package/references/minimem/src/embeddings/__tests__/embeddings.test.ts +431 -0
  190. package/references/minimem/src/embeddings/batch-gemini.ts +392 -0
  191. package/references/minimem/src/embeddings/batch-openai.ts +409 -0
  192. package/references/minimem/src/embeddings/embeddings.ts +434 -0
  193. package/references/minimem/src/index.ts +109 -0
  194. package/references/minimem/src/internal.ts +299 -0
  195. package/references/minimem/src/minimem.ts +1276 -0
  196. package/references/minimem/src/search/__tests__/hybrid.test.ts +247 -0
  197. package/references/minimem/src/search/graph.ts +234 -0
  198. package/references/minimem/src/search/hybrid.ts +151 -0
  199. package/references/minimem/src/search/search.ts +256 -0
  200. package/references/minimem/src/server/__tests__/mcp.test.ts +341 -0
  201. package/references/minimem/src/server/__tests__/tools.test.ts +364 -0
  202. package/references/minimem/src/server/mcp.ts +326 -0
  203. package/references/minimem/src/server/tools.ts +720 -0
  204. package/references/minimem/src/session.ts +460 -0
  205. package/references/minimem/tsconfig.json +19 -0
  206. package/references/minimem/tsup.config.ts +26 -0
  207. package/references/minimem/vitest.config.ts +24 -0
  208. package/references/openteams/.claude/settings.json +6 -0
  209. package/references/openteams/README.md +1 -0
  210. package/references/openteams/SKILL.md +341 -0
  211. package/references/openteams/design.md +411 -0
  212. package/references/openteams/examples/bmad-method/prompts/analyst/ROLE.md +16 -0
  213. package/references/openteams/examples/bmad-method/prompts/analyst/SOUL.md +5 -0
  214. package/references/openteams/examples/bmad-method/prompts/architect/ROLE.md +24 -0
  215. package/references/openteams/examples/bmad-method/prompts/architect/SOUL.md +5 -0
  216. package/references/openteams/examples/bmad-method/prompts/developer/ROLE.md +25 -0
  217. package/references/openteams/examples/bmad-method/prompts/developer/SOUL.md +5 -0
  218. package/references/openteams/examples/bmad-method/prompts/master/ROLE.md +21 -0
  219. package/references/openteams/examples/bmad-method/prompts/master/SOUL.md +5 -0
  220. package/references/openteams/examples/bmad-method/prompts/pm/ROLE.md +20 -0
  221. package/references/openteams/examples/bmad-method/prompts/pm/SOUL.md +5 -0
  222. package/references/openteams/examples/bmad-method/prompts/qa/ROLE.md +17 -0
  223. package/references/openteams/examples/bmad-method/prompts/qa/SOUL.md +5 -0
  224. package/references/openteams/examples/bmad-method/prompts/quick-flow-dev/ROLE.md +23 -0
  225. package/references/openteams/examples/bmad-method/prompts/quick-flow-dev/SOUL.md +5 -0
  226. package/references/openteams/examples/bmad-method/prompts/scrum-master/ROLE.md +27 -0
  227. package/references/openteams/examples/bmad-method/prompts/scrum-master/SOUL.md +5 -0
  228. package/references/openteams/examples/bmad-method/prompts/tech-writer/ROLE.md +21 -0
  229. package/references/openteams/examples/bmad-method/prompts/tech-writer/SOUL.md +5 -0
  230. package/references/openteams/examples/bmad-method/prompts/ux-designer/ROLE.md +16 -0
  231. package/references/openteams/examples/bmad-method/prompts/ux-designer/SOUL.md +5 -0
  232. package/references/openteams/examples/bmad-method/roles/analyst.yaml +9 -0
  233. package/references/openteams/examples/bmad-method/roles/architect.yaml +9 -0
  234. package/references/openteams/examples/bmad-method/roles/developer.yaml +8 -0
  235. package/references/openteams/examples/bmad-method/roles/master.yaml +8 -0
  236. package/references/openteams/examples/bmad-method/roles/pm.yaml +9 -0
  237. package/references/openteams/examples/bmad-method/roles/qa.yaml +8 -0
  238. package/references/openteams/examples/bmad-method/roles/quick-flow-dev.yaml +8 -0
  239. package/references/openteams/examples/bmad-method/roles/scrum-master.yaml +9 -0
  240. package/references/openteams/examples/bmad-method/roles/tech-writer.yaml +8 -0
  241. package/references/openteams/examples/bmad-method/roles/ux-designer.yaml +8 -0
  242. package/references/openteams/examples/bmad-method/team.yaml +161 -0
  243. package/references/openteams/examples/get-shit-done/prompts/codebase-mapper/ROLE.md +17 -0
  244. package/references/openteams/examples/get-shit-done/prompts/codebase-mapper/SOUL.md +5 -0
  245. package/references/openteams/examples/get-shit-done/prompts/debugger/ROLE.md +25 -0
  246. package/references/openteams/examples/get-shit-done/prompts/debugger/SOUL.md +5 -0
  247. package/references/openteams/examples/get-shit-done/prompts/executor/ROLE.md +34 -0
  248. package/references/openteams/examples/get-shit-done/prompts/executor/SOUL.md +5 -0
  249. package/references/openteams/examples/get-shit-done/prompts/integration-checker/ROLE.md +18 -0
  250. package/references/openteams/examples/get-shit-done/prompts/integration-checker/SOUL.md +3 -0
  251. package/references/openteams/examples/get-shit-done/prompts/orchestrator/ROLE.md +42 -0
  252. package/references/openteams/examples/get-shit-done/prompts/orchestrator/SOUL.md +5 -0
  253. package/references/openteams/examples/get-shit-done/prompts/phase-researcher/ROLE.md +15 -0
  254. package/references/openteams/examples/get-shit-done/prompts/phase-researcher/SOUL.md +3 -0
  255. package/references/openteams/examples/get-shit-done/prompts/plan-checker/ROLE.md +17 -0
  256. package/references/openteams/examples/get-shit-done/prompts/plan-checker/SOUL.md +3 -0
  257. package/references/openteams/examples/get-shit-done/prompts/planner/ROLE.md +28 -0
  258. package/references/openteams/examples/get-shit-done/prompts/planner/SOUL.md +5 -0
  259. package/references/openteams/examples/get-shit-done/prompts/project-researcher/ROLE.md +16 -0
  260. package/references/openteams/examples/get-shit-done/prompts/project-researcher/SOUL.md +3 -0
  261. package/references/openteams/examples/get-shit-done/prompts/research-synthesizer/ROLE.md +13 -0
  262. package/references/openteams/examples/get-shit-done/prompts/research-synthesizer/SOUL.md +3 -0
  263. package/references/openteams/examples/get-shit-done/prompts/roadmapper/ROLE.md +14 -0
  264. package/references/openteams/examples/get-shit-done/prompts/roadmapper/SOUL.md +3 -0
  265. package/references/openteams/examples/get-shit-done/prompts/verifier/ROLE.md +19 -0
  266. package/references/openteams/examples/get-shit-done/prompts/verifier/SOUL.md +5 -0
  267. package/references/openteams/examples/get-shit-done/roles/codebase-mapper.yaml +8 -0
  268. package/references/openteams/examples/get-shit-done/roles/debugger.yaml +8 -0
  269. package/references/openteams/examples/get-shit-done/roles/executor.yaml +8 -0
  270. package/references/openteams/examples/get-shit-done/roles/integration-checker.yaml +8 -0
  271. package/references/openteams/examples/get-shit-done/roles/orchestrator.yaml +9 -0
  272. package/references/openteams/examples/get-shit-done/roles/phase-researcher.yaml +7 -0
  273. package/references/openteams/examples/get-shit-done/roles/plan-checker.yaml +8 -0
  274. package/references/openteams/examples/get-shit-done/roles/planner.yaml +8 -0
  275. package/references/openteams/examples/get-shit-done/roles/project-researcher.yaml +8 -0
  276. package/references/openteams/examples/get-shit-done/roles/research-synthesizer.yaml +7 -0
  277. package/references/openteams/examples/get-shit-done/roles/roadmapper.yaml +7 -0
  278. package/references/openteams/examples/get-shit-done/roles/verifier.yaml +8 -0
  279. package/references/openteams/examples/get-shit-done/team.yaml +154 -0
  280. package/references/openteams/package-lock.json +2181 -0
  281. package/references/openteams/package.json +48 -0
  282. package/references/openteams/schema/role.schema.json +125 -0
  283. package/references/openteams/schema/team.schema.json +284 -0
  284. package/references/openteams/src/cli/agent.ts +104 -0
  285. package/references/openteams/src/cli/cli.test.ts +381 -0
  286. package/references/openteams/src/cli/generate.ts +220 -0
  287. package/references/openteams/src/cli/message.ts +241 -0
  288. package/references/openteams/src/cli/task.ts +154 -0
  289. package/references/openteams/src/cli/team.ts +104 -0
  290. package/references/openteams/src/cli/template.ts +207 -0
  291. package/references/openteams/src/cli.ts +45 -0
  292. package/references/openteams/src/db/database.test.ts +185 -0
  293. package/references/openteams/src/db/database.ts +240 -0
  294. package/references/openteams/src/generators/agent-prompt-generator.test.ts +332 -0
  295. package/references/openteams/src/generators/agent-prompt-generator.ts +521 -0
  296. package/references/openteams/src/generators/package-generator.test.ts +129 -0
  297. package/references/openteams/src/generators/package-generator.ts +102 -0
  298. package/references/openteams/src/generators/skill-generator.test.ts +246 -0
  299. package/references/openteams/src/generators/skill-generator.ts +374 -0
  300. package/references/openteams/src/index.ts +104 -0
  301. package/references/openteams/src/services/agent-service.test.ts +158 -0
  302. package/references/openteams/src/services/agent-service.ts +84 -0
  303. package/references/openteams/src/services/communication-service.test.ts +455 -0
  304. package/references/openteams/src/services/communication-service.ts +371 -0
  305. package/references/openteams/src/services/message-service.test.ts +342 -0
  306. package/references/openteams/src/services/message-service.ts +203 -0
  307. package/references/openteams/src/services/task-service.test.ts +434 -0
  308. package/references/openteams/src/services/task-service.ts +239 -0
  309. package/references/openteams/src/services/team-service.test.ts +181 -0
  310. package/references/openteams/src/services/team-service.ts +139 -0
  311. package/references/openteams/src/services/template-service.test.ts +306 -0
  312. package/references/openteams/src/services/template-service.ts +182 -0
  313. package/references/openteams/src/spawner/acp-factory.ts +96 -0
  314. package/references/openteams/src/spawner/interface.ts +31 -0
  315. package/references/openteams/src/spawner/mock.test.ts +93 -0
  316. package/references/openteams/src/spawner/mock.ts +59 -0
  317. package/references/openteams/src/template/loader.test.ts +1319 -0
  318. package/references/openteams/src/template/loader.ts +698 -0
  319. package/references/openteams/src/template/types.ts +200 -0
  320. package/references/openteams/src/types.ts +205 -0
  321. package/references/openteams/tsconfig.json +18 -0
  322. package/references/openteams/vitest.config.ts +9 -0
  323. package/references/skill-tree/.claude/settings.json +6 -0
  324. package/references/skill-tree/.sudocode/issues.jsonl +11 -0
  325. package/references/skill-tree/.sudocode/specs.jsonl +1 -0
  326. package/references/skill-tree/CLAUDE.md +150 -0
  327. package/references/skill-tree/README.md +324 -0
  328. package/references/skill-tree/docs/GAPS_v1.md +221 -0
  329. package/references/skill-tree/docs/INTEGRATION_PLAN.md +467 -0
  330. package/references/skill-tree/docs/TODOS.md +91 -0
  331. package/references/skill-tree/docs/anthropic_skill_guide.md +1364 -0
  332. package/references/skill-tree/docs/design/federated-skill-trees.md +524 -0
  333. package/references/skill-tree/docs/design/multi-agent-sync.md +759 -0
  334. package/references/skill-tree/docs/scraper/BRAINSTORM.md +583 -0
  335. package/references/skill-tree/docs/scraper/POC_PLAN.md +420 -0
  336. package/references/skill-tree/docs/scraper/README.md +170 -0
  337. package/references/skill-tree/examples/basic-usage.ts +190 -0
  338. package/references/skill-tree/package-lock.json +1509 -0
  339. package/references/skill-tree/package.json +66 -0
  340. package/references/skill-tree/scraper/README.md +123 -0
  341. package/references/skill-tree/scraper/docs/DESIGN.md +683 -0
  342. package/references/skill-tree/scraper/docs/PLAN.md +336 -0
  343. package/references/skill-tree/scraper/drizzle.config.ts +10 -0
  344. package/references/skill-tree/scraper/package-lock.json +6329 -0
  345. package/references/skill-tree/scraper/package.json +68 -0
  346. package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-description.md +7 -0
  347. package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-name.md +7 -0
  348. package/references/skill-tree/scraper/test/fixtures/minimal-skill/SKILL.md +27 -0
  349. package/references/skill-tree/scraper/test/fixtures/skill-json/SKILL.json +21 -0
  350. package/references/skill-tree/scraper/test/fixtures/skill-with-meta/SKILL.md +54 -0
  351. package/references/skill-tree/scraper/test/fixtures/skill-with-meta/_meta.json +24 -0
  352. package/references/skill-tree/scraper/test/fixtures/valid-skill/SKILL.md +93 -0
  353. package/references/skill-tree/scraper/test/fixtures/valid-skill/_meta.json +22 -0
  354. package/references/skill-tree/scraper/tsup.config.ts +14 -0
  355. package/references/skill-tree/scraper/vitest.config.ts +17 -0
  356. package/references/skill-tree/scripts/convert-to-vitest.ts +166 -0
  357. package/references/skill-tree/skills/skill-writer/SKILL.md +339 -0
  358. package/references/skill-tree/skills/skill-writer/references/examples.md +326 -0
  359. package/references/skill-tree/skills/skill-writer/references/patterns.md +210 -0
  360. package/references/skill-tree/skills/skill-writer/references/quality-checklist.md +123 -0
  361. package/references/skill-tree/test/run-all.ts +106 -0
  362. package/references/skill-tree/test/utils.ts +128 -0
  363. package/references/skill-tree/vitest.config.ts +16 -0
  364. package/src/agent/agent-manager.ts +143 -72
  365. package/src/agent/types.ts +9 -0
  366. package/src/api/__tests__/server.test.ts +203 -4
  367. package/src/api/server.ts +130 -5
  368. package/src/api/types.ts +3 -1
  369. package/src/cli/acp.ts +68 -1
  370. package/src/cli/index.ts +5 -1
  371. package/src/cli/mcp.ts +27 -13
  372. package/src/config/project-config.ts +27 -3
  373. package/src/index.ts +3 -0
  374. package/src/lifecycle/__tests__/handlers.test.ts +53 -0
  375. package/src/lifecycle/handlers/index.ts +25 -8
  376. package/src/lifecycle/types.ts +3 -0
  377. package/src/map/adapter/__tests__/stream-extensions.test.ts +494 -0
  378. package/src/map/adapter/extensions/index.ts +36 -0
  379. package/src/map/adapter/extensions/streams.ts +839 -0
  380. package/src/map/adapter/index.ts +5 -0
  381. package/src/map/adapter/types.ts +8 -1
  382. package/src/mcp/mcp-server.ts +14 -3
  383. package/src/mcp/tools/done.ts +19 -0
  384. package/src/roles/builtin/coordinator.ts +2 -0
  385. package/src/roles/builtin/integrator.ts +2 -0
  386. package/src/roles/builtin/worker.ts +3 -0
  387. package/src/roles/capabilities.ts +11 -0
  388. package/src/roles/config-loader.ts +3 -2
  389. package/src/roles/types.ts +7 -0
  390. package/src/server/combined-server.ts +15 -1
  391. package/src/store/__tests__/event-store-oob.test.ts +109 -0
  392. package/src/store/event-store.ts +13 -3
  393. package/src/store/instance.ts +2 -2
  394. package/src/store/types/agents.ts +5 -0
  395. package/src/task/backend/__tests__/memory-pull-mode.test.ts +153 -0
  396. package/src/task/backend/opentasks/daemon-manager.ts +4 -1
  397. package/src/teams/CLAUDE.md +180 -0
  398. package/src/teams/__tests__/e2e/workspace-isolation.e2e.test.ts +1263 -0
  399. package/src/teams/__tests__/team-manager.test.ts +814 -0
  400. package/src/teams/__tests__/team-system.test.ts +1291 -8
  401. package/src/teams/index.ts +21 -3
  402. package/src/teams/seed-defaults.ts +79 -0
  403. package/src/teams/team-loader.ts +200 -234
  404. package/src/teams/team-manager.ts +387 -0
  405. package/src/teams/team-runtime.ts +590 -121
  406. package/src/teams/types.ts +99 -200
@@ -0,0 +1,381 @@
1
+ import { describe, it, expect, beforeEach, afterEach, vi } from "vitest";
2
+ import type Database from "better-sqlite3";
3
+ import { createInMemoryDatabase } from "../db/database";
4
+ import { createMessageCommands } from "./message";
5
+ import { createTaskCommands } from "./task";
6
+ import { createTeamCommands } from "./team";
7
+ import { createAgentCommands } from "./agent";
8
+ import { TeamService } from "../services/team-service";
9
+ import { MessageService } from "../services/message-service";
10
+ import { MockSpawner } from "../spawner/mock";
11
+ import type { Command } from "commander";
12
+
13
+ describe("CLI Commands", () => {
14
+ let db: Database.Database;
15
+ let teamService: TeamService;
16
+ let messageService: MessageService;
17
+ let messageCmd: Command;
18
+ let taskCmd: Command;
19
+ let teamCmd: Command;
20
+ let agentCmd: Command;
21
+ let logs: string[];
22
+ let errors: string[];
23
+
24
+ beforeEach(() => {
25
+ db = createInMemoryDatabase();
26
+ teamService = new TeamService(db);
27
+ messageService = new MessageService(db);
28
+ messageCmd = createMessageCommands(db);
29
+ taskCmd = createTaskCommands(db);
30
+ teamCmd = createTeamCommands(db);
31
+ agentCmd = createAgentCommands(db, new MockSpawner());
32
+
33
+ // Set up test team with members
34
+ teamService.create({ name: "myteam" });
35
+ teamService.addMember("myteam", "alice");
36
+ teamService.addMember("myteam", "bob");
37
+
38
+ // Capture console output
39
+ logs = [];
40
+ errors = [];
41
+ vi.spyOn(console, "log").mockImplementation((...args: any[]) => {
42
+ logs.push(args.map(String).join(" "));
43
+ });
44
+ vi.spyOn(console, "error").mockImplementation((...args: any[]) => {
45
+ errors.push(args.map(String).join(" "));
46
+ });
47
+ process.exitCode = undefined;
48
+ });
49
+
50
+ afterEach(() => {
51
+ db.close();
52
+ vi.restoreAllMocks();
53
+ process.exitCode = undefined;
54
+ });
55
+
56
+ async function run(cmd: Command, args: string[]) {
57
+ // commander needs the first two args as node and script path
58
+ cmd.exitOverride(); // prevent process.exit on errors
59
+ try {
60
+ await cmd.parseAsync(["node", "test", ...args]);
61
+ } catch {
62
+ // commander may throw on --help or missing required options
63
+ }
64
+ }
65
+
66
+ describe("message shutdown-response (Gap 7)", () => {
67
+ it("approves a shutdown request", async () => {
68
+ const req = messageService.sendShutdownRequest({
69
+ teamName: "myteam",
70
+ sender: "alice",
71
+ recipient: "bob",
72
+ });
73
+
74
+ await run(messageCmd, [
75
+ "shutdown-response",
76
+ "myteam",
77
+ "--request-id",
78
+ req.request_id!,
79
+ "--approve",
80
+ "--from",
81
+ "bob",
82
+ ]);
83
+
84
+ expect(logs.join("\n")).toContain("Shutdown approved");
85
+ expect(logs.join("\n")).toContain(req.request_id!);
86
+ });
87
+
88
+ it("rejects a shutdown request", async () => {
89
+ const req = messageService.sendShutdownRequest({
90
+ teamName: "myteam",
91
+ sender: "alice",
92
+ recipient: "bob",
93
+ });
94
+
95
+ await run(messageCmd, [
96
+ "shutdown-response",
97
+ "myteam",
98
+ "--request-id",
99
+ req.request_id!,
100
+ "--reject",
101
+ "--from",
102
+ "bob",
103
+ ]);
104
+
105
+ expect(logs.join("\n")).toContain("Shutdown rejected");
106
+ });
107
+
108
+ it("errors when neither --approve nor --reject is given", async () => {
109
+ await run(messageCmd, [
110
+ "shutdown-response",
111
+ "myteam",
112
+ "--request-id",
113
+ "req-123",
114
+ ]);
115
+
116
+ expect(errors.join("\n")).toContain(
117
+ "Must specify either --approve or --reject"
118
+ );
119
+ });
120
+ });
121
+
122
+ describe("message plan-response (Gap 7)", () => {
123
+ it("approves a plan", async () => {
124
+ await run(messageCmd, [
125
+ "plan-response",
126
+ "myteam",
127
+ "--to",
128
+ "alice",
129
+ "--request-id",
130
+ "plan-1",
131
+ "--approve",
132
+ "--from",
133
+ "bob",
134
+ ]);
135
+
136
+ expect(logs.join("\n")).toContain("Plan approved");
137
+ expect(logs.join("\n")).toContain("alice");
138
+ });
139
+
140
+ it("rejects a plan with feedback", async () => {
141
+ await run(messageCmd, [
142
+ "plan-response",
143
+ "myteam",
144
+ "--to",
145
+ "bob",
146
+ "--request-id",
147
+ "plan-2",
148
+ "--reject",
149
+ "--content",
150
+ "Needs more tests",
151
+ ]);
152
+
153
+ expect(logs.join("\n")).toContain("Plan rejected");
154
+ });
155
+
156
+ it("errors when neither --approve nor --reject is given", async () => {
157
+ await run(messageCmd, [
158
+ "plan-response",
159
+ "myteam",
160
+ "--to",
161
+ "alice",
162
+ "--request-id",
163
+ "plan-3",
164
+ ]);
165
+
166
+ expect(errors.join("\n")).toContain(
167
+ "Must specify either --approve or --reject"
168
+ );
169
+ });
170
+ });
171
+
172
+ describe("message poll (Gap 8)", () => {
173
+ it("lists undelivered messages", async () => {
174
+ messageService.send({
175
+ teamName: "myteam",
176
+ sender: "alice",
177
+ recipient: "bob",
178
+ content: "Hello Bob",
179
+ summary: "Greeting",
180
+ });
181
+
182
+ await run(messageCmd, ["poll", "myteam", "--agent", "bob"]);
183
+
184
+ expect(logs.join("\n")).toContain("Hello Bob");
185
+ expect(logs.join("\n")).toContain("[message]");
186
+ });
187
+
188
+ it("shows empty message when no undelivered", async () => {
189
+ await run(messageCmd, ["poll", "myteam", "--agent", "bob"]);
190
+
191
+ expect(logs.join("\n")).toContain("No undelivered messages");
192
+ });
193
+
194
+ it("marks messages as delivered with --mark-delivered", async () => {
195
+ messageService.send({
196
+ teamName: "myteam",
197
+ sender: "alice",
198
+ recipient: "bob",
199
+ content: "Important",
200
+ summary: "Urgent",
201
+ });
202
+
203
+ await run(messageCmd, [
204
+ "poll",
205
+ "myteam",
206
+ "--agent",
207
+ "bob",
208
+ "--mark-delivered",
209
+ ]);
210
+
211
+ expect(logs.join("\n")).toContain("Marked 1 message(s) as delivered");
212
+
213
+ // Verify it's actually delivered
214
+ const undelivered = messageService.getUndelivered("myteam", "bob");
215
+ expect(undelivered).toHaveLength(0);
216
+ });
217
+
218
+ it("outputs JSON with --json flag", async () => {
219
+ messageService.send({
220
+ teamName: "myteam",
221
+ sender: "alice",
222
+ recipient: "bob",
223
+ content: "JSON test",
224
+ summary: "Test",
225
+ });
226
+
227
+ await run(messageCmd, [
228
+ "poll",
229
+ "myteam",
230
+ "--agent",
231
+ "bob",
232
+ "--json",
233
+ ]);
234
+
235
+ const output = logs.join("\n");
236
+ const parsed = JSON.parse(output);
237
+ expect(Array.isArray(parsed)).toBe(true);
238
+ expect(parsed).toHaveLength(1);
239
+ expect(parsed[0].content).toBe("JSON test");
240
+ expect(parsed[0].delivered).toBe(false);
241
+ });
242
+ });
243
+
244
+ describe("message ack (Gap 8)", () => {
245
+ it("marks a message as delivered", async () => {
246
+ const msg = messageService.send({
247
+ teamName: "myteam",
248
+ sender: "alice",
249
+ recipient: "bob",
250
+ content: "Ack me",
251
+ summary: "Test",
252
+ });
253
+
254
+ await run(messageCmd, ["ack", "myteam", String(msg.id)]);
255
+
256
+ expect(logs.join("\n")).toContain(`Message #${msg.id} marked as delivered`);
257
+ const undelivered = messageService.getUndelivered("myteam", "bob");
258
+ expect(undelivered).toHaveLength(0);
259
+ });
260
+
261
+ it("errors on invalid message ID", async () => {
262
+ await run(messageCmd, ["ack", "myteam", "abc"]);
263
+
264
+ expect(errors.join("\n")).toContain('Invalid message ID: "abc"');
265
+ });
266
+ });
267
+
268
+ describe("message list --json (Gap 9)", () => {
269
+ it("outputs JSON array of messages", async () => {
270
+ messageService.send({
271
+ teamName: "myteam",
272
+ sender: "alice",
273
+ recipient: "bob",
274
+ content: "Hi",
275
+ summary: "Greeting",
276
+ });
277
+
278
+ await run(messageCmd, ["list", "myteam", "--json"]);
279
+
280
+ const output = logs.join("\n");
281
+ const parsed = JSON.parse(output);
282
+ expect(Array.isArray(parsed)).toBe(true);
283
+ expect(parsed).toHaveLength(1);
284
+ expect(parsed[0].type).toBe("message");
285
+ expect(parsed[0].sender).toBe("alice");
286
+ expect(parsed[0].recipient).toBe("bob");
287
+ });
288
+
289
+ it("outputs empty JSON array when no messages", async () => {
290
+ await run(messageCmd, ["list", "myteam", "--json"]);
291
+
292
+ const parsed = JSON.parse(logs.join("\n"));
293
+ expect(parsed).toEqual([]);
294
+ });
295
+ });
296
+
297
+ describe("task list --json (Gap 9)", () => {
298
+ it("outputs JSON array of tasks", async () => {
299
+ db.prepare(
300
+ "INSERT INTO tasks (team_name, subject, description) VALUES (?, ?, ?)"
301
+ ).run("myteam", "Fix bug", "Fix the critical bug");
302
+
303
+ await run(taskCmd, ["list", "myteam", "--json"]);
304
+
305
+ const output = logs.join("\n");
306
+ const parsed = JSON.parse(output);
307
+ expect(Array.isArray(parsed)).toBe(true);
308
+ expect(parsed).toHaveLength(1);
309
+ expect(parsed[0].subject).toBe("Fix bug");
310
+ });
311
+ });
312
+
313
+ describe("task get --json (Gap 9)", () => {
314
+ it("outputs full task details as JSON", async () => {
315
+ const result = db
316
+ .prepare(
317
+ "INSERT INTO tasks (team_name, subject, description, metadata) VALUES (?, ?, ?, ?)"
318
+ )
319
+ .run("myteam", "Task A", "Description A", '{"priority":"high"}');
320
+ const taskId = Number(result.lastInsertRowid);
321
+
322
+ await run(taskCmd, ["get", "myteam", String(taskId), "--json"]);
323
+
324
+ const output = logs.join("\n");
325
+ const parsed = JSON.parse(output);
326
+ expect(parsed.subject).toBe("Task A");
327
+ expect(parsed.metadata).toEqual({ priority: "high" });
328
+ expect(parsed.blockedBy).toEqual([]);
329
+ expect(parsed.blocks).toEqual([]);
330
+ });
331
+ });
332
+
333
+ describe("agent list --json (Gap 9)", () => {
334
+ it("outputs JSON array of members", async () => {
335
+ await run(agentCmd, ["list", "myteam", "--json"]);
336
+
337
+ const output = logs.join("\n");
338
+ const parsed = JSON.parse(output);
339
+ expect(Array.isArray(parsed)).toBe(true);
340
+ expect(parsed).toHaveLength(2);
341
+ expect(parsed.map((m: any) => m.agent_name).sort()).toEqual([
342
+ "alice",
343
+ "bob",
344
+ ]);
345
+ });
346
+ });
347
+
348
+ describe("team add-member (Gap 10)", () => {
349
+ it("adds a member to a team", async () => {
350
+ await run(teamCmd, ["add-member", "myteam", "charlie"]);
351
+
352
+ expect(logs.join("\n")).toContain('Member "charlie" added to team "myteam"');
353
+ const member = teamService.getMember("myteam", "charlie");
354
+ expect(member).not.toBeNull();
355
+ expect(member!.agent_type).toBe("general-purpose");
356
+ });
357
+
358
+ it("adds a member with role and type", async () => {
359
+ await run(teamCmd, [
360
+ "add-member",
361
+ "myteam",
362
+ "dave",
363
+ "--role",
364
+ "reviewer",
365
+ "--type",
366
+ "bash",
367
+ ]);
368
+
369
+ expect(logs.join("\n")).toContain("role: reviewer");
370
+ const member = teamService.getMember("myteam", "dave");
371
+ expect(member!.role).toBe("reviewer");
372
+ expect(member!.agent_type).toBe("bash");
373
+ });
374
+
375
+ it("errors when team does not exist", async () => {
376
+ await run(teamCmd, ["add-member", "nonexistent", "agent1"]);
377
+
378
+ expect(errors.join("\n")).toContain('Team "nonexistent" not found');
379
+ });
380
+ });
381
+ });
@@ -0,0 +1,220 @@
1
+ import fs from "fs";
2
+ import path from "path";
3
+ import { Command } from "commander";
4
+ import { TemplateLoader } from "../template/loader";
5
+ import { generateSkillMd, generateCatalog } from "../generators/skill-generator";
6
+ import {
7
+ generateAgentPrompts,
8
+ generateAgentPrompt,
9
+ generateRoleSkillMd,
10
+ } from "../generators/agent-prompt-generator";
11
+ import { generatePackage } from "../generators/package-generator";
12
+
13
+ export function createGenerateCommands(): Command {
14
+ const generate = new Command("generate").description(
15
+ "Generate SKILL.md and agent prompts from a team template"
16
+ );
17
+
18
+ generate
19
+ .command("skill <dir>")
20
+ .description(
21
+ "Generate a SKILL.md file from a team template directory"
22
+ )
23
+ .option("-n, --name <name>", "Override the team name")
24
+ .option(
25
+ "-o, --output <path>",
26
+ "Output path (default: <dir>/SKILL.md)"
27
+ )
28
+ .option("--no-cli-examples", "Omit CLI usage examples")
29
+ .action((dir: string, opts) => {
30
+ try {
31
+ const template = TemplateLoader.load(dir);
32
+ const teamName = opts.name ?? template.manifest.name;
33
+ const content = generateSkillMd(template, {
34
+ teamName,
35
+ includeCliExamples: opts.cliExamples !== false,
36
+ });
37
+
38
+ const outputPath = opts.output ?? path.join(dir, "SKILL.md");
39
+ fs.writeFileSync(outputPath, content, "utf-8");
40
+ console.log(`Generated SKILL.md at ${outputPath}`);
41
+ } catch (err: any) {
42
+ console.error(`Error: ${err.message}`);
43
+ process.exitCode = 1;
44
+ }
45
+ });
46
+
47
+ generate
48
+ .command("agents <dir>")
49
+ .description(
50
+ "Generate agent prompt files from a team template directory"
51
+ )
52
+ .option("-n, --name <name>", "Override the team name")
53
+ .option(
54
+ "-o, --output <path>",
55
+ "Output directory for prompt files (default: <dir>/agents/)"
56
+ )
57
+ .option("--preamble <text>", "Additional context to prepend to every prompt")
58
+ .action((dir: string, opts) => {
59
+ try {
60
+ const template = TemplateLoader.load(dir);
61
+ const teamName = opts.name ?? template.manifest.name;
62
+ const prompts = generateAgentPrompts(template, {
63
+ teamName,
64
+ preamble: opts.preamble,
65
+ });
66
+
67
+ const outputDir = opts.output ?? path.join(dir, "agents");
68
+ fs.mkdirSync(outputDir, { recursive: true });
69
+
70
+ for (const agentPrompt of prompts) {
71
+ const filePath = path.join(outputDir, `${agentPrompt.role}.md`);
72
+ fs.writeFileSync(filePath, agentPrompt.prompt, "utf-8");
73
+ console.log(` ${agentPrompt.role} -> ${filePath}`);
74
+ }
75
+ console.log(
76
+ `Generated ${prompts.length} agent prompt(s) in ${outputDir}`
77
+ );
78
+ } catch (err: any) {
79
+ console.error(`Error: ${err.message}`);
80
+ process.exitCode = 1;
81
+ }
82
+ });
83
+
84
+ generate
85
+ .command("all <dir>")
86
+ .description(
87
+ "Generate SKILL.md and all agent prompts from a team template"
88
+ )
89
+ .option("-n, --name <name>", "Override the team name")
90
+ .option(
91
+ "-o, --output <path>",
92
+ "Output base directory (default: <dir>)"
93
+ )
94
+ .option("--preamble <text>", "Additional context for agent prompts")
95
+ .action((dir: string, opts) => {
96
+ try {
97
+ const template = TemplateLoader.load(dir);
98
+ const teamName = opts.name ?? template.manifest.name;
99
+ const baseDir = opts.output ?? dir;
100
+
101
+ // Generate SKILL.md
102
+ const skillContent = generateSkillMd(template, { teamName });
103
+ const skillPath = path.join(baseDir, "SKILL.md");
104
+ fs.writeFileSync(skillPath, skillContent, "utf-8");
105
+ console.log(`Generated ${skillPath}`);
106
+
107
+ // Generate agent prompts
108
+ const prompts = generateAgentPrompts(template, {
109
+ teamName,
110
+ preamble: opts.preamble,
111
+ });
112
+ const agentsDir = path.join(baseDir, "agents");
113
+ fs.mkdirSync(agentsDir, { recursive: true });
114
+
115
+ for (const agentPrompt of prompts) {
116
+ const filePath = path.join(agentsDir, `${agentPrompt.role}.md`);
117
+ fs.writeFileSync(filePath, agentPrompt.prompt, "utf-8");
118
+ console.log(` ${agentPrompt.role} -> ${filePath}`);
119
+ }
120
+ console.log(
121
+ `\nGenerated SKILL.md + ${prompts.length} agent prompt(s) for team "${teamName}"`
122
+ );
123
+ } catch (err: any) {
124
+ console.error(`Error: ${err.message}`);
125
+ process.exitCode = 1;
126
+ }
127
+ });
128
+
129
+ generate
130
+ .command("package <dir>")
131
+ .description(
132
+ "Generate a skill package directory from a team template"
133
+ )
134
+ .option("-n, --name <name>", "Override the team name")
135
+ .option(
136
+ "-o, --output <path>",
137
+ "Output directory (default: <dir>/package/)"
138
+ )
139
+ .action((dir: string, opts) => {
140
+ try {
141
+ const template = TemplateLoader.load(dir);
142
+ const teamName = opts.name ?? template.manifest.name;
143
+ const outputDir = opts.output ?? path.join(dir, "package");
144
+
145
+ const result = generatePackage(template, {
146
+ teamName,
147
+ outputDir,
148
+ });
149
+
150
+ console.log(`Generated skill package in ${outputDir}`);
151
+ console.log(` Catalog: ${result.catalogPath}`);
152
+ for (const rp of result.rolePaths) {
153
+ console.log(` ${rp.role}: ${rp.path}`);
154
+ }
155
+ if (result.manifestPath) {
156
+ console.log(` Manifest: ${result.manifestPath}`);
157
+ }
158
+ } catch (err: any) {
159
+ console.error(`Error: ${err.message}`);
160
+ process.exitCode = 1;
161
+ }
162
+ });
163
+
164
+ generate
165
+ .command("catalog <dir>")
166
+ .description(
167
+ "Generate a lightweight team catalog from a template"
168
+ )
169
+ .option("-n, --name <name>", "Override the team name")
170
+ .option("-o, --output <path>", "Output path (default: stdout)")
171
+ .action((dir: string, opts) => {
172
+ try {
173
+ const template = TemplateLoader.load(dir);
174
+ const teamName = opts.name ?? template.manifest.name;
175
+ const content = generateCatalog(template, { teamName });
176
+
177
+ if (opts.output) {
178
+ fs.writeFileSync(opts.output, content, "utf-8");
179
+ console.log(`Generated catalog at ${opts.output}`);
180
+ } else {
181
+ process.stdout.write(content);
182
+ }
183
+ } catch (err: any) {
184
+ console.error(`Error: ${err.message}`);
185
+ process.exitCode = 1;
186
+ }
187
+ });
188
+
189
+ generate
190
+ .command("role-package <dir>")
191
+ .description(
192
+ "Generate a standalone SKILL.md for a specific role"
193
+ )
194
+ .requiredOption("-r, --role <role>", "Role name")
195
+ .option("-n, --name <name>", "Override the team name")
196
+ .option("-o, --output <path>", "Output path (default: stdout)")
197
+ .action((dir: string, opts) => {
198
+ try {
199
+ const template = TemplateLoader.load(dir);
200
+ const teamName = opts.name ?? template.manifest.name;
201
+ const result = generateRoleSkillMd(template, opts.role, {
202
+ teamName,
203
+ });
204
+
205
+ if (opts.output) {
206
+ const outDir = path.dirname(opts.output);
207
+ fs.mkdirSync(outDir, { recursive: true });
208
+ fs.writeFileSync(opts.output, result.content, "utf-8");
209
+ console.log(`Generated role package at ${opts.output}`);
210
+ } else {
211
+ process.stdout.write(result.content);
212
+ }
213
+ } catch (err: any) {
214
+ console.error(`Error: ${err.message}`);
215
+ process.exitCode = 1;
216
+ }
217
+ });
218
+
219
+ return generate;
220
+ }