2020-04-28 12:22:11 +02:00
|
|
|
*nvim-treesitter*
|
|
|
|
|
|
|
|
|
|
Minimum version of neovim: nightly
|
|
|
|
|
|
2020-04-28 12:32:01 +02:00
|
|
|
Authors: Yazdani Kiyan <yazdani.kiyan@protonmail.com>, Vigouroux Thomas <tomvig38@gmail.com>
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
==============================================================================
|
2020-04-28 12:32:01 +02:00
|
|
|
INTRODUCTION *nvim-treesitter-intro*
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
nvim-treesitter wraps the neovim treesitter api to provide functionnalities such
|
|
|
|
|
as highlighting and incremental selection, and a command to easily install parsers.
|
|
|
|
|
|
|
|
|
|
==============================================================================
|
|
|
|
|
QUICK START *nvim-treesitter-quickstart*
|
|
|
|
|
|
|
|
|
|
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
|
|
|
<
|
|
|
|
|
|
|
|
|
|
By default, everything is disabled. To enable support for features, in your `init.vim`:
|
|
|
|
|
|
|
|
|
|
>
|
2020-04-28 12:32:01 +02:00
|
|
|
lua <<EOF
|
|
|
|
|
require'nvim-treesitter.configs'.setup {
|
2020-05-03 11:10:36 +02:00
|
|
|
highlight = {
|
2020-05-08 11:22:59 +02:00
|
|
|
enable = true, -- false will disable the whole extension
|
|
|
|
|
disable = { 'c', 'rust' }, -- list of language that will be disabled
|
2020-07-12 14:51:11 +02:00
|
|
|
custom_captures = { -- mapping of user defined captures to highlight groups
|
|
|
|
|
-- ["foo.bar"] = "Identifier" -- highlight own capture @foo.bar with highlight group "Identifier", see :h nvim-treesitter-query-extensions
|
|
|
|
|
},
|
2020-05-03 11:10:36 +02:00
|
|
|
},
|
2020-05-08 11:22:59 +02:00
|
|
|
incremental_selection = {
|
2020-05-03 11:10:36 +02:00
|
|
|
enable = true,
|
|
|
|
|
disable = { 'cpp', 'lua' },
|
|
|
|
|
keymaps = { -- mappings for incremental selection (visual mappings)
|
2020-05-08 11:22:59 +02:00
|
|
|
init_selection = 'gnn', -- maps in normal mode to init the node/scope selection
|
|
|
|
|
node_incremental = "grn", -- increment to the upper named parent
|
|
|
|
|
scope_incremental = "grc", -- increment to the upper scope (as defined in locals.scm)
|
2020-06-01 19:15:28 -05:00
|
|
|
node_decremental = "grm", -- decrement to the previous node
|
2020-05-03 11:10:36 +02:00
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
ensure_installed = 'all' -- one of 'all', 'language', or a list of languages
|
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-12 14:51:11 +02:00
|
|
|
==============================================================================
|
|
|
|
|
USER QUERY EXTENSIONS *nvim-treesitter-query-extensions*
|
|
|
|
|
|
|
|
|
|
You can add your own query files by placing a query file in vim's runtime path
|
|
|
|
|
after `nvim-treesitter` is sourced. If the language has a built in query file,
|
|
|
|
|
that file will be appended to or it will be used (useful for languages not yet
|
|
|
|
|
supported).
|
|
|
|
|
|
|
|
|
|
For example, you can add files to `<vim-config-dir>/after/queries/lua/highlights.scm`
|
|
|
|
|
to add more queries to lua highlights. You can also manually add query paths
|
|
|
|
|
to the runtime path by adding this to your vim config `set rtp+='path/to/queries'`.
|
|
|
|
|
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
==============================================================================
|
2020-04-28 12:32:01 +02:00
|
|
|
COMMANDS *nvim-treesitter-commands*
|
2020-04-28 12:22:11 +02:00
|
|
|
|
2020-06-27 12:43:19 +02:00
|
|
|
|:TSInstall| {language} ... *:TSInstall*
|
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
|
|
|
|
|
|
|
|
|:TSInstallInfo| *:TSInstallInfo*
|
|
|
|
|
|
|
|
|
|
List informations about currently installed parsers
|
|
|
|
|
|
|
|
|
|
|:TSBufEnable| {module} *:TSBufEnable*
|
|
|
|
|
|
|
|
|
|
Enable {module} on the current buffer.
|
|
|
|
|
A list of modules can be found at |:TSModuleInfo|
|
|
|
|
|
|
|
|
|
|
|:TSBufDisable| {module} *:TSBufDisable*
|
|
|
|
|
|
|
|
|
|
Disable {module} on the current buffer
|
|
|
|
|
A list of modules can be found at |:TSModuleInfo|
|
|
|
|
|
|
|
|
|
|
|:TSBufEnableAll| {module} [{language}] *:TSBufEnableAll*
|
|
|
|
|
|
|
|
|
|
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-04-28 12:32:01 +02:00
|
|
|
|:TSBufDisableAll| {module} [{language}] *:TSBufDisableAll*
|
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-04-28 12:32:01 +02:00
|
|
|
|:TSModuleInfo| [{module}] *:TSModuleInfo*
|
2020-04-28 12:22:11 +02:00
|
|
|
|
|
|
|
|
List modules state for the current session.
|
|
|
|
|
|
2020-05-07 08:18:13 +02:00
|
|
|
==============================================================================
|
2020-06-19 13:51:09 +02: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-06-19 14:13:23 +02:00
|
|
|
get_node_at_cursor(winnr) *ts_utils.get_node_at_cursor*
|
|
|
|
|
winnr will be 0 if nil
|
2020-06-19 13:51:09 +02:00
|
|
|
returns the node under the cursor
|
|
|
|
|
|
|
|
|
|
get_node_text(node, bufnr) *ts_utils.get_node_text*
|
2020-05-15 14:19:29 +02:00
|
|
|
return the text content of a node
|
|
|
|
|
|
2020-06-19 13:51:09 +02:00
|
|
|
is_parent(dest, source) *ts_utils.is_parent*
|
2020-05-15 14:19:29 +02:00
|
|
|
determines wether `dest` is a parent of `source`
|
|
|
|
|
return a boolean
|
|
|
|
|
|
2020-06-19 13:51:09 +02:00
|
|
|
get_named_children(node) *ts_utils.get_named_children*
|
2020-05-15 14:19:29 +02:00
|
|
|
return a table of named children of `node`
|
|
|
|
|
|
2020-06-19 13:51:09 +02:00
|
|
|
get_next_node(node, allow_switch_parent, allow_next_parent) *ts_utils.get_next_node*
|
2020-05-15 14:19:29 +02:00
|
|
|
return 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-06-19 13:51:09 +02:00
|
|
|
get_previous_node(node, allow_switch_parents, allow_prev_parent) *ts_utils.get_previous_node*
|
2020-05-15 14:19:29 +02:00
|
|
|
return the previous node within the same parent.
|
|
|
|
|
`allow_switch_parent` and `allow_prev_parent` follow the same rule
|
2020-06-19 13:51:09 +02:00
|
|
|
as |ts_utils.get_next_node| but if the node is the first node.
|
2020-05-15 14:19:29 +02:00
|
|
|
|
2020-06-19 13:51:09 +02:00
|
|
|
containing_scope(node) *ts_utils.containing_scope*
|
2020-05-15 14:19:29 +02:00
|
|
|
return the smallest scope containing the node
|
|
|
|
|
|
2020-06-19 13:51:09 +02:00
|
|
|
parent_scope(node, cursor_pos) *ts_utils.parent_scope*
|
2020-05-15 14:19:29 +02:00
|
|
|
return the parent scope of the current scope that contains the node.
|
|
|
|
|
`cursor_pos` should be `{ row = number, col = number }`
|
|
|
|
|
|
2020-06-19 13:51:09 +02:00
|
|
|
nested_scope(node, cursor_pos) *ts_utils.nested_scope*
|
2020-05-15 14:19:29 +02:00
|
|
|
return the first scope within current scope that contains the node.
|
|
|
|
|
`cursor_pos` should be `{ row = number, col = number }`
|
|
|
|
|
|
2020-06-19 13:51:09 +02:00
|
|
|
next_scope(node) *ts_utils.next_scope*
|
2020-05-15 14:19:29 +02:00
|
|
|
return the neighbour scope of the current node
|
|
|
|
|
|
2020-06-19 13:51:09 +02:00
|
|
|
previous_scope(node) *ts_utils.previous_scope*
|
2020-05-15 14:19:29 +02:00
|
|
|
return the previous neighbour scope of the current node
|
|
|
|
|
|
|
|
|
|
==============================================================================
|
|
|
|
|
FUNCTIONS *nvim-treesitter-functions*
|
2020-05-07 08:18:13 +02:00
|
|
|
|
|
|
|
|
|nvim_treesitter#statusline(size)|
|
|
|
|
|
*nvim_treesitter#statusline()*
|
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.
|
|
|
|
|
Note: The `size` argument is optionnal. When specified, the string will not be
|
|
|
|
|
longer than `size`.
|
|
|
|
|
|
2020-05-25 10:29:18 +02:00
|
|
|
|nvim_treesitter#foldexpr()|
|
|
|
|
|
*nvim_treesitter#foldexpr()*
|
|
|
|
|
|
|
|
|
|
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`
|
|
|
|
|
*hl-TSError*
|
|
|
|
|
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`
|
|
|
|
|
*hl-TSPunctDelimiter*
|
|
|
|
|
For delimiters ie: `.`
|
|
|
|
|
|
|
|
|
|
`TSPunctBracket`
|
|
|
|
|
*hl-TSPunctBracket*
|
|
|
|
|
For brackets and parens.
|
|
|
|
|
|
|
|
|
|
`TSPunctSpecial`
|
|
|
|
|
*hl-TSPunctSpecial*
|
|
|
|
|
For special punctutation that does not fall in the catagories before.
|
|
|
|
|
|
|
|
|
|
`TSConstant`
|
|
|
|
|
*hl-TSConstant*
|
|
|
|
|
For constants
|
|
|
|
|
|
|
|
|
|
`TSConstBuiltin`
|
|
|
|
|
*hl-TSConstBuiltin*
|
|
|
|
|
For constant that are built in the language: `nil` in Lua.
|
|
|
|
|
|
|
|
|
|
`TSConstMacro`
|
|
|
|
|
*hl-TSConstMacro*
|
|
|
|
|
For constants that are defined by macros: `NULL` in C.
|
|
|
|
|
|
|
|
|
|
`TSString`
|
|
|
|
|
*hl-TSString*
|
|
|
|
|
For strings.
|
|
|
|
|
|
|
|
|
|
`TSStringRegex`
|
|
|
|
|
*hl-TSStringRegex*
|
|
|
|
|
For regexes.
|
|
|
|
|
|
|
|
|
|
`TSStringEscape`
|
|
|
|
|
*hl-TSStringEscape*
|
|
|
|
|
For escape characters within a string.
|
|
|
|
|
|
|
|
|
|
`TSCharacter`
|
|
|
|
|
*hl-TSCharacter*
|
|
|
|
|
For characters.
|
|
|
|
|
|
|
|
|
|
`TSNumber`
|
|
|
|
|
*hl-TSNumber*
|
|
|
|
|
For integers.
|
|
|
|
|
|
|
|
|
|
`TSBoolean`
|
|
|
|
|
*hl-TSBoolean*
|
|
|
|
|
For booleans.
|
|
|
|
|
|
|
|
|
|
`TSFloat`
|
|
|
|
|
*hl-TSFloat*
|
|
|
|
|
For floats.
|
|
|
|
|
|
|
|
|
|
`TSFunction`
|
|
|
|
|
*hl-TSFunction*
|
|
|
|
|
For function (calls and definitions).
|
|
|
|
|
|
|
|
|
|
`TSFuncBuiltin`
|
|
|
|
|
*hl-TSFuncBuiltin*
|
|
|
|
|
For builtin functions: `table.insert` in Lua.
|
|
|
|
|
|
|
|
|
|
`TSFuncMacro`
|
|
|
|
|
*hl-TSFuncMacro*
|
|
|
|
|
For macro defined fuctions (calls and definitions): each `macro_rules` in
|
|
|
|
|
Rust.
|
|
|
|
|
|
|
|
|
|
`TSParameter`
|
|
|
|
|
*hl-TSParameter*
|
|
|
|
|
For parameters of a function.
|
|
|
|
|
|
|
|
|
|
`TSMethod`
|
|
|
|
|
*hl-TSMethod*
|
|
|
|
|
For method calls and definitions.
|
|
|
|
|
|
|
|
|
|
`TSField`
|
|
|
|
|
*hl-TSField*
|
|
|
|
|
For fields.
|
|
|
|
|
|
|
|
|
|
`TSProperty`
|
|
|
|
|
*hl-TSProperty*
|
|
|
|
|
Same as `TSField`.
|
|
|
|
|
|
|
|
|
|
`TSConstructor`
|
|
|
|
|
*hl-TSConstructor*
|
|
|
|
|
For constructor calls and definitions: `{}` in Lua, and Java constructors.
|
|
|
|
|
|
|
|
|
|
`TSConditional`
|
|
|
|
|
*hl-TSConditional*
|
|
|
|
|
For keywords related to conditionnals.
|
|
|
|
|
|
|
|
|
|
`TSRepeat`
|
|
|
|
|
*hl-TSRepeat*
|
|
|
|
|
For keywords related to loops.
|
|
|
|
|
|
|
|
|
|
`TSLabel`
|
|
|
|
|
*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`
|
|
|
|
|
*hl-TSOperator*
|
|
|
|
|
For any operator: `+`, but also `->` and `*` in C.
|
|
|
|
|
|
|
|
|
|
`TSKeyword`
|
|
|
|
|
*hl-TSKeyword*
|
|
|
|
|
For keywords that don't fall in previous categories.
|
|
|
|
|
|
|
|
|
|
`TSException`
|
|
|
|
|
*hl-TSException*
|
|
|
|
|
For exception related keywords.
|
|
|
|
|
|
|
|
|
|
`TSType`
|
|
|
|
|
*hl-TSType*
|
|
|
|
|
For types.
|
|
|
|
|
|
|
|
|
|
`TSTypeBuiltin`
|
|
|
|
|
*hl-TSTypeBuiltin*
|
|
|
|
|
For builtin types (you guessed it, right ?).
|
|
|
|
|
|
|
|
|
|
`TSStructure`
|
|
|
|
|
*hl-TSStructure*
|
|
|
|
|
This is left as an exercise for the reader.
|
|
|
|
|
|
|
|
|
|
`TSInclude`
|
|
|
|
|
*hl-TSInclude*
|
|
|
|
|
For includes: `#include` in C, `use` or `extern crate` in Rust, or `require`
|
|
|
|
|
in Lua
|
|
|
|
|
|
2020-05-07 08:18:13 +02:00
|
|
|
vim:tw=78:ts=8:noet:ft=help:norl:
|