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.
- package/.coderabbit.yaml +40 -0
- package/.github/CODE_OF_CONDUCT.md +128 -0
- package/.github/FUNDING.yaml +15 -0
- package/.github/ISSUE_TEMPLATE/config.yaml +8 -0
- package/.github/ISSUE_TEMPLATE/feature_request.md +22 -0
- package/.github/ISSUE_TEMPLATE/issue.md +32 -0
- package/.github/scripts/discord-helpers.sh +34 -0
- package/.github/workflows/bundle-latest.yaml +330 -0
- package/.github/workflows/discord.yaml +90 -0
- package/.github/workflows/docs.yaml +63 -0
- package/.github/workflows/manual-release.yaml +190 -0
- package/.github/workflows/quality.yaml +115 -0
- package/.health-status.json +7 -0
- package/.husky/pre-commit +20 -0
- package/.markdownlint-cli2.yaml +41 -0
- package/.nvmrc +1 -0
- package/.prettierignore +9 -0
- package/.vscode/settings.json +97 -0
- package/CHANGELOG.md +1394 -0
- package/CNAME +1 -0
- package/CONTRIBUTING.md +167 -0
- package/CONTRIBUTORS.md +32 -0
- package/LICENSE +30 -0
- package/README.md +100 -0
- package/SECURITY.md +85 -0
- package/TRADEMARK.md +55 -0
- package/Wordmark.png +0 -0
- package/banner-bmad-method.png +0 -0
- package/bmad-method-6.0.0-alpha.23.tgz +0 -0
- package/docs/404.md +9 -0
- package/docs/_README_WORKFLOW_DIAGRAMS.md +40 -0
- package/docs/_STYLE_GUIDE.md +367 -0
- package/docs/_archive/customize-workflows.md +30 -0
- package/docs/_archive/getting-started-bmadv4.md +247 -0
- package/docs/_archive/vendor-workflows.md +52 -0
- package/docs/downloads.md +72 -0
- package/docs/explanation/agents/barry-quick-flow.md +328 -0
- package/docs/explanation/agents/index.md +19 -0
- package/docs/explanation/architecture/four-phases.md +107 -0
- package/docs/explanation/architecture/preventing-agent-conflicts.md +111 -0
- package/docs/explanation/architecture/why-solutioning-matters.md +75 -0
- package/docs/explanation/bmm/index.md +131 -0
- package/docs/explanation/core/index.md +18 -0
- package/docs/explanation/core-concepts/agent-roles.md +179 -0
- package/docs/explanation/core-concepts/index.md +35 -0
- package/docs/explanation/core-concepts/what-are-agents.md +97 -0
- package/docs/explanation/core-concepts/what-are-modules.md +85 -0
- package/docs/explanation/core-concepts/what-are-workflows.md +204 -0
- package/docs/explanation/faq/brownfield-faq.md +73 -0
- package/docs/explanation/faq/getting-started-faq.md +67 -0
- package/docs/explanation/faq/implementation-faq.md +52 -0
- package/docs/explanation/faq/index.md +16 -0
- package/docs/explanation/faq/levels-and-tracks-faq.md +52 -0
- package/docs/explanation/faq/planning-faq.md +41 -0
- package/docs/explanation/faq/tools-faq.md +277 -0
- package/docs/explanation/faq/workflows-faq.md +61 -0
- package/docs/explanation/features/advanced-elicitation.md +95 -0
- package/docs/explanation/features/brainstorming-techniques.md +92 -0
- package/docs/explanation/features/party-mode.md +95 -0
- package/docs/explanation/features/quick-flow.md +149 -0
- package/docs/explanation/features/tea-overview.md +410 -0
- package/docs/explanation/features/web-bundles.md +34 -0
- package/docs/explanation/philosophy/facilitation-over-generation.md +333 -0
- package/docs/explanation/philosophy/testing-as-engineering.md +112 -0
- package/docs/explanation/tea/engagement-models.md +710 -0
- package/docs/explanation/tea/fixture-architecture.md +457 -0
- package/docs/explanation/tea/knowledge-base-system.md +554 -0
- package/docs/explanation/tea/network-first-patterns.md +853 -0
- package/docs/explanation/tea/risk-based-testing.md +586 -0
- package/docs/explanation/tea/test-quality-standards.md +907 -0
- package/docs/how-to/brownfield/add-feature-to-existing.md +74 -0
- package/docs/how-to/brownfield/document-existing-project.md +66 -0
- package/docs/how-to/brownfield/index.md +84 -0
- package/docs/how-to/brownfield/quick-fix-in-brownfield.md +77 -0
- package/docs/how-to/brownfield/use-tea-for-enterprise.md +525 -0
- package/docs/how-to/brownfield/use-tea-with-existing-tests.md +577 -0
- package/docs/how-to/customization/customize-agents.md +212 -0
- package/docs/how-to/customization/enable-tea-mcp-enhancements.md +424 -0
- package/docs/how-to/customization/index.md +23 -0
- package/docs/how-to/customization/integrate-playwright-utils.md +813 -0
- package/docs/how-to/customization/shard-large-documents.md +101 -0
- package/docs/how-to/get-answers-about-bmad.md +102 -0
- package/docs/how-to/installation/index.md +12 -0
- package/docs/how-to/installation/install-bmad.md +111 -0
- package/docs/how-to/installation/install-custom-modules.md +118 -0
- package/docs/how-to/installation/upgrade-to-v6.md +131 -0
- package/docs/how-to/workflows/bmgd-quick-flow.md +156 -0
- package/docs/how-to/workflows/conduct-research.md +97 -0
- package/docs/how-to/workflows/create-architecture.md +119 -0
- package/docs/how-to/workflows/create-epics-and-stories.md +109 -0
- package/docs/how-to/workflows/create-prd.md +91 -0
- package/docs/how-to/workflows/create-product-brief.md +94 -0
- package/docs/how-to/workflows/create-story.md +102 -0
- package/docs/how-to/workflows/create-ux-design.md +100 -0
- package/docs/how-to/workflows/implement-story.md +97 -0
- package/docs/how-to/workflows/quick-spec.md +122 -0
- package/docs/how-to/workflows/run-atdd.md +436 -0
- package/docs/how-to/workflows/run-automate.md +653 -0
- package/docs/how-to/workflows/run-brainstorming-session.md +73 -0
- package/docs/how-to/workflows/run-code-review.md +89 -0
- package/docs/how-to/workflows/run-implementation-readiness.md +125 -0
- package/docs/how-to/workflows/run-nfr-assess.md +679 -0
- package/docs/how-to/workflows/run-sprint-planning.md +94 -0
- package/docs/how-to/workflows/run-test-design.md +135 -0
- package/docs/how-to/workflows/run-test-review.md +605 -0
- package/docs/how-to/workflows/run-trace.md +883 -0
- package/docs/how-to/workflows/setup-ci.md +712 -0
- package/docs/how-to/workflows/setup-party-mode.md +89 -0
- package/docs/how-to/workflows/setup-test-framework.md +98 -0
- package/docs/index.md +63 -0
- package/docs/reference/agents/index.md +109 -0
- package/docs/reference/configuration/core-tasks.md +67 -0
- package/docs/reference/configuration/global-config.md +28 -0
- package/docs/reference/glossary/index.md +159 -0
- package/docs/reference/tea/commands.md +276 -0
- package/docs/reference/tea/configuration.md +678 -0
- package/docs/reference/tea/knowledge-base.md +340 -0
- package/docs/reference/workflows/core-workflows.md +32 -0
- package/docs/reference/workflows/document-project.md +73 -0
- package/docs/reference/workflows/index.md +12 -0
- package/docs/tutorials/getting-started/getting-started-bmadv6.md +246 -0
- package/docs/tutorials/getting-started/images/workflow-method-greenfield.excalidraw +5034 -0
- package/docs/tutorials/getting-started/images/workflow-method-greenfield.svg +4 -0
- package/docs/tutorials/getting-started/images/workflow-overview.jpg +0 -0
- package/docs/tutorials/getting-started/tea-lite-quickstart.md +444 -0
- package/docs/tutorials/getting-started/workflow-overview.jpg +0 -0
- package/eslint.config.mjs +152 -0
- package/package.json +117 -0
- package/prettier.config.mjs +32 -0
- package/src/bmm/_module-installer/installer.js +48 -0
- package/src/bmm/_module-installer/platform-specifics/claude-code.js +35 -0
- package/src/bmm/_module-installer/platform-specifics/windsurf.js +32 -0
- package/src/bmm/agents/analyst.agent.yaml +36 -0
- package/src/bmm/agents/architect.agent.yaml +28 -0
- package/src/bmm/agents/dev.agent.yaml +38 -0
- package/src/bmm/agents/pm.agent.yaml +46 -0
- package/src/bmm/agents/quick-flow-solo-dev.agent.yaml +32 -0
- package/src/bmm/agents/sm.agent.yaml +36 -0
- package/src/bmm/agents/tea.agent.yaml +63 -0
- package/src/bmm/agents/tech-writer/tech-writer-sidecar/documentation-standards.md +224 -0
- package/src/bmm/agents/tech-writer/tech-writer.agent.yaml +45 -0
- package/src/bmm/agents/ux-designer.agent.yaml +26 -0
- package/src/bmm/data/project-context-template.md +26 -0
- package/src/bmm/module-help.csv +32 -0
- package/src/bmm/module.yaml +44 -0
- package/src/bmm/sub-modules/claude-code/config.yaml +4 -0
- package/src/bmm/sub-modules/claude-code/injections.yaml +242 -0
- package/src/bmm/sub-modules/claude-code/readme.md +87 -0
- package/src/bmm/teams/default-party.csv +21 -0
- package/src/bmm/teams/team-fullstack.yaml +12 -0
- package/src/bmm/testarch/knowledge/adr-quality-readiness-checklist.md +350 -0
- package/src/bmm/testarch/knowledge/api-request.md +442 -0
- package/src/bmm/testarch/knowledge/api-testing-patterns.md +843 -0
- package/src/bmm/testarch/knowledge/auth-session.md +552 -0
- package/src/bmm/testarch/knowledge/burn-in.md +273 -0
- package/src/bmm/testarch/knowledge/ci-burn-in.md +675 -0
- package/src/bmm/testarch/knowledge/component-tdd.md +486 -0
- package/src/bmm/testarch/knowledge/contract-testing.md +957 -0
- package/src/bmm/testarch/knowledge/data-factories.md +500 -0
- package/src/bmm/testarch/knowledge/email-auth.md +721 -0
- package/src/bmm/testarch/knowledge/error-handling.md +725 -0
- package/src/bmm/testarch/knowledge/feature-flags.md +750 -0
- package/src/bmm/testarch/knowledge/file-utils.md +463 -0
- package/src/bmm/testarch/knowledge/fixture-architecture.md +401 -0
- package/src/bmm/testarch/knowledge/fixtures-composition.md +382 -0
- package/src/bmm/testarch/knowledge/intercept-network-call.md +430 -0
- package/src/bmm/testarch/knowledge/log.md +429 -0
- package/src/bmm/testarch/knowledge/network-error-monitor.md +405 -0
- package/src/bmm/testarch/knowledge/network-first.md +486 -0
- package/src/bmm/testarch/knowledge/network-recorder.md +527 -0
- package/src/bmm/testarch/knowledge/nfr-criteria.md +670 -0
- package/src/bmm/testarch/knowledge/overview.md +286 -0
- package/src/bmm/testarch/knowledge/playwright-config.md +730 -0
- package/src/bmm/testarch/knowledge/probability-impact.md +601 -0
- package/src/bmm/testarch/knowledge/recurse.md +421 -0
- package/src/bmm/testarch/knowledge/risk-governance.md +615 -0
- package/src/bmm/testarch/knowledge/selective-testing.md +732 -0
- package/src/bmm/testarch/knowledge/selector-resilience.md +527 -0
- package/src/bmm/testarch/knowledge/test-healing-patterns.md +644 -0
- package/src/bmm/testarch/knowledge/test-levels-framework.md +473 -0
- package/src/bmm/testarch/knowledge/test-priorities-matrix.md +373 -0
- package/src/bmm/testarch/knowledge/test-quality.md +664 -0
- package/src/bmm/testarch/knowledge/timing-debugging.md +372 -0
- package/src/bmm/testarch/knowledge/visual-debugging.md +524 -0
- package/src/bmm/testarch/tea-index.csv +35 -0
- package/src/bmm/workflows/1-analysis/create-product-brief/product-brief.template.md +10 -0
- package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-01-init.md +177 -0
- package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-01b-continue.md +161 -0
- package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-02-vision.md +199 -0
- package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-03-users.md +202 -0
- package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-04-metrics.md +205 -0
- package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-05-scope.md +219 -0
- package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-06-complete.md +162 -0
- package/src/bmm/workflows/1-analysis/create-product-brief/workflow.md +58 -0
- package/src/bmm/workflows/1-analysis/research/domain-steps/step-01-init.md +137 -0
- package/src/bmm/workflows/1-analysis/research/domain-steps/step-02-domain-analysis.md +229 -0
- package/src/bmm/workflows/1-analysis/research/domain-steps/step-03-competitive-landscape.md +238 -0
- package/src/bmm/workflows/1-analysis/research/domain-steps/step-04-regulatory-focus.md +206 -0
- package/src/bmm/workflows/1-analysis/research/domain-steps/step-05-technical-trends.md +234 -0
- package/src/bmm/workflows/1-analysis/research/domain-steps/step-06-research-synthesis.md +443 -0
- package/src/bmm/workflows/1-analysis/research/market-steps/step-01-init.md +182 -0
- package/src/bmm/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +237 -0
- package/src/bmm/workflows/1-analysis/research/market-steps/step-02-customer-insights.md +200 -0
- package/src/bmm/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +249 -0
- package/src/bmm/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +259 -0
- package/src/bmm/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +177 -0
- package/src/bmm/workflows/1-analysis/research/market-steps/step-06-research-completion.md +475 -0
- package/src/bmm/workflows/1-analysis/research/research.template.md +29 -0
- package/src/bmm/workflows/1-analysis/research/technical-steps/step-01-init.md +137 -0
- package/src/bmm/workflows/1-analysis/research/technical-steps/step-02-technical-overview.md +239 -0
- package/src/bmm/workflows/1-analysis/research/technical-steps/step-03-integration-patterns.md +248 -0
- package/src/bmm/workflows/1-analysis/research/technical-steps/step-04-architectural-patterns.md +202 -0
- package/src/bmm/workflows/1-analysis/research/technical-steps/step-05-implementation-research.md +239 -0
- package/src/bmm/workflows/1-analysis/research/technical-steps/step-06-research-synthesis.md +486 -0
- package/src/bmm/workflows/1-analysis/research/workflow.md +173 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01-init.md +135 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01b-continue.md +127 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-02-discovery.md +190 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-03-core-experience.md +216 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-04-emotional-response.md +219 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-05-inspiration.md +234 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-06-design-system.md +252 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-07-defining-experience.md +254 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-08-visual-foundation.md +224 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-09-design-directions.md +224 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-10-user-journeys.md +241 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-11-component-strategy.md +248 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-12-ux-patterns.md +237 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-13-responsive-accessibility.md +264 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-14-complete.md +171 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +13 -0
- package/src/bmm/workflows/2-plan-workflows/create-ux-design/workflow.md +43 -0
- package/src/bmm/workflows/2-plan-workflows/prd/data/domain-complexity.csv +13 -0
- package/src/bmm/workflows/2-plan-workflows/prd/data/prd-purpose.md +197 -0
- package/src/bmm/workflows/2-plan-workflows/prd/data/project-types.csv +11 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-01-init.md +191 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-01b-continue.md +153 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-02-discovery.md +224 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-03-success.md +226 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-04-journeys.md +213 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-05-domain.md +207 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-06-innovation.md +226 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-07-project-type.md +237 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-08-scoping.md +228 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-09-functional.md +231 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-10-nonfunctional.md +242 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-11-polish.md +217 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-c/step-12-complete.md +124 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-01-discovery.md +247 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-01b-legacy-conversion.md +208 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-02-review.md +249 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-03-edit.md +253 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-04-complete.md +168 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-01-discovery.md +218 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-02-format-detection.md +191 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-02b-parity-check.md +209 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-03-density-validation.md +174 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-04-brief-coverage-validation.md +214 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-05-measurability-validation.md +228 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-06-traceability-validation.md +217 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-07-implementation-leakage-validation.md +205 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-08-domain-compliance-validation.md +243 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-09-project-type-validation.md +263 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-10-smart-validation.md +209 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-11-holistic-quality-validation.md +264 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-12-completeness-validation.md +242 -0
- package/src/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-13-report-complete.md +231 -0
- package/src/bmm/workflows/2-plan-workflows/prd/templates/prd-template.md +10 -0
- package/src/bmm/workflows/2-plan-workflows/prd/validation-report-prd-workflow.md +433 -0
- package/src/bmm/workflows/2-plan-workflows/prd/workflow.md +150 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-01-document-discovery.md +190 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-02-prd-analysis.md +178 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-03-epic-coverage-validation.md +179 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-04-ux-alignment.md +139 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-05-epic-quality-review.md +252 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +135 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/templates/readiness-report-template.md +4 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/workflow.md +55 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/architecture-decision-template.md +12 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/data/domain-complexity.csv +11 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/data/project-types.csv +7 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-01-init.md +153 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-01b-continue.md +164 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-02-context.md +224 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-03-starter.md +331 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-04-decisions.md +318 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-05-patterns.md +359 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-06-structure.md +379 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-07-validation.md +359 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-08-complete.md +76 -0
- package/src/bmm/workflows/3-solutioning/create-architecture/workflow.md +50 -0
- package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-01-validate-prerequisites.md +259 -0
- package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-02-design-epics.md +233 -0
- package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-03-create-stories.md +272 -0
- package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-04-final-validation.md +149 -0
- package/src/bmm/workflows/3-solutioning/create-epics-and-stories/templates/epics-template.md +57 -0
- package/src/bmm/workflows/3-solutioning/create-epics-and-stories/workflow.md +59 -0
- package/src/bmm/workflows/4-implementation/code-review/checklist.md +23 -0
- package/src/bmm/workflows/4-implementation/code-review/instructions.xml +227 -0
- package/src/bmm/workflows/4-implementation/code-review/workflow.yaml +51 -0
- package/src/bmm/workflows/4-implementation/correct-course/checklist.md +288 -0
- package/src/bmm/workflows/4-implementation/correct-course/instructions.md +206 -0
- package/src/bmm/workflows/4-implementation/correct-course/workflow.yaml +60 -0
- package/src/bmm/workflows/4-implementation/create-story/checklist.md +358 -0
- package/src/bmm/workflows/4-implementation/create-story/instructions.xml +345 -0
- package/src/bmm/workflows/4-implementation/create-story/template.md +49 -0
- package/src/bmm/workflows/4-implementation/create-story/workflow.yaml +61 -0
- package/src/bmm/workflows/4-implementation/dev-story/checklist.md +80 -0
- package/src/bmm/workflows/4-implementation/dev-story/instructions.xml +410 -0
- package/src/bmm/workflows/4-implementation/dev-story/workflow.yaml +27 -0
- package/src/bmm/workflows/4-implementation/retrospective/instructions.md +1443 -0
- package/src/bmm/workflows/4-implementation/retrospective/workflow.yaml +58 -0
- package/src/bmm/workflows/4-implementation/sprint-planning/checklist.md +33 -0
- package/src/bmm/workflows/4-implementation/sprint-planning/instructions.md +225 -0
- package/src/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +55 -0
- package/src/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +54 -0
- package/src/bmm/workflows/4-implementation/sprint-status/instructions.md +229 -0
- package/src/bmm/workflows/4-implementation/sprint-status/workflow.yaml +36 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/data/project-levels.yaml +59 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-01-mode-detection.md +156 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-02-context-gathering.md +120 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-03-execute.md +113 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-04-self-check.md +113 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-05-adversarial-review.md +106 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-06-resolve-findings.md +140 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/workflow.md +50 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-01-understand.md +189 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-02-investigate.md +144 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-03-generate.md +128 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-04-review.md +191 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-spec/tech-spec-template.md +74 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-spec/workflow.md +79 -0
- package/src/bmm/workflows/document-project/checklist.md +245 -0
- package/src/bmm/workflows/document-project/documentation-requirements.csv +12 -0
- package/src/bmm/workflows/document-project/instructions.md +221 -0
- package/src/bmm/workflows/document-project/templates/deep-dive-template.md +345 -0
- package/src/bmm/workflows/document-project/templates/index-template.md +169 -0
- package/src/bmm/workflows/document-project/templates/project-overview-template.md +103 -0
- package/src/bmm/workflows/document-project/templates/project-scan-report-schema.json +160 -0
- package/src/bmm/workflows/document-project/templates/source-tree-template.md +135 -0
- package/src/bmm/workflows/document-project/workflow.yaml +30 -0
- package/src/bmm/workflows/document-project/workflows/deep-dive-instructions.md +298 -0
- package/src/bmm/workflows/document-project/workflows/deep-dive.yaml +31 -0
- package/src/bmm/workflows/document-project/workflows/full-scan-instructions.md +1106 -0
- package/src/bmm/workflows/document-project/workflows/full-scan.yaml +31 -0
- package/src/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-library.json +90 -0
- package/src/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-templates.yaml +127 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-dataflow/checklist.md +39 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-dataflow/instructions.md +130 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-dataflow/workflow.yaml +27 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-diagram/checklist.md +43 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-diagram/instructions.md +141 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-diagram/workflow.yaml +27 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-flowchart/checklist.md +49 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-flowchart/instructions.md +241 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-flowchart/workflow.yaml +27 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-wireframe/checklist.md +38 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-wireframe/instructions.md +133 -0
- package/src/bmm/workflows/excalidraw-diagrams/create-wireframe/workflow.yaml +27 -0
- package/src/bmm/workflows/testarch/atdd/atdd-checklist-template.md +363 -0
- package/src/bmm/workflows/testarch/atdd/checklist.md +374 -0
- package/src/bmm/workflows/testarch/atdd/instructions.md +806 -0
- package/src/bmm/workflows/testarch/atdd/workflow.yaml +47 -0
- package/src/bmm/workflows/testarch/automate/checklist.md +582 -0
- package/src/bmm/workflows/testarch/automate/instructions.md +1324 -0
- package/src/bmm/workflows/testarch/automate/workflow.yaml +54 -0
- package/src/bmm/workflows/testarch/ci/checklist.md +247 -0
- package/src/bmm/workflows/testarch/ci/github-actions-template.yaml +198 -0
- package/src/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +149 -0
- package/src/bmm/workflows/testarch/ci/instructions.md +536 -0
- package/src/bmm/workflows/testarch/ci/workflow.yaml +47 -0
- package/src/bmm/workflows/testarch/framework/checklist.md +320 -0
- package/src/bmm/workflows/testarch/framework/instructions.md +481 -0
- package/src/bmm/workflows/testarch/framework/workflow.yaml +49 -0
- package/src/bmm/workflows/testarch/nfr-assess/checklist.md +407 -0
- package/src/bmm/workflows/testarch/nfr-assess/instructions.md +726 -0
- package/src/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +461 -0
- package/src/bmm/workflows/testarch/nfr-assess/workflow.yaml +49 -0
- package/src/bmm/workflows/testarch/test-design/checklist.md +407 -0
- package/src/bmm/workflows/testarch/test-design/instructions.md +1158 -0
- package/src/bmm/workflows/testarch/test-design/test-design-architecture-template.md +213 -0
- package/src/bmm/workflows/testarch/test-design/test-design-qa-template.md +286 -0
- package/src/bmm/workflows/testarch/test-design/test-design-template.md +294 -0
- package/src/bmm/workflows/testarch/test-design/workflow.yaml +71 -0
- package/src/bmm/workflows/testarch/test-review/checklist.md +472 -0
- package/src/bmm/workflows/testarch/test-review/instructions.md +628 -0
- package/src/bmm/workflows/testarch/test-review/test-review-template.md +390 -0
- package/src/bmm/workflows/testarch/test-review/workflow.yaml +48 -0
- package/src/bmm/workflows/testarch/trace/checklist.md +642 -0
- package/src/bmm/workflows/testarch/trace/instructions.md +1030 -0
- package/src/bmm/workflows/testarch/trace/trace-template.md +675 -0
- package/src/bmm/workflows/testarch/trace/workflow.yaml +57 -0
- package/src/core/_module-installer/installer.js +60 -0
- package/src/core/agents/bmad-master.agent.yaml +29 -0
- package/src/core/module-help.csv +9 -0
- package/src/core/module.yaml +25 -0
- package/src/core/resources/excalidraw/README.md +160 -0
- package/src/core/resources/excalidraw/excalidraw-helpers.md +127 -0
- package/src/core/resources/excalidraw/library-loader.md +50 -0
- package/src/core/resources/excalidraw/validate-json-instructions.md +79 -0
- package/src/core/tasks/editorial-review-prose.xml +100 -0
- package/src/core/tasks/editorial-review-structure.xml +209 -0
- package/src/core/tasks/help.md +62 -0
- package/src/core/tasks/index-docs.xml +65 -0
- package/src/core/tasks/review-adversarial-general.xml +48 -0
- package/src/core/tasks/shard-doc.xml +109 -0
- package/src/core/tasks/workflow.xml +235 -0
- package/src/core/workflows/advanced-elicitation/methods.csv +51 -0
- package/src/core/workflows/advanced-elicitation/workflow.xml +117 -0
- package/src/core/workflows/brainstorming/brain-methods.csv +62 -0
- package/src/core/workflows/brainstorming/steps/step-01-session-setup.md +197 -0
- package/src/core/workflows/brainstorming/steps/step-01b-continue.md +122 -0
- package/src/core/workflows/brainstorming/steps/step-02a-user-selected.md +225 -0
- package/src/core/workflows/brainstorming/steps/step-02b-ai-recommended.md +237 -0
- package/src/core/workflows/brainstorming/steps/step-02c-random-selection.md +209 -0
- package/src/core/workflows/brainstorming/steps/step-02d-progressive-flow.md +264 -0
- package/src/core/workflows/brainstorming/steps/step-03-technique-execution.md +399 -0
- package/src/core/workflows/brainstorming/steps/step-04-idea-organization.md +303 -0
- package/src/core/workflows/brainstorming/template.md +15 -0
- package/src/core/workflows/brainstorming/workflow.md +58 -0
- package/src/core/workflows/party-mode/steps/step-01-agent-loading.md +138 -0
- package/src/core/workflows/party-mode/steps/step-02-discussion-orchestration.md +187 -0
- package/src/core/workflows/party-mode/steps/step-03-graceful-exit.md +157 -0
- package/src/core/workflows/party-mode/workflow.md +194 -0
- package/src/utility/agent-components/activation-rules.txt +6 -0
- package/src/utility/agent-components/activation-steps.txt +14 -0
- package/src/utility/agent-components/agent-command-header.md +1 -0
- package/src/utility/agent-components/agent.customize.template.yaml +41 -0
- package/src/utility/agent-components/handler-action.txt +4 -0
- package/src/utility/agent-components/handler-data.txt +5 -0
- package/src/utility/agent-components/handler-exec.txt +6 -0
- package/src/utility/agent-components/handler-multi.txt +14 -0
- package/src/utility/agent-components/handler-tmpl.txt +5 -0
- package/src/utility/agent-components/handler-validate-workflow.txt +7 -0
- package/src/utility/agent-components/handler-workflow.txt +10 -0
- package/src/utility/agent-components/menu-handlers.txt +6 -0
- package/test/README.md +295 -0
- package/test/adversarial-review-tests/README.md +56 -0
- package/test/adversarial-review-tests/sample-content.md +46 -0
- package/test/adversarial-review-tests/test-cases.yaml +103 -0
- package/test/fixtures/agent-schema/invalid/critical-actions/actions-as-string.agent.yaml +27 -0
- package/test/fixtures/agent-schema/invalid/critical-actions/empty-string-in-actions.agent.yaml +30 -0
- package/test/fixtures/agent-schema/invalid/menu/empty-menu.agent.yaml +22 -0
- package/test/fixtures/agent-schema/invalid/menu/missing-menu.agent.yaml +20 -0
- package/test/fixtures/agent-schema/invalid/menu-commands/empty-command-target.agent.yaml +25 -0
- package/test/fixtures/agent-schema/invalid/menu-commands/no-command-target.agent.yaml +24 -0
- package/test/fixtures/agent-schema/invalid/menu-triggers/camel-case.agent.yaml +25 -0
- package/test/fixtures/agent-schema/invalid/menu-triggers/compound-invalid-format.agent.yaml +25 -0
- package/test/fixtures/agent-schema/invalid/menu-triggers/compound-mismatched-kebab.agent.yaml +25 -0
- package/test/fixtures/agent-schema/invalid/menu-triggers/duplicate-triggers.agent.yaml +31 -0
- package/test/fixtures/agent-schema/invalid/menu-triggers/empty-trigger.agent.yaml +25 -0
- package/test/fixtures/agent-schema/invalid/menu-triggers/leading-asterisk.agent.yaml +25 -0
- package/test/fixtures/agent-schema/invalid/menu-triggers/snake-case.agent.yaml +25 -0
- package/test/fixtures/agent-schema/invalid/menu-triggers/trigger-with-spaces.agent.yaml +25 -0
- package/test/fixtures/agent-schema/invalid/metadata/empty-module-string.agent.yaml +26 -0
- package/test/fixtures/agent-schema/invalid/metadata/empty-name.agent.yaml +24 -0
- package/test/fixtures/agent-schema/invalid/metadata/extra-metadata-fields.agent.yaml +27 -0
- package/test/fixtures/agent-schema/invalid/metadata/missing-id.agent.yaml +23 -0
- package/test/fixtures/agent-schema/invalid/persona/empty-principles-array.agent.yaml +24 -0
- package/test/fixtures/agent-schema/invalid/persona/empty-string-in-principles.agent.yaml +27 -0
- package/test/fixtures/agent-schema/invalid/persona/extra-persona-fields.agent.yaml +27 -0
- package/test/fixtures/agent-schema/invalid/persona/missing-role.agent.yaml +24 -0
- package/test/fixtures/agent-schema/invalid/prompts/empty-content.agent.yaml +29 -0
- package/test/fixtures/agent-schema/invalid/prompts/extra-prompt-fields.agent.yaml +31 -0
- package/test/fixtures/agent-schema/invalid/prompts/missing-content.agent.yaml +28 -0
- package/test/fixtures/agent-schema/invalid/prompts/missing-id.agent.yaml +28 -0
- package/test/fixtures/agent-schema/invalid/top-level/empty-file.agent.yaml +5 -0
- package/test/fixtures/agent-schema/invalid/top-level/extra-top-level-keys.agent.yaml +28 -0
- package/test/fixtures/agent-schema/invalid/top-level/missing-agent-key.agent.yaml +11 -0
- package/test/fixtures/agent-schema/invalid/yaml-errors/invalid-indentation.agent.yaml +19 -0
- package/test/fixtures/agent-schema/invalid/yaml-errors/malformed-yaml.agent.yaml +18 -0
- package/test/fixtures/agent-schema/valid/critical-actions/empty-critical-actions.agent.yaml +24 -0
- package/test/fixtures/agent-schema/valid/critical-actions/no-critical-actions.agent.yaml +22 -0
- package/test/fixtures/agent-schema/valid/critical-actions/valid-critical-actions.agent.yaml +27 -0
- package/test/fixtures/agent-schema/valid/menu/multiple-menu-items.agent.yaml +31 -0
- package/test/fixtures/agent-schema/valid/menu/single-menu-item.agent.yaml +22 -0
- package/test/fixtures/agent-schema/valid/menu-commands/all-command-types.agent.yaml +38 -0
- package/test/fixtures/agent-schema/valid/menu-commands/multiple-commands.agent.yaml +24 -0
- package/test/fixtures/agent-schema/valid/menu-triggers/compound-triggers.agent.yaml +31 -0
- package/test/fixtures/agent-schema/valid/menu-triggers/kebab-case-triggers.agent.yaml +34 -0
- package/test/fixtures/agent-schema/valid/metadata/core-agent-with-module.agent.yaml +24 -0
- package/test/fixtures/agent-schema/valid/metadata/empty-module-name-in-path.agent.yaml +24 -0
- package/test/fixtures/agent-schema/valid/metadata/malformed-path-treated-as-core.agent.yaml +24 -0
- package/test/fixtures/agent-schema/valid/metadata/module-agent-correct.agent.yaml +24 -0
- package/test/fixtures/agent-schema/valid/metadata/module-agent-missing-module.agent.yaml +23 -0
- package/test/fixtures/agent-schema/valid/metadata/wrong-module-value.agent.yaml +24 -0
- package/test/fixtures/agent-schema/valid/persona/complete-persona.agent.yaml +24 -0
- package/test/fixtures/agent-schema/valid/prompts/empty-prompts.agent.yaml +24 -0
- package/test/fixtures/agent-schema/valid/prompts/no-prompts.agent.yaml +22 -0
- package/test/fixtures/agent-schema/valid/prompts/valid-prompts-minimal.agent.yaml +28 -0
- package/test/fixtures/agent-schema/valid/prompts/valid-prompts-with-description.agent.yaml +30 -0
- package/test/fixtures/agent-schema/valid/top-level/minimal-core-agent.agent.yaml +24 -0
- package/test/test-agent-schema.js +387 -0
- package/test/test-cli-integration.sh +159 -0
- package/test/test-installation-components.js +214 -0
- package/test/unit-test-schema.js +133 -0
- package/tools/bmad-npx-wrapper.js +38 -0
- package/tools/build-docs.js +577 -0
- package/tools/cli/README.md +7 -0
- package/tools/cli/bmad-cli.js +58 -0
- package/tools/cli/commands/install.js +87 -0
- package/tools/cli/commands/status.js +65 -0
- package/tools/cli/external-official-modules.yaml +56 -0
- package/tools/cli/installers/install-messages.yaml +58 -0
- package/tools/cli/installers/lib/core/config-collector.js +1079 -0
- package/tools/cli/installers/lib/core/custom-module-cache.js +259 -0
- package/tools/cli/installers/lib/core/dependency-resolver.js +739 -0
- package/tools/cli/installers/lib/core/detector.js +223 -0
- package/tools/cli/installers/lib/core/ide-config-manager.js +156 -0
- package/tools/cli/installers/lib/core/installer.js +2826 -0
- package/tools/cli/installers/lib/core/manifest-generator.js +1054 -0
- package/tools/cli/installers/lib/core/manifest.js +1036 -0
- package/tools/cli/installers/lib/custom/handler.js +363 -0
- package/tools/cli/installers/lib/ide/STANDARDIZATION_PLAN.md +208 -0
- package/tools/cli/installers/lib/ide/_base-ide.js +655 -0
- package/tools/cli/installers/lib/ide/antigravity.js +474 -0
- package/tools/cli/installers/lib/ide/auggie.js +244 -0
- package/tools/cli/installers/lib/ide/claude-code.js +506 -0
- package/tools/cli/installers/lib/ide/cline.js +272 -0
- package/tools/cli/installers/lib/ide/codex.js +412 -0
- package/tools/cli/installers/lib/ide/crush.js +149 -0
- package/tools/cli/installers/lib/ide/cursor.js +160 -0
- package/tools/cli/installers/lib/ide/gemini.js +301 -0
- package/tools/cli/installers/lib/ide/github-copilot.js +383 -0
- package/tools/cli/installers/lib/ide/iflow.js +191 -0
- package/tools/cli/installers/lib/ide/kilo.js +250 -0
- package/tools/cli/installers/lib/ide/kiro-cli.js +326 -0
- package/tools/cli/installers/lib/ide/manager.js +244 -0
- package/tools/cli/installers/lib/ide/opencode.js +257 -0
- package/tools/cli/installers/lib/ide/qwen.js +372 -0
- package/tools/cli/installers/lib/ide/roo.js +273 -0
- package/tools/cli/installers/lib/ide/rovo-dev.js +290 -0
- package/tools/cli/installers/lib/ide/shared/agent-command-generator.js +165 -0
- package/tools/cli/installers/lib/ide/shared/bmad-artifacts.js +158 -0
- package/tools/cli/installers/lib/ide/shared/module-injections.js +136 -0
- package/tools/cli/installers/lib/ide/shared/path-utils.js +165 -0
- package/tools/cli/installers/lib/ide/shared/task-tool-command-generator.js +268 -0
- package/tools/cli/installers/lib/ide/shared/workflow-command-generator.js +293 -0
- package/tools/cli/installers/lib/ide/templates/agent-command-template.md +14 -0
- package/tools/cli/installers/lib/ide/templates/gemini-agent-command.toml +14 -0
- package/tools/cli/installers/lib/ide/templates/gemini-task-command.toml +12 -0
- package/tools/cli/installers/lib/ide/templates/workflow-command-template.md +13 -0
- package/tools/cli/installers/lib/ide/templates/workflow-commander.md +5 -0
- package/tools/cli/installers/lib/ide/trae.js +313 -0
- package/tools/cli/installers/lib/ide/windsurf.js +258 -0
- package/tools/cli/installers/lib/message-loader.js +85 -0
- package/tools/cli/installers/lib/modules/external-manager.js +135 -0
- package/tools/cli/installers/lib/modules/manager.js +1375 -0
- package/tools/cli/lib/activation-builder.js +163 -0
- package/tools/cli/lib/agent/compiler.js +522 -0
- package/tools/cli/lib/agent/installer.js +716 -0
- package/tools/cli/lib/agent/template-engine.js +152 -0
- package/tools/cli/lib/agent-analyzer.js +109 -0
- package/tools/cli/lib/agent-party-generator.js +194 -0
- package/tools/cli/lib/cli-utils.js +227 -0
- package/tools/cli/lib/config.js +213 -0
- package/tools/cli/lib/file-ops.js +204 -0
- package/tools/cli/lib/platform-codes.js +116 -0
- package/tools/cli/lib/project-root.js +77 -0
- package/tools/cli/lib/prompts.js +433 -0
- package/tools/cli/lib/ui.js +1716 -0
- package/tools/cli/lib/xml-handler.js +177 -0
- package/tools/cli/lib/xml-to-markdown.js +82 -0
- package/tools/cli/lib/yaml-format.js +245 -0
- package/tools/cli/lib/yaml-xml-builder.js +587 -0
- package/tools/docs/BUNDLE_DISTRIBUTION_SETUP.md +95 -0
- package/tools/docs/index.md +2 -0
- package/tools/fix-doc-links.js +288 -0
- package/tools/flattener/aggregate.js +76 -0
- package/tools/flattener/binary.js +80 -0
- package/tools/flattener/discovery.js +71 -0
- package/tools/flattener/files.js +35 -0
- package/tools/flattener/ignoreRules.js +172 -0
- package/tools/flattener/main.js +483 -0
- package/tools/flattener/projectRoot.js +201 -0
- package/tools/flattener/prompts.js +44 -0
- package/tools/flattener/stats.helpers.js +368 -0
- package/tools/flattener/stats.js +75 -0
- package/tools/flattener/test-matrix.js +409 -0
- package/tools/flattener/xml.js +82 -0
- package/tools/format-workflow-md.js +263 -0
- package/tools/lib/xml-utils.js +13 -0
- package/tools/maintainer/review-pr-README.md +55 -0
- package/tools/maintainer/review-pr.md +242 -0
- package/tools/migrate-custom-module-paths.js +124 -0
- package/tools/platform-codes.yaml +157 -0
- package/tools/schema/agent.js +491 -0
- package/tools/validate-agent-schema.js +110 -0
- package/tools/validate-doc-links.js +363 -0
- package/tools/validate-svg-changes.sh +356 -0
- package/website/README.md +76 -0
- package/website/astro.config.mjs +228 -0
- package/website/public/favicon.ico +0 -0
- package/website/public/img/bmad-dark.png +0 -0
- package/website/public/img/bmad-light.png +0 -0
- package/website/public/img/logo.svg +4 -0
- package/website/public/robots.txt +37 -0
- package/website/src/components/Banner.astro +59 -0
- package/website/src/components/Header.astro +121 -0
- package/website/src/components/MobileMenuFooter.astro +53 -0
- package/website/src/content/config.ts +6 -0
- package/website/src/lib/site-url.js +25 -0
- package/website/src/rehype-markdown-links.js +102 -0
- 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 };
|