neovim-mcp

neovim-mcp

Enables AI agents to navigate code using Neovim's LSP and Treesitter features, and read/write the quickfix list.

Category
Visit Server

README

neovim-mcp

Make your AI agent leverage Neovim for code navigation.

This MCP server allows you to access your Neovim instance so that your AI agent can:

  • use LSP functionalities: go to definition, find references, find symbols etc.
  • use Treesitter to inspect the AST (abstract syntaxt tree)
  • read and write to your quickfix list

How I use it

This is my typical workflow:

  1. open the project in Neovim
  2. instruct the agent to e.g. find the flow of a feature in the codebase
  3. the agent uses builtin bash tools (e.g. grep and find) as well as tools from this MCP to navigate the code
  4. the agent returns a summary of the feature and saves the result locations to the Neovim quickfix list, with details for each location

Requirements

  • a Neovim installation with LSP servers and treesitter
  • tested with Neovim 0.11. Older versions might work but they it's not guaranteed.
  • Node.js to run the MCP server

Setup

1. Start Neovim on the reserved socket

The MCP server talks to Neovim over a unix socket at /tmp/nvim. You must use the --listen option when starting Neovim. You have a couple of options:

  • directly from the terminal when invoking the program: nvim --listen /tmp/nvim
  • attach the instance to the socket at startup from your Neovim config:
    -- init.lua
    vim.fn.serverstart("/tmp/nvim")
    
  • If you run multiple Neovim instances, add a toggle keymap — it lets you change which instance the MCP server talks to:
    -- keymaps.lua
    vim.keymap.set("n", "<leader>ts", function()
      if vim.tbl_contains(vim.fn.serverlist(), "/tmp/nvim") then
        vim.fn.serverstop("/tmp/nvim")
        vim.notify("MCP server released")
      else
        os.remove("/tmp/nvim")
        vim.fn.serverstart("/tmp/nvim")
        vim.notify("MCP server assigned to this instance")
      end
    end, { desc = "[T]oggle MCP [S]erver to this instance" })
    

2. Build the server

This server is so simple that downloading a release is not worth it. You can just clone this repo and build the JS files with the following:

npm install && npm run build

3. Register the server with your MCP client

Depending on your agent harness of choice this step might look different:

  • for Claude Code:
    claude mcp add --transport stdio --scope user neovim-nav -- node /path/to/neovim-mcp/build/index.js
    
  • for other clients (Cursor, etc.): add this to your MCP config file
    {
      "neovim-nav": {
        "type": "stdio",
        "command": "node",
        "args": ["/path/to/neovim-mcp/build/index.js"]
      }
    }
    
    

3.1. Custom socket

The server connects to /tmp/nvim by default. To use a different socket path specify the env variable NVIM_SOCKET_PATH:

  • Claude code:
    claude mcp add --transport stdio --scope user neovim-nav -e NVIM_SOCKET_PATH=/tmp/my-nvim -- node /path/to/neovim-mcp/build/index.js
    
  • other clients:
    {
      "neovim-nav": {
        "type": "stdio",
        "command": "node",
        "args": ["/path/to/neovim-mcp/build/index.js"],
        "env": { "NVIM_SOCKET_PATH": "/tmp/custom-nvim-socket" }
      }
    }
    

Remember to connect both your server and Neovim instance to the same socket: nvim --listen /tmp/custom-nvim-socket

Tools

Tool Description
get_document_symbols File outline via LSP (with optional name filter)
get_ast_context Treesitter Abstract syntaxt tree at a cursor position
search_symbols Workspace-wide symbol search via LSP
get_diagnostics LSP errors/warnings for a file or workspace
get_references Find all usages of a symbol
goto_definition Jump to where a symbol is defined
goto_implementation Find implementations of an interface/abstract method
hover Type signature and docs at a position for a symbol
get_quickfix / set_quickfix Read/write the Neovim quickfix list
restart_lsp Restart LSP clients (useful after external file changes)
get_lsp get active LSP clients
vim_health Check connection with the Neovim instance

Compared to other projects

Project Diffs
mcp-neovim-server mcp-neovim-server is about overall control of your Neovim instance, with focus on text editing. This project focuses only on code navigation instead.

Contributing

See src/README.md for project structure and how to add new tools.

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured