diff options
Diffstat (limited to 'lua')
| -rw-r--r-- | lua/nvim-treesitter.lua | 3 | ||||
| -rw-r--r-- | lua/nvim-treesitter/lib.lua | 19 | ||||
| -rw-r--r-- | lua/nvim-treesitter/parsers.lua | 21 | ||||
| -rw-r--r-- | lua/nvim-treesitter/query.lua | 76 |
4 files changed, 100 insertions, 19 deletions
diff --git a/lua/nvim-treesitter.lua b/lua/nvim-treesitter.lua index cbed117d2..ab3edf071 100644 --- a/lua/nvim-treesitter.lua +++ b/lua/nvim-treesitter.lua @@ -1,10 +1,13 @@ local api = vim.api +local parsers = require'nvim-treesitter.parsers' local M = {} -- This function sets up everythin needed for a given language -- this is the main interface through the plugin function M.setup(lang) + if parsers.has_parser(lang) then + end end return M diff --git a/lua/nvim-treesitter/lib.lua b/lua/nvim-treesitter/lib.lua deleted file mode 100644 index 328e4a571..000000000 --- a/lua/nvim-treesitter/lib.lua +++ /dev/null @@ -1,19 +0,0 @@ --- Treesitter utils - -local api = vim.api -local ts = vim.treesitter - -local M = {} - -local function read_query_file(fname) - return table.concat(vim.fn.readfile(fname), '\n') -end - -function M.get_query(ft, query_name) - local query_files = api.nvim_get_runtime_file(string.format('queries/%s/%s.scm', ft, query_name), false) - if #query_files > 0 then - return ts.parse_query(ft, read_query_file(query_files[1])) - end -end - -return M diff --git a/lua/nvim-treesitter/parsers.lua b/lua/nvim-treesitter/parsers.lua new file mode 100644 index 000000000..c85177733 --- /dev/null +++ b/lua/nvim-treesitter/parsers.lua @@ -0,0 +1,21 @@ +local api = vim.api +local ts = vim.treesitter + +local M = {} + +function M.has_parser(lang) + local lang = lang or api.nvim_buf_get_option(0, 'filetype') + return #api.nvim_get_runtime_file('parser/' .. lang .. '.*', false) > 0 +end + +function M.get_parser(bufnr) + if M.has_parser() then + local buf = bufnr or api.nvim_get_current_buf() + if not M[buf] then + M[buf] = ts.get_parser(buf) + end + return M[buf] + end +end + +return M diff --git a/lua/nvim-treesitter/query.lua b/lua/nvim-treesitter/query.lua new file mode 100644 index 000000000..be650c795 --- /dev/null +++ b/lua/nvim-treesitter/query.lua @@ -0,0 +1,76 @@ +-- Treesitter utils + +local api = vim.api +local ts = vim.treesitter + +local M = {} + +local function read_query_file(fname) + return table.concat(vim.fn.readfile(fname), '\n') +end + +function M.get_query(ft, query_name) + local query_files = api.nvim_get_runtime_file(string.format('queries/%s/%s.scm', ft, query_name), false) + if #query_files > 0 then + return ts.parse_query(ft, read_query_file(query_files[1])) + end +end + +function M.iter_prepared_matches(query, qnode, bufnr, start_row, end_row) + -- A function that splits a string on '.' + local function split(string) + local t = {} + for str in string.gmatch(string, "([^.]+)") do + table.insert(t, str) + end + + return t + end + + -- Given a path (i.e. a List(String)) this functions inserts value at path + local function insert_to_path(object, path, value) + local curr_obj = object + + for index=1,(#path -1) do + if curr_obj[path[index]] == nil then + curr_obj[path[index]] = {} + end + + curr_obj = curr_obj[path[index]] + end + + curr_obj[path[#path]] = value + end + + local matches = query:iter_matches(qnode, bufnr, start_row, end_row) + + return function() + local pattern, match = matches() + if pattern ~= nil then + local prepared_match = {} + + -- Extract capture names from each match + for id, node in pairs(match) do + local name = query.captures[id] -- name of the capture in the query + if name ~= nil then + local path = split(name) + insert_to_path(prepared_match, path, node) + end + end + + -- Add some predicates for testing + local preds = query.info.patterns[pattern] + if preds then + for _, pred in pairs(preds) do + if pred[1] == "set!" and pred[2] ~= nil then + insert_to_path(prepared_match, split(pred[2]), pred[3]) + end + end + end + + return prepared_match + end + end +end + +return M |
