feat(diagnostics): More responsive and configurable diagnostics signs. (#303)

This commit is contained in:
Sindre T. Strøm
2021-04-16 17:57:16 +02:00
committed by GitHub
parent 090697e71f
commit da09da3318
6 changed files with 51 additions and 18 deletions

View File

@@ -67,6 +67,12 @@ let g:nvim_tree_icons = {
\ 'empty_open': "", \ 'empty_open': "",
\ 'symlink': "", \ 'symlink': "",
\ 'symlink_open': "", \ 'symlink_open': "",
\ },
\ 'lsp': {
\ 'hint': "",
\ 'info': "",
\ 'warning': "",
\ 'error': "",
\ } \ }
\ } \ }

View File

@@ -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*

View File

@@ -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 {

View File

@@ -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)

View File

@@ -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

View File

@@ -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