mdan-cli 2.5.0 → 2.5.2
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/.augment/code_review_guidelines.yaml +271 -0
- package/.claude/skills/bmad-os-audit-file-refs/SKILL.md +6 -0
- package/.claude/skills/bmad-os-audit-file-refs/prompts/instructions.md +59 -0
- package/.claude/skills/bmad-os-changelog-social/SKILL.md +177 -0
- package/.claude/skills/bmad-os-changelog-social/examples/discord-example.md +53 -0
- package/.claude/skills/bmad-os-changelog-social/examples/linkedin-example.md +49 -0
- package/.claude/skills/bmad-os-changelog-social/examples/twitter-example.md +55 -0
- package/.claude/skills/bmad-os-diataxis-style-fix/SKILL.md +6 -0
- package/.claude/skills/bmad-os-diataxis-style-fix/prompts/instructions.md +229 -0
- package/.claude/skills/bmad-os-draft-changelog/SKILL.md +6 -0
- package/.claude/skills/bmad-os-draft-changelog/prompts/instructions.md +82 -0
- package/.claude/skills/bmad-os-gh-triage/SKILL.md +6 -0
- package/.claude/skills/bmad-os-gh-triage/prompts/agent-prompt.md +60 -0
- package/.claude/skills/bmad-os-gh-triage/prompts/instructions.md +74 -0
- package/.claude/skills/bmad-os-release-module/SKILL.md +6 -0
- package/.claude/skills/bmad-os-release-module/prompts/instructions.md +53 -0
- package/.claude/skills/bmad-os-review-pr/SKILL.md +6 -0
- package/.claude/skills/bmad-os-review-pr/prompts/instructions.md +231 -0
- package/.claude/skills/bmad-os-root-cause-analysis/SKILL.md +12 -0
- package/.claude/skills/bmad-os-root-cause-analysis/prompts/instructions.md +74 -0
- package/.coderabbit.yaml +85 -0
- package/.github/CODE_OF_CONDUCT.md +128 -0
- package/.github/FUNDING.yaml +15 -0
- package/.github/ISSUE_TEMPLATE/bug-report.yaml +124 -0
- package/.github/ISSUE_TEMPLATE/config.yaml +8 -0
- package/.github/ISSUE_TEMPLATE/documentation.yaml +55 -0
- package/.github/ISSUE_TEMPLATE/feature-request.md +22 -0
- package/.github/ISSUE_TEMPLATE/issue.md +32 -0
- package/.github/PULL_REQUEST_TEMPLATE.md +13 -0
- package/.github/scripts/discord-helpers.sh +34 -0
- package/.github/workflows/coderabbit-review.yaml +22 -0
- package/.github/workflows/discord.yaml +90 -0
- package/.github/workflows/docs.yaml +64 -0
- package/.github/workflows/quality.yaml +116 -0
- package/.husky/pre-commit +20 -0
- package/.markdownlint-cli2.yaml +41 -0
- package/.nvmrc +1 -0
- package/.prettierignore +12 -0
- package/.vscode/settings.json +96 -0
- package/AGENTS.md +227 -165
- package/AGENTS_LIST.md +946 -0
- package/ARCHITECTURE.md +590 -0
- package/CHANGELOG.md +1770 -0
- package/CNAME +1 -0
- package/CONTRIBUTING.md +512 -0
- package/CONTRIBUTORS.md +32 -0
- package/INSTALL.md +246 -0
- package/LICENSE +30 -0
- package/README.md +133 -194
- package/RELEASE_NOTES.md +246 -0
- package/SECURITY.md +85 -0
- package/TRADEMARK.md +55 -0
- package/USAGE.md +368 -0
- package/Wordmark.png +0 -0
- package/app/__init__.py +5 -0
- package/app/cis/agents/__init__.py +31 -0
- package/app/cis/agents/brainstorming-coach/__init__.py +3 -0
- package/app/cis/agents/brainstorming-coach/agent.py +162 -0
- package/app/cis/agents/brainstorming-coach/prompt.yaml +53 -0
- package/app/cis/agents/creative-problem-solver/__init__.py +3 -0
- package/app/cis/agents/creative-problem-solver/agent.py +233 -0
- package/app/cis/agents/creative-problem-solver/prompt.yaml +74 -0
- package/app/cis/agents/design-thinking-coach/__init__.py +3 -0
- package/app/cis/agents/design-thinking-coach/agent.py +241 -0
- package/app/cis/agents/design-thinking-coach/prompt.yaml +77 -0
- package/app/cis/agents/innovation-strategist/__init__.py +3 -0
- package/app/cis/agents/innovation-strategist/agent.py +271 -0
- package/app/cis/agents/innovation-strategist/prompt.yaml +70 -0
- package/app/cis/agents/presentation-master/__init__.py +3 -0
- package/app/cis/agents/presentation-master/agent.py +420 -0
- package/app/cis/agents/presentation-master/prompt.yaml +62 -0
- package/app/cis/agents/storyteller/__init__.py +3 -0
- package/app/cis/agents/storyteller/agent.py +303 -0
- package/app/cis/agents/storyteller/prompt.yaml +99 -0
- package/app/core/__init__.py +5 -0
- package/app/core/agents/__init__.py +5 -0
- package/app/core/agents/mdan-master/__init__.py +7 -0
- package/app/core/agents/mdan-master/agent.py +302 -0
- package/app/core/agents/mdan-master/prompt.yaml +105 -0
- package/app/mmb/agents/__init__.py +24 -0
- package/app/mmb/agents/agent-builder/__init__.py +5 -0
- package/app/mmb/agents/agent-builder/agent.py +261 -0
- package/app/mmb/agents/agent-builder/prompt.yaml +48 -0
- package/app/mmb/agents/module-builder/__init__.py +5 -0
- package/app/mmb/agents/module-builder/agent.py +299 -0
- package/app/mmb/agents/module-builder/prompt.yaml +50 -0
- package/app/mmb/agents/workflow-builder/__init__.py +5 -0
- package/app/mmb/agents/workflow-builder/agent.py +318 -0
- package/app/mmb/agents/workflow-builder/prompt.yaml +52 -0
- package/app/mmm/agents/__init__.py +48 -0
- package/app/mmm/agents/analyst/__init__.py +7 -0
- package/app/mmm/agents/analyst/agent.py +384 -0
- package/app/mmm/agents/analyst/prompt.yaml +62 -0
- package/app/mmm/agents/architect/__init__.py +7 -0
- package/app/mmm/agents/architect/agent.py +300 -0
- package/app/mmm/agents/architect/prompt.yaml +66 -0
- package/app/mmm/agents/dev/__init__.py +7 -0
- package/app/mmm/agents/dev/agent.py +285 -0
- package/app/mmm/agents/dev/prompt.yaml +62 -0
- package/app/mmm/agents/pm/__init__.py +7 -0
- package/app/mmm/agents/pm/agent.py +417 -0
- package/app/mmm/agents/pm/prompt.yaml +64 -0
- package/app/mmm/agents/qa/__init__.py +7 -0
- package/app/mmm/agents/qa/agent.py +267 -0
- package/app/mmm/agents/qa/prompt.yaml +67 -0
- package/app/mmm/agents/quick-flow-solo-dev/__init__.py +7 -0
- package/app/mmm/agents/quick-flow-solo-dev/agent.py +319 -0
- package/app/mmm/agents/quick-flow-solo-dev/prompt.yaml +60 -0
- package/app/mmm/agents/sm/__init__.py +7 -0
- package/app/mmm/agents/sm/agent.py +357 -0
- package/app/mmm/agents/sm/prompt.yaml +61 -0
- package/app/mmm/agents/tech-writer/__init__.py +7 -0
- package/app/mmm/agents/tech-writer/agent.py +420 -0
- package/app/mmm/agents/tech-writer/prompt.yaml +70 -0
- package/app/mmm/agents/ux-designer/__init__.py +14 -0
- package/app/mmm/agents/ux-designer/agent.py +412 -0
- package/app/mmm/agents/ux-designer/prompt.yaml +37 -0
- package/app/packs/__init__.py +32 -0
- package/app/packs/db-optimization/__init__.py +13 -0
- package/app/packs/db-optimization/agents/__init__.py +11 -0
- package/app/packs/db-optimization/agents/db-performance-analyst/__init__.py +5 -0
- package/app/packs/db-optimization/agents/db-performance-analyst/agent.py +559 -0
- package/app/packs/db-optimization/agents/db-performance-analyst/prompt.yaml +63 -0
- package/app/packs/db-optimization/agents/indexing-specialist/__init__.py +5 -0
- package/app/packs/db-optimization/agents/indexing-specialist/agent.py +713 -0
- package/app/packs/db-optimization/agents/indexing-specialist/prompt.yaml +92 -0
- package/app/packs/db-optimization/agents/query-optimizer/__init__.py +5 -0
- package/app/packs/db-optimization/agents/query-optimizer/agent.py +566 -0
- package/app/packs/db-optimization/agents/query-optimizer/prompt.yaml +74 -0
- package/app/packs/devops-azure/__init__.py +13 -0
- package/app/packs/devops-azure/agents/__init__.py +11 -0
- package/app/packs/devops-azure/agents/azure-specialist/__init__.py +5 -0
- package/app/packs/devops-azure/agents/azure-specialist/agent.py +584 -0
- package/app/packs/devops-azure/agents/azure-specialist/prompt.yaml +301 -0
- package/app/packs/devops-azure/agents/cicd-architect/__init__.py +5 -0
- package/app/packs/devops-azure/agents/cicd-architect/agent.py +665 -0
- package/app/packs/devops-azure/agents/cicd-architect/prompt.yaml +409 -0
- package/app/packs/devops-azure/agents/devops-engineer/__init__.py +5 -0
- package/app/packs/devops-azure/agents/devops-engineer/agent.py +545 -0
- package/app/packs/devops-azure/agents/devops-engineer/prompt.yaml +263 -0
- package/app/packs/fintech/__init__.py +13 -0
- package/app/packs/fintech/agents/__init__.py +11 -0
- package/app/packs/fintech/agents/compliance-officer/__init__.py +5 -0
- package/app/packs/fintech/agents/compliance-officer/agent.py +449 -0
- package/app/packs/fintech/agents/compliance-officer/prompt.yaml +135 -0
- package/app/packs/fintech/agents/financial-analyst/__init__.py +5 -0
- package/app/packs/fintech/agents/financial-analyst/agent.py +392 -0
- package/app/packs/fintech/agents/financial-analyst/prompt.yaml +143 -0
- package/app/packs/fintech/agents/risk-manager/__init__.py +5 -0
- package/app/packs/fintech/agents/risk-manager/agent.py +664 -0
- package/app/packs/fintech/agents/risk-manager/prompt.yaml +240 -0
- package/app/tea/agents/tea/__init__.py +9 -0
- package/app/tea/agents/tea/agent.py +689 -0
- package/app/tea/agents/tea/prompt.yaml +100 -0
- package/banner-bmad-method.png +0 -0
- package/docs/404.md +9 -0
- package/docs/_STYLE_GUIDE.md +370 -0
- package/docs/explanation/advanced-elicitation.md +49 -0
- package/docs/explanation/adversarial-review.md +59 -0
- package/docs/explanation/brainstorming.md +33 -0
- package/docs/explanation/established-projects-faq.md +50 -0
- package/docs/explanation/party-mode.md +59 -0
- package/docs/explanation/preventing-agent-conflicts.md +112 -0
- package/docs/explanation/project-context.md +157 -0
- package/docs/explanation/quick-flow.md +73 -0
- package/docs/explanation/why-solutioning-matters.md +77 -0
- package/docs/how-to/customize-bmad.md +172 -0
- package/docs/how-to/established-projects.md +117 -0
- package/docs/how-to/get-answers-about-bmad.md +134 -0
- package/docs/how-to/install-bmad.md +97 -0
- package/docs/how-to/non-interactive-installation.md +171 -0
- package/docs/how-to/project-context.md +136 -0
- package/docs/how-to/quick-fixes.md +123 -0
- package/docs/how-to/shard-large-documents.md +78 -0
- package/docs/how-to/upgrade-to-v6.md +97 -0
- package/docs/index.md +59 -0
- package/docs/reference/agents.md +28 -0
- package/docs/reference/commands.md +151 -0
- package/docs/reference/modules.md +76 -0
- package/docs/reference/testing.md +106 -0
- package/docs/reference/workflow-map.md +89 -0
- package/docs/roadmap.mdx +136 -0
- package/docs/tutorials/getting-started.md +286 -0
- package/eslint.config.mjs +141 -0
- package/package.json +106 -37
- package/prettier.config.mjs +32 -0
- package/prompts/cis/brainstorming-coach.yaml +53 -0
- package/prompts/cis/creative-problem-solver.yaml +74 -0
- package/prompts/cis/design-thinking-coach.yaml +77 -0
- package/prompts/cis/innovation-strategist.yaml +70 -0
- package/prompts/cis/presentation-master.yaml +62 -0
- package/prompts/cis/storyteller.yaml +99 -0
- package/prompts/core/mdan-master.yaml +105 -0
- package/prompts/mmb/agent-builder.yaml +48 -0
- package/prompts/mmb/module-builder.yaml +50 -0
- package/prompts/mmb/workflow-builder.yaml +52 -0
- package/prompts/mmm/analyst.yaml +62 -0
- package/prompts/mmm/architect.yaml +66 -0
- package/prompts/mmm/dev.yaml +62 -0
- package/prompts/mmm/pm.yaml +64 -0
- package/prompts/mmm/qa.yaml +67 -0
- package/prompts/mmm/quick-flow-solo-dev.yaml +60 -0
- package/prompts/mmm/sm.yaml +61 -0
- package/prompts/mmm/tech-writer.yaml +70 -0
- package/prompts/mmm/ux-designer.yaml +33 -0
- package/prompts/packs/db-optimization/db-performance-analyst.yaml +63 -0
- package/prompts/packs/db-optimization/indexing-specialist.yaml +92 -0
- package/prompts/packs/db-optimization/query-optimizer.yaml +74 -0
- package/prompts/packs/devops-azure/azure-specialist.yaml +301 -0
- package/prompts/packs/devops-azure/cicd-architect.yaml +409 -0
- package/prompts/packs/devops-azure/devops-engineer.yaml +263 -0
- package/prompts/packs/fintech/compliance-officer.yaml +135 -0
- package/prompts/packs/fintech/financial-analyst.yaml +143 -0
- package/prompts/packs/fintech/risk-manager.yaml +240 -0
- package/prompts/tea/tea.yaml +100 -0
- package/prompts.json +237 -0
- package/src/bmm/agents/analyst.agent.yaml +43 -0
- package/src/bmm/agents/architect.agent.yaml +29 -0
- package/src/bmm/agents/dev.agent.yaml +38 -0
- package/src/bmm/agents/pm.agent.yaml +44 -0
- package/src/bmm/agents/qa.agent.yaml +58 -0
- package/src/bmm/agents/quick-flow-solo-dev.agent.yaml +32 -0
- package/src/bmm/agents/sm.agent.yaml +37 -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 +46 -0
- package/src/bmm/agents/ux-designer.agent.yaml +27 -0
- package/src/bmm/data/project-context-template.md +26 -0
- package/src/bmm/module-help.csv +31 -0
- package/src/bmm/module.yaml +50 -0
- package/src/bmm/teams/default-party.csv +20 -0
- package/src/bmm/teams/team-fullstack.yaml +12 -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 +57 -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 +444 -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-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 +476 -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 +233 -0
- package/src/bmm/workflows/1-analysis/research/technical-steps/step-06-research-synthesis.md +487 -0
- package/src/bmm/workflows/1-analysis/research/workflow-domain-research.md +54 -0
- package/src/bmm/workflows/1-analysis/research/workflow-market-research.md +54 -0
- package/src/bmm/workflows/1-analysis/research/workflow-technical-research.md +54 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/data/domain-complexity.csv +15 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/data/prd-purpose.md +197 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/data/project-types.csv +11 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01-init.md +191 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01b-continue.md +152 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-02-discovery.md +224 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-02b-vision.md +154 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-02c-executive-summary.md +170 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-03-success.md +226 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-04-journeys.md +213 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-05-domain.md +207 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-06-innovation.md +226 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-07-project-type.md +237 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-08-scoping.md +228 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-09-functional.md +231 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-10-nonfunctional.md +242 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-11-polish.md +217 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-12-complete.md +124 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01-discovery.md +247 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01b-legacy-conversion.md +208 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-02-review.md +249 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-03-edit.md +253 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-04-complete.md +168 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-01-discovery.md +226 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02-format-detection.md +191 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02b-parity-check.md +209 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-03-density-validation.md +174 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-04-brief-coverage-validation.md +214 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-05-measurability-validation.md +228 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-06-traceability-validation.md +217 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-07-implementation-leakage-validation.md +205 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-08-domain-compliance-validation.md +243 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-09-project-type-validation.md +263 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-10-smart-validation.md +209 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-11-holistic-quality-validation.md +264 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-12-completeness-validation.md +242 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +231 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/templates/prd-template.md +10 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/workflow-create-prd.md +63 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/workflow-edit-prd.md +65 -0
- package/src/bmm/workflows/2-plan-workflows/create-prd/workflow-validate-prd.md +63 -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 +42 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-01-document-discovery.md +184 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-02-prd-analysis.md +172 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-03-epic-coverage-validation.md +173 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-04-ux-alignment.md +133 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-05-epic-quality-review.md +245 -0
- package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +129 -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 +54 -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 +13 -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 +173 -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 +329 -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 +49 -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 +58 -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 +43 -0
- package/src/bmm/workflows/4-implementation/correct-course/checklist.md +288 -0
- package/src/bmm/workflows/4-implementation/correct-course/instructions.md +207 -0
- package/src/bmm/workflows/4-implementation/correct-course/workflow.yaml +53 -0
- package/src/bmm/workflows/4-implementation/create-story/checklist.md +358 -0
- package/src/bmm/workflows/4-implementation/create-story/instructions.xml +346 -0
- package/src/bmm/workflows/4-implementation/create-story/template.md +49 -0
- package/src/bmm/workflows/4-implementation/create-story/workflow.yaml +52 -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 +20 -0
- package/src/bmm/workflows/4-implementation/retrospective/instructions.md +1444 -0
- package/src/bmm/workflows/4-implementation/retrospective/workflow.yaml +52 -0
- package/src/bmm/workflows/4-implementation/sprint-planning/checklist.md +33 -0
- package/src/bmm/workflows/4-implementation/sprint-planning/instructions.md +226 -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 +47 -0
- package/src/bmm/workflows/4-implementation/sprint-status/instructions.md +230 -0
- package/src/bmm/workflows/4-implementation/sprint-status/workflow.yaml +25 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-01-mode-detection.md +174 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-02-context-gathering.md +118 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-03-execute.md +111 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-04-self-check.md +111 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-05-adversarial-review.md +104 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-06-resolve-findings.md +146 -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 +143 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-03-generate.md +126 -0
- package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-04-review.md +200 -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 +130 -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 +22 -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/generate-project-context/project-context-template.md +21 -0
- package/src/bmm/workflows/generate-project-context/steps/step-01-discover.md +184 -0
- package/src/bmm/workflows/generate-project-context/steps/step-02-generate.md +318 -0
- package/src/bmm/workflows/generate-project-context/steps/step-03-complete.md +278 -0
- package/src/bmm/workflows/generate-project-context/workflow.md +49 -0
- package/src/bmm/workflows/qa-generate-e2e-tests/checklist.md +33 -0
- package/src/bmm/workflows/qa-generate-e2e-tests/instructions.md +110 -0
- package/src/bmm/workflows/qa-generate-e2e-tests/workflow.yaml +42 -0
- package/src/core/agents/bmad-master.agent.yaml +30 -0
- package/src/core/module-help.csv +9 -0
- package/src/core/module.yaml +25 -0
- package/src/core/tasks/editorial-review-prose.xml +102 -0
- package/src/core/tasks/editorial-review-structure.xml +208 -0
- package/src/core/tasks/help.md +86 -0
- package/src/core/tasks/index-docs.xml +65 -0
- package/src/core/tasks/review-adversarial-general.xml +49 -0
- package/src/core/tasks/shard-doc.xml +108 -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 +118 -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 +168 -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/fixtures/file-refs-csv/invalid/all-empty-workflow.csv +3 -0
- package/test/fixtures/file-refs-csv/invalid/empty-data.csv +1 -0
- package/test/fixtures/file-refs-csv/invalid/no-workflow-column.csv +3 -0
- package/test/fixtures/file-refs-csv/invalid/unresolvable-vars.csv +3 -0
- package/test/fixtures/file-refs-csv/valid/bmm-style.csv +3 -0
- package/test/fixtures/file-refs-csv/valid/core-style.csv +3 -0
- package/test/fixtures/file-refs-csv/valid/minimal.csv +2 -0
- package/test/test-agent-schema.js +387 -0
- package/test/test-cli-integration.sh +159 -0
- package/test/test-file-refs-csv.js +133 -0
- package/test/test-installation-components.js +212 -0
- package/test/test-rehype-plugins.mjs +1050 -0
- package/test/unit-test-schema.js +133 -0
- package/tests/run_all_tests.py +80 -0
- package/tests/scenarios/cis/brainstorming-coach.test.py +150 -0
- package/tests/scenarios/cis/creative-problem-solver.test.py +167 -0
- package/tests/scenarios/cis/design-thinking-coach.test.py +177 -0
- package/tests/scenarios/cis/innovation-strategist.test.py +191 -0
- package/tests/scenarios/cis/presentation-master.test.py +240 -0
- package/tests/scenarios/cis/storyteller.test.py +324 -0
- package/tests/scenarios/core/mdan-master.test.py +281 -0
- package/tests/scenarios/mmb/agent-builder.test.py +124 -0
- package/tests/scenarios/mmb/module-builder.test.py +124 -0
- package/tests/scenarios/mmb/workflow-builder.test.py +124 -0
- package/tests/scenarios/mmm/analyst.test.py +138 -0
- package/tests/scenarios/mmm/architect.test.py +138 -0
- package/tests/scenarios/mmm/dev.test.py +138 -0
- package/tests/scenarios/mmm/pm.test.py +138 -0
- package/tests/scenarios/mmm/qa.test.py +138 -0
- package/tests/scenarios/mmm/quick-flow-solo-dev.test.py +138 -0
- package/tests/scenarios/mmm/sm.test.py +138 -0
- package/tests/scenarios/mmm/tech-writer.test.py +138 -0
- package/tests/scenarios/mmm/ux-designer.test.py +294 -0
- package/tests/scenarios/packs/db-optimization/db-performance-analyst.test.py +108 -0
- package/tests/scenarios/packs/db-optimization/indexing-specialist.test.py +108 -0
- package/tests/scenarios/packs/db-optimization/query-optimizer.test.py +106 -0
- package/tests/scenarios/packs/devops-azure/azure-specialist.test.py +125 -0
- package/tests/scenarios/packs/devops-azure/cicd-architect.test.py +122 -0
- package/tests/scenarios/packs/devops-azure/devops-engineer.test.py +128 -0
- package/tests/scenarios/packs/fintech/compliance-officer.test.py +165 -0
- package/tests/scenarios/packs/fintech/financial-analyst.test.py +184 -0
- package/tests/scenarios/packs/fintech/risk-manager.test.py +171 -0
- package/tests/scenarios/tea/tea.test.py +346 -0
- package/tests/simple_cis_test.py +285 -0
- package/tests/simple_db_optimization_test.py +199 -0
- package/tests/simple_devops_test.py +193 -0
- package/tests/simple_fintech_test.py +205 -0
- package/tests/simple_mmb_test.py +103 -0
- package/tests/simple_mmm_test.py +159 -0
- package/tests/simple_tea_test.py +80 -0
- package/tests/simple_test.py +111 -0
- package/tests/simple_ux_designer_test.py +144 -0
- package/tests/validate_yaml.py +86 -0
- package/tools/bmad-npx-wrapper.js +38 -0
- package/tools/build-docs.mjs +463 -0
- package/tools/cli/README.md +60 -0
- package/tools/cli/bmad-cli.js +106 -0
- package/tools/cli/commands/install.js +87 -0
- package/tools/cli/commands/status.js +65 -0
- package/tools/cli/commands/uninstall.js +167 -0
- package/tools/cli/external-official-modules.yaml +53 -0
- package/tools/cli/installers/install-messages.yaml +39 -0
- package/tools/cli/installers/lib/core/config-collector.js +1285 -0
- package/tools/cli/installers/lib/core/custom-module-cache.js +260 -0
- package/tools/cli/installers/lib/core/dependency-resolver.js +743 -0
- package/tools/cli/installers/lib/core/detector.js +223 -0
- package/tools/cli/installers/lib/core/ide-config-manager.js +157 -0
- package/tools/cli/installers/lib/core/installer.js +3162 -0
- package/tools/cli/installers/lib/core/manifest-generator.js +1081 -0
- package/tools/cli/installers/lib/core/manifest.js +1038 -0
- package/tools/cli/installers/lib/custom/handler.js +358 -0
- package/tools/cli/installers/lib/ide/_base-ide.js +665 -0
- package/tools/cli/installers/lib/ide/_config-driven.js +634 -0
- package/tools/cli/installers/lib/ide/codex.js +440 -0
- package/tools/cli/installers/lib/ide/github-copilot.js +699 -0
- package/tools/cli/installers/lib/ide/kilo.js +269 -0
- package/tools/cli/installers/lib/ide/manager.js +342 -0
- package/tools/cli/installers/lib/ide/platform-codes.js +100 -0
- package/tools/cli/installers/lib/ide/platform-codes.yaml +243 -0
- package/tools/cli/installers/lib/ide/rovodev.js +257 -0
- package/tools/cli/installers/lib/ide/shared/agent-command-generator.js +180 -0
- package/tools/cli/installers/lib/ide/shared/bmad-artifacts.js +174 -0
- package/tools/cli/installers/lib/ide/shared/module-injections.js +136 -0
- package/tools/cli/installers/lib/ide/shared/path-utils.js +299 -0
- package/tools/cli/installers/lib/ide/shared/task-tool-command-generator.js +366 -0
- package/tools/cli/installers/lib/ide/shared/workflow-command-generator.js +318 -0
- package/tools/cli/installers/lib/ide/templates/agent-command-template.md +14 -0
- package/tools/cli/installers/lib/ide/templates/combined/antigravity.md +8 -0
- package/tools/cli/installers/lib/ide/templates/combined/default-agent.md +15 -0
- package/tools/cli/installers/lib/ide/templates/combined/default-task.md +10 -0
- package/tools/cli/installers/lib/ide/templates/combined/default-tool.md +10 -0
- package/tools/cli/installers/lib/ide/templates/combined/default-workflow-yaml.md +14 -0
- package/tools/cli/installers/lib/ide/templates/combined/default-workflow.md +6 -0
- package/tools/cli/installers/lib/ide/templates/combined/gemini-agent.toml +14 -0
- package/tools/cli/installers/lib/ide/templates/combined/gemini-task.toml +11 -0
- package/tools/cli/installers/lib/ide/templates/combined/gemini-tool.toml +11 -0
- package/tools/cli/installers/lib/ide/templates/combined/gemini-workflow-yaml.toml +16 -0
- package/tools/cli/installers/lib/ide/templates/combined/gemini-workflow.toml +14 -0
- package/tools/cli/installers/lib/ide/templates/combined/kiro-agent.md +16 -0
- package/tools/cli/installers/lib/ide/templates/combined/kiro-task.md +9 -0
- package/tools/cli/installers/lib/ide/templates/combined/kiro-tool.md +9 -0
- package/tools/cli/installers/lib/ide/templates/combined/kiro-workflow-yaml.md +15 -0
- package/tools/cli/installers/lib/ide/templates/combined/kiro-workflow.md +7 -0
- package/tools/cli/installers/lib/ide/templates/combined/opencode-agent.md +15 -0
- package/tools/cli/installers/lib/ide/templates/combined/opencode-task.md +13 -0
- package/tools/cli/installers/lib/ide/templates/combined/opencode-tool.md +13 -0
- package/tools/cli/installers/lib/ide/templates/combined/opencode-workflow-yaml.md +16 -0
- package/tools/cli/installers/lib/ide/templates/combined/opencode-workflow.md +16 -0
- package/tools/cli/installers/lib/ide/templates/combined/rovodev.md +9 -0
- package/tools/cli/installers/lib/ide/templates/combined/trae.md +9 -0
- package/tools/cli/installers/lib/ide/templates/combined/windsurf-workflow.md +10 -0
- package/tools/cli/installers/lib/ide/templates/split/.gitkeep +0 -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/message-loader.js +83 -0
- package/tools/cli/installers/lib/modules/external-manager.js +136 -0
- package/tools/cli/installers/lib/modules/manager.js +1498 -0
- package/tools/cli/lib/activation-builder.js +165 -0
- package/tools/cli/lib/agent/compiler.js +525 -0
- package/tools/cli/lib/agent/installer.js +680 -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 +182 -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 +809 -0
- package/tools/cli/lib/ui.js +1936 -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/_prompt-external-modules-page.md +59 -0
- package/tools/docs/fix-refs.md +91 -0
- package/tools/fix-doc-links.js +285 -0
- package/tools/format-workflow-md.js +263 -0
- package/tools/lib/xml-utils.js +13 -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 +407 -0
- package/tools/validate-file-refs.js +554 -0
- package/tools/validate-svg-changes.sh +356 -0
- package/website/README.md +75 -0
- package/website/astro.config.mjs +136 -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/workflow-map-diagram.html +361 -0
- package/website/src/components/Banner.astro +62 -0
- package/website/src/components/Header.astro +96 -0
- package/website/src/components/MobileMenuFooter.astro +33 -0
- package/website/src/content/config.ts +6 -0
- package/website/src/lib/site-url.mjs +25 -0
- package/website/src/pages/404.astro +11 -0
- package/website/src/pages/robots.txt.ts +48 -0
- package/website/src/rehype-base-paths.js +112 -0
- package/website/src/rehype-markdown-links.js +119 -0
- package/website/src/styles/custom.css +805 -0
- package/.mcp.json +0 -46
- package/agents/AGENTS-REGISTRY.md +0 -215
- package/agents/architect.md +0 -160
- package/agents/dev.md +0 -166
- package/agents/devops.md +0 -230
- package/agents/doc.md +0 -189
- package/agents/learn.md +0 -377
- package/agents/product.md +0 -124
- package/agents/security.md +0 -168
- package/agents/test.md +0 -209
- package/agents/ux.md +0 -207
- package/cli/mdan.js +0 -628
- package/cli/mdan.py +0 -316
- package/cli/mdan.sh +0 -724
- package/cli/postinstall.js +0 -4
- package/core/orchestrator.md +0 -238
- package/core/universal-envelope.md +0 -160
- package/install.sh +0 -91
- package/integrations/all-integrations.md +0 -300
- package/integrations/claude.md +0 -46
- package/integrations/cursor.md +0 -74
- package/integrations/mcp.md +0 -153
- package/integrations/windsurf.md +0 -48
- package/memory/MDAN-STATE.template.json +0 -44
- package/memory/MEMORY-SYSTEM.md +0 -197
- package/phases/01-discover.md +0 -136
- package/phases/02-design.md +0 -147
- package/phases/03-build.md +0 -113
- package/phases/04-verify.md +0 -107
- package/phases/05-ship.md +0 -156
- package/skills/find-skills/skill.md +0 -133
- package/templates/ARCHITECTURE.md +0 -186
- package/templates/CHANGELOG.md +0 -41
- package/templates/MDAN-KNOWLEDGE.md +0 -73
- package/templates/PRD.md +0 -120
- package/templates/SECURITY-REVIEW.md +0 -99
- package/templates/TEST-PLAN.md +0 -97
- package/templates/prompts/README.md +0 -108
- package/templates/prompts/dev-agent.yaml +0 -85
- package/templates/prompts/orchestrator.yaml +0 -97
- package/templates/prompts.json +0 -81
- package/templates/tests/evaluations/README.md +0 -80
- package/templates/tests/evaluations/classification_eval.md +0 -136
- package/templates/tests/evaluations/rag_eval.md +0 -116
- package/templates/tests/scenarios/README.md +0 -62
- package/templates/tests/scenarios/basic_authentication.test.md +0 -82
- package/templates/tests/scenarios/user_registration.test.md +0 -107
|
@@ -0,0 +1,463 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BMAD Documentation Build Pipeline
|
|
3
|
+
*
|
|
4
|
+
* Consolidates docs from multiple sources, generates LLM-friendly files,
|
|
5
|
+
* and builds the Astro+Starlight site.
|
|
6
|
+
*
|
|
7
|
+
* Build outputs:
|
|
8
|
+
* build/artifacts/ - With llms.txt, llms-full.txt
|
|
9
|
+
* build/site/ - Final Astro output (deployable)
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import { execSync } from 'node:child_process';
|
|
13
|
+
import fs from 'node:fs';
|
|
14
|
+
import path from 'node:path';
|
|
15
|
+
import { fileURLToPath } from 'node:url';
|
|
16
|
+
import { getSiteUrl } from '../website/src/lib/site-url.mjs';
|
|
17
|
+
|
|
18
|
+
// =============================================================================
|
|
19
|
+
// Configuration
|
|
20
|
+
// =============================================================================
|
|
21
|
+
|
|
22
|
+
const PROJECT_ROOT = path.dirname(path.dirname(fileURLToPath(import.meta.url)));
|
|
23
|
+
const BUILD_DIR = path.join(PROJECT_ROOT, 'build');
|
|
24
|
+
|
|
25
|
+
const REPO_URL = 'https://github.com/bmad-code-org/BMAD-METHOD';
|
|
26
|
+
|
|
27
|
+
// DO NOT CHANGE THESE VALUES!
|
|
28
|
+
// llms-full.txt is consumed by AI agents as context. Most LLMs have ~200k token limits.
|
|
29
|
+
// 600k chars ≈ 150k tokens (safe margin). Exceeding this breaks AI agent functionality.
|
|
30
|
+
const LLM_MAX_CHARS = 600_000;
|
|
31
|
+
const LLM_WARN_CHARS = 500_000;
|
|
32
|
+
|
|
33
|
+
const LLM_EXCLUDE_PATTERNS = [
|
|
34
|
+
'changelog',
|
|
35
|
+
'ide-info/',
|
|
36
|
+
'v4-to-v6-upgrade',
|
|
37
|
+
'faq',
|
|
38
|
+
'reference/glossary/',
|
|
39
|
+
'explanation/game-dev/',
|
|
40
|
+
'bmgd/',
|
|
41
|
+
// Note: Files/dirs starting with _ (like _STYLE_GUIDE.md, _archive/) are excluded in shouldExcludeFromLlm()
|
|
42
|
+
];
|
|
43
|
+
|
|
44
|
+
// =============================================================================
|
|
45
|
+
// Main Entry Point
|
|
46
|
+
/**
|
|
47
|
+
* Orchestrates the full BMAD documentation build pipeline.
|
|
48
|
+
*
|
|
49
|
+
* Executes the high-level build steps in sequence: prints headers and paths, validates internal
|
|
50
|
+
* documentation links, cleans the build directory, generates artifacts from the `docs/` folder,
|
|
51
|
+
* builds the Astro site, and prints a final build summary.
|
|
52
|
+
*/
|
|
53
|
+
|
|
54
|
+
async function main() {
|
|
55
|
+
if (process.platform === 'win32') {
|
|
56
|
+
console.error('Error: The docs build pipeline does not support Windows.');
|
|
57
|
+
console.error('Please build on Linux, macOS, or WSL.');
|
|
58
|
+
process.exit(1);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
console.log();
|
|
62
|
+
printBanner('BMAD Documentation Build Pipeline');
|
|
63
|
+
console.log();
|
|
64
|
+
console.log(`Project root: ${PROJECT_ROOT}`);
|
|
65
|
+
console.log(`Build directory: ${BUILD_DIR}`);
|
|
66
|
+
console.log();
|
|
67
|
+
|
|
68
|
+
// Check for broken internal links before building
|
|
69
|
+
checkDocLinks();
|
|
70
|
+
|
|
71
|
+
cleanBuildDirectory();
|
|
72
|
+
|
|
73
|
+
const docsDir = path.join(PROJECT_ROOT, 'docs');
|
|
74
|
+
const artifactsDir = await generateArtifacts(docsDir);
|
|
75
|
+
const siteDir = buildAstroSite();
|
|
76
|
+
|
|
77
|
+
printBuildSummary(docsDir, artifactsDir, siteDir);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
main().catch((error) => {
|
|
81
|
+
console.error(error);
|
|
82
|
+
process.exit(1);
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
// =============================================================================
|
|
86
|
+
// Pipeline Stages
|
|
87
|
+
/**
|
|
88
|
+
* Generate LLM files for the documentation pipeline.
|
|
89
|
+
*
|
|
90
|
+
* Creates the build/artifacts directory and writes `llms.txt` and `llms-full.txt` (sourced from the provided docs directory).
|
|
91
|
+
*
|
|
92
|
+
* @param {string} docsDir - Path to the source docs directory containing Markdown files.
|
|
93
|
+
* @returns {string} Path to the created artifacts directory.
|
|
94
|
+
*/
|
|
95
|
+
|
|
96
|
+
async function generateArtifacts(docsDir) {
|
|
97
|
+
printHeader('Generating LLM files');
|
|
98
|
+
|
|
99
|
+
const outputDir = path.join(BUILD_DIR, 'artifacts');
|
|
100
|
+
fs.mkdirSync(outputDir, { recursive: true });
|
|
101
|
+
|
|
102
|
+
// Generate LLM files reading from docs/, output to artifacts/
|
|
103
|
+
generateLlmsTxt(outputDir);
|
|
104
|
+
generateLlmsFullTxt(docsDir, outputDir);
|
|
105
|
+
|
|
106
|
+
console.log();
|
|
107
|
+
console.log(` \u001B[32m✓\u001B[0m Artifact generation complete`);
|
|
108
|
+
|
|
109
|
+
return outputDir;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
/**
|
|
113
|
+
* Builds the Astro + Starlight site and copies generated artifacts into the site output directory.
|
|
114
|
+
*
|
|
115
|
+
* @returns {string} The filesystem path to the built site directory (e.g., build/site).
|
|
116
|
+
*/
|
|
117
|
+
function buildAstroSite() {
|
|
118
|
+
printHeader('Building Astro + Starlight site');
|
|
119
|
+
|
|
120
|
+
const siteDir = path.join(BUILD_DIR, 'site');
|
|
121
|
+
const artifactsDir = path.join(BUILD_DIR, 'artifacts');
|
|
122
|
+
|
|
123
|
+
// Build Astro site (outputs to build/site via astro.config.mjs)
|
|
124
|
+
runAstroBuild();
|
|
125
|
+
copyArtifactsToSite(artifactsDir, siteDir);
|
|
126
|
+
|
|
127
|
+
console.log();
|
|
128
|
+
console.log(` \u001B[32m✓\u001B[0m Astro build complete`);
|
|
129
|
+
|
|
130
|
+
return siteDir;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
// =============================================================================
|
|
134
|
+
// LLM File Generation
|
|
135
|
+
/**
|
|
136
|
+
* Create a concise llms.txt summary file containing project metadata, core links, and quick navigation entries for LLM consumption.
|
|
137
|
+
*
|
|
138
|
+
* Writes the file to `${outputDir}/llms.txt`.
|
|
139
|
+
*
|
|
140
|
+
* @param {string} outputDir - Destination directory where `llms.txt` will be written.
|
|
141
|
+
*/
|
|
142
|
+
|
|
143
|
+
function generateLlmsTxt(outputDir) {
|
|
144
|
+
console.log(' → Generating llms.txt...');
|
|
145
|
+
|
|
146
|
+
const siteUrl = getSiteUrl();
|
|
147
|
+
const content = [
|
|
148
|
+
'# BMAD Method Documentation',
|
|
149
|
+
'',
|
|
150
|
+
'> AI-driven agile development with specialized agents and workflows that scale from bug fixes to enterprise platforms.',
|
|
151
|
+
'',
|
|
152
|
+
`Documentation: ${siteUrl}`,
|
|
153
|
+
`Repository: ${REPO_URL}`,
|
|
154
|
+
`Full docs: ${siteUrl}/llms-full.txt`,
|
|
155
|
+
'',
|
|
156
|
+
'## Quick Start',
|
|
157
|
+
'',
|
|
158
|
+
`- **[Getting Started](${siteUrl}/tutorials/getting-started/)** - Tutorial: install and learn how BMad works`,
|
|
159
|
+
`- **[Installation](${siteUrl}/how-to/install-bmad/)** - How to install BMad Method`,
|
|
160
|
+
'',
|
|
161
|
+
'## Core Concepts',
|
|
162
|
+
'',
|
|
163
|
+
`- **[Quick Flow](${siteUrl}/explanation/quick-flow/)** - Fast development workflow`,
|
|
164
|
+
`- **[Party Mode](${siteUrl}/explanation/party-mode/)** - Multi-agent collaboration`,
|
|
165
|
+
`- **[Workflow Map](${siteUrl}/reference/workflow-map/)** - Visual overview of phases and workflows`,
|
|
166
|
+
'',
|
|
167
|
+
'## Modules',
|
|
168
|
+
'',
|
|
169
|
+
`- **[Official Modules](${siteUrl}/reference/modules/)** - BMM, BMB, BMGD, and more`,
|
|
170
|
+
'',
|
|
171
|
+
'---',
|
|
172
|
+
'',
|
|
173
|
+
'## Quick Links',
|
|
174
|
+
'',
|
|
175
|
+
`- [Full Documentation (llms-full.txt)](${siteUrl}/llms-full.txt) - Complete docs for AI context`,
|
|
176
|
+
'',
|
|
177
|
+
].join('\n');
|
|
178
|
+
|
|
179
|
+
const outputPath = path.join(outputDir, 'llms.txt');
|
|
180
|
+
fs.writeFileSync(outputPath, content, 'utf-8');
|
|
181
|
+
console.log(` Generated llms.txt (${content.length.toLocaleString()} chars)`);
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
/**
|
|
185
|
+
* Builds a consolidated llms-full.txt containing all Markdown files under docsDir wrapped in <document path="..."> tags for LLM consumption.
|
|
186
|
+
*
|
|
187
|
+
* Writes the generated file to outputDir/llms-full.txt. Files matching LLM_EXCLUDE_PATTERNS are skipped; read errors for individual files are logged. The combined content is validated against configured size thresholds (will exit on overflow and warn if near limit).
|
|
188
|
+
* @param {string} docsDir - Root directory containing source Markdown files; paths in the output are relative to this directory.
|
|
189
|
+
* @param {string} outputDir - Directory where llms-full.txt will be written.
|
|
190
|
+
*/
|
|
191
|
+
function generateLlmsFullTxt(docsDir, outputDir) {
|
|
192
|
+
console.log(' → Generating llms-full.txt...');
|
|
193
|
+
|
|
194
|
+
const date = new Date().toISOString().split('T')[0];
|
|
195
|
+
const files = getAllMarkdownFiles(docsDir).sort(compareLlmDocs);
|
|
196
|
+
|
|
197
|
+
const output = [
|
|
198
|
+
'# BMAD Method Documentation (Full)',
|
|
199
|
+
'',
|
|
200
|
+
'> Complete documentation for AI consumption',
|
|
201
|
+
`> Generated: ${date}`,
|
|
202
|
+
`> Repository: ${REPO_URL}`,
|
|
203
|
+
'',
|
|
204
|
+
];
|
|
205
|
+
|
|
206
|
+
let fileCount = 0;
|
|
207
|
+
let skippedCount = 0;
|
|
208
|
+
|
|
209
|
+
for (const mdPath of files) {
|
|
210
|
+
if (shouldExcludeFromLlm(mdPath)) {
|
|
211
|
+
skippedCount++;
|
|
212
|
+
continue;
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
const fullPath = path.join(docsDir, mdPath);
|
|
216
|
+
try {
|
|
217
|
+
const content = readMarkdownContent(fullPath);
|
|
218
|
+
output.push(`<document path="${mdPath}">`, content, '</document>', '');
|
|
219
|
+
fileCount++;
|
|
220
|
+
} catch (error) {
|
|
221
|
+
console.error(` Warning: Could not read ${mdPath}: ${error.message}`);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
const result = output.join('\n');
|
|
226
|
+
validateLlmSize(result);
|
|
227
|
+
|
|
228
|
+
const outputPath = path.join(outputDir, 'llms-full.txt');
|
|
229
|
+
fs.writeFileSync(outputPath, result, 'utf-8');
|
|
230
|
+
|
|
231
|
+
const tokenEstimate = Math.floor(result.length / 4).toLocaleString();
|
|
232
|
+
console.log(
|
|
233
|
+
` Processed ${fileCount} files (skipped ${skippedCount}), ${result.length.toLocaleString()} chars (~${tokenEstimate} tokens)`,
|
|
234
|
+
);
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
function compareLlmDocs(a, b) {
|
|
238
|
+
const aKey = getLlmSortKey(a);
|
|
239
|
+
const bKey = getLlmSortKey(b);
|
|
240
|
+
|
|
241
|
+
if (aKey !== bKey) return aKey - bKey;
|
|
242
|
+
return a.localeCompare(b);
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
function getLlmSortKey(filePath) {
|
|
246
|
+
if (filePath === 'index.md') return 0;
|
|
247
|
+
if (filePath.startsWith(`tutorials${path.sep}`) || filePath.startsWith('tutorials/')) return 2;
|
|
248
|
+
if (filePath.startsWith(`how-to${path.sep}`) || filePath.startsWith('how-to/')) return 3;
|
|
249
|
+
if (filePath.startsWith(`explanation${path.sep}`) || filePath.startsWith('explanation/')) return 4;
|
|
250
|
+
if (filePath.startsWith(`reference${path.sep}`) || filePath.startsWith('reference/')) return 5;
|
|
251
|
+
if (filePath.startsWith(`bmgd${path.sep}`) || filePath.startsWith('bmgd/')) return 6;
|
|
252
|
+
return 7;
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
/**
|
|
256
|
+
* Collects all Markdown (.md) files under a directory and returns their paths relative to a base directory.
|
|
257
|
+
* @param {string} dir - Directory to search for Markdown files.
|
|
258
|
+
* @param {string} [baseDir=dir] - Base directory used to compute returned relative paths.
|
|
259
|
+
* @returns {string[]} An array of file paths (relative to `baseDir`) for every `.md` file found under `dir`.
|
|
260
|
+
*/
|
|
261
|
+
function getAllMarkdownFiles(dir, baseDir = dir) {
|
|
262
|
+
const files = [];
|
|
263
|
+
|
|
264
|
+
for (const entry of fs.readdirSync(dir, { withFileTypes: true })) {
|
|
265
|
+
const fullPath = path.join(dir, entry.name);
|
|
266
|
+
|
|
267
|
+
if (entry.isDirectory()) {
|
|
268
|
+
files.push(...getAllMarkdownFiles(fullPath, baseDir));
|
|
269
|
+
} else if (entry.name.endsWith('.md')) {
|
|
270
|
+
// Return relative path from baseDir
|
|
271
|
+
const relativePath = path.relative(baseDir, fullPath);
|
|
272
|
+
files.push(relativePath);
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
return files;
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
/**
|
|
280
|
+
* Determine whether a file path matches any configured LLM exclusion pattern.
|
|
281
|
+
* Also excludes any files or directories starting with underscore.
|
|
282
|
+
* @param {string} filePath - The file path to test.
|
|
283
|
+
* @returns {boolean} `true` if excluded, `false` otherwise.
|
|
284
|
+
*/
|
|
285
|
+
function shouldExcludeFromLlm(filePath) {
|
|
286
|
+
// Exclude if ANY path component starts with underscore
|
|
287
|
+
// (e.g., _STYLE_GUIDE.md, _archive/file.md, dir/_STYLE_GUIDE.md)
|
|
288
|
+
const pathParts = filePath.split(path.sep);
|
|
289
|
+
if (pathParts.some((part) => part.startsWith('_'))) return true;
|
|
290
|
+
|
|
291
|
+
// Check configured patterns
|
|
292
|
+
return LLM_EXCLUDE_PATTERNS.some((pattern) => filePath.includes(pattern));
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
function readMarkdownContent(filePath) {
|
|
296
|
+
let content = fs.readFileSync(filePath, 'utf-8');
|
|
297
|
+
|
|
298
|
+
if (content.startsWith('---')) {
|
|
299
|
+
const end = content.indexOf('---', 3);
|
|
300
|
+
if (end !== -1) {
|
|
301
|
+
content = content.slice(end + 3).trim();
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
return content;
|
|
306
|
+
}
|
|
307
|
+
|
|
308
|
+
function validateLlmSize(content) {
|
|
309
|
+
const charCount = content.length;
|
|
310
|
+
|
|
311
|
+
if (charCount > LLM_MAX_CHARS) {
|
|
312
|
+
console.error(` ERROR: Exceeds ${LLM_MAX_CHARS.toLocaleString()} char limit`);
|
|
313
|
+
process.exit(1);
|
|
314
|
+
} else if (charCount > LLM_WARN_CHARS) {
|
|
315
|
+
console.warn(` \u001B[33mWARNING: Approaching ${LLM_WARN_CHARS.toLocaleString()} char limit\u001B[0m`);
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
// =============================================================================
|
|
320
|
+
// Astro Build
|
|
321
|
+
/**
|
|
322
|
+
* Builds the Astro site to build/site (configured in astro.config.mjs).
|
|
323
|
+
*/
|
|
324
|
+
function runAstroBuild() {
|
|
325
|
+
console.log(' → Running astro build...');
|
|
326
|
+
execSync('npx astro build --root website', {
|
|
327
|
+
cwd: PROJECT_ROOT,
|
|
328
|
+
stdio: 'inherit',
|
|
329
|
+
env: {
|
|
330
|
+
...process.env,
|
|
331
|
+
},
|
|
332
|
+
});
|
|
333
|
+
}
|
|
334
|
+
|
|
335
|
+
/**
|
|
336
|
+
* Copy generated artifact files into the built site directory.
|
|
337
|
+
*
|
|
338
|
+
* Copies llms.txt and llms-full.txt from the artifacts directory into the site directory.
|
|
339
|
+
*
|
|
340
|
+
* @param {string} artifactsDir - Path to the build artifacts directory containing generated files.
|
|
341
|
+
* @param {string} siteDir - Path to the target site directory where artifacts should be placed.
|
|
342
|
+
*/
|
|
343
|
+
function copyArtifactsToSite(artifactsDir, siteDir) {
|
|
344
|
+
console.log(' → Copying artifacts to site...');
|
|
345
|
+
|
|
346
|
+
fs.copyFileSync(path.join(artifactsDir, 'llms.txt'), path.join(siteDir, 'llms.txt'));
|
|
347
|
+
fs.copyFileSync(path.join(artifactsDir, 'llms-full.txt'), path.join(siteDir, 'llms-full.txt'));
|
|
348
|
+
}
|
|
349
|
+
|
|
350
|
+
// =============================================================================
|
|
351
|
+
// Build Summary
|
|
352
|
+
/**
|
|
353
|
+
* Prints a concise end-of-build summary and displays a sample listing of the final site directory.
|
|
354
|
+
*
|
|
355
|
+
* @param {string} docsDir - Path to the source documentation directory used for the build.
|
|
356
|
+
* @param {string} artifactsDir - Path to the directory containing generated artifacts (e.g., llms.txt).
|
|
357
|
+
* @param {string} siteDir - Path to the final built site directory whose contents will be listed.
|
|
358
|
+
*/
|
|
359
|
+
|
|
360
|
+
function printBuildSummary(docsDir, artifactsDir, siteDir) {
|
|
361
|
+
console.log();
|
|
362
|
+
printBanner('Build Complete!');
|
|
363
|
+
console.log();
|
|
364
|
+
console.log('Build artifacts:');
|
|
365
|
+
console.log(` Source docs: ${docsDir}`);
|
|
366
|
+
console.log(` Generated files: ${artifactsDir}`);
|
|
367
|
+
console.log(` Final site: ${siteDir}`);
|
|
368
|
+
console.log();
|
|
369
|
+
console.log(`Deployable output: ${siteDir}/`);
|
|
370
|
+
console.log();
|
|
371
|
+
|
|
372
|
+
listDirectoryContents(siteDir);
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
function listDirectoryContents(dir) {
|
|
376
|
+
const entries = fs.readdirSync(dir).slice(0, 15);
|
|
377
|
+
|
|
378
|
+
for (const entry of entries) {
|
|
379
|
+
const fullPath = path.join(dir, entry);
|
|
380
|
+
const stat = fs.statSync(fullPath);
|
|
381
|
+
|
|
382
|
+
if (stat.isFile()) {
|
|
383
|
+
const sizeStr = formatFileSize(stat.size);
|
|
384
|
+
console.log(` ${entry.padEnd(40)} ${sizeStr.padStart(8)}`);
|
|
385
|
+
} else {
|
|
386
|
+
console.log(` ${entry}/`);
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
|
|
391
|
+
/**
|
|
392
|
+
* Format a byte count into a compact human-readable string using B, K, or M units.
|
|
393
|
+
* @param {number} bytes - The number of bytes to format.
|
|
394
|
+
* @returns {string} The formatted size: bytes as `N B` (e.g. `512B`), kilobytes truncated to an integer with `K` (e.g. `2K`), or megabytes with one decimal and `M` (e.g. `1.2M`).
|
|
395
|
+
*/
|
|
396
|
+
function formatFileSize(bytes) {
|
|
397
|
+
if (bytes > 1024 * 1024) {
|
|
398
|
+
return `${(bytes / 1024 / 1024).toFixed(1)}M`;
|
|
399
|
+
} else if (bytes > 1024) {
|
|
400
|
+
return `${Math.floor(bytes / 1024)}K`;
|
|
401
|
+
}
|
|
402
|
+
return `${bytes}B`;
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
// =============================================================================
|
|
406
|
+
// File System Utilities
|
|
407
|
+
/**
|
|
408
|
+
* Remove any existing build output and recreate the build directory.
|
|
409
|
+
*
|
|
410
|
+
* Ensures the configured BUILD_DIR is empty by deleting it if present and then creating a fresh directory.
|
|
411
|
+
*/
|
|
412
|
+
|
|
413
|
+
function cleanBuildDirectory() {
|
|
414
|
+
console.log('Cleaning previous build...');
|
|
415
|
+
|
|
416
|
+
if (fs.existsSync(BUILD_DIR)) {
|
|
417
|
+
fs.rmSync(BUILD_DIR, { recursive: true });
|
|
418
|
+
}
|
|
419
|
+
fs.mkdirSync(BUILD_DIR, { recursive: true });
|
|
420
|
+
}
|
|
421
|
+
|
|
422
|
+
// =============================================================================
|
|
423
|
+
// Console Output Formatting
|
|
424
|
+
// =============================================================================
|
|
425
|
+
|
|
426
|
+
function printHeader(title) {
|
|
427
|
+
console.log();
|
|
428
|
+
console.log('┌' + '─'.repeat(62) + '┐');
|
|
429
|
+
console.log(`│ ${title.padEnd(60)} │`);
|
|
430
|
+
console.log('└' + '─'.repeat(62) + '┘');
|
|
431
|
+
}
|
|
432
|
+
|
|
433
|
+
/**
|
|
434
|
+
* Prints a centered decorative ASCII banner to the console using the provided title.
|
|
435
|
+
* @param {string} title - Text to display centered inside the banner. */
|
|
436
|
+
function printBanner(title) {
|
|
437
|
+
console.log('╔' + '═'.repeat(62) + '╗');
|
|
438
|
+
console.log(`║${title.padStart(31 + title.length / 2).padEnd(62)}║`);
|
|
439
|
+
console.log('╚' + '═'.repeat(62) + '╝');
|
|
440
|
+
}
|
|
441
|
+
|
|
442
|
+
// =============================================================================
|
|
443
|
+
// Link Checking
|
|
444
|
+
/**
|
|
445
|
+
* Verify internal documentation links by running the link-checking script.
|
|
446
|
+
*
|
|
447
|
+
* Executes the Node script tools/validate-doc-links.js from the project root and
|
|
448
|
+
* exits the process with code 1 if the check fails.
|
|
449
|
+
*/
|
|
450
|
+
|
|
451
|
+
function checkDocLinks() {
|
|
452
|
+
printHeader('Checking documentation links');
|
|
453
|
+
|
|
454
|
+
try {
|
|
455
|
+
execSync('node tools/validate-doc-links.js', {
|
|
456
|
+
cwd: PROJECT_ROOT,
|
|
457
|
+
stdio: 'inherit',
|
|
458
|
+
});
|
|
459
|
+
} catch {
|
|
460
|
+
console.error('\n \u001B[31m✗\u001B[0m Link check failed - fix broken links before building\n');
|
|
461
|
+
process.exit(1);
|
|
462
|
+
}
|
|
463
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
# BMad CLI Tool
|
|
2
|
+
|
|
3
|
+
## Installing external repo BMad official modules
|
|
4
|
+
|
|
5
|
+
For external official modules to be discoverable during install, ensure an entry for the external repo is added to external-official-modules.yaml.
|
|
6
|
+
|
|
7
|
+
For community modules - this will be handled in a different way. This file is only for registration of modules under the bmad-code-org.
|
|
8
|
+
|
|
9
|
+
## Post-Install Notes
|
|
10
|
+
|
|
11
|
+
Modules can display setup guidance to users after configuration is collected during `npx bmad-method install`. Notes are defined in the module's own `module.yaml` — no changes to the installer are needed.
|
|
12
|
+
|
|
13
|
+
### Simple Format
|
|
14
|
+
|
|
15
|
+
Always displayed after the module is configured:
|
|
16
|
+
|
|
17
|
+
```yaml
|
|
18
|
+
post-install-notes: |
|
|
19
|
+
Thank you for choosing the XYZ Cool Module
|
|
20
|
+
For Support about this Module call 555-1212
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
### Conditional Format
|
|
24
|
+
|
|
25
|
+
Display different messages based on a config question's answer:
|
|
26
|
+
|
|
27
|
+
```yaml
|
|
28
|
+
post-install-notes:
|
|
29
|
+
config_key_name:
|
|
30
|
+
value1: |
|
|
31
|
+
Instructions for value1...
|
|
32
|
+
value2: |
|
|
33
|
+
Instructions for value2...
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
Values without an entry (e.g., `none`) display nothing. Multiple config keys can each have their own conditional notes.
|
|
37
|
+
|
|
38
|
+
### Example: TEA Module
|
|
39
|
+
|
|
40
|
+
The TEA module uses the conditional format keyed on `tea_browser_automation`:
|
|
41
|
+
|
|
42
|
+
```yaml
|
|
43
|
+
post-install-notes:
|
|
44
|
+
tea_browser_automation:
|
|
45
|
+
cli: |
|
|
46
|
+
Playwright CLI Setup:
|
|
47
|
+
npm install -g @playwright/cli@latest
|
|
48
|
+
playwright-cli install --skills
|
|
49
|
+
mcp: |
|
|
50
|
+
Playwright MCP Setup (two servers):
|
|
51
|
+
1. playwright — npx @playwright/mcp@latest
|
|
52
|
+
2. playwright-test — npx playwright run-test-mcp-server
|
|
53
|
+
auto: |
|
|
54
|
+
Playwright CLI Setup:
|
|
55
|
+
...
|
|
56
|
+
Playwright MCP Setup (two servers):
|
|
57
|
+
...
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
When a user selects `auto`, they see both CLI and MCP instructions. When they select `none`, nothing is shown.
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
const { program } = require('commander');
|
|
2
|
+
const path = require('node:path');
|
|
3
|
+
const fs = require('node:fs');
|
|
4
|
+
const { execSync } = require('node:child_process');
|
|
5
|
+
const semver = require('semver');
|
|
6
|
+
const prompts = require('./lib/prompts');
|
|
7
|
+
|
|
8
|
+
// The installer flow uses many sequential @clack/prompts, each adding keypress
|
|
9
|
+
// listeners to stdin. Raise the limit to avoid spurious EventEmitter warnings.
|
|
10
|
+
if (process.stdin?.setMaxListeners) {
|
|
11
|
+
const currentLimit = process.stdin.getMaxListeners();
|
|
12
|
+
process.stdin.setMaxListeners(Math.max(currentLimit, 50));
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
// Check for updates - do this asynchronously so it doesn't block startup
|
|
16
|
+
const packageJson = require('../../package.json');
|
|
17
|
+
const packageName = 'bmad-method';
|
|
18
|
+
checkForUpdate().catch(() => {
|
|
19
|
+
// Silently ignore errors - version check is best-effort
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
async function checkForUpdate() {
|
|
23
|
+
try {
|
|
24
|
+
// For beta versions, check the beta tag; otherwise check latest
|
|
25
|
+
const isBeta =
|
|
26
|
+
packageJson.version.includes('Beta') ||
|
|
27
|
+
packageJson.version.includes('beta') ||
|
|
28
|
+
packageJson.version.includes('alpha') ||
|
|
29
|
+
packageJson.version.includes('rc');
|
|
30
|
+
const tag = isBeta ? 'beta' : 'latest';
|
|
31
|
+
|
|
32
|
+
const result = execSync(`npm view ${packageName}@${tag} version`, {
|
|
33
|
+
encoding: 'utf8',
|
|
34
|
+
stdio: 'pipe',
|
|
35
|
+
timeout: 5000,
|
|
36
|
+
}).trim();
|
|
37
|
+
|
|
38
|
+
if (result && semver.gt(result, packageJson.version)) {
|
|
39
|
+
const color = await prompts.getColor();
|
|
40
|
+
const updateMsg = [
|
|
41
|
+
`You are using version ${packageJson.version} but ${result} is available.`,
|
|
42
|
+
'',
|
|
43
|
+
'To update, exit and first run:',
|
|
44
|
+
` npm cache clean --force && npx bmad-method@${tag} install`,
|
|
45
|
+
].join('\n');
|
|
46
|
+
await prompts.box(updateMsg, 'Update Available', {
|
|
47
|
+
rounded: true,
|
|
48
|
+
formatBorder: color.yellow,
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
} catch {
|
|
52
|
+
// Silently fail - network issues or npm not available
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
// Fix for stdin issues when running through npm on Windows
|
|
57
|
+
// Ensures keyboard interaction works properly with CLI prompts
|
|
58
|
+
if (process.stdin.isTTY) {
|
|
59
|
+
try {
|
|
60
|
+
process.stdin.resume();
|
|
61
|
+
process.stdin.setEncoding('utf8');
|
|
62
|
+
|
|
63
|
+
// On Windows, explicitly reference the stdin stream to ensure it's properly initialized
|
|
64
|
+
if (process.platform === 'win32') {
|
|
65
|
+
process.stdin.on('error', () => {
|
|
66
|
+
// Ignore stdin errors - they can occur when the terminal is closing
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
} catch {
|
|
70
|
+
// Silently ignore - some environments may not support these operations
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
// Load all command modules
|
|
75
|
+
const commandsPath = path.join(__dirname, 'commands');
|
|
76
|
+
const commandFiles = fs.readdirSync(commandsPath).filter((file) => file.endsWith('.js'));
|
|
77
|
+
|
|
78
|
+
const commands = {};
|
|
79
|
+
for (const file of commandFiles) {
|
|
80
|
+
const command = require(path.join(commandsPath, file));
|
|
81
|
+
commands[command.command] = command;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
// Set up main program
|
|
85
|
+
program.version(packageJson.version).description('BMAD Core CLI - Universal AI agent framework');
|
|
86
|
+
|
|
87
|
+
// Register all commands
|
|
88
|
+
for (const [name, cmd] of Object.entries(commands)) {
|
|
89
|
+
const command = program.command(name).description(cmd.description);
|
|
90
|
+
|
|
91
|
+
// Add options
|
|
92
|
+
for (const option of cmd.options || []) {
|
|
93
|
+
command.option(...option);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
// Set action
|
|
97
|
+
command.action(cmd.action);
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
// Parse arguments
|
|
101
|
+
program.parse(process.argv);
|
|
102
|
+
|
|
103
|
+
// Show help if no command provided
|
|
104
|
+
if (process.argv.slice(2).length === 0) {
|
|
105
|
+
program.outputHelp();
|
|
106
|
+
}
|