wendelinism/prolog-mcp-server
If you are the rightful owner of prolog-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
The Prolog MCP Server facilitates seamless integration between Large Language Models and SWI-Prolog, enabling logical reasoning and query execution.
Prolog MCP Server
A Model Context Protocol (MCP) server that enables direct integration between Large Language Models and SWI-Prolog. This server allows LLMs to define Prolog facts and rules (clauses) and to execute Prolog queries and leverage logical reasoning capabilities.
Features
- Allow LLMs to add facts and rules (clauses) to SWI Prolog server
- Execute Prolog queries through MCP protocol
- Support for both HTTP and stdio transport
- Docker containerization support for the SWI Prolog server
- Implemented as python package for easy integration to agentic LLM applications
- Compatible with MCP Inspector for interactive testing and debugging
Prolog MCP Server running in MCP Inspector showing available tools and interface
Prerequisites
- Python 3.8 or higher
- Git (for installation from source)
- Docker
Installation on linux
- Make sure git, python-venv and docker are installed, i.e. Install git
sudo apt install git python3.12-venv docker-buildx
- Clone git repo
git clone https://github.com/wendelinism/prolog-mcp-server.git
Move into newly downloaded folder
cd prolog-mcp-server/
- Create local python environment
python3 -m venv .
Activate local python environment
source bin/activate
- Install python package prolog-mcp-server, and all it's python dependencies
pip install -e .
- Build prolog docker image (without this the MCP-server will have no prolog server to connect to)
docker buildx build -t prolog-docker-image -f docker/prolog.dockerfile .
In case your user does not have permission yet to interact with docker, add local user to docker group:
sudo usermod -aG docker $USER
To make this change effective, restart the terminal session with
exec su - $USER
then go back to the project folder. Now you should be able to build the docker image.
Installation on Windows and Mac
Should work on windows and Mac OS as well, but not tested yet.
Usage
Integration with Claude Desktop
Claude Desktop with connector to Prolog-MCP-server
Claude Desktop can choose to use any of the tools shown for connected Prolog-MCP-server
If Claude Desktop is installed, the Prolog MCP server can be added to the Claude config, so that Claude can start a local instance of the server and run prolog code directly. Preconditions:
- Local clone of prolog-mcp-server repository (see above)
- Local python environment installed (see above)
- Docker prolog-docker-image built (see above)
Configuration
Add the following configuration to your claude_desktop_config.json
file:
Linux/Mac: ~/.config/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"prolog-mcp-server": {
"command": "/path/to/python-env/bin/python",
"args": [
"/path/to/prolog-mcp-server/src/prolog_mcp_server.py",
"--transport=stdio"
],
"env": {
"PATH": "/path/to/python-env/bin:/usr/local/bin:/usr/bin:/bin"
}
}
}
}
Note: Update both
/path/to/python-env/
and/path/to/prolog-mcp-server/
to match your actual installation paths.
Starting the Standalone Server with HTTP
For HTTP transport setup, see the the minimal example implemenation to start the standalone Prolg MCP server at .
Examples for HTTP and stdio usage
Check the examples/
directory for:
- , detectable for MCP clients
- , starting prolog, adding clauses, running query
To start standalone Prolog MCP server with http server:
python3 examples/demo_prolog_MCP-server-start_http.py
Test MCP-server with MCP inspector
To test a running MCP server with MCP inspector, first install npm:
sudo apt install npm -y
When MCP server is running with http transport, run in separate terminal:
fastmcp dev examples/demo_prolog_MCP-server-start_http.py
Follow link to MCP inspector with prefilled token. In the web interface make sure to adjust transport type ("Streamable HTTP") and URL ("http://localhost:8000/mcp") Hit connect, for test you should be able to go to "tools" now, and there "list tools"
Docker Support
A Dockerfile is provided in the docker/
directory for containerized deployment.
License
MIT License - see LICENSE file for details.
Contributing
Contributions are welcome. Feel free to submit issues and pull requests.
Credits
This MCP server relies on SWI-Prolog, an open-source Prolog implementation. All credits for the actual Prolog implementation go to the SWI-Prolog development team.