Christmas edition. This is a maintenance release, focusing on fixes. FEATURES -------------------------------------------------------------------------------- -085f1cc99d
main: expand file ~\ or ~/ prefix on Windows FIXES -------------------------------------------------------------------------------- -f8ee92feec
deps build for ARM64 MSVC -163a532cfa
api: make `nvim_set_hl()` respect all `cterm` attributes (#31390) -6a63034b51
completion: avoid deleting text when completion leader changes #31448 -c257fe5582
coverity/510275: linematch out of bounds access (#30687) -7ca0408a1f
defaults: don't replace keycodes in Visual search mappings (#31460) -71faa2be88
events: don't expand `args.file` for Lua callback (#31473) -e80e8a0980
extmark: builtin completion can still affect nearby extmarks #31387 -7abc58349e
filetype: make filetype detection work with :doautocmd (#31470) -98ec48eefb
inccommand: ensure cursor is where it belongs -650dcbbafe
inspect: always show priority -b5b84b806a
inspect: show priority for treesitter highlights -bf66871113
lsp: cancel pending requests before refreshing (#31500) -308e9719cf
lsp: retrigger diagnostics request on server cancellation (#31345) (#31427) -84bbbd9fbe
lsp: str_byteindex_enc bounds checking #30747 -01fe4fc589
marks: skip right_gravity marks when deleting text -57b0fecd47
startup: report --startuptime error to stderr (#31131) -3c0e1a89d9
treesitter: show proper node name error messages -bbefbc995e
tui: avoid flushing buffer halfway an OSC 2 sequence (#30793) -424a452401
uri: uri_encode encodes brackets incorrectly for RFC2732 #31284 -1a030f6e04
vim.system: invalid MAX_TIMEOUT for 32-bit systems #31638 -ee7885aa21
9.1.0759: screenpos() may return invalid position (#30681) REFACTOR -------------------------------------------------------------------------------- -b286ba419a
fix incorrect use of enum (#30924) -fb5a0e28db
sort various Lua tables in src/ alphabetically (#30978) DOCUMENTATION -------------------------------------------------------------------------------- -9455686b6f
misc (#29410) -5480c0bd75
lua: "vim.bo" is always equivalent to :setlocal (#30733) -27fca9c7d2
lua: clarify when on_key "typed" will be empty (#30774)
Neovim is a project that seeks to aggressively refactor Vim in order to:
- Simplify maintenance and encourage contributions
- Split the work between multiple developers
- Enable advanced UIs without modifications to the core
- Maximize extensibility
See the Introduction wiki page and Roadmap for more information.
Features
- Modern GUIs
- API access from any language including C/C++, C#, Clojure, D, Elixir, Go, Haskell, Java/Kotlin, JavaScript/Node.js, Julia, Lisp, Lua, Perl, Python, Racket, Ruby, Rust
- Embedded, scriptable terminal emulator
- Asynchronous job control
- Shared data (shada) among multiple editor instances
- XDG base directories support
- Compatible with most Vim plugins, including Ruby and Python plugins
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
(orcmake -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 for details.
Vim is Charityware. You can use and copy it as much as you like, but you are
encouraged to make a donation for needy children in Uganda. Please see the
kcc section of the vim docs or visit the ICCF web site, available at these URLs:
https://iccf-holland.org/
https://www.vim.org/iccf/
https://www.iccf.nl/
You can also sponsor the development of Vim. Vim sponsors can vote for
features. The money goes to Uganda anyway.