Vim-fork focused on extensibility and usability
  • Vim Script 40.6%
  • Lua 31.3%
  • C 27.3%
  • CMake 0.4%
  • Zig 0.1%
  • Other 0.1%
Find a file
2026-03-27 23:58:50 +01:00
.github ci: bump actions/cache 2026-03-26 13:44:19 +01:00
cmake test: start test runners in Xtest_xdg dir (#37964) 2026-02-20 06:53:33 +08:00
cmake.config build: haiku os support #36639 2025-11-23 09:45:00 -08:00
cmake.deps build(deps): bump luajit to fbb36bb6b 2026-03-27 23:58:50 +01:00
cmake.packaging build: update-alternatives during deb install #37980 2026-03-21 04:50:47 -04:00
contrib docs(dev): fix references to LOG_DEBUG #37825 2026-02-12 04:20:01 -05:00
deps feat(build.zig): add option to use system dependencies 2026-01-13 22:09:03 -05:00
runtime docs(lsp): add init_options to Copilot example #38502 2026-03-27 12:33:31 -04:00
scripts fix(scripts): collect_typos.lua: show commit message on failure 2026-02-12 13:46:53 +01:00
src fix(:connect): don't use freed memory (#38512) 2026-03-27 22:32:06 +08:00
test feat(prompt): prompt_appendbuf() appends to prompt buffer #37763 2026-03-27 07:39:09 -04:00
.cirrus.yml ci(cirrus): use parallel functionaltests (#38145) 2026-03-06 10:05:59 +08:00
.clang-format build: align .clang-format rules with uncrustify config 2023-05-28 15:39:43 +02:00
.clang-tidy build: noisy readability-implicit-bool-conversion warning #38282 2026-03-13 09:02:22 -04:00
.clangd build(clangd): docstrings are Doxygen 2026-03-20 23:30:09 +01:00
.editorconfig fix(editorconfig): use 4 spaces indentation for zig files 2026-01-13 22:09:03 -05:00
.emmyrc.json build(emmyrc.json): use StyLua formatter in .emmyrc.json #35196 2025-08-06 19:52:46 -07:00
.git-blame-ignore-revs docs: .git-blame-ignore-revs #26397 2024-01-28 15:03:10 -08:00
.gitattributes fix: remove exec permission from .gitattributes #33140 2025-03-29 05:30:30 -07:00
.gitignore feat(logging): rename ".nvimlog" => "nvim.log" #37935 2026-02-18 11:58:34 -05:00
.luacheckrc docs(luv): replace bundled LuaCATS meta files with upstream 2025-05-06 18:47:33 +02:00
.luacov build: move shared.lua to _core/ 2025-12-30 01:44:52 -05:00
.luarc.json docs(luv): replace bundled LuaCATS meta files with upstream 2025-05-06 18:47:33 +02:00
.mailmap docs: fix .mailmap entry (#37259) 2026-01-05 16:34:51 -08:00
.stylua.toml build: enable lintlua for scripts/ dir #26391 2023-12-04 12:38:31 -08:00
.stylua2.toml refactor(tests): lint decorations_spec, float_spec, multigrid_spec #33274 2025-05-06 18:00:20 -07:00
.styluaignore refactor(tests): lint decorations_spec, float_spec, multigrid_spec #33274 2025-05-06 18:00:20 -07:00
AGENTS.md ci: label disclosed AI-assisted PRs 2026-03-13 12:29:44 +00:00
BSDmakefile feat(lua)!: register_keystroke_callback => on_key 2021-09-09 06:09:33 -07:00
BUILD.md docs: misc 2026-03-12 11:12:56 +01:00
build.zig fix(build): build.zig: use luajit for windows 2026-02-23 10:33:06 +01:00
build.zig.zon build(deps): bump luv to 1.52.1-0 2026-03-16 10:29:58 +01:00
CMakeLists.txt ci: lint and format treesitter queries 2026-02-21 13:26:36 +01:00
CMakePresets.json docs: misc 2025-01-11 10:34:12 +01:00
CONTRIBUTING.md docs: misc 2026-03-16 14:52:03 +01:00
INSTALL.md feat(ftplugin): treesitter default highlighting for markdown 2026-02-17 10:35:19 +01:00
LICENSE.txt docs: api, messages, lsp, trust 2026-03-11 18:00:18 +01:00
MAINTAIN.md docs: api, messages, lsp, trust 2026-03-11 18:00:18 +01:00
Makefile refactor(build): Makefile readability 2026-03-20 23:30:09 +01:00
README.md feat(ftplugin): treesitter default highlighting for markdown 2026-02-17 10:35:19 +01:00

Neovim

Documentation | Chat

Coverity Scan analysis Packages Debian CI Downloads

Neovim is a project that seeks to aggressively refactor Vim in order to:

See the Introduction wiki page and Roadmap for more information.

Features

See :help nvim-features for the full list, and :help news for noteworthy changes in the latest version!

Install from package

Pre-built packages for Windows, macOS, and Linux are found on the Releases page.

Managed packages are in Homebrew, Debian, Ubuntu, Fedora, Arch Linux, Void Linux, Gentoo, and more!

Install from source

See BUILD.md and supported platforms for details.

The build is CMake-based, but a Makefile is provided as a convenience. After installing the dependencies, run the following command.

make CMAKE_BUILD_TYPE=RelWithDebInfo
sudo make install

To install to a non-default location:

make CMAKE_BUILD_TYPE=RelWithDebInfo CMAKE_INSTALL_PREFIX=/full/path/
make install

CMake hints for inspecting the build:

  • cmake --build build --target help lists all build targets.
  • build/CMakeCache.txt (or cmake -LAH build/) contains the resolved values of all CMake variables.
  • build/compile_commands.json shows the full compiler invocations for each translation unit.

Transitioning from Vim

See :help nvim-from-vim for instructions.

Project layout

├─ cmake/           CMake utils
├─ cmake.config/    CMake defines
├─ cmake.deps/      subproject to fetch and build dependencies (optional)
├─ runtime/         plugins and docs
├─ src/nvim/        application source code (see src/nvim/README.md)
│  ├─ api/          API subsystem
│  ├─ eval/         Vimscript subsystem
│  ├─ event/        event-loop subsystem
│  ├─ generators/   code generation (pre-compilation)
│  ├─ lib/          generic data structures
│  ├─ lua/          Lua subsystem
│  ├─ msgpack_rpc/  RPC subsystem
│  ├─ os/           low-level platform code
│  └─ tui/          built-in UI
└─ test/            tests (see test/README.md)

License

Neovim contributions since b17d96 are licensed under the Apache 2.0 license, except for contributions copied from Vim (identified by the vim-patch token). See LICENSE.txt for details.