observer-ggboy-bmad-method 6.0.0-alpha.23

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 (604) hide show
  1. package/.coderabbit.yaml +40 -0
  2. package/.github/CODE_OF_CONDUCT.md +128 -0
  3. package/.github/FUNDING.yaml +15 -0
  4. package/.github/ISSUE_TEMPLATE/config.yaml +8 -0
  5. package/.github/ISSUE_TEMPLATE/feature_request.md +22 -0
  6. package/.github/ISSUE_TEMPLATE/issue.md +32 -0
  7. package/.github/scripts/discord-helpers.sh +34 -0
  8. package/.github/workflows/bundle-latest.yaml +330 -0
  9. package/.github/workflows/discord.yaml +90 -0
  10. package/.github/workflows/docs.yaml +63 -0
  11. package/.github/workflows/manual-release.yaml +190 -0
  12. package/.github/workflows/quality.yaml +115 -0
  13. package/.health-status.json +7 -0
  14. package/.husky/pre-commit +20 -0
  15. package/.markdownlint-cli2.yaml +41 -0
  16. package/.nvmrc +1 -0
  17. package/.prettierignore +9 -0
  18. package/.vscode/settings.json +97 -0
  19. package/CHANGELOG.md +1394 -0
  20. package/CNAME +1 -0
  21. package/CONTRIBUTING.md +167 -0
  22. package/CONTRIBUTORS.md +32 -0
  23. package/LICENSE +30 -0
  24. package/README.md +100 -0
  25. package/SECURITY.md +85 -0
  26. package/TRADEMARK.md +55 -0
  27. package/Wordmark.png +0 -0
  28. package/banner-bmad-method.png +0 -0
  29. package/bmad-method-6.0.0-alpha.23.tgz +0 -0
  30. package/docs/404.md +9 -0
  31. package/docs/_README_WORKFLOW_DIAGRAMS.md +40 -0
  32. package/docs/_STYLE_GUIDE.md +367 -0
  33. package/docs/_archive/customize-workflows.md +30 -0
  34. package/docs/_archive/getting-started-bmadv4.md +247 -0
  35. package/docs/_archive/vendor-workflows.md +52 -0
  36. package/docs/downloads.md +72 -0
  37. package/docs/explanation/agents/barry-quick-flow.md +328 -0
  38. package/docs/explanation/agents/index.md +19 -0
  39. package/docs/explanation/architecture/four-phases.md +107 -0
  40. package/docs/explanation/architecture/preventing-agent-conflicts.md +111 -0
  41. package/docs/explanation/architecture/why-solutioning-matters.md +75 -0
  42. package/docs/explanation/bmm/index.md +131 -0
  43. package/docs/explanation/core/index.md +18 -0
  44. package/docs/explanation/core-concepts/agent-roles.md +179 -0
  45. package/docs/explanation/core-concepts/index.md +35 -0
  46. package/docs/explanation/core-concepts/what-are-agents.md +97 -0
  47. package/docs/explanation/core-concepts/what-are-modules.md +85 -0
  48. package/docs/explanation/core-concepts/what-are-workflows.md +204 -0
  49. package/docs/explanation/faq/brownfield-faq.md +73 -0
  50. package/docs/explanation/faq/getting-started-faq.md +67 -0
  51. package/docs/explanation/faq/implementation-faq.md +52 -0
  52. package/docs/explanation/faq/index.md +16 -0
  53. package/docs/explanation/faq/levels-and-tracks-faq.md +52 -0
  54. package/docs/explanation/faq/planning-faq.md +41 -0
  55. package/docs/explanation/faq/tools-faq.md +277 -0
  56. package/docs/explanation/faq/workflows-faq.md +61 -0
  57. package/docs/explanation/features/advanced-elicitation.md +95 -0
  58. package/docs/explanation/features/brainstorming-techniques.md +92 -0
  59. package/docs/explanation/features/party-mode.md +95 -0
  60. package/docs/explanation/features/quick-flow.md +149 -0
  61. package/docs/explanation/features/tea-overview.md +410 -0
  62. package/docs/explanation/features/web-bundles.md +34 -0
  63. package/docs/explanation/philosophy/facilitation-over-generation.md +333 -0
  64. package/docs/explanation/philosophy/testing-as-engineering.md +112 -0
  65. package/docs/explanation/tea/engagement-models.md +710 -0
  66. package/docs/explanation/tea/fixture-architecture.md +457 -0
  67. package/docs/explanation/tea/knowledge-base-system.md +554 -0
  68. package/docs/explanation/tea/network-first-patterns.md +853 -0
  69. package/docs/explanation/tea/risk-based-testing.md +586 -0
  70. package/docs/explanation/tea/test-quality-standards.md +907 -0
  71. package/docs/how-to/brownfield/add-feature-to-existing.md +74 -0
  72. package/docs/how-to/brownfield/document-existing-project.md +66 -0
  73. package/docs/how-to/brownfield/index.md +84 -0
  74. package/docs/how-to/brownfield/quick-fix-in-brownfield.md +77 -0
  75. package/docs/how-to/brownfield/use-tea-for-enterprise.md +525 -0
  76. package/docs/how-to/brownfield/use-tea-with-existing-tests.md +577 -0
  77. package/docs/how-to/customization/customize-agents.md +212 -0
  78. package/docs/how-to/customization/enable-tea-mcp-enhancements.md +424 -0
  79. package/docs/how-to/customization/index.md +23 -0
  80. package/docs/how-to/customization/integrate-playwright-utils.md +813 -0
  81. package/docs/how-to/customization/shard-large-documents.md +101 -0
  82. package/docs/how-to/get-answers-about-bmad.md +102 -0
  83. package/docs/how-to/installation/index.md +12 -0
  84. package/docs/how-to/installation/install-bmad.md +111 -0
  85. package/docs/how-to/installation/install-custom-modules.md +118 -0
  86. package/docs/how-to/installation/upgrade-to-v6.md +131 -0
  87. package/docs/how-to/workflows/bmgd-quick-flow.md +156 -0
  88. package/docs/how-to/workflows/conduct-research.md +97 -0
  89. package/docs/how-to/workflows/create-architecture.md +119 -0
  90. package/docs/how-to/workflows/create-epics-and-stories.md +109 -0
  91. package/docs/how-to/workflows/create-prd.md +91 -0
  92. package/docs/how-to/workflows/create-product-brief.md +94 -0
  93. package/docs/how-to/workflows/create-story.md +102 -0
  94. package/docs/how-to/workflows/create-ux-design.md +100 -0
  95. package/docs/how-to/workflows/implement-story.md +97 -0
  96. package/docs/how-to/workflows/quick-spec.md +122 -0
  97. package/docs/how-to/workflows/run-atdd.md +436 -0
  98. package/docs/how-to/workflows/run-automate.md +653 -0
  99. package/docs/how-to/workflows/run-brainstorming-session.md +73 -0
  100. package/docs/how-to/workflows/run-code-review.md +89 -0
  101. package/docs/how-to/workflows/run-implementation-readiness.md +125 -0
  102. package/docs/how-to/workflows/run-nfr-assess.md +679 -0
  103. package/docs/how-to/workflows/run-sprint-planning.md +94 -0
  104. package/docs/how-to/workflows/run-test-design.md +135 -0
  105. package/docs/how-to/workflows/run-test-review.md +605 -0
  106. package/docs/how-to/workflows/run-trace.md +883 -0
  107. package/docs/how-to/workflows/setup-ci.md +712 -0
  108. package/docs/how-to/workflows/setup-party-mode.md +89 -0
  109. package/docs/how-to/workflows/setup-test-framework.md +98 -0
  110. package/docs/index.md +63 -0
  111. package/docs/reference/agents/index.md +109 -0
  112. package/docs/reference/configuration/core-tasks.md +67 -0
  113. package/docs/reference/configuration/global-config.md +28 -0
  114. package/docs/reference/glossary/index.md +159 -0
  115. package/docs/reference/tea/commands.md +276 -0
  116. package/docs/reference/tea/configuration.md +678 -0
  117. package/docs/reference/tea/knowledge-base.md +340 -0
  118. package/docs/reference/workflows/core-workflows.md +32 -0
  119. package/docs/reference/workflows/document-project.md +73 -0
  120. package/docs/reference/workflows/index.md +12 -0
  121. package/docs/tutorials/getting-started/getting-started-bmadv6.md +246 -0
  122. package/docs/tutorials/getting-started/images/workflow-method-greenfield.excalidraw +5034 -0
  123. package/docs/tutorials/getting-started/images/workflow-method-greenfield.svg +4 -0
  124. package/docs/tutorials/getting-started/images/workflow-overview.jpg +0 -0
  125. package/docs/tutorials/getting-started/tea-lite-quickstart.md +444 -0
  126. package/docs/tutorials/getting-started/workflow-overview.jpg +0 -0
  127. package/eslint.config.mjs +152 -0
  128. package/package.json +117 -0
  129. package/prettier.config.mjs +32 -0
  130. package/src/bmm/_module-installer/installer.js +48 -0
  131. package/src/bmm/_module-installer/platform-specifics/claude-code.js +35 -0
  132. package/src/bmm/_module-installer/platform-specifics/windsurf.js +32 -0
  133. package/src/bmm/agents/analyst.agent.yaml +36 -0
  134. package/src/bmm/agents/architect.agent.yaml +28 -0
  135. package/src/bmm/agents/dev.agent.yaml +38 -0
  136. package/src/bmm/agents/pm.agent.yaml +46 -0
  137. package/src/bmm/agents/quick-flow-solo-dev.agent.yaml +32 -0
  138. package/src/bmm/agents/sm.agent.yaml +36 -0
  139. package/src/bmm/agents/tea.agent.yaml +63 -0
  140. package/src/bmm/agents/tech-writer/tech-writer-sidecar/documentation-standards.md +224 -0
  141. package/src/bmm/agents/tech-writer/tech-writer.agent.yaml +45 -0
  142. package/src/bmm/agents/ux-designer.agent.yaml +26 -0
  143. package/src/bmm/data/project-context-template.md +26 -0
  144. package/src/bmm/module-help.csv +32 -0
  145. package/src/bmm/module.yaml +44 -0
  146. package/src/bmm/sub-modules/claude-code/config.yaml +4 -0
  147. package/src/bmm/sub-modules/claude-code/injections.yaml +242 -0
  148. package/src/bmm/sub-modules/claude-code/readme.md +87 -0
  149. package/src/bmm/teams/default-party.csv +21 -0
  150. package/src/bmm/teams/team-fullstack.yaml +12 -0
  151. package/src/bmm/testarch/knowledge/adr-quality-readiness-checklist.md +350 -0
  152. package/src/bmm/testarch/knowledge/api-request.md +442 -0
  153. package/src/bmm/testarch/knowledge/api-testing-patterns.md +843 -0
  154. package/src/bmm/testarch/knowledge/auth-session.md +552 -0
  155. package/src/bmm/testarch/knowledge/burn-in.md +273 -0
  156. package/src/bmm/testarch/knowledge/ci-burn-in.md +675 -0
  157. package/src/bmm/testarch/knowledge/component-tdd.md +486 -0
  158. package/src/bmm/testarch/knowledge/contract-testing.md +957 -0
  159. package/src/bmm/testarch/knowledge/data-factories.md +500 -0
  160. package/src/bmm/testarch/knowledge/email-auth.md +721 -0
  161. package/src/bmm/testarch/knowledge/error-handling.md +725 -0
  162. package/src/bmm/testarch/knowledge/feature-flags.md +750 -0
  163. package/src/bmm/testarch/knowledge/file-utils.md +463 -0
  164. package/src/bmm/testarch/knowledge/fixture-architecture.md +401 -0
  165. package/src/bmm/testarch/knowledge/fixtures-composition.md +382 -0
  166. package/src/bmm/testarch/knowledge/intercept-network-call.md +430 -0
  167. package/src/bmm/testarch/knowledge/log.md +429 -0
  168. package/src/bmm/testarch/knowledge/network-error-monitor.md +405 -0
  169. package/src/bmm/testarch/knowledge/network-first.md +486 -0
  170. package/src/bmm/testarch/knowledge/network-recorder.md +527 -0
  171. package/src/bmm/testarch/knowledge/nfr-criteria.md +670 -0
  172. package/src/bmm/testarch/knowledge/overview.md +286 -0
  173. package/src/bmm/testarch/knowledge/playwright-config.md +730 -0
  174. package/src/bmm/testarch/knowledge/probability-impact.md +601 -0
  175. package/src/bmm/testarch/knowledge/recurse.md +421 -0
  176. package/src/bmm/testarch/knowledge/risk-governance.md +615 -0
  177. package/src/bmm/testarch/knowledge/selective-testing.md +732 -0
  178. package/src/bmm/testarch/knowledge/selector-resilience.md +527 -0
  179. package/src/bmm/testarch/knowledge/test-healing-patterns.md +644 -0
  180. package/src/bmm/testarch/knowledge/test-levels-framework.md +473 -0
  181. package/src/bmm/testarch/knowledge/test-priorities-matrix.md +373 -0
  182. package/src/bmm/testarch/knowledge/test-quality.md +664 -0
  183. package/src/bmm/testarch/knowledge/timing-debugging.md +372 -0
  184. package/src/bmm/testarch/knowledge/visual-debugging.md +524 -0
  185. package/src/bmm/testarch/tea-index.csv +35 -0
  186. package/src/bmm/workflows/1-analysis/create-product-brief/product-brief.template.md +10 -0
  187. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-01-init.md +177 -0
  188. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-01b-continue.md +161 -0
  189. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-02-vision.md +199 -0
  190. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-03-users.md +202 -0
  191. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-04-metrics.md +205 -0
  192. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-05-scope.md +219 -0
  193. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-06-complete.md +162 -0
  194. package/src/bmm/workflows/1-analysis/create-product-brief/workflow.md +58 -0
  195. package/src/bmm/workflows/1-analysis/research/domain-steps/step-01-init.md +137 -0
  196. package/src/bmm/workflows/1-analysis/research/domain-steps/step-02-domain-analysis.md +229 -0
  197. package/src/bmm/workflows/1-analysis/research/domain-steps/step-03-competitive-landscape.md +238 -0
  198. package/src/bmm/workflows/1-analysis/research/domain-steps/step-04-regulatory-focus.md +206 -0
  199. package/src/bmm/workflows/1-analysis/research/domain-steps/step-05-technical-trends.md +234 -0
  200. package/src/bmm/workflows/1-analysis/research/domain-steps/step-06-research-synthesis.md +443 -0
  201. package/src/bmm/workflows/1-analysis/research/market-steps/step-01-init.md +182 -0
  202. package/src/bmm/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +237 -0
  203. package/src/bmm/workflows/1-analysis/research/market-steps/step-02-customer-insights.md +200 -0
  204. package/src/bmm/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +249 -0
  205. package/src/bmm/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +259 -0
  206. package/src/bmm/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +177 -0
  207. package/src/bmm/workflows/1-analysis/research/market-steps/step-06-research-completion.md +475 -0
  208. package/src/bmm/workflows/1-analysis/research/research.template.md +29 -0
  209. package/src/bmm/workflows/1-analysis/research/technical-steps/step-01-init.md +137 -0
  210. package/src/bmm/workflows/1-analysis/research/technical-steps/step-02-technical-overview.md +239 -0
  211. package/src/bmm/workflows/1-analysis/research/technical-steps/step-03-integration-patterns.md +248 -0
  212. package/src/bmm/workflows/1-analysis/research/technical-steps/step-04-architectural-patterns.md +202 -0
  213. package/src/bmm/workflows/1-analysis/research/technical-steps/step-05-implementation-research.md +239 -0
  214. package/src/bmm/workflows/1-analysis/research/technical-steps/step-06-research-synthesis.md +486 -0
  215. package/src/bmm/workflows/1-analysis/research/workflow.md +173 -0
  216. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01-init.md +135 -0
  217. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01b-continue.md +127 -0
  218. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-02-discovery.md +190 -0
  219. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-03-core-experience.md +216 -0
  220. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-04-emotional-response.md +219 -0
  221. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-05-inspiration.md +234 -0
  222. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-06-design-system.md +252 -0
  223. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-07-defining-experience.md +254 -0
  224. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-08-visual-foundation.md +224 -0
  225. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-09-design-directions.md +224 -0
  226. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-10-user-journeys.md +241 -0
  227. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-11-component-strategy.md +248 -0
  228. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-12-ux-patterns.md +237 -0
  229. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-13-responsive-accessibility.md +264 -0
  230. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-14-complete.md +171 -0
  231. package/src/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +13 -0
  232. package/src/bmm/workflows/2-plan-workflows/create-ux-design/workflow.md +43 -0
  233. package/src/bmm/workflows/2-plan-workflows/prd/data/domain-complexity.csv +13 -0
  234. package/src/bmm/workflows/2-plan-workflows/prd/data/prd-purpose.md +197 -0
  235. package/src/bmm/workflows/2-plan-workflows/prd/data/project-types.csv +11 -0
  236. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-01-init.md +191 -0
  237. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-01b-continue.md +153 -0
  238. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-02-discovery.md +224 -0
  239. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-03-success.md +226 -0
  240. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-04-journeys.md +213 -0
  241. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-05-domain.md +207 -0
  242. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-06-innovation.md +226 -0
  243. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-07-project-type.md +237 -0
  244. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-08-scoping.md +228 -0
  245. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-09-functional.md +231 -0
  246. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-10-nonfunctional.md +242 -0
  247. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-11-polish.md +217 -0
  248. package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-12-complete.md +124 -0
  249. package/src/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-01-discovery.md +247 -0
  250. package/src/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-01b-legacy-conversion.md +208 -0
  251. package/src/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-02-review.md +249 -0
  252. package/src/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-03-edit.md +253 -0
  253. package/src/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-04-complete.md +168 -0
  254. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-01-discovery.md +218 -0
  255. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-02-format-detection.md +191 -0
  256. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-02b-parity-check.md +209 -0
  257. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-03-density-validation.md +174 -0
  258. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-04-brief-coverage-validation.md +214 -0
  259. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-05-measurability-validation.md +228 -0
  260. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-06-traceability-validation.md +217 -0
  261. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-07-implementation-leakage-validation.md +205 -0
  262. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-08-domain-compliance-validation.md +243 -0
  263. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-09-project-type-validation.md +263 -0
  264. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-10-smart-validation.md +209 -0
  265. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-11-holistic-quality-validation.md +264 -0
  266. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-12-completeness-validation.md +242 -0
  267. package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-13-report-complete.md +231 -0
  268. package/src/bmm/workflows/2-plan-workflows/prd/templates/prd-template.md +10 -0
  269. package/src/bmm/workflows/2-plan-workflows/prd/validation-report-prd-workflow.md +433 -0
  270. package/src/bmm/workflows/2-plan-workflows/prd/workflow.md +150 -0
  271. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-01-document-discovery.md +190 -0
  272. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-02-prd-analysis.md +178 -0
  273. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-03-epic-coverage-validation.md +179 -0
  274. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-04-ux-alignment.md +139 -0
  275. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-05-epic-quality-review.md +252 -0
  276. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +135 -0
  277. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/templates/readiness-report-template.md +4 -0
  278. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/workflow.md +55 -0
  279. package/src/bmm/workflows/3-solutioning/create-architecture/architecture-decision-template.md +12 -0
  280. package/src/bmm/workflows/3-solutioning/create-architecture/data/domain-complexity.csv +11 -0
  281. package/src/bmm/workflows/3-solutioning/create-architecture/data/project-types.csv +7 -0
  282. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-01-init.md +153 -0
  283. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-01b-continue.md +164 -0
  284. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-02-context.md +224 -0
  285. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-03-starter.md +331 -0
  286. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-04-decisions.md +318 -0
  287. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-05-patterns.md +359 -0
  288. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-06-structure.md +379 -0
  289. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-07-validation.md +359 -0
  290. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-08-complete.md +76 -0
  291. package/src/bmm/workflows/3-solutioning/create-architecture/workflow.md +50 -0
  292. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-01-validate-prerequisites.md +259 -0
  293. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-02-design-epics.md +233 -0
  294. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-03-create-stories.md +272 -0
  295. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-04-final-validation.md +149 -0
  296. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/templates/epics-template.md +57 -0
  297. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/workflow.md +59 -0
  298. package/src/bmm/workflows/4-implementation/code-review/checklist.md +23 -0
  299. package/src/bmm/workflows/4-implementation/code-review/instructions.xml +227 -0
  300. package/src/bmm/workflows/4-implementation/code-review/workflow.yaml +51 -0
  301. package/src/bmm/workflows/4-implementation/correct-course/checklist.md +288 -0
  302. package/src/bmm/workflows/4-implementation/correct-course/instructions.md +206 -0
  303. package/src/bmm/workflows/4-implementation/correct-course/workflow.yaml +60 -0
  304. package/src/bmm/workflows/4-implementation/create-story/checklist.md +358 -0
  305. package/src/bmm/workflows/4-implementation/create-story/instructions.xml +345 -0
  306. package/src/bmm/workflows/4-implementation/create-story/template.md +49 -0
  307. package/src/bmm/workflows/4-implementation/create-story/workflow.yaml +61 -0
  308. package/src/bmm/workflows/4-implementation/dev-story/checklist.md +80 -0
  309. package/src/bmm/workflows/4-implementation/dev-story/instructions.xml +410 -0
  310. package/src/bmm/workflows/4-implementation/dev-story/workflow.yaml +27 -0
  311. package/src/bmm/workflows/4-implementation/retrospective/instructions.md +1443 -0
  312. package/src/bmm/workflows/4-implementation/retrospective/workflow.yaml +58 -0
  313. package/src/bmm/workflows/4-implementation/sprint-planning/checklist.md +33 -0
  314. package/src/bmm/workflows/4-implementation/sprint-planning/instructions.md +225 -0
  315. package/src/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +55 -0
  316. package/src/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +54 -0
  317. package/src/bmm/workflows/4-implementation/sprint-status/instructions.md +229 -0
  318. package/src/bmm/workflows/4-implementation/sprint-status/workflow.yaml +36 -0
  319. package/src/bmm/workflows/bmad-quick-flow/quick-dev/data/project-levels.yaml +59 -0
  320. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-01-mode-detection.md +156 -0
  321. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-02-context-gathering.md +120 -0
  322. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-03-execute.md +113 -0
  323. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-04-self-check.md +113 -0
  324. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-05-adversarial-review.md +106 -0
  325. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-06-resolve-findings.md +140 -0
  326. package/src/bmm/workflows/bmad-quick-flow/quick-dev/workflow.md +50 -0
  327. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-01-understand.md +189 -0
  328. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-02-investigate.md +144 -0
  329. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-03-generate.md +128 -0
  330. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-04-review.md +191 -0
  331. package/src/bmm/workflows/bmad-quick-flow/quick-spec/tech-spec-template.md +74 -0
  332. package/src/bmm/workflows/bmad-quick-flow/quick-spec/workflow.md +79 -0
  333. package/src/bmm/workflows/document-project/checklist.md +245 -0
  334. package/src/bmm/workflows/document-project/documentation-requirements.csv +12 -0
  335. package/src/bmm/workflows/document-project/instructions.md +221 -0
  336. package/src/bmm/workflows/document-project/templates/deep-dive-template.md +345 -0
  337. package/src/bmm/workflows/document-project/templates/index-template.md +169 -0
  338. package/src/bmm/workflows/document-project/templates/project-overview-template.md +103 -0
  339. package/src/bmm/workflows/document-project/templates/project-scan-report-schema.json +160 -0
  340. package/src/bmm/workflows/document-project/templates/source-tree-template.md +135 -0
  341. package/src/bmm/workflows/document-project/workflow.yaml +30 -0
  342. package/src/bmm/workflows/document-project/workflows/deep-dive-instructions.md +298 -0
  343. package/src/bmm/workflows/document-project/workflows/deep-dive.yaml +31 -0
  344. package/src/bmm/workflows/document-project/workflows/full-scan-instructions.md +1106 -0
  345. package/src/bmm/workflows/document-project/workflows/full-scan.yaml +31 -0
  346. package/src/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-library.json +90 -0
  347. package/src/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-templates.yaml +127 -0
  348. package/src/bmm/workflows/excalidraw-diagrams/create-dataflow/checklist.md +39 -0
  349. package/src/bmm/workflows/excalidraw-diagrams/create-dataflow/instructions.md +130 -0
  350. package/src/bmm/workflows/excalidraw-diagrams/create-dataflow/workflow.yaml +27 -0
  351. package/src/bmm/workflows/excalidraw-diagrams/create-diagram/checklist.md +43 -0
  352. package/src/bmm/workflows/excalidraw-diagrams/create-diagram/instructions.md +141 -0
  353. package/src/bmm/workflows/excalidraw-diagrams/create-diagram/workflow.yaml +27 -0
  354. package/src/bmm/workflows/excalidraw-diagrams/create-flowchart/checklist.md +49 -0
  355. package/src/bmm/workflows/excalidraw-diagrams/create-flowchart/instructions.md +241 -0
  356. package/src/bmm/workflows/excalidraw-diagrams/create-flowchart/workflow.yaml +27 -0
  357. package/src/bmm/workflows/excalidraw-diagrams/create-wireframe/checklist.md +38 -0
  358. package/src/bmm/workflows/excalidraw-diagrams/create-wireframe/instructions.md +133 -0
  359. package/src/bmm/workflows/excalidraw-diagrams/create-wireframe/workflow.yaml +27 -0
  360. package/src/bmm/workflows/testarch/atdd/atdd-checklist-template.md +363 -0
  361. package/src/bmm/workflows/testarch/atdd/checklist.md +374 -0
  362. package/src/bmm/workflows/testarch/atdd/instructions.md +806 -0
  363. package/src/bmm/workflows/testarch/atdd/workflow.yaml +47 -0
  364. package/src/bmm/workflows/testarch/automate/checklist.md +582 -0
  365. package/src/bmm/workflows/testarch/automate/instructions.md +1324 -0
  366. package/src/bmm/workflows/testarch/automate/workflow.yaml +54 -0
  367. package/src/bmm/workflows/testarch/ci/checklist.md +247 -0
  368. package/src/bmm/workflows/testarch/ci/github-actions-template.yaml +198 -0
  369. package/src/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +149 -0
  370. package/src/bmm/workflows/testarch/ci/instructions.md +536 -0
  371. package/src/bmm/workflows/testarch/ci/workflow.yaml +47 -0
  372. package/src/bmm/workflows/testarch/framework/checklist.md +320 -0
  373. package/src/bmm/workflows/testarch/framework/instructions.md +481 -0
  374. package/src/bmm/workflows/testarch/framework/workflow.yaml +49 -0
  375. package/src/bmm/workflows/testarch/nfr-assess/checklist.md +407 -0
  376. package/src/bmm/workflows/testarch/nfr-assess/instructions.md +726 -0
  377. package/src/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +461 -0
  378. package/src/bmm/workflows/testarch/nfr-assess/workflow.yaml +49 -0
  379. package/src/bmm/workflows/testarch/test-design/checklist.md +407 -0
  380. package/src/bmm/workflows/testarch/test-design/instructions.md +1158 -0
  381. package/src/bmm/workflows/testarch/test-design/test-design-architecture-template.md +213 -0
  382. package/src/bmm/workflows/testarch/test-design/test-design-qa-template.md +286 -0
  383. package/src/bmm/workflows/testarch/test-design/test-design-template.md +294 -0
  384. package/src/bmm/workflows/testarch/test-design/workflow.yaml +71 -0
  385. package/src/bmm/workflows/testarch/test-review/checklist.md +472 -0
  386. package/src/bmm/workflows/testarch/test-review/instructions.md +628 -0
  387. package/src/bmm/workflows/testarch/test-review/test-review-template.md +390 -0
  388. package/src/bmm/workflows/testarch/test-review/workflow.yaml +48 -0
  389. package/src/bmm/workflows/testarch/trace/checklist.md +642 -0
  390. package/src/bmm/workflows/testarch/trace/instructions.md +1030 -0
  391. package/src/bmm/workflows/testarch/trace/trace-template.md +675 -0
  392. package/src/bmm/workflows/testarch/trace/workflow.yaml +57 -0
  393. package/src/core/_module-installer/installer.js +60 -0
  394. package/src/core/agents/bmad-master.agent.yaml +29 -0
  395. package/src/core/module-help.csv +9 -0
  396. package/src/core/module.yaml +25 -0
  397. package/src/core/resources/excalidraw/README.md +160 -0
  398. package/src/core/resources/excalidraw/excalidraw-helpers.md +127 -0
  399. package/src/core/resources/excalidraw/library-loader.md +50 -0
  400. package/src/core/resources/excalidraw/validate-json-instructions.md +79 -0
  401. package/src/core/tasks/editorial-review-prose.xml +100 -0
  402. package/src/core/tasks/editorial-review-structure.xml +209 -0
  403. package/src/core/tasks/help.md +62 -0
  404. package/src/core/tasks/index-docs.xml +65 -0
  405. package/src/core/tasks/review-adversarial-general.xml +48 -0
  406. package/src/core/tasks/shard-doc.xml +109 -0
  407. package/src/core/tasks/workflow.xml +235 -0
  408. package/src/core/workflows/advanced-elicitation/methods.csv +51 -0
  409. package/src/core/workflows/advanced-elicitation/workflow.xml +117 -0
  410. package/src/core/workflows/brainstorming/brain-methods.csv +62 -0
  411. package/src/core/workflows/brainstorming/steps/step-01-session-setup.md +197 -0
  412. package/src/core/workflows/brainstorming/steps/step-01b-continue.md +122 -0
  413. package/src/core/workflows/brainstorming/steps/step-02a-user-selected.md +225 -0
  414. package/src/core/workflows/brainstorming/steps/step-02b-ai-recommended.md +237 -0
  415. package/src/core/workflows/brainstorming/steps/step-02c-random-selection.md +209 -0
  416. package/src/core/workflows/brainstorming/steps/step-02d-progressive-flow.md +264 -0
  417. package/src/core/workflows/brainstorming/steps/step-03-technique-execution.md +399 -0
  418. package/src/core/workflows/brainstorming/steps/step-04-idea-organization.md +303 -0
  419. package/src/core/workflows/brainstorming/template.md +15 -0
  420. package/src/core/workflows/brainstorming/workflow.md +58 -0
  421. package/src/core/workflows/party-mode/steps/step-01-agent-loading.md +138 -0
  422. package/src/core/workflows/party-mode/steps/step-02-discussion-orchestration.md +187 -0
  423. package/src/core/workflows/party-mode/steps/step-03-graceful-exit.md +157 -0
  424. package/src/core/workflows/party-mode/workflow.md +194 -0
  425. package/src/utility/agent-components/activation-rules.txt +6 -0
  426. package/src/utility/agent-components/activation-steps.txt +14 -0
  427. package/src/utility/agent-components/agent-command-header.md +1 -0
  428. package/src/utility/agent-components/agent.customize.template.yaml +41 -0
  429. package/src/utility/agent-components/handler-action.txt +4 -0
  430. package/src/utility/agent-components/handler-data.txt +5 -0
  431. package/src/utility/agent-components/handler-exec.txt +6 -0
  432. package/src/utility/agent-components/handler-multi.txt +14 -0
  433. package/src/utility/agent-components/handler-tmpl.txt +5 -0
  434. package/src/utility/agent-components/handler-validate-workflow.txt +7 -0
  435. package/src/utility/agent-components/handler-workflow.txt +10 -0
  436. package/src/utility/agent-components/menu-handlers.txt +6 -0
  437. package/test/README.md +295 -0
  438. package/test/adversarial-review-tests/README.md +56 -0
  439. package/test/adversarial-review-tests/sample-content.md +46 -0
  440. package/test/adversarial-review-tests/test-cases.yaml +103 -0
  441. package/test/fixtures/agent-schema/invalid/critical-actions/actions-as-string.agent.yaml +27 -0
  442. package/test/fixtures/agent-schema/invalid/critical-actions/empty-string-in-actions.agent.yaml +30 -0
  443. package/test/fixtures/agent-schema/invalid/menu/empty-menu.agent.yaml +22 -0
  444. package/test/fixtures/agent-schema/invalid/menu/missing-menu.agent.yaml +20 -0
  445. package/test/fixtures/agent-schema/invalid/menu-commands/empty-command-target.agent.yaml +25 -0
  446. package/test/fixtures/agent-schema/invalid/menu-commands/no-command-target.agent.yaml +24 -0
  447. package/test/fixtures/agent-schema/invalid/menu-triggers/camel-case.agent.yaml +25 -0
  448. package/test/fixtures/agent-schema/invalid/menu-triggers/compound-invalid-format.agent.yaml +25 -0
  449. package/test/fixtures/agent-schema/invalid/menu-triggers/compound-mismatched-kebab.agent.yaml +25 -0
  450. package/test/fixtures/agent-schema/invalid/menu-triggers/duplicate-triggers.agent.yaml +31 -0
  451. package/test/fixtures/agent-schema/invalid/menu-triggers/empty-trigger.agent.yaml +25 -0
  452. package/test/fixtures/agent-schema/invalid/menu-triggers/leading-asterisk.agent.yaml +25 -0
  453. package/test/fixtures/agent-schema/invalid/menu-triggers/snake-case.agent.yaml +25 -0
  454. package/test/fixtures/agent-schema/invalid/menu-triggers/trigger-with-spaces.agent.yaml +25 -0
  455. package/test/fixtures/agent-schema/invalid/metadata/empty-module-string.agent.yaml +26 -0
  456. package/test/fixtures/agent-schema/invalid/metadata/empty-name.agent.yaml +24 -0
  457. package/test/fixtures/agent-schema/invalid/metadata/extra-metadata-fields.agent.yaml +27 -0
  458. package/test/fixtures/agent-schema/invalid/metadata/missing-id.agent.yaml +23 -0
  459. package/test/fixtures/agent-schema/invalid/persona/empty-principles-array.agent.yaml +24 -0
  460. package/test/fixtures/agent-schema/invalid/persona/empty-string-in-principles.agent.yaml +27 -0
  461. package/test/fixtures/agent-schema/invalid/persona/extra-persona-fields.agent.yaml +27 -0
  462. package/test/fixtures/agent-schema/invalid/persona/missing-role.agent.yaml +24 -0
  463. package/test/fixtures/agent-schema/invalid/prompts/empty-content.agent.yaml +29 -0
  464. package/test/fixtures/agent-schema/invalid/prompts/extra-prompt-fields.agent.yaml +31 -0
  465. package/test/fixtures/agent-schema/invalid/prompts/missing-content.agent.yaml +28 -0
  466. package/test/fixtures/agent-schema/invalid/prompts/missing-id.agent.yaml +28 -0
  467. package/test/fixtures/agent-schema/invalid/top-level/empty-file.agent.yaml +5 -0
  468. package/test/fixtures/agent-schema/invalid/top-level/extra-top-level-keys.agent.yaml +28 -0
  469. package/test/fixtures/agent-schema/invalid/top-level/missing-agent-key.agent.yaml +11 -0
  470. package/test/fixtures/agent-schema/invalid/yaml-errors/invalid-indentation.agent.yaml +19 -0
  471. package/test/fixtures/agent-schema/invalid/yaml-errors/malformed-yaml.agent.yaml +18 -0
  472. package/test/fixtures/agent-schema/valid/critical-actions/empty-critical-actions.agent.yaml +24 -0
  473. package/test/fixtures/agent-schema/valid/critical-actions/no-critical-actions.agent.yaml +22 -0
  474. package/test/fixtures/agent-schema/valid/critical-actions/valid-critical-actions.agent.yaml +27 -0
  475. package/test/fixtures/agent-schema/valid/menu/multiple-menu-items.agent.yaml +31 -0
  476. package/test/fixtures/agent-schema/valid/menu/single-menu-item.agent.yaml +22 -0
  477. package/test/fixtures/agent-schema/valid/menu-commands/all-command-types.agent.yaml +38 -0
  478. package/test/fixtures/agent-schema/valid/menu-commands/multiple-commands.agent.yaml +24 -0
  479. package/test/fixtures/agent-schema/valid/menu-triggers/compound-triggers.agent.yaml +31 -0
  480. package/test/fixtures/agent-schema/valid/menu-triggers/kebab-case-triggers.agent.yaml +34 -0
  481. package/test/fixtures/agent-schema/valid/metadata/core-agent-with-module.agent.yaml +24 -0
  482. package/test/fixtures/agent-schema/valid/metadata/empty-module-name-in-path.agent.yaml +24 -0
  483. package/test/fixtures/agent-schema/valid/metadata/malformed-path-treated-as-core.agent.yaml +24 -0
  484. package/test/fixtures/agent-schema/valid/metadata/module-agent-correct.agent.yaml +24 -0
  485. package/test/fixtures/agent-schema/valid/metadata/module-agent-missing-module.agent.yaml +23 -0
  486. package/test/fixtures/agent-schema/valid/metadata/wrong-module-value.agent.yaml +24 -0
  487. package/test/fixtures/agent-schema/valid/persona/complete-persona.agent.yaml +24 -0
  488. package/test/fixtures/agent-schema/valid/prompts/empty-prompts.agent.yaml +24 -0
  489. package/test/fixtures/agent-schema/valid/prompts/no-prompts.agent.yaml +22 -0
  490. package/test/fixtures/agent-schema/valid/prompts/valid-prompts-minimal.agent.yaml +28 -0
  491. package/test/fixtures/agent-schema/valid/prompts/valid-prompts-with-description.agent.yaml +30 -0
  492. package/test/fixtures/agent-schema/valid/top-level/minimal-core-agent.agent.yaml +24 -0
  493. package/test/test-agent-schema.js +387 -0
  494. package/test/test-cli-integration.sh +159 -0
  495. package/test/test-installation-components.js +214 -0
  496. package/test/unit-test-schema.js +133 -0
  497. package/tools/bmad-npx-wrapper.js +38 -0
  498. package/tools/build-docs.js +577 -0
  499. package/tools/cli/README.md +7 -0
  500. package/tools/cli/bmad-cli.js +58 -0
  501. package/tools/cli/commands/install.js +87 -0
  502. package/tools/cli/commands/status.js +65 -0
  503. package/tools/cli/external-official-modules.yaml +56 -0
  504. package/tools/cli/installers/install-messages.yaml +58 -0
  505. package/tools/cli/installers/lib/core/config-collector.js +1079 -0
  506. package/tools/cli/installers/lib/core/custom-module-cache.js +259 -0
  507. package/tools/cli/installers/lib/core/dependency-resolver.js +739 -0
  508. package/tools/cli/installers/lib/core/detector.js +223 -0
  509. package/tools/cli/installers/lib/core/ide-config-manager.js +156 -0
  510. package/tools/cli/installers/lib/core/installer.js +2826 -0
  511. package/tools/cli/installers/lib/core/manifest-generator.js +1054 -0
  512. package/tools/cli/installers/lib/core/manifest.js +1036 -0
  513. package/tools/cli/installers/lib/custom/handler.js +363 -0
  514. package/tools/cli/installers/lib/ide/STANDARDIZATION_PLAN.md +208 -0
  515. package/tools/cli/installers/lib/ide/_base-ide.js +655 -0
  516. package/tools/cli/installers/lib/ide/antigravity.js +474 -0
  517. package/tools/cli/installers/lib/ide/auggie.js +244 -0
  518. package/tools/cli/installers/lib/ide/claude-code.js +506 -0
  519. package/tools/cli/installers/lib/ide/cline.js +272 -0
  520. package/tools/cli/installers/lib/ide/codex.js +412 -0
  521. package/tools/cli/installers/lib/ide/crush.js +149 -0
  522. package/tools/cli/installers/lib/ide/cursor.js +160 -0
  523. package/tools/cli/installers/lib/ide/gemini.js +301 -0
  524. package/tools/cli/installers/lib/ide/github-copilot.js +383 -0
  525. package/tools/cli/installers/lib/ide/iflow.js +191 -0
  526. package/tools/cli/installers/lib/ide/kilo.js +250 -0
  527. package/tools/cli/installers/lib/ide/kiro-cli.js +326 -0
  528. package/tools/cli/installers/lib/ide/manager.js +244 -0
  529. package/tools/cli/installers/lib/ide/opencode.js +257 -0
  530. package/tools/cli/installers/lib/ide/qwen.js +372 -0
  531. package/tools/cli/installers/lib/ide/roo.js +273 -0
  532. package/tools/cli/installers/lib/ide/rovo-dev.js +290 -0
  533. package/tools/cli/installers/lib/ide/shared/agent-command-generator.js +165 -0
  534. package/tools/cli/installers/lib/ide/shared/bmad-artifacts.js +158 -0
  535. package/tools/cli/installers/lib/ide/shared/module-injections.js +136 -0
  536. package/tools/cli/installers/lib/ide/shared/path-utils.js +165 -0
  537. package/tools/cli/installers/lib/ide/shared/task-tool-command-generator.js +268 -0
  538. package/tools/cli/installers/lib/ide/shared/workflow-command-generator.js +293 -0
  539. package/tools/cli/installers/lib/ide/templates/agent-command-template.md +14 -0
  540. package/tools/cli/installers/lib/ide/templates/gemini-agent-command.toml +14 -0
  541. package/tools/cli/installers/lib/ide/templates/gemini-task-command.toml +12 -0
  542. package/tools/cli/installers/lib/ide/templates/workflow-command-template.md +13 -0
  543. package/tools/cli/installers/lib/ide/templates/workflow-commander.md +5 -0
  544. package/tools/cli/installers/lib/ide/trae.js +313 -0
  545. package/tools/cli/installers/lib/ide/windsurf.js +258 -0
  546. package/tools/cli/installers/lib/message-loader.js +85 -0
  547. package/tools/cli/installers/lib/modules/external-manager.js +135 -0
  548. package/tools/cli/installers/lib/modules/manager.js +1375 -0
  549. package/tools/cli/lib/activation-builder.js +163 -0
  550. package/tools/cli/lib/agent/compiler.js +522 -0
  551. package/tools/cli/lib/agent/installer.js +716 -0
  552. package/tools/cli/lib/agent/template-engine.js +152 -0
  553. package/tools/cli/lib/agent-analyzer.js +109 -0
  554. package/tools/cli/lib/agent-party-generator.js +194 -0
  555. package/tools/cli/lib/cli-utils.js +227 -0
  556. package/tools/cli/lib/config.js +213 -0
  557. package/tools/cli/lib/file-ops.js +204 -0
  558. package/tools/cli/lib/platform-codes.js +116 -0
  559. package/tools/cli/lib/project-root.js +77 -0
  560. package/tools/cli/lib/prompts.js +433 -0
  561. package/tools/cli/lib/ui.js +1716 -0
  562. package/tools/cli/lib/xml-handler.js +177 -0
  563. package/tools/cli/lib/xml-to-markdown.js +82 -0
  564. package/tools/cli/lib/yaml-format.js +245 -0
  565. package/tools/cli/lib/yaml-xml-builder.js +587 -0
  566. package/tools/docs/BUNDLE_DISTRIBUTION_SETUP.md +95 -0
  567. package/tools/docs/index.md +2 -0
  568. package/tools/fix-doc-links.js +288 -0
  569. package/tools/flattener/aggregate.js +76 -0
  570. package/tools/flattener/binary.js +80 -0
  571. package/tools/flattener/discovery.js +71 -0
  572. package/tools/flattener/files.js +35 -0
  573. package/tools/flattener/ignoreRules.js +172 -0
  574. package/tools/flattener/main.js +483 -0
  575. package/tools/flattener/projectRoot.js +201 -0
  576. package/tools/flattener/prompts.js +44 -0
  577. package/tools/flattener/stats.helpers.js +368 -0
  578. package/tools/flattener/stats.js +75 -0
  579. package/tools/flattener/test-matrix.js +409 -0
  580. package/tools/flattener/xml.js +82 -0
  581. package/tools/format-workflow-md.js +263 -0
  582. package/tools/lib/xml-utils.js +13 -0
  583. package/tools/maintainer/review-pr-README.md +55 -0
  584. package/tools/maintainer/review-pr.md +242 -0
  585. package/tools/migrate-custom-module-paths.js +124 -0
  586. package/tools/platform-codes.yaml +157 -0
  587. package/tools/schema/agent.js +491 -0
  588. package/tools/validate-agent-schema.js +110 -0
  589. package/tools/validate-doc-links.js +363 -0
  590. package/tools/validate-svg-changes.sh +356 -0
  591. package/website/README.md +76 -0
  592. package/website/astro.config.mjs +228 -0
  593. package/website/public/favicon.ico +0 -0
  594. package/website/public/img/bmad-dark.png +0 -0
  595. package/website/public/img/bmad-light.png +0 -0
  596. package/website/public/img/logo.svg +4 -0
  597. package/website/public/robots.txt +37 -0
  598. package/website/src/components/Banner.astro +59 -0
  599. package/website/src/components/Header.astro +121 -0
  600. package/website/src/components/MobileMenuFooter.astro +53 -0
  601. package/website/src/content/config.ts +6 -0
  602. package/website/src/lib/site-url.js +25 -0
  603. package/website/src/rehype-markdown-links.js +102 -0
  604. package/website/src/styles/custom.css +485 -0
@@ -0,0 +1,372 @@
1
+ const path = require('node:path');
2
+ const fs = require('fs-extra');
3
+ const { BaseIdeSetup } = require('./_base-ide');
4
+ const chalk = require('chalk');
5
+ const { getAgentsFromBmad, getTasksFromBmad } = require('./shared/bmad-artifacts');
6
+ const { AgentCommandGenerator } = require('./shared/agent-command-generator');
7
+
8
+ /**
9
+ * Qwen Code setup handler
10
+ * Creates TOML command files in .qwen/commands/BMad/
11
+ */
12
+ class QwenSetup extends BaseIdeSetup {
13
+ constructor() {
14
+ super('qwen', 'Qwen Code');
15
+ this.configDir = '.qwen';
16
+ this.commandsDir = 'commands';
17
+ this.bmadDir = 'bmad';
18
+ }
19
+
20
+ /**
21
+ * Setup Qwen Code configuration
22
+ * @param {string} projectDir - Project directory
23
+ * @param {string} bmadDir - BMAD installation directory
24
+ * @param {Object} options - Setup options
25
+ */
26
+ async setup(projectDir, bmadDir, options = {}) {
27
+ console.log(chalk.cyan(`Setting up ${this.name}...`));
28
+
29
+ // Create .qwen/commands/BMad directory structure
30
+ const qwenDir = path.join(projectDir, this.configDir);
31
+ const commandsDir = path.join(qwenDir, this.commandsDir);
32
+ const bmadCommandsDir = path.join(commandsDir, this.bmadDir);
33
+
34
+ await this.ensureDir(bmadCommandsDir);
35
+
36
+ // Update existing settings.json if present
37
+ await this.updateSettings(qwenDir);
38
+
39
+ // Clean up old configuration if exists
40
+ await this.cleanupOldConfig(qwenDir);
41
+
42
+ // Generate agent launchers
43
+ const agentGen = new AgentCommandGenerator(this.bmadFolderName);
44
+ const { artifacts: agentArtifacts } = await agentGen.collectAgentArtifacts(bmadDir, options.selectedModules || []);
45
+
46
+ // Get tasks, tools, and workflows (standalone only for tools/workflows)
47
+ const tasks = await getTasksFromBmad(bmadDir, options.selectedModules || []);
48
+ const tools = await this.getTools(bmadDir, true);
49
+ const workflows = await this.getWorkflows(bmadDir, true);
50
+
51
+ // Create directories for each module (including standalone)
52
+ const modules = new Set();
53
+ for (const item of [...agentArtifacts, ...tasks, ...tools, ...workflows]) modules.add(item.module);
54
+
55
+ for (const module of modules) {
56
+ await this.ensureDir(path.join(bmadCommandsDir, module));
57
+ await this.ensureDir(path.join(bmadCommandsDir, module, 'agents'));
58
+ await this.ensureDir(path.join(bmadCommandsDir, module, 'tasks'));
59
+ await this.ensureDir(path.join(bmadCommandsDir, module, 'tools'));
60
+ await this.ensureDir(path.join(bmadCommandsDir, module, 'workflows'));
61
+ }
62
+
63
+ // Create TOML files for each agent launcher
64
+ let agentCount = 0;
65
+ for (const artifact of agentArtifacts) {
66
+ // Convert markdown launcher content to TOML format
67
+ const tomlContent = this.processAgentLauncherContent(artifact.content, {
68
+ module: artifact.module,
69
+ name: artifact.name,
70
+ });
71
+
72
+ const targetPath = path.join(bmadCommandsDir, artifact.module, 'agents', `${artifact.name}.toml`);
73
+
74
+ await this.writeFile(targetPath, tomlContent);
75
+
76
+ agentCount++;
77
+ console.log(chalk.green(` ✓ Added agent: /bmad_${artifact.module}_agents_${artifact.name}`));
78
+ }
79
+
80
+ // Create TOML files for each task
81
+ let taskCount = 0;
82
+ for (const task of tasks) {
83
+ const content = await this.readAndProcess(task.path, {
84
+ module: task.module,
85
+ name: task.name,
86
+ });
87
+
88
+ const targetPath = path.join(bmadCommandsDir, task.module, 'tasks', `${task.name}.toml`);
89
+
90
+ await this.writeFile(targetPath, content);
91
+
92
+ taskCount++;
93
+ console.log(chalk.green(` ✓ Added task: /bmad_${task.module}_tasks_${task.name}`));
94
+ }
95
+
96
+ // Create TOML files for each tool
97
+ let toolCount = 0;
98
+ for (const tool of tools) {
99
+ const content = await this.readAndProcess(tool.path, {
100
+ module: tool.module,
101
+ name: tool.name,
102
+ });
103
+
104
+ const targetPath = path.join(bmadCommandsDir, tool.module, 'tools', `${tool.name}.toml`);
105
+
106
+ await this.writeFile(targetPath, content);
107
+
108
+ toolCount++;
109
+ console.log(chalk.green(` ✓ Added tool: /bmad_${tool.module}_tools_${tool.name}`));
110
+ }
111
+
112
+ // Create TOML files for each workflow
113
+ let workflowCount = 0;
114
+ for (const workflow of workflows) {
115
+ const content = await this.readAndProcess(workflow.path, {
116
+ module: workflow.module,
117
+ name: workflow.name,
118
+ });
119
+
120
+ const targetPath = path.join(bmadCommandsDir, workflow.module, 'workflows', `${workflow.name}.toml`);
121
+
122
+ await this.writeFile(targetPath, content);
123
+
124
+ workflowCount++;
125
+ console.log(chalk.green(` ✓ Added workflow: /bmad_${workflow.module}_workflows_${workflow.name}`));
126
+ }
127
+
128
+ console.log(chalk.green(`✓ ${this.name} configured:`));
129
+ console.log(chalk.dim(` - ${agentCount} agents configured`));
130
+ console.log(chalk.dim(` - ${taskCount} tasks configured`));
131
+ console.log(chalk.dim(` - ${toolCount} tools configured`));
132
+ console.log(chalk.dim(` - ${workflowCount} workflows configured`));
133
+ console.log(chalk.dim(` - Commands directory: ${path.relative(projectDir, bmadCommandsDir)}`));
134
+
135
+ return {
136
+ success: true,
137
+ agents: agentCount,
138
+ tasks: taskCount,
139
+ tools: toolCount,
140
+ workflows: workflowCount,
141
+ };
142
+ }
143
+
144
+ /**
145
+ * Update settings.json to remove old agent references
146
+ */
147
+ async updateSettings(qwenDir) {
148
+ const fs = require('fs-extra');
149
+ const settingsPath = path.join(qwenDir, 'settings.json');
150
+
151
+ if (await fs.pathExists(settingsPath)) {
152
+ try {
153
+ const settingsContent = await fs.readFile(settingsPath, 'utf8');
154
+ const settings = JSON.parse(settingsContent);
155
+ let updated = false;
156
+
157
+ // Remove agent file references from contextFileName
158
+ if (settings.contextFileName && Array.isArray(settings.contextFileName)) {
159
+ const originalLength = settings.contextFileName.length;
160
+ settings.contextFileName = settings.contextFileName.filter(
161
+ (fileName) => !fileName.startsWith('agents/') && !fileName.startsWith('bmad-method/'),
162
+ );
163
+
164
+ if (settings.contextFileName.length !== originalLength) {
165
+ updated = true;
166
+ }
167
+ }
168
+
169
+ if (updated) {
170
+ await fs.writeFile(settingsPath, JSON.stringify(settings, null, 2));
171
+ console.log(chalk.green(' ✓ Updated .qwen/settings.json'));
172
+ }
173
+ } catch (error) {
174
+ console.warn(chalk.yellow(' ⚠ Could not update settings.json:'), error.message);
175
+ }
176
+ }
177
+ }
178
+
179
+ /**
180
+ * Clean up old configuration directories
181
+ */
182
+ async cleanupOldConfig(qwenDir) {
183
+ const fs = require('fs-extra');
184
+ const agentsDir = path.join(qwenDir, 'agents');
185
+ const bmadMethodDir = path.join(qwenDir, 'bmad-method');
186
+ const bmadDir = path.join(qwenDir, 'bmadDir');
187
+
188
+ if (await fs.pathExists(agentsDir)) {
189
+ await fs.remove(agentsDir);
190
+ console.log(chalk.green(' ✓ Removed old agents directory'));
191
+ }
192
+
193
+ if (await fs.pathExists(bmadMethodDir)) {
194
+ await fs.remove(bmadMethodDir);
195
+ console.log(chalk.green(' ✓ Removed old bmad-method directory'));
196
+ }
197
+
198
+ if (await fs.pathExists(bmadDir)) {
199
+ await fs.remove(bmadDir);
200
+ console.log(chalk.green(' ✓ Removed old BMad directory'));
201
+ }
202
+ }
203
+
204
+ /**
205
+ * Read and process file content
206
+ */
207
+ async readAndProcess(filePath, metadata) {
208
+ const fs = require('fs-extra');
209
+ const content = await fs.readFile(filePath, 'utf8');
210
+ return this.processContent(content, metadata);
211
+ }
212
+
213
+ /**
214
+ * Process agent launcher content and convert to TOML format
215
+ * @param {string} launcherContent - Launcher markdown content
216
+ * @param {Object} metadata - File metadata
217
+ * @returns {string} TOML formatted content
218
+ */
219
+ processAgentLauncherContent(launcherContent, metadata = {}) {
220
+ // Strip frontmatter from launcher content
221
+ const frontmatterRegex = /^---\s*\n[\s\S]*?\n---\s*\n/;
222
+ const contentWithoutFrontmatter = launcherContent.replace(frontmatterRegex, '');
223
+
224
+ // Extract title for TOML description
225
+ const titleMatch = launcherContent.match(/description:\s*"([^"]+)"/);
226
+ const title = titleMatch ? titleMatch[1] : metadata.name;
227
+
228
+ // Create TOML with launcher content (without frontmatter)
229
+ return `description = "BMAD ${metadata.module.toUpperCase()} Agent: ${title}"
230
+ prompt = """
231
+ ${contentWithoutFrontmatter.trim()}
232
+ """
233
+ `;
234
+ }
235
+
236
+ /**
237
+ * Override processContent to add TOML metadata header for Qwen
238
+ * @param {string} content - File content
239
+ * @param {Object} metadata - File metadata
240
+ * @returns {string} Processed content with Qwen template
241
+ */
242
+ processContent(content, metadata = {}) {
243
+ // First apply base processing (includes activation injection for agents)
244
+ let prompt = super.processContent(content, metadata);
245
+
246
+ // Determine the type and description based on content
247
+ const isAgent = content.includes('<agent');
248
+ const isTask = content.includes('<task');
249
+ const isTool = content.includes('<tool');
250
+ const isWorkflow = content.includes('workflow:') || content.includes('name:');
251
+
252
+ let description = '';
253
+
254
+ if (isAgent) {
255
+ // Extract agent title if available
256
+ const titleMatch = content.match(/title="([^"]+)"/);
257
+ const title = titleMatch ? titleMatch[1] : metadata.name;
258
+ description = `BMAD ${metadata.module.toUpperCase()} Agent: ${title}`;
259
+ } else if (isTask) {
260
+ // Extract task name if available
261
+ const nameMatch = content.match(/name="([^"]+)"/);
262
+ const taskName = nameMatch ? nameMatch[1] : metadata.name;
263
+ description = `BMAD ${metadata.module.toUpperCase()} Task: ${taskName}`;
264
+ } else if (isTool) {
265
+ // Extract tool name if available
266
+ const nameMatch = content.match(/name="([^"]+)"/);
267
+ const toolName = nameMatch ? nameMatch[1] : metadata.name;
268
+ description = `BMAD ${metadata.module.toUpperCase()} Tool: ${toolName}`;
269
+ } else if (isWorkflow) {
270
+ // Workflow
271
+ description = `BMAD ${metadata.module.toUpperCase()} Workflow: ${metadata.name}`;
272
+ } else {
273
+ description = `BMAD ${metadata.module.toUpperCase()}: ${metadata.name}`;
274
+ }
275
+
276
+ return `description = "${description}"
277
+ prompt = """
278
+ ${prompt}
279
+ """
280
+ `;
281
+ }
282
+
283
+ /**
284
+ * Format name as title
285
+ */
286
+ formatTitle(name) {
287
+ return name
288
+ .split('-')
289
+ .map((word) => word.charAt(0).toUpperCase() + word.slice(1))
290
+ .join(' ');
291
+ }
292
+
293
+ /**
294
+ * Cleanup Qwen configuration
295
+ */
296
+ async cleanup(projectDir) {
297
+ const fs = require('fs-extra');
298
+ const bmadCommandsDir = path.join(projectDir, this.configDir, this.commandsDir, this.bmadDir);
299
+ const oldBmadMethodDir = path.join(projectDir, this.configDir, 'bmad-method');
300
+ const oldBMadDir = path.join(projectDir, this.configDir, 'BMad');
301
+
302
+ if (await fs.pathExists(bmadCommandsDir)) {
303
+ await fs.remove(bmadCommandsDir);
304
+ console.log(chalk.dim(`Removed BMAD configuration from Qwen Code`));
305
+ }
306
+
307
+ if (await fs.pathExists(oldBmadMethodDir)) {
308
+ await fs.remove(oldBmadMethodDir);
309
+ console.log(chalk.dim(`Removed old BMAD configuration from Qwen Code`));
310
+ }
311
+
312
+ if (await fs.pathExists(oldBMadDir)) {
313
+ await fs.remove(oldBMadDir);
314
+ console.log(chalk.dim(`Removed old BMAD configuration from Qwen Code`));
315
+ }
316
+ }
317
+
318
+ /**
319
+ * Install a custom agent launcher for Qwen
320
+ * @param {string} projectDir - Project directory
321
+ * @param {string} agentName - Agent name (e.g., "fred-commit-poet")
322
+ * @param {string} agentPath - Path to compiled agent (relative to project root)
323
+ * @param {Object} metadata - Agent metadata
324
+ * @returns {Object} Installation result
325
+ */
326
+ async installCustomAgentLauncher(projectDir, agentName, agentPath, metadata) {
327
+ const qwenDir = path.join(projectDir, this.configDir);
328
+ const commandsDir = path.join(qwenDir, this.commandsDir);
329
+ const bmadCommandsDir = path.join(commandsDir, this.bmadDir);
330
+
331
+ // Create .qwen/commands/BMad directory if it doesn't exist
332
+ await fs.ensureDir(bmadCommandsDir);
333
+
334
+ // Create custom agent launcher in TOML format (same pattern as regular agents)
335
+ const launcherContent = `# ${agentName} Custom Agent
336
+
337
+ **⚠️ IMPORTANT**: Run @${agentPath} first to load the complete agent!
338
+
339
+ This is a launcher for the custom BMAD agent "${agentName}".
340
+
341
+ ## Usage
342
+ 1. First run: \`${agentPath}\` to load the complete agent
343
+ 2. Then use this command to activate ${agentName}
344
+
345
+ The agent will follow the persona and instructions from the main agent file.
346
+
347
+ ---
348
+
349
+ *Generated by BMAD Method*`;
350
+
351
+ // Use Qwen's TOML conversion method
352
+ const tomlContent = this.processAgentLauncherContent(launcherContent, {
353
+ name: agentName,
354
+ module: 'custom',
355
+ });
356
+
357
+ const fileName = `custom-${agentName.toLowerCase()}.toml`;
358
+ const launcherPath = path.join(bmadCommandsDir, fileName);
359
+
360
+ // Write the launcher file
361
+ await fs.writeFile(launcherPath, tomlContent, 'utf8');
362
+
363
+ return {
364
+ ide: 'qwen',
365
+ path: path.relative(projectDir, launcherPath),
366
+ command: agentName,
367
+ type: 'custom-agent-launcher',
368
+ };
369
+ }
370
+ }
371
+
372
+ module.exports = { QwenSetup };
@@ -0,0 +1,273 @@
1
+ const path = require('node:path');
2
+ const { BaseIdeSetup } = require('./_base-ide');
3
+ const chalk = require('chalk');
4
+ const { AgentCommandGenerator } = require('./shared/agent-command-generator');
5
+ const { toDashPath, customAgentDashName } = require('./shared/path-utils');
6
+
7
+ /**
8
+ * Roo IDE setup handler
9
+ * Creates custom commands in .roo/commands directory
10
+ */
11
+ class RooSetup extends BaseIdeSetup {
12
+ constructor() {
13
+ super('roo', 'Roo Code');
14
+ this.configDir = '.roo';
15
+ this.commandsDir = 'commands';
16
+ }
17
+
18
+ /**
19
+ * Setup Roo IDE configuration
20
+ * @param {string} projectDir - Project directory
21
+ * @param {string} bmadDir - BMAD installation directory
22
+ * @param {Object} options - Setup options
23
+ */
24
+ async setup(projectDir, bmadDir, options = {}) {
25
+ console.log(chalk.cyan(`Setting up ${this.name}...`));
26
+
27
+ // Create .roo/commands directory
28
+ const rooCommandsDir = path.join(projectDir, this.configDir, this.commandsDir);
29
+ await this.ensureDir(rooCommandsDir);
30
+
31
+ // Generate agent launchers
32
+ const agentGen = new AgentCommandGenerator(this.bmadFolderName);
33
+ const { artifacts: agentArtifacts } = await agentGen.collectAgentArtifacts(bmadDir, options.selectedModules || []);
34
+
35
+ let addedCount = 0;
36
+ let skippedCount = 0;
37
+
38
+ for (const artifact of agentArtifacts) {
39
+ // Use shared toDashPath to get consistent naming: bmad_bmm_name.md
40
+ const commandName = toDashPath(artifact.relativePath).replace('.md', '');
41
+ const commandPath = path.join(rooCommandsDir, `${commandName}.md`);
42
+
43
+ // Skip if already exists
44
+ if (await this.pathExists(commandPath)) {
45
+ console.log(chalk.dim(` Skipping ${commandName} - already exists`));
46
+ skippedCount++;
47
+ continue;
48
+ }
49
+
50
+ // artifact.sourcePath contains the full path to the agent file
51
+ if (!artifact.sourcePath) {
52
+ console.error(`Error: Missing sourcePath for artifact ${artifact.name} from module ${artifact.module}`);
53
+ console.error(`Artifact object:`, artifact);
54
+ throw new Error(`Missing sourcePath for agent: ${artifact.name}`);
55
+ }
56
+
57
+ const content = await this.readFile(artifact.sourcePath);
58
+
59
+ // Create command file that references the actual _bmad agent
60
+ await this.createCommandFile(
61
+ { module: artifact.module, name: artifact.name, path: artifact.sourcePath },
62
+ content,
63
+ commandPath,
64
+ projectDir,
65
+ );
66
+
67
+ addedCount++;
68
+ console.log(chalk.green(` ✓ Added command: ${commandName}`));
69
+ }
70
+
71
+ console.log(chalk.green(`✓ ${this.name} configured:`));
72
+ console.log(chalk.dim(` - ${addedCount} commands added`));
73
+ if (skippedCount > 0) {
74
+ console.log(chalk.dim(` - ${skippedCount} commands skipped (already exist)`));
75
+ }
76
+ console.log(chalk.dim(` - Commands directory: ${this.configDir}/${this.commandsDir}/`));
77
+ console.log(chalk.dim(` Commands will be available when you open this project in Roo Code`));
78
+
79
+ return {
80
+ success: true,
81
+ commands: addedCount,
82
+ skipped: skippedCount,
83
+ };
84
+ }
85
+
86
+ /**
87
+ * Create a unified command file for agents
88
+ * @param {string} commandPath - Path where to write the command file
89
+ * @param {Object} options - Command options
90
+ * @param {string} options.name - Display name for the command
91
+ * @param {string} options.description - Description for the command
92
+ * @param {string} options.agentPath - Path to the agent file (relative to project root)
93
+ * @param {string} [options.icon] - Icon emoji (defaults to 🤖)
94
+ * @param {string} [options.extraContent] - Additional content to include before activation
95
+ */
96
+ async createAgentCommandFile(commandPath, options) {
97
+ const { name, description, agentPath, icon = '🤖', extraContent = '' } = options;
98
+
99
+ // Build command content with YAML frontmatter
100
+ let commandContent = `---\n`;
101
+ commandContent += `name: '${icon} ${name}'\n`;
102
+ commandContent += `description: '${description}'\n`;
103
+ commandContent += `---\n\n`;
104
+
105
+ commandContent += `You must fully embody this agent's persona and follow all activation instructions exactly as specified. NEVER break character until given an exit command.\n\n`;
106
+
107
+ // Add any extra content (e.g., warnings for custom agents)
108
+ if (extraContent) {
109
+ commandContent += `${extraContent}\n\n`;
110
+ }
111
+
112
+ commandContent += `<agent-activation CRITICAL="TRUE">\n`;
113
+ commandContent += `1. LOAD the FULL agent file from @${agentPath}\n`;
114
+ commandContent += `2. READ its entire contents - this contains the complete agent persona, menu, and instructions\n`;
115
+ commandContent += `3. Execute ALL activation steps exactly as written in the agent file\n`;
116
+ commandContent += `4. Follow the agent's persona and menu system precisely\n`;
117
+ commandContent += `5. Stay in character throughout the session\n`;
118
+ commandContent += `</agent-activation>\n`;
119
+
120
+ // Write command file
121
+ await this.writeFile(commandPath, commandContent);
122
+ }
123
+
124
+ /**
125
+ * Create a command file for an agent
126
+ */
127
+ async createCommandFile(agent, content, commandPath, projectDir) {
128
+ // Extract metadata from agent content
129
+ const titleMatch = content.match(/title="([^"]+)"/);
130
+ const title = titleMatch ? titleMatch[1] : this.formatTitle(agent.name);
131
+
132
+ const iconMatch = content.match(/icon="([^"]+)"/);
133
+ const icon = iconMatch ? iconMatch[1] : '🤖';
134
+
135
+ const whenToUseMatch = content.match(/whenToUse="([^"]+)"/);
136
+ const whenToUse = whenToUseMatch ? whenToUseMatch[1] : `Use for ${title} tasks`;
137
+
138
+ // Get relative path
139
+ const relativePath = path.relative(projectDir, agent.path).replaceAll('\\', '/');
140
+
141
+ // Use unified method
142
+ await this.createAgentCommandFile(commandPath, {
143
+ name: title,
144
+ description: whenToUse,
145
+ agentPath: relativePath,
146
+ icon: icon,
147
+ });
148
+ }
149
+
150
+ /**
151
+ * Format name as title
152
+ */
153
+ formatTitle(name) {
154
+ return name
155
+ .split('-')
156
+ .map((word) => word.charAt(0).toUpperCase() + word.slice(1))
157
+ .join(' ');
158
+ }
159
+
160
+ /**
161
+ * Cleanup Roo configuration
162
+ */
163
+ async cleanup(projectDir) {
164
+ const fs = require('fs-extra');
165
+ const rooCommandsDir = path.join(projectDir, this.configDir, this.commandsDir);
166
+
167
+ if (await fs.pathExists(rooCommandsDir)) {
168
+ const files = await fs.readdir(rooCommandsDir);
169
+ let removedCount = 0;
170
+
171
+ for (const file of files) {
172
+ if (file.startsWith('bmad') && file.endsWith('.md')) {
173
+ await fs.remove(path.join(rooCommandsDir, file));
174
+ removedCount++;
175
+ }
176
+ }
177
+
178
+ if (removedCount > 0) {
179
+ console.log(chalk.dim(`Removed ${removedCount} BMAD commands from .roo/commands/`));
180
+ }
181
+ }
182
+
183
+ // Also clean up old .roomodes file if it exists
184
+ const roomodesPath = path.join(projectDir, '.roomodes');
185
+ if (await fs.pathExists(roomodesPath)) {
186
+ const content = await fs.readFile(roomodesPath, 'utf8');
187
+
188
+ // Remove BMAD modes only
189
+ const lines = content.split('\n');
190
+ const filteredLines = [];
191
+ let skipMode = false;
192
+ let removedCount = 0;
193
+
194
+ for (const line of lines) {
195
+ if (/^\s*- slug: bmad/.test(line)) {
196
+ skipMode = true;
197
+ removedCount++;
198
+ } else if (skipMode && /^\s*- slug: /.test(line)) {
199
+ skipMode = false;
200
+ }
201
+
202
+ if (!skipMode) {
203
+ filteredLines.push(line);
204
+ }
205
+ }
206
+
207
+ // Write back filtered content
208
+ await fs.writeFile(roomodesPath, filteredLines.join('\n'));
209
+ if (removedCount > 0) {
210
+ console.log(chalk.dim(`Removed ${removedCount} BMAD modes from legacy .roomodes file`));
211
+ }
212
+ }
213
+ }
214
+
215
+ /**
216
+ * Install a custom agent launcher for Roo
217
+ * @param {string} projectDir - Project directory
218
+ * @param {string} agentName - Agent name (e.g., "fred-commit-poet")
219
+ * @param {string} agentPath - Path to compiled agent (relative to project root)
220
+ * @param {Object} metadata - Agent metadata (unused, kept for compatibility)
221
+ * @returns {Object} Installation result
222
+ */
223
+ async installCustomAgentLauncher(projectDir, agentName, agentPath, metadata) {
224
+ const rooCommandsDir = path.join(projectDir, this.configDir, this.commandsDir);
225
+ await this.ensureDir(rooCommandsDir);
226
+
227
+ // Use underscore format: bmad_custom_fred-commit-poet.md
228
+ const commandName = customAgentDashName(agentName).replace('.md', '');
229
+ const commandPath = path.join(rooCommandsDir, `${commandName}.md`);
230
+
231
+ // Check if command already exists
232
+ if (await this.pathExists(commandPath)) {
233
+ return {
234
+ ide: 'roo',
235
+ path: path.join(this.configDir, this.commandsDir, `${commandName}.md`),
236
+ command: commandName,
237
+ type: 'custom-agent-launcher',
238
+ alreadyExists: true,
239
+ };
240
+ }
241
+
242
+ // Read the custom agent file to extract metadata (same as regular agents)
243
+ const fullAgentPath = path.join(projectDir, agentPath);
244
+ const content = await this.readFile(fullAgentPath);
245
+
246
+ // Extract metadata from agent content
247
+ const titleMatch = content.match(/title="([^"]+)"/);
248
+ const title = titleMatch ? titleMatch[1] : this.formatTitle(agentName);
249
+
250
+ const iconMatch = content.match(/icon="([^"]+)"/);
251
+ const icon = iconMatch ? iconMatch[1] : '🤖';
252
+
253
+ const whenToUseMatch = content.match(/whenToUse="([^"]+)"/);
254
+ const whenToUse = whenToUseMatch ? whenToUseMatch[1] : `Use for ${title} tasks`;
255
+
256
+ // Use unified method without extra content (clean)
257
+ await this.createAgentCommandFile(commandPath, {
258
+ name: title,
259
+ description: whenToUse,
260
+ agentPath: agentPath,
261
+ icon: icon,
262
+ });
263
+
264
+ return {
265
+ ide: 'roo',
266
+ path: path.join(this.configDir, this.commandsDir, `${commandName}.md`),
267
+ command: commandName,
268
+ type: 'custom-agent-launcher',
269
+ };
270
+ }
271
+ }
272
+
273
+ module.exports = { RooSetup };