sonic-pi-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@sonic-pi-mcpplay a C major scale with synth :blade"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
sonic-pi-mcp
sonic-pi-mcp is a Python MCP server that lets an MCP client control a local
Sonic Pi runtime over the standard stdio transport.
It starts Sonic Pi's Ruby daemon, sends OSC messages to the Spider runtime, runs Sonic Pi code, stops jobs, reads runtime events/logs, and searches the local Sonic Pi docs/samples/synthdefs.
Requirements
Python 3.11+
A local Sonic Pi installation or checkout.
The Sonic Pi root directory must contain:
app/server/ruby/bin/daemon.rbapp/server/ruby/bin/spider-server.rbusually
etc/doc,etc/samples, andetc/synthdefs
No machine-specific path is baked into this package. Set SONIC_PI_ROOT in the
MCP client environment unless you pass root_path to sonic_start.
Related MCP server: MCP2OSC
Install
From PyPI, after the package is published:
pip install sonic-pi-mcpFrom a local checkout:
pip install .Build a wheel/sdist:
python -m buildThen install the wheel on another machine:
pip install dist/sonic_pi_mcp-0.1.0-py3-none-any.whlThe wheel only contains the Python package under src/sonic_pi_mcp. Generated
runtime files, exported audio, examples, tests, and local scripts are excluded
from distribution.
Publish to PyPI
This repository is prepared for PyPI Trusted Publishing through GitHub Actions. No PyPI API token should be stored in the repository.
Configure a PyPI Trusted Publisher for the package:
PyPI project name: sonic-pi-mcp
GitHub owner: WEEZZ-admin
GitHub repository: sonic-pi-mcp
Workflow name: publish.yml
Environment name: pypiThen publish a GitHub Release. The workflow in .github/workflows/publish.yml
will build the wheel/sdist and upload them to PyPI.
Before each release, update version in pyproject.toml. PyPI does not allow
re-uploading the same version.
Recommended local preflight:
python -m pip install --upgrade build twine
python -m build
python -m twine check dist/*Configuration
Required in most deployments:
SONIC_PI_ROOT=<path to the Sonic Pi root directory>Useful optional variables:
SONIC_PI_MCP_RUNTIME_DIR=<writable directory for temporary run_file buffers>
SONIC_PI_MCP_STARTUP_TIMEOUT=60
SONIC_PI_MCP_KEEPALIVE_INTERVAL=4
SONIC_PI_MCP_EVENT_BUFFER_SIZE=5000
SONIC_PI_MCP_DEFAULT_COLLECT_MS=1500
SONIC_PI_HOME=<custom Sonic Pi user-home root for logs, if needed>SONIC_PI_MCP_RUNTIME_DIR is used when code is too large for Sonic Pi's OSC
packet size and must be submitted with run_file. If it is not set, the server
uses a per-user cache directory such as %LOCALAPPDATA%\sonic-pi-mcp on
Windows, ~/Library/Caches/sonic-pi-mcp on macOS, or
${XDG_CACHE_HOME:-~/.cache}/sonic-pi-mcp on Linux.
PowerShell example without hard-coding a drive:
$env:SONIC_PI_ROOT = Join-Path $env:ProgramFiles 'Sonic Pi'
$env:SONIC_PI_MCP_RUNTIME_DIR = Join-Path $env:LOCALAPPDATA 'sonic-pi-mcp'
sonic-pi-mcpPOSIX shell example:
export SONIC_PI_ROOT="$HOME/apps/sonic-pi"
export SONIC_PI_MCP_RUNTIME_DIR="${XDG_CACHE_HOME:-$HOME/.cache}/sonic-pi-mcp"
sonic-pi-mcpMCP Client Setup
This package is a stdio MCP server. Configure clients to run the installed
console command sonic-pi-mcp.
Generic MCP JSON shape:
{
"mcpServers": {
"sonic-pi": {
"command": "sonic-pi-mcp",
"args": [],
"env": {
"SONIC_PI_ROOT": "<path to Sonic Pi root>",
"SONIC_PI_MCP_RUNTIME_DIR": "<writable runtime directory>"
}
}
}
}If your client does not inherit shell environment variables, put the variables in the client config. Avoid relying on the terminal profile of the user who installed the package.
Run Manually
python -m sonic_pi_mcpor:
sonic-pi-mcpBoth commands run the same stdio MCP server. They do not open an HTTP port.
MCP Tools
sonic_start(root_path?, no_inputs?)sonic_status()sonic_run_code(code, buffer_name?, collect_ms?)sonic_stop(collect_ms?)sonic_shutdown()sonic_read_events(since?, limit?)sonic_get_logs(source?, tail?)sonic_send_cue(path, args?)sonic_search_docs(query, limit?, root_path?)sonic_list_samples(limit?, root_path?)sonic_list_synths(limit?, root_path?)sonic_list_fx(limit?, root_path?)
Suggested Agent Workflow
Call
sonic_start(no_inputs=true)unless the user needs audio input.Call
sonic_status()and confirmstateisready.Use
sonic_search_docs,sonic_list_samples,sonic_list_synths, andsonic_list_fxto stay within the user's installed Sonic Pi version.Send music with
sonic_run_code(code, buffer_name, collect_ms).Inspect returned events for
syntax_error,runtime_error, or missingDefining fn :live_loop_...messages.Call
sonic_stop()before replacing a long-running composition.Call
sonic_shutdown()when the session is no longer needed.
Security
sonic_run_code executes local Sonic Pi code through the same token-protected
Spider API used by the Sonic Pi GUI. Treat access to this MCP server as local
code execution and local audio-device control.
License
MIT License. You may use, copy, modify, publish, distribute, sublicense, and sell copies of this package, provided the license text is included.
Packaging Notes
The package is intentionally path-neutral:
No repository-local absolute path is embedded.
SONIC_PI_ROOTor theroot_pathtool argument identifies Sonic Pi.SONIC_PI_MCP_RUNTIME_DIRcontrols where temporary large-buffer files are written.Build configuration excludes generated files such as
.runtime/,exports/, examples, tests, and local playback/export scripts.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/WEEZZ-admin/sonic-pi-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server