@zeyue0329/xiaoma-cli 1.6.5 → 1.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (755) hide show
  1. package/README.md +13 -13
  2. package/package.json +5 -13
  3. package/pipeline-optimization-report.md +455 -0
  4. package/src/core/module-help.csv +7 -6
  5. package/src/core/skills/xiaoma-advanced-elicitation/SKILL.md +6 -0
  6. package/src/core/{workflows/advanced-elicitation → skills/xiaoma-advanced-elicitation}/workflow.md +6 -9
  7. package/src/core/skills/xiaoma-brainstorming/SKILL.md +6 -0
  8. package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/steps/step-01-session-setup.md +5 -1
  9. package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/steps/step-01b-continue.md +3 -1
  10. package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/steps/step-02a-user-selected.md +5 -1
  11. package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/steps/step-02b-ai-recommended.md +3 -1
  12. package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/steps/step-02c-random-selection.md +3 -1
  13. package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/steps/step-02d-progressive-flow.md +3 -1
  14. package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/steps/step-03-technique-execution.md +4 -2
  15. package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/steps/step-04-idea-organization.md +2 -0
  16. package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/workflow.md +1 -8
  17. package/src/core/skills/xiaoma-distillator/SKILL.md +178 -0
  18. package/src/core/skills/xiaoma-distillator/agents/distillate-compressor.md +116 -0
  19. package/src/core/skills/xiaoma-distillator/agents/round-trip-reconstructor.md +68 -0
  20. package/src/core/skills/xiaoma-distillator/resources/compression-rules.md +51 -0
  21. package/src/core/skills/xiaoma-distillator/resources/distillate-format-reference.md +227 -0
  22. package/src/core/skills/xiaoma-distillator/resources/splitting-strategy.md +78 -0
  23. package/src/core/skills/xiaoma-distillator/scripts/analyze_sources.py +300 -0
  24. package/src/core/skills/xiaoma-distillator/scripts/tests/test_analyze_sources.py +204 -0
  25. package/src/core/skills/xiaoma-distillator/xiaoma-skill-manifest.yaml +15 -0
  26. package/src/core/skills/xiaoma-editorial-review-prose/SKILL.md +6 -0
  27. package/src/core/skills/xiaoma-editorial-review-prose/workflow.md +81 -0
  28. package/src/core/skills/xiaoma-editorial-review-structure/SKILL.md +6 -0
  29. package/src/core/skills/xiaoma-editorial-review-structure/workflow.md +174 -0
  30. package/src/core/skills/xiaoma-editorial-review-structure/xiaoma-skill-manifest.yaml +1 -0
  31. package/src/core/skills/xiaoma-help/SKILL.md +6 -0
  32. package/src/core/{tasks → skills}/xiaoma-help/workflow.md +5 -5
  33. package/src/core/skills/xiaoma-help/xiaoma-skill-manifest.yaml +1 -0
  34. package/src/core/skills/xiaoma-index-docs/SKILL.md +6 -0
  35. package/src/core/skills/xiaoma-index-docs/workflow.md +61 -0
  36. package/src/core/skills/xiaoma-index-docs/xiaoma-skill-manifest.yaml +1 -0
  37. package/src/core/skills/xiaoma-party-mode/SKILL.md +6 -0
  38. package/src/core/{workflows/party-mode → skills/xiaoma-party-mode}/steps/step-03-graceful-exit.md +0 -1
  39. package/src/core/{workflows/party-mode → skills/xiaoma-party-mode}/workflow.md +0 -4
  40. package/src/core/skills/xiaoma-party-mode/xiaoma-skill-manifest.yaml +1 -0
  41. package/src/core/{tasks → skills}/xiaoma-review-adversarial-general/SKILL.md +1 -1
  42. package/src/core/skills/xiaoma-review-adversarial-general/xiaoma-skill-manifest.yaml +1 -0
  43. package/src/core/{tasks → skills}/xiaoma-review-edge-case-hunter/SKILL.md +2 -2
  44. package/src/core/skills/xiaoma-review-edge-case-hunter/xiaoma-skill-manifest.yaml +1 -0
  45. package/src/core/skills/xiaoma-shard-doc/SKILL.md +6 -0
  46. package/src/core/skills/xiaoma-shard-doc/workflow.md +100 -0
  47. package/src/core/skills/xiaoma-shard-doc/xiaoma-skill-manifest.yaml +1 -0
  48. package/src/core/tasks/xiaoma-create-prd/SKILL.md +6 -0
  49. package/src/core/tasks/xiaoma-create-prd/data/domain-complexity.csv +15 -0
  50. package/src/core/tasks/xiaoma-create-prd/data/prd-purpose.md +197 -0
  51. package/src/core/tasks/xiaoma-create-prd/data/project-types.csv +11 -0
  52. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-01-init.md +7 -20
  53. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-01b-continue.md +29 -20
  54. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-02-discovery.md +7 -23
  55. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-02b-vision.md +5 -17
  56. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-02c-executive-summary.md +5 -17
  57. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-03-success.md +5 -17
  58. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-04-journeys.md +5 -17
  59. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-05-domain.md +7 -20
  60. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-06-innovation.md +8 -23
  61. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-07-project-type.md +6 -21
  62. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-08-scoping.md +5 -17
  63. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-09-functional.md +5 -17
  64. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-10-nonfunctional.md +5 -17
  65. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-11-polish.md +23 -19
  66. package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/steps-c/step-12-complete.md +3 -12
  67. package/src/{xmc/workflows/2-plan-workflows/create-prd/workflow-create-prd.md → core/tasks/xiaoma-create-prd/workflow.md} +3 -4
  68. package/src/core/tasks/xiaoma-create-prd/xiaoma-skill-manifest.yaml +1 -0
  69. package/src/utility/agent-components/activation-steps.txt +2 -2
  70. package/src/xmc/agents/analyst.agent.yaml +10 -6
  71. package/src/xmc/agents/architect.agent.yaml +2 -2
  72. package/src/xmc/agents/dev.agent.yaml +2 -2
  73. package/src/xmc/agents/pm.agent.yaml +6 -6
  74. package/src/xmc/agents/qa.agent.yaml +1 -1
  75. package/src/xmc/agents/quick-flow-solo-dev.agent.yaml +3 -3
  76. package/src/xmc/agents/sm.agent.yaml +8 -4
  77. package/src/xmc/agents/tech-writer/tech-writer.agent.yaml +1 -1
  78. package/src/xmc/agents/ux-designer.agent.yaml +1 -1
  79. package/src/xmc/module-help.csv +25 -25
  80. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/SKILL.md +6 -0
  81. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/checklist.md +28 -0
  82. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-01-init-and-validate.md +102 -0
  83. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-02-requirements-analysis.md +146 -0
  84. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-03-architecture-analysis.md +141 -0
  85. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-04-create-prd.md +101 -0
  86. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-05-validate-prd.md +106 -0
  87. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-06-create-epics.md +104 -0
  88. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-07-create-architecture.md +107 -0
  89. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-08-finalize.md +124 -0
  90. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/workflow.md +107 -0
  91. package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/xiaoma-skill-manifest.yaml +3 -0
  92. package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/SKILL.md +6 -0
  93. package/src/xmc/workflows/1-analysis/research/{domain-steps → xiaoma-domain-research/domain-steps}/step-01-init.md +2 -2
  94. package/src/xmc/workflows/1-analysis/research/{domain-steps → xiaoma-domain-research/domain-steps}/step-02-domain-analysis.md +2 -2
  95. package/src/xmc/workflows/1-analysis/research/{domain-steps → xiaoma-domain-research/domain-steps}/step-03-competitive-landscape.md +2 -2
  96. package/src/xmc/workflows/1-analysis/research/{domain-steps → xiaoma-domain-research/domain-steps}/step-04-regulatory-focus.md +2 -2
  97. package/src/xmc/workflows/1-analysis/research/{domain-steps → xiaoma-domain-research/domain-steps}/step-05-technical-trends.md +1 -1
  98. package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/research.template.md +29 -0
  99. package/src/xmc/workflows/1-analysis/research/{workflow-domain-research.md → xiaoma-domain-research/workflow.md} +0 -5
  100. package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/xiaoma-skill-manifest.yaml +1 -0
  101. package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/SKILL.md +6 -0
  102. package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/research.template.md +29 -0
  103. package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-01-init.md +184 -0
  104. package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-02-customer-behavior.md +239 -0
  105. package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-03-customer-pain-points.md +251 -0
  106. package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-04-customer-decisions.md +261 -0
  107. package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-05-competitive-analysis.md +173 -0
  108. package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-06-research-completion.md +478 -0
  109. package/src/xmc/workflows/1-analysis/research/{workflow-market-research.md → xiaoma-market-research/workflow.md} +1 -6
  110. package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/xiaoma-skill-manifest.yaml +1 -0
  111. package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/SKILL.md +6 -0
  112. package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/research.template.md +29 -0
  113. package/src/xmc/workflows/1-analysis/research/{technical-steps → xiaoma-technical-research/technical-steps}/step-01-init.md +2 -2
  114. package/src/xmc/workflows/1-analysis/research/{technical-steps → xiaoma-technical-research/technical-steps}/step-02-technical-overview.md +2 -2
  115. package/src/xmc/workflows/1-analysis/research/{technical-steps → xiaoma-technical-research/technical-steps}/step-03-integration-patterns.md +2 -2
  116. package/src/xmc/workflows/1-analysis/research/{technical-steps → xiaoma-technical-research/technical-steps}/step-04-architectural-patterns.md +2 -2
  117. package/src/xmc/workflows/1-analysis/research/{technical-steps → xiaoma-technical-research/technical-steps}/step-05-implementation-research.md +2 -2
  118. package/src/xmc/workflows/1-analysis/research/{workflow-technical-research.md → xiaoma-technical-research/workflow.md} +0 -4
  119. package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/xiaoma-skill-manifest.yaml +1 -0
  120. package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/SKILL.md +6 -0
  121. package/src/xmc/workflows/1-analysis/{create-product-brief → xiaoma-create-product-brief}/product-brief.template.md +2 -2
  122. package/src/xmc/workflows/1-analysis/{create-product-brief → xiaoma-create-product-brief}/steps/step-01-init.md +5 -12
  123. package/src/xmc/workflows/1-analysis/{create-product-brief → xiaoma-create-product-brief}/steps/step-01b-continue.md +3 -6
  124. package/src/xmc/workflows/1-analysis/{create-product-brief → xiaoma-create-product-brief}/steps/step-02-vision.md +5 -11
  125. package/src/xmc/workflows/1-analysis/{create-product-brief → xiaoma-create-product-brief}/steps/step-03-users.md +5 -11
  126. package/src/xmc/workflows/1-analysis/{create-product-brief → xiaoma-create-product-brief}/steps/step-04-metrics.md +5 -11
  127. package/src/xmc/workflows/1-analysis/{create-product-brief → xiaoma-create-product-brief}/steps/step-05-scope.md +5 -11
  128. package/src/xmc/workflows/1-analysis/{create-product-brief → xiaoma-create-product-brief}/steps/step-06-complete.md +0 -3
  129. package/src/xmc/workflows/1-analysis/{create-product-brief → xiaoma-create-product-brief}/workflow.md +4 -6
  130. package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/xiaoma-skill-manifest.yaml +1 -0
  131. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/SKILL.md +88 -0
  132. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/agents/artifact-analyzer.md +60 -0
  133. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/agents/opportunity-reviewer.md +44 -0
  134. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/agents/skeptic-reviewer.md +44 -0
  135. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/agents/web-researcher.md +49 -0
  136. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/prompts/contextual-discovery.md +57 -0
  137. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/prompts/draft-and-review.md +86 -0
  138. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/prompts/finalize.md +75 -0
  139. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/prompts/guided-elicitation.md +70 -0
  140. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/resources/brief-template.md +60 -0
  141. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/xiaoma-manifest.json +17 -0
  142. package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/xiaoma-skill-manifest.yaml +1 -0
  143. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-01-discovery.md +2 -4
  144. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-10-smart-validation.md +1 -1
  145. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-11-holistic-quality-validation.md +3 -3
  146. package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +2 -1
  147. package/src/xmc/workflows/2-plan-workflows/create-prd/workflow-validate-prd.md +2 -0
  148. package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/SKILL.md +6 -0
  149. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-01-init.md +4 -4
  150. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-01b-continue.md +4 -4
  151. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-02-discovery.md +4 -4
  152. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-03-core-experience.md +7 -6
  153. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-04-emotional-response.md +7 -6
  154. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-05-inspiration.md +7 -6
  155. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-06-design-system.md +7 -6
  156. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-07-defining-experience.md +7 -6
  157. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-08-visual-foundation.md +7 -6
  158. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-09-design-directions.md +7 -6
  159. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-10-user-journeys.md +7 -6
  160. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-11-component-strategy.md +7 -6
  161. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-12-ux-patterns.md +7 -6
  162. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-13-responsive-accessibility.md +7 -6
  163. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/steps/step-14-complete.md +2 -2
  164. package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/workflow.md +2 -8
  165. package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/xiaoma-skill-manifest.yaml +1 -0
  166. package/src/xmc/workflows/2-plan-workflows/xiaoma-edit-prd/SKILL.md +6 -0
  167. package/src/xmc/workflows/2-plan-workflows/{create-prd → xiaoma-edit-prd}/steps-e/step-e-01-discovery.md +3 -8
  168. package/src/xmc/workflows/2-plan-workflows/{create-prd → xiaoma-edit-prd}/steps-e/step-e-01b-legacy-conversion.md +1 -5
  169. package/src/xmc/workflows/2-plan-workflows/{create-prd → xiaoma-edit-prd}/steps-e/step-e-02-review.md +5 -9
  170. package/src/xmc/workflows/2-plan-workflows/{create-prd → xiaoma-edit-prd}/steps-e/step-e-03-edit.md +3 -6
  171. package/src/xmc/workflows/2-plan-workflows/{create-prd → xiaoma-edit-prd}/steps-e/step-e-04-complete.md +2 -5
  172. package/src/xmc/workflows/2-plan-workflows/{create-prd/workflow-edit-prd.md → xiaoma-edit-prd/workflow.md} +2 -4
  173. package/src/xmc/workflows/2-plan-workflows/xiaoma-edit-prd/xiaoma-skill-manifest.yaml +1 -0
  174. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/SKILL.md +6 -0
  175. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/data/domain-complexity.csv +15 -0
  176. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/data/prd-purpose.md +197 -0
  177. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/data/project-types.csv +11 -0
  178. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-01-discovery.md +221 -0
  179. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-02-format-detection.md +188 -0
  180. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-02b-parity-check.md +206 -0
  181. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-03-density-validation.md +171 -0
  182. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-04-brief-coverage-validation.md +211 -0
  183. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-05-measurability-validation.md +225 -0
  184. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-06-traceability-validation.md +214 -0
  185. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-07-implementation-leakage-validation.md +202 -0
  186. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-08-domain-compliance-validation.md +240 -0
  187. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-09-project-type-validation.md +260 -0
  188. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-10-smart-validation.md +206 -0
  189. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-11-holistic-quality-validation.md +261 -0
  190. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-12-completeness-validation.md +239 -0
  191. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-13-report-complete.md +229 -0
  192. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/workflow.md +62 -0
  193. package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/xiaoma-skill-manifest.yaml +1 -0
  194. package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/SKILL.md +6 -0
  195. package/src/xmc/workflows/3-solutioning/{check-implementation-readiness → xiaoma-check-implementation-readiness}/steps/step-01-document-discovery.md +3 -8
  196. package/src/xmc/workflows/3-solutioning/{check-implementation-readiness → xiaoma-check-implementation-readiness}/steps/step-02-prd-analysis.md +1 -5
  197. package/src/xmc/workflows/3-solutioning/{check-implementation-readiness → xiaoma-check-implementation-readiness}/steps/step-03-epic-coverage-validation.md +1 -5
  198. package/src/xmc/workflows/3-solutioning/{check-implementation-readiness → xiaoma-check-implementation-readiness}/steps/step-04-ux-alignment.md +1 -5
  199. package/src/xmc/workflows/3-solutioning/{check-implementation-readiness → xiaoma-check-implementation-readiness}/steps/step-05-epic-quality-review.md +2 -6
  200. package/src/xmc/workflows/3-solutioning/{check-implementation-readiness → xiaoma-check-implementation-readiness}/steps/step-06-final-assessment.md +0 -3
  201. package/src/xmc/workflows/3-solutioning/{check-implementation-readiness → xiaoma-check-implementation-readiness}/workflow.md +0 -5
  202. package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/xiaoma-skill-manifest.yaml +1 -0
  203. package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/SKILL.md +6 -0
  204. package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/steps/step-01-init.md +6 -6
  205. package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/steps/step-01b-continue.md +9 -9
  206. package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/steps/step-02-context.md +6 -6
  207. package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/steps/step-03-starter.md +6 -6
  208. package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/steps/step-04-decisions.md +6 -6
  209. package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/steps/step-05-patterns.md +6 -6
  210. package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/steps/step-06-structure.md +6 -6
  211. package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/steps/step-07-validation.md +6 -6
  212. package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/workflow.md +1 -12
  213. package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/xiaoma-skill-manifest.yaml +1 -0
  214. package/src/xmc/workflows/3-solutioning/xiaoma-create-epics-and-stories/SKILL.md +6 -0
  215. package/src/xmc/workflows/3-solutioning/{create-epics-and-stories → xiaoma-create-epics-and-stories}/steps/step-01-validate-prerequisites.md +37 -41
  216. package/src/xmc/workflows/3-solutioning/{create-epics-and-stories → xiaoma-create-epics-and-stories}/steps/step-02-design-epics.md +7 -28
  217. package/src/xmc/workflows/3-solutioning/{create-epics-and-stories → xiaoma-create-epics-and-stories}/steps/step-03-create-stories.md +13 -30
  218. package/src/xmc/workflows/3-solutioning/{create-epics-and-stories → xiaoma-create-epics-and-stories}/steps/step-04-final-validation.md +2 -20
  219. package/src/xmc/workflows/3-solutioning/{create-epics-and-stories → xiaoma-create-epics-and-stories}/templates/epics-template.md +4 -0
  220. package/src/xmc/workflows/3-solutioning/{create-epics-and-stories → xiaoma-create-epics-and-stories}/workflow.md +1 -6
  221. package/src/xmc/workflows/3-solutioning/xiaoma-create-epics-and-stories/xiaoma-skill-manifest.yaml +1 -0
  222. package/src/xmc/workflows/4-implementation/auto-story-pipeline/SKILL.md +6 -0
  223. package/src/xmc/workflows/4-implementation/auto-story-pipeline/checklist.md +22 -0
  224. package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-01-init-and-validate.md +163 -0
  225. package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-02-create-story.md +92 -0
  226. package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-03-validate-story.md +105 -0
  227. package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-04-develop-story.md +90 -0
  228. package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-05-code-review.md +95 -0
  229. package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-06-test-story.md +144 -0
  230. package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-07-fix-and-retest.md +128 -0
  231. package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-08-complete-story.md +115 -0
  232. package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-09-cycle-check.md +144 -0
  233. package/src/xmc/workflows/4-implementation/auto-story-pipeline/workflow.md +92 -0
  234. package/src/xmc/workflows/4-implementation/auto-story-pipeline/xiaoma-skill-manifest.yaml +3 -0
  235. package/src/xmc/workflows/4-implementation/xiaoma-code-review/SKILL.md +6 -0
  236. package/src/xmc/workflows/4-implementation/xiaoma-code-review/steps/step-01-gather-context.md +61 -0
  237. package/src/xmc/workflows/4-implementation/xiaoma-code-review/steps/step-02-review.md +41 -0
  238. package/src/xmc/workflows/4-implementation/xiaoma-code-review/steps/step-03-triage.md +50 -0
  239. package/src/xmc/workflows/4-implementation/xiaoma-code-review/steps/step-04-present.md +38 -0
  240. package/src/xmc/workflows/4-implementation/xiaoma-code-review/workflow.md +54 -0
  241. package/src/xmc/workflows/4-implementation/xiaoma-code-review/xiaoma-skill-manifest.yaml +1 -0
  242. package/src/xmc/workflows/4-implementation/xiaoma-correct-course/SKILL.md +6 -0
  243. package/src/xmc/workflows/4-implementation/{correct-course → xiaoma-correct-course}/checklist.md +1 -1
  244. package/src/xmc/workflows/4-implementation/{correct-course → xiaoma-correct-course}/workflow.md +3 -10
  245. package/src/xmc/workflows/4-implementation/xiaoma-correct-course/xiaoma-skill-manifest.yaml +1 -0
  246. package/src/xmc/workflows/4-implementation/xiaoma-create-story/SKILL.md +6 -0
  247. package/src/xmc/workflows/4-implementation/{create-story → xiaoma-create-story}/checklist.md +2 -2
  248. package/src/xmc/workflows/4-implementation/{create-story → xiaoma-create-story}/workflow.md +3 -11
  249. package/src/xmc/workflows/4-implementation/xiaoma-create-story/xiaoma-skill-manifest.yaml +1 -0
  250. package/src/xmc/workflows/4-implementation/xiaoma-dev-story/SKILL.md +6 -0
  251. package/src/xmc/workflows/4-implementation/{dev-story → xiaoma-dev-story}/workflow.md +0 -7
  252. package/src/xmc/workflows/4-implementation/xiaoma-dev-story/xiaoma-skill-manifest.yaml +1 -0
  253. package/src/xmc/workflows/4-implementation/xiaoma-retrospective/SKILL.md +6 -0
  254. package/src/xmc/workflows/4-implementation/{retrospective → xiaoma-retrospective}/workflow.md +0 -6
  255. package/src/xmc/workflows/4-implementation/xiaoma-retrospective/xiaoma-skill-manifest.yaml +1 -0
  256. package/src/xmc/workflows/4-implementation/xiaoma-sprint-planning/SKILL.md +6 -0
  257. package/src/xmc/workflows/4-implementation/{sprint-planning → xiaoma-sprint-planning}/workflow.md +0 -8
  258. package/src/xmc/workflows/4-implementation/xiaoma-sprint-planning/xiaoma-skill-manifest.yaml +1 -0
  259. package/src/xmc/workflows/4-implementation/xiaoma-sprint-status/SKILL.md +6 -0
  260. package/src/xmc/workflows/4-implementation/{sprint-status → xiaoma-sprint-status}/workflow.md +0 -6
  261. package/src/xmc/workflows/4-implementation/xiaoma-sprint-status/xiaoma-skill-manifest.yaml +1 -0
  262. package/src/xmc/workflows/xiaoma-document-project/SKILL.md +6 -0
  263. package/src/xmc/workflows/{document-project → xiaoma-document-project}/instructions.md +6 -6
  264. package/src/xmc/workflows/xiaoma-document-project/workflow.md +27 -0
  265. package/src/xmc/workflows/{document-project → xiaoma-document-project}/workflows/deep-dive-instructions.md +3 -1
  266. package/src/xmc/workflows/{document-project → xiaoma-document-project}/workflows/deep-dive-workflow.md +4 -12
  267. package/src/xmc/workflows/{document-project → xiaoma-document-project}/workflows/full-scan-instructions.md +5 -3
  268. package/src/xmc/workflows/{document-project → xiaoma-document-project}/workflows/full-scan-workflow.md +4 -12
  269. package/src/xmc/workflows/xiaoma-document-project/xiaoma-skill-manifest.yaml +1 -0
  270. package/src/xmc/workflows/xiaoma-generate-project-context/SKILL.md +6 -0
  271. package/src/xmc/workflows/{generate-project-context → xiaoma-generate-project-context}/steps/step-01-discover.md +4 -2
  272. package/src/xmc/workflows/{generate-project-context → xiaoma-generate-project-context}/steps/step-02-generate.md +8 -5
  273. package/src/xmc/workflows/{generate-project-context → xiaoma-generate-project-context}/workflow.md +2 -8
  274. package/src/xmc/workflows/xiaoma-generate-project-context/xiaoma-skill-manifest.yaml +1 -0
  275. package/src/xmc/workflows/xiaoma-qa-generate-e2e-tests/SKILL.md +6 -0
  276. package/src/xmc/workflows/{qa-generate-e2e-tests → xiaoma-qa-generate-e2e-tests}/workflow.md +2 -9
  277. package/src/xmc/workflows/xiaoma-qa-generate-e2e-tests/xiaoma-skill-manifest.yaml +1 -0
  278. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/SKILL.md +6 -0
  279. package/src/xmc/workflows/xiaoma-quick-flow/{quick-dev → xiaoma-quick-dev}/steps/step-01-mode-detection.md +9 -14
  280. package/src/xmc/workflows/xiaoma-quick-flow/{quick-dev → xiaoma-quick-dev}/steps/step-02-context-gathering.md +1 -5
  281. package/src/xmc/workflows/xiaoma-quick-flow/{quick-dev → xiaoma-quick-dev}/steps/step-03-execute.md +1 -5
  282. package/src/xmc/workflows/xiaoma-quick-flow/{quick-dev → xiaoma-quick-dev}/steps/step-04-self-check.md +1 -5
  283. package/src/xmc/workflows/xiaoma-quick-flow/{quick-dev → xiaoma-quick-dev}/steps/step-05-adversarial-review.md +1 -5
  284. package/src/xmc/workflows/xiaoma-quick-flow/{quick-dev → xiaoma-quick-dev}/steps/step-06-resolve-findings.md +0 -2
  285. package/src/xmc/workflows/xiaoma-quick-flow/{quick-dev → xiaoma-quick-dev}/workflow.md +1 -13
  286. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/xiaoma-skill-manifest.yaml +1 -0
  287. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/SKILL.md +2 -2
  288. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-01-clarify-and-route.md +2 -5
  289. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-02-plan.md +2 -6
  290. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-03-implement.md +1 -3
  291. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-04-review.md +3 -8
  292. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-05-present.md +2 -4
  293. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/workflow.md +0 -5
  294. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-spec/SKILL.md +6 -0
  295. package/src/xmc/workflows/xiaoma-quick-flow/{quick-spec → xiaoma-quick-spec}/steps/step-01-understand.md +7 -11
  296. package/src/xmc/workflows/xiaoma-quick-flow/{quick-spec → xiaoma-quick-spec}/steps/step-02-investigate.md +3 -6
  297. package/src/xmc/workflows/xiaoma-quick-flow/{quick-spec → xiaoma-quick-spec}/steps/step-03-generate.md +1 -4
  298. package/src/xmc/workflows/xiaoma-quick-flow/{quick-spec → xiaoma-quick-spec}/steps/step-04-review.md +5 -8
  299. package/src/xmc/workflows/xiaoma-quick-flow/{quick-spec → xiaoma-quick-spec}/workflow.md +1 -7
  300. package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-spec/xiaoma-skill-manifest.yaml +1 -0
  301. package/tools/cli/external-official-modules.yaml +2 -54
  302. package/tools/cli/installers/install-messages.yaml +2 -2
  303. package/tools/cli/installers/lib/core/config-collector.js +1 -1
  304. package/tools/cli/installers/lib/core/detector.js +1 -1
  305. package/tools/cli/installers/lib/core/installer.js +30 -13
  306. package/tools/cli/installers/lib/core/manifest-generator.js +4 -4
  307. package/tools/cli/installers/lib/core/manifest.js +6 -4
  308. package/tools/cli/installers/lib/custom/handler.js +2 -2
  309. package/tools/cli/installers/lib/ide/_base-ide.js +1 -2
  310. package/tools/cli/installers/lib/ide/_config-driven.js +11 -6
  311. package/tools/cli/installers/lib/ide/manager.js +8 -8
  312. package/tools/cli/installers/lib/ide/shared/agent-command-generator.js +2 -2
  313. package/tools/cli/installers/lib/ide/shared/skill-manifest.js +2 -2
  314. package/tools/cli/installers/lib/ide/shared/task-tool-command-generator.js +5 -5
  315. package/tools/cli/installers/lib/ide/shared/xiaoma-artifacts.js +4 -4
  316. package/tools/cli/installers/lib/ide/templates/combined/gemini-agent.toml +5 -5
  317. package/tools/cli/installers/lib/ide/templates/combined/gemini-task.toml +4 -4
  318. package/tools/cli/installers/lib/ide/templates/combined/gemini-tool.toml +4 -4
  319. package/tools/cli/installers/lib/ide/templates/combined/gemini-workflow-yaml.toml +3 -3
  320. package/tools/cli/installers/lib/ide/templates/combined/gemini-workflow.toml +3 -3
  321. package/tools/cli/installers/lib/modules/manager.js +8 -8
  322. package/tools/cli/lib/agent/compiler.js +1 -1
  323. package/tools/cli/lib/agent/installer.js +4 -4
  324. package/tools/cli/lib/agent-party-generator.js +1 -1
  325. package/tools/cli/lib/ui.js +37 -17
  326. package/tools/cli/lib/yaml-format.js +1 -1
  327. package/tools/cli/xiaoma-cli.js +0 -0
  328. package/tools/xiaoma-npx-wrapper.js +0 -0
  329. package/.github/workflows/quality.yaml +0 -116
  330. package/.husky/pre-commit +0 -26
  331. package/.idea/codeStyles/Project.xml +0 -60
  332. package/.idea/codeStyles/codeStyleConfig.xml +0 -5
  333. package/.idea/inspectionProfiles/Project_Default.xml +0 -6
  334. package/.idea/jsLibraryMappings.xml +0 -6
  335. package/.idea/modules.xml +0 -8
  336. package/.idea/prettier.xml +0 -6
  337. package/.idea/vcs.xml +0 -6
  338. package/.idea/workspace.xml +0 -133
  339. package/.markdownlint-cli2.yaml +0 -41
  340. package/.prettierignore +0 -12
  341. package/.vscode/settings.json +0 -96
  342. package/XIAOMA-CLI-GUIDE.md +0 -512
  343. package/XiaoMa-Cli.iml +0 -9
  344. package/custom/src/agents/commit-poet/commit-poet.agent.yaml +0 -129
  345. package/custom/src/agents/commit-poet/installation-guide.md +0 -36
  346. package/custom/src/agents/toolsmith/installation-guide.md +0 -36
  347. package/custom/src/agents/toolsmith/toolsmith-sidecar/instructions.md +0 -70
  348. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/bundlers.md +0 -111
  349. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/deploy.md +0 -70
  350. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/docs.md +0 -114
  351. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/installers.md +0 -134
  352. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/modules.md +0 -160
  353. package/custom/src/agents/toolsmith/toolsmith-sidecar/knowledge/tests.md +0 -103
  354. package/custom/src/agents/toolsmith/toolsmith-sidecar/memories.md +0 -17
  355. package/custom/src/agents/toolsmith/toolsmith.agent.yaml +0 -108
  356. package/docs/BUNDLE_DISTRIBUTION_SETUP.md +0 -95
  357. package/docs/agent-customization-guide.md +0 -208
  358. package/docs/custom-agent-installation.md +0 -183
  359. package/docs/document-sharding-guide.md +0 -449
  360. package/docs/explanation/advanced-elicitation.md +0 -49
  361. package/docs/explanation/adversarial-review.md +0 -59
  362. package/docs/explanation/brainstorming.md +0 -33
  363. package/docs/explanation/established-projects-faq.md +0 -50
  364. package/docs/explanation/party-mode.md +0 -59
  365. package/docs/explanation/preventing-agent-conflicts.md +0 -112
  366. package/docs/explanation/project-context.md +0 -157
  367. package/docs/explanation/quick-dev-new-preview.md +0 -73
  368. package/docs/explanation/quick-flow.md +0 -77
  369. package/docs/explanation/why-solutioning-matters.md +0 -77
  370. package/docs/how-to/customize-xiaoma.md +0 -172
  371. package/docs/how-to/established-projects.md +0 -117
  372. package/docs/how-to/get-answers-about-xiaoma.md +0 -134
  373. package/docs/how-to/install-xiaoma.md +0 -107
  374. package/docs/how-to/non-interactive-installation.md +0 -171
  375. package/docs/how-to/project-context.md +0 -136
  376. package/docs/how-to/quick-fixes.md +0 -123
  377. package/docs/how-to/shard-large-documents.md +0 -78
  378. package/docs/how-to/upgrade-to-v6.md +0 -100
  379. package/docs/ide-info/auggie.md +0 -31
  380. package/docs/ide-info/claude-code.md +0 -25
  381. package/docs/ide-info/cline.md +0 -31
  382. package/docs/ide-info/codex.md +0 -21
  383. package/docs/ide-info/crush.md +0 -30
  384. package/docs/ide-info/cursor.md +0 -25
  385. package/docs/ide-info/gemini.md +0 -25
  386. package/docs/ide-info/github-copilot.md +0 -26
  387. package/docs/ide-info/iflow.md +0 -33
  388. package/docs/ide-info/kilo.md +0 -24
  389. package/docs/ide-info/opencode.md +0 -24
  390. package/docs/ide-info/qwen.md +0 -25
  391. package/docs/ide-info/roo.md +0 -27
  392. package/docs/ide-info/rovo-dev.md +0 -388
  393. package/docs/ide-info/trae.md +0 -25
  394. package/docs/ide-info/windsurf.md +0 -22
  395. package/docs/index.md +0 -60
  396. package/docs/installers-bundlers/ide-injections.md +0 -186
  397. package/docs/installers-bundlers/installers-modules-platforms-reference.md +0 -379
  398. package/docs/rag/rag.md +0 -856
  399. package/docs/reference/agents.md +0 -28
  400. package/docs/reference/commands.md +0 -145
  401. package/docs/reference/modules.md +0 -76
  402. package/docs/reference/testing.md +0 -106
  403. package/docs/reference/workflow-map.md +0 -89
  404. package/docs/roadmap.mdx +0 -136
  405. package/docs/superpowers/plans/2026-03-11-upstream-sync-with-branding.md +0 -586
  406. package/docs/tutorials/getting-started.md +0 -273
  407. package/docs/v4-to-v6-upgrade.md +0 -220
  408. package/docs/v6-open-items.md +0 -17
  409. package/docs/web-bundles-gemini-gpt-guide.md +0 -468
  410. package/docs/zh-cn/404.md +0 -9
  411. package/docs/zh-cn/_STYLE_GUIDE.md +0 -370
  412. package/docs/zh-cn/explanation/advanced-elicitation.md +0 -62
  413. package/docs/zh-cn/explanation/adversarial-review.md +0 -71
  414. package/docs/zh-cn/explanation/brainstorming.md +0 -43
  415. package/docs/zh-cn/explanation/established-projects-faq.md +0 -60
  416. package/docs/zh-cn/explanation/party-mode.md +0 -79
  417. package/docs/zh-cn/explanation/preventing-agent-conflicts.md +0 -137
  418. package/docs/zh-cn/explanation/project-context.md +0 -176
  419. package/docs/zh-cn/explanation/quick-flow.md +0 -93
  420. package/docs/zh-cn/explanation/why-solutioning-matters.md +0 -90
  421. package/docs/zh-cn/how-to/customize-xiaoma.md +0 -182
  422. package/docs/zh-cn/how-to/established-projects.md +0 -134
  423. package/docs/zh-cn/how-to/get-answers-about-xiaoma.md +0 -144
  424. package/docs/zh-cn/how-to/install-xiaoma.md +0 -105
  425. package/docs/zh-cn/how-to/non-interactive-installation.md +0 -181
  426. package/docs/zh-cn/how-to/project-context.md +0 -152
  427. package/docs/zh-cn/how-to/quick-fixes.md +0 -140
  428. package/docs/zh-cn/how-to/shard-large-documents.md +0 -86
  429. package/docs/zh-cn/how-to/upgrade-to-v6.md +0 -120
  430. package/docs/zh-cn/index.md +0 -69
  431. package/docs/zh-cn/reference/agents.md +0 -41
  432. package/docs/zh-cn/reference/commands.md +0 -166
  433. package/docs/zh-cn/reference/modules.md +0 -94
  434. package/docs/zh-cn/reference/testing.md +0 -122
  435. package/docs/zh-cn/reference/workflow-map.md +0 -104
  436. package/docs/zh-cn/roadmap.mdx +0 -152
  437. package/docs/zh-cn/tutorials/getting-started.md +0 -300
  438. package/eslint.config.mjs +0 -144
  439. package/prettier.config.mjs +0 -32
  440. package/src/core/_module-installer/install-config.yaml +0 -29
  441. package/src/core/_module-installer/installer.js +0 -60
  442. package/src/core/agents/xiaoma-master.agent.yaml +0 -30
  443. package/src/core/agents/xiaoma-skill-manifest.yaml +0 -3
  444. package/src/core/agents/xiaoma-web-orchestrator.agent.xml +0 -113
  445. package/src/core/resources/excalidraw/README.md +0 -160
  446. package/src/core/resources/excalidraw/excalidraw-helpers.md +0 -127
  447. package/src/core/resources/excalidraw/library-loader.md +0 -50
  448. package/src/core/resources/excalidraw/validate-json-instructions.md +0 -79
  449. package/src/core/tasks/advanced-elicitation-methods.csv +0 -51
  450. package/src/core/tasks/advanced-elicitation.xml +0 -116
  451. package/src/core/tasks/editorial-review-prose.xml +0 -102
  452. package/src/core/tasks/editorial-review-structure.xml +0 -208
  453. package/src/core/tasks/help.md +0 -92
  454. package/src/core/tasks/index-docs.xml +0 -65
  455. package/src/core/tasks/review-adversarial-general.xml +0 -49
  456. package/src/core/tasks/review-edge-case-hunter.xml +0 -63
  457. package/src/core/tasks/shard-doc.xml +0 -108
  458. package/src/core/tasks/validate-workflow.xml +0 -89
  459. package/src/core/tasks/workflow.xml +0 -235
  460. package/src/core/tasks/xiaoma-help/SKILL.md +0 -6
  461. package/src/core/tasks/xiaoma-skill-manifest.yaml +0 -19
  462. package/src/core/tools/shard-doc.xml +0 -109
  463. package/src/core/workflows/advanced-elicitation/workflow.xml +0 -118
  464. package/src/core/workflows/advanced-elicitation/xiaoma-skill-manifest.yaml +0 -3
  465. package/src/core/workflows/brainstorming/xiaoma-skill-manifest.yaml +0 -3
  466. package/src/core/workflows/party-mode/xiaoma-skill-manifest.yaml +0 -3
  467. package/src/utility/agent-components/handler-validate-workflow.txt +0 -7
  468. package/src/utility/agent-components/handler-workflow.txt +0 -10
  469. package/src/utility/models/action-command-header.md +0 -0
  470. package/src/utility/models/agent-activation-ide.xml +0 -51
  471. package/src/utility/models/agent-activation-web.xml +0 -50
  472. package/src/utility/models/agent-command-header.md +0 -1
  473. package/src/utility/models/agent-config-template.md +0 -23
  474. package/src/utility/models/agent-in-team-activation.xml +0 -3
  475. package/src/utility/models/fragments/activation-rules.xml +0 -7
  476. package/src/utility/models/fragments/activation-steps.xml +0 -16
  477. package/src/utility/models/fragments/handler-action.xml +0 -4
  478. package/src/utility/models/fragments/handler-data.xml +0 -5
  479. package/src/utility/models/fragments/handler-exec.xml +0 -6
  480. package/src/utility/models/fragments/handler-multi.xml +0 -14
  481. package/src/utility/models/fragments/handler-tmpl.xml +0 -5
  482. package/src/utility/models/fragments/handler-validate-workflow.xml +0 -7
  483. package/src/utility/models/fragments/handler-workflow.xml +0 -9
  484. package/src/utility/models/fragments/menu-handlers.xml +0 -6
  485. package/src/utility/models/fragments/web-bundle-activation-steps.xml +0 -32
  486. package/src/utility/templates/agent.customize.template.yaml +0 -42
  487. package/src/xmc/_module-installer/install-config.yaml +0 -53
  488. package/src/xmc/_module-installer/installer.js +0 -131
  489. package/src/xmc/_module-installer/platform-specifics/claude-code.js +0 -35
  490. package/src/xmc/_module-installer/platform-specifics/windsurf.js +0 -32
  491. package/src/xmc/sub-modules/claude-code/config.yaml +0 -5
  492. package/src/xmc/sub-modules/claude-code/injections.yaml +0 -242
  493. package/src/xmc/sub-modules/claude-code/readme.md +0 -87
  494. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-analysis/api-documenter.md +0 -102
  495. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-analysis/codebase-analyzer.md +0 -82
  496. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-analysis/data-analyst.md +0 -101
  497. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-analysis/pattern-detector.md +0 -84
  498. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/dependency-mapper.md +0 -83
  499. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/epic-optimizer.md +0 -81
  500. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/requirements-analyst.md +0 -61
  501. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/technical-decisions-curator.md +0 -168
  502. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/trend-spotter.md +0 -115
  503. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/user-journey-mapper.md +0 -123
  504. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-planning/user-researcher.md +0 -72
  505. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-research/market-researcher.md +0 -51
  506. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-research/tech-debt-auditor.md +0 -106
  507. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-review/document-reviewer.md +0 -102
  508. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-review/technical-evaluator.md +0 -68
  509. package/src/xmc/sub-modules/claude-code/sub-agents/xiaoma-review/test-coverage-analyzer.md +0 -108
  510. package/src/xmc/testarch/knowledge/api-request.md +0 -303
  511. package/src/xmc/testarch/knowledge/auth-session.md +0 -356
  512. package/src/xmc/testarch/knowledge/burn-in.md +0 -273
  513. package/src/xmc/testarch/knowledge/ci-burn-in.md +0 -675
  514. package/src/xmc/testarch/knowledge/component-tdd.md +0 -486
  515. package/src/xmc/testarch/knowledge/contract-testing.md +0 -957
  516. package/src/xmc/testarch/knowledge/data-factories.md +0 -500
  517. package/src/xmc/testarch/knowledge/email-auth.md +0 -721
  518. package/src/xmc/testarch/knowledge/error-handling.md +0 -725
  519. package/src/xmc/testarch/knowledge/feature-flags.md +0 -750
  520. package/src/xmc/testarch/knowledge/file-utils.md +0 -260
  521. package/src/xmc/testarch/knowledge/fixture-architecture.md +0 -401
  522. package/src/xmc/testarch/knowledge/fixtures-composition.md +0 -382
  523. package/src/xmc/testarch/knowledge/intercept-network-call.md +0 -280
  524. package/src/xmc/testarch/knowledge/log.md +0 -294
  525. package/src/xmc/testarch/knowledge/network-error-monitor.md +0 -272
  526. package/src/xmc/testarch/knowledge/network-first.md +0 -486
  527. package/src/xmc/testarch/knowledge/network-recorder.md +0 -265
  528. package/src/xmc/testarch/knowledge/nfr-criteria.md +0 -670
  529. package/src/xmc/testarch/knowledge/overview.md +0 -284
  530. package/src/xmc/testarch/knowledge/playwright-config.md +0 -730
  531. package/src/xmc/testarch/knowledge/probability-impact.md +0 -601
  532. package/src/xmc/testarch/knowledge/recurse.md +0 -296
  533. package/src/xmc/testarch/knowledge/risk-governance.md +0 -615
  534. package/src/xmc/testarch/knowledge/selective-testing.md +0 -732
  535. package/src/xmc/testarch/knowledge/selector-resilience.md +0 -527
  536. package/src/xmc/testarch/knowledge/test-healing-patterns.md +0 -644
  537. package/src/xmc/testarch/knowledge/test-levels-framework.md +0 -473
  538. package/src/xmc/testarch/knowledge/test-priorities-matrix.md +0 -373
  539. package/src/xmc/testarch/knowledge/test-quality.md +0 -664
  540. package/src/xmc/testarch/knowledge/timing-debugging.md +0 -372
  541. package/src/xmc/testarch/knowledge/visual-debugging.md +0 -524
  542. package/src/xmc/testarch/tea-index.csv +0 -33
  543. package/src/xmc/workflows/1-analysis/create-product-brief/xiaoma-skill-manifest.yaml +0 -3
  544. package/src/xmc/workflows/1-analysis/research/xiaoma-skill-manifest.yaml +0 -14
  545. package/src/xmc/workflows/2-plan-workflows/create-prd/xiaoma-skill-manifest.yaml +0 -14
  546. package/src/xmc/workflows/2-plan-workflows/create-ux-design/xiaoma-skill-manifest.yaml +0 -3
  547. package/src/xmc/workflows/3-solutioning/check-implementation-readiness/xiaoma-skill-manifest.yaml +0 -3
  548. package/src/xmc/workflows/3-solutioning/create-architecture/xiaoma-skill-manifest.yaml +0 -3
  549. package/src/xmc/workflows/3-solutioning/create-epics-and-stories/xiaoma-skill-manifest.yaml +0 -3
  550. package/src/xmc/workflows/4-implementation/code-review/workflow.md +0 -271
  551. package/src/xmc/workflows/4-implementation/code-review/xiaoma-skill-manifest.yaml +0 -3
  552. package/src/xmc/workflows/4-implementation/correct-course/xiaoma-skill-manifest.yaml +0 -3
  553. package/src/xmc/workflows/4-implementation/create-story/xiaoma-skill-manifest.yaml +0 -3
  554. package/src/xmc/workflows/4-implementation/dev-story/xiaoma-skill-manifest.yaml +0 -3
  555. package/src/xmc/workflows/4-implementation/retrospective/xiaoma-skill-manifest.yaml +0 -3
  556. package/src/xmc/workflows/4-implementation/sprint-planning/xiaoma-skill-manifest.yaml +0 -3
  557. package/src/xmc/workflows/4-implementation/sprint-status/xiaoma-skill-manifest.yaml +0 -3
  558. package/src/xmc/workflows/document-project/workflow.md +0 -39
  559. package/src/xmc/workflows/document-project/xiaoma-skill-manifest.yaml +0 -3
  560. package/src/xmc/workflows/generate-project-context/xiaoma-skill-manifest.yaml +0 -3
  561. package/src/xmc/workflows/qa-generate-e2e-tests/xiaoma-skill-manifest.yaml +0 -3
  562. package/src/xmc/workflows/xiaoma-quick-flow/quick-dev/xiaoma-skill-manifest.yaml +0 -3
  563. package/src/xmc/workflows/xiaoma-quick-flow/quick-spec/xiaoma-skill-manifest.yaml +0 -3
  564. package/test/README.md +0 -295
  565. package/test/adversarial-review-tests/README.md +0 -56
  566. package/test/adversarial-review-tests/sample-content.md +0 -46
  567. package/test/adversarial-review-tests/test-cases.yaml +0 -103
  568. package/test/fixtures/agent-schema/invalid/critical-actions/actions-as-string.agent.yaml +0 -27
  569. package/test/fixtures/agent-schema/invalid/critical-actions/empty-string-in-actions.agent.yaml +0 -30
  570. package/test/fixtures/agent-schema/invalid/menu/empty-menu.agent.yaml +0 -22
  571. package/test/fixtures/agent-schema/invalid/menu/missing-menu.agent.yaml +0 -20
  572. package/test/fixtures/agent-schema/invalid/menu-commands/empty-command-target.agent.yaml +0 -25
  573. package/test/fixtures/agent-schema/invalid/menu-commands/no-command-target.agent.yaml +0 -24
  574. package/test/fixtures/agent-schema/invalid/menu-triggers/camel-case.agent.yaml +0 -25
  575. package/test/fixtures/agent-schema/invalid/menu-triggers/compound-invalid-format.agent.yaml +0 -25
  576. package/test/fixtures/agent-schema/invalid/menu-triggers/compound-mismatched-kebab.agent.yaml +0 -25
  577. package/test/fixtures/agent-schema/invalid/menu-triggers/duplicate-triggers.agent.yaml +0 -31
  578. package/test/fixtures/agent-schema/invalid/menu-triggers/empty-trigger.agent.yaml +0 -25
  579. package/test/fixtures/agent-schema/invalid/menu-triggers/leading-asterisk.agent.yaml +0 -25
  580. package/test/fixtures/agent-schema/invalid/menu-triggers/snake-case.agent.yaml +0 -25
  581. package/test/fixtures/agent-schema/invalid/menu-triggers/trigger-with-spaces.agent.yaml +0 -25
  582. package/test/fixtures/agent-schema/invalid/metadata/empty-module-string.agent.yaml +0 -26
  583. package/test/fixtures/agent-schema/invalid/metadata/empty-name.agent.yaml +0 -24
  584. package/test/fixtures/agent-schema/invalid/metadata/extra-metadata-fields.agent.yaml +0 -27
  585. package/test/fixtures/agent-schema/invalid/metadata/missing-id.agent.yaml +0 -23
  586. package/test/fixtures/agent-schema/invalid/persona/empty-principles-array.agent.yaml +0 -24
  587. package/test/fixtures/agent-schema/invalid/persona/empty-string-in-principles.agent.yaml +0 -27
  588. package/test/fixtures/agent-schema/invalid/persona/extra-persona-fields.agent.yaml +0 -27
  589. package/test/fixtures/agent-schema/invalid/persona/missing-role.agent.yaml +0 -24
  590. package/test/fixtures/agent-schema/invalid/prompts/empty-content.agent.yaml +0 -29
  591. package/test/fixtures/agent-schema/invalid/prompts/extra-prompt-fields.agent.yaml +0 -31
  592. package/test/fixtures/agent-schema/invalid/prompts/missing-content.agent.yaml +0 -28
  593. package/test/fixtures/agent-schema/invalid/prompts/missing-id.agent.yaml +0 -28
  594. package/test/fixtures/agent-schema/invalid/top-level/empty-file.agent.yaml +0 -5
  595. package/test/fixtures/agent-schema/invalid/top-level/extra-top-level-keys.agent.yaml +0 -28
  596. package/test/fixtures/agent-schema/invalid/top-level/missing-agent-key.agent.yaml +0 -11
  597. package/test/fixtures/agent-schema/invalid/yaml-errors/invalid-indentation.agent.yaml +0 -19
  598. package/test/fixtures/agent-schema/invalid/yaml-errors/malformed-yaml.agent.yaml +0 -18
  599. package/test/fixtures/agent-schema/valid/critical-actions/empty-critical-actions.agent.yaml +0 -24
  600. package/test/fixtures/agent-schema/valid/critical-actions/no-critical-actions.agent.yaml +0 -22
  601. package/test/fixtures/agent-schema/valid/critical-actions/valid-critical-actions.agent.yaml +0 -27
  602. package/test/fixtures/agent-schema/valid/menu/multiple-menu-items.agent.yaml +0 -31
  603. package/test/fixtures/agent-schema/valid/menu/single-menu-item.agent.yaml +0 -22
  604. package/test/fixtures/agent-schema/valid/menu-commands/all-command-types.agent.yaml +0 -38
  605. package/test/fixtures/agent-schema/valid/menu-commands/multiple-commands.agent.yaml +0 -23
  606. package/test/fixtures/agent-schema/valid/menu-triggers/compound-triggers.agent.yaml +0 -31
  607. package/test/fixtures/agent-schema/valid/menu-triggers/kebab-case-triggers.agent.yaml +0 -34
  608. package/test/fixtures/agent-schema/valid/metadata/core-agent-with-module.agent.yaml +0 -24
  609. package/test/fixtures/agent-schema/valid/metadata/empty-module-name-in-path.agent.yaml +0 -24
  610. package/test/fixtures/agent-schema/valid/metadata/malformed-path-treated-as-core.agent.yaml +0 -24
  611. package/test/fixtures/agent-schema/valid/metadata/module-agent-correct.agent.yaml +0 -24
  612. package/test/fixtures/agent-schema/valid/metadata/module-agent-missing-module.agent.yaml +0 -23
  613. package/test/fixtures/agent-schema/valid/metadata/wrong-module-value.agent.yaml +0 -24
  614. package/test/fixtures/agent-schema/valid/persona/complete-persona.agent.yaml +0 -24
  615. package/test/fixtures/agent-schema/valid/prompts/empty-prompts.agent.yaml +0 -24
  616. package/test/fixtures/agent-schema/valid/prompts/no-prompts.agent.yaml +0 -22
  617. package/test/fixtures/agent-schema/valid/prompts/valid-prompts-minimal.agent.yaml +0 -28
  618. package/test/fixtures/agent-schema/valid/prompts/valid-prompts-with-description.agent.yaml +0 -30
  619. package/test/fixtures/agent-schema/valid/top-level/minimal-core-agent.agent.yaml +0 -24
  620. package/test/fixtures/file-refs-csv/invalid/all-empty-workflow.csv +0 -3
  621. package/test/fixtures/file-refs-csv/invalid/empty-data.csv +0 -1
  622. package/test/fixtures/file-refs-csv/invalid/no-workflow-column.csv +0 -3
  623. package/test/fixtures/file-refs-csv/invalid/unresolvable-vars.csv +0 -3
  624. package/test/fixtures/file-refs-csv/valid/core-style.csv +0 -3
  625. package/test/fixtures/file-refs-csv/valid/minimal.csv +0 -2
  626. package/test/fixtures/file-refs-csv/valid/xmc-style.csv +0 -3
  627. package/test/test-agent-schema.js +0 -387
  628. package/test/test-cli-integration.sh +0 -159
  629. package/test/test-file-refs-csv.js +0 -133
  630. package/test/test-install-to-xiaoma.js +0 -154
  631. package/test/test-installation-components.js +0 -1802
  632. package/test/test-rehype-plugins.mjs +0 -1050
  633. package/test/test-workflow-path-regex.js +0 -88
  634. package/test/unit-test-schema.js +0 -133
  635. package/tools/build-docs.mjs +0 -464
  636. package/tools/cli/bundlers/bundle-web.js +0 -179
  637. package/tools/cli/bundlers/bundlers/bundle-web.js +0 -179
  638. package/tools/cli/bundlers/bundlers/test-analyst.js +0 -28
  639. package/tools/cli/bundlers/bundlers/test-bundler.js +0 -119
  640. package/tools/cli/bundlers/bundlers/web-bundler.js +0 -1754
  641. package/tools/cli/bundlers/test-analyst.js +0 -28
  642. package/tools/cli/bundlers/test-bundler.js +0 -119
  643. package/tools/cli/bundlers/web-bundler.js +0 -1754
  644. package/tools/cli/commands/agent-install.js +0 -409
  645. package/tools/cli/commands/build.js +0 -458
  646. package/tools/cli/commands/cleanup.js +0 -144
  647. package/tools/cli/commands/list.js +0 -43
  648. package/tools/cli/commands/update.js +0 -28
  649. package/tools/cli/installers/lib/ide/antigravity.js +0 -510
  650. package/tools/cli/installers/lib/ide/auggie.js +0 -232
  651. package/tools/cli/installers/lib/ide/claude-code.js +0 -512
  652. package/tools/cli/installers/lib/ide/cline.js +0 -269
  653. package/tools/cli/installers/lib/ide/codex.js +0 -440
  654. package/tools/cli/installers/lib/ide/crush.js +0 -287
  655. package/tools/cli/installers/lib/ide/cursor.js +0 -400
  656. package/tools/cli/installers/lib/ide/gemini.js +0 -253
  657. package/tools/cli/installers/lib/ide/github-copilot.js +0 -699
  658. package/tools/cli/installers/lib/ide/iflow.js +0 -172
  659. package/tools/cli/installers/lib/ide/kilo.js +0 -269
  660. package/tools/cli/installers/lib/ide/opencode.js +0 -257
  661. package/tools/cli/installers/lib/ide/qwen.js +0 -372
  662. package/tools/cli/installers/lib/ide/roo.js +0 -324
  663. package/tools/cli/installers/lib/ide/rovo-dev.js +0 -290
  664. package/tools/cli/installers/lib/ide/rovodev.js +0 -257
  665. package/tools/cli/installers/lib/ide/templates/combined/default-workflow-yaml.md +0 -14
  666. package/tools/cli/installers/lib/ide/templates/combined/kiro-workflow-yaml.md +0 -15
  667. package/tools/cli/installers/lib/ide/templates/gemini-agent-command.toml +0 -14
  668. package/tools/cli/installers/lib/ide/templates/gemini-task-command.toml +0 -12
  669. package/tools/cli/installers/lib/ide/templates/workflow-command-template.md +0 -13
  670. package/tools/cli/installers/lib/ide/templates/workflow-commander.md +0 -5
  671. package/tools/cli/installers/lib/ide/trae.js +0 -313
  672. package/tools/cli/installers/lib/ide/windsurf.js +0 -258
  673. package/tools/cli/lib/replace-project-root.js +0 -239
  674. package/tools/cli/regenerate-manifests.js +0 -28
  675. package/tools/cli/test-yaml-builder.js +0 -43
  676. package/tools/docs/_prompt-external-modules-page.md +0 -59
  677. package/tools/docs/fix-refs.md +0 -91
  678. package/tools/docs/native-skills-migration-checklist.md +0 -281
  679. package/tools/fix-doc-links.js +0 -285
  680. package/tools/flattener/aggregate.js +0 -76
  681. package/tools/flattener/binary.js +0 -80
  682. package/tools/flattener/discovery.js +0 -71
  683. package/tools/flattener/files.js +0 -35
  684. package/tools/flattener/flattener/aggregate.js +0 -76
  685. package/tools/flattener/flattener/binary.js +0 -80
  686. package/tools/flattener/flattener/discovery.js +0 -71
  687. package/tools/flattener/flattener/files.js +0 -35
  688. package/tools/flattener/flattener/ignoreRules.js +0 -172
  689. package/tools/flattener/flattener/main.js +0 -483
  690. package/tools/flattener/flattener/projectRoot.js +0 -201
  691. package/tools/flattener/flattener/prompts.js +0 -44
  692. package/tools/flattener/flattener/stats.helpers.js +0 -368
  693. package/tools/flattener/flattener/stats.js +0 -75
  694. package/tools/flattener/flattener/test-matrix.js +0 -409
  695. package/tools/flattener/flattener/xml.js +0 -88
  696. package/tools/flattener/ignoreRules.js +0 -172
  697. package/tools/flattener/main.js +0 -483
  698. package/tools/flattener/projectRoot.js +0 -201
  699. package/tools/flattener/prompts.js +0 -44
  700. package/tools/flattener/stats.helpers.js +0 -368
  701. package/tools/flattener/stats.js +0 -75
  702. package/tools/flattener/test-matrix.js +0 -409
  703. package/tools/flattener/xml.js +0 -88
  704. package/tools/format-workflow-md.js +0 -263
  705. package/tools/migrate-custom-module-paths.js +0 -124
  706. package/tools/validate-agent-schema.js +0 -110
  707. package/tools/validate-bundles.js +0 -87
  708. package/tools/validate-doc-links.js +0 -409
  709. package/tools/validate-file-refs.js +0 -556
  710. package/web-bundles/xmc/agents/analyst.xml +0 -109
  711. package/web-bundles/xmc/agents/architect.xml +0 -101
  712. package/web-bundles/xmc/agents/dev.xml +0 -106
  713. package/web-bundles/xmc/agents/pm.xml +0 -112
  714. package/web-bundles/xmc/agents/qa.xml +0 -126
  715. package/web-bundles/xmc/agents/quick-flow-solo-dev.xml +0 -104
  716. package/web-bundles/xmc/agents/sm.xml +0 -109
  717. package/web-bundles/xmc/agents/ux-designer.xml +0 -100
  718. package/web-bundles/xmc/teams/team-fullstack.xml +0 -1192
  719. /package/src/core/{workflows/advanced-elicitation → skills/xiaoma-advanced-elicitation}/methods.csv +0 -0
  720. /package/src/core/{tasks/xiaoma-help → skills/xiaoma-advanced-elicitation}/xiaoma-skill-manifest.yaml +0 -0
  721. /package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/brain-methods.csv +0 -0
  722. /package/src/core/{workflows/brainstorming → skills/xiaoma-brainstorming}/template.md +0 -0
  723. /package/src/core/{tasks/xiaoma-review-adversarial-general → skills/xiaoma-brainstorming}/xiaoma-skill-manifest.yaml +0 -0
  724. /package/src/core/{tasks/xiaoma-review-edge-case-hunter → skills/xiaoma-editorial-review-prose}/xiaoma-skill-manifest.yaml +0 -0
  725. /package/src/core/{workflows/party-mode → skills/xiaoma-party-mode}/steps/step-01-agent-loading.md +0 -0
  726. /package/src/core/{workflows/party-mode → skills/xiaoma-party-mode}/steps/step-02-discussion-orchestration.md +0 -0
  727. /package/src/core/{tasks → skills}/xiaoma-review-adversarial-general/workflow.md +0 -0
  728. /package/src/core/{tasks → skills}/xiaoma-review-edge-case-hunter/workflow.md +0 -0
  729. /package/src/{xmc/workflows/2-plan-workflows/create-prd → core/tasks/xiaoma-create-prd}/templates/prd-template.md +0 -0
  730. /package/src/xmc/workflows/1-analysis/research/{domain-steps → xiaoma-domain-research/domain-steps}/step-06-research-synthesis.md +0 -0
  731. /package/src/xmc/workflows/1-analysis/research/{technical-steps → xiaoma-technical-research/technical-steps}/step-06-research-synthesis.md +0 -0
  732. /package/src/xmc/workflows/2-plan-workflows/{create-ux-design → xiaoma-create-ux-design}/ux-design-template.md +0 -0
  733. /package/src/xmc/workflows/3-solutioning/{check-implementation-readiness → xiaoma-check-implementation-readiness}/templates/readiness-report-template.md +0 -0
  734. /package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/architecture-decision-template.md +0 -0
  735. /package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/data/domain-complexity.csv +0 -0
  736. /package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/data/project-types.csv +0 -0
  737. /package/src/xmc/workflows/3-solutioning/{create-architecture → xiaoma-create-architecture}/steps/step-08-complete.md +0 -0
  738. /package/src/xmc/workflows/4-implementation/{code-review → xiaoma-code-review}/checklist.md +0 -0
  739. /package/src/xmc/workflows/4-implementation/{code-review → xiaoma-code-review}/discover-inputs.md +0 -0
  740. /package/src/xmc/workflows/4-implementation/{create-story → xiaoma-create-story}/discover-inputs.md +0 -0
  741. /package/src/xmc/workflows/4-implementation/{create-story → xiaoma-create-story}/template.md +0 -0
  742. /package/src/xmc/workflows/4-implementation/{dev-story → xiaoma-dev-story}/checklist.md +0 -0
  743. /package/src/xmc/workflows/4-implementation/{sprint-planning → xiaoma-sprint-planning}/checklist.md +0 -0
  744. /package/src/xmc/workflows/4-implementation/{sprint-planning → xiaoma-sprint-planning}/sprint-status-template.yaml +0 -0
  745. /package/src/xmc/workflows/{document-project → xiaoma-document-project}/checklist.md +0 -0
  746. /package/src/xmc/workflows/{document-project → xiaoma-document-project}/documentation-requirements.csv +0 -0
  747. /package/src/xmc/workflows/{document-project → xiaoma-document-project}/templates/deep-dive-template.md +0 -0
  748. /package/src/xmc/workflows/{document-project → xiaoma-document-project}/templates/index-template.md +0 -0
  749. /package/src/xmc/workflows/{document-project → xiaoma-document-project}/templates/project-overview-template.md +0 -0
  750. /package/src/xmc/workflows/{document-project → xiaoma-document-project}/templates/project-scan-report-schema.json +0 -0
  751. /package/src/xmc/workflows/{document-project → xiaoma-document-project}/templates/source-tree-template.md +0 -0
  752. /package/src/xmc/workflows/{generate-project-context → xiaoma-generate-project-context}/project-context-template.md +0 -0
  753. /package/src/xmc/workflows/{generate-project-context → xiaoma-generate-project-context}/steps/step-03-complete.md +0 -0
  754. /package/src/xmc/workflows/{qa-generate-e2e-tests → xiaoma-qa-generate-e2e-tests}/checklist.md +0 -0
  755. /package/src/xmc/workflows/xiaoma-quick-flow/{quick-spec → xiaoma-quick-spec}/tech-spec-template.md +0 -0
@@ -1,1754 +0,0 @@
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 };