Neovim MCP Server
Connects any MCP client to the Neovim editor for seamless integration and control.
Neovim MCP Server
Connect Claude Desktop (or any Model Context Protocol client) to Neovim using MCP and the official neovim/node-client JavaScript library. This server leverages Vim's native text editing commands and workflows, which Claude already understands, to create a lightweight code or general purpose AI text assistance layer.
Features
- Connects to your nvim instance if you expose a socket file, for example
--listen /tmp/nvim, when starting nvim - Views your current buffers and manages buffer switching
- Gets cursor location, mode, file name, marks, registers, and visual selections
- Runs vim commands and optionally shell commands through vim
- Can make edits using insert, replace, or replaceAll modes
- Search and replace functionality with regex support
- Project-wide grep search with quickfix integration
- Comprehensive window management
- Health monitoring and connection diagnostics
API
Resources
nvim://session: Current neovim text editor sessionnvim://buffers: List of all open buffers in the current Neovim session with metadata including modified status, syntax, and window IDs
Tools
Core Tools
- vim_buffer
- Get buffer contents with line numbers (supports filename parameter)
- Input
filename(string, optional) - Get specific buffer by filename - Returns numbered lines with buffer content
- vim_command
- Send a command to VIM for navigation, spot editing, and line deletion
- Input
command(string) - Runs vim commands with
nvim.replaceTermcodes. Multiple commands work with newlines - Shell commands supported with
!prefix whenALLOW_SHELL_COMMANDS=true - On error,
'nvim:errmsg'contents are returned
- vim_status
- Get comprehensive Neovim status
- Returns cursor position, mode, filename, visual selection with enhanced detection, window layout, current tab, marks, registers, working directory, LSP client info, and plugin detection
- Enhanced visual selection reporting: detects visual mode type (character/line/block), provides accurate selection text, start/end positions, and last visual selection marks
- vim_edit
- Edit lines using insert, replace, or replaceAll modes
- Input
startLine(number),mode("insert"|"replace"|"replaceAll"),lines(string) - insert: insert lines at startLine
- replace: replace lines starting at startLine
- replaceAll: replace entire buffer contents
- vim_window
- Manipulate Neovim windows (split, vsplit, close, navigate)
- Input
command(string: "split", "vsplit", "only", "close", "wincmd h/j/k/l")
- vim_mark
- Set named marks at specific positions
- Input
mark(string: a-z),line(number),column(number)
- vim_register
- Set content of registers
- Input
register(string: a-z or "),content(string)
- vim_visual
- Create visual mode selections
- Input
startLine(number),startColumn(number),endLine(number),endColumn(number)
Enhanced Buffer Management
- vim_buffer_switch
- Switch between buffers by name or number
- Input
identifier(string | number) - Buffer name or number
- vim_buffer_save
- Save current buffer or save to specific filename
- Input
filename(string, optional) - Save to specific file
- vim_file_open
- Open files into new buffers
- Input
filename(string) - File to open
Search and Replace
- vim_search
- Search within current buffer with regex support
- Input
pattern(string),ignoreCase(boolean, optional),wholeWord(boolean, optional)
- vim_search_replace
- Find and replace with advanced options
- Input
pattern(string),replacement(string),global(boolean, optional),ignoreCase(boolean, optional),confirm(boolean, optional)
- vim_grep
- Project-wide search using vimgrep with quickfix list
- Input
pattern(string),filePattern(string, optional) - File pattern to search
Advanced Workflow Tools
- vim_macro
- Record, stop, and play Vim macros
- Input
action("record" | "stop" | "play"),register(string, a-z),count(number, optional)
- vim_tab
- Complete tab management
- Input
action("new" | "close" | "next" | "prev" | "first" | "last" | "list"),filename(string, optional)
- vim_fold
- Code folding operations
- Input
action("create" | "open" | "close" | "toggle" | "openall" | "closeall" | "delete"),startLine/endLine(numbers, for create)
- vim_jump
- Jump list navigation
- Input
direction("back" | "forward" | "list")
System Tools
- vim_health
- Check Neovim connection health and socket status
Using this comprehensive set of 19 tools, Claude can peer into your neovim session, navigate buffers, perform searches, make edits, record macros, manage tabs and folds, and handle your complete development workflow with standard Neovim features.
Prompts
- neovim_workflow: Get contextual help and guidance for common Neovim workflows including editing, navigation, search, buffer management, window operations, and macro usage. Provides step-by-step instructions for accomplishing tasks with the available MCP tools.
Error Handling
The server implements comprehensive error handling with custom error classes and consistent error responses:
- NeovimConnectionError: Socket connection failures with detailed messages
- NeovimCommandError: Command execution failures with command context
- NeovimValidationError: Input validation failures
New in v0.5.2: All tools now include robust try-catch error handling that returns meaningful error messages in proper MCP format. Features include connection health monitoring, graceful error propagation, and actionable error messages to help diagnose issues.
Limitations
- May not interact well with complex neovim configurations or plugins
- Shell command execution is disabled by default for security
- Socket connection required - won't work with standard vim
Configuration
Environment Variables
ALLOW_SHELL_COMMANDS: Set to 'true' to enable shell command execution (e.g.!ls). Defaults to false for security.NVIM_SOCKET_PATH: Set to the path of your Neovim socket. Defaults to '/tmp/nvim' if not specified.
Installation
Option 1: DXT Package (Recommended)
- Download the latest
.dxtfile from Releases - Drag the file to Claude Desktop
Option 2: Manual Installation
Add this to your claude_desktop_config.json:
{
"mcpServers": {
"MCP Neovim Server": {
"command": "npx",
"args": [
"-y",
"mcp-neovim-server"
],
"env": {
"ALLOW_SHELL_COMMANDS": "true",
"NVIM_SOCKET_PATH": "/tmp/nvim"
}
}
}
}
License
This MCP server is licensed under the MIT License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MIT License. For more details, please see the LICENSE file in the project repository.
Verwandte Server
Alpha Vantage MCP Server
SponsorAccess financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
ServiceNow
A production-ready Model Context Protocol (MCP) server for ServiceNow platform integration. Built with TypeScript for Node.js 20+, this server enables LLMs and AI assistants to interact with ServiceNow instances through a standardized interface.
MCP Tool Builder
An MCP server that allows LLMs to dynamically create new tools through MCP clients like Claude Desktop.
Grafana
Search dashboards, investigate incidents and query datasources in your Grafana instance
MCP Jupiter
Access Jupiter's swap API on the Solana blockchain.
Unity MCP Server
An MCP server that allows AI assistants to programmatically interact with Unity development projects.
DevContext
Provides developers with continuous, project-centric context awareness. Requires a TursoDB database.
Tickerr — Live AI Tool Status & API Pricing
Real-time status monitoring, uptime tracking, incident history, and API pricing for 42+ AI tools including ChatGPT, Claude, Gemini, Cursor, GitHub Copilot, Perplexity, DeepSeek, and Groq. No API key required. Data updated every 5 minutes from independent monitoring infrastructure.
MCP HTTP Requests
A comprehensive HTTP client for API testing, web automation, and security testing with detailed logging.
Enoch
MCP server for the Enoch control plane: dispatch gates, evidence sync, provenance, and quality gates for long-running autonomous AI work.
Nextflow Developer Tools
An MCP server for Nextflow development and testing, which requires a local clone of the Nextflow Git repository.