diff options
author | Abouzar Parvan <[email protected]> | 2021-09-22 10:56:52 +0330 |
---|---|---|
committer | GitHub <[email protected]> | 2021-09-22 10:56:52 +0330 |
commit | edeadaf05d98034bc91a22ad50263a7a25c6020a (patch) | |
tree | 116147fd65d0cc82bb83cec0fde39433fffbb4a2 | |
parent | 938e0f88bc3c27ce019470e0279233a373df61ef (diff) |
[Bugfix] instead of wrapping the `gl` diagnostics, split them (#1595)
-rw-r--r-- | lua/lsp/handlers.lua | 41 |
1 files changed, 27 insertions, 14 deletions
diff --git a/lua/lsp/handlers.lua b/lua/lsp/handlers.lua index 2f06cb8a..ffb7564a 100644 --- a/lua/lsp/handlers.lua +++ b/lua/lsp/handlers.lua @@ -81,7 +81,16 @@ function M.setup() }) end +local function split_by_chunk(text, chunkSize) + local s = {} + for i = 1, #text, chunkSize do + s[#s + 1] = text:sub(i, i + chunkSize - 1) + end + return s +end + function M.show_line_diagnostics() + -- TODO: replace all this with vim.diagnostic.show_position_diagnostics() local diagnostics = vim.lsp.diagnostic.get_line_diagnostics() local severity_highlight = { "LspDiagnosticsFloatingError", @@ -102,7 +111,8 @@ function M.show_line_diagnostics() } diagnostics = vim_diag.get(buf_id, { lnum = cursor_position[1] - 1 }) end - local diags = vim.deepcopy(diagnostics) + local lines = {} + local max_width = vim.fn.winwidth(0) - 5 local height = #diagnostics local width = 0 local opts = {} @@ -111,26 +121,31 @@ function M.show_line_diagnostics() return end local bufnr = vim.api.nvim_create_buf(false, true) - + local diag_message + table.sort(diagnostics, function(a, b) + return a.severity < b.severity + end) for i, diagnostic in ipairs(diagnostics) do local source = diagnostic.source + diag_message = diagnostic.message:gsub("[\n\r]", " ") if source then if string.find(source, "/") then source = string.sub(diagnostic.source, string.find(diagnostic.source, "([%w-_]+)$")) end - diags[i].message = string.format("%s: %s", source, diagnostic.message) + diag_message = string.format("%d. %s: %s", i, source, diag_message) else - diags[i].message = string.format("%s", diagnostic.message) + diag_message = string.format("%d. %s", i, diag_message) end - if diagnostic.code then - diags[i].message = string.format("%s [%s]", diags[i].message, diagnostic.code) + diag_message = string.format("%s [%s]", diag_message, diagnostic.code) + end + local msgs = split_by_chunk(diag_message, max_width) + for _, diag in ipairs(msgs) do + table.insert(lines, { message = diag, severity = diagnostic.severity }) + width = math.max(diag:len(), width) end - width = math.max(width, diags[i].message:len()) end - local max_width = vim.fn.winwidth(0) - 10 - width = math.min(width, max_width) - + height = #lines opts = vim.lsp.util.make_floating_popup_options(width, height, opts) opts["style"] = "minimal" opts["border"] = "rounded" @@ -139,11 +154,9 @@ function M.show_line_diagnostics() vim.api.nvim_buf_set_option(bufnr, "bufhidden", "wipe") local winnr = vim.api.nvim_open_win(bufnr, false, opts) vim.api.nvim_win_set_option(winnr, "winblend", 0) - vim.api.nvim_win_set_option(winnr, "wrap", true) vim.api.nvim_buf_set_var(bufnr, "lsp_floating_window", winnr) - for i, diag in ipairs(diags) do - local message = diag.message:gsub("[\n\r]", " ") - vim.api.nvim_buf_set_lines(bufnr, i - 1, i - 1, 0, { message }) + for i, diag in ipairs(lines) do + vim.api.nvim_buf_set_lines(bufnr, i - 1, i - 1, 0, { diag.message }) vim.api.nvim_buf_add_highlight(bufnr, -1, severity_highlight[diag.severity], i - 1, 0, diag.message:len()) end |