diff options
author | Björn Linse <bjorn.linse@gmail.com> | 2020-09-10 08:50:42 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-09-10 08:50:42 +0200 |
commit | 5581ac88c60b0a3f7595088b30a8621f280b5e4c (patch) | |
tree | 134b85598a37003b2339bc996f934759b826918f /runtime/lua/vim/treesitter/highlighter.lua | |
parent | 0f41caa265602f8a6bc9f30f28d9f726699075cb (diff) | |
parent | ef5e7b862db38d3b0376417e137c6463c4d909e6 (diff) | |
download | rneovim-5581ac88c60b0a3f7595088b30a8621f280b5e4c.tar.gz rneovim-5581ac88c60b0a3f7595088b30a8621f280b5e4c.tar.bz2 rneovim-5581ac88c60b0a3f7595088b30a8621f280b5e4c.zip |
Merge pull request #12568 from nvim-treesitter/bytetrack
Bytetrack
Diffstat (limited to 'runtime/lua/vim/treesitter/highlighter.lua')
-rw-r--r-- | runtime/lua/vim/treesitter/highlighter.lua | 13 |
1 files changed, 5 insertions, 8 deletions
diff --git a/runtime/lua/vim/treesitter/highlighter.lua b/runtime/lua/vim/treesitter/highlighter.lua index b261d51d4a..718088e0ad 100644 --- a/runtime/lua/vim/treesitter/highlighter.lua +++ b/runtime/lua/vim/treesitter/highlighter.lua @@ -60,14 +60,11 @@ function TSHighlighter.new(query, bufnr, ft) ft, { on_changedtree = function(...) self:on_changedtree(...) end, - on_lines = function() self.root = self.parser:parse():root() end + on_bytes = function() self.parser:parse() end } ) self.buf = self.parser.bufnr - - local tree = self.parser:parse() - self.root = tree:root() self:set_query(query) self.edit_count = 0 self.redraw_count = 0 @@ -126,17 +123,17 @@ function TSHighlighter:set_query(query) end }) - self:on_changedtree({{self.root:range()}}) + self:on_changedtree({{self.parser:parse():root():range()}}) end function TSHighlighter:on_changedtree(changes) -- Get a fresh root - self.root = self.parser.tree:root() + local root = self.parser:parse():root() for _, ch in ipairs(changes or {}) do - a.nvim_buf_clear_namespace(self.buf, ts_hs_ns, ch[1], ch[3] + 1) + a.nvim_buf_clear_namespace(self.buf, ts_hs_ns, ch[1], ch[3]+1) - for capture, node in self.query:iter_captures(self.root, self.buf, ch[1], ch[3] + 1) do + for capture, node in self.query:iter_captures(root, self.buf, ch[1], ch[3] + 1) do local start_row, start_col, end_row, end_col = node:range() local hl = self.hl_cache[capture] if hl then |