Skip to main content
Glama

DollhouseMCP

by DollhouseMCP
update-readme-version.jsโ€ข2.71 kB
#!/usr/bin/env node /** * Script to update version numbers in README.md * Usage: node scripts/update-readme-version.js * * This will read the version from package.json and update all references in README.md */ import { readFileSync, writeFileSync } from 'fs'; import { join, dirname } from 'path'; import { fileURLToPath } from 'url'; const __filename = fileURLToPath(import.meta.url); const __dirname = dirname(__filename); const rootDir = join(__dirname, '..'); // Read current version from package.json const packageJson = JSON.parse(readFileSync(join(rootDir, 'package.json'), 'utf8')); const currentVersion = packageJson.version; console.log(`Updating README.md to version v${currentVersion}...`); // Read README.md const readmePath = join(rootDir, 'README.md'); let readme = readFileSync(readmePath, 'utf8'); // Patterns to update const updates = [ // Main version reference { pattern: /\*\*๐Ÿ“ฆ Version\*\*: v\d+\.\d+\.\d+/g, replacement: `**๐Ÿ“ฆ Version**: v${currentVersion}` }, // Package.json reference in file structure { pattern: /โ”œโ”€โ”€ package\.json\s+# Project config \(dollhousemcp v\d+\.\d+\.\d+\)/g, replacement: `โ”œโ”€โ”€ package.json # Project config (dollhousemcp v${currentVersion})` }, // Any "Current" version in changelog (remove "Current" from old versions) { pattern: /### v\d+\.\d+\.\d+ - .+ \(Current\)/g, replacement: (match) => match.replace(' (Current)', '') } ]; // Apply updates updates.forEach(({ pattern, replacement }) => { const matches = readme.match(pattern); if (matches) { console.log(`Found ${matches.length} matches for pattern: ${pattern}`); readme = readme.replace(pattern, replacement); } }); // Add (Current) to the new version in changelog if it exists const changelogPattern = new RegExp(`(### v${currentVersion} - [^\\n]+)(?! \\(Current\\))`, 'g'); readme = readme.replace(changelogPattern, '$1 (Current)'); // Write updated README writeFileSync(readmePath, readme); console.log(`โœ… README.md updated to v${currentVersion}`); // Count tools and tests for reference try { // This is a simple count - in production you might want to actually parse the TypeScript interface const interfaceContent = readFileSync(join(rootDir, 'src/server/types.ts'), 'utf8'); const toolCount = (interfaceContent.match(/^\s*\w+\([^)]*\):\s*Promise<any>/gm) || []).length; console.log(`\n๐Ÿ“Š Current counts for reference:`); console.log(` Tools: ${toolCount}`); console.log(` Tests: Run 'npm test' to get accurate count`); console.log(`\n๐Ÿ’ก Don't forget to update these counts in README if they've changed!`); } catch (e) { // Ignore if file structure changes }

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/DollhouseMCP/DollhouseMCP'

If you have feedback or need assistance with the MCP directory API, please join our Discord server