Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Control Neovim using Model Context Protocol (MCP) and the official neovim/node-client JavaScript library

License

NotificationsYou must be signed in to change notification settings

bigcodegen/mcp-neovim-server

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

42 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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.

mcp-neovim-server MCP server

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)
    • Inputfilename (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
    • Inputcommand (string)
    • Runs vim commands withnvim.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
    • InputstartLine (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)
    • Inputcommand (string: "split", "vsplit", "only", "close", "wincmd h/j/k/l")
  • vim_mark
    • Set named marks at specific positions
    • Inputmark (string: a-z),line (number),column (number)
  • vim_register
    • Set content of registers
    • Inputregister (string: a-z or "),content (string)
  • vim_visual
    • Create visual mode selections
    • InputstartLine (number),startColumn (number),endLine (number),endColumn (number)

Enhanced Buffer Management

  • vim_buffer_switch
    • Switch between buffers by name or number
    • Inputidentifier (string | number) - Buffer name or number
  • vim_buffer_save
    • Save current buffer or save to specific filename
    • Inputfilename (string, optional) - Save to specific file
  • vim_file_open
    • Open files into new buffers
    • Inputfilename (string) - File to open

Search and Replace

  • vim_search
    • Search within current buffer with regex support
    • Inputpattern (string),ignoreCase (boolean, optional),wholeWord (boolean, optional)
  • vim_search_replace
    • Find and replace with advanced options
    • Inputpattern (string),replacement (string),global (boolean, optional),ignoreCase (boolean, optional),confirm (boolean, optional)
  • vim_grep
    • Project-wide search using vimgrep with quickfix list
    • Inputpattern (string),filePattern (string, optional) - File pattern to search

Advanced Workflow Tools

  • vim_macro
    • Record, stop, and play Vim macros
    • Inputaction ("record" | "stop" | "play"),register (string, a-z),count (number, optional)
  • vim_tab
    • Complete tab management
    • Inputaction ("new" | "close" | "next" | "prev" | "first" | "last" | "list"),filename (string, optional)
  • vim_fold
    • Code folding operations
    • Inputaction ("create" | "open" | "close" | "toggle" | "openall" | "closeall" | "delete"),startLine/endLine (numbers, for create)
  • vim_jump
    • Jump list navigation
    • Inputdirection ("back" | "forward" | "list")

System Tools

  • vim_health
    • Check Neovim connection health and socket status

Using this comprehensive set of19 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)

  1. Download the latest.dxt file fromReleases
  2. Drag the file to Claude Desktop

Option 2: Manual Installation

Add this to yourclaude_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.

About

Control Neovim using Model Context Protocol (MCP) and the official neovim/node-client JavaScript library

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors3

  •  
  •  
  •  

[8]ページ先頭

©2009-2025 Movatter.jp