chore: update imports to Node.js prefix and add error handling improvements (#221)

## CHANGES

- Replace require('fs') with require('node:fs')
- Replace require('path') with require('node:path')
- Add debug logging for directory cleanup
- Add roomodes to VSCode dictionary
- Format README workflow guides section
- Improve error handling in installer
- Add fallback error message display
This commit is contained in:
Kayvan Sylvan
2025-06-15 07:59:25 -07:00
committed by GitHub
parent e753d02a4b
commit 732d536542
4 changed files with 29 additions and 25 deletions

View File

@@ -41,6 +41,7 @@
"rescope",
"roadmaps",
"roleplay",
"roomodes",
"runbooks",
"Serilog",
"shadcn",

View File

@@ -254,6 +254,7 @@ npm install
## Documentation & Guides
### Workflow Guides
- 📚 [Universal BMAD Workflow Guide](docs/bmad-workflow-guide.md) - Core workflow that applies to all IDEs
- 🎯 [Cursor Guide](docs/cursor-guide.md) - Complete workflow for Cursor users
- 🤖 [Claude Code Guide](docs/claude-code-guide.md) - Complete workflow for Claude Code users

View File

@@ -1,5 +1,5 @@
const fs = require('fs').promises;
const path = require('path');
const fs = require('node:fs').promises;
const path = require('node:path');
const DependencyResolver = require('../lib/dependency-resolver');
class WebBuilder {
@@ -19,6 +19,7 @@ class WebBuilder {
await fs.rm(dir, { recursive: true, force: true });
console.log(`Cleaned: ${path.relative(this.rootDir, dir)}`);
} catch (error) {
console.debug(`Failed to clean directory ${dir}:`, error.message);
// Directory might not exist, that's fine
}
}
@@ -26,11 +27,11 @@ class WebBuilder {
async buildAgents() {
const agents = await this.resolver.listAgents();
for (const agentId of agents) {
console.log(` Building agent: ${agentId}`);
const bundle = await this.buildAgentBundle(agentId);
// Write to all output directories
for (const outputDir of this.outputDirs) {
const outputPath = path.join(outputDir, 'agents');
@@ -45,11 +46,11 @@ class WebBuilder {
async buildTeams() {
const teams = await this.resolver.listTeams();
for (const teamId of teams) {
console.log(` Building team: ${teamId}`);
const bundle = await this.buildTeamBundle(teamId);
// Write to all output directories
for (const outputDir of this.outputDirs) {
const outputPath = path.join(outputDir, 'teams');
@@ -65,39 +66,39 @@ class WebBuilder {
async buildAgentBundle(agentId) {
const dependencies = await this.resolver.resolveAgentDependencies(agentId);
const template = await fs.readFile(this.templatePath, 'utf8');
const sections = [template];
// Add agent configuration
sections.push(this.formatSection(dependencies.agent.path, dependencies.agent.content));
// Add all dependencies
for (const resource of dependencies.resources) {
sections.push(this.formatSection(resource.path, resource.content));
}
return sections.join('\n');
}
async buildTeamBundle(teamId) {
const dependencies = await this.resolver.resolveTeamDependencies(teamId);
const template = await fs.readFile(this.templatePath, 'utf8');
const sections = [template];
// Add team configuration
sections.push(this.formatSection(dependencies.team.path, dependencies.team.content));
// Add all agents
for (const agent of dependencies.agents) {
sections.push(this.formatSection(agent.path, agent.content));
}
// Add all deduplicated resources
for (const resource of dependencies.resources) {
sections.push(this.formatSection(resource.path, resource.content));
}
return sections.join('\n');
}

View File

@@ -3,16 +3,17 @@
const { program } = require('commander');
const inquirer = require('inquirer');
const chalk = require('chalk');
const path = require('path');
// Handle both execution contexts (from root via npx or from installer directory)
let version, installer;
let version;
let installer;
try {
// Try installer context first (when run from tools/installer/)
version = require('../package.json').version;
installer = require('../lib/installer');
} catch (e) {
// Fall back to root context (when run via npx from GitHub)
console.log(chalk.yellow(`Installer context not found (${e.message}), trying root context...`));
try {
version = require('../../../package.json').version;
installer = require('../../../tools/installer/lib/installer');
@@ -42,7 +43,7 @@ program
try {
if (!options.full && !options.agent) {
// Interactive mode
const answers = await promptInstallation(options);
const answers = await promptInstallation();
await installer.install(answers);
} else {
// Direct mode
@@ -98,11 +99,11 @@ program
}
});
async function promptInstallation(options) {
async function promptInstallation() {
console.log(chalk.bold.blue(`\nWelcome to BMAD Method Installer v${version}\n`));
const answers = {};
// Ask for installation directory
const { directory } = await inquirer.prompt([
{
@@ -113,7 +114,7 @@ async function promptInstallation(options) {
}
]);
answers.directory = directory;
// Ask for installation type
const { installType } = await inquirer.prompt([
{
@@ -133,7 +134,7 @@ async function promptInstallation(options) {
}
]);
answers.installType = installType;
// If single agent, ask which one
if (installType === 'single-agent') {
const agents = await installer.getAvailableAgents();
@@ -150,7 +151,7 @@ async function promptInstallation(options) {
]);
answers.agent = agent;
}
// Ask for IDE configuration
const { ide } = await inquirer.prompt([
{
@@ -167,7 +168,7 @@ async function promptInstallation(options) {
}
]);
answers.ide = ide;
return answers;
}