aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorQuentin Rasmont <qrasmont@gmail.com>2022-04-22 21:50:52 +0200
committerbfredl <bjorn.linse@gmail.com>2022-08-25 18:01:14 +0200
commit3aba4ba37859e4407eff2bb3f4d99c44b108ed79 (patch)
treeb64398bebd9f5f2860249056eef84016e250ca58
parent22f920030214c0023525c59daf763441baddba1a (diff)
downloadrneovim-3aba4ba37859e4407eff2bb3f4d99c44b108ed79.tar.gz
rneovim-3aba4ba37859e4407eff2bb3f4d99c44b108ed79.tar.bz2
rneovim-3aba4ba37859e4407eff2bb3f4d99c44b108ed79.zip
feat(treesitter): upstream is_parent()
Util from the nvim-treesitter project. Renamed is_parent to is_ancestor for clarity.
-rw-r--r--runtime/lua/vim/treesitter.lua23
-rw-r--r--test/functional/treesitter/utils_spec.lua29
2 files changed, 52 insertions, 0 deletions
diff --git a/runtime/lua/vim/treesitter.lua b/runtime/lua/vim/treesitter.lua
index 70f2c425ed..37ab59b259 100644
--- a/runtime/lua/vim/treesitter.lua
+++ b/runtime/lua/vim/treesitter.lua
@@ -118,4 +118,27 @@ function M.get_string_parser(str, lang, opts)
return LanguageTree.new(str, lang, opts)
end
+--- Determines whether a node is the ancestor of another
+---
+---@param dest table the possible ancestor
+---@param source table the possible descendant node
+---
+---@returns (boolean) True if dest is an ancestor of source
+function M.is_ancestor(dest, source)
+ if not (dest and source) then
+ return false
+ end
+
+ local current = source
+ while current ~= nil do
+ if current == dest then
+ return true
+ end
+
+ current = current:parent()
+ end
+
+ return false
+end
+
return M
diff --git a/test/functional/treesitter/utils_spec.lua b/test/functional/treesitter/utils_spec.lua
new file mode 100644
index 0000000000..c5609501a7
--- /dev/null
+++ b/test/functional/treesitter/utils_spec.lua
@@ -0,0 +1,29 @@
+local helpers = require('test.functional.helpers')(after_each)
+
+local clear = helpers.clear
+local insert = helpers.insert
+local eq = helpers.eq
+local exec_lua = helpers.exec_lua
+
+before_each(clear)
+
+describe('treesitter utils', function()
+ clear()
+ it('can find an ancestor', function()
+ insert([[
+ int main() {
+ int x = 3;
+ }]])
+
+ exec_lua([[
+ parser = vim.treesitter.get_parser(0, "c")
+ tree = parser:parse()[1]
+ root = tree:root()
+ ancestor = root:child(0)
+ child = ancestor:child(0)
+ ]])
+
+ eq(true, exec_lua('return vim.treesitter.is_ancestor(ancestor, child)'))
+ eq(false, exec_lua('return vim.treesitter.is_ancestor(child, ancestor)'))
+ end)
+end)