2020-07-26 09:38:53 -05:00
|
|
|
*nvim-treesitter*
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
Minimum version of neovim: nightly
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
Authors: Yazdani Kiyan <yazdani.kiyan@protonmail.com>
|
|
|
|
|
Vigouroux Thomas <tomvig38@gmail.com>
|
|
|
|
|
https://github.com/nvim-treesitter/nvim-treesitter/graphs/contributors
|
|
|
|
|
|
|
|
|
|
Type |gO| to see the table of contents.
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
==============================================================================
|
2020-08-09 11:39:51 -05:00
|
|
|
INTRODUCTION *nvim-treesitter-intro*
|
2020-04-28 12:22:11 +02:00
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
nvim-treesitter wraps the Neovim treesitter API to provide functionnalities
|
|
|
|
|
such as highlighting and incremental selection, and a command to easily
|
|
|
|
|
install parsers.
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
==============================================================================
|
2020-08-09 11:39:51 -05:00
|
|
|
QUICK START *nvim-treesitter-quickstart*
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
Install the parser for your language
|
2020-04-28 12:32:01 +02:00
|
|
|
|
2020-04-28 12:22:11 +02:00
|
|
|
>
|
2020-04-28 12:32:01 +02:00
|
|
|
:TSInstall {language}
|
2020-04-28 12:22:11 +02:00
|
|
|
<
|
|
|
|
|
|
|
|
|
|
To get a list of supported languages
|
2020-04-28 12:32:01 +02:00
|
|
|
|
2020-04-28 12:22:11 +02:00
|
|
|
>
|
2020-04-28 12:32:01 +02:00
|
|
|
:TSInstallInfo
|
2020-04-28 12:22:11 +02:00
|
|
|
<
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
By default, everything is disabled.
|
|
|
|
|
To enable supported features, put this in your `init.vim` file:
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
>
|
2020-04-28 12:32:01 +02:00
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
2020-08-26 13:22:31 +02:00
|
|
|
ensure_installed = "all", -- one of "all", "language", or a list of languages
|
2020-08-09 11:39:51 -05:00
|
|
|
highlight = {
|
|
|
|
|
enable = true, -- false will disable the whole extension
|
|
|
|
|
disable = { "c", "rust" }, -- list of language that will be disabled
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
See |nvim-treesitter-modules| for a list of all available modules and its options.
|
|
|
|
|
|
|
|
|
|
==============================================================================
|
|
|
|
|
MODULES *nvim-treesitter-modules*
|
|
|
|
|
|
|
|
|
|
|nvim-treesitter| provides several functionalities via modules (and submodules),
|
|
|
|
|
each module makes use of the query files defined for each language,
|
|
|
|
|
you can add your own queries too, see |nvim-treesitter-query-extensions|.
|
|
|
|
|
|
|
|
|
|
All modules are disabled by default, and some provide default keymaps.
|
|
|
|
|
Each module corresponds to an entry in the dictionary passed to the
|
|
|
|
|
`nvim-treesitter.configs.setup` function, this should be in your `init.vim` file.
|
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
-- Modules and its options go here
|
|
|
|
|
highlight = { enable = true },
|
|
|
|
|
incremental_selection = { enable = true },
|
|
|
|
|
refactor = {
|
|
|
|
|
highlight_definitions = { enable = true },
|
|
|
|
|
smart_rename = { enable = true },
|
|
|
|
|
navigation = { enable = true },
|
|
|
|
|
},
|
|
|
|
|
textobjects = { enable = true },
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
All modules share some common options, like `enable` and `disable`.
|
|
|
|
|
When `enable` is `true` this will enable the module for all supported languages,
|
|
|
|
|
if you want to disable the module for some languages you can pass a list to the `disable` option.
|
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
highlight = {
|
|
|
|
|
enable = true,
|
|
|
|
|
disable = { "cpp", "lua" },
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
Options that define or accept a keymap use the same format you use to define
|
|
|
|
|
keymaps in Neovim, so you can write keymaps as `gd`, `<space>a`, `<leader>a`
|
|
|
|
|
`<C-a>` (control + a), `<A-n>` (alt + n), `<CR>` (enter), etc.
|
|
|
|
|
|
|
|
|
|
External plugins can provide their own modules with their own options,
|
|
|
|
|
those can also be configured using the `nvim-treesitter.configs.setup`
|
|
|
|
|
function.
|
|
|
|
|
|
|
|
|
|
------------------------------------------------------------------------------
|
|
|
|
|
HIGHLIGHT *nvim-treesitter-highlight-mod*
|
|
|
|
|
|
|
|
|
|
Consistent syntax highlighting.
|
|
|
|
|
|
|
|
|
|
Query files: `highlights.scm`.
|
|
|
|
|
Supported options:
|
|
|
|
|
|
|
|
|
|
- enable: `true` or `false`.
|
|
|
|
|
- disable: list of languages.
|
|
|
|
|
- custom_captures: A map of user defined capture groups to highlight groups.
|
|
|
|
|
See |nvim-treesitter-query-extensions|.
|
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
highlight = {
|
|
|
|
|
enable = true,
|
|
|
|
|
custom_captures = {
|
|
|
|
|
-- Highlight the @foo.bar capture group with the "Identifier" highlight group.
|
|
|
|
|
["foo.bar"] = "Identifier",
|
2020-07-27 09:23:42 -05:00
|
|
|
},
|
2020-08-09 11:39:51 -05:00
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
Note: The api is not stable yet.
|
|
|
|
|
|
|
|
|
|
------------------------------------------------------------------------------
|
|
|
|
|
INCREMENTAL SELECTION *nvim-treesitter-incremental-selection-mod*
|
|
|
|
|
|
|
|
|
|
Incremental selection based on the named nodes from the grammar.
|
|
|
|
|
|
|
|
|
|
Query files: `locals.scm`.
|
|
|
|
|
Supported options:
|
|
|
|
|
- enable: `true` or `false`.
|
|
|
|
|
- disable: list of languages.
|
|
|
|
|
- keymaps:
|
|
|
|
|
- init_selection: in normal mode, start incremental selection.
|
|
|
|
|
Defaults to `gnn`.
|
|
|
|
|
- node_incremental: in visual mode, increment to the upper named parent.
|
|
|
|
|
Defaults to `grn`.
|
|
|
|
|
- scope_incremental: in visual mode, increment to the upper scope
|
|
|
|
|
(as defined in `locals.scm`). Defaults to `grc`.
|
|
|
|
|
- node_decremental: in visual mode, decrement to the previous named node.
|
|
|
|
|
Defaults to `grm`.
|
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
incremental_selection = {
|
2020-07-27 09:23:42 -05:00
|
|
|
enable = true,
|
|
|
|
|
keymaps = {
|
2020-08-09 11:39:51 -05:00
|
|
|
init_selection = "gnn",
|
|
|
|
|
node_incremental = "grn",
|
|
|
|
|
scope_incremental = "grc",
|
|
|
|
|
node_decremental = "grm",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
------------------------------------------------------------------------------
|
|
|
|
|
REFACTOR *nvim-treesitter-refactor-mod*
|
|
|
|
|
|
|
|
|
|
*nvim-treesitter-highlight-definitions-submod*
|
|
|
|
|
Highlight definitions~
|
|
|
|
|
|
|
|
|
|
Highlights definition and usages of the current symbol under the cursor.
|
|
|
|
|
|
|
|
|
|
Query files: `locals.scm`.
|
|
|
|
|
Supported options:
|
|
|
|
|
- enable: `true` or `false`.
|
|
|
|
|
- disable: list of languages.
|
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
refactor = {
|
|
|
|
|
highlight_definitions = { enable = true },
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
*nvim-treesitter-highlight-current-scope-submod*
|
|
|
|
|
Highlight current scope~
|
|
|
|
|
|
|
|
|
|
Highlights the block from the current scope where the cursor is.
|
|
|
|
|
|
|
|
|
|
Query files: `locals.scm`.
|
|
|
|
|
Supported options:
|
|
|
|
|
- enable: `true` or `false`.
|
|
|
|
|
- disable: list of languages.
|
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
refactor = {
|
|
|
|
|
highlight_current_scope = { enable = true },
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
*nvim-treesitter-smart-rename-submod*
|
|
|
|
|
Smart rename~
|
|
|
|
|
|
|
|
|
|
Renames the symbol under the cursor within the current scope (and current file).
|
|
|
|
|
|
|
|
|
|
Query files: `locals.scm`.
|
|
|
|
|
Supported options:
|
|
|
|
|
- enable: `true` or `false`.
|
|
|
|
|
- disable: list of languages.
|
|
|
|
|
- keymaps:
|
|
|
|
|
- smart_rename: rename symbol under the cursor.
|
|
|
|
|
Defaults to `grr`.
|
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
refactor = {
|
|
|
|
|
smart_rename = {
|
|
|
|
|
enable = true,
|
|
|
|
|
keymaps = {
|
|
|
|
|
smart_rename = "grr",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
*nvim-treesitter-navigation-submod*
|
|
|
|
|
Navigation~
|
|
|
|
|
|
|
|
|
|
Provides "go to definition" for the symbol under the cursor,
|
|
|
|
|
and lists the definitions from the current file.
|
|
|
|
|
|
|
|
|
|
Query files: `locals.scm`.
|
|
|
|
|
Supported options:
|
|
|
|
|
- enable: `true` or `false`.
|
|
|
|
|
- disable: list of languages.
|
|
|
|
|
- keymaps:
|
|
|
|
|
- goto_definition: go to the definition of the symbol under the cursor.
|
|
|
|
|
Defaults to `gnd`.
|
2020-08-29 11:37:26 +02:00
|
|
|
- goto_definition_lsp_fallback: go to the definition of the symbol under
|
|
|
|
|
the cursor or use vim.lsp.buf.definition if the symbol can not be
|
|
|
|
|
resolved. You can use your own fallback function if create a mapping for
|
|
|
|
|
`lua require'nvim-treesitter.refactor.navigation(nil, fallback_function)<cr>` .
|
|
|
|
|
No default mapping
|
2020-08-09 11:39:51 -05:00
|
|
|
- list_definitions: list all definitions from the current file.
|
|
|
|
|
Defaults to `gnD`.
|
2020-08-22 20:46:40 +02:00
|
|
|
- goto_next_usage: go to next usage of identifier under the cursor.
|
|
|
|
|
Defaults to `<a-*>`.
|
|
|
|
|
- goto_previous_usage: go to previous usage of identifier.
|
|
|
|
|
Defaults to `<a-#>`.
|
2020-08-09 11:39:51 -05:00
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
refactor = {
|
|
|
|
|
navigation = {
|
|
|
|
|
enable = true,
|
|
|
|
|
keymaps = {
|
|
|
|
|
goto_definition = "gnd",
|
|
|
|
|
list_definitions = "gnD",
|
2020-08-22 20:46:40 +02:00
|
|
|
goto_next_usage = "<a-*>",
|
|
|
|
|
goto_previous_usage = "<a-#>",
|
2020-08-09 11:39:51 -05:00
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
------------------------------------------------------------------------------
|
|
|
|
|
TEXT OBJECTS *nvim-treesitter-textobjects-mod*
|
|
|
|
|
|
|
|
|
|
Syntax aware |text-objects|.
|
|
|
|
|
|
|
|
|
|
*nvim-treesitter-text-objects-select-submod*
|
|
|
|
|
Text object selection~
|
|
|
|
|
|
|
|
|
|
Define your own text objects mappings
|
|
|
|
|
similar to `ip` (inner paragraph) and `ap` (a paragraph).
|
|
|
|
|
|
|
|
|
|
Query files: `textobjects.scm`.
|
|
|
|
|
Supported options:
|
|
|
|
|
- enable: `true` or `false`.
|
|
|
|
|
- disable: list of languages.
|
|
|
|
|
- keymaps: map of keymaps to a tree-sitter query
|
|
|
|
|
(`(function_definition) @function`) or capture group (`@function.inner`).
|
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
textobjects = {
|
|
|
|
|
select = {
|
|
|
|
|
enable = true,
|
|
|
|
|
keymaps = {
|
|
|
|
|
-- You can use the capture groups defined in textobjects.scm
|
|
|
|
|
["af"] = "@function.outer",
|
|
|
|
|
["if"] = "@function.inner",
|
|
|
|
|
["ac"] = "@class.outer",
|
|
|
|
|
["ic"] = "@class.inner",
|
|
|
|
|
|
|
|
|
|
-- Or you can define your own textobjects like this
|
|
|
|
|
["iF"] = {
|
|
|
|
|
python = "(function_definition) @function",
|
|
|
|
|
cpp = "(function_definition) @function",
|
|
|
|
|
c = "(function_definition) @function",
|
|
|
|
|
java = "(method_declaration) @function",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
*nvim-treesitter-text-objects-swap-submod*
|
|
|
|
|
Swap text objects~
|
|
|
|
|
|
|
|
|
|
Define your own mappings to swap the node under the cursor with the next or previous one,
|
|
|
|
|
like function parameters or arguments.
|
|
|
|
|
|
|
|
|
|
Query files: `textobjects.scm`.
|
|
|
|
|
Supported options:
|
|
|
|
|
- enable: `true` or `false`.
|
|
|
|
|
- disable: list of languages.
|
|
|
|
|
- swap_next: map of keymaps to a tree-sitter capture group (`@parameter.inner`).
|
|
|
|
|
- swap_previous: same as swap_next.
|
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
textobjects = {
|
|
|
|
|
swap = {
|
|
|
|
|
enable = true,
|
|
|
|
|
swap_next = {
|
|
|
|
|
["<leader>a"] = "@parameter.inner",
|
|
|
|
|
},
|
|
|
|
|
swap_previous = {
|
|
|
|
|
["<leader>A"] = "@parameter.inner",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
EOF
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
*nvim-treesitter-text-objects-move-submod*
|
|
|
|
|
Go to next/previous text object~
|
|
|
|
|
|
|
|
|
|
Define your own mappings to jump to the next or previous text object.
|
|
|
|
|
This is similar to |]m|, |[m|, |]M|, |[M| Neovim's mappings to jump to the next
|
|
|
|
|
or previous function.
|
|
|
|
|
|
|
|
|
|
Query files: `textobjects.scm`.
|
|
|
|
|
Supported options:
|
|
|
|
|
- enable: `true` or `false`.
|
|
|
|
|
- disable: list of languages.
|
|
|
|
|
- goto_next_start: map of keymaps to a tree-sitter capture group (`@function.outer`).
|
|
|
|
|
- goto_next_end: same as goto_next_start, but it jumps to the start of
|
|
|
|
|
the text object.
|
|
|
|
|
- goto_previous_start: same as goto_next_start, but it jumps to the previous
|
|
|
|
|
text object.
|
|
|
|
|
- goto_previous_end: same as goto_next_end, but it jumps to the previous
|
|
|
|
|
text object.
|
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
|
|
|
|
textobjects = {
|
2020-08-19 22:25:01 +06:00
|
|
|
move = {
|
2020-08-09 11:39:51 -05:00
|
|
|
enable = true,
|
|
|
|
|
goto_next_start = {
|
|
|
|
|
["]m"] = "@function.outer",
|
|
|
|
|
["]]"] = "@class.outer",
|
|
|
|
|
},
|
|
|
|
|
goto_next_end = {
|
|
|
|
|
["]M"] = "@function.outer",
|
|
|
|
|
["]["] = "@class.outer",
|
|
|
|
|
},
|
|
|
|
|
goto_previous_start = {
|
|
|
|
|
["[m"] = "@function.outer",
|
|
|
|
|
["[["] = "@class.outer",
|
|
|
|
|
},
|
|
|
|
|
goto_previous_end = {
|
|
|
|
|
["[M"] = "@function.outer",
|
|
|
|
|
["[]"] = "@class.outer",
|
|
|
|
|
},
|
2020-07-27 09:23:42 -05:00
|
|
|
},
|
2020-08-09 11:39:51 -05:00
|
|
|
},
|
2020-04-28 12:32:01 +02:00
|
|
|
}
|
2020-05-19 10:05:35 -07:00
|
|
|
EOF
|
2020-04-28 12:22:11 +02:00
|
|
|
<
|
2020-07-27 09:23:42 -05:00
|
|
|
|
2020-07-12 14:51:11 +02:00
|
|
|
==============================================================================
|
2020-08-09 11:39:51 -05:00
|
|
|
USER QUERY EXTENSIONS *nvim-treesitter-query-extensions*
|
2020-07-12 14:51:11 +02:00
|
|
|
|
2020-08-12 23:06:08 +02:00
|
|
|
Queries are what `nvim-treesitter` uses to extract informations from the syntax tree, and they are
|
|
|
|
|
located in the `queries/{lang}/*` runtime directories (like the `queries` folder of this plugin).
|
2020-07-12 14:51:11 +02:00
|
|
|
|
2020-08-12 23:06:08 +02:00
|
|
|
`nvim-treesitter` considers queries as any runtime file (see `:h rtp`), that is :
|
2020-07-12 14:51:11 +02:00
|
|
|
|
2020-08-12 23:06:08 +02:00
|
|
|
- if the file is in any `after/queries/` folder, then it will be used to extend the already defined
|
|
|
|
|
queries.
|
|
|
|
|
- Otherwise, it will be used as a base to define the query, the first query found (with the highest
|
|
|
|
|
priority) will be the only one to be used.
|
|
|
|
|
|
|
|
|
|
This hybrid approach is the most standard way, and according to that, here is some ideas on how to
|
|
|
|
|
use is :
|
|
|
|
|
- If you want to rewrite (or write) a query, don't use `after/queries`.
|
|
|
|
|
- If you want to override a part of a query (only one match for example), use the `after/queries`
|
|
|
|
|
directory.
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
==============================================================================
|
2020-08-09 11:39:51 -05:00
|
|
|
COMMANDS *nvim-treesitter-commands*
|
2020-04-28 12:22:11 +02:00
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*:TSInstall*
|
2020-07-27 09:23:42 -05:00
|
|
|
:TSInstall| {language} ...~
|
2020-04-28 12:22:11 +02:00
|
|
|
|
2020-06-27 12:43:19 +02:00
|
|
|
Install one or more treesitter parsers.
|
|
|
|
|
You can use |:TSInstall| `all` to install all parsers.
|
2020-04-28 12:22:11 +02:00
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*:TSInstallInfo*
|
2020-07-27 09:23:42 -05:00
|
|
|
:TSInstallInfo~
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
List informations about currently installed parsers
|
2020-08-01 18:32:12 +02:00
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*:TSUpdate*
|
2020-07-31 20:27:06 +02:00
|
|
|
:TSUpdate {language}~
|
|
|
|
|
|
|
|
|
|
Update the installed parser of {language} or all installed parsers
|
|
|
|
|
if {language} is omitted.
|
2020-04-28 12:22:11 +02:00
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*:TSUninstall*
|
2020-08-01 18:32:12 +02:00
|
|
|
:TSUninstall {language}~
|
|
|
|
|
|
|
|
|
|
Deletes the parser for corresponding {language}. You can use 'all' for
|
|
|
|
|
language to uninstall all parsers.
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*:TSBufEnable*
|
2020-07-27 09:23:42 -05:00
|
|
|
:TSBufEnable {module}~
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
Enable {module} on the current buffer.
|
|
|
|
|
A list of modules can be found at |:TSModuleInfo|
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*:TSBufDisable*
|
2020-07-27 09:23:42 -05:00
|
|
|
:TSBufDisable {module}~
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
Disable {module} on the current buffer
|
|
|
|
|
A list of modules can be found at |:TSModuleInfo|
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*:TSBufEnableAll*
|
2020-07-27 09:23:42 -05:00
|
|
|
:TSBufEnableAll {module} [{language}]~
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
Enable {module} for the session
|
|
|
|
|
if {language} is specified, enable module for the session only for this
|
|
|
|
|
particular language.
|
|
|
|
|
A list of modules can be found at |:TSModuleInfo|
|
|
|
|
|
A list of languages can be found at |:TSInstallInfo|
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*:TSBufDisableAll*
|
2020-07-27 09:23:42 -05:00
|
|
|
:TSBufDisableAll {module} [{language}]~
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
Disable {module} for the session
|
|
|
|
|
if {language} is specified, disable module for the session only for this
|
|
|
|
|
particular language.
|
|
|
|
|
A list of modules can be found at |:TSModuleInfo|
|
|
|
|
|
A list of languages can be found at |:TSInstallInfo|
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*:TSModuleInfo*
|
2020-07-27 09:23:42 -05:00
|
|
|
:TSModuleInfo [{module}]~
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
List modules state for the current session.
|
|
|
|
|
|
2020-05-07 08:18:13 +02:00
|
|
|
==============================================================================
|
2020-08-09 11:39:51 -05:00
|
|
|
UTILS *nvim-treesitter-utils*
|
2020-05-15 14:19:29 +02:00
|
|
|
|
2020-06-19 13:51:09 +02:00
|
|
|
Nvim treesitter has some wrapper functions that you can retrieve with:
|
2020-05-15 14:19:29 +02:00
|
|
|
>
|
2020-06-19 13:51:09 +02:00
|
|
|
local ts_utils = require 'nvim-treesitter.ts_utils'
|
2020-05-15 14:19:29 +02:00
|
|
|
<
|
|
|
|
|
Methods
|
2020-08-09 11:39:51 -05:00
|
|
|
*ts_utils.get_node_at_cursor*
|
2020-07-27 09:23:42 -05:00
|
|
|
get_node_at_cursor(winnr)~
|
|
|
|
|
|
|
|
|
|
`winnr` will be 0 if nil.
|
|
|
|
|
Returns the node under the cursor.
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*ts_utils.get_node_text*
|
2020-07-27 09:23:42 -05:00
|
|
|
get_node_text(node, bufnr)~
|
|
|
|
|
|
|
|
|
|
Returns the text content of a `node`.
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*ts_utils.is_parent*
|
2020-07-27 09:23:42 -05:00
|
|
|
is_parent(dest, source)~
|
|
|
|
|
|
|
|
|
|
Determines whether `dest` is a parent of `source`.
|
|
|
|
|
Returns a boolean.
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*ts_utils.get_named_children*
|
2020-07-27 09:23:42 -05:00
|
|
|
get_named_children(node)~
|
|
|
|
|
|
|
|
|
|
Returns a table of named children of `node`.
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*ts_utilsiget_next_node*
|
2020-07-27 09:23:42 -05:00
|
|
|
get_next_node(node, allow_switch_parent, allow_next_parent)~
|
|
|
|
|
|
|
|
|
|
Returns the next node within the same parent.
|
|
|
|
|
If no node is found, returns `nil`.
|
|
|
|
|
If `allow_switch_parent` is true, it will allow switching parent
|
|
|
|
|
when the node is the last node.
|
|
|
|
|
If `allow_next_parent` is true, it will allow next parent if
|
|
|
|
|
the node is the last node and the next parent doesn't have children.
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*ts_utils.get_previous_node*
|
2020-07-27 09:23:42 -05:00
|
|
|
get_previous_node(node, allow_switch_parents, allow_prev_parent)~
|
2020-05-15 14:19:29 +02:00
|
|
|
|
2020-07-27 09:23:42 -05:00
|
|
|
Returns the previous node within the same parent.
|
|
|
|
|
`allow_switch_parent` and `allow_prev_parent` follow the same rule
|
|
|
|
|
as |ts_utils.get_next_node| but if the node is the first node.
|
2020-06-19 13:51:09 +02:00
|
|
|
|
2020-08-22 20:46:40 +02:00
|
|
|
*ts_utils.goto_node*
|
|
|
|
|
goto_node(node, goto_end, avoid_set_jump)~
|
|
|
|
|
|
|
|
|
|
Sets cursor to the position of `node` in the current windows.
|
|
|
|
|
If `goto_end` is truthy, the cursor is set to the end the node range.
|
|
|
|
|
Setting `avoid_set_jump` to `true`, avoids setting the current cursor position
|
|
|
|
|
to the jump list.
|
|
|
|
|
|
2020-05-15 14:19:29 +02:00
|
|
|
==============================================================================
|
2020-07-27 09:23:42 -05:00
|
|
|
FUNCTIONS *nvim-treesitter-functions*
|
2020-05-07 08:18:13 +02:00
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*nvim_treesitter#statusline()*
|
2020-07-27 09:23:42 -05:00
|
|
|
nvim_treesitter#statusline(size)~
|
2020-04-28 12:22:11 +02:00
|
|
|
|
2020-05-07 08:18:13 +02:00
|
|
|
Returns a string describing the current position in the syntax tree. This
|
|
|
|
|
could be used as a statusline indicator.
|
2020-08-09 11:39:51 -05:00
|
|
|
Note: The `size` argument is optional. When specified, the string will not be
|
2020-05-07 08:18:13 +02:00
|
|
|
longer than `size`.
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
*nvim_treesitter#foldexpr()*
|
2020-07-27 09:23:42 -05:00
|
|
|
nvim_treesitter#foldexpr()~
|
2020-05-25 10:29:18 +02:00
|
|
|
|
|
|
|
|
Functions to be used to determine the fold level at a given line number.
|
|
|
|
|
To use it: >
|
|
|
|
|
set foldmethod=expr
|
|
|
|
|
set foldexpr=nvim_treesitter#foldexr()
|
|
|
|
|
<
|
|
|
|
|
Note: This is highly experimental, and folding can break on some types of
|
|
|
|
|
edits. If you encounter such breakage, hiting `zx` should fix folding.
|
|
|
|
|
In any case, feel free to open an issue with the reproducing steps.
|
|
|
|
|
|
2020-06-21 19:43:02 +02:00
|
|
|
==============================================================================
|
|
|
|
|
HIGHLIGHTS *nvim-treesitter-highlights*
|
|
|
|
|
|
2020-06-27 20:43:41 +02:00
|
|
|
`TSError`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSError*
|
2020-06-27 20:43:41 +02:00
|
|
|
For syntax/parser errors.
|
|
|
|
|
|
|
|
|
|
You can deactivate highlighting of syntax errors by adding this to your
|
|
|
|
|
init.vim: >
|
|
|
|
|
highlight link TSError Normal
|
2020-06-21 19:43:02 +02:00
|
|
|
|
|
|
|
|
`TSPunctDelimiter`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSPunctDelimiter*
|
2020-06-21 19:43:02 +02:00
|
|
|
For delimiters ie: `.`
|
|
|
|
|
|
|
|
|
|
`TSPunctBracket`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSPunctBracket*
|
2020-06-21 19:43:02 +02:00
|
|
|
For brackets and parens.
|
|
|
|
|
|
|
|
|
|
`TSPunctSpecial`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSPunctSpecial*
|
2020-06-21 19:43:02 +02:00
|
|
|
For special punctutation that does not fall in the catagories before.
|
|
|
|
|
|
|
|
|
|
`TSConstant`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSConstant*
|
2020-06-21 19:43:02 +02:00
|
|
|
For constants
|
|
|
|
|
|
|
|
|
|
`TSConstBuiltin`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSConstBuiltin*
|
2020-06-21 19:43:02 +02:00
|
|
|
For constant that are built in the language: `nil` in Lua.
|
|
|
|
|
|
|
|
|
|
`TSConstMacro`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSConstMacro*
|
2020-06-21 19:43:02 +02:00
|
|
|
For constants that are defined by macros: `NULL` in C.
|
|
|
|
|
|
|
|
|
|
`TSString`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSString*
|
2020-06-21 19:43:02 +02:00
|
|
|
For strings.
|
|
|
|
|
|
|
|
|
|
`TSStringRegex`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSStringRegex*
|
2020-06-21 19:43:02 +02:00
|
|
|
For regexes.
|
|
|
|
|
|
|
|
|
|
`TSStringEscape`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSStringEscape*
|
2020-06-21 19:43:02 +02:00
|
|
|
For escape characters within a string.
|
|
|
|
|
|
|
|
|
|
`TSCharacter`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSCharacter*
|
2020-06-21 19:43:02 +02:00
|
|
|
For characters.
|
|
|
|
|
|
|
|
|
|
`TSNumber`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSNumber*
|
2020-06-21 19:43:02 +02:00
|
|
|
For integers.
|
|
|
|
|
|
|
|
|
|
`TSBoolean`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSBoolean*
|
2020-06-21 19:43:02 +02:00
|
|
|
For booleans.
|
|
|
|
|
|
|
|
|
|
`TSFloat`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSFloat*
|
2020-06-21 19:43:02 +02:00
|
|
|
For floats.
|
|
|
|
|
|
|
|
|
|
`TSFunction`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSFunction*
|
2020-06-21 19:43:02 +02:00
|
|
|
For function (calls and definitions).
|
|
|
|
|
|
|
|
|
|
`TSFuncBuiltin`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSFuncBuiltin*
|
2020-06-21 19:43:02 +02:00
|
|
|
For builtin functions: `table.insert` in Lua.
|
|
|
|
|
|
|
|
|
|
`TSFuncMacro`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSFuncMacro*
|
2020-06-21 19:43:02 +02:00
|
|
|
For macro defined fuctions (calls and definitions): each `macro_rules` in
|
|
|
|
|
Rust.
|
|
|
|
|
|
|
|
|
|
`TSParameter`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSParameter*
|
2020-06-21 19:43:02 +02:00
|
|
|
For parameters of a function.
|
|
|
|
|
|
2020-08-15 09:24:24 -05:00
|
|
|
`TSParameterReference`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSParameterReference*
|
2020-08-15 09:24:24 -05:00
|
|
|
For references to parameters of a function.
|
|
|
|
|
|
2020-06-21 19:43:02 +02:00
|
|
|
`TSMethod`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSMethod*
|
2020-06-21 19:43:02 +02:00
|
|
|
For method calls and definitions.
|
|
|
|
|
|
|
|
|
|
`TSField`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSField*
|
2020-06-21 19:43:02 +02:00
|
|
|
For fields.
|
|
|
|
|
|
|
|
|
|
`TSProperty`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSProperty*
|
2020-06-21 19:43:02 +02:00
|
|
|
Same as `TSField`.
|
|
|
|
|
|
|
|
|
|
`TSConstructor`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSConstructor*
|
2020-06-21 19:43:02 +02:00
|
|
|
For constructor calls and definitions: `{}` in Lua, and Java constructors.
|
|
|
|
|
|
|
|
|
|
`TSConditional`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSConditional*
|
2020-06-21 19:43:02 +02:00
|
|
|
For keywords related to conditionnals.
|
|
|
|
|
|
|
|
|
|
`TSRepeat`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSRepeat*
|
2020-06-21 19:43:02 +02:00
|
|
|
For keywords related to loops.
|
|
|
|
|
|
|
|
|
|
`TSLabel`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSLabel*
|
2020-06-27 20:33:55 +02:00
|
|
|
For labels: `label:` in C and `:label:` in Lua.
|
2020-06-21 19:43:02 +02:00
|
|
|
|
|
|
|
|
`TSOperator`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSOperator*
|
2020-06-21 19:43:02 +02:00
|
|
|
For any operator: `+`, but also `->` and `*` in C.
|
|
|
|
|
|
|
|
|
|
`TSKeyword`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSKeyword*
|
2020-06-21 19:43:02 +02:00
|
|
|
For keywords that don't fall in previous categories.
|
|
|
|
|
|
2020-08-03 21:40:23 -05:00
|
|
|
`TSKeywordFunction`
|
|
|
|
|
*hl-TSKeywordFunction*
|
|
|
|
|
For keywords used to define a fuction.
|
|
|
|
|
|
2020-06-21 19:43:02 +02:00
|
|
|
`TSException`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSException*
|
2020-06-21 19:43:02 +02:00
|
|
|
For exception related keywords.
|
|
|
|
|
|
|
|
|
|
`TSType`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSType*
|
2020-06-21 19:43:02 +02:00
|
|
|
For types.
|
|
|
|
|
|
|
|
|
|
`TSTypeBuiltin`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSTypeBuiltin*
|
2020-06-21 19:43:02 +02:00
|
|
|
For builtin types (you guessed it, right ?).
|
|
|
|
|
|
|
|
|
|
`TSStructure`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSStructure*
|
2020-06-21 19:43:02 +02:00
|
|
|
This is left as an exercise for the reader.
|
|
|
|
|
|
|
|
|
|
`TSInclude`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSInclude*
|
2020-06-21 19:43:02 +02:00
|
|
|
For includes: `#include` in C, `use` or `extern crate` in Rust, or `require`
|
2020-08-16 15:43:16 +02:00
|
|
|
in Lua.
|
|
|
|
|
|
|
|
|
|
`TSAnnotation`
|
|
|
|
|
*hl-TSAnnotation*
|
|
|
|
|
For C++/Dart attributes, annotations that can be attached to the code to
|
|
|
|
|
denote some kind of meta information.
|
2020-06-21 19:43:02 +02:00
|
|
|
|
2020-07-26 09:38:53 -05:00
|
|
|
`TSText`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSText*
|
2020-07-26 09:38:53 -05:00
|
|
|
For strings considered text in a markup language.
|
|
|
|
|
|
|
|
|
|
`TSStrong`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSStrong*
|
2020-07-26 09:38:53 -05:00
|
|
|
For text to be represented with strong.
|
|
|
|
|
|
|
|
|
|
`TSEmphasis`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSEmphasis*
|
2020-07-26 09:38:53 -05:00
|
|
|
For text to be represented with emphasis.
|
|
|
|
|
|
|
|
|
|
`TSUnderline`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSUnderline*
|
2020-07-26 09:38:53 -05:00
|
|
|
For text to be represented with an underline.
|
|
|
|
|
|
|
|
|
|
`TSTitle`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSTitle*
|
2020-07-26 09:38:53 -05:00
|
|
|
|
|
|
|
|
Text that is part of a title.
|
|
|
|
|
|
|
|
|
|
`TSLiteral`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSLiteral*
|
2020-07-26 09:38:53 -05:00
|
|
|
Literal text.
|
|
|
|
|
|
|
|
|
|
`TSURI`
|
2020-08-09 11:39:51 -05:00
|
|
|
*hl-TSURI*
|
2020-07-26 09:38:53 -05:00
|
|
|
Any URI like a link or email.
|
|
|
|
|
|
2020-08-16 15:43:16 +02:00
|
|
|
==============================================================================
|
|
|
|
|
MODULE-HIGHLIGHTS *nvim-treesitter-module-highlights*
|
|
|
|
|
|
2020-08-17 21:16:03 +09:00
|
|
|
Apart from the general purpose highlights in |nvim-treesitter-highlights|,
|
2020-08-16 15:43:16 +02:00
|
|
|
some submodules use their own highlight groups to visualize additional
|
|
|
|
|
information.
|
|
|
|
|
|
|
|
|
|
`TSDefinition`
|
|
|
|
|
*hl-TSDefinition*
|
|
|
|
|
Used by refactor.highlight_definitions to highlight the definition of the
|
|
|
|
|
symbol under the cursor.
|
|
|
|
|
|
|
|
|
|
`TSDefinitionUsage`
|
|
|
|
|
*hl-TSDefinitionUsage*
|
|
|
|
|
Used by refactor.highlight_definitions to highlight usages of the symbol under
|
|
|
|
|
the cursor.
|
|
|
|
|
|
|
|
|
|
`TSCurrentScope`
|
|
|
|
|
*hl-TSCurrentScope*
|
|
|
|
|
Used by refactor.highlight_current_scope to highlight the current scope.
|
|
|
|
|
|
2020-08-09 11:39:51 -05:00
|
|
|
vim:tw=78:ts=8:expandtab:noet:ft=help:norl:
|
2020-09-02 21:02:27 +00:00
|
|
|
|
|
|
|
|
==============================================================================
|
|
|
|
|
PERFORMANCE *nvim-treesitter-performance*
|
|
|
|
|
|
|
|
|
|
`nvim-treesitter` checks the 'runtimepath' on startup in order to discover
|
|
|
|
|
available parsers and install them. As a consequence, a very long
|
|
|
|
|
'runtimepath' might result in delayed startup times.
|