- Explore MCP Servers
- freecad_mcp
Freecad Mcp
What is Freecad Mcp
freecad_mcp is a tool that connects FreeCAD to Claude AI and other MCP-ready tools through the Model Control Protocol (MCP), enabling direct interaction and control of FreeCAD for assisted CAD 3D design.
Use cases
Use cases for freecad_mcp include automating design tasks in FreeCAD, integrating AI assistance for design suggestions, and enhancing collaboration between different design tools through the MCP.
How to use
To use freecad_mcp, configure the MCP server using a JSON format to specify server settings, including the command to run the Python executable and the path to the ‘freecad_bridge.py’ script. Execute commands and retrieve information about the FreeCAD document and scene through the server-client architecture.
Key features
Key features of freecad_mcp include simplified interaction with FreeCAD, command execution, information retrieval about the current document and scene, and integration with AI tools for enhanced design assistance.
Where to use
freecad_mcp can be used in fields such as computer-aided design (CAD), architecture, engineering, and any domain requiring 3D modeling and design automation.
Clients Supporting MCP
The following are the main client software that supports the Model Context Protocol. Click the link to visit the official website for more information.
Overview
What is Freecad Mcp
freecad_mcp is a tool that connects FreeCAD to Claude AI and other MCP-ready tools through the Model Control Protocol (MCP), enabling direct interaction and control of FreeCAD for assisted CAD 3D design.
Use cases
Use cases for freecad_mcp include automating design tasks in FreeCAD, integrating AI assistance for design suggestions, and enhancing collaboration between different design tools through the MCP.
How to use
To use freecad_mcp, configure the MCP server using a JSON format to specify server settings, including the command to run the Python executable and the path to the ‘freecad_bridge.py’ script. Execute commands and retrieve information about the FreeCAD document and scene through the server-client architecture.
Key features
Key features of freecad_mcp include simplified interaction with FreeCAD, command execution, information retrieval about the current document and scene, and integration with AI tools for enhanced design assistance.
Where to use
freecad_mcp can be used in fields such as computer-aided design (CAD), architecture, engineering, and any domain requiring 3D modeling and design automation.
Clients Supporting MCP
The following are the main client software that supports the Model Context Protocol. Click the link to visit the official website for more information.
Content
FreeCAD MCP (Model Control Protocol)
Overview
The FreeCAD MCP (Model Control Protocol) provides a simplified interface for interacting with FreeCAD through a server-client architecture. This allows users to execute commands and retrieve information about the current FreeCAD document and scene.
https://github.com/user-attachments/assets/5acafa17-4b5b-4fef-9f6c-617e85357d44
Configuration
To configure the MCP server, you can use a JSON format to specify the server settings. Below is an example configuration:
{
"mcpServers": {
"freecad": {
"command": "C:\\ProgramData\\anaconda3\\python.exe",
"args": [
"C:\\Users\\USER\\AppData\\Roaming\\FreeCAD\\Mod\\freecad_mcp\\src\\freecad_bridge.py"
]
}
}
}
Configuration Details
-
command: The path to the Python executable that will run the FreeCAD MCP server. This can vary based on your operating system:
- Windows: Typically, it might look like
C:\\ProgramData\\anaconda3\\python.exeorC:\\Python39\\python.exe. - Linux: It could be
/usr/bin/python3or the path to your Python installation. - macOS: Usually, it would be
/usr/local/bin/python3or the path to your Python installation.
- Windows: Typically, it might look like
-
args: An array of arguments to pass to the Python command. The first argument should be the path to the
freecad_bridge.pyscript, which is responsible for handling the MCP server logic. Make sure to adjust the path according to your installation.
Example for Different Operating Systems
Windows
{
"mcpServers": {
"freecad": {
"command": "C:\\ProgramData\\anaconda3\\python.exe",
"args": [
"C:\\Users\\USER\\AppData\\Roaming\\FreeCAD\\Mod\\freecad_mcp\\src\\freecad_bridge.py"
]
}
}
}
Linux
{
"mcpServers": {
"freecad": {
"command": "/usr/bin/python3",
"args": [
"/home/USER/.FreeCAD/Mod/freecad_mcp/src/freecad_bridge.py"
]
}
}
}
macOS
{
"mcpServers": {
"freecad": {
"command": "/usr/local/bin/python3",
"args": [
"/Users/USER/Library/Preferences/FreeCAD/Mod/freecad_mcp/src/freecad_bridge.py"
]
}
}
}
Features
The FreeCAD MCP currently supports the following functionalities:
1. get_scene_info
- Description: Retrieves comprehensive information about the current FreeCAD document, including:
- Document properties (name, label, filename, object count)
- Detailed object information (type, position, rotation, shape properties)
- Sketch data (geometry, constraints)
- View information (camera position, direction, etc.)
2. run_script
- Description: Executes arbitrary Python code within the FreeCAD context. This allows users to perform complex operations, create new objects, modify existing ones, and automate tasks using FreeCAD’s Python API.
Example Usage
To use the FreeCAD MCP, you can connect to the server and send commands as follows:
import socket
import json
# Connect to the FreeCAD MCP server
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client.connect(('localhost', 9876))
# Example: Get scene information
command = {
"type": "get_scene_info"
}
client.sendall(json.dumps(command).encode('utf-8'))
# Receive the response
response = client.recv(4096)
print(json.loads(response.decode('utf-8')))
# Example: Run a script
script = """
import FreeCAD
doc = FreeCAD.ActiveDocument
box = doc.addObject("Part::Box", "MyBox")
box.Length = 20
box.Width = 20
box.Height = 20
doc.recompute()
"""
command = {
"type": "run_script",
"params": {
"script": script
}
}
client.sendall(json.dumps(command).encode('utf-8'))
# Receive the response
response = client.recv(4096)
print(json.loads(response.decode('utf-8')))
# Close the connection
client.close()
Installation
- Clone the repository or download the files.
- Place the
freecad_mcpdirectory in your FreeCAD modules directory:- Windows:
%APPDATA%/FreeCAD/Mod/ - Linux:
~/.FreeCAD/Mod/ - macOS:
~/Library/Preferences/FreeCAD/Mod/
- Windows:
- Restart FreeCAD and select the “FreeCAD MCP” workbench from the workbench selector.
Contributing
Feel free to contribute by submitting issues or pull requests. Your feedback and contributions are welcome!
License
This project is licensed under the MIT License. See the LICENSE file for details.
Dev Tools Supporting MCP
The following are the main code editors that support the Model Context Protocol. Click the link to visit the official website for more information.










