From d05728e155ced9a815bb3f6fc9e8004093beb3d3 Mon Sep 17 00:00:00 2001 From: Thomas Vigouroux Date: Mon, 20 Apr 2020 16:18:02 +0200 Subject: feat: syntax highlighting --- lua/nvim-treesitter.lua | 3 +++ lua/nvim-treesitter/highlight.lua | 17 +++++++++++++++++ lua/nvim-treesitter/query.lua | 2 +- 3 files changed, 21 insertions(+), 1 deletion(-) create mode 100644 lua/nvim-treesitter/highlight.lua (limited to 'lua') diff --git a/lua/nvim-treesitter.lua b/lua/nvim-treesitter.lua index 8f2fa05ed..b053f39b0 100644 --- a/lua/nvim-treesitter.lua +++ b/lua/nvim-treesitter.lua @@ -3,6 +3,7 @@ local parsers = require'nvim-treesitter.parsers' local configs = require 'nvim-treesitter.configs' local install = require'nvim-treesitter.install' local locals = require'nvim-treesitter.locals' +local highlight = require'nvim-treesitter.highlight' local M = {} @@ -14,6 +15,8 @@ end -- this is the main interface through the plugin function M.setup(lang) if parsers.has_parser(lang) then + local autocmd = "autocmd NvimTreesitter FileType %s lua require'nvim-treesitter.highlight'.setup()" + api.nvim_command(string.format(autocmd, lang)) end end diff --git a/lua/nvim-treesitter/highlight.lua b/lua/nvim-treesitter/highlight.lua new file mode 100644 index 000000000..4acb202b5 --- /dev/null +++ b/lua/nvim-treesitter/highlight.lua @@ -0,0 +1,17 @@ +local api = vim.api +local queries = require'nvim-treesitter.query' +local ts = vim.treesitter + +local M = {} + +function M.setup(bufnr, ft) + local buf = bufnr or api.nvim_get_current_buf() + local ft = ft or api.nvim_buf_get_option(buf, 'ft') + + local query = queries.get_query(ft, "highlights") + if not query then return end + + ts.TSHighlighter.new(query, buf, ft) +end + +return M diff --git a/lua/nvim-treesitter/query.lua b/lua/nvim-treesitter/query.lua index e9f671f93..277c29697 100644 --- a/lua/nvim-treesitter/query.lua +++ b/lua/nvim-treesitter/query.lua @@ -62,7 +62,7 @@ function M.iter_prepared_matches(query, qnode, bufnr, start_row, end_row) local preds = query.info.patterns[pattern] if preds then for _, pred in pairs(preds) do - if pred[1] == "set!" and pred[2] ~= nil then + if pred[1] == "set!" and type(pred[2]) == "string" then insert_to_path(prepared_match, split(pred[2]), pred[3]) end end -- cgit v1.2.3-70-g09d2