local-executor-mcp
An MCP server that lets a frontier planner (Claude Code) delegate mechanical code-generation subtasks to a local LLM served by llama-swap, to save frontier-model tokens.
README
local-executor-mcp
An MCP server that lets a frontier planner (Claude Code) delegate mechanical
code-generation subtasks to a local LLM served by llama-swap, to save
frontier-model tokens.
Mental model: Claude Code plans and verifies; the local model does the high-volume, mechanical writing. The split saves tokens because the expensive part — generating large amounts of output — happens on a free local model.
Design choices (and why)
- Generation-only, stateless. The server never writes files and never runs tests. Claude Code keeps its native file + bash tools for that. This keeps the server portable (no repo coupling, no Windows path pain) and trivial to share.
- Compact output. The tool returns just the generated artifact plus a short usage footer. (Claude Code warns when an MCP tool output exceeds ~10k tokens, and re-reading huge blobs would eat the token savings.)
- Model routing built in. A
tierargument routes between aqualitymodel and afastmodel. - Fallback is explicit. On failure the tool returns
DELEGATION_FAILEDand tells the planner to do the task itself — so a weak local result never blocks you. This is your guardrail against compounding errors. - Metrics. Every call is appended to
~/.local-executor-mcp/usage.jsonl(model, tokens, latency, ok/fail) so you can quantify savings later.
Model recommendations (from a typical llama-swap list)
| Use | Model | Why |
|---|---|---|
quality (default) |
qwen3.6-35b-a3b-q8_0 |
35B MoE, ~3B active → fast and capable, high-fidelity quant |
fast |
qwen3.5-4b-q8_0 |
small, quick, for trivial / high-volume tasks |
A/B alternative for quality |
qwopus3.6-35b-a3b-v1-q8_0 |
if code-tuned, may beat Qwen — measure it |
Avoid for code: translation models (hy-mt2-*, tower-plus), the vision model
(minicpm-v), and ultra-low quants (iq2_xxs / iq3_xxs).
Build
Requires Node.js 18+.
npm install
npm run build
Quick test (no Claude Code needed)
Confirm the server starts and your backend is reachable:
LOCAL_LLM_BASE_URL=http://10.0.0.42:8080/v1 npx @modelcontextprotocol/inspector node build/index.js
In the Inspector UI, call list_local_models first, then try delegate_code.
Use it from Claude Code
Solo (personal)
claude mcp add local-executor \
--env LOCAL_LLM_BASE_URL=http://10.0.0.42:8080/v1 \
--env LOCAL_LLM_MODEL_QUALITY=qwen3.6-35b-a3b-q8_0 \
--env LOCAL_LLM_MODEL_FAST=qwen3.5-4b-q8_0 \
-- node /absolute/path/to/local-executor-mcp/build/index.js
Restart your Claude Code session so the tools are discovered.
Team rollout (the point of this project)
Use project scope so the config is checked into git and every teammate gets
it automatically. Copy .mcp.json.example to .mcp.json at the repo root and
commit it. The first time each teammate opens the repo, Claude Code asks them to
approve the server (workspace trust), then it just works.
.mcp.json.example— assumes the package is published to npm and runs vianpx. Lowest friction; teammates need nothing installed..mcp.json.vendored.example— no publishing: drop the built server intools/local-executor-mcp/inside the repo and pointnodeat it.
The backend URL uses ${LOCAL_LLM_BASE_URL:-...default...} expansion, so each
machine can override it via an environment variable without editing the file.
Windows notes
- Node +
npxwork fine on Windows for stdio servers like this one. - If a teammate hits issues with
npx, pre-install once (npm i -g @yourorg/local-executor-mcp) and set"command": "local-executor-mcp". - Nothing here touches the filesystem, so there are no path-separator issues.
How to actually drive it (prompt Claude Code like this)
"Plan the module. For the boilerplate parts — the Odoo model fields, the XML views, and the security CSV — use the
delegate_codetool with a precise spec and the relevant context, then review what comes back and run the tests."
Good delegation targets: boilerplate, scaffolding, CRUD, test stubs, format
conversions, Odoo models/views/manifest/ir.model.access.csv, bulk
rule-based edits. Keep logic, debugging, and security-sensitive code on Claude.
Inspect your savings
cat ~/.local-executor-mcp/usage.jsonl
Each line records the model, token counts, latency and success. Aggregate it to get "X tokens / Y% of a representative workload handled locally at Z% fallback rate" — a quantified, defensible impact claim.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.