@zeyue0329/xiaoma-cli 1.0.49 → 1.6.4

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 (895) hide show
  1. package/.github/workflows/quality.yaml +116 -0
  2. package/.husky/pre-commit +26 -0
  3. package/.idea/codeStyles/Project.xml +60 -0
  4. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  5. package/.idea/jsLibraryMappings.xml +6 -0
  6. package/.idea/modules.xml +1 -1
  7. package/.idea/vcs.xml +0 -1
  8. package/.idea/workspace.xml +40 -24
  9. package/.markdownlint-cli2.yaml +41 -0
  10. package/.prettierignore +12 -0
  11. package/.vscode/settings.json +96 -0
  12. package/LICENSE +30 -0
  13. package/README.md +108 -2
  14. package/XIAOMA-CLI-GUIDE.md +512 -0
  15. package/{.idea/XiaoMa-Cli.iml → XiaoMa-Cli.iml} +1 -1
  16. package/custom/src/agents/commit-poet/commit-poet.agent.yaml +129 -0
  17. package/custom/src/agents/commit-poet/installation-guide.md +36 -0
  18. package/custom/src/agents/toolsmith/installation-guide.md +36 -0
  19. package/custom/src/agents/toolsmith/toolsmith-sidecar/instructions.md +70 -0
  20. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/bundlers.md +111 -0
  21. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/deploy.md +70 -0
  22. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/docs.md +114 -0
  23. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/installers.md +134 -0
  24. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/modules.md +160 -0
  25. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/tests.md +103 -0
  26. package/custom/src/agents/toolsmith/toolsmith-sidecar/memories.md +17 -0
  27. package/custom/src/agents/toolsmith/toolsmith.agent.yaml +108 -0
  28. package/docs/BUNDLE_DISTRIBUTION_SETUP.md +95 -0
  29. package/docs/agent-customization-guide.md +208 -0
  30. package/docs/custom-agent-installation.md +183 -0
  31. package/docs/document-sharding-guide.md +449 -0
  32. package/docs/explanation/advanced-elicitation.md +49 -0
  33. package/docs/explanation/adversarial-review.md +59 -0
  34. package/docs/explanation/brainstorming.md +33 -0
  35. package/docs/explanation/established-projects-faq.md +50 -0
  36. package/docs/explanation/party-mode.md +59 -0
  37. package/docs/explanation/preventing-agent-conflicts.md +112 -0
  38. package/docs/explanation/project-context.md +157 -0
  39. package/docs/explanation/quick-dev-new-preview.md +73 -0
  40. package/docs/explanation/quick-flow.md +77 -0
  41. package/docs/explanation/why-solutioning-matters.md +77 -0
  42. package/docs/how-to/customize-xiaoma.md +172 -0
  43. package/docs/how-to/established-projects.md +117 -0
  44. package/docs/how-to/get-answers-about-xiaoma.md +134 -0
  45. package/docs/how-to/install-xiaoma.md +107 -0
  46. package/docs/how-to/non-interactive-installation.md +171 -0
  47. package/docs/how-to/project-context.md +136 -0
  48. package/docs/how-to/quick-fixes.md +123 -0
  49. package/docs/how-to/shard-large-documents.md +78 -0
  50. package/docs/how-to/upgrade-to-v6.md +100 -0
  51. package/docs/ide-info/auggie.md +31 -0
  52. package/docs/ide-info/claude-code.md +25 -0
  53. package/docs/ide-info/cline.md +31 -0
  54. package/docs/ide-info/codex.md +21 -0
  55. package/docs/ide-info/crush.md +30 -0
  56. package/docs/ide-info/cursor.md +25 -0
  57. package/docs/ide-info/gemini.md +25 -0
  58. package/docs/ide-info/github-copilot.md +26 -0
  59. package/docs/ide-info/iflow.md +33 -0
  60. package/docs/ide-info/kilo.md +24 -0
  61. package/docs/ide-info/opencode.md +24 -0
  62. package/docs/ide-info/qwen.md +25 -0
  63. package/docs/ide-info/roo.md +27 -0
  64. package/docs/ide-info/rovo-dev.md +388 -0
  65. package/docs/ide-info/trae.md +25 -0
  66. package/docs/ide-info/windsurf.md +22 -0
  67. package/docs/index.md +60 -0
  68. package/docs/installers-bundlers/ide-injections.md +186 -0
  69. package/docs/installers-bundlers/installers-modules-platforms-reference.md +379 -0
  70. package/docs/rag/rag.md +856 -0
  71. package/docs/reference/agents.md +28 -0
  72. package/docs/reference/commands.md +145 -0
  73. package/docs/reference/modules.md +76 -0
  74. package/docs/reference/testing.md +106 -0
  75. package/docs/reference/workflow-map.md +89 -0
  76. package/docs/roadmap.mdx +136 -0
  77. package/docs/superpowers/plans/2026-03-11-upstream-sync-with-branding.md +586 -0
  78. package/docs/tutorials/getting-started.md +273 -0
  79. package/docs/v4-to-v6-upgrade.md +220 -0
  80. package/docs/v6-open-items.md +17 -0
  81. package/docs/web-bundles-gemini-gpt-guide.md +468 -0
  82. package/docs/zh-cn/404.md +9 -0
  83. package/docs/zh-cn/_STYLE_GUIDE.md +370 -0
  84. package/docs/zh-cn/explanation/advanced-elicitation.md +62 -0
  85. package/docs/zh-cn/explanation/adversarial-review.md +71 -0
  86. package/docs/zh-cn/explanation/brainstorming.md +43 -0
  87. package/docs/zh-cn/explanation/established-projects-faq.md +60 -0
  88. package/docs/zh-cn/explanation/party-mode.md +79 -0
  89. package/docs/zh-cn/explanation/preventing-agent-conflicts.md +137 -0
  90. package/docs/zh-cn/explanation/project-context.md +176 -0
  91. package/docs/zh-cn/explanation/quick-flow.md +93 -0
  92. package/docs/zh-cn/explanation/why-solutioning-matters.md +90 -0
  93. package/docs/zh-cn/how-to/customize-xiaoma.md +182 -0
  94. package/docs/zh-cn/how-to/established-projects.md +134 -0
  95. package/docs/zh-cn/how-to/get-answers-about-xiaoma.md +144 -0
  96. package/docs/zh-cn/how-to/install-xiaoma.md +105 -0
  97. package/docs/zh-cn/how-to/non-interactive-installation.md +181 -0
  98. package/docs/zh-cn/how-to/project-context.md +152 -0
  99. package/docs/zh-cn/how-to/quick-fixes.md +140 -0
  100. package/docs/zh-cn/how-to/shard-large-documents.md +86 -0
  101. package/docs/zh-cn/how-to/upgrade-to-v6.md +120 -0
  102. package/docs/zh-cn/index.md +69 -0
  103. package/docs/zh-cn/reference/agents.md +41 -0
  104. package/docs/zh-cn/reference/commands.md +166 -0
  105. package/docs/zh-cn/reference/modules.md +94 -0
  106. package/docs/zh-cn/reference/testing.md +122 -0
  107. package/docs/zh-cn/reference/workflow-map.md +104 -0
  108. package/docs/zh-cn/roadmap.mdx +152 -0
  109. package/docs/zh-cn/tutorials/getting-started.md +300 -0
  110. package/eslint.config.mjs +144 -0
  111. package/package.json +56 -58
  112. package/prettier.config.mjs +32 -0
  113. package/src/core/_module-installer/install-config.yaml +29 -0
  114. package/src/core/_module-installer/installer.js +60 -0
  115. package/src/core/agents/xiaoma-master.agent.yaml +30 -0
  116. package/src/core/agents/xiaoma-skill-manifest.yaml +3 -0
  117. package/src/core/agents/xiaoma-web-orchestrator.agent.xml +113 -0
  118. package/src/core/module-help.csv +10 -0
  119. package/src/core/module.yaml +25 -0
  120. package/src/core/resources/excalidraw/README.md +160 -0
  121. package/src/core/resources/excalidraw/excalidraw-helpers.md +127 -0
  122. package/src/core/resources/excalidraw/library-loader.md +50 -0
  123. package/src/core/resources/excalidraw/validate-json-instructions.md +79 -0
  124. package/src/core/tasks/advanced-elicitation-methods.csv +51 -0
  125. package/src/core/tasks/advanced-elicitation.xml +116 -0
  126. package/src/core/tasks/editorial-review-prose.xml +102 -0
  127. package/src/core/tasks/editorial-review-structure.xml +208 -0
  128. package/src/core/tasks/help.md +92 -0
  129. package/src/core/tasks/index-docs.xml +65 -0
  130. package/src/core/tasks/review-adversarial-general.xml +49 -0
  131. package/src/core/tasks/review-edge-case-hunter.xml +63 -0
  132. package/src/core/tasks/shard-doc.xml +108 -0
  133. package/src/core/tasks/validate-workflow.xml +89 -0
  134. package/src/core/tasks/workflow.xml +235 -0
  135. package/src/core/tasks/xiaoma-help/SKILL.md +6 -0
  136. package/src/core/tasks/xiaoma-help/workflow.md +88 -0
  137. package/src/core/tasks/xiaoma-help/xiaoma-skill-manifest.yaml +1 -0
  138. package/src/core/tasks/xiaoma-review-adversarial-general/SKILL.md +6 -0
  139. package/src/core/tasks/xiaoma-review-adversarial-general/workflow.md +32 -0
  140. package/src/core/tasks/xiaoma-review-adversarial-general/xiaoma-skill-manifest.yaml +1 -0
  141. package/src/core/tasks/xiaoma-review-edge-case-hunter/SKILL.md +6 -0
  142. package/src/core/tasks/xiaoma-review-edge-case-hunter/workflow.md +62 -0
  143. package/src/core/tasks/xiaoma-review-edge-case-hunter/xiaoma-skill-manifest.yaml +1 -0
  144. package/src/core/tasks/xiaoma-skill-manifest.yaml +19 -0
  145. package/src/core/tools/shard-doc.xml +109 -0
  146. package/src/core/workflows/advanced-elicitation/methods.csv +51 -0
  147. package/src/core/workflows/advanced-elicitation/workflow.md +138 -0
  148. package/src/core/workflows/advanced-elicitation/workflow.xml +118 -0
  149. package/src/core/workflows/advanced-elicitation/xiaoma-skill-manifest.yaml +3 -0
  150. package/src/core/workflows/brainstorming/brain-methods.csv +62 -0
  151. package/src/core/workflows/brainstorming/steps/step-01-session-setup.md +210 -0
  152. package/src/core/workflows/brainstorming/steps/step-01b-continue.md +122 -0
  153. package/src/core/workflows/brainstorming/steps/step-02a-user-selected.md +225 -0
  154. package/src/core/workflows/brainstorming/steps/step-02b-ai-recommended.md +237 -0
  155. package/src/core/workflows/brainstorming/steps/step-02c-random-selection.md +209 -0
  156. package/src/core/workflows/brainstorming/steps/step-02d-progressive-flow.md +264 -0
  157. package/src/core/workflows/brainstorming/steps/step-03-technique-execution.md +399 -0
  158. package/src/core/workflows/brainstorming/steps/step-04-idea-organization.md +303 -0
  159. package/src/core/workflows/brainstorming/template.md +15 -0
  160. package/src/core/workflows/brainstorming/workflow.md +60 -0
  161. package/src/core/workflows/brainstorming/xiaoma-skill-manifest.yaml +3 -0
  162. package/src/core/workflows/party-mode/steps/step-01-agent-loading.md +138 -0
  163. package/src/core/workflows/party-mode/steps/step-02-discussion-orchestration.md +187 -0
  164. package/src/core/workflows/party-mode/steps/step-03-graceful-exit.md +168 -0
  165. package/src/core/workflows/party-mode/workflow.md +194 -0
  166. package/src/core/workflows/party-mode/xiaoma-skill-manifest.yaml +3 -0
  167. package/src/utility/agent-components/activation-rules.txt +6 -0
  168. package/src/utility/agent-components/activation-steps.txt +14 -0
  169. package/src/utility/agent-components/agent-command-header.md +1 -0
  170. package/src/utility/agent-components/agent.customize.template.yaml +41 -0
  171. package/src/utility/agent-components/handler-action.txt +4 -0
  172. package/src/utility/agent-components/handler-data.txt +5 -0
  173. package/src/utility/agent-components/handler-exec.txt +6 -0
  174. package/src/utility/agent-components/handler-multi.txt +13 -0
  175. package/src/utility/agent-components/handler-tmpl.txt +5 -0
  176. package/src/utility/agent-components/handler-validate-workflow.txt +7 -0
  177. package/src/utility/agent-components/handler-workflow.txt +10 -0
  178. package/src/utility/agent-components/menu-handlers.txt +6 -0
  179. package/src/utility/models/action-command-header.md +0 -0
  180. package/src/utility/models/agent-activation-ide.xml +51 -0
  181. package/src/utility/models/agent-activation-web.xml +50 -0
  182. package/src/utility/models/agent-command-header.md +1 -0
  183. package/src/utility/models/agent-config-template.md +23 -0
  184. package/src/utility/models/agent-in-team-activation.xml +3 -0
  185. package/src/utility/models/fragments/activation-rules.xml +7 -0
  186. package/src/utility/models/fragments/activation-steps.xml +16 -0
  187. package/src/utility/models/fragments/handler-action.xml +4 -0
  188. package/src/utility/models/fragments/handler-data.xml +5 -0
  189. package/src/utility/models/fragments/handler-exec.xml +6 -0
  190. package/src/utility/models/fragments/handler-multi.xml +14 -0
  191. package/src/utility/models/fragments/handler-tmpl.xml +5 -0
  192. package/src/utility/models/fragments/handler-validate-workflow.xml +7 -0
  193. package/src/utility/models/fragments/handler-workflow.xml +9 -0
  194. package/src/utility/models/fragments/menu-handlers.xml +6 -0
  195. package/src/utility/models/fragments/web-bundle-activation-steps.xml +32 -0
  196. package/src/utility/templates/agent.customize.template.yaml +42 -0
  197. package/src/xmc/_module-installer/install-config.yaml +53 -0
  198. package/src/xmc/_module-installer/installer.js +131 -0
  199. package/src/xmc/_module-installer/platform-specifics/claude-code.js +35 -0
  200. package/src/xmc/_module-installer/platform-specifics/windsurf.js +32 -0
  201. package/src/xmc/agents/analyst.agent.yaml +43 -0
  202. package/src/xmc/agents/architect.agent.yaml +29 -0
  203. package/src/xmc/agents/dev.agent.yaml +38 -0
  204. package/src/xmc/agents/pm.agent.yaml +44 -0
  205. package/src/xmc/agents/qa.agent.yaml +58 -0
  206. package/src/xmc/agents/quick-flow-solo-dev.agent.yaml +36 -0
  207. package/src/xmc/agents/sm.agent.yaml +37 -0
  208. package/src/xmc/agents/tech-writer/tech-writer-sidecar/documentation-standards.md +224 -0
  209. package/src/xmc/agents/tech-writer/tech-writer.agent.yaml +46 -0
  210. package/src/xmc/agents/tech-writer/xiaoma-skill-manifest.yaml +3 -0
  211. package/src/xmc/agents/ux-designer.agent.yaml +27 -0
  212. package/src/xmc/agents/xiaoma-skill-manifest.yaml +39 -0
  213. package/src/xmc/data/project-context-template.md +26 -0
  214. package/src/xmc/module-help.csv +32 -0
  215. package/src/xmc/module.yaml +50 -0
  216. package/src/xmc/sub-modules/claude-code/config.yaml +5 -0
  217. package/src/xmc/sub-modules/claude-code/injections.yaml +242 -0
  218. package/src/xmc/sub-modules/claude-code/readme.md +87 -0
  219. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-analysis/api-documenter.md +102 -0
  220. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-analysis/codebase-analyzer.md +82 -0
  221. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-analysis/data-analyst.md +101 -0
  222. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-analysis/pattern-detector.md +84 -0
  223. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/dependency-mapper.md +83 -0
  224. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/epic-optimizer.md +81 -0
  225. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/requirements-analyst.md +61 -0
  226. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/technical-decisions-curator.md +168 -0
  227. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/trend-spotter.md +115 -0
  228. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/user-journey-mapper.md +123 -0
  229. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/user-researcher.md +72 -0
  230. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-research/market-researcher.md +51 -0
  231. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-research/tech-debt-auditor.md +106 -0
  232. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-review/document-reviewer.md +102 -0
  233. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-review/technical-evaluator.md +68 -0
  234. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-review/test-coverage-analyzer.md +108 -0
  235. package/src/xmc/teams/default-party.csv +20 -0
  236. package/src/xmc/teams/team-fullstack.yaml +12 -0
  237. package/src/xmc/testarch/knowledge/api-request.md +303 -0
  238. package/src/xmc/testarch/knowledge/auth-session.md +356 -0
  239. package/src/xmc/testarch/knowledge/burn-in.md +273 -0
  240. package/src/xmc/testarch/knowledge/ci-burn-in.md +675 -0
  241. package/src/xmc/testarch/knowledge/component-tdd.md +486 -0
  242. package/src/xmc/testarch/knowledge/contract-testing.md +957 -0
  243. package/src/xmc/testarch/knowledge/data-factories.md +500 -0
  244. package/src/xmc/testarch/knowledge/email-auth.md +721 -0
  245. package/src/xmc/testarch/knowledge/error-handling.md +725 -0
  246. package/src/xmc/testarch/knowledge/feature-flags.md +750 -0
  247. package/src/xmc/testarch/knowledge/file-utils.md +260 -0
  248. package/src/xmc/testarch/knowledge/fixture-architecture.md +401 -0
  249. package/src/xmc/testarch/knowledge/fixtures-composition.md +382 -0
  250. package/src/xmc/testarch/knowledge/intercept-network-call.md +280 -0
  251. package/src/xmc/testarch/knowledge/log.md +294 -0
  252. package/src/xmc/testarch/knowledge/network-error-monitor.md +272 -0
  253. package/src/xmc/testarch/knowledge/network-first.md +486 -0
  254. package/src/xmc/testarch/knowledge/network-recorder.md +265 -0
  255. package/src/xmc/testarch/knowledge/nfr-criteria.md +670 -0
  256. package/src/xmc/testarch/knowledge/overview.md +284 -0
  257. package/src/xmc/testarch/knowledge/playwright-config.md +730 -0
  258. package/src/xmc/testarch/knowledge/probability-impact.md +601 -0
  259. package/src/xmc/testarch/knowledge/recurse.md +296 -0
  260. package/src/xmc/testarch/knowledge/risk-governance.md +615 -0
  261. package/src/xmc/testarch/knowledge/selective-testing.md +732 -0
  262. package/src/xmc/testarch/knowledge/selector-resilience.md +527 -0
  263. package/src/xmc/testarch/knowledge/test-healing-patterns.md +644 -0
  264. package/src/xmc/testarch/knowledge/test-levels-framework.md +473 -0
  265. package/src/xmc/testarch/knowledge/test-priorities-matrix.md +373 -0
  266. package/src/xmc/testarch/knowledge/test-quality.md +664 -0
  267. package/src/xmc/testarch/knowledge/timing-debugging.md +372 -0
  268. package/src/xmc/testarch/knowledge/visual-debugging.md +524 -0
  269. package/src/xmc/testarch/tea-index.csv +33 -0
  270. package/src/xmc/workflows/1-analysis/create-product-brief/product-brief.template.md +10 -0
  271. package/src/xmc/workflows/1-analysis/create-product-brief/steps/step-01-init.md +177 -0
  272. package/src/xmc/workflows/1-analysis/create-product-brief/steps/step-01b-continue.md +161 -0
  273. package/src/xmc/workflows/1-analysis/create-product-brief/steps/step-02-vision.md +199 -0
  274. package/src/xmc/workflows/1-analysis/create-product-brief/steps/step-03-users.md +202 -0
  275. package/src/xmc/workflows/1-analysis/create-product-brief/steps/step-04-metrics.md +205 -0
  276. package/src/xmc/workflows/1-analysis/create-product-brief/steps/step-05-scope.md +219 -0
  277. package/src/xmc/workflows/1-analysis/create-product-brief/steps/step-06-complete.md +162 -0
  278. package/src/xmc/workflows/1-analysis/create-product-brief/workflow.md +57 -0
  279. package/src/xmc/workflows/1-analysis/create-product-brief/xiaoma-skill-manifest.yaml +3 -0
  280. package/src/xmc/workflows/1-analysis/research/domain-steps/step-01-init.md +137 -0
  281. package/src/xmc/workflows/1-analysis/research/domain-steps/step-02-domain-analysis.md +229 -0
  282. package/src/xmc/workflows/1-analysis/research/domain-steps/step-03-competitive-landscape.md +238 -0
  283. package/src/xmc/workflows/1-analysis/research/domain-steps/step-04-regulatory-focus.md +206 -0
  284. package/src/xmc/workflows/1-analysis/research/domain-steps/step-05-technical-trends.md +234 -0
  285. package/src/xmc/workflows/1-analysis/research/domain-steps/step-06-research-synthesis.md +444 -0
  286. package/src/xmc/workflows/1-analysis/research/market-steps/step-01-init.md +182 -0
  287. package/src/xmc/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +237 -0
  288. package/src/xmc/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +249 -0
  289. package/src/xmc/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +259 -0
  290. package/src/xmc/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +177 -0
  291. package/src/xmc/workflows/1-analysis/research/market-steps/step-06-research-completion.md +476 -0
  292. package/src/xmc/workflows/1-analysis/research/research.template.md +29 -0
  293. package/src/xmc/workflows/1-analysis/research/technical-steps/step-01-init.md +137 -0
  294. package/src/xmc/workflows/1-analysis/research/technical-steps/step-02-technical-overview.md +239 -0
  295. package/src/xmc/workflows/1-analysis/research/technical-steps/step-03-integration-patterns.md +248 -0
  296. package/src/xmc/workflows/1-analysis/research/technical-steps/step-04-architectural-patterns.md +202 -0
  297. package/src/xmc/workflows/1-analysis/research/technical-steps/step-05-implementation-research.md +233 -0
  298. package/src/xmc/workflows/1-analysis/research/technical-steps/step-06-research-synthesis.md +487 -0
  299. package/src/xmc/workflows/1-analysis/research/workflow-domain-research.md +54 -0
  300. package/src/xmc/workflows/1-analysis/research/workflow-market-research.md +54 -0
  301. package/src/xmc/workflows/1-analysis/research/workflow-technical-research.md +54 -0
  302. package/src/xmc/workflows/1-analysis/research/xiaoma-skill-manifest.yaml +14 -0
  303. package/src/xmc/workflows/2-plan-workflows/create-prd/data/domain-complexity.csv +15 -0
  304. package/src/xmc/workflows/2-plan-workflows/create-prd/data/prd-purpose.md +197 -0
  305. package/src/xmc/workflows/2-plan-workflows/create-prd/data/project-types.csv +11 -0
  306. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-01-init.md +191 -0
  307. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-01b-continue.md +152 -0
  308. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-02-discovery.md +224 -0
  309. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-02b-vision.md +154 -0
  310. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-02c-executive-summary.md +170 -0
  311. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-03-success.md +226 -0
  312. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-04-journeys.md +213 -0
  313. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-05-domain.md +207 -0
  314. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-06-innovation.md +226 -0
  315. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-07-project-type.md +237 -0
  316. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-08-scoping.md +228 -0
  317. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-09-functional.md +231 -0
  318. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-10-nonfunctional.md +242 -0
  319. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-11-polish.md +217 -0
  320. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-c/step-12-complete.md +124 -0
  321. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-e/step-e-01-discovery.md +247 -0
  322. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-e/step-e-01b-legacy-conversion.md +208 -0
  323. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-e/step-e-02-review.md +249 -0
  324. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-e/step-e-03-edit.md +253 -0
  325. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-e/step-e-04-complete.md +168 -0
  326. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-01-discovery.md +226 -0
  327. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-02-format-detection.md +191 -0
  328. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-02b-parity-check.md +209 -0
  329. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-03-density-validation.md +174 -0
  330. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-04-brief-coverage-validation.md +214 -0
  331. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-05-measurability-validation.md +228 -0
  332. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-06-traceability-validation.md +217 -0
  333. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-07-implementation-leakage-validation.md +205 -0
  334. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-08-domain-compliance-validation.md +243 -0
  335. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-09-project-type-validation.md +263 -0
  336. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-10-smart-validation.md +209 -0
  337. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-11-holistic-quality-validation.md +264 -0
  338. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-12-completeness-validation.md +242 -0
  339. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +231 -0
  340. package/src/xmc/workflows/2-plan-workflows/create-prd/templates/prd-template.md +10 -0
  341. package/src/xmc/workflows/2-plan-workflows/create-prd/workflow-create-prd.md +63 -0
  342. package/src/xmc/workflows/2-plan-workflows/create-prd/workflow-edit-prd.md +65 -0
  343. package/src/xmc/workflows/2-plan-workflows/create-prd/workflow-validate-prd.md +63 -0
  344. package/src/xmc/workflows/2-plan-workflows/create-prd/xiaoma-skill-manifest.yaml +14 -0
  345. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-01-init.md +135 -0
  346. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-01b-continue.md +127 -0
  347. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-02-discovery.md +190 -0
  348. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-03-core-experience.md +216 -0
  349. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-04-emotional-response.md +219 -0
  350. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-05-inspiration.md +234 -0
  351. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-06-design-system.md +252 -0
  352. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-07-defining-experience.md +254 -0
  353. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-08-visual-foundation.md +224 -0
  354. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-09-design-directions.md +224 -0
  355. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-10-user-journeys.md +241 -0
  356. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-11-component-strategy.md +248 -0
  357. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-12-ux-patterns.md +237 -0
  358. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-13-responsive-accessibility.md +264 -0
  359. package/src/xmc/workflows/2-plan-workflows/create-ux-design/steps/step-14-complete.md +171 -0
  360. package/src/xmc/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +13 -0
  361. package/src/xmc/workflows/2-plan-workflows/create-ux-design/workflow.md +42 -0
  362. package/src/xmc/workflows/2-plan-workflows/create-ux-design/xiaoma-skill-manifest.yaml +3 -0
  363. package/src/xmc/workflows/3-solutioning/check-implementation-readiness/steps/step-01-document-discovery.md +184 -0
  364. package/src/xmc/workflows/3-solutioning/check-implementation-readiness/steps/step-02-prd-analysis.md +172 -0
  365. package/src/xmc/workflows/3-solutioning/check-implementation-readiness/steps/step-03-epic-coverage-validation.md +173 -0
  366. package/src/xmc/workflows/3-solutioning/check-implementation-readiness/steps/step-04-ux-alignment.md +133 -0
  367. package/src/xmc/workflows/3-solutioning/check-implementation-readiness/steps/step-05-epic-quality-review.md +245 -0
  368. package/src/xmc/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +129 -0
  369. package/src/xmc/workflows/3-solutioning/check-implementation-readiness/templates/readiness-report-template.md +4 -0
  370. package/src/xmc/workflows/3-solutioning/check-implementation-readiness/workflow.md +54 -0
  371. package/src/xmc/workflows/3-solutioning/check-implementation-readiness/xiaoma-skill-manifest.yaml +3 -0
  372. package/src/xmc/workflows/3-solutioning/create-architecture/architecture-decision-template.md +12 -0
  373. package/src/xmc/workflows/3-solutioning/create-architecture/data/domain-complexity.csv +13 -0
  374. package/src/xmc/workflows/3-solutioning/create-architecture/data/project-types.csv +7 -0
  375. package/src/xmc/workflows/3-solutioning/create-architecture/steps/step-01-init.md +153 -0
  376. package/src/xmc/workflows/3-solutioning/create-architecture/steps/step-01b-continue.md +173 -0
  377. package/src/xmc/workflows/3-solutioning/create-architecture/steps/step-02-context.md +224 -0
  378. package/src/xmc/workflows/3-solutioning/create-architecture/steps/step-03-starter.md +329 -0
  379. package/src/xmc/workflows/3-solutioning/create-architecture/steps/step-04-decisions.md +318 -0
  380. package/src/xmc/workflows/3-solutioning/create-architecture/steps/step-05-patterns.md +359 -0
  381. package/src/xmc/workflows/3-solutioning/create-architecture/steps/step-06-structure.md +379 -0
  382. package/src/xmc/workflows/3-solutioning/create-architecture/steps/step-07-validation.md +359 -0
  383. package/src/xmc/workflows/3-solutioning/create-architecture/steps/step-08-complete.md +76 -0
  384. package/src/xmc/workflows/3-solutioning/create-architecture/workflow.md +49 -0
  385. package/src/xmc/workflows/3-solutioning/create-architecture/xiaoma-skill-manifest.yaml +3 -0
  386. package/src/xmc/workflows/3-solutioning/create-epics-and-stories/steps/step-01-validate-prerequisites.md +259 -0
  387. package/src/xmc/workflows/3-solutioning/create-epics-and-stories/steps/step-02-design-epics.md +233 -0
  388. package/src/xmc/workflows/3-solutioning/create-epics-and-stories/steps/step-03-create-stories.md +272 -0
  389. package/src/xmc/workflows/3-solutioning/create-epics-and-stories/steps/step-04-final-validation.md +149 -0
  390. package/src/xmc/workflows/3-solutioning/create-epics-and-stories/templates/epics-template.md +57 -0
  391. package/src/xmc/workflows/3-solutioning/create-epics-and-stories/workflow.md +58 -0
  392. package/src/xmc/workflows/3-solutioning/create-epics-and-stories/xiaoma-skill-manifest.yaml +3 -0
  393. package/src/xmc/workflows/4-implementation/code-review/checklist.md +23 -0
  394. package/src/xmc/workflows/4-implementation/code-review/discover-inputs.md +88 -0
  395. package/src/xmc/workflows/4-implementation/code-review/workflow.md +271 -0
  396. package/src/xmc/workflows/4-implementation/code-review/xiaoma-skill-manifest.yaml +3 -0
  397. package/src/xmc/workflows/4-implementation/correct-course/checklist.md +288 -0
  398. package/src/xmc/workflows/4-implementation/correct-course/workflow.md +274 -0
  399. package/src/xmc/workflows/4-implementation/correct-course/xiaoma-skill-manifest.yaml +3 -0
  400. package/src/xmc/workflows/4-implementation/create-story/checklist.md +357 -0
  401. package/src/xmc/workflows/4-implementation/create-story/discover-inputs.md +88 -0
  402. package/src/xmc/workflows/4-implementation/create-story/template.md +49 -0
  403. package/src/xmc/workflows/4-implementation/create-story/workflow.md +388 -0
  404. package/src/xmc/workflows/4-implementation/create-story/xiaoma-skill-manifest.yaml +3 -0
  405. package/src/xmc/workflows/4-implementation/dev-story/checklist.md +80 -0
  406. package/src/xmc/workflows/4-implementation/dev-story/workflow.md +457 -0
  407. package/src/xmc/workflows/4-implementation/dev-story/xiaoma-skill-manifest.yaml +3 -0
  408. package/src/xmc/workflows/4-implementation/retrospective/workflow.md +1485 -0
  409. package/src/xmc/workflows/4-implementation/retrospective/xiaoma-skill-manifest.yaml +3 -0
  410. package/src/xmc/workflows/4-implementation/sprint-planning/checklist.md +33 -0
  411. package/src/xmc/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +56 -0
  412. package/src/xmc/workflows/4-implementation/sprint-planning/workflow.md +271 -0
  413. package/src/xmc/workflows/4-implementation/sprint-planning/xiaoma-skill-manifest.yaml +3 -0
  414. package/src/xmc/workflows/4-implementation/sprint-status/workflow.md +267 -0
  415. package/src/xmc/workflows/4-implementation/sprint-status/xiaoma-skill-manifest.yaml +3 -0
  416. package/src/xmc/workflows/document-project/checklist.md +245 -0
  417. package/src/xmc/workflows/document-project/documentation-requirements.csv +12 -0
  418. package/src/xmc/workflows/document-project/instructions.md +128 -0
  419. package/src/xmc/workflows/document-project/templates/deep-dive-template.md +345 -0
  420. package/src/xmc/workflows/document-project/templates/index-template.md +169 -0
  421. package/src/xmc/workflows/document-project/templates/project-overview-template.md +103 -0
  422. package/src/xmc/workflows/document-project/templates/project-scan-report-schema.json +160 -0
  423. package/src/xmc/workflows/document-project/templates/source-tree-template.md +135 -0
  424. package/src/xmc/workflows/document-project/workflow.md +39 -0
  425. package/src/xmc/workflows/document-project/workflows/deep-dive-instructions.md +297 -0
  426. package/src/xmc/workflows/document-project/workflows/deep-dive-workflow.md +42 -0
  427. package/src/xmc/workflows/document-project/workflows/full-scan-instructions.md +1105 -0
  428. package/src/xmc/workflows/document-project/workflows/full-scan-workflow.md +42 -0
  429. package/src/xmc/workflows/document-project/xiaoma-skill-manifest.yaml +3 -0
  430. package/src/xmc/workflows/generate-project-context/project-context-template.md +21 -0
  431. package/src/xmc/workflows/generate-project-context/steps/step-01-discover.md +184 -0
  432. package/src/xmc/workflows/generate-project-context/steps/step-02-generate.md +318 -0
  433. package/src/xmc/workflows/generate-project-context/steps/step-03-complete.md +278 -0
  434. package/src/xmc/workflows/generate-project-context/workflow.md +49 -0
  435. package/src/xmc/workflows/generate-project-context/xiaoma-skill-manifest.yaml +3 -0
  436. package/src/xmc/workflows/qa-generate-e2e-tests/checklist.md +33 -0
  437. package/src/xmc/workflows/qa-generate-e2e-tests/workflow.md +143 -0
  438. package/src/xmc/workflows/qa-generate-e2e-tests/xiaoma-skill-manifest.yaml +3 -0
  439. package/src/xmc/workflows/xiaoma-quick-flow/quick-dev/steps/step-01-mode-detection.md +174 -0
  440. package/src/xmc/workflows/xiaoma-quick-flow/quick-dev/steps/step-02-context-gathering.md +118 -0
  441. package/src/xmc/workflows/xiaoma-quick-flow/quick-dev/steps/step-03-execute.md +111 -0
  442. package/src/xmc/workflows/xiaoma-quick-flow/quick-dev/steps/step-04-self-check.md +111 -0
  443. package/src/xmc/workflows/xiaoma-quick-flow/quick-dev/steps/step-05-adversarial-review.md +98 -0
  444. package/src/xmc/workflows/xiaoma-quick-flow/quick-dev/steps/step-06-resolve-findings.md +146 -0
  445. package/src/xmc/workflows/xiaoma-quick-flow/quick-dev/workflow.md +50 -0
  446. package/src/xmc/workflows/xiaoma-quick-flow/quick-dev/xiaoma-skill-manifest.yaml +3 -0
  447. package/src/xmc/workflows/xiaoma-quick-flow/quick-spec/steps/step-01-understand.md +189 -0
  448. package/src/xmc/workflows/xiaoma-quick-flow/quick-spec/steps/step-02-investigate.md +143 -0
  449. package/src/xmc/workflows/xiaoma-quick-flow/quick-spec/steps/step-03-generate.md +126 -0
  450. package/src/xmc/workflows/xiaoma-quick-flow/quick-spec/steps/step-04-review.md +198 -0
  451. package/src/xmc/workflows/xiaoma-quick-flow/quick-spec/tech-spec-template.md +74 -0
  452. package/src/xmc/workflows/xiaoma-quick-flow/quick-spec/workflow.md +79 -0
  453. package/src/xmc/workflows/xiaoma-quick-flow/quick-spec/xiaoma-skill-manifest.yaml +3 -0
  454. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/SKILL.md +6 -0
  455. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-01-clarify-and-route.md +54 -0
  456. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-02-plan.md +39 -0
  457. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-03-implement.md +35 -0
  458. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-04-review.md +55 -0
  459. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-05-present.md +19 -0
  460. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/tech-spec-template.md +90 -0
  461. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/workflow.md +84 -0
  462. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/xiaoma-skill-manifest.yaml +1 -0
  463. package/test/README.md +295 -0
  464. package/test/adversarial-review-tests/README.md +56 -0
  465. package/test/adversarial-review-tests/sample-content.md +46 -0
  466. package/test/adversarial-review-tests/test-cases.yaml +103 -0
  467. package/test/fixtures/agent-schema/invalid/critical-actions/actions-as-string.agent.yaml +27 -0
  468. package/test/fixtures/agent-schema/invalid/critical-actions/empty-string-in-actions.agent.yaml +30 -0
  469. package/test/fixtures/agent-schema/invalid/menu/empty-menu.agent.yaml +22 -0
  470. package/test/fixtures/agent-schema/invalid/menu/missing-menu.agent.yaml +20 -0
  471. package/test/fixtures/agent-schema/invalid/menu-commands/empty-command-target.agent.yaml +25 -0
  472. package/test/fixtures/agent-schema/invalid/menu-commands/no-command-target.agent.yaml +24 -0
  473. package/test/fixtures/agent-schema/invalid/menu-triggers/camel-case.agent.yaml +25 -0
  474. package/test/fixtures/agent-schema/invalid/menu-triggers/compound-invalid-format.agent.yaml +25 -0
  475. package/test/fixtures/agent-schema/invalid/menu-triggers/compound-mismatched-kebab.agent.yaml +25 -0
  476. package/test/fixtures/agent-schema/invalid/menu-triggers/duplicate-triggers.agent.yaml +31 -0
  477. package/test/fixtures/agent-schema/invalid/menu-triggers/empty-trigger.agent.yaml +25 -0
  478. package/test/fixtures/agent-schema/invalid/menu-triggers/leading-asterisk.agent.yaml +25 -0
  479. package/test/fixtures/agent-schema/invalid/menu-triggers/snake-case.agent.yaml +25 -0
  480. package/test/fixtures/agent-schema/invalid/menu-triggers/trigger-with-spaces.agent.yaml +25 -0
  481. package/test/fixtures/agent-schema/invalid/metadata/empty-module-string.agent.yaml +26 -0
  482. package/test/fixtures/agent-schema/invalid/metadata/empty-name.agent.yaml +24 -0
  483. package/test/fixtures/agent-schema/invalid/metadata/extra-metadata-fields.agent.yaml +27 -0
  484. package/test/fixtures/agent-schema/invalid/metadata/missing-id.agent.yaml +23 -0
  485. package/test/fixtures/agent-schema/invalid/persona/empty-principles-array.agent.yaml +24 -0
  486. package/test/fixtures/agent-schema/invalid/persona/empty-string-in-principles.agent.yaml +27 -0
  487. package/test/fixtures/agent-schema/invalid/persona/extra-persona-fields.agent.yaml +27 -0
  488. package/test/fixtures/agent-schema/invalid/persona/missing-role.agent.yaml +24 -0
  489. package/test/fixtures/agent-schema/invalid/prompts/empty-content.agent.yaml +29 -0
  490. package/test/fixtures/agent-schema/invalid/prompts/extra-prompt-fields.agent.yaml +31 -0
  491. package/test/fixtures/agent-schema/invalid/prompts/missing-content.agent.yaml +28 -0
  492. package/test/fixtures/agent-schema/invalid/prompts/missing-id.agent.yaml +28 -0
  493. package/test/fixtures/agent-schema/invalid/top-level/empty-file.agent.yaml +5 -0
  494. package/test/fixtures/agent-schema/invalid/top-level/extra-top-level-keys.agent.yaml +28 -0
  495. package/test/fixtures/agent-schema/invalid/top-level/missing-agent-key.agent.yaml +11 -0
  496. package/test/fixtures/agent-schema/invalid/yaml-errors/invalid-indentation.agent.yaml +19 -0
  497. package/test/fixtures/agent-schema/invalid/yaml-errors/malformed-yaml.agent.yaml +18 -0
  498. package/test/fixtures/agent-schema/valid/critical-actions/empty-critical-actions.agent.yaml +24 -0
  499. package/test/fixtures/agent-schema/valid/critical-actions/no-critical-actions.agent.yaml +22 -0
  500. package/test/fixtures/agent-schema/valid/critical-actions/valid-critical-actions.agent.yaml +27 -0
  501. package/test/fixtures/agent-schema/valid/menu/multiple-menu-items.agent.yaml +31 -0
  502. package/test/fixtures/agent-schema/valid/menu/single-menu-item.agent.yaml +22 -0
  503. package/test/fixtures/agent-schema/valid/menu-commands/all-command-types.agent.yaml +38 -0
  504. package/test/fixtures/agent-schema/valid/menu-commands/multiple-commands.agent.yaml +23 -0
  505. package/test/fixtures/agent-schema/valid/menu-triggers/compound-triggers.agent.yaml +31 -0
  506. package/test/fixtures/agent-schema/valid/menu-triggers/kebab-case-triggers.agent.yaml +34 -0
  507. package/test/fixtures/agent-schema/valid/metadata/core-agent-with-module.agent.yaml +24 -0
  508. package/test/fixtures/agent-schema/valid/metadata/empty-module-name-in-path.agent.yaml +24 -0
  509. package/test/fixtures/agent-schema/valid/metadata/malformed-path-treated-as-core.agent.yaml +24 -0
  510. package/test/fixtures/agent-schema/valid/metadata/module-agent-correct.agent.yaml +24 -0
  511. package/test/fixtures/agent-schema/valid/metadata/module-agent-missing-module.agent.yaml +23 -0
  512. package/test/fixtures/agent-schema/valid/metadata/wrong-module-value.agent.yaml +24 -0
  513. package/test/fixtures/agent-schema/valid/persona/complete-persona.agent.yaml +24 -0
  514. package/test/fixtures/agent-schema/valid/prompts/empty-prompts.agent.yaml +24 -0
  515. package/test/fixtures/agent-schema/valid/prompts/no-prompts.agent.yaml +22 -0
  516. package/test/fixtures/agent-schema/valid/prompts/valid-prompts-minimal.agent.yaml +28 -0
  517. package/test/fixtures/agent-schema/valid/prompts/valid-prompts-with-description.agent.yaml +30 -0
  518. package/test/fixtures/agent-schema/valid/top-level/minimal-core-agent.agent.yaml +24 -0
  519. package/test/fixtures/file-refs-csv/invalid/all-empty-workflow.csv +3 -0
  520. package/test/fixtures/file-refs-csv/invalid/empty-data.csv +1 -0
  521. package/test/fixtures/file-refs-csv/invalid/no-workflow-column.csv +3 -0
  522. package/test/fixtures/file-refs-csv/invalid/unresolvable-vars.csv +3 -0
  523. package/test/fixtures/file-refs-csv/valid/core-style.csv +3 -0
  524. package/test/fixtures/file-refs-csv/valid/minimal.csv +2 -0
  525. package/test/fixtures/file-refs-csv/valid/xmc-style.csv +3 -0
  526. package/test/test-agent-schema.js +387 -0
  527. package/test/test-cli-integration.sh +159 -0
  528. package/test/test-file-refs-csv.js +133 -0
  529. package/test/test-install-to-xiaoma.js +154 -0
  530. package/test/test-installation-components.js +1802 -0
  531. package/test/test-rehype-plugins.mjs +1050 -0
  532. package/test/test-workflow-path-regex.js +88 -0
  533. package/test/unit-test-schema.js +133 -0
  534. package/tools/build-docs.mjs +464 -0
  535. package/tools/cli/README.md +60 -0
  536. package/tools/cli/bundlers/bundle-web.js +179 -0
  537. package/tools/cli/bundlers/bundlers/bundle-web.js +179 -0
  538. package/tools/cli/bundlers/bundlers/test-analyst.js +28 -0
  539. package/tools/cli/bundlers/bundlers/test-bundler.js +119 -0
  540. package/tools/cli/bundlers/bundlers/web-bundler.js +1754 -0
  541. package/tools/cli/bundlers/test-analyst.js +28 -0
  542. package/tools/cli/bundlers/test-bundler.js +119 -0
  543. package/tools/cli/bundlers/web-bundler.js +1754 -0
  544. package/tools/cli/commands/agent-install.js +409 -0
  545. package/tools/cli/commands/build.js +458 -0
  546. package/tools/cli/commands/cleanup.js +144 -0
  547. package/tools/cli/commands/install.js +87 -0
  548. package/tools/cli/commands/list.js +43 -0
  549. package/tools/cli/commands/status.js +65 -0
  550. package/tools/cli/commands/uninstall.js +167 -0
  551. package/tools/cli/commands/update.js +28 -0
  552. package/tools/cli/external-official-modules.yaml +53 -0
  553. package/tools/cli/installers/install-messages.yaml +39 -0
  554. package/tools/cli/installers/lib/core/config-collector.js +1285 -0
  555. package/tools/cli/installers/lib/core/custom-module-cache.js +260 -0
  556. package/tools/cli/installers/lib/core/dependency-resolver.js +743 -0
  557. package/tools/cli/installers/lib/core/detector.js +223 -0
  558. package/tools/cli/installers/lib/core/ide-config-manager.js +157 -0
  559. package/tools/cli/installers/lib/core/installer.js +3195 -0
  560. package/tools/cli/installers/lib/core/manifest-generator.js +1374 -0
  561. package/tools/cli/installers/lib/core/manifest.js +1038 -0
  562. package/tools/cli/installers/lib/custom/handler.js +358 -0
  563. package/tools/cli/installers/lib/ide/_base-ide.js +674 -0
  564. package/tools/cli/installers/lib/ide/_config-driven.js +1053 -0
  565. package/tools/cli/installers/lib/ide/antigravity.js +510 -0
  566. package/tools/cli/installers/lib/ide/auggie.js +232 -0
  567. package/tools/cli/installers/lib/ide/claude-code.js +512 -0
  568. package/tools/cli/installers/lib/ide/cline.js +269 -0
  569. package/tools/cli/installers/lib/ide/codex.js +440 -0
  570. package/tools/cli/installers/lib/ide/crush.js +287 -0
  571. package/tools/cli/installers/lib/ide/cursor.js +400 -0
  572. package/tools/cli/installers/lib/ide/gemini.js +253 -0
  573. package/tools/cli/installers/lib/ide/github-copilot.js +699 -0
  574. package/tools/cli/installers/lib/ide/iflow.js +172 -0
  575. package/tools/cli/installers/lib/ide/kilo.js +269 -0
  576. package/tools/cli/installers/lib/ide/manager.js +304 -0
  577. package/tools/cli/installers/lib/ide/opencode.js +257 -0
  578. package/tools/cli/installers/lib/ide/platform-codes.js +100 -0
  579. package/tools/cli/installers/lib/ide/platform-codes.yaml +321 -0
  580. package/tools/cli/installers/lib/ide/qwen.js +372 -0
  581. package/tools/cli/installers/lib/ide/roo.js +324 -0
  582. package/tools/cli/installers/lib/ide/rovo-dev.js +290 -0
  583. package/tools/cli/installers/lib/ide/rovodev.js +257 -0
  584. package/tools/cli/installers/lib/ide/shared/agent-command-generator.js +181 -0
  585. package/tools/cli/installers/lib/ide/shared/module-injections.js +136 -0
  586. package/tools/cli/installers/lib/ide/shared/path-utils.js +364 -0
  587. package/tools/cli/installers/lib/ide/shared/skill-manifest.js +90 -0
  588. package/tools/cli/installers/lib/ide/shared/task-tool-command-generator.js +368 -0
  589. package/tools/cli/installers/lib/ide/shared/workflow-command-generator.js +179 -0
  590. package/tools/cli/installers/lib/ide/shared/xiaoma-artifacts.js +181 -0
  591. package/tools/cli/installers/lib/ide/templates/agent-command-template.md +14 -0
  592. package/tools/cli/installers/lib/ide/templates/combined/antigravity.md +8 -0
  593. package/tools/cli/installers/lib/ide/templates/combined/default-agent.md +15 -0
  594. package/tools/cli/installers/lib/ide/templates/combined/default-task.md +10 -0
  595. package/tools/cli/installers/lib/ide/templates/combined/default-tool.md +10 -0
  596. package/tools/cli/installers/lib/ide/templates/combined/default-workflow-yaml.md +14 -0
  597. package/tools/cli/installers/lib/ide/templates/combined/default-workflow.md +6 -0
  598. package/tools/cli/installers/lib/ide/templates/combined/gemini-agent.toml +14 -0
  599. package/tools/cli/installers/lib/ide/templates/combined/gemini-task.toml +11 -0
  600. package/tools/cli/installers/lib/ide/templates/combined/gemini-tool.toml +11 -0
  601. package/tools/cli/installers/lib/ide/templates/combined/gemini-workflow-yaml.toml +16 -0
  602. package/tools/cli/installers/lib/ide/templates/combined/gemini-workflow.toml +14 -0
  603. package/tools/cli/installers/lib/ide/templates/combined/kiro-agent.md +16 -0
  604. package/tools/cli/installers/lib/ide/templates/combined/kiro-task.md +9 -0
  605. package/tools/cli/installers/lib/ide/templates/combined/kiro-tool.md +9 -0
  606. package/tools/cli/installers/lib/ide/templates/combined/kiro-workflow-yaml.md +15 -0
  607. package/tools/cli/installers/lib/ide/templates/combined/kiro-workflow.md +7 -0
  608. package/tools/cli/installers/lib/ide/templates/combined/opencode-agent.md +15 -0
  609. package/tools/cli/installers/lib/ide/templates/combined/opencode-task.md +13 -0
  610. package/tools/cli/installers/lib/ide/templates/combined/opencode-tool.md +13 -0
  611. package/tools/cli/installers/lib/ide/templates/combined/opencode-workflow-yaml.md +16 -0
  612. package/tools/cli/installers/lib/ide/templates/combined/opencode-workflow.md +16 -0
  613. package/tools/cli/installers/lib/ide/templates/combined/rovodev.md +9 -0
  614. package/tools/cli/installers/lib/ide/templates/combined/trae.md +9 -0
  615. package/tools/cli/installers/lib/ide/templates/combined/windsurf-workflow.md +10 -0
  616. package/tools/cli/installers/lib/ide/templates/gemini-agent-command.toml +14 -0
  617. package/tools/cli/installers/lib/ide/templates/gemini-task-command.toml +12 -0
  618. package/tools/cli/installers/lib/ide/templates/split/.gitkeep +0 -0
  619. package/tools/cli/installers/lib/ide/templates/workflow-command-template.md +13 -0
  620. package/tools/cli/installers/lib/ide/templates/workflow-commander.md +5 -0
  621. package/tools/cli/installers/lib/ide/trae.js +313 -0
  622. package/tools/cli/installers/lib/ide/windsurf.js +258 -0
  623. package/tools/cli/installers/lib/message-loader.js +83 -0
  624. package/tools/cli/installers/lib/modules/external-manager.js +136 -0
  625. package/tools/cli/installers/lib/modules/manager.js +1382 -0
  626. package/tools/cli/lib/activation-builder.js +165 -0
  627. package/tools/cli/lib/agent/compiler.js +516 -0
  628. package/tools/cli/lib/agent/installer.js +680 -0
  629. package/tools/cli/lib/agent/template-engine.js +152 -0
  630. package/tools/cli/lib/agent-analyzer.js +97 -0
  631. package/tools/cli/lib/agent-party-generator.js +194 -0
  632. package/tools/cli/lib/cli-utils.js +182 -0
  633. package/tools/cli/lib/config.js +213 -0
  634. package/tools/cli/lib/file-ops.js +204 -0
  635. package/tools/cli/lib/platform-codes.js +116 -0
  636. package/tools/cli/lib/project-root.js +77 -0
  637. package/tools/cli/lib/prompts.js +809 -0
  638. package/tools/cli/lib/replace-project-root.js +239 -0
  639. package/tools/cli/lib/ui.js +1940 -0
  640. package/tools/cli/lib/xml-handler.js +177 -0
  641. package/tools/cli/lib/xml-to-markdown.js +82 -0
  642. package/tools/{yaml-format.js → cli/lib/yaml-format.js} +39 -71
  643. package/tools/cli/lib/yaml-xml-builder.js +570 -0
  644. package/tools/cli/regenerate-manifests.js +28 -0
  645. package/tools/cli/test-yaml-builder.js +43 -0
  646. package/tools/cli/xiaoma-cli.js +106 -0
  647. package/tools/docs/_prompt-external-modules-page.md +59 -0
  648. package/tools/docs/fix-refs.md +91 -0
  649. package/tools/docs/native-skills-migration-checklist.md +281 -0
  650. package/tools/fix-doc-links.js +285 -0
  651. package/tools/flattener/aggregate.js +12 -30
  652. package/tools/flattener/binary.js +43 -46
  653. package/tools/flattener/discovery.js +15 -23
  654. package/tools/flattener/files.js +6 -6
  655. package/tools/flattener/flattener/aggregate.js +76 -0
  656. package/tools/flattener/flattener/binary.js +80 -0
  657. package/tools/flattener/flattener/discovery.js +71 -0
  658. package/tools/flattener/flattener/files.js +35 -0
  659. package/tools/flattener/flattener/ignoreRules.js +172 -0
  660. package/tools/flattener/flattener/main.js +483 -0
  661. package/tools/flattener/flattener/projectRoot.js +201 -0
  662. package/tools/flattener/flattener/prompts.js +44 -0
  663. package/tools/flattener/flattener/stats.helpers.js +368 -0
  664. package/tools/flattener/flattener/stats.js +75 -0
  665. package/tools/flattener/flattener/test-matrix.js +409 -0
  666. package/tools/flattener/flattener/xml.js +88 -0
  667. package/tools/flattener/ignoreRules.js +122 -127
  668. package/tools/flattener/main.js +140 -330
  669. package/tools/flattener/projectRoot.js +71 -81
  670. package/tools/flattener/prompts.js +10 -12
  671. package/tools/flattener/stats.helpers.js +63 -119
  672. package/tools/flattener/stats.js +2 -7
  673. package/tools/flattener/test-matrix.js +169 -228
  674. package/tools/flattener/xml.js +23 -31
  675. package/tools/format-workflow-md.js +263 -0
  676. package/tools/lib/xml-utils.js +13 -0
  677. package/tools/migrate-custom-module-paths.js +124 -0
  678. package/tools/platform-codes.yaml +157 -0
  679. package/tools/schema/agent.js +489 -0
  680. package/tools/validate-agent-schema.js +110 -0
  681. package/tools/validate-bundles.js +87 -0
  682. package/tools/validate-doc-links.js +409 -0
  683. package/tools/validate-file-refs.js +556 -0
  684. package/tools/validate-svg-changes.sh +356 -0
  685. package/tools/xiaoma-npx-wrapper.js +18 -24
  686. package/web-bundles/xmc/agents/analyst.xml +109 -0
  687. package/web-bundles/xmc/agents/architect.xml +101 -0
  688. package/web-bundles/xmc/agents/dev.xml +106 -0
  689. package/web-bundles/xmc/agents/pm.xml +112 -0
  690. package/web-bundles/xmc/agents/qa.xml +126 -0
  691. package/web-bundles/xmc/agents/quick-flow-solo-dev.xml +104 -0
  692. package/web-bundles/xmc/agents/sm.xml +109 -0
  693. package/web-bundles/xmc/agents/ux-designer.xml +100 -0
  694. package/web-bundles/xmc/teams/team-fullstack.xml +1192 -0
  695. package/.claude/agents/tech-translator.md +0 -124
  696. package/.claude/settings.local.json +0 -37
  697. package/.idea/misc.xml +0 -6
  698. package/.xiaoma-core/.coordinator-state.json +0 -19
  699. package/CLAUDE.md +0 -283
  700. package/JAVA-BACKEND-COMMANDS-REFERENCE.md +0 -300
  701. package/JAVA-BACKEND-ITERATION-GUIDE.md +0 -2116
  702. package/common/tasks/create-doc.md +0 -103
  703. package/common/tasks/execute-checklist.md +0 -88
  704. package/common/utils/bmad-doc-template.md +0 -327
  705. package/common/utils/workflow-management.md +0 -71
  706. package/dist/agents/analyst.txt +0 -6308
  707. package/dist/agents/architect.txt +0 -5046
  708. package/dist/agents/automation-orchestrator.txt +0 -396
  709. package/dist/agents/dev.txt +0 -1180
  710. package/dist/agents/full-requirement-orchestrator.txt +0 -505
  711. package/dist/agents/pm.txt +0 -3078
  712. package/dist/agents/po.txt +0 -1358
  713. package/dist/agents/qa.txt +0 -2002
  714. package/dist/agents/sm.txt +0 -3044
  715. package/dist/agents/ux-expert.txt +0 -707
  716. package/dist/agents/workflow-executor.txt +0 -1029
  717. package/dist/agents/workflow-helper.txt +0 -93
  718. package/dist/agents/xiaoma-master.txt +0 -9008
  719. package/dist/agents/xiaoma-orchestrator.txt +0 -1523
  720. package/dist/teams/team-all.txt +0 -23101
  721. package/dist/teams/team-fullstack-with-database.txt +0 -25076
  722. package/dist/teams/team-fullstack.txt +0 -15820
  723. package/dist/teams/team-ide-minimal.txt +0 -8285
  724. package/dist/teams/team-no-ui.txt +0 -14368
  725. package/docs/GUIDING-PRINCIPLES.md +0 -91
  726. package/docs/architecture/workflow-coordinator-implementation.md +0 -1188
  727. package/docs/architecture-sharding-modification.md +0 -623
  728. package/docs/automated-requirements-analysis-outputs.md +0 -896
  729. package/docs/core-architecture.md +0 -219
  730. package/docs/enhanced-ide-development-workflow.md +0 -248
  731. package/docs/prd/workflow-coordinator-prd.md +0 -1214
  732. package/docs/user-guide.md +0 -530
  733. package/docs/versioning-and-releases.md +0 -155
  734. package/docs/versions.md +0 -48
  735. package/docs/working-in-the-brownfield.md +0 -597
  736. package/tools/api-server.js +0 -367
  737. package/tools/builders/web-builder.js +0 -830
  738. package/tools/bump-all-versions.js +0 -133
  739. package/tools/cli.js +0 -157
  740. package/tools/installer/README.md +0 -8
  741. package/tools/installer/bin/xiaoma.js +0 -477
  742. package/tools/installer/config/ide-agent-config.yaml +0 -58
  743. package/tools/installer/config/install.config.yaml +0 -164
  744. package/tools/installer/lib/config-loader.js +0 -286
  745. package/tools/installer/lib/file-manager.js +0 -446
  746. package/tools/installer/lib/ide-base-setup.js +0 -238
  747. package/tools/installer/lib/ide-setup.js +0 -2027
  748. package/tools/installer/lib/installer.js +0 -2333
  749. package/tools/installer/lib/memory-profiler.js +0 -235
  750. package/tools/installer/lib/module-manager.js +0 -116
  751. package/tools/installer/lib/resource-locator.js +0 -334
  752. package/tools/installer/package-lock.json +0 -715
  753. package/tools/installer/package.json +0 -44
  754. package/tools/lib/dependency-resolver.js +0 -186
  755. package/tools/lib/yaml-utils.js +0 -34
  756. package/tools/md-assets/web-agent-startup-instructions.md +0 -39
  757. package/tools/preview-release-notes.js +0 -74
  758. package/tools/setup-hooks.sh +0 -37
  759. package/tools/shared/bannerArt.js +0 -105
  760. package/tools/sync-installer-version.js +0 -41
  761. package/tools/sync-version.sh +0 -23
  762. package/tools/upgraders/v3-to-v4-upgrader.js +0 -753
  763. package/tools/version-bump.js +0 -100
  764. package/tools/workflow-coordinator/README.md +0 -38
  765. package/tools/workflow-coordinator/USAGE.md +0 -548
  766. package/tools/workflow-coordinator/package-lock.json +0 -4868
  767. package/tools/workflow-coordinator/package.json +0 -35
  768. package/tools/workflow-coordinator/src/api/server.js +0 -207
  769. package/tools/workflow-coordinator/src/controller/workflow-controller.js +0 -263
  770. package/tools/workflow-coordinator/src/index.js +0 -113
  771. package/tools/workflow-coordinator/src/parser/workflow-parser.js +0 -144
  772. package/tools/workflow-coordinator/src/utils/state-manager.js +0 -59
  773. package/tools/workflow-coordinator/src/utils/validator.js +0 -86
  774. package/tools/workflow-coordinator/test/integration-test.js +0 -266
  775. package/tools/workflow-coordinator/test/quick-test.js +0 -127
  776. package/xiaoma-core/agent-teams/team-all.yaml +0 -15
  777. package/xiaoma-core/agent-teams/team-fullstack-with-database.yaml +0 -27
  778. package/xiaoma-core/agent-teams/team-fullstack.yaml +0 -19
  779. package/xiaoma-core/agent-teams/team-ide-minimal.yaml +0 -11
  780. package/xiaoma-core/agent-teams/team-no-ui.yaml +0 -14
  781. package/xiaoma-core/agents/analyst.md +0 -91
  782. package/xiaoma-core/agents/architect.md +0 -88
  783. package/xiaoma-core/agents/automated-fix-validator.yaml +0 -579
  784. package/xiaoma-core/agents/automated-quality-validator.yaml +0 -549
  785. package/xiaoma-core/agents/automation-orchestrator.md +0 -353
  786. package/xiaoma-core/agents/dev.md +0 -144
  787. package/xiaoma-core/agents/enhanced-workflow-orchestrator.yaml +0 -304
  788. package/xiaoma-core/agents/full-requirement-orchestrator.md +0 -462
  789. package/xiaoma-core/agents/global-requirements-auditor.yaml +0 -520
  790. package/xiaoma-core/agents/intelligent-template-adapter.yaml +0 -389
  791. package/xiaoma-core/agents/issue-dispatcher.yaml +0 -627
  792. package/xiaoma-core/agents/master-execution-engine.yaml +0 -543
  793. package/xiaoma-core/agents/pm.md +0 -85
  794. package/xiaoma-core/agents/po.md +0 -77
  795. package/xiaoma-core/agents/qa.md +0 -88
  796. package/xiaoma-core/agents/requirements-coverage-auditor.yaml +0 -373
  797. package/xiaoma-core/agents/sm.md +0 -125
  798. package/xiaoma-core/agents/ux-expert.md +0 -67
  799. package/xiaoma-core/agents/workflow-executor.md +0 -1031
  800. package/xiaoma-core/agents/workflow-helper.md +0 -481
  801. package/xiaoma-core/agents/xiaoma-master.md +0 -108
  802. package/xiaoma-core/agents/xiaoma-orchestrator.md +0 -145
  803. package/xiaoma-core/checklists/architect-checklist.md +0 -440
  804. package/xiaoma-core/checklists/change-checklist.md +0 -184
  805. package/xiaoma-core/checklists/dev-completion-checklist.md +0 -324
  806. package/xiaoma-core/checklists/pm-checklist.md +0 -372
  807. package/xiaoma-core/checklists/po-master-checklist.md +0 -434
  808. package/xiaoma-core/checklists/po-story-validation-checklist.md +0 -219
  809. package/xiaoma-core/checklists/qa-approval-checklist.md +0 -393
  810. package/xiaoma-core/checklists/story-dod-checklist.md +0 -96
  811. package/xiaoma-core/checklists/story-draft-checklist.md +0 -155
  812. package/xiaoma-core/core-config.yaml +0 -23
  813. package/xiaoma-core/data/bmad-kb.md +0 -809
  814. package/xiaoma-core/data/brainstorming-techniques.md +0 -38
  815. package/xiaoma-core/data/elicitation-methods.md +0 -156
  816. package/xiaoma-core/data/technical-preferences.md +0 -5
  817. package/xiaoma-core/data/test-levels-framework.md +0 -148
  818. package/xiaoma-core/data/test-priorities-matrix.md +0 -174
  819. package/xiaoma-core/scripts/build-validation/pre-dev-validation.sh +0 -71
  820. package/xiaoma-core/scripts/build-validation/progressive-validation.sh +0 -88
  821. package/xiaoma-core/scripts/build-validation/quick-check.sh +0 -69
  822. package/xiaoma-core/tasks/advanced-elicitation.md +0 -119
  823. package/xiaoma-core/tasks/analyze-existing-database.md +0 -155
  824. package/xiaoma-core/tasks/apply-qa-fixes.md +0 -150
  825. package/xiaoma-core/tasks/automated-story-cycle.md +0 -370
  826. package/xiaoma-core/tasks/batch-story-generation.md +0 -354
  827. package/xiaoma-core/tasks/brownfield-create-epic.md +0 -162
  828. package/xiaoma-core/tasks/brownfield-create-story.md +0 -149
  829. package/xiaoma-core/tasks/correct-course.md +0 -72
  830. package/xiaoma-core/tasks/create-brownfield-story.md +0 -314
  831. package/xiaoma-core/tasks/create-database-design.md +0 -161
  832. package/xiaoma-core/tasks/create-deep-research-prompt.md +0 -280
  833. package/xiaoma-core/tasks/create-enhanced-story-with-database.md +0 -250
  834. package/xiaoma-core/tasks/create-incremental-architecture.md +0 -525
  835. package/xiaoma-core/tasks/create-next-story.md +0 -114
  836. package/xiaoma-core/tasks/create-prd-from-rag.md +0 -435
  837. package/xiaoma-core/tasks/create-story-with-rag.md +0 -559
  838. package/xiaoma-core/tasks/develop-story-with-rag.md +0 -536
  839. package/xiaoma-core/tasks/document-project.md +0 -345
  840. package/xiaoma-core/tasks/facilitate-brainstorming-session.md +0 -138
  841. package/xiaoma-core/tasks/generate-ai-frontend-prompt.md +0 -53
  842. package/xiaoma-core/tasks/generate-database-ddl.md +0 -240
  843. package/xiaoma-core/tasks/generate-database-entities.md +0 -501
  844. package/xiaoma-core/tasks/generate-rag-questions.md +0 -312
  845. package/xiaoma-core/tasks/index-docs.md +0 -175
  846. package/xiaoma-core/tasks/kb-mode-interaction.md +0 -77
  847. package/xiaoma-core/tasks/nfr-assess.md +0 -345
  848. package/xiaoma-core/tasks/project-integration-testing.md +0 -477
  849. package/xiaoma-core/tasks/qa-gate.md +0 -163
  850. package/xiaoma-core/tasks/requirement-analysis-with-rag.md +0 -1318
  851. package/xiaoma-core/tasks/requirements-coverage-audit.md +0 -198
  852. package/xiaoma-core/tasks/review-story.md +0 -316
  853. package/xiaoma-core/tasks/risk-profile.md +0 -355
  854. package/xiaoma-core/tasks/serial-development-orchestration.md +0 -426
  855. package/xiaoma-core/tasks/shard-doc.md +0 -187
  856. package/xiaoma-core/tasks/test-design.md +0 -176
  857. package/xiaoma-core/tasks/trace-requirements.md +0 -266
  858. package/xiaoma-core/tasks/validate-next-story.md +0 -136
  859. package/xiaoma-core/templates/api-design-tmpl.yaml +0 -704
  860. package/xiaoma-core/templates/architecture-tmpl.yaml +0 -650
  861. package/xiaoma-core/templates/brainstorming-output-tmpl.yaml +0 -156
  862. package/xiaoma-core/templates/brownfield-architecture-tmpl.yaml +0 -476
  863. package/xiaoma-core/templates/brownfield-prd-tmpl.yaml +0 -280
  864. package/xiaoma-core/templates/competitor-analysis-tmpl.yaml +0 -336
  865. package/xiaoma-core/templates/database-design-tmpl.yaml +0 -266
  866. package/xiaoma-core/templates/enhanced-story-with-database-tmpl.yaml +0 -428
  867. package/xiaoma-core/templates/front-end-architecture-tmpl.yaml +0 -272
  868. package/xiaoma-core/templates/front-end-spec-tmpl.yaml +0 -354
  869. package/xiaoma-core/templates/fullstack-architecture-tmpl.yaml +0 -925
  870. package/xiaoma-core/templates/global-qa-monitoring-tmpl.yaml +0 -443
  871. package/xiaoma-core/templates/incremental-architecture-tmpl.yaml +0 -601
  872. package/xiaoma-core/templates/market-research-tmpl.yaml +0 -252
  873. package/xiaoma-core/templates/maven-lombok-template.xml +0 -111
  874. package/xiaoma-core/templates/prd-from-rag-tmpl.yaml +0 -410
  875. package/xiaoma-core/templates/prd-tmpl.yaml +0 -202
  876. package/xiaoma-core/templates/project-brief-tmpl.yaml +0 -221
  877. package/xiaoma-core/templates/qa-gate-tmpl.yaml +0 -102
  878. package/xiaoma-core/templates/rag-knowledge-tmpl.yaml +0 -569
  879. package/xiaoma-core/templates/rag-questions-tmpl.yaml +0 -949
  880. package/xiaoma-core/templates/requirements-coverage-audit.yaml +0 -330
  881. package/xiaoma-core/templates/start-enhanced-workflow.yaml +0 -347
  882. package/xiaoma-core/templates/story-tmpl.yaml +0 -137
  883. package/xiaoma-core/templates/story-with-rag-tmpl.yaml +0 -360
  884. package/xiaoma-core/workflows/automated-requirements-analysis.yaml +0 -2149
  885. package/xiaoma-core/workflows/automated-requirements-development.yaml +0 -739
  886. package/xiaoma-core/workflows/automated-story-development.yaml +0 -1264
  887. package/xiaoma-core/workflows/brownfield-fullstack.yaml +0 -298
  888. package/xiaoma-core/workflows/brownfield-service.yaml +0 -188
  889. package/xiaoma-core/workflows/brownfield-ui.yaml +0 -198
  890. package/xiaoma-core/workflows/enhanced-fullstack-with-database.yaml +0 -427
  891. package/xiaoma-core/workflows/enhanced-fullstack-with-qa-loop.yaml +0 -766
  892. package/xiaoma-core/workflows/full-requirement-automation.yaml +0 -1305
  893. package/xiaoma-core/workflows/greenfield-fullstack.yaml +0 -241
  894. package/xiaoma-core/workflows/greenfield-service.yaml +0 -207
  895. package/xiaoma-core/workflows/greenfield-ui.yaml +0 -236
@@ -0,0 +1,1754 @@
1
+ const path = require('node:path');
2
+ const fs = require('fs-extra');
3
+ const chalk = require('chalk');
4
+ const yaml = require('js-yaml');
5
+ const { DependencyResolver } = require('../installers/lib/core/dependency-resolver');
6
+ const { XmlHandler } = require('../lib/xml-handler');
7
+ const { YamlXmlBuilder } = require('../lib/yaml-xml-builder');
8
+ const { AgentPartyGenerator } = require('../lib/agent-party-generator');
9
+ const xml2js = require('xml2js');
10
+ const { getProjectRoot, getSourcePath, getModulePath } = require('../lib/project-root');
11
+
12
+ class WebBundler {
13
+ constructor(sourceDir = null, outputDir = 'web-bundles') {
14
+ this.sourceDir = sourceDir || getSourcePath();
15
+ this.outputDir = path.isAbsolute(outputDir) ? outputDir : path.join(getProjectRoot(), outputDir);
16
+ this.utilityPath = getSourcePath('utility');
17
+
18
+ this.dependencyResolver = new DependencyResolver();
19
+ this.xmlHandler = new XmlHandler();
20
+ this.yamlBuilder = new YamlXmlBuilder();
21
+
22
+ // Cache for resolved dependencies to avoid duplicates
23
+ this.dependencyCache = new Map();
24
+
25
+ // Discovered agents and teams for manifest generation
26
+ this.discoveredAgents = [];
27
+ this.discoveredTeams = [];
28
+
29
+ // Temporary directory for generated manifests
30
+ this.tempDir = path.join(process.cwd(), '.bundler-temp');
31
+ this.tempManifestDir = path.join(this.tempDir, 'xiaoma', '_cfg');
32
+
33
+ // Bundle statistics
34
+ this.stats = {
35
+ totalAgents: 0,
36
+ bundledAgents: 0,
37
+ skippedAgents: 0,
38
+ failedAgents: 0,
39
+ invalidXml: 0,
40
+ warnings: [],
41
+ };
42
+ }
43
+
44
+ /**
45
+ * Main entry point to bundle all modules
46
+ */
47
+ async bundleAll() {
48
+ console.log(chalk.cyan.bold('═══════════════════════════════════════════════'));
49
+ console.log(chalk.cyan.bold(' 🚀 Web Bundle Generation'));
50
+ console.log(chalk.cyan.bold('═══════════════════════════════════════════════\n'));
51
+
52
+ try {
53
+ // Vendor cross-module workflows FIRST
54
+ const modules = await this.discoverModules();
55
+ for (const module of modules) {
56
+ await this.vendorCrossModuleWorkflows(module);
57
+ }
58
+
59
+ // Pre-discover all modules to generate complete manifests
60
+ for (const module of modules) {
61
+ await this.preDiscoverModule(module);
62
+ }
63
+
64
+ // Create temporary manifest files
65
+ await this.createTempManifests();
66
+
67
+ // Process all modules
68
+ for (const module of modules) {
69
+ await this.bundleModule(module);
70
+ }
71
+
72
+ // Display summary
73
+ this.displaySummary();
74
+ } finally {
75
+ // Clean up temp files
76
+ await this.cleanupTempFiles();
77
+ }
78
+ }
79
+
80
+ /**
81
+ * Bundle a specific module
82
+ */
83
+ async bundleModule(moduleName) {
84
+ const modulePath = getModulePath(moduleName);
85
+
86
+ if (!(await fs.pathExists(modulePath))) {
87
+ console.log(chalk.yellow(`Module ${moduleName} not found`));
88
+ return { module: moduleName, agents: [], teams: [] };
89
+ }
90
+
91
+ console.log(chalk.bold(`\n📦 Bundling module: ${moduleName}`));
92
+
93
+ const results = {
94
+ module: moduleName,
95
+ agents: [],
96
+ teams: [],
97
+ };
98
+
99
+ // Vendor cross-module workflows first (if not already done by bundleAll)
100
+ await this.vendorCrossModuleWorkflows(moduleName);
101
+
102
+ // Pre-discover all agents and teams for manifest generation
103
+ await this.preDiscoverModule(moduleName);
104
+
105
+ // Ensure temp manifests exist (might not exist if called directly)
106
+ if (!(await fs.pathExists(this.tempManifestDir))) {
107
+ await this.createTempManifests();
108
+ }
109
+
110
+ // Process agents
111
+ const agents = await this.discoverAgents(modulePath);
112
+ for (const agent of agents) {
113
+ try {
114
+ await this.bundleAgent(moduleName, agent, false); // false = don't track again
115
+ results.agents.push(agent);
116
+ } catch (error) {
117
+ console.error(` Failed to bundle agent ${agent}:`, error.message);
118
+ }
119
+ }
120
+
121
+ // Process teams
122
+ const teams = await this.discoverTeams(modulePath);
123
+ for (const team of teams) {
124
+ try {
125
+ await this.bundleTeam(moduleName, team);
126
+ results.teams.push(team);
127
+ } catch (error) {
128
+ console.error(` Failed to bundle team ${team}:`, error.message);
129
+ }
130
+ }
131
+
132
+ return results;
133
+ }
134
+
135
+ /**
136
+ * Bundle a single agent
137
+ */
138
+ async bundleAgent(moduleName, agentFile, shouldTrack = true) {
139
+ const agentName = agentFile.endsWith('.agent.yaml') ? path.basename(agentFile, '.agent.yaml') : path.basename(agentFile, '.md');
140
+ this.stats.totalAgents++;
141
+
142
+ console.log(chalk.dim(` → Processing: ${agentName}`));
143
+
144
+ // Vendor cross-module workflows first (if not already done)
145
+ await this.vendorCrossModuleWorkflows(moduleName);
146
+
147
+ const agentPath = path.join(getModulePath(moduleName), 'agents', agentFile);
148
+
149
+ // Check if agent file exists
150
+ if (!(await fs.pathExists(agentPath))) {
151
+ this.stats.failedAgents++;
152
+ console.log(chalk.red(` ✗ Agent file not found`));
153
+ throw new Error(`Agent file not found: ${agentPath}`);
154
+ }
155
+
156
+ let content;
157
+ let agentXml;
158
+
159
+ // Handle YAML agents - build in-memory to XML
160
+ if (agentFile.endsWith('.agent.yaml')) {
161
+ // Check for webskip flag in YAML before building
162
+ const yamlContent = await fs.readFile(agentPath, 'utf8');
163
+ const agentYaml = yaml.load(yamlContent);
164
+
165
+ if (agentYaml?.agent?.webskip === true) {
166
+ this.stats.skippedAgents++;
167
+ console.log(chalk.gray(` ⊘ Skipped (webskip="true")`));
168
+ return;
169
+ }
170
+
171
+ // Build agent from YAML (no customize file for web bundles)
172
+ const xmlContent = await this.yamlBuilder.buildFromYaml(agentPath, null, {
173
+ includeMetadata: false, // Don't include build metadata in web bundles
174
+ forWebBundle: true, // Use web-specific activation fragments
175
+ });
176
+
177
+ content = xmlContent;
178
+ agentXml = this.extractAgentXml(xmlContent);
179
+ } else {
180
+ // Legacy MD format - read and extract XML
181
+ content = await fs.readFile(agentPath, 'utf8');
182
+ agentXml = this.extractAgentXml(content);
183
+ }
184
+
185
+ if (!agentXml) {
186
+ this.stats.failedAgents++;
187
+ console.log(chalk.red(` ✗ No agent XML found in ${agentFile}`));
188
+ return;
189
+ }
190
+
191
+ // Check if agent has bundle="false" attribute
192
+ if (this.shouldSkipBundling(agentXml)) {
193
+ this.stats.skippedAgents++;
194
+ console.log(chalk.gray(` ⊘ Skipped (bundle="false")`));
195
+ return;
196
+ }
197
+
198
+ // Process {project-root} references in agent XML
199
+ agentXml = this.processProjectRootReferences(agentXml);
200
+
201
+ // Track for manifest generation BEFORE generating manifests (if not pre-discovered)
202
+ if (shouldTrack) {
203
+ const agentDetails = AgentPartyGenerator.extractAgentDetails(content, moduleName, agentName);
204
+ if (agentDetails) {
205
+ this.discoveredAgents.push(agentDetails);
206
+ }
207
+ }
208
+
209
+ // Resolve dependencies with warning tracking
210
+ const dependencyWarnings = [];
211
+ const { dependencies, skippedWorkflows } = await this.resolveAgentDependencies(agentXml, moduleName, dependencyWarnings);
212
+
213
+ if (dependencyWarnings.length > 0) {
214
+ this.stats.warnings.push({ agent: agentName, warnings: dependencyWarnings });
215
+ }
216
+
217
+ // Check for module's default-party.csv and include it as agent manifest
218
+ const defaultPartyPath = path.join(getModulePath(moduleName), 'teams', 'default-party.csv');
219
+ if (await fs.pathExists(defaultPartyPath)) {
220
+ const partyContent = await fs.readFile(defaultPartyPath, 'utf8');
221
+ // Process any placeholders in the CSV content
222
+ const processedPartyContent = this.processProjectRootReferences(partyContent);
223
+ // Wrap as text to preserve raw CSV format in CDATA
224
+ const wrappedParty = this.wrapContentInXml(processedPartyContent, 'xiaoma/_cfg/agent-manifest.csv', 'text');
225
+ dependencies.set('xiaoma/_cfg/agent-manifest.csv', wrappedParty);
226
+ console.log(chalk.gray(` + Added party manifest from module default-party.csv`));
227
+ }
228
+
229
+ // Remove commands for skipped workflows from agent XML
230
+ if (skippedWorkflows.length > 0) {
231
+ agentXml = this.removeSkippedWorkflowCommands(agentXml, skippedWorkflows);
232
+ }
233
+
234
+ // Build the bundle (no manifests for individual agents)
235
+ const bundle = this.buildAgentBundle(agentXml, dependencies);
236
+
237
+ // Validate XML
238
+ const isValid = await this.validateXml(bundle);
239
+ if (!isValid) {
240
+ this.stats.invalidXml++;
241
+ console.log(chalk.red(` ⚠ Invalid XML generated!`));
242
+ }
243
+
244
+ // Format XML for readability
245
+ const formattedBundle = this.formatXml(bundle);
246
+
247
+ // Write bundle to output
248
+ const outputPath = path.join(this.outputDir, moduleName, 'agents', `${agentName}.xml`);
249
+ await fs.ensureDir(path.dirname(outputPath));
250
+ await fs.writeFile(outputPath, formattedBundle, 'utf8');
251
+
252
+ this.stats.bundledAgents++;
253
+ const statusIcon = isValid ? chalk.green('✓') : chalk.yellow('⚠');
254
+ console.log(` ${statusIcon} Bundled: ${agentName}.xml${isValid ? '' : chalk.yellow(' (invalid XML)')}`);
255
+ }
256
+
257
+ /**
258
+ * Bundle a team - includes orchestrator and all agents with their dependencies
259
+ */
260
+ async bundleTeam(moduleName, teamFile) {
261
+ const teamName = path.basename(teamFile, path.extname(teamFile));
262
+ console.log(chalk.dim(` → Processing team: ${teamName}`));
263
+
264
+ const teamPath = path.join(getModulePath(moduleName), 'teams', teamFile);
265
+
266
+ // Check if team file exists
267
+ if (!(await fs.pathExists(teamPath))) {
268
+ console.log(chalk.red(` ✗ Team file not found`));
269
+ throw new Error(`Team file not found: ${teamPath}`);
270
+ }
271
+
272
+ // Read and parse team YAML
273
+ const teamContent = await fs.readFile(teamPath, 'utf8');
274
+ const teamConfig = yaml.load(teamContent);
275
+
276
+ if (!teamConfig || !teamConfig.bundle) {
277
+ console.log(chalk.red(` ✗ Invalid team configuration`));
278
+ return;
279
+ }
280
+
281
+ // Start building the team bundle
282
+ const dependencies = new Map();
283
+ const processed = new Set();
284
+ const allAgentXmls = [];
285
+ const warnings = [];
286
+
287
+ // Check if team has a party CSV file (agent manifest)
288
+ const hasPartyFile = teamConfig.party && teamConfig.party.endsWith('.csv');
289
+ if (hasPartyFile) {
290
+ // Load the party CSV and add it as xiaoma/_cfg/agent-manifest.csv
291
+ const partyPath = path.join(path.dirname(teamPath), teamConfig.party.replace(/^\.\//, ''));
292
+ if (await fs.pathExists(partyPath)) {
293
+ const partyContent = await fs.readFile(partyPath, 'utf8');
294
+ // Process any placeholders in the CSV content
295
+ const processedPartyContent = this.processProjectRootReferences(partyContent);
296
+ // Wrap as text/csv to preserve raw CSV format in CDATA
297
+ const wrappedParty = this.wrapContentInXml(processedPartyContent, 'xiaoma/_cfg/agent-manifest.csv', 'text');
298
+ dependencies.set('xiaoma/_cfg/agent-manifest.csv', wrappedParty);
299
+ console.log(chalk.gray(` + Added agent manifest from: ${teamConfig.party}`));
300
+ } else {
301
+ console.log(chalk.yellow(` ⚠ Party file not found: ${partyPath}`));
302
+ }
303
+ }
304
+
305
+ // 1. First, always add the xiaoma-web-orchestrator (XML file only, no transformation needed)
306
+ const orchestratorXmlPath = path.join(this.sourceDir, 'core', 'agents', 'xiaoma-web-orchestrator.agent.xml');
307
+
308
+ if (await fs.pathExists(orchestratorXmlPath)) {
309
+ // Read the XML file directly - no transformation needed
310
+ const xmlContent = await fs.readFile(orchestratorXmlPath, 'utf8');
311
+ let orchestratorXml = xmlContent.trim();
312
+
313
+ // Process {project-root} references
314
+ orchestratorXml = this.processProjectRootReferences(orchestratorXml);
315
+
316
+ // Inject help/exit menu items only (orchestrator has its own activation)
317
+ orchestratorXml = this.injectHelpExitMenuItems(orchestratorXml);
318
+
319
+ // Resolve orchestrator dependencies
320
+ const { dependencies: orchDeps } = await this.resolveAgentDependencies(orchestratorXml, 'core', warnings);
321
+
322
+ // Merge orchestrator dependencies
323
+ for (const [id, content] of orchDeps) {
324
+ if (!dependencies.has(id)) {
325
+ dependencies.set(id, content);
326
+ }
327
+ }
328
+
329
+ // Add orchestrator XML first
330
+ allAgentXmls.push(orchestratorXml);
331
+ console.log(chalk.gray(` + Added orchestrator: xiaoma-web-orchestrator`));
332
+ } else {
333
+ console.log(chalk.yellow(` ⚠ Orchestrator not found at: ${orchestratorXmlPath}`));
334
+ }
335
+
336
+ // 2. Determine which agents to include
337
+ let agentsToBundle = [];
338
+
339
+ if (teamConfig.agents === '*' || (Array.isArray(teamConfig.agents) && teamConfig.agents.includes('*'))) {
340
+ // Include all agents from the module
341
+ const agentsPath = path.join(getModulePath(moduleName), 'agents');
342
+ if (await fs.pathExists(agentsPath)) {
343
+ const agentFiles = await fs.readdir(agentsPath);
344
+ agentsToBundle = agentFiles
345
+ .filter((file) => file.endsWith('.agent.yaml') || (file.endsWith('.md') && !file.toLowerCase().includes('readme')))
346
+ .map((file) => file.replace(/\.(agent\.yaml|md)$/, ''));
347
+ }
348
+ } else if (Array.isArray(teamConfig.agents)) {
349
+ // Include specific agents listed
350
+ agentsToBundle = teamConfig.agents;
351
+ } else {
352
+ console.log(chalk.yellow(` ⚠ No agents specified in team configuration`));
353
+ }
354
+
355
+ // 3. Process each agent and their dependencies
356
+ for (const agentName of agentsToBundle) {
357
+ // Try YAML first, then MD
358
+ let agentPath = path.join(getModulePath(moduleName), 'agents', `${agentName}.agent.yaml`);
359
+ let isYaml = await fs.pathExists(agentPath);
360
+
361
+ if (!isYaml) {
362
+ agentPath = path.join(getModulePath(moduleName), 'agents', `${agentName}.md`);
363
+ if (!(await fs.pathExists(agentPath))) {
364
+ console.log(chalk.yellow(` ⚠ Agent not found: ${agentName}`));
365
+ continue;
366
+ }
367
+ }
368
+
369
+ let agentXml;
370
+
371
+ if (isYaml) {
372
+ // Check for webskip flag in YAML
373
+ const yamlContent = await fs.readFile(agentPath, 'utf8');
374
+ const agentYaml = yaml.load(yamlContent);
375
+
376
+ if (agentYaml?.agent?.webskip === true) {
377
+ console.log(chalk.gray(` ⊘ Skipped agent (webskip="true"): ${agentName}`));
378
+ continue;
379
+ }
380
+
381
+ // Build YAML agent in-memory - skip activation for team agents (orchestrator handles it)
382
+ const xmlContent = await this.yamlBuilder.buildFromYaml(agentPath, null, {
383
+ includeMetadata: false,
384
+ skipActivation: true, // Skip activation for team agents
385
+ });
386
+ agentXml = this.extractAgentXml(xmlContent);
387
+ } else {
388
+ // Read legacy MD agent
389
+ const agentContent = await fs.readFile(agentPath, 'utf8');
390
+ agentXml = this.extractAgentXml(agentContent);
391
+ }
392
+
393
+ if (!agentXml) {
394
+ console.log(chalk.yellow(` ⚠ No XML found in agent: ${agentName}`));
395
+ continue;
396
+ }
397
+
398
+ // Skip agents with bundle="false"
399
+ if (this.shouldSkipBundling(agentXml)) {
400
+ console.log(chalk.gray(` ⊘ Skipped agent (bundle="false"): ${agentName}`));
401
+ continue;
402
+ }
403
+
404
+ // Process {project-root} references
405
+ agentXml = this.processProjectRootReferences(agentXml);
406
+
407
+ // Resolve agent dependencies
408
+ const agentWarnings = [];
409
+ const { dependencies: agentDeps, skippedWorkflows } = await this.resolveAgentDependencies(agentXml, moduleName, agentWarnings);
410
+
411
+ if (agentWarnings.length > 0) {
412
+ warnings.push({ agent: agentName, warnings: agentWarnings });
413
+ }
414
+
415
+ // Remove commands for skipped workflows from agent XML
416
+ if (skippedWorkflows.length > 0) {
417
+ agentXml = this.removeSkippedWorkflowCommands(agentXml, skippedWorkflows);
418
+ }
419
+
420
+ // Merge agent dependencies (deduplicate)
421
+ for (const [id, content] of agentDeps) {
422
+ if (!dependencies.has(id)) {
423
+ dependencies.set(id, content);
424
+ }
425
+ }
426
+
427
+ // Skip web activation injection for team agents - orchestrator handles everything
428
+ // Only inject help/exit menu items if missing
429
+ agentXml = this.injectHelpExitMenuItems(agentXml);
430
+
431
+ // Add agent XML to the collection
432
+ allAgentXmls.push(agentXml);
433
+ console.log(chalk.gray(` + Added agent: ${agentName}`));
434
+ }
435
+
436
+ // 4. Build the team bundle XML
437
+ const bundle = this.buildTeamBundle(teamConfig.bundle, allAgentXmls, dependencies);
438
+
439
+ // 5. Validate XML
440
+ const isValid = await this.validateXml(bundle);
441
+ if (!isValid) {
442
+ console.log(chalk.red(` ⚠ Invalid XML generated for team!`));
443
+ }
444
+
445
+ // Format XML for readability
446
+ const formattedBundle = this.formatXml(bundle);
447
+
448
+ // 6. Write bundle to output
449
+ const outputPath = path.join(this.outputDir, moduleName, 'teams', `${teamName}.xml`);
450
+ await fs.ensureDir(path.dirname(outputPath));
451
+ await fs.writeFile(outputPath, formattedBundle, 'utf8');
452
+
453
+ const statusIcon = isValid ? chalk.green('✓') : chalk.yellow('⚠');
454
+ console.log(` ${statusIcon} Bundled team: ${teamName}.xml${isValid ? '' : chalk.yellow(' (invalid XML)')}`);
455
+
456
+ // Track warnings
457
+ if (warnings.length > 0) {
458
+ this.stats.warnings.push(...warnings);
459
+ }
460
+ }
461
+
462
+ /**
463
+ * Build the final team bundle XML
464
+ */
465
+ buildTeamBundle(teamMetadata, agentXmls, dependencies) {
466
+ const parts = ['<?xml version="1.0" encoding="UTF-8"?>', '<team-bundle>', ' <!-- Agent Definitions -->', ' <agents>'];
467
+
468
+ for (const agentXml of agentXmls) {
469
+ // Indent each agent XML properly (add 4 spaces to each line)
470
+ const indentedAgent = agentXml
471
+ .split('\n')
472
+ .map((line) => ' ' + line)
473
+ .join('\n');
474
+ parts.push(indentedAgent);
475
+ }
476
+
477
+ parts.push(' </agents>');
478
+
479
+ // Add all dependencies
480
+ if (dependencies && dependencies.size > 0) {
481
+ parts.push('', ' <!-- Shared Dependencies -->', ' <dependencies>');
482
+
483
+ for (const [id, content] of dependencies) {
484
+ // All dependencies are now consistently wrapped in <file> elements
485
+ // Indent properly (add 4 spaces to each line)
486
+ const indentedContent = content
487
+ .split('\n')
488
+ .map((line) => ' ' + line)
489
+ .join('\n');
490
+ parts.push(indentedContent);
491
+ }
492
+
493
+ parts.push(' </dependencies>');
494
+ }
495
+
496
+ parts.push('</team-bundle>');
497
+
498
+ return parts.join('\n');
499
+ }
500
+
501
+ /**
502
+ * Vendor cross-module workflows for a module
503
+ * Scans source agent YAML files for workflow-install attributes and copies workflows
504
+ */
505
+ async vendorCrossModuleWorkflows(moduleName) {
506
+ const modulePath = getModulePath(moduleName);
507
+ const agentsPath = path.join(modulePath, 'agents');
508
+
509
+ if (!(await fs.pathExists(agentsPath))) {
510
+ return;
511
+ }
512
+
513
+ // Find all agent YAML files
514
+ const files = await fs.readdir(agentsPath);
515
+ const yamlFiles = files.filter((f) => f.endsWith('.agent.yaml'));
516
+
517
+ for (const agentFile of yamlFiles) {
518
+ const agentPath = path.join(agentsPath, agentFile);
519
+ const agentYaml = yaml.load(await fs.readFile(agentPath, 'utf8'));
520
+
521
+ const menuItems = agentYaml?.agent?.menu || [];
522
+ const workflowInstallItems = menuItems.filter((item) => item['workflow-install']);
523
+
524
+ for (const item of workflowInstallItems) {
525
+ const sourceWorkflowPath = item.workflow;
526
+ const installWorkflowPath = item['workflow-install'];
527
+
528
+ if (!sourceWorkflowPath || !installWorkflowPath) {
529
+ continue;
530
+ }
531
+
532
+ // Parse paths to extract module and workflow location
533
+ // Support both {project-root}/xiaoma/... and {project-root}/{xiaoma_folder}/... patterns
534
+ const sourceMatch = sourceWorkflowPath.match(/\{project-root\}\/(?:\{xiaoma_folder\}|xiaoma)\/([^/]+)\/workflows\/(.+)/);
535
+ const installMatch = installWorkflowPath.match(/\{project-root\}\/(?:\{xiaoma_folder\}|xiaoma)\/([^/]+)\/workflows\/(.+)/);
536
+
537
+ if (!sourceMatch || !installMatch) {
538
+ continue;
539
+ }
540
+
541
+ const sourceModule = sourceMatch[1];
542
+ const sourceWorkflowRelPath = sourceMatch[2];
543
+ const installModule = installMatch[1];
544
+ const installWorkflowRelPath = installMatch[2];
545
+
546
+ // Build actual filesystem paths
547
+ const actualSourceWorkflowPath = path.join(getModulePath(sourceModule), 'workflows', sourceWorkflowRelPath);
548
+ const actualDestWorkflowPath = path.join(getModulePath(installModule), 'workflows', installWorkflowRelPath);
549
+
550
+ // Check if source workflow exists
551
+ if (!(await fs.pathExists(actualSourceWorkflowPath))) {
552
+ console.log(chalk.yellow(` ⚠ Source workflow not found for vendoring: ${sourceWorkflowPath}`));
553
+ continue;
554
+ }
555
+
556
+ // Check if destination already exists (skip if already vendored)
557
+ if (await fs.pathExists(actualDestWorkflowPath)) {
558
+ continue;
559
+ }
560
+
561
+ // Get workflow directory (workflow.yaml is in a directory with other files)
562
+ const sourceWorkflowDir = path.dirname(actualSourceWorkflowPath);
563
+ const destWorkflowDir = path.dirname(actualDestWorkflowPath);
564
+
565
+ // Copy entire workflow directory
566
+ await fs.copy(sourceWorkflowDir, destWorkflowDir, { overwrite: false });
567
+
568
+ // Update config_source in the vendored workflow.yaml
569
+ const workflowYamlPath = actualDestWorkflowPath;
570
+ if (await fs.pathExists(workflowYamlPath)) {
571
+ await this.updateWorkflowConfigSource(workflowYamlPath, installModule);
572
+ }
573
+
574
+ console.log(chalk.dim(` → Vendored workflow: ${sourceWorkflowRelPath} → ${installModule}/workflows/${installWorkflowRelPath}`));
575
+ }
576
+ }
577
+ }
578
+
579
+ /**
580
+ * Update config_source in a vendored workflow YAML file
581
+ */
582
+ async updateWorkflowConfigSource(workflowYamlPath, newModuleName) {
583
+ let yamlContent = await fs.readFile(workflowYamlPath, 'utf8');
584
+
585
+ // Replace config_source with new module reference
586
+ // Support both old format (xiaoma) and new format ({xiaoma_folder})
587
+ const configSourcePattern = /config_source:\s*["']?\{project-root\}\/(?:\{xiaoma_folder\}|xiaoma)\/[^/]+\/config\.yaml["']?/g;
588
+ const newConfigSource = `config_source: "{project-root}/{xiaoma_folder}/${newModuleName}/config.yaml"`;
589
+
590
+ const updatedYaml = yamlContent.replaceAll(configSourcePattern, newConfigSource);
591
+ await fs.writeFile(workflowYamlPath, updatedYaml, 'utf8');
592
+ }
593
+
594
+ /**
595
+ * Pre-discover all agents and teams in a module for manifest generation
596
+ */
597
+ async preDiscoverModule(moduleName) {
598
+ const modulePath = getModulePath(moduleName);
599
+
600
+ // Clear any previously discovered agents for this module
601
+ this.discoveredAgents = this.discoveredAgents.filter((a) => a.module !== moduleName);
602
+
603
+ // Discover agents
604
+ const agentsPath = path.join(modulePath, 'agents');
605
+ if (await fs.pathExists(agentsPath)) {
606
+ const files = await fs.readdir(agentsPath);
607
+ for (const file of files) {
608
+ if (file.endsWith('.agent.yaml') || (file.endsWith('.md') && !file.toLowerCase().includes('readme'))) {
609
+ const agentPath = path.join(agentsPath, file);
610
+ let content;
611
+
612
+ if (file.endsWith('.agent.yaml')) {
613
+ // Check for webskip flag in YAML
614
+ const yamlContent = await fs.readFile(agentPath, 'utf8');
615
+ const agentYaml = yaml.load(yamlContent);
616
+
617
+ if (agentYaml?.agent?.webskip === true) {
618
+ continue; // Skip this agent
619
+ }
620
+
621
+ // Build YAML agent in-memory
622
+ content = await this.yamlBuilder.buildFromYaml(agentPath, null, {
623
+ includeMetadata: false,
624
+ });
625
+ } else {
626
+ // Read legacy MD agent
627
+ content = await fs.readFile(agentPath, 'utf8');
628
+ }
629
+
630
+ const agentXml = this.extractAgentXml(content);
631
+
632
+ if (agentXml) {
633
+ // Skip agents with bundle="false"
634
+ if (this.shouldSkipBundling(agentXml)) {
635
+ continue;
636
+ }
637
+
638
+ const agentName = file.endsWith('.agent.yaml') ? path.basename(file, '.agent.yaml') : path.basename(file, '.md');
639
+ // Use the shared generator to extract agent details (pass full content)
640
+ const agentDetails = AgentPartyGenerator.extractAgentDetails(content, moduleName, agentName);
641
+ if (agentDetails) {
642
+ this.discoveredAgents.push(agentDetails);
643
+ }
644
+ }
645
+ }
646
+ }
647
+ }
648
+
649
+ // TODO: Discover teams when implemented
650
+ }
651
+
652
+ /**
653
+ * Extract agent XML from markdown content
654
+ */
655
+ extractAgentXml(content) {
656
+ // Try 4 backticks first (can contain 3 backtick blocks inside)
657
+ let match = content.match(/````xml\s*([\s\S]*?)````/);
658
+ if (!match) {
659
+ // Fall back to 3 backticks if no 4-backtick block found
660
+ match = content.match(/```xml\s*([\s\S]*?)```/);
661
+ }
662
+
663
+ if (match) {
664
+ const xmlContent = match[1];
665
+ const agentMatch = xmlContent.match(/<agent[^>]*>[\s\S]*?<\/agent>/);
666
+ return agentMatch ? agentMatch[0] : null;
667
+ }
668
+
669
+ // Fall back to direct extraction
670
+ match = content.match(/<agent[^>]*>[\s\S]*?<\/agent>/);
671
+ return match ? match[0] : null;
672
+ }
673
+
674
+ /**
675
+ * Resolve all dependencies for an agent
676
+ */
677
+ async resolveAgentDependencies(agentXml, moduleName, warnings = []) {
678
+ const dependencies = new Map();
679
+ const processed = new Set();
680
+ const skippedWorkflows = [];
681
+
682
+ // Extract file references from agent XML
683
+ const { refs, workflowRefs } = this.extractFileReferences(agentXml);
684
+
685
+ // Process regular file references
686
+ for (const ref of refs) {
687
+ await this.processFileDependency(ref, dependencies, processed, moduleName, warnings);
688
+ }
689
+
690
+ // Process workflow references with special handling
691
+ for (const workflowRef of workflowRefs) {
692
+ const result = await this.processWorkflowDependency(workflowRef, dependencies, processed, moduleName, warnings);
693
+ if (result && result.skipped) {
694
+ skippedWorkflows.push(workflowRef);
695
+ }
696
+ }
697
+
698
+ return { dependencies, skippedWorkflows };
699
+ }
700
+
701
+ /**
702
+ * Extract file references from agent XML
703
+ */
704
+ extractFileReferences(xml) {
705
+ const refs = new Set();
706
+ const workflowRefs = new Set();
707
+
708
+ // Remove agent id attribute to prevent it from being treated as a dependency
709
+ // The id attribute is just a metadata identifier, not a file reference
710
+ const xmlWithoutAgentId = xml.replace(/<agent[^>]*id="[^"]*"[^>]*>/, (match) => {
711
+ return match.replace(/\sid="[^"]*"/, '');
712
+ });
713
+
714
+ // Match various file reference patterns
715
+ const patterns = [
716
+ /exec="([^"]+)"/g, // Command exec paths
717
+ /tmpl="([^"]+)"/g, // Template paths
718
+ /data="([^"]+)"/g, // Data file paths
719
+ /file="([^"]+)"/g, // Generic file refs
720
+ /src="([^"]+)"/g, // Source paths
721
+ /system-prompts="([^"]+)"/g,
722
+ /tools="([^"]+)"/g,
723
+ /knowledge="([^"]+)"/g,
724
+ /{project-root}\/([^"'\s<>]+)/g, // Legacy {project-root} paths
725
+ /\bxiaoma\/([^"'\s<>]+)/g, // Direct xiaoma/ paths (after {xiaoma_folder} replacement)
726
+ ];
727
+
728
+ for (const pattern of patterns) {
729
+ let match;
730
+ // Use the XML with agent id removed for pattern matching
731
+ while ((match = pattern.exec(xmlWithoutAgentId)) !== null) {
732
+ let filePath = match[1];
733
+ // Remove {project-root} prefix if present
734
+ filePath = filePath.replace(/^{project-root}\//, '');
735
+ // Remove {xiaoma_folder} prefix if present (should be rare, mostly replaced already)
736
+ filePath = filePath.replace(/^{xiaoma_folder}\//, 'xiaoma/');
737
+
738
+ // For xiaoma/ pattern, prepend 'xiaoma/' since it was captured without it
739
+ if (pattern.source.includes(String.raw`\bxiaoma\/`)) {
740
+ filePath = 'xiaoma/' + filePath;
741
+ }
742
+
743
+ // Skip obvious placeholder/example paths
744
+ if (filePath && !filePath.includes('path/to/') && !filePath.includes('example') && !filePath.includes('...')) {
745
+ refs.add(filePath);
746
+ }
747
+ }
748
+ }
749
+
750
+ // Extract workflow references from agent files
751
+ const workflowPatterns = [
752
+ /workflow="([^"]+)"/g, // Menu items with workflow attribute
753
+ /validate-workflow="([^"]+)"/g, // Validation workflow references
754
+ ];
755
+
756
+ for (const pattern of workflowPatterns) {
757
+ let match;
758
+ // Use original xml for workflow patterns (they don't conflict with agent id)
759
+ while ((match = pattern.exec(xml)) !== null) {
760
+ let workflowPath = match[1];
761
+ workflowPath = workflowPath.replace(/^{project-root}\//, '');
762
+ // Remove {xiaoma_folder} prefix if present and replace with xiaoma
763
+ workflowPath = workflowPath.replace(/^{xiaoma_folder}\//, 'xiaoma/');
764
+
765
+ // Skip obvious placeholder/example paths
766
+ if (workflowPath && workflowPath.endsWith('.yaml') && !workflowPath.includes('path/to/') && !workflowPath.includes('example')) {
767
+ workflowRefs.add(workflowPath);
768
+ }
769
+ }
770
+ }
771
+
772
+ return { refs: [...refs], workflowRefs: [...workflowRefs] };
773
+ }
774
+
775
+ /**
776
+ * Remove commands from agent XML that reference skipped workflows
777
+ */
778
+ removeSkippedWorkflowCommands(agentXml, skippedWorkflows) {
779
+ let modifiedXml = agentXml;
780
+
781
+ // For each skipped workflow, find and remove menu items and commands
782
+ for (const workflowPath of skippedWorkflows) {
783
+ // Need to escape special regex characters in the path
784
+ const escapedPath = workflowPath.replaceAll(/[.*+?^${}()|[\]\\]/g, String.raw`\$&`);
785
+
786
+ // Pattern 1: Remove <item> tags with workflow attribute
787
+ // Match: <item cmd="..." workflow="workflowPath">...</item>
788
+ const itemWorkflowPattern = new RegExp(`\\s*<item\\s+[^>]*workflow="[^"]*${escapedPath}"[^>]*>.*?</item>\\s*`, 'gs');
789
+ modifiedXml = modifiedXml.replace(itemWorkflowPattern, '');
790
+ }
791
+
792
+ return modifiedXml;
793
+ }
794
+
795
+ /**
796
+ * Process a file dependency recursively
797
+ */
798
+ async processFileDependency(filePath, dependencies, processed, moduleName, warnings = []) {
799
+ // Skip workflow YAML files - they're handled by processWorkflowDependency
800
+ if (filePath.includes('/workflow') && filePath.endsWith('workflow.yaml')) {
801
+ return;
802
+ }
803
+
804
+ // Skip if already processed
805
+ if (processed.has(filePath)) {
806
+ return;
807
+ }
808
+ processed.add(filePath);
809
+
810
+ // Skip agent-manifest.csv manifest for web bundles (agents are already bundled)
811
+ if (filePath === 'xiaoma/_cfg/agent-manifest.csv' || filePath.endsWith('/agent-manifest.csv')) {
812
+ return;
813
+ }
814
+
815
+ // Handle wildcard patterns
816
+ if (filePath.includes('*')) {
817
+ await this.processWildcardDependency(filePath, dependencies, processed, moduleName, warnings);
818
+ return;
819
+ }
820
+
821
+ // Resolve actual file path
822
+ const actualPath = this.resolveFilePath(filePath, moduleName);
823
+
824
+ if (!actualPath || !(await fs.pathExists(actualPath))) {
825
+ warnings.push(filePath);
826
+ return;
827
+ }
828
+
829
+ // Skip if it's a directory
830
+ const stats = await fs.stat(actualPath);
831
+ if (stats.isDirectory()) {
832
+ // Silently skip directories - they're not file dependencies
833
+ return;
834
+ }
835
+
836
+ // Read file content
837
+ let content = await fs.readFile(actualPath, 'utf8');
838
+
839
+ // Process {project-root} references
840
+ content = this.processProjectRootReferences(content);
841
+
842
+ // Extract dependencies from frontmatter if present
843
+ const frontmatterMatch = content.match(/^---\s*\n([\s\S]*?)\n---/);
844
+ if (frontmatterMatch) {
845
+ const frontmatter = frontmatterMatch[1];
846
+ // Look for dependencies in frontmatter
847
+ const depMatch = frontmatter.match(/dependencies:\s*\[(.*?)\]/);
848
+ if (depMatch) {
849
+ const deps = depMatch[1].match(/['"]([^'"]+)['"]/g);
850
+ if (deps) {
851
+ for (const dep of deps) {
852
+ let depPath = dep.replaceAll(/['"]/g, '').replace(/^{project-root}\//, '');
853
+ depPath = depPath.replace(/^{xiaoma_folder}\//, 'xiaoma/');
854
+ if (depPath && !processed.has(depPath)) {
855
+ await this.processFileDependency(depPath, dependencies, processed, moduleName, warnings);
856
+ }
857
+ }
858
+ }
859
+ }
860
+ // Look for template references
861
+ const templateMatch = frontmatter.match(/template:\s*\[(.*?)\]/);
862
+ if (templateMatch) {
863
+ const templates = templateMatch[1].match(/['"]([^'"]+)['"]/g);
864
+ if (templates) {
865
+ for (const template of templates) {
866
+ let templatePath = template.replaceAll(/['"]/g, '').replace(/^{project-root}\//, '');
867
+ templatePath = templatePath.replace(/^{xiaoma_folder}\//, 'xiaoma/');
868
+ if (templatePath && !processed.has(templatePath)) {
869
+ await this.processFileDependency(templatePath, dependencies, processed, moduleName, warnings);
870
+ }
871
+ }
872
+ }
873
+ }
874
+ }
875
+
876
+ // Extract XML from markdown if applicable
877
+ const ext = path.extname(actualPath).toLowerCase();
878
+ let processedContent = content;
879
+
880
+ switch (ext) {
881
+ case '.md': {
882
+ // Try to extract XML from markdown - handle both 3 and 4 backtick blocks
883
+ // First try 4 backticks (which can contain 3 backtick blocks inside)
884
+ let xmlMatches = [...content.matchAll(/````xml\s*([\s\S]*?)````/g)];
885
+
886
+ // If no 4-backtick blocks, try 3 backticks
887
+ if (xmlMatches.length === 0) {
888
+ xmlMatches = [...content.matchAll(/```xml\s*([\s\S]*?)```/g)];
889
+ }
890
+
891
+ const xmlBlocks = [];
892
+
893
+ for (const match of xmlMatches) {
894
+ if (match[1]) {
895
+ xmlBlocks.push(match[1].trim());
896
+ }
897
+ }
898
+
899
+ if (xmlBlocks.length > 0) {
900
+ // For XML content, just include it directly (it's already valid XML)
901
+ processedContent = xmlBlocks.join('\n\n');
902
+ } else {
903
+ // No XML blocks found, skip non-XML markdown files
904
+ return;
905
+ }
906
+
907
+ break;
908
+ }
909
+ case '.csv': {
910
+ // CSV files need special handling - convert to XML file-index
911
+ const lines = content.split('\n').filter((line) => line.trim());
912
+ if (lines.length === 0) return;
913
+
914
+ const headers = lines[0].split(',').map((h) => h.trim());
915
+ const rows = lines.slice(1);
916
+
917
+ const indexParts = [`<file-index id="${filePath}">`];
918
+ indexParts.push(' <items>');
919
+
920
+ // Track files referenced in CSV for additional bundling
921
+ const referencedFiles = new Set();
922
+
923
+ for (const row of rows) {
924
+ const values = row.split(',').map((v) => v.trim());
925
+ if (values.every((v) => !v)) continue;
926
+
927
+ indexParts.push(' <item>');
928
+ for (const [i, header] of headers.entries()) {
929
+ const value = values[i] || '';
930
+ const tagName = header.toLowerCase().replaceAll(/[^a-z0-9]/g, '_');
931
+ indexParts.push(` <${tagName}>${value}</${tagName}>`);
932
+
933
+ // Track referenced files
934
+ if (header.toLowerCase().includes('file') && value.endsWith('.md')) {
935
+ // Build path relative to CSV location
936
+ const csvDir = path.dirname(actualPath);
937
+ const refPath = path.join(csvDir, value);
938
+ if (fs.existsSync(refPath)) {
939
+ const refId = filePath.replace('index.csv', value);
940
+ referencedFiles.add(refId);
941
+ }
942
+ }
943
+ }
944
+ indexParts.push(' </item>');
945
+ }
946
+
947
+ indexParts.push(' </items>', '</file-index>');
948
+
949
+ // Store the XML version wrapped in a file element
950
+ const csvXml = indexParts.join('\n');
951
+ const wrappedCsv = `<file id="${filePath}" type="xml">\n${csvXml}\n</file>`;
952
+ dependencies.set(filePath, wrappedCsv);
953
+
954
+ // Process referenced files from CSV
955
+ for (const refId of referencedFiles) {
956
+ if (!processed.has(refId)) {
957
+ await this.processFileDependency(refId, dependencies, processed, moduleName, warnings);
958
+ }
959
+ }
960
+
961
+ return;
962
+ }
963
+ case '.xml': {
964
+ // XML files can be included directly
965
+ processedContent = content;
966
+ break;
967
+ }
968
+ default: {
969
+ // For other non-XML file types, skip them
970
+ return;
971
+ }
972
+ }
973
+
974
+ // Determine file type for wrapping
975
+ let fileType = 'text';
976
+ if (ext === '.xml' || (ext === '.md' && processedContent.trim().startsWith('<'))) {
977
+ fileType = 'xml';
978
+ } else
979
+ switch (ext) {
980
+ case '.yaml':
981
+ case '.yml': {
982
+ fileType = 'yaml';
983
+
984
+ break;
985
+ }
986
+ case '.json': {
987
+ fileType = 'json';
988
+
989
+ break;
990
+ }
991
+ case '.md': {
992
+ fileType = 'md';
993
+
994
+ break;
995
+ }
996
+ // No default
997
+ }
998
+
999
+ // Wrap content in file element and store
1000
+ const wrappedContent = this.wrapContentInXml(processedContent, filePath, fileType);
1001
+ dependencies.set(filePath, wrappedContent);
1002
+
1003
+ // Recursively scan for more dependencies
1004
+ const { refs: nestedRefs } = this.extractFileReferences(processedContent);
1005
+ for (const ref of nestedRefs) {
1006
+ await this.processFileDependency(ref, dependencies, processed, moduleName, warnings);
1007
+ }
1008
+ }
1009
+
1010
+ /**
1011
+ * Process a workflow YAML file and its bundle files
1012
+ */
1013
+ async processWorkflowDependency(workflowPath, dependencies, processed, moduleName, warnings = []) {
1014
+ // Skip if already processed
1015
+ if (processed.has(workflowPath)) {
1016
+ return { skipped: false };
1017
+ }
1018
+ processed.add(workflowPath);
1019
+
1020
+ // Resolve actual file path
1021
+ const actualPath = this.resolveFilePath(workflowPath, moduleName);
1022
+
1023
+ if (!actualPath || !(await fs.pathExists(actualPath))) {
1024
+ warnings.push(workflowPath);
1025
+ return { skipped: true };
1026
+ }
1027
+
1028
+ // Read and parse YAML file
1029
+ const yamlContent = await fs.readFile(actualPath, 'utf8');
1030
+ let workflowConfig;
1031
+
1032
+ try {
1033
+ workflowConfig = yaml.load(yamlContent);
1034
+ } catch (error) {
1035
+ warnings.push(`${workflowPath} (invalid YAML: ${error.message})`);
1036
+ return { skipped: true };
1037
+ }
1038
+
1039
+ // Check if web_bundle is explicitly set to false
1040
+ if (workflowConfig.web_bundle === false) {
1041
+ // Mark this workflow as skipped so we can remove the command from agent
1042
+ return { skipped: true, workflowPath };
1043
+ }
1044
+
1045
+ // Create YAML content with only web_bundle section (flattened)
1046
+ let bundleYamlContent;
1047
+ if (workflowConfig.web_bundle && typeof workflowConfig.web_bundle === 'object') {
1048
+ // Only include the web_bundle content, flattened to root level
1049
+ bundleYamlContent = yaml.dump(workflowConfig.web_bundle);
1050
+ } else {
1051
+ // If no web_bundle section, include full YAML
1052
+ bundleYamlContent = yamlContent;
1053
+ }
1054
+
1055
+ // Process {project-root} and {xiaoma_folder} references in the YAML content
1056
+ bundleYamlContent = this.processProjectRootReferences(bundleYamlContent);
1057
+
1058
+ // Include the YAML file with only web_bundle content, wrapped in XML
1059
+ // Process the workflow path to create a clean ID
1060
+ let yamlId = workflowPath.replace(/^{project-root}\//, '');
1061
+ yamlId = yamlId.replace(/^{xiaoma_folder}\//, 'xiaoma/');
1062
+ const wrappedYaml = this.wrapContentInXml(bundleYamlContent, yamlId, 'yaml');
1063
+ dependencies.set(yamlId, wrappedYaml);
1064
+
1065
+ // Always include core workflow task when processing workflows
1066
+ await this.includeCoreWorkflowFiles(dependencies, processed, moduleName, warnings);
1067
+
1068
+ // Check if advanced elicitation is enabled
1069
+ if (workflowConfig.web_bundle && workflowConfig.web_bundle.use_advanced_elicitation) {
1070
+ await this.includeAdvancedElicitationFiles(dependencies, processed, moduleName, warnings);
1071
+ }
1072
+
1073
+ // Process web_bundle_files if they exist
1074
+ if (workflowConfig.web_bundle && workflowConfig.web_bundle.web_bundle_files) {
1075
+ const bundleFiles = workflowConfig.web_bundle.web_bundle_files;
1076
+
1077
+ for (const bundleFilePath of bundleFiles) {
1078
+ // Process the file path to create a clean ID for checking if already processed
1079
+ let cleanFilePath = bundleFilePath.replace(/^{project-root}\//, '');
1080
+ cleanFilePath = cleanFilePath.replace(/^{xiaoma_folder}\//, 'xiaoma/');
1081
+
1082
+ if (processed.has(cleanFilePath)) {
1083
+ continue;
1084
+ }
1085
+
1086
+ const bundleActualPath = this.resolveFilePath(bundleFilePath, moduleName);
1087
+
1088
+ if (!bundleActualPath || !(await fs.pathExists(bundleActualPath))) {
1089
+ // Use the cleaned path in warnings (with {xiaoma_folder} replaced)
1090
+ warnings.push(cleanFilePath);
1091
+ continue;
1092
+ }
1093
+
1094
+ // Check if this is another workflow.yaml file - if so, recursively process it
1095
+ if (bundleFilePath.endsWith('workflow.yaml')) {
1096
+ // Recursively process this workflow and its dependencies
1097
+ await this.processWorkflowDependency(bundleFilePath, dependencies, processed, moduleName, warnings);
1098
+ } else {
1099
+ // Regular file - process normally
1100
+ processed.add(cleanFilePath);
1101
+
1102
+ // Read the file content
1103
+ let fileContent = await fs.readFile(bundleActualPath, 'utf8');
1104
+ const fileExt = path.extname(bundleActualPath).toLowerCase().replace('.', '');
1105
+
1106
+ // Process {project-root} references before wrapping
1107
+ fileContent = this.processProjectRootReferences(fileContent);
1108
+
1109
+ // Wrap in XML with proper escaping
1110
+ const wrappedContent = this.wrapContentInXml(fileContent, cleanFilePath, fileExt);
1111
+ dependencies.set(cleanFilePath, wrappedContent);
1112
+ }
1113
+ }
1114
+ }
1115
+
1116
+ return { skipped: false };
1117
+ }
1118
+
1119
+ /**
1120
+ * Include core workflow task files
1121
+ */
1122
+ async includeCoreWorkflowFiles(dependencies, processed, moduleName, warnings = []) {
1123
+ const coreWorkflowPath = 'xiaoma/core/tasks/workflow.xml';
1124
+
1125
+ if (processed.has(coreWorkflowPath)) {
1126
+ return;
1127
+ }
1128
+ processed.add(coreWorkflowPath);
1129
+
1130
+ const actualPath = this.resolveFilePath(coreWorkflowPath, moduleName);
1131
+
1132
+ if (!actualPath || !(await fs.pathExists(actualPath))) {
1133
+ warnings.push(coreWorkflowPath);
1134
+ return;
1135
+ }
1136
+
1137
+ let fileContent = await fs.readFile(actualPath, 'utf8');
1138
+ // Process {project-root} and {xiaoma_folder} references
1139
+ fileContent = this.processProjectRootReferences(fileContent);
1140
+ const wrappedContent = this.wrapContentInXml(fileContent, coreWorkflowPath, 'xml');
1141
+ dependencies.set(coreWorkflowPath, wrappedContent);
1142
+ }
1143
+
1144
+ /**
1145
+ * Include advanced elicitation files
1146
+ */
1147
+ async includeAdvancedElicitationFiles(dependencies, processed, moduleName, warnings = []) {
1148
+ const elicitationFiles = ['xiaoma/core/tasks/advanced-elicitation.xml', 'xiaoma/core/tasks/advanced-elicitation-methods.csv'];
1149
+
1150
+ for (const filePath of elicitationFiles) {
1151
+ if (processed.has(filePath)) {
1152
+ continue;
1153
+ }
1154
+ processed.add(filePath);
1155
+
1156
+ const actualPath = this.resolveFilePath(filePath, moduleName);
1157
+
1158
+ if (!actualPath || !(await fs.pathExists(actualPath))) {
1159
+ warnings.push(filePath);
1160
+ continue;
1161
+ }
1162
+
1163
+ let fileContent = await fs.readFile(actualPath, 'utf8');
1164
+ // Process {project-root} and {xiaoma_folder} references
1165
+ fileContent = this.processProjectRootReferences(fileContent);
1166
+ const fileExt = path.extname(actualPath).toLowerCase().replace('.', '');
1167
+ const wrappedContent = this.wrapContentInXml(fileContent, filePath, fileExt);
1168
+ dependencies.set(filePath, wrappedContent);
1169
+ }
1170
+ }
1171
+
1172
+ /**
1173
+ * Wrap file content in XML with proper escaping
1174
+ */
1175
+ wrapContentInXml(content, id, type = 'text') {
1176
+ // For XML files, include directly without CDATA (they're already valid XML)
1177
+ if (type === 'xml') {
1178
+ // XML files can be included directly as they're already well-formed
1179
+ // Just wrap in a file element
1180
+ return `<file id="${id}" type="${type}">\n${content}\n</file>`;
1181
+ }
1182
+
1183
+ // For all other file types, use CDATA to preserve content exactly
1184
+ // Escape any ]]> sequences in the content by splitting CDATA sections
1185
+ // Replace ]]> with ]]]]><![CDATA[> to properly escape it within CDATA
1186
+ const escapedContent = content.replaceAll(']]>', ']]]]><![CDATA[>');
1187
+
1188
+ // Use CDATA to preserve content exactly as-is, including special characters
1189
+ return `<file id="${id}" type="${type}"><![CDATA[${escapedContent}]]></file>`;
1190
+ }
1191
+
1192
+ /**
1193
+ * Process wildcard dependency patterns
1194
+ */
1195
+ async processWildcardDependency(pattern, dependencies, processed, moduleName, warnings = []) {
1196
+ // Remove {project-root} prefix
1197
+ pattern = pattern.replace(/^{project-root}\//, '');
1198
+ // Replace {xiaoma_folder} with xiaoma
1199
+ pattern = pattern.replace(/^{xiaoma_folder}\//, 'xiaoma/');
1200
+
1201
+ // Get directory and file pattern
1202
+ const lastSlash = pattern.lastIndexOf('/');
1203
+ const dirPath = pattern.slice(0, Math.max(0, lastSlash));
1204
+ const filePattern = pattern.slice(Math.max(0, lastSlash + 1));
1205
+
1206
+ // Resolve directory path without checking file existence
1207
+ let dir;
1208
+ if (dirPath.startsWith('xiaoma/')) {
1209
+ // Remove xiaoma/ prefix
1210
+ const actualPath = dirPath.replace(/^xiaoma\//, '');
1211
+
1212
+ // Try different path mappings for directories
1213
+ // Modules are directly under src/, e.g. xiaoma/cis/... -> src/cis/...
1214
+ const possibleDirs = [path.join(this.sourceDir, actualPath)];
1215
+
1216
+ for (const testDir of possibleDirs) {
1217
+ if (fs.existsSync(testDir)) {
1218
+ dir = testDir;
1219
+ break;
1220
+ }
1221
+ }
1222
+ }
1223
+
1224
+ if (!dir) {
1225
+ warnings.push(`${pattern} (could not resolve directory)`);
1226
+ return;
1227
+ }
1228
+ if (!(await fs.pathExists(dir))) {
1229
+ warnings.push(pattern);
1230
+ return;
1231
+ }
1232
+
1233
+ // Read directory and match files
1234
+ const files = await fs.readdir(dir);
1235
+ let matchedFiles = [];
1236
+
1237
+ if (filePattern === '*.*') {
1238
+ matchedFiles = files;
1239
+ } else if (filePattern.startsWith('*.')) {
1240
+ const ext = filePattern.slice(1);
1241
+ matchedFiles = files.filter((f) => f.endsWith(ext));
1242
+ } else {
1243
+ // Simple glob matching
1244
+ const regex = new RegExp('^' + filePattern.replace('*', '.*') + '$');
1245
+ matchedFiles = files.filter((f) => regex.test(f));
1246
+ }
1247
+
1248
+ // Process each matched file
1249
+ for (const file of matchedFiles) {
1250
+ const fullPath = dirPath + '/' + file;
1251
+ if (!processed.has(fullPath)) {
1252
+ await this.processFileDependency(fullPath, dependencies, processed, moduleName, warnings);
1253
+ }
1254
+ }
1255
+ }
1256
+
1257
+ /**
1258
+ * Resolve file path relative to project
1259
+ */
1260
+ resolveFilePath(filePath, moduleName) {
1261
+ // Remove {project-root} prefix
1262
+ filePath = filePath.replace(/^{project-root}\//, '');
1263
+ // Replace {xiaoma_folder} with xiaoma
1264
+ filePath = filePath.replace(/^{xiaoma_folder}\//, 'xiaoma/');
1265
+ filePath = filePath.replace(/^{xiaoma_folder}$/, 'xiaoma');
1266
+
1267
+ // Check temp directory first for _cfg files
1268
+ if (filePath.startsWith('xiaoma/_cfg/')) {
1269
+ const filename = filePath.split('/').pop();
1270
+ const tempPath = path.join(this.tempManifestDir, filename);
1271
+ if (fs.existsSync(tempPath)) {
1272
+ return tempPath;
1273
+ }
1274
+ }
1275
+
1276
+ // Handle different path patterns for xiaoma files
1277
+ // xiaoma/cis/tasks/brain-session.md -> src/cis/tasks/brain-session.md
1278
+ // xiaoma/core/tasks/create-doc.md -> src/core/tasks/create-doc.md
1279
+ // xiaoma/xmc/templates/brief.md -> src/xmc/templates/brief.md
1280
+
1281
+ let actualPath = filePath;
1282
+
1283
+ if (filePath.startsWith('xiaoma/')) {
1284
+ // Remove xiaoma/ prefix
1285
+ actualPath = filePath.replace(/^xiaoma\//, '');
1286
+
1287
+ // Check if it's a module-specific file (cis, xmc, etc) or core file
1288
+ const parts = actualPath.split('/');
1289
+ const firstPart = parts[0];
1290
+
1291
+ // Try different path mappings
1292
+ const possiblePaths = [
1293
+ // Try in temp directory first
1294
+ path.join(this.tempDir, filePath),
1295
+ // Try as direct path: xiaoma/xmc/... -> src/xmc/..., xiaoma/core/... -> src/core/...
1296
+ path.join(this.sourceDir, actualPath),
1297
+ // Try without any prefix in src
1298
+ path.join(this.sourceDir, parts.slice(1).join('/')),
1299
+ // Try in project root
1300
+ path.join(this.sourceDir, '..', actualPath),
1301
+ // Try original with xiaoma
1302
+ path.join(this.sourceDir, '..', filePath),
1303
+ ];
1304
+
1305
+ for (const testPath of possiblePaths) {
1306
+ if (fs.existsSync(testPath)) {
1307
+ return testPath;
1308
+ }
1309
+ }
1310
+ }
1311
+
1312
+ // Try standard paths for non-xiaoma files
1313
+ const basePaths = [
1314
+ this.sourceDir, // src directory
1315
+ getModulePath(moduleName), // Current module directly under src/
1316
+ path.join(this.sourceDir, '..'), // Project root
1317
+ ];
1318
+
1319
+ for (const basePath of basePaths) {
1320
+ const fullPath = path.join(basePath, actualPath);
1321
+ if (fs.existsSync(fullPath)) {
1322
+ return fullPath;
1323
+ }
1324
+ }
1325
+
1326
+ return null;
1327
+ }
1328
+
1329
+ /**
1330
+ * Process and remove {project-root} references and replace {xiaoma_folder} with xiaoma
1331
+ */
1332
+ processProjectRootReferences(content) {
1333
+ // Remove {project-root}/ prefix (with slash)
1334
+ content = content.replaceAll('{project-root}/', '');
1335
+ // Also remove {project-root} without slash
1336
+ content = content.replaceAll('{project-root}', '');
1337
+ // Replace {xiaoma_folder} with xiaoma
1338
+ content = content.replaceAll('{xiaoma_folder}', 'xiaoma');
1339
+ return content;
1340
+ }
1341
+
1342
+ /**
1343
+ * Escape special XML characters in text content
1344
+ */
1345
+ escapeXmlText(text) {
1346
+ return text
1347
+ .replaceAll('&', '&amp;')
1348
+ .replaceAll('<', '&lt;')
1349
+ .replaceAll('>', '&gt;')
1350
+ .replaceAll('"', '&quot;')
1351
+ .replaceAll("'", '&apos;');
1352
+ }
1353
+
1354
+ /**
1355
+ * Escape XML content while preserving XML tags
1356
+ */
1357
+ escapeXmlContent(content) {
1358
+ const tagPattern = /<([^>]+)>/g;
1359
+ const parts = [];
1360
+ let lastIndex = 0;
1361
+ let match;
1362
+
1363
+ while ((match = tagPattern.exec(content)) !== null) {
1364
+ if (match.index > lastIndex) {
1365
+ parts.push(this.escapeXmlText(content.slice(lastIndex, match.index)));
1366
+ }
1367
+ parts.push('<' + match[1] + '>');
1368
+ lastIndex = match.index + match[0].length;
1369
+ }
1370
+
1371
+ if (lastIndex < content.length) {
1372
+ parts.push(this.escapeXmlText(content.slice(lastIndex)));
1373
+ }
1374
+
1375
+ return parts.join('');
1376
+ }
1377
+
1378
+ /**
1379
+ * Inject help and exit menu items into agent XML
1380
+ */
1381
+ injectHelpExitMenuItems(agentXml) {
1382
+ // Check if menu already has help and exit
1383
+ const hasHelp = agentXml.includes('cmd="*help"') || agentXml.includes('trigger="*help"');
1384
+ const hasExit = agentXml.includes('cmd="*exit"') || agentXml.includes('trigger="*exit"');
1385
+
1386
+ if (hasHelp && hasExit) {
1387
+ return agentXml; // Already has both, skip injection
1388
+ }
1389
+
1390
+ // Find the menu section
1391
+ const menuMatch = agentXml.match(/(<menu>[\s\S]*?<\/menu>)/);
1392
+ if (!menuMatch) {
1393
+ return agentXml; // No menu found, skip injection
1394
+ }
1395
+
1396
+ const menuContent = menuMatch[1];
1397
+ const menuClosingMatch = menuContent.match(/(\s*)<\/menu>/);
1398
+ if (!menuClosingMatch) {
1399
+ return agentXml;
1400
+ }
1401
+
1402
+ const indent = menuClosingMatch[1];
1403
+ const menuItems = [];
1404
+
1405
+ if (!hasHelp) {
1406
+ menuItems.push(`${indent}<item cmd="*menu">[M] Redisplay Menu Options</item>`);
1407
+ }
1408
+
1409
+ if (!hasExit) {
1410
+ menuItems.push(`${indent}<item cmd="*dismiss">[D] Dismiss Agent</item>`);
1411
+ }
1412
+
1413
+ if (menuItems.length === 0) {
1414
+ return agentXml;
1415
+ }
1416
+
1417
+ // Inject menu items before closing </menu> tag
1418
+ const newMenuContent = menuContent.replace(/(\s*)<\/menu>/, `\n${menuItems.join('\n')}\n${indent}</menu>`);
1419
+ return agentXml.replace(menuContent, newMenuContent);
1420
+ }
1421
+
1422
+ /**
1423
+ * Inject web activation instructions into agent XML
1424
+ */
1425
+ injectWebActivation(agentXml) {
1426
+ // First, always inject help/exit menu items
1427
+ agentXml = this.injectHelpExitMenuItems(agentXml);
1428
+
1429
+ // Load the web activation template
1430
+ const activationPath = path.join(this.sourceDir, 'utility', 'models', 'agent-activation-web.xml');
1431
+
1432
+ if (!fs.existsSync(activationPath)) {
1433
+ console.warn(chalk.yellow('Warning: agent-activation-web.xml not found, skipping activation injection'));
1434
+ return agentXml;
1435
+ }
1436
+
1437
+ const activationXml = fs.readFileSync(activationPath, 'utf8');
1438
+
1439
+ // For web bundles, ALWAYS replace existing activation with web activation
1440
+ // This is because fragment-based activation assumes filesystem access which won't work in web bundles
1441
+ const hasActivation = agentXml.includes('<activation');
1442
+
1443
+ if (hasActivation) {
1444
+ // Replace existing activation block with web activation
1445
+ const injectedXml = agentXml.replace(/<activation[^>]*>[\s\S]*?<\/activation>/, activationXml);
1446
+ return injectedXml;
1447
+ }
1448
+
1449
+ // Check for critical-actions block (legacy)
1450
+ const hasCriticalActions = agentXml.includes('<critical-actions');
1451
+
1452
+ if (hasCriticalActions) {
1453
+ // Replace critical-actions block with activation
1454
+ const injectedXml = agentXml.replace(/<critical-actions>[\s\S]*?<\/critical-actions>/, activationXml);
1455
+ return injectedXml;
1456
+ }
1457
+
1458
+ // If no critical-actions, inject before closing </agent> tag
1459
+ const closingTagMatch = agentXml.match(/(\s*)<\/agent>/);
1460
+ if (!closingTagMatch) {
1461
+ console.warn(chalk.yellow('Warning: Could not find </agent> tag for activation injection'));
1462
+ return agentXml;
1463
+ }
1464
+
1465
+ // Inject the activation block before the closing </agent> tag
1466
+ // Properly indent each line of the activation XML
1467
+ const indent = closingTagMatch[1];
1468
+ const indentedActivation = activationXml
1469
+ .split('\n')
1470
+ .map((line) => (line.trim() ? indent + line : ''))
1471
+ .join('\n');
1472
+
1473
+ const injectedXml = agentXml.replace(/(\s*)<\/agent>/, `\n${indentedActivation}\n${indent}</agent>`);
1474
+
1475
+ return injectedXml;
1476
+ }
1477
+
1478
+ /**
1479
+ * Build the final agent bundle XML
1480
+ */
1481
+ buildAgentBundle(agentXml, dependencies) {
1482
+ // Web activation is now handled by fragments during YAML building
1483
+ // agentXml = this.injectWebActivation(agentXml);
1484
+
1485
+ const parts = [
1486
+ '<?xml version="1.0" encoding="UTF-8"?>',
1487
+ '<agent-bundle>',
1488
+ ' <!-- Agent Definition -->',
1489
+ ' ' + agentXml.replaceAll('\n', '\n '),
1490
+ ];
1491
+
1492
+ // Add dependencies (all are now consistently wrapped in <file> elements)
1493
+ if (dependencies && dependencies.size > 0) {
1494
+ parts.push('\n <!-- Dependencies -->');
1495
+ for (const [id, content] of dependencies) {
1496
+ // All dependencies are now wrapped in <file> elements
1497
+ // Indent properly
1498
+ const indentedContent = content
1499
+ .split('\n')
1500
+ .map((line) => ' ' + line)
1501
+ .join('\n');
1502
+ parts.push(indentedContent);
1503
+ }
1504
+ }
1505
+
1506
+ parts.push('</agent-bundle>');
1507
+
1508
+ return parts.join('\n');
1509
+ }
1510
+
1511
+ /**
1512
+ * Discover all modules
1513
+ */
1514
+ async discoverModules() {
1515
+ const modules = [];
1516
+
1517
+ // Check for the built-in xmc module directly under src/
1518
+ const xmcPath = getSourcePath('xmc');
1519
+ if (await fs.pathExists(xmcPath)) {
1520
+ modules.push('xmc');
1521
+ }
1522
+
1523
+ if (modules.length === 0) {
1524
+ console.log(chalk.yellow('No modules found under src/'));
1525
+ }
1526
+
1527
+ return modules;
1528
+ }
1529
+
1530
+ /**
1531
+ * Discover agents in a module
1532
+ */
1533
+ async discoverAgents(modulePath) {
1534
+ const agents = [];
1535
+ const agentsPath = path.join(modulePath, 'agents');
1536
+
1537
+ if (!(await fs.pathExists(agentsPath))) {
1538
+ return agents;
1539
+ }
1540
+
1541
+ const files = await fs.readdir(agentsPath);
1542
+
1543
+ for (const file of files) {
1544
+ // Look for .agent.yaml files (new format) or .md files (legacy format)
1545
+ if (file.endsWith('.agent.yaml') || (file.endsWith('.md') && !file.toLowerCase().includes('readme'))) {
1546
+ agents.push(file);
1547
+ }
1548
+ }
1549
+
1550
+ return agents;
1551
+ }
1552
+
1553
+ /**
1554
+ * Discover all teams in a module
1555
+ */
1556
+ async discoverTeams(modulePath) {
1557
+ const teams = [];
1558
+ const teamsPath = path.join(modulePath, 'teams');
1559
+
1560
+ if (!(await fs.pathExists(teamsPath))) {
1561
+ return teams;
1562
+ }
1563
+
1564
+ const files = await fs.readdir(teamsPath);
1565
+
1566
+ for (const file of files) {
1567
+ if (file.endsWith('.yaml') || file.endsWith('.yml')) {
1568
+ teams.push(file);
1569
+ }
1570
+ }
1571
+
1572
+ return teams;
1573
+ }
1574
+
1575
+ /**
1576
+ * Extract agent name from XML
1577
+ */
1578
+ getAgentName(xml) {
1579
+ const match = xml.match(/<agent[^>]*name="([^"]+)"/);
1580
+ return match ? match[1] : 'Unknown';
1581
+ }
1582
+
1583
+ /**
1584
+ * Extract agent description from XML
1585
+ */
1586
+ getAgentDescription(xml) {
1587
+ const match = xml.match(/<description>([^<]+)<\/description>/);
1588
+ return match ? match[1] : '';
1589
+ }
1590
+
1591
+ /**
1592
+ * Check if agent should be skipped for bundling
1593
+ */
1594
+ shouldSkipBundling(xml) {
1595
+ // Check for bundle="false" attribute in the agent tag
1596
+ const match = xml.match(/<agent[^>]*bundle="false"[^>]*>/);
1597
+ return match !== null;
1598
+ }
1599
+
1600
+ /**
1601
+ * Create temporary manifest files
1602
+ */
1603
+ async createTempManifests() {
1604
+ // Ensure temp directory exists
1605
+ await fs.ensureDir(this.tempManifestDir);
1606
+
1607
+ // Generate agent-manifest.csv using shared generator
1608
+ const agentPartyPath = path.join(this.tempManifestDir, 'agent-manifest.csv');
1609
+ await AgentPartyGenerator.writeAgentParty(agentPartyPath, this.discoveredAgents, { forWeb: true });
1610
+
1611
+ console.log(chalk.dim(' ✓ Created temporary manifest files'));
1612
+ }
1613
+
1614
+ /**
1615
+ * Clean up temporary files
1616
+ */
1617
+ async cleanupTempFiles() {
1618
+ if (await fs.pathExists(this.tempDir)) {
1619
+ await fs.remove(this.tempDir);
1620
+ console.log(chalk.dim('\n✓ Cleaned up temporary files'));
1621
+ }
1622
+ }
1623
+
1624
+ /**
1625
+ * Validate XML content
1626
+ */
1627
+ async validateXml(xmlContent) {
1628
+ try {
1629
+ await xml2js.parseStringPromise(xmlContent, {
1630
+ strict: true,
1631
+ explicitArray: false,
1632
+ });
1633
+ return true;
1634
+ } catch {
1635
+ return false;
1636
+ }
1637
+ }
1638
+
1639
+ /**
1640
+ * Format XML content for readability
1641
+ */
1642
+ formatXml(xml) {
1643
+ const TAB = ' '; // 2 spaces
1644
+ let result = '';
1645
+ let depth = 0;
1646
+
1647
+ // Split by tags while preserving them
1648
+ const parts = xml.split(/(<[^>]+>)/g);
1649
+
1650
+ for (let i = 0; i < parts.length; i++) {
1651
+ const part = parts[i];
1652
+ if (!part) continue;
1653
+
1654
+ if (part.startsWith('<?xml')) {
1655
+ // XML declaration - no indent
1656
+ result += part + '\n';
1657
+ } else if (part.startsWith('<!--')) {
1658
+ // Comment
1659
+ result += TAB.repeat(depth) + part + '\n';
1660
+ } else if (part.startsWith('</')) {
1661
+ // Closing tag - unindent first
1662
+ depth = Math.max(0, depth - 1);
1663
+ result += TAB.repeat(depth) + part + '\n';
1664
+ } else if (part.startsWith('<')) {
1665
+ // Opening or self-closing tag
1666
+ const isSelfClosing = part.endsWith('/>');
1667
+ const tagName = part.match(/<(\w+)/)?.[1];
1668
+
1669
+ // Check if next part is simple text content
1670
+ const nextPart = parts[i + 1];
1671
+ const hasSimpleContent = nextPart && !nextPart.startsWith('<') && nextPart.trim().length > 0 && nextPart.trim().length <= 100;
1672
+
1673
+ if (hasSimpleContent && parts[i + 2] && parts[i + 2] === `</${tagName}>`) {
1674
+ // Simple tag with inline content: <tag>content</tag>
1675
+ result += TAB.repeat(depth) + part + nextPart.trim() + parts[i + 2] + '\n';
1676
+ i += 2; // Skip content and closing tag
1677
+ } else {
1678
+ // Multi-line tag
1679
+ result += TAB.repeat(depth) + part + '\n';
1680
+ if (!isSelfClosing) {
1681
+ depth++;
1682
+ }
1683
+ }
1684
+ } else {
1685
+ // Text content between tags
1686
+ const trimmed = part.trim();
1687
+ if (trimmed) {
1688
+ result += TAB.repeat(depth) + trimmed + '\n';
1689
+ }
1690
+ }
1691
+ }
1692
+
1693
+ return result;
1694
+ }
1695
+
1696
+ /**
1697
+ * Display summary statistics
1698
+ */
1699
+ displaySummary() {
1700
+ console.log(chalk.cyan.bold('\n═══════════════════════════════════════════════'));
1701
+ console.log(chalk.cyan.bold(' SUMMARY'));
1702
+ console.log(chalk.cyan.bold('═══════════════════════════════════════════════\n'));
1703
+
1704
+ console.log(chalk.bold('Bundle Statistics:'));
1705
+ console.log(` Total agents found: ${this.stats.totalAgents}`);
1706
+ console.log(` Successfully bundled: ${chalk.green(this.stats.bundledAgents)}`);
1707
+ if (this.stats.skippedAgents > 0) {
1708
+ console.log(` Skipped (webskip/bundle): ${chalk.gray(this.stats.skippedAgents)}`);
1709
+ }
1710
+
1711
+ if (this.stats.failedAgents > 0) {
1712
+ console.log(` Failed to bundle: ${chalk.red(this.stats.failedAgents)}`);
1713
+ }
1714
+
1715
+ if (this.stats.invalidXml > 0) {
1716
+ console.log(` Invalid XML bundles: ${chalk.yellow(this.stats.invalidXml)}`);
1717
+ }
1718
+
1719
+ // Display warnings summary
1720
+ // Check if there are actually any warnings with content
1721
+ const hasActualWarnings = this.stats.warnings.some((w) => w && w.warnings && w.warnings.length > 0);
1722
+
1723
+ if (hasActualWarnings) {
1724
+ console.log(chalk.yellow('\n⚠ Missing Dependencies by Agent:'));
1725
+
1726
+ // Group and display warnings by agent
1727
+ for (const agentWarning of this.stats.warnings) {
1728
+ if (agentWarning && agentWarning.warnings && agentWarning.warnings.length > 0) {
1729
+ console.log(chalk.bold(`\n ${agentWarning.agent}:`));
1730
+ // Display unique warnings for this agent
1731
+ const uniqueWarnings = [...new Set(agentWarning.warnings)];
1732
+ for (const warning of uniqueWarnings) {
1733
+ console.log(chalk.dim(` • ${warning}`));
1734
+ }
1735
+ }
1736
+ }
1737
+ } else {
1738
+ console.log(chalk.green('\n✓ No missing dependencies'));
1739
+ }
1740
+
1741
+ // Final status
1742
+ if (this.stats.invalidXml > 0) {
1743
+ console.log(chalk.yellow('\n⚠ Some bundles have invalid XML. Please review the output.'));
1744
+ } else if (this.stats.failedAgents > 0) {
1745
+ console.log(chalk.yellow('\n⚠ Some agents failed to bundle. Please review the errors.'));
1746
+ } else {
1747
+ console.log(chalk.green('\n✨ All bundles generated successfully!'));
1748
+ }
1749
+
1750
+ console.log(chalk.cyan.bold('\n═══════════════════════════════════════════════\n'));
1751
+ }
1752
+ }
1753
+
1754
+ module.exports = { WebBundler };