Browse Source

Merge pull request #14200 from teto/treesitter-checkhealth

feat: treesitter checkhealth
pull/13459/merge
Marco Hinz 1 week ago
committed by GitHub
parent
commit
cd75d3289a
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 48 additions and 1 deletions
  1. +5
    -0
      runtime/autoload/health/treesitter.vim
  2. +3
    -0
      runtime/lua/vim/treesitter.lua
  3. +34
    -0
      runtime/lua/vim/treesitter/health.lua
  4. +5
    -0
      src/nvim/lua/treesitter.c
  5. +1
    -1
      test/functional/treesitter/language_spec.lua

+ 5
- 0
runtime/autoload/health/treesitter.vim View File

@ -0,0 +1,5 @@
function! health#treesitter#check() abort
call health#report_start('Checking treesitter configuration')
lua require 'vim.treesitter.health'.check_health()
endfunction

+ 3
- 0
runtime/lua/vim/treesitter.lua View File

@ -17,6 +17,9 @@ setmetatable(M, {
if k == "highlighter" then
t[k] = require'vim.treesitter.highlighter'
return t[k]
elseif k == "language" then
t[k] = require"vim.treesitter.language"
return t[k]
end
end
})


+ 34
- 0
runtime/lua/vim/treesitter/health.lua View File

@ -0,0 +1,34 @@
local M = {}
local ts = vim.treesitter
function M.list_parsers()
return vim.api.nvim_get_runtime_file('parser/*', true)
end
function M.check_health()
local report_info = vim.fn['health#report_info']
local report_ok = vim.fn['health#report_ok']
local report_error = vim.fn['health#report_error']
local parsers = M.list_parsers()
report_info(string.format("Runtime ABI version : %d", ts.language_version))
for _, parser in pairs(parsers) do
local parsername = vim.fn.fnamemodify(parser, ":t:r")
local is_loadable, ret = pcall(ts.language.require_language, parsername)
if not is_loadable then
report_error(string.format("Impossible to load parser for %s: %s", parsername, ret))
elseif ret then
local lang = ts.language.inspect_language(parsername)
report_ok(string.format("Loaded parser for %s: ABI version %d",
parsername, lang._abi_version))
else
report_error(string.format("Unable to load parser for %s", parsername))
end
end
end
return M

+ 5
- 0
src/nvim/lua/treesitter.c View File

@ -230,6 +230,11 @@ int tslua_inspect_lang(lua_State *L)
}
lua_setfield(L, -2, "fields"); // [retval]
uint32_t lang_version = ts_language_version(lang);
lua_pushinteger(L, lang_version); // [retval, version]
lua_setfield(L, -2, "_abi_version");
return 1;
}


+ 1
- 1
test/functional/treesitter/language_spec.lua View File

@ -45,7 +45,7 @@ describe('treesitter API', function()
return {keys, lang.fields, symbols}
]]))
eq({fields=true, symbols=true}, keys)
eq({fields=true, symbols=true, _abi_version=true}, keys)
local fset = {}
for _,f in pairs(fields) do


Loading…
Cancel
Save