A drop-in replacement for fsi.exe that adds MCP capabilities to F# Interactive sessions. Perfect for AI-assisted development workflows where you need programmatic access to F# Interactive.
This is a technical proof-of-concept and not yet ready for production/enterprise use.
- Why FSI MCP Server?
- Overview
- Quick Start
- JetBrains Rider Integration
- Typical Programming Session Workflow
- Configuration
- Requirements
- License
It's the F# Interactive REPL we know and love, but your AI assistant is sitting right next to you, both of you coding together in the same REPL session.
Demo
Imagine you're developing a tricky F# algorithm in your fsi REPL. You've loaded your modules, you're exploring data structures, and you're trying to figure out why a function isn't behaving as expected. Now imagine your AI assistant can see what you're typing into F# Interactive, see the output, and execute code snippets to help you - all in the same session you're working in, seamlessly. No more wild growth of several debug.fsx scripts or waiting on new sessions to start, the AI agent just hitches a ride on your active session.
Instead of copy-pasting F# code between your AI chat and F# Interactive, your AI assistant becomes a first-class participant in your interactive REPL-driven development workflow:
Replace your F# Interactive executable with fsi-mcp in your tool of choice (vscode, JetBrains Rider, ...), connect your AI assistant (like Claude Code) with mcp, and suddenly your REPL sessions are collaborative. Your AI can run test cases, check edge cases, refactor code, and validate hypotheses, all while you maintain your familiar REPL workflow with the familiar console stdio interface.
fsi-mcp wraps the standard F# Interactive process while maintaining full CLI compatibility. It intercepts all FSI input/output to provide:
- Hybrid Usage: Mix console input and MCP calls in the same session
- Full CLI Compatibility: Use as a drop-in replacement for
fsi.exe. All arguments not prefixed withfsi-mcp:are passed to the underlying FSI process.
┌───────────────────────────────────────────────────────────┐
│ External Clients │
│ ┌──────────┐ ┌──────────┐ ┌─────────────────┐ │
│ │ Console │ │ MCP │ │ IDE │ │
│ │ Users │ │ Clients │ │ │ │
│ └──────────┘ └──────────┘ └─────────────────┘ │
└───────┬─────────────┬─────────────────┬───────────────────┘
│ │ │
│ stdin/out │ HTTP/SSE │ stdin/out
│ │ :5020 │
v v v
┌─────────────────────────────────────────────────────────────┐
│ FSI MCP Server (ASP.NET Core) │
│ │
│ ┌────────────────────────────────────────────────────┐ │
│ │ MCP Tools (HTTP Transport) │ │
│ │ • SendFSharpCode │ │
│ │ • LoadFSharpScript │ │
│ │ • GetRecentFsiEvents │ │
│ │ • GetFsiStatus │ │
│ └────────────────────────────────────────────────────┘ │
│ │ │
│ ┌────────────────────────────────────────────────────┐ │
│ │ FsiService (Core) │ │
│ │ • Manages FSI process lifecycle │ │
│ │ • Captures I/O streams │ │
│ │ • Tracks events from all sources │ │
│ └────────────────────────────────────────────────────┘ │
│ │ │
└─────────────────────────┼───────────────────────────────────┘
│
v stdin
┌───────────┐
│ dotnet │
│ fsi │
└───────────┘
stdout/stderr
Key Flows:
- Console input → forwarded to FSI + logged as events
- MCP tool calls → forwarded to FSI + logged as events
- FSI output → displayed on console + logged as events
- All logged events → available via MCP tool call GetRecentFsiEvents
# Clone and build
git clone <repository-url>
cd fsi-mcp-server
dotnet build
# Run as FSI replacement
dotnet run -- fsi:--nologo fsi:--load:script.fsx# Start FSI Server (runs on http://0.0.0.0:5020)
dotnet runReplace Rider's built-in F# Interactive with FSI Server for seamless AI integration:
- Open File → Settings → Languages & Frameworks → F# → F# Interactive
- In the F# Interactive executable field, replace the default path with:
C:\path\to\fsi-mcp-server.exe - Click OK to save
Benefits:
- Use Rider's F# Interactive integrations normally (Send to F# Interactive, etc.)
- FSI sessions interactions automatically get AI integration capabilities through an integrated MCP server.
- Open Rider's integrated terminal
- Navigate to your fsi-server directory
- Run:
dotnet run - FSI Server starts and accepts both console input and API calls
Install the mcp server:
native:
claude mcp add --transport sse fsi-server http://localhost:5020/sseThis creates a seamless experience where you can work with F# interactively while Claude assists by executing code, running tests, and maintaining collaborative scripts.
{
"mcpServers": {
"fsi-mcp": {
"command": "npx",
"args": [
"mcp-remote",
"http://localhost:5020/sse"
]
}
}"servers": {
"fsi-mcp": {
"url": "http://localhost:5020/sse",
"type": "http"
}
}2. Create a custom agent file, e.g. fsi.agent.md
You can find an example prompt here:
cd your-fsharp-project
dotnet run --project path/to/fsi-server// In console or with IDE integration
#r "path/to/your/project.dll";;
#load "YourModule.fs";;- Console: Direct F# experimentation and REPL interaction using your regular workflow
- MCP: AI assistant sends code snippets for evaluation and reads fsi.exe output.
None yet, even the local ip/ports are hardcoded for now 😂
fsi command-line arguments are forwarded to the underlying fsi.exe process.
Args for the fsi-mcp process itself should be prefixed with fsi-mcp:.
dotnet run -- --nologo --define:DEBUG --load:setup.fsx fsi-mcp:--some-fsi-mcp-specific-arg- .NET 6.0 or later
- F# Interactive (
dotnet fsi) available
See LICENSE file for details.

