This branch is a full, incompatible, rewrite of nvim-treesitter
and work in progress. The stable branch is master
.
The nvim-treesitter
plugin provides
- functions for installing, updating, and removing tree-sitter parsers;
- a collection of queries for enabling tree-sitter features built into Neovim for these languages.
- Neovim 0.10.0 or later (nightly)
tar
andcurl
in your path (or alternativelygit
)tree-sitter
CLI (0.22.6 or later)- a C compiler in your path (see https://docs.rs/cc/latest/cc/#compile-time-requirements)
You can install nvim-treesitter
with your favorite package manager (or using the native package
feature of vim, see :h packages
).
NOTE: This plugin is only guaranteed to work with specific versions of language parsers (as specified in the parser.lua
table). When upgrading the plugin, you must make sure that all installed parsers are updated to the latest version via :TSUpdate
.
It is strongly recommended to automate this; e.g., using lazy.nvim
require('lazy').setup(
{ 'nvim-treesitter/nvim-treesitter', build = ':TSUpdate', lazy = false }
)
NOTE: This plugin does not support lazy-loading.
nvim-treesitter
can be configured by calling setup
. The following snippet lists the available options and their default values. You do not need to call setup
for nvim-treesitter
to work using default values.
require'nvim-treesitter'.setup {
-- A list of parser names or tiers ('stable', 'core', 'community', 'unsupported')
ensure_install = { },
-- List of parsers to ignore installing
ignore_install = { 'unsupported' },
-- Automatically install missing parsers when entering buffer
auto_install = false,
-- Directory to install parsers and queries to
install_dir = vim.fn.stdpath('data') .. '/site'
}
Check :h nvim-treesitter-commands
for a list of all available commands.
For nvim-treesitter
to support a specific feature for a specific language requires both a parser for that language and an appropriate language-specific query file for that feature.
A list of the currently supported languages can be found on this page.
We are looking for maintainers to add more parsers and to write query files for their languages. Check our tracking issue for open language requests.
For related information on the supported languages, including related plugins, see this wiki page.
nvim-treesitter
provides queries for the following features. These are not automatically enabled.
Treesitter highlighting is provided by Neovim, see :h treesitter-highlight
. To enable it for a filetype, put vim.treesitter.start()
in a ftplugin/<filetype>.lua
in your config directory, or place the following in your init.lua
:
vim.api.nvim_create_autocmd('FileType', {
pattern = { '<filetype>' },
callback = function() vim.treesitter.start() end,
})
Treesitter-based folding is provided by Neovim. To enable it, put the following in your ftplugin
or FileType
autocommand:
vim.wo.foldexpr = 'v:lua.vim.treesitter.foldexpr()'
Treesitter-based indentation is provided by this plugin but considered experimental. To enable it, put the following in your ftplugin
or FileType
autocommand:
vim.bo.indentexpr = "v:lua.require'nvim-treesitter'.indentexpr()"
(Note the specific quotes used.)
Injections are used for multi-language documents, see :h treesitter-language-injections
. No setup is needed.
These queries can be used to look up definitions and references to identifiers in a given scope. They are used, e.g., by the nvim-treesitter-refactor
plugin.
If you have a parser that is not on the list of supported languages (either as a repository on Github or in a local directory), you can add it manually for use by nvim-treesitter
as follows:
- Add the following snippet in a
User TSUpdate
autocommand:
vim.api.nvim_create_autocmd('User', { pattern = 'TSUpdate',
callback = function()
require('nvim-treesitter.parsers').zimbu = {
install_info = {
url = 'https://github.com/zimbulang/tree-sitter-zimbu',
files = { 'src/parser.c' }, -- note that some parsers also require src/scanner.c
revision = <sha>, -- commit hash for revision to check out; HEAD if missing
-- optional entries:
branch = 'develop', -- only needed if different from default branch
location = 'parser', -- only needed if the parser is in subdirectory of a "monorepo"
generate = true, -- only needed if repo does not contain pre-generated src/parser.c
generate_from_json = true, -- only needed if parser has npm dependencies
},
}
end})
Alternatively, if you have a local checkout, you can instead use
install_info = {
path = '~/parsers/tree-sitter-zimbu',
files = { 'src/parser.c' }, -- note that some parsers also require src/scanner.c
-- optional entries
location = 'parser', -- only needed if the parser is in subdirectory of a "monorepo"
generate = true, -- only needed if repo does not contain pre-generated src/parser.c
generate_from_json = true, -- only needed if parser has npm dependencies
},
This will always use the state of the directory as-is (i.e., branch
and revision
will be ignored).
- If the parser name differs from the filetype(s) used by Neovim, you need to register the parser via
vim.treesitter.language.register('zimbu', { 'zu' })
If Neovim does not detect your language's filetype by default, you can use Neovim's vim.filetype.add()
to add a custom detection rule.
- Start
nvim
and:TSInstall zimbu
.
Note: Parsers using external scanner need to be written in C. C++ scanners are no longer supported.
You can use the same approach for overriding parser information. E.g., if you always want to generate the lua
parser from grammar, add
vim.api.nvim_create_autocmd('User', { pattern = 'TSUpdate',
callback = function()
require('nvim-treesitter.parsers').lua.install_info.generate = true
end})
Queries can be placed anywhere in your runtimepath
under queries/<language>
, with earlier directories taking precedence unless the queries are marked with ; extends
; see :h treesitter-query
.
E.g., to add queries for zimbu
, put highlights.scm
etc. under
vim.fn.stdpath('data') .. 'site/queries/zimbu'
Before doing anything, make sure you have the latest version of this plugin and run :checkhealth nvim-treesitter
.
It can also help to update the parsers via :TSUpdate
.
This is probably due to a change in a parser's grammar or its queries.
Try updating the parser that you suspect has changed (:TSUpdate {language}
) or all of them (:TSUpdate
).
If the error persists after updating all parsers,
please open an issue.
This could be due a query file outside this plugin using outdated nodes, or due to an outdated parser.
- Make sure you have the parsers up to date with
:TSUpdate
- Make sure you don't have more than one
parser
runtime directory. You can execute this command:= vim.api.nvim_get_runtime_file('parser', true)
to find all runtime directories. If you get more than one path, remove the ones that are outside this plugin (nvim-treesitter
directory), so the correct version of the parser is used.
I want to use a mirror instead of "https://github.com/"
In your Lua config:
for _, config in pairs(require("nvim-treesitter.parsers")) do
config.install_info.url = config.install_info.url:gsub("https://github.com/", "something else")
end
require'nvim-treesitter'.setup {
--
--
}