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