ray-x/go.nvim

github github
programming-languages-supportgolang
stars 2,607
issues 95
subscribers 13
forks 153
CREATED

UPDATED


go.nvim

A modern go neovim plugin based on treesitter, nvim-lsp, dap debugger and AI. It is written in Lua and async as much as possible. PR & Suggestions are welcome.

The plugin covers most features required for a gopher.

LSP & Navigation

  • gopls commands: fillstruct, organize imports, list modules/packages, gc_details, generate, change signature, etc.
  • All GoToXxx (reference, implementation, definition, doc, peek code/doc, etc.) via gopls/lspconfig. Check navigator.lua for a floating UI experience
  • Show interface implementations with virtual text
  • Inlay hints (gopls 0.9+; enabled by default in 0.10+)
  • CodeLens & CodeAction support

Build, Test & Coverage

  • Async build/make/test with libuv job wrapper
  • Test with go test, gotestsum, or ginkgo — including floaterm support
  • Generate unit tests with gotests (table-driven, testify)
  • Test coverage: run coverage, display signs, and show function metrics
  • Smart build-tag detection for debug/test runs (e.g. //go:build integration)

Code Generation & Refactoring

Formatting & Linting

  • Format via LSP (gopls) or CLI (gofumpt, goimports, golines)
  • Lint with golangci-lint (v2) — LSP diagnostics or async background checks

Debugging

  • Dlv debug with nvim-dap and nvim-dap-ui — zero-config Go adapter included
  • Load VSCode launch.json configurations

AI-Powered

  • GoAI — natural-language command dispatcher (translates natural-language into go.nvim commands via Copilot/OpenAI). Use -f to include the full command catalog in the prompt for better accuracy
  • GoCmtAI — generate doc comments with AI for the declaration at cursor
  • GoDocAI — AI-powered documentation: find symbols by vague name and generate rich docs from source
  • GoCodeReview — AI code review for files, selections, or diffs; results populate the quickfix list
  • GoAIChat — ask questions about Go code with AI; auto-includes function context and LSP references

Documentation & Navigation

Comments & Docs

  • Auto-generate doc comments for packages, functions, structs, and interfaces (suppresses golint warnings)

Module & Workspace

Syntax & Snippets

  • Treesitter-based syntax highlighting and textobjects
  • Treesitter highlight injection for SQL, JSON, go template, and gohtmltmpl
  • Feature-rich LuaSnip snippets included

Project & Configuration

  • Per-project setup via .gonvim/init.lua or launch.json
  • Async jobs with libuv throughout

Installation

Use your favorite package manager to install. The dependency treesitter main branch (and optionally, treesitter-objects) should be installed the first time you use it. Also Run TSInstall go to install the go parser if not installed yet. sed is recommended to run this plugin.

vim-plug

Plug 'nvim-treesitter/nvim-treesitter'
Plug 'neovim/nvim-lspconfig'
Plug 'ray-x/go.nvim'
Plug 'ray-x/guihua.lua' ; required if you using treesitter main branch

packer.nvim/pckr.nvim

use 'ray-x/go.nvim'
use 'ray-x/guihua.lua' -- required if using treesitter main branch
use 'neovim/nvim-lspconfig'
use 'nvim-treesitter/nvim-treesitter'

lazy.nvim

{
  "ray-x/go.nvim",
  dependencies = {  -- optional packages
    "ray-x/guihua.lua",
    "neovim/nvim-lspconfig",
    "nvim-treesitter/nvim-treesitter",
  },
  opts = function()

    require("go").setup(opts)
    local format_sync_grp = vim.api.nvim_create_augroup("GoFormat", {})
    vim.api.nvim_create_autocmd("BufWritePre", {
      pattern = "*.go",
      callback = function()
      require('go.format').goimports()
      end,
      group = format_sync_grp,
    })
    return {
      -- lsp_keymaps = false,
      -- other options
    }
  end,
  event = {"CmdlineEnter"},
  ft = {"go", 'gomod'},
  build = ':lua require("go.install").update_all_sync()' -- if you need to install/update all binaries
}

The go.nvim load speed is fast and you can enable it by default

Make sure the $GOPATH/bin path is added to your $PATH environment variable. To check this you can run

echo $PATH | grep "$GOPATH/bin"

If nothing shows up, you can add the following to your shell config file:

export PATH=$PATH:$GOPATH/bin

Add format in your vimrc (or lazy.nvim config function).

lua <<EOF
local format_sync_grp = vim.api.nvim_create_augroup("GoFormat", {})
vim.api.nvim_create_autocmd("BufWritePre", {
  pattern = "*.go",
  callback = function()
   require('go.format').goimports()
  end,
  group = format_sync_grp,
})

EOF

To startup/setup the plugin

require('go').setup()

Screenshots

Add comments

auto comments

Add/Remove tags

auto tag

GoTest in floating term

gotest

Use:

:GoTermClose

To close the floating term.

SQL/JSON Highlight injection

Inlay hints

Usage & Demo

For detailed command usage, demos, screenshots, and examples, see the Usage Guide.

Quick links: Code Format | Build & Test | Debug | AI Code Review | AI Chat | GoImpl | GoDoc | Tags | Mock | All commands

Commands

Check commands.lua on all the commands provided

Gopls commands

Check gopls.lua on all the gopls commands provided, some of them are not exposed to user, but you can still use it in your lua setup.

  • list_imports
  • add_import
  • list_packages
  • tidy
  • change_signature
  • ...

Configuration

For the full default configuration with all options, see the Default Configuration in the Advanced Setup guide.

Minimal setup:

require('go').setup()

To enable AI features:

require('go').setup({
  ai = {
    enable = true,
    provider = 'copilot', -- or 'openai'
  },
})

To use gopls setup provided by go.nvim:

require('go').setup({
  lsp_cfg = true,
})

Project setup

go.nvim allow you override your setup by a project file. Put .gonvim/init.lua in your root folder. It is a small lua script and will be run durning go.setup(). The return value is used to override go.nvim setup. The sample project setup. You can check the youtube video here on how to use this feature.

-- .gonvim/init.lua project config

return {
  go = "go", -- set to go1.18beta1 if necessary
  goimports = "gopls", -- if set to 'gopls' will use gopls format, also goimports
  gofmt = "gofumpt", -- if set to gopls will use gopls format
  null_ls_document_formatting_disable = true
}

This will override your global go.nvim setup

Advanced Setup

For LSP/gopls configuration, text objects, LuaSnip snippets, mason-lspconfig integration, null-ls, treesitter highlighting, and sample vimrc, see the Advanced Setup Guide.

Other plugins that you may like

Running plugin test / github action locally

If you'd like to commit to this project, and would like to run unit tests, you can run the following command:

XDG_CONFIG_HOME=/tmp/nvim-test make localtestfile

this will run the following commands in headless mode

make setup # install plenary etc
nvim --headless --noplugin -u lua/tests/init.vim -c "PlenaryBustedFile lua/tests/go_fixplurals_spec.lua"

This runs test spec file lua/tests/go_fixplurals_spec.lua in headless mode.

Please check Makefile for more details

Q & A

Q: What is Toggle gc annotation details

A: This is a codelens message, please run codelens GoCodeLenAct and get more info