diff options
| author | Steven Sojka <steelsojka@gmail.com> | 2020-08-15 09:24:24 -0500 |
|---|---|---|
| committer | Steven Sojka <steelsojka@gmail.com> | 2020-08-16 09:04:07 -0500 |
| commit | 579c9936d617ca1d7f01542a4b8000972c1ce73c (patch) | |
| tree | 8b9cbb24ab959ad45a8e8611edd7cf20d707b327 /lua/nvim-treesitter/query_predicates.lua | |
| parent | 994baf45396972d9eb6b918e0757d2eceecc8130 (diff) | |
feat(highlights): add is predicate
Diffstat (limited to 'lua/nvim-treesitter/query_predicates.lua')
| -rw-r--r-- | lua/nvim-treesitter/query_predicates.lua | 38 |
1 files changed, 33 insertions, 5 deletions
diff --git a/lua/nvim-treesitter/query_predicates.lua b/lua/nvim-treesitter/query_predicates.lua index 67850dea..f6a21f28 100644 --- a/lua/nvim-treesitter/query_predicates.lua +++ b/lua/nvim-treesitter/query_predicates.lua @@ -4,12 +4,25 @@ local function error(str) vim.api.nvim_err_writeln(str) end -query.add_predicate("nth?", function(match, pattern, bufnr, pred) - if #pred ~= 3 then - error("nth? must hav exactly two arguments") - return +local function valid_args(name, pred, count, strict_count) + local arg_count = #pred - 1 + + if strict_count then + if arg_count ~= count then + error(string.format("%s must have exactly %d arguments", name, count)) + return false + end + elseif arg_count < count then + error(string.format("%s must have at least %d arguments", name, count)) + return false end + return true +end + +query.add_predicate("nth?", function(match, pattern, bufnr, pred) + if not valid_args("nth?", pred, 2, true) then return end + local node = match[pred[2]] local n = pred[3] - 1 if node and node:parent() and node:named_child_count() > n then @@ -20,7 +33,7 @@ query.add_predicate("nth?", function(match, pattern, bufnr, pred) end) query.add_predicate('has-ancestor?', function(match, pattern, bufnr, pred) - if #pred ~= 3 then error("has-ancestor? must have exactly two arguments!") return end + if not valid_args("has-ancestor?", pred, 2, true) then return end local node = match[pred[2]] local ancestor_type = pred[3] @@ -35,3 +48,18 @@ query.add_predicate('has-ancestor?', function(match, pattern, bufnr, pred) end return false end) + +query.add_predicate('is?', function(match, pattern, bufnr, pred) + if not valid_args("is?", pred, 2) then return end + + -- Avoid circular dependencies + local locals = require"nvim-treesitter.locals" + local node = match[pred[2]] + local types = {unpack(pred, 3)} + + if not node then return true end + + local _, _, kind = locals.find_definition(node, bufnr) + + return vim.tbl_contains(types, kind) +end) |
