vibe-prompt-mcp
vibe-prompt-mcp
Every vague prompt costs you 2–3 follow-up messages. This MCP fixes your prompt before it reaches the AI — so you get the right output on the first try.
vibe-prompt-mcp scores your prompt across 4 quality dimensions, rewrites the weak parts, and fills in what's missing. The AI gets a precise instruction. You get fewer iterations.
No API key. No account. No server to run. Works inside Claude Code, Cursor, Windsurf, Zed, and any stdio MCP client.
The problem it solves
You send a prompt. The AI produces something close but not quite right. You clarify. It tries again. You say "also add loading states." Another round. "Make it responsive." One more.
Three iterations to get what you could have specified upfront.
vibe-prompt-mcp catches the gaps before the prompt is sent — vague verbs, subjective language, missing acceptance criteria, absent style stack — and fixes them automatically. The AI gets one clear instruction instead of a guessing game.
See it in action
Example 1 — vague UI prompt
Before:
can you please improve the login page, it looks bad and i want it to feel more modernScore: 76/100 — 5 issues detected
After optimize_prompt:
please redesign the login page, it looks bad and i want it to use
Inter font, neutral color palette, 8px border radius, consistent
16px grid spacing. Done when: the page renders correctly on mobile
and desktop with no console errors. Use Tailwind CSS and shadcn/ui.Score: 78/100 — filler stripped, vague terms replaced, missing specs appended
Example 2 — feature request with missing specs
Before:
Add a notifications bell icon to the navbar that shows unread count
and a dropdown list of recent notifications with mark-as-read functionalityScore: 79/100 — 3 issues detected
After optimize_prompt:
Add a notifications bell icon to the navbar that shows unread count
and a dropdown list of recent notifications with mark-as-read
functionality. Done when: the list renders correctly on mobile and
desktop with no console errors. Use Tailwind CSS and shadcn/ui.
Include loading, error, and empty states.Score: 84/100 — acceptance criteria, style stack, and state requirements added
Without this, you'd have built the feature — then asked about loading states, then responsive layout, then the empty state. Three follow-ups eliminated upfront.
How it works
vibe-prompt-mcp runs entirely on your machine as a local Node.js process. It uses no AI, makes no API calls, and sends nothing to any external service.
Under the hood it's a rule engine — 18 rules across 4 dimensions — that analyzes the structure and language of your prompt, detects patterns that consistently cause poor AI output, and applies targeted fixes. Think of it as a linter for prompts.
What this means for you:
Zero AI cost for the optimization itself. The only tokens spent are ~130 for the tool call overhead (your message + Claude routing the request + the response).
Net savings come from avoiding re-iterations. Each back-and-forth cycle with the AI costs 500–1,000+ tokens. One optimized prompt that gets it right on the first try pays for itself immediately.
Runs offline. No network call is made during optimization.
This is the core difference from AI-based prompt improvers — those spend tokens to save tokens. This one doesn't.
Quick start
Step 1 — Add to your AI tool (pick your platform below)
Step 2 — Use it
Ask your AI in plain language:
optimize this prompt: [your prompt here]score this prompt: [your prompt here]optimize in verbose mode: [your prompt here]Step 3 — Send the result
Copy the rewritten prompt and use it as your actual instruction.
Add to your AI tool
Claude Code
Option A — project-level (recommended, checked into source control and shared with your team):
Create .mcp.json at your project root:
{
"mcpServers": {
"vibe-prompt-mcp": {
"type": "stdio",
"command": "npx",
"args": ["-y", "vibe-prompt-mcp"]
}
}
}Option B — global (available in every project on your machine):
claude mcp add vibe-prompt-mcp -s user -- npx -y vibe-prompt-mcpRestart Claude Code, then type /mcp to confirm vibe-prompt-mcp appears with both tools listed.
Cursor
Settings → MCP → Add new server:
Name:
vibe-prompt-mcpCommand:
npxArgs:
-y vibe-prompt-mcp
Windsurf
Add to ~/.codeium/windsurf/mcp_config.json:
{
"mcpServers": {
"vibe-prompt-mcp": {
"command": "npx",
"args": ["-y", "vibe-prompt-mcp"]
}
}
}Zed
Add to .zed/settings.json:
{
"context_servers": {
"vibe-prompt-mcp": {
"command": {
"path": "npx",
"args": ["-y", "vibe-prompt-mcp"]
}
}
}
}Antigravity
Add to ~/.gemini/antigravity/mcp_config.json:
{
"mcpServers": {
"vibe-prompt-mcp": {
"command": "npx",
"args": ["-y", "vibe-prompt-mcp"]
}
}
}Lovable / Replit / Codex (HTTP)
These platforms require a deployed remote endpoint. The package ships an HTTP server:
node node_modules/vibe-prompt-mcp/dist/http.js
# Express on port 3000 (or $PORT) — MCP endpoint: POST /mcpDeploy to Railway or Render and point the platform's MCP URL to https://YOUR_HOST/mcp.
Scoring dimensions
Each dimension is worth 25 points. Total score: 0–100.
Dimension | What it evaluates |
Clarity | Vague action verbs, subjective descriptors, contradictory requirements, pronoun ambiguity |
Specificity | Acceptance criteria, style framework, error/loading/empty states, data shape definitions |
Completeness | Scope boundaries, responsive and accessibility constraints, tech stack, context references |
Efficiency | Filler language, meta-commentary, hedge phrases, duplicate context |
Severity:
🔴 Critical — high likelihood of wrong output
⚠ Warn — reduces quality or causes follow-up iterations
✦ Info — noise with no instructional value
Running locally from source
git clone https://github.com/saurabhjambure-pixel/vibe-prompt-mcp
cd vibe-prompt-mcp
npm install
npm run build # TypeScript → dist/
npm run dev # stdio server, hot reload
npm run start:http # HTTP server on port 3000To use your local build instead of npx:
{
"mcpServers": {
"vibe-prompt-mcp": {
"command": "node",
"args": ["/path/to/vibe-prompt-mcp/dist/index.js"]
}
}
}Contributing
Issues and PRs welcome. If you have a rule idea — a pattern you keep seeing that produces poor AI output — open an issue.
License
MIT
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/saurabhjambure-pixel/vibe-prompt-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server