Parses Ableton Live .als XML files to make project metadata queryable via natural language. Extracts BPM, track structure, plugin inventory, sample references, device chains, and more, entirely locally through MCP.
Pairs well with the filesystem MCP server for directory browsing.
- Missing samples: Extracts file paths from project XML. Returns structured JSON for batch relinking.
- Plugin inventory: Lists VST3/VST2/AU plugins with instance counts. Useful for migrations.
- Metadata queries: BPM, track count, arrangement length. JSON output for scripting.
- Duplicate detection: Content-based hashing (track structure, device chains, MIDI patterns).
- Master chain analysis: Compare mastering setups across projects.
Requires Python 3.10+ and uv.
curl -LsSf https://astral.sh/uv/install.sh | shAdd the server to your MCP client's configuration file (e.g., claude_desktop_config.json, Cursor settings, or your custom client):
{
"mcpServers": {
"ableton-manager": {
"command": "uv",
"args": [
"tool",
"run",
"--from",
"/path/to/ableton-proj-mcp",
"music-manager-mcp"
]
}
}
}Note: Restart your MCP client after updating the configuration.
Scan directory for .als files and return basic metadata.
Input:
directory(string): Path to scan
Output:
- Project name, folder, size, modification date
- Safety limits applied automatically
Safety Limits:
- Max 100 files (configurable via
MAX_FILES_TO_SCAN) - Skip files > 50MB (configurable via
MAX_FILE_SIZE_MB) - Max depth: 3 subdirectories (configurable via
SCAN_DEPTH)
Deep analysis of project files. Parses gzipped XML to extract comprehensive metadata.
Input:
project_paths(array): List of absolute .als file paths
Output:
{
"basic_info": {
"bpm": 140.0,
"track_count": 15,
"audio_tracks": 6,
"midi_tracks": 9,
"frozen_tracks": 2
},
"structure": {
"arrangement_length_bars": 128,
"scene_count": 8,
"markers": ["INTRO", "DROP", "OUTRO"],
"automation_lanes": 24,
"total_clips": 45
},
"devices": {
"stock_ableton": ["Eq8", "Compressor2", "Reverb"],
"third_party_vsts": ["Serum 2", "OTT", "ShaperBox 3"],
"heavy_cpu_count": 3
},
"master_chain": ["Eq8", "GlueCompressor", "Limiter"],
"completion": {
"likely_finished": true,
"has_arrangement": true,
"has_master_chain": true
}
}Supported Devices:
- Stock: All Ableton Live instruments, effects, and utility devices
- VST3: Full name extraction from plugin metadata
- VST2: Legacy plugin format support
- AU: Audio Units (macOS)
Find recently modified projects, sorted by modification time.
Input:
directory(string): Path to scanlimit(integer, optional): Number of results (default: 10)
Output: List of most recent projects with metadata
Content-based duplicate detection using structural hashing.
Similarity Factors:
- Track structure hash: 40%
- Track count match: 15%
- BPM match: 10%
- Master chain match: 20%
- MIDI pattern hash: 15%
Input:
directory(string): Path to scanthreshold(number, optional): Similarity percentage (default: 80)
Enumerate all third-party plugins used across projects.
Output:
- List of unique plugins found
- Projects using each plugin
- Note: Does not verify system installation
Scan projects for broken audio file references.
Input:
directory(string): Path to scan
Output:
{
"projects_with_issues": [
{
"name": "project.als",
"missing_count": 5,
"total_samples": 20,
"missing_samples": ["/path/to/missing.wav"]
}
],
"total_missing_samples": 142
}Extract and compare mastering device chains across projects.
Input:
project_paths(array): List of .als file paths
Output: Groups projects by unique master chain configurations
Classify projects as finished or sketches using heuristics.
Completion Indicators (requires 3+ for "finished"):
- Has 3+ arrangement markers
- Has 2+ devices on master track
- Arrangement length > 64 bars
- Has 5+ session view scenes
Ableton .als files are gzip-compressed XML documents. The server:
- Decompresses files using gzip
- Parses XML with ElementTree
- Extracts data from LiveSet structure
- Returns structured JSON
Stock devices are identified by XML tag names. Third-party plugins are parsed from PluginDevice elements:
- VST3:
Vst3PluginInfo/Name - VST2:
VstPluginInfo/PlugName - AU:
AuPluginInfo/Name
- Scans: ~100ms per project (metadata only)
- Deep analysis: ~200-500ms per project (full XML parse)
- Batch operations use safety limits to prevent timeouts
Edit constants in src/music_manager_mcp/__main__.py:
MAX_FILES_TO_SCAN = 100 # Maximum files per scan
MAX_FILE_SIZE_MB = 50 # Skip files larger than this
SCAN_DEPTH = 3 # Maximum subdirectory depthExtracted:
- BPM, track counts (audio/MIDI/frozen)
- Arrangement length, scenes, markers
- All devices (stock and third-party)
- Master chain device order
- Automation lane count
- Clip count
- Sample file references
- Content hashes for duplicate detection
Not Currently Extracted:
- MIDI note data
- Audio clip waveforms
- Plugin parameter values
- Routing/send configurations
- Clip envelopes
No projects found: Verify directory path and .als file presence
Analysis timeout: Reduce batch size or increase MAX_FILES_TO_SCAN
Missing plugin names: Ensure project is from Ableton Live 11+
Large file skipped: Increase MAX_FILE_SIZE_MB or analyze individually
Pull requests welcome. Please ensure:
- Code follows existing style
- New features include tests
- Documentation is updated
MIT License - see LICENSE file for details