mcp-neovim-server
Сообществоот bigcodegen
Control Neovim using Model Context Protocol (MCP) and the official neovim/node-client JavaScript library
Установка
{Описание
# 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. <a href="https://glama.ai/mcp/servers/s0fywdwp87"><img width="380" height="200" src="https://glama.ai/mcp/servers/s0fywdwp87/badge" alt="mcp-neovim-server MCP server" /></a> ## 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 session - `nvim://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 when `ALLOW_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
Отзывы (0)
Пока нет отзывов. Будьте первым!
Статистика
Информация
Технологии
Похожие серверы
GitHub MCP
Полная интеграция с GitHub API: репозитории, issues, pull requests, actions и многое другое.
Filesystem MCP
Безопасный доступ к файловой системе для чтения, записи и управления файлами с настраиваемыми разрешениями.
Context7 MCP
Доступ к актуальной документации библиотек и фреймворков.
Serena MCP
Мощный MCP сервер для семантической навигации по коду и рефакторинга.