*nvim-treesitter* Minimum version of neovim: nightly Authors: Yazdani Kiyan , Vigouroux Thomas ============================================================================== INTRODUCTION *nvim-treesitter-intro* 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 > :TSInstall {language} < To get a list of supported languages > :TSInstallInfo < By default, everything is disabled. To enable support for features, in your `init.vim`: > lua < local ts_utils = require 'nvim-treesitter.ts_utils' < Methods *ts_utils.get_node_at_cursor* get_node_at_cursor(winnr)~ `winnr` will be 0 if nil. Returns the node under the cursor. *ts_utils.get_node_text* get_node_text(node, bufnr)~ Returns the text content of a `node`. *ts_utils.is_parent* is_parent(dest, source)~ Determines whether `dest` is a parent of `source`. Returns a boolean. *ts_utils.get_named_children* get_named_children(node)~ Returns a table of named children of `node`. *ts_utilsiget_next_node* 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. *ts_utils.get_previous_node* get_previous_node(node, allow_switch_parents, allow_prev_parent)~ 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. *ts_utils.containing_scope* containing_scope(node)~ Returns the smallest scope containing the node. *ts_utils.parent_scope* parent_scope(node, cursor_pos)~ Returns the parent scope of the current scope that contains the node. `cursor_pos` should be `{ row = number, col = number }` *ts_utils.nested_scope* nested_scope(node, cursor_pos)~ Returns the first scope within current scope that contains the node. `cursor_pos` should be `{ row = number, col = number }` *ts_utils.next_scope* next_scope(node)~ Returns the neighbour scope of the current node. *ts_utils.previous_scope* previous_scope(node)~ Returns the previous neighbour scope of the current node. ============================================================================== FUNCTIONS *nvim-treesitter-functions* *nvim_treesitter#statusline()* nvim_treesitter#statusline(size)~ 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`. *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. ============================================================================== HIGHLIGHTS *nvim-treesitter-highlights* `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 `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. `TSParameterReference` *hl-TSParameterReference* For references to 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* For labels: `label:` in C and `:label:` in Lua. `TSOperator` *hl-TSOperator* For any operator: `+`, but also `->` and `*` in C. `TSKeyword` *hl-TSKeyword* For keywords that don't fall in previous categories. `TSKeywordFunction` *hl-TSKeywordFunction* For keywords used to define a fuction. `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 `TSText` *hl-TSText* For strings considered text in a markup language. `TSStrong` *hl-TSStrong* For text to be represented with strong. `TSEmphasis` *hl-TSEmphasis* For text to be represented with emphasis. `TSUnderline` *hl-TSUnderline* For text to be represented with an underline. `TSTitle` Text that is part of a title. `TSLiteral` *hl-TSLiteral* Literal text. `TSURI` *hl-TSURI* Any URI like a link or email. vim:tw=78:ts=8:noet:ft=help:norl: