aboutsummaryrefslogtreecommitdiffstats
path: root/lua
diff options
context:
space:
mode:
Diffstat (limited to 'lua')
-rw-r--r--lua/nvim-treesitter.lua3
-rw-r--r--lua/nvim-treesitter/lib.lua19
-rw-r--r--lua/nvim-treesitter/parsers.lua21
-rw-r--r--lua/nvim-treesitter/query.lua76
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