diff options
author | Riley Bruins <ribru17@hotmail.com> | 2024-09-13 05:09:11 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-13 05:09:11 -0700 |
commit | b9b408a56c7e607972beaa7214719ff1494e384c (patch) | |
tree | 92c415c133cd2d591000d314df0a026c49961e17 /runtime/lua/vim/treesitter/_query_linter.lua | |
parent | 8654a9700690a715e35baa600bb982f4ea608ead (diff) | |
download | rneovim-b9b408a56c7e607972beaa7214719ff1494e384c.tar.gz rneovim-b9b408a56c7e607972beaa7214719ff1494e384c.tar.bz2 rneovim-b9b408a56c7e607972beaa7214719ff1494e384c.zip |
feat(treesitter): start moving get_parser to return nil #30313
**Problem:** `vim.treesitter.get_parser` will throw an error if no parser
can be found.
- This means the caller is responsible for wrapping it in a `pcall`,
which is easy to forget
- It also makes it slightly harder to potentially memoize `get_parser`
in the future
- It's a bit unintuitive since many other `get_*` style functions
conventionally return `nil` if no object is found (e.g. `get_node`,
`get_lang`, `query.get`, etc.)
**Solution:** Return `nil` if no parser can be found or created
- This requires a function signature change, and some new assertions in
places where the parser will always (or should always) be found.
- This commit starts by making this change internally, since it is
breaking. Eventually it will be rolled out to the public API.
Diffstat (limited to 'runtime/lua/vim/treesitter/_query_linter.lua')
-rw-r--r-- | runtime/lua/vim/treesitter/_query_linter.lua | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/runtime/lua/vim/treesitter/_query_linter.lua b/runtime/lua/vim/treesitter/_query_linter.lua index ea1ae5416a..30acef559e 100644 --- a/runtime/lua/vim/treesitter/_query_linter.lua +++ b/runtime/lua/vim/treesitter/_query_linter.lua @@ -172,7 +172,7 @@ function M.lint(buf, opts) --- @type (table|nil) local parser_info = vim.F.npcall(vim.treesitter.language.inspect, lang) - local parser = vim.treesitter.get_parser(buf) + local parser = assert(vim.treesitter._get_parser(buf), 'query parser not found.') parser:parse() parser:for_each_tree(function(tree, ltree) if ltree:lang() == 'query' then |