Merge branch 'main' into feat/quick-spec-adversarial-review-copy-paste-command
This commit is contained in:
commit
ace23f6902
|
|
@ -5,7 +5,7 @@
|
||||||
[](https://nodejs.org)
|
[](https://nodejs.org)
|
||||||
[](https://discord.gg/gk8jAdXWmj)
|
[](https://discord.gg/gk8jAdXWmj)
|
||||||
|
|
||||||
**Breakthrough Method of Agile AI Driven Development** — An AI-driven agile development module for the BMad Method Module Ecosystem, the best and most comprehensive Agile AI Driven Development framework that has true scale-adaptive intelligence that adjusts from bug fixes to enterprise systems.
|
**Build More Architect Dreams** — An AI-driven agile development module for the BMad Method Module Ecosystem, the best and most comprehensive Agile AI Driven Development framework that has true scale-adaptive intelligence that adjusts from bug fixes to enterprise systems.
|
||||||
|
|
||||||
**100% free and open source.** No paywalls. No gated content. No gated Discord. We believe in empowering everyone, not just those who can pay for a gated community or courses.
|
**100% free and open source.** No paywalls. No gated content. No gated Discord. We believe in empowering everyone, not just those who can pay for a gated community or courses.
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@ title: Welcome to the BMad Method
|
||||||
description: AI-driven development framework with specialized agents, guided workflows, and intelligent planning
|
description: AI-driven development framework with specialized agents, guided workflows, and intelligent planning
|
||||||
---
|
---
|
||||||
|
|
||||||
The BMad Method (**B**reakthrough **M**ethod of **A**gile AI **D**riven Development) is an AI-driven development framework module within the BMad Method Ecosystem that helps you build software through the whole process from ideation and planning all the way through agentic implementation. It provides specialized AI agents, guided workflows, and intelligent planning that adapts to your project's complexity, whether you're fixing a bug or building an enterprise platform.
|
The BMad Method (**B**uild **M**ore **A**rchitect **D**reams) is an AI-driven development framework module within the BMad Method Ecosystem that helps you build software through the whole process from ideation and planning all the way through agentic implementation. It provides specialized AI agents, guided workflows, and intelligent planning that adapts to your project's complexity, whether you're fixing a bug or building an enterprise platform.
|
||||||
|
|
||||||
If you're comfortable working with AI coding assistants like Claude, Cursor, or GitHub Copilot, you're ready to get started.
|
If you're comfortable working with AI coding assistants like Claude, Cursor, or GitHub Copilot, you're ready to get started.
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,12 +1,12 @@
|
||||||
{
|
{
|
||||||
"name": "bmad-method",
|
"name": "bmad-method",
|
||||||
"version": "6.0.2",
|
"version": "6.0.3",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "bmad-method",
|
"name": "bmad-method",
|
||||||
"version": "6.0.2",
|
"version": "6.0.3",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@clack/core": "^1.0.0",
|
"@clack/core": "^1.0.0",
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"$schema": "https://json.schemastore.org/package.json",
|
"$schema": "https://json.schemastore.org/package.json",
|
||||||
"name": "bmad-method",
|
"name": "bmad-method",
|
||||||
"version": "6.0.2",
|
"version": "6.0.3",
|
||||||
"description": "Breakthrough Method of Agile AI-driven Development",
|
"description": "Breakthrough Method of Agile AI-driven Development",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"agile",
|
"agile",
|
||||||
|
|
|
||||||
|
|
@ -453,6 +453,15 @@ LOAD and execute from: {project-root}/{{bmadFolderName}}/{{path}}
|
||||||
* @param {string} projectDir - Project directory
|
* @param {string} projectDir - Project directory
|
||||||
*/
|
*/
|
||||||
async cleanup(projectDir, options = {}) {
|
async cleanup(projectDir, options = {}) {
|
||||||
|
// Migrate legacy target directories (e.g. .opencode/agent → .opencode/agents)
|
||||||
|
if (this.installerConfig?.legacy_targets) {
|
||||||
|
if (!options.silent) await prompts.log.message(' Migrating legacy directories...');
|
||||||
|
for (const legacyDir of this.installerConfig.legacy_targets) {
|
||||||
|
await this.cleanupTarget(projectDir, legacyDir, options);
|
||||||
|
await this.removeEmptyParents(projectDir, legacyDir);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Clean all target directories
|
// Clean all target directories
|
||||||
if (this.installerConfig?.targets) {
|
if (this.installerConfig?.targets) {
|
||||||
const parentDirs = new Set();
|
const parentDirs = new Set();
|
||||||
|
|
@ -532,24 +541,37 @@ LOAD and execute from: {project-root}/{{bmadFolderName}}/{{path}}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Recursively remove empty directories walking up from dir toward projectDir
|
* Walk up ancestor directories from relativeDir toward projectDir, removing each if empty
|
||||||
* Stops at projectDir boundary — never removes projectDir itself
|
* Stops at projectDir boundary — never removes projectDir itself
|
||||||
* @param {string} projectDir - Project root (boundary)
|
* @param {string} projectDir - Project root (boundary)
|
||||||
* @param {string} relativeDir - Relative directory to start from
|
* @param {string} relativeDir - Relative directory to start from
|
||||||
*/
|
*/
|
||||||
async removeEmptyParents(projectDir, relativeDir) {
|
async removeEmptyParents(projectDir, relativeDir) {
|
||||||
|
const resolvedProject = path.resolve(projectDir);
|
||||||
let current = relativeDir;
|
let current = relativeDir;
|
||||||
let last = null;
|
let last = null;
|
||||||
while (current && current !== '.' && current !== last) {
|
while (current && current !== '.' && current !== last) {
|
||||||
last = current;
|
last = current;
|
||||||
const fullPath = path.join(projectDir, current);
|
const fullPath = path.resolve(projectDir, current);
|
||||||
|
// Boundary guard: never traverse outside projectDir
|
||||||
|
if (!fullPath.startsWith(resolvedProject + path.sep) && fullPath !== resolvedProject) break;
|
||||||
try {
|
try {
|
||||||
if (!(await fs.pathExists(fullPath))) break;
|
if (!(await fs.pathExists(fullPath))) {
|
||||||
|
// Dir already gone — advance current; last is reset at top of next iteration
|
||||||
|
current = path.dirname(current);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
const remaining = await fs.readdir(fullPath);
|
const remaining = await fs.readdir(fullPath);
|
||||||
if (remaining.length > 0) break;
|
if (remaining.length > 0) break;
|
||||||
await fs.rmdir(fullPath);
|
await fs.rmdir(fullPath);
|
||||||
} catch {
|
} catch (error) {
|
||||||
break;
|
// ENOTEMPTY: TOCTOU race (file added between readdir and rmdir) — skip level, continue upward
|
||||||
|
// ENOENT: dir removed by another process between pathExists and rmdir — skip level, continue upward
|
||||||
|
if (error.code === 'ENOTEMPTY' || error.code === 'ENOENT') {
|
||||||
|
current = path.dirname(current);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
break; // fatal error (e.g. EACCES) — stop upward walk
|
||||||
}
|
}
|
||||||
current = path.dirname(current);
|
current = path.dirname(current);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -131,11 +131,14 @@ platforms:
|
||||||
category: ide
|
category: ide
|
||||||
description: "OpenCode terminal coding assistant"
|
description: "OpenCode terminal coding assistant"
|
||||||
installer:
|
installer:
|
||||||
|
legacy_targets:
|
||||||
|
- .opencode/agent
|
||||||
|
- .opencode/command
|
||||||
targets:
|
targets:
|
||||||
- target_dir: .opencode/agent
|
- target_dir: .opencode/agents
|
||||||
template_type: opencode
|
template_type: opencode
|
||||||
artifact_types: [agents]
|
artifact_types: [agents]
|
||||||
- target_dir: .opencode/command
|
- target_dir: .opencode/commands
|
||||||
template_type: opencode
|
template_type: opencode
|
||||||
artifact_types: [workflows, tasks, tools]
|
artifact_types: [workflows, tasks, tools]
|
||||||
|
|
||||||
|
|
@ -191,6 +194,8 @@ platforms:
|
||||||
# template_type: string # Default template type to use
|
# template_type: string # Default template type to use
|
||||||
# header_template: string (optional) # Override for header/frontmatter template
|
# header_template: string (optional) # Override for header/frontmatter template
|
||||||
# body_template: string (optional) # Override for body/content template
|
# body_template: string (optional) # Override for body/content template
|
||||||
|
# legacy_targets: array (optional) # Old target dirs to clean up on reinstall (migration)
|
||||||
|
# - string # Relative path, e.g. .opencode/agent
|
||||||
# targets: array (optional) # For multi-target installations
|
# targets: array (optional) # For multi-target installations
|
||||||
# - target_dir: string
|
# - target_dir: string
|
||||||
# template_type: string
|
# template_type: string
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
name: '{{name}}'
|
mode: all
|
||||||
description: '{{description}}'
|
description: '{{description}}'
|
||||||
---
|
---
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,4 @@
|
||||||
---
|
---
|
||||||
name: '{{name}}'
|
|
||||||
description: '{{description}}'
|
description: '{{description}}'
|
||||||
---
|
---
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,4 @@
|
||||||
---
|
---
|
||||||
name: '{{name}}'
|
|
||||||
description: '{{description}}'
|
description: '{{description}}'
|
||||||
---
|
---
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,4 @@
|
||||||
---
|
---
|
||||||
name: '{{name}}'
|
|
||||||
description: '{{description}}'
|
description: '{{description}}'
|
||||||
---
|
---
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,4 @@
|
||||||
---
|
---
|
||||||
name: '{{name}}'
|
|
||||||
description: '{{description}}'
|
description: '{{description}}'
|
||||||
---
|
---
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue