diff options
author | Justin M. Keyes <justinkz@gmail.com> | 2025-03-10 14:48:50 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-03-10 14:48:50 -0700 |
commit | f2c0755828d529af101b5d0e4a1fd204fd0a7039 (patch) | |
tree | de21ac52c18d7fc6be4d48120a33c45791444783 | |
parent | debabaf884fc26e9dc257aa5b62581d3846f80f1 (diff) | |
parent | e00d67ef310cab43ac60610c710d36c1c0903759 (diff) | |
download | rneovim-f2c0755828d529af101b5d0e4a1fd204fd0a7039.tar.gz rneovim-f2c0755828d529af101b5d0e4a1fd204fd0a7039.tar.bz2 rneovim-f2c0755828d529af101b5d0e4a1fd204fd0a7039.zip |
Merge pull request #32825 from moguls753/issue-32714-redundant-parsers
feat(checkhealth): group parsers by name and path in output
-rw-r--r-- | runtime/lua/vim/treesitter/health.lua | 31 |
1 files changed, 25 insertions, 6 deletions
diff --git a/runtime/lua/vim/treesitter/health.lua b/runtime/lua/vim/treesitter/health.lua index 0c9e210fc1..fb352382b8 100644 --- a/runtime/lua/vim/treesitter/health.lua +++ b/runtime/lua/vim/treesitter/health.lua @@ -19,23 +19,42 @@ function M.check() health.start('Treesitter parsers') local parsers = vim.api.nvim_get_runtime_file('parser/*', true) - for _, parser in pairs(parsers) do + + ---@class ParserEntry + ---@field name string + ---@field path string + + local sorted_parsers = {} ---@type ParserEntry[] + + for _, parser in ipairs(parsers) do local parsername = vim.fn.fnamemodify(parser, ':t:r') - local is_loadable, err_or_nil = pcall(ts.language.add, parsername) + table.insert(sorted_parsers, { name = parsername, path = parser }) + end + + table.sort(sorted_parsers, function(a, b) + if a.name == b.name then + return a.path < b.path + else + return a.name < b.name + end + end) + + for _, parser in ipairs(sorted_parsers) do + local is_loadable, err_or_nil = pcall(ts.language.add, parser.name) if not is_loadable then health.error( string.format( 'Parser "%s" failed to load (path: %s): %s', - parsername, - parser, + parser.name, + parser.path, err_or_nil or '?' ) ) else - local lang = ts.language.inspect(parsername) + local lang = ts.language.inspect(parser.name) health.ok( - string.format('Parser: %-20s ABI: %d, path: %s', parsername, lang.abi_version, parser) + string.format('Parser: %-20s ABI: %d, path: %s', parser.name, lang.abi_version, parser.path) ) end end |