aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2025-03-10 14:48:50 -0700
committerGitHub <noreply@github.com>2025-03-10 14:48:50 -0700
commitf2c0755828d529af101b5d0e4a1fd204fd0a7039 (patch)
treede21ac52c18d7fc6be4d48120a33c45791444783
parentdebabaf884fc26e9dc257aa5b62581d3846f80f1 (diff)
parente00d67ef310cab43ac60610c710d36c1c0903759 (diff)
downloadrneovim-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.lua31
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