diff options
author | Lewis Russell <lewis6991@gmail.com> | 2023-02-21 17:09:18 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-02-21 17:09:18 +0000 |
commit | 8714a4009c0f0be0bb27a6b3eb486eeb3d9f3049 (patch) | |
tree | ba930952af970a189e735f3b6f001d92a0fff72f /runtime/lua/vim/treesitter.lua | |
parent | 344a1ee8e6b7d78120f8393d1babfd285e866334 (diff) | |
download | rneovim-8714a4009c0f0be0bb27a6b3eb486eeb3d9f3049.tar.gz rneovim-8714a4009c0f0be0bb27a6b3eb486eeb3d9f3049.tar.bz2 rneovim-8714a4009c0f0be0bb27a6b3eb486eeb3d9f3049.zip |
feat(treesitter): add filetype -> lang API
Problem:
vim.treesitter does not know how to map a specific filetype to a parser.
This creates problems since in a few places (including in vim.treesitter itself), the filetype is incorrectly used in place of lang.
Solution:
Add an API to enable this:
- Add vim.treesitter.language.add() as a replacement for vim.treesitter.language.require_language().
- Optional arguments are now passed via an opts table.
- Also takes a filetype (or list of filetypes) so we can keep track of what filetypes are associated with which langs.
- Deprecated vim.treesitter.language.require_language().
- Add vim.treesitter.language.get_lang() which returns the associated lang for a given filetype.
- Add vim.treesitter.language.register() to associate filetypes to a lang without loading the parser.
Diffstat (limited to 'runtime/lua/vim/treesitter.lua')
-rw-r--r-- | runtime/lua/vim/treesitter.lua | 24 |
1 files changed, 14 insertions, 10 deletions
diff --git a/runtime/lua/vim/treesitter.lua b/runtime/lua/vim/treesitter.lua index 4127198576..c524b20bc2 100644 --- a/runtime/lua/vim/treesitter.lua +++ b/runtime/lua/vim/treesitter.lua @@ -29,6 +29,8 @@ setmetatable(M, { end, }) +---@diagnostic disable:invisible + --- Creates a new parser --- --- It is not recommended to use this; use |get_parser()| instead. @@ -39,16 +41,15 @@ setmetatable(M, { --- ---@return LanguageTree object to use for parsing function M._create_parser(bufnr, lang, opts) - language.require_language(lang) if bufnr == 0 then bufnr = vim.api.nvim_get_current_buf() end vim.fn.bufload(bufnr) - local self = LanguageTree.new(bufnr, lang, opts) + language.add(lang, { filetype = vim.bo[bufnr].filetype }) - ---@diagnostic disable:invisible + local self = LanguageTree.new(bufnr, lang, opts) ---@private local function bytes_cb(_, ...) @@ -96,13 +97,16 @@ function M.get_parser(bufnr, lang, opts) if bufnr == nil or bufnr == 0 then bufnr = a.nvim_get_current_buf() end + if lang == nil then + local ft = vim.bo[bufnr].filetype + lang = language.get_lang(ft) or ft + -- TODO(lewis6991): we should error here and not default to ft + -- if not lang then + -- error(string.format('filetype %s of buffer %d is not associated with any lang', ft, bufnr)) + -- end + end - if parsers[bufnr] == nil then - lang = lang or a.nvim_buf_get_option(bufnr, 'filetype') - parsers[bufnr] = M._create_parser(bufnr, lang, opts) - elseif lang and parsers[bufnr]:lang() ~= lang then - -- Only try to create a new parser if lang is provided - -- and it doesn't match the stored parser + if parsers[bufnr] == nil or parsers[bufnr]:lang() ~= lang then parsers[bufnr] = M._create_parser(bufnr, lang, opts) end @@ -123,7 +127,7 @@ function M.get_string_parser(str, lang, opts) str = { str, 'string' }, lang = { lang, 'string' }, }) - language.require_language(lang) + language.add(lang) return LanguageTree.new(str, lang, opts) end |