feat(diagnostics): More responsive and configurable diagnostics signs. (#303)
This commit is contained in:
@@ -67,6 +67,12 @@ let g:nvim_tree_icons = {
|
|||||||
\ 'empty_open': "",
|
\ 'empty_open': "",
|
||||||
\ 'symlink': "",
|
\ 'symlink': "",
|
||||||
\ 'symlink_open': "",
|
\ 'symlink_open': "",
|
||||||
|
\ },
|
||||||
|
\ 'lsp': {
|
||||||
|
\ 'hint': "",
|
||||||
|
\ 'info': "",
|
||||||
|
\ 'warning': "",
|
||||||
|
\ 'error': "",
|
||||||
\ }
|
\ }
|
||||||
\ }
|
\ }
|
||||||
|
|
||||||
|
|||||||
@@ -229,7 +229,7 @@ together. 0 by default.
|
|||||||
|
|
||||||
Can be 0 or 1. When 1, will show nvim-lsp diagnostics in the signcolumn
|
Can be 0 or 1. When 1, will show nvim-lsp diagnostics in the signcolumn
|
||||||
of the tree highlighted by diagnostic severity.
|
of the tree highlighted by diagnostic severity.
|
||||||
Code will be executed on `BufWritePost`. 0 by default.
|
Code will be executed on `LspDiagnosticsChanged`. 0 by default.
|
||||||
|
|
||||||
==============================================================================
|
==============================================================================
|
||||||
INFORMATIONS *nvim-tree-info*
|
INFORMATIONS *nvim-tree-info*
|
||||||
|
|||||||
@@ -21,7 +21,13 @@ function M.get_icon_state()
|
|||||||
empty_open = "",
|
empty_open = "",
|
||||||
symlink = "",
|
symlink = "",
|
||||||
symlink_open = "",
|
symlink_open = "",
|
||||||
}
|
},
|
||||||
|
lsp = {
|
||||||
|
hint = "",
|
||||||
|
info = "",
|
||||||
|
warning = "",
|
||||||
|
error = "",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
local user_icons = vim.g.nvim_tree_icons
|
local user_icons = vim.g.nvim_tree_icons
|
||||||
@@ -43,6 +49,11 @@ function M.get_icon_state()
|
|||||||
icons.folder_icons[key] = val
|
icons.folder_icons[key] = val
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
for key, val in pairs(user_icons.lsp or {}) do
|
||||||
|
if icons.lsp[key] then
|
||||||
|
icons.lsp[key] = val
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
|||||||
@@ -1,14 +1,16 @@
|
|||||||
local a = vim.api
|
local a = vim.api
|
||||||
local utils = require'nvim-tree.utils'
|
local utils = require'nvim-tree.utils'
|
||||||
local view = require'nvim-tree.view'
|
local view = require'nvim-tree.view'
|
||||||
|
local config = require'nvim-tree.config'
|
||||||
|
local icon_state = config.get_icon_state()
|
||||||
local get_diagnostics = vim.lsp.diagnostic.get_all
|
local get_diagnostics = vim.lsp.diagnostic.get_all
|
||||||
|
|
||||||
local M = {}
|
local M = {}
|
||||||
|
|
||||||
local function get_highest_severity(diagnostics)
|
local function get_lowest_severity(diagnostics)
|
||||||
local severity = 0
|
local severity = math.huge
|
||||||
for _, v in ipairs(diagnostics) do
|
for _, v in ipairs(diagnostics) do
|
||||||
if v.severity > severity then
|
if v.severity < severity then
|
||||||
severity = v.severity
|
severity = v.severity
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -16,21 +18,22 @@ local function get_highest_severity(diagnostics)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local sign_names = {
|
local sign_names = {
|
||||||
{ "NvimTreeSignHint", "NvimTreeLspDiagnosticsHint" },
|
|
||||||
{ "NvimTreeSignInformation", "NvimTreeLspDiagnosticsInformation" },
|
|
||||||
{ "NvimTreeSignWarning", "NvimTreeLspDiagnosticsWarning" },
|
|
||||||
{ "NvimTreeSignError", "NvimTreeLspDiagnosticsError" },
|
{ "NvimTreeSignError", "NvimTreeLspDiagnosticsError" },
|
||||||
|
{ "NvimTreeSignWarning", "NvimTreeLspDiagnosticsWarning" },
|
||||||
|
{ "NvimTreeSignInformation", "NvimTreeLspDiagnosticsInformation" },
|
||||||
|
{ "NvimTreeSignHint", "NvimTreeLspDiagnosticsHint" },
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, v in ipairs(sign_names) do
|
vim.fn.sign_define(sign_names[1][1], { text=icon_state.icons.lsp.error, texthl=sign_names[1][2]})
|
||||||
vim.fn.sign_define(v[1], { text="⚠", texthl=v[2]})
|
vim.fn.sign_define(sign_names[2][1], { text=icon_state.icons.lsp.warning, texthl=sign_names[2][2]})
|
||||||
end
|
vim.fn.sign_define(sign_names[3][1], { text=icon_state.icons.lsp.info, texthl=sign_names[3][2]})
|
||||||
|
vim.fn.sign_define(sign_names[4][1], { text=icon_state.icons.lsp.hint, texthl=sign_names[4][2]})
|
||||||
|
|
||||||
local signs = {}
|
local signs = {}
|
||||||
|
|
||||||
local function add_sign(linenr, severity)
|
local function add_sign(linenr, severity)
|
||||||
local buf = view.View.bufnr
|
local buf = view.View.bufnr
|
||||||
if not vim.fn.bufexists(buf) or not vim.fn.bufloaded(buf) then return end
|
if not a.nvim_buf_is_valid(buf) or not a.nvim_buf_is_loaded(buf) then return end
|
||||||
local sign_name = sign_names[severity][1]
|
local sign_name = sign_names[severity][1]
|
||||||
table.insert(signs, vim.fn.sign_place(1, 'NvimTreeDiagnosticSigns', sign_name, buf, { lnum = linenr+1 }))
|
table.insert(signs, vim.fn.sign_place(1, 'NvimTreeDiagnosticSigns', sign_name, buf, { lnum = linenr+1 }))
|
||||||
end
|
end
|
||||||
@@ -39,12 +42,14 @@ function M.update()
|
|||||||
local buffer_severity = {}
|
local buffer_severity = {}
|
||||||
|
|
||||||
for buf, diagnostics in pairs(get_diagnostics()) do
|
for buf, diagnostics in pairs(get_diagnostics()) do
|
||||||
|
if a.nvim_buf_is_valid(buf) then
|
||||||
local bufname = a.nvim_buf_get_name(buf)
|
local bufname = a.nvim_buf_get_name(buf)
|
||||||
if not buffer_severity[bufname] then
|
if not buffer_severity[bufname] then
|
||||||
local severity = get_highest_severity(diagnostics)
|
local severity = get_lowest_severity(diagnostics)
|
||||||
buffer_severity[bufname] = severity
|
buffer_severity[bufname] = severity
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
local nodes = require'nvim-tree.lib'.Tree.entries
|
local nodes = require'nvim-tree.lib'.Tree.entries
|
||||||
if #signs then
|
if #signs then
|
||||||
@@ -58,7 +63,7 @@ function M.update()
|
|||||||
signs = {}
|
signs = {}
|
||||||
end
|
end
|
||||||
for bufname, severity in pairs(buffer_severity) do
|
for bufname, severity in pairs(buffer_severity) do
|
||||||
if severity > 0 then
|
if 0 < severity and severity < 5 then
|
||||||
local node, line = utils.find_node(nodes, function(node)
|
local node, line = utils.find_node(nodes, function(node)
|
||||||
return node.absolute_path == bufname
|
return node.absolute_path == bufname
|
||||||
end)
|
end)
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ local luv = vim.loop
|
|||||||
local renderer = require'nvim-tree.renderer'
|
local renderer = require'nvim-tree.renderer'
|
||||||
local config = require'nvim-tree.config'
|
local config = require'nvim-tree.config'
|
||||||
local git = require'nvim-tree.git'
|
local git = require'nvim-tree.git'
|
||||||
|
local diagnostics = require'nvim-tree.diagnostics'
|
||||||
local pops = require'nvim-tree.populate'
|
local pops = require'nvim-tree.populate'
|
||||||
local utils = require'nvim-tree.utils'
|
local utils = require'nvim-tree.utils'
|
||||||
local view = require'nvim-tree.view'
|
local view = require'nvim-tree.view'
|
||||||
@@ -115,6 +116,11 @@ function M.unroll_dir(node)
|
|||||||
git.git_root(node.absolute_path)
|
git.git_root(node.absolute_path)
|
||||||
git.update_gitignore_map_sync()
|
git.update_gitignore_map_sync()
|
||||||
populate(node.entries, node.link_to or node.absolute_path, node)
|
populate(node.entries, node.link_to or node.absolute_path, node)
|
||||||
|
|
||||||
|
if vim.g.nvim_tree_lsp_diagnostics == 1 then
|
||||||
|
diagnostics.update()
|
||||||
|
end
|
||||||
|
|
||||||
renderer.draw(M.Tree, true)
|
renderer.draw(M.Tree, true)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -151,6 +157,11 @@ function M.refresh_tree()
|
|||||||
git.reload_roots()
|
git.reload_roots()
|
||||||
refresh_git(M.Tree)
|
refresh_git(M.Tree)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if vim.g.nvim_tree_lsp_diagnostics == 1 then
|
||||||
|
diagnostics.update()
|
||||||
|
end
|
||||||
|
|
||||||
if view.win_open() then
|
if view.win_open() then
|
||||||
renderer.draw(M.Tree, true)
|
renderer.draw(M.Tree, true)
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ augroup NvimTree
|
|||||||
endif
|
endif
|
||||||
au BufWritePost * lua require'nvim-tree'.refresh()
|
au BufWritePost * lua require'nvim-tree'.refresh()
|
||||||
if get(g:, 'nvim_tree_lsp_diagnostics', 0) == 1
|
if get(g:, 'nvim_tree_lsp_diagnostics', 0) == 1
|
||||||
au BufWritePost * lua require'nvim-tree.diagnostics'.update()
|
au User LspDiagnosticsChanged lua require'nvim-tree.diagnostics'.update()
|
||||||
endif
|
endif
|
||||||
au BufEnter * lua require'nvim-tree'.buf_enter()
|
au BufEnter * lua require'nvim-tree'.buf_enter()
|
||||||
if get(g:, 'nvim_tree_auto_close') == 1
|
if get(g:, 'nvim_tree_auto_close') == 1
|
||||||
|
|||||||
Reference in New Issue
Block a user