mirror of
https://github.com/neovim/neovim.git
synced 2024-12-23 20:55:18 -07:00
fix(treesitter): allow passing lang to vim.treesitter.get_node() now correctly takes opts.lang (#26360)
PROBLEM: `vim.treesitter.get_node()` does not recognize the `lang` in the option table. This option was used in somewhere else, for instance, `vim.treesitter.dev` (for `inspect_tree`) but was never implemented. SOLUTION: Make `get_node()` correctly use `opts.lang` when getting a treesitter parser.
This commit is contained in:
parent
589f4761ee
commit
cf612c64b0
@ -616,6 +616,8 @@ get_node({opts}) *vim.treesitter.get_node()*
|
|||||||
• pos table|nil 0-indexed (row, col) tuple. Defaults to cursor
|
• pos table|nil 0-indexed (row, col) tuple. Defaults to cursor
|
||||||
position in the current window. Required if {bufnr} is not
|
position in the current window. Required if {bufnr} is not
|
||||||
the current buffer
|
the current buffer
|
||||||
|
• lang string|nil Parser language. (default: from buffer
|
||||||
|
filetype)
|
||||||
• ignore_injections boolean Ignore injected languages (default
|
• ignore_injections boolean Ignore injected languages (default
|
||||||
true)
|
true)
|
||||||
|
|
||||||
|
@ -362,6 +362,7 @@ end
|
|||||||
--- - bufnr integer|nil Buffer number (nil or 0 for current buffer)
|
--- - bufnr integer|nil Buffer number (nil or 0 for current buffer)
|
||||||
--- - pos table|nil 0-indexed (row, col) tuple. Defaults to cursor position in the
|
--- - pos table|nil 0-indexed (row, col) tuple. Defaults to cursor position in the
|
||||||
--- current window. Required if {bufnr} is not the current buffer
|
--- current window. Required if {bufnr} is not the current buffer
|
||||||
|
--- - lang string|nil Parser language. (default: from buffer filetype)
|
||||||
--- - ignore_injections boolean Ignore injected languages (default true)
|
--- - ignore_injections boolean Ignore injected languages (default true)
|
||||||
---
|
---
|
||||||
---@return TSNode | nil Node at the given position
|
---@return TSNode | nil Node at the given position
|
||||||
@ -392,7 +393,7 @@ function M.get_node(opts)
|
|||||||
|
|
||||||
local ts_range = { row, col, row, col }
|
local ts_range = { row, col, row, col }
|
||||||
|
|
||||||
local root_lang_tree = M.get_parser(bufnr)
|
local root_lang_tree = M.get_parser(bufnr, opts.lang)
|
||||||
if not root_lang_tree then
|
if not root_lang_tree then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
@ -40,6 +40,20 @@ describe('treesitter node API', function()
|
|||||||
assert_alive()
|
assert_alive()
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
it('get_node() with lang given', function()
|
||||||
|
-- this buffer doesn't have filetype set!
|
||||||
|
insert('local foo = function() end')
|
||||||
|
exec_lua([[
|
||||||
|
node = vim.treesitter.get_node({
|
||||||
|
bufnr = 0,
|
||||||
|
pos = { 0, 6 }, -- on "foo"
|
||||||
|
lang = 'lua',
|
||||||
|
})
|
||||||
|
]])
|
||||||
|
eq('foo', lua_eval('vim.treesitter.query.get_node_text(node, 0)'))
|
||||||
|
eq('identifier', lua_eval('node:type()'))
|
||||||
|
end)
|
||||||
|
|
||||||
it('can move between siblings', function()
|
it('can move between siblings', function()
|
||||||
insert([[
|
insert([[
|
||||||
int main(int x, int y, int z) {
|
int main(int x, int y, int z) {
|
||||||
|
Loading…
Reference in New Issue
Block a user