macOS-first MCP bridge for FL Studio using CoreMIDI and FL Studio Python MIDI scripts.
Project description
FL Studio MCP Mac
macOS-first MCP bridge for FL Studio. It exposes FL Studio transport, mixer, channel, MIDI export, and Piano Roll note-apply workflows to MCP clients such as Claude Desktop, Claude Code, Cursor, and other MCP-capable tools.
This is an alpha MVP. It is intentionally scoped around FL Studio's documented Python MIDI scripting and Piano Roll scripting APIs. It does not promise full headless FL Studio automation.
Why This Exists
Most FL Studio MCP work today is Windows-oriented. macOS has a cleaner CoreMIDI path for virtual ports, and FL Studio supports Python-based MIDI scripts on macOS. This project turns that into a small local MCP server plus companion FL Studio scripts.
What Works
- Live bridge over macOS virtual MIDI ports.
- FL Studio status and health checks.
- Transport: play, stop, record toggle, rewind, song/pattern mode, metronome toggle.
- Tempo changes.
- Mixer track reads and explicit track mutations.
- Channel Rack reads and explicit channel mutations.
- Standard MIDI file generation for import into FL Studio.
- Piano Roll queue file plus an included
.pyscriptto insert persistent notes.
Known Limits
- FL Studio's MIDI scripting API is not a complete DAW API.
- Loading plugins, loading arbitrary audio files, and rendering/exporting are not implemented here.
- Persistent note writing goes through the included Piano Roll script. The MCP server queues notes; you run
Scripts > FL Studio MCP Applyin the target Piano Roll. - Live bridge setup requires FL Studio's MIDI settings to map the request/response ports. The MCP server starts a singleton local MIDI daemon so Claude Desktop, Claude Code, and terminal tests share the same CoreMIDI endpoints.
Install
From this repo:
python3 -m pip install .
flstudio-mcp-mac-install
The installer copies:
device_FLStudioMCP.pyto~/Documents/Image-Line/FL Studio/Settings/Hardware/FLStudioMCP/FL Studio MCP Apply.pyscriptto~/Documents/Image-Line/FL Studio/Settings/Piano roll scripts/
Configure FL Studio on macOS
-
Start the MCP server once so it starts the local MIDI daemon and creates the virtual CoreMIDI ports:
flstudio-mcp-mac
You can stop this foreground MCP process after the ports appear. The background daemon keeps the
FLStudioMCP RequestandFLStudioMCP Responseports available for all MCP clients. -
Open FL Studio and go to
Options > MIDI Settings. -
In the input list, choose
FLStudioMCP Request. -
Set
Controller typetoFL Studio MCP Mac. -
Set the controller output to
FLStudioMCP Response. -
Restart the MCP client if needed. If duplicate
FLStudioMCPports appear, quit old MCP server processes and start the v0.1.1+ daemon again.
MCP Client Config
For detailed setup across Claude Desktop, Claude Code, Cursor, Windsurf, PyPI, and the MCP Registry, see docs/publishing.md.
Example Claude Desktop config:
{
"mcpServers": {
"flstudio-mcp-mac": {
"command": "flstudio-mcp-mac"
}
}
}
For source installs where the command is not on PATH:
{
"mcpServers": {
"flstudio-mcp-mac": {
"command": "python3",
"args": ["-m", "flstudio_mcp_mac"]
}
}
}
MIDI Note Workflow
Use fl_create_midi_file when you want a normal .mid file to import.
Use fl_queue_piano_roll_notes when you want to apply notes into the currently open Piano Roll:
- Ask the MCP client to queue notes.
- In FL Studio, open the target channel's Piano Roll.
- Run
Scripts > FL Studio MCP Apply.
Note shape:
[
{ "pitch": 60, "start": 0, "duration": 1, "velocity": 100 },
{ "pitch": 64, "start": 1, "duration": 1, "velocity": 96 },
{ "pitch": 67, "start": 2, "duration": 2, "velocity": 96 }
]
Times are in beats. MIDI pitch uses the standard 0-127 scale.
Development
python3 -m pip install ".[dev]"
PYTHONPATH=src pytest
Set FLSTUDIO_MCP_BRIDGE=mock to run the MCP server with deterministic in-memory FL Studio responses for protocol tests:
FLSTUDIO_MCP_BRIDGE=mock python3 -m flstudio_mcp_mac
Normal live mode uses a background daemon. For low-level debugging, set FLSTUDIO_MCP_BRIDGE=direct to make one MCP process own the virtual MIDI ports directly.
For live FL Studio validation steps, see docs/testing.md.
Protocol
The bridge sends base64 JSON over MIDI control-change frames on channel 16:
- CC 120: frame start
- CC 121: one base64 character
- CC 122: frame end
The FL script only accepts whitelisted command names and returns one JSON response for each request.
Privacy
This server runs entirely on your machine. It collects no telemetry and stores no data on any remote service. It communicates only with your local FL Studio instance over macOS virtual MIDI ports (CoreMIDI), and writes files only where you ask: generated MIDI files and the Piano Roll queue JSON under your local Music folder. No account, API key, or network connection is required, and nothing you do in FL Studio leaves your computer.
Built by
Built by Puya Ventures LLC. I build custom MCP servers and AI integrations. Get in touch: purahmanian@gmail.com | Portfolio: https://puyarahmanian.com
License
MIT. See LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file flstudio_mcp_mac-0.1.2.tar.gz.
File metadata
- Download URL: flstudio_mcp_mac-0.1.2.tar.gz
- Upload date:
- Size: 22.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cee6ab6d659ee87ce1ec86cb2dd6a939e6b48f1a724041fa7580b255e3cac436
|
|
| MD5 |
3835d5575dca59f0e313369d20cc339a
|
|
| BLAKE2b-256 |
bf6c1c49b1c48aaafb72fe4ca5f48504b275b019b43a33954517033deb93537f
|
File details
Details for the file flstudio_mcp_mac-0.1.2-py3-none-any.whl.
File metadata
- Download URL: flstudio_mcp_mac-0.1.2-py3-none-any.whl
- Upload date:
- Size: 20.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1d365a79ed326c1caa395ec9dba49f629d9536dd28e419c610d8ea4d7c62decc
|
|
| MD5 |
cdeb924cc2c30243e22b36d14dcd7d4c
|
|
| BLAKE2b-256 |
a8c6a79d1383100b7c10910076085f2d81ea9f22f67506b5e3bd38437ac9b8f9
|