diff options
Diffstat (limited to 'lua/lvim')
| -rw-r--r-- | lua/lvim/core/autocmds.lua | 2 | ||||
| -rw-r--r-- | lua/lvim/core/which-key.lua | 10 | ||||
| -rw-r--r-- | lua/lvim/lsp/handlers.lua | 119 | ||||
| -rw-r--r-- | lua/lvim/lsp/null-ls/init.lua | 8 | ||||
| -rw-r--r-- | lua/lvim/plugins.lua | 38 | 
5 files changed, 30 insertions, 147 deletions
| diff --git a/lua/lvim/core/autocmds.lua b/lua/lvim/core/autocmds.lua index e4577e63..adb2c509 100644 --- a/lua/lvim/core/autocmds.lua +++ b/lua/lvim/core/autocmds.lua @@ -78,7 +78,7 @@ local get_format_on_save_opts = function()  end  function M.enable_format_on_save(opts) -  local fmd_cmd = string.format(":silent lua vim.lsp.buf.formatting_sync({}, %s)", opts.timeout_ms) +  local fmd_cmd = string.format(":silent lua vim.lsp.buf.formatting_sync({}, %s)", opts.timeout)    M.define_augroups {      format_on_save = { { "BufWritePre", opts.pattern, fmd_cmd } },    } diff --git a/lua/lvim/core/which-key.lua b/lua/lvim/core/which-key.lua index a1bc3011..20c4cf0c 100644 --- a/lua/lvim/core/which-key.lua +++ b/lua/lvim/core/which-key.lua @@ -61,12 +61,12 @@ M.config = function()      -- NOTE: Prefer using : over <cmd> as the latter avoids going back in normal-mode.      -- see https://neovim.io/doc/user/map.html#:map-cmd      vmappings = { -      ["/"] = { "<ESC><CMD>lua require('Comment.api').gc(vim.fn.visualmode())<CR>", "Comment" }, +      ["/"] = { "<ESC><CMD>lua require('Comment.api').toggle_linewise_op(vim.fn.visualmode())<CR>", "Comment" },      },      mappings = {        ["w"] = { "<cmd>w!<CR>", "Save" },        ["q"] = { "<cmd>q!<CR>", "Quit" }, -      ["/"] = { "<cmd>lua require('Comment').toggle()<CR>", "Comment" }, +      ["/"] = { "<cmd>lua require('Comment.api').toggle_current_linewise()<CR>", "Comment" },        ["c"] = { "<cmd>BufferClose!<CR>", "Close Buffer" },        ["f"] = { require("lvim.core.telescope.custom-finders").find_project_files, "Find File" },        ["h"] = { "<cmd>nohlsearch<CR>", "No Highlight" }, @@ -152,11 +152,11 @@ M.config = function()          i = { "<cmd>LspInfo<cr>", "Info" },          I = { "<cmd>LspInstallInfo<cr>", "Installer Info" },          j = { -          "<cmd>lua vim.lsp.diagnostic.goto_next({popup_opts = {border = lvim.lsp.popup_border}})<cr>", +          "<cmd>lua vim.diagnostic.goto_next()<cr>",            "Next Diagnostic",          },          k = { -          "<cmd>lua vim.lsp.diagnostic.goto_prev({popup_opts = {border = lvim.lsp.popup_border}})<cr>", +          "<cmd>lua vim.diagnostic.goto_prev()<cr>",            "Prev Diagnostic",          },          l = { "<cmd>lua vim.lsp.codelens.run()<cr>", "CodeLens Action" }, @@ -166,7 +166,7 @@ M.config = function()            t = { "<cmd>lua require('lvim.lsp.peek').Peek('typeDefinition')<cr>", "Type Definition" },            i = { "<cmd>lua require('lvim.lsp.peek').Peek('implementation')<cr>", "Implementation" },          }, -        q = { "<cmd>lua vim.lsp.diagnostic.set_loclist()<cr>", "Quickfix" }, +        q = { "<cmd>lua vim.diagnostic.setloclist()<cr>", "Quickfix" },          r = { "<cmd>lua vim.lsp.buf.rename()<cr>", "Rename" },          s = { "<cmd>Telescope lsp_document_symbols<cr>", "Document Symbols" },          S = { diff --git a/lua/lvim/lsp/handlers.lua b/lua/lvim/lsp/handlers.lua index bbadf25a..5da0b21e 100644 --- a/lua/lvim/lsp/handlers.lua +++ b/lua/lvim/lsp/handlers.lua @@ -11,126 +11,15 @@ function M.setup()      severity_sort = lvim.lsp.diagnostics.severity_sort,      float = lvim.lsp.diagnostics.float,    } -  if vim.fn.has "nvim-0.6" == 1 then -    vim.diagnostic.config(config) -  else -    vim.lsp.handlers["textDocument/publishDiagnostics"] = function(_, _, params, client_id, _) -      local uri = params.uri -      local bufnr = vim.uri_to_bufnr(uri) -      if not bufnr then -        return -      end - -      local diagnostics = params.diagnostics -      vim.lsp.diagnostic.save(diagnostics, bufnr, client_id) -      if not vim.api.nvim_buf_is_loaded(bufnr) then -        return -      end -      vim.lsp.diagnostic.display(diagnostics, bufnr, client_id, config) -    end -  end - +  vim.diagnostic.config(config)    vim.lsp.handlers["textDocument/hover"] = vim.lsp.with(vim.lsp.handlers.hover, lvim.lsp.float) -    vim.lsp.handlers["textDocument/signatureHelp"] = vim.lsp.with(vim.lsp.handlers.signature_help, lvim.lsp.float)  end  function M.show_line_diagnostics() -  if vim.fn.has "nvim-0.6" == 1 then -    return vim.diagnostic.open_float(0, { scope = "line" }) -  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 -  local diagnostics = vim.lsp.diagnostic.get_line_diagnostics() -  local severity_highlight = { -    "LspDiagnosticsFloatingError", -    "LspDiagnosticsFloatingWarning", -    "LspDiagnosticsFloatingInformation", -    "LspDiagnosticsFloatingHint", -  } -  local ok, vim_diag = pcall(require, "vim.diagnostic") -  if ok then -    local buf_id = vim.api.nvim_win_get_buf(0) -    local win_id = vim.api.nvim_get_current_win() -    local cursor_position = vim.api.nvim_win_get_cursor(win_id) -    severity_highlight = { -      "DiagnosticFloatingError", -      "DiagnosticFloatingWarn", -      "DiagnosticFloatingInfo", -      "DiagnosticFloatingHint", -    } -    diagnostics = vim_diag.get(buf_id, { lnum = cursor_position[1] - 1 }) -  end -  local lines = {} -  local max_width = vim.fn.winwidth(0) - 5 -  local height = #diagnostics -  local width = 0 -  local opts = {} -  local close_events = { "CursorMoved", "CursorMovedI", "BufHidden", "InsertCharPre" } -  if height == 0 then -    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) - -  local hash = {} -  local diagnostics_no_dupes = {} -  for _, v in ipairs(diagnostics) do -    if not hash[v["message"]] then -      diagnostics_no_dupes[#diagnostics_no_dupes + 1] = v -- you could print here instead of saving to result table if you wanted -      hash[v["message"]] = true -    end -  end -  -- print(vim.inspect(diagnostics_no_dupes)) - -  for i, diagnostic in ipairs(diagnostics_no_dupes) 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 -      diag_message = string.format("%d. %s: %s", i, source, diag_message) -    else -      diag_message = string.format("%d. %s", i, diag_message) -    end -    if diagnostic.code then -      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 -  end -  height = #lines -  opts = vim.lsp.util.make_floating_popup_options(width, height, opts) -  opts["style"] = "minimal" -  opts["border"] = "rounded" -  opts["focusable"] = true - -  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_buf_set_var(bufnr, "lsp_floating_window", winnr) -  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 - -  vim.api.nvim_command( -    "autocmd QuitPre <buffer> ++nested ++once lua pcall(vim.api.nvim_win_close, " .. winnr .. ", true)" -  ) -  vim.lsp.util.close_preview_autocmd(close_events, winnr) +  local config = lvim.lsp.diagnostics.float +  config.scope = "line" +  return vim.diagnostic.open_float(0, config)  end  return M diff --git a/lua/lvim/lsp/null-ls/init.lua b/lua/lvim/lsp/null-ls/init.lua index f5e820e8..68e20c98 100644 --- a/lua/lvim/lsp/null-ls/init.lua +++ b/lua/lvim/lsp/null-ls/init.lua @@ -9,14 +9,8 @@ function M:setup()      return    end -  null_ls.config(lvim.lsp.null_ls.config)    local default_opts = require("lvim.lsp").get_common_opts() - -  if vim.tbl_isempty(lvim.lsp.null_ls.setup or {}) then -    lvim.lsp.null_ls.setup = default_opts -  end - -  require("lspconfig")["null-ls"].setup(lvim.lsp.null_ls.setup) +  null_ls.setup(vim.tbl_deep_extend("force", default_opts, lvim.lsp.null_ls.setup))  end  return M diff --git a/lua/lvim/plugins.lua b/lua/lvim/plugins.lua index ef53c3d4..c24c04d0 100644 --- a/lua/lvim/plugins.lua +++ b/lua/lvim/plugins.lua @@ -1,35 +1,35 @@  local commit = {    barbar = "6e638309efcad2f308eb9c5eaccf6f62b794bbab", -  cmp_buffer = "a0fe52489ff6e235d62407f8fa72aef80222040a", +  cmp_buffer = "e26cdfb26f645cd4c6330b541b7e74ff69daa483",    cmp_luasnip = "7bd2612533db6863381193df83f9934b373b21e1",    cmp_nvim_lsp = "134117299ff9e34adde30a735cd8ca9cf8f3db81",    cmp_nvim_lua = "d276254e7198ab7d00f117e88e223b4bd8c02d21", -  cmp_path = "d83839ae510d18530c6d36b662a9e806d4dceb73", -  comment = "eb0a84a2ea42858a2bb3cdf5fabe54e7c700555d", +  cmp_path = "81d88dfcafe26cc0cc856fc66f4677b20e6a9ffc", +  comment = "9e80d5146013275277238c89bbcaf4164f4e5140",    dapinstall = "dd09e9dd3a6e29f02ac171515b8a089fb82bb425",    fixcursorhold = "0e4e22d21975da60b0fd2d302285b3b603f9f71e", -  friendly_snippets = "4bd6974bd3fcf036a29810bf0570acea55cecfb6", +  friendly_snippets = "24481f883c980ed8c4c5c08bf8fcdd0fef57c16f",    gitsigns = "a451f97117bd1ede582a6b9db61c387c48d880b6", -  lualine = "c4a09735a68c30981c223310848f0649235ec2be", -  luasnip = "21bdf396438b98e12d5cd7c0210804e379babae3", -  nlsp_settings = "5647a930a0883362b609acb6bfe29cce4202f75d", -  null_ls = "fb9e2a64ae8e43c2255025064cfee37dc7d6a752", -  nvim_autopairs = "04cd1779f81e9d50d5a116c5dccd054b275bd191", -  nvim_cmp = "47d7cfc06abd8661e28dc919882a2fcf01c99729", -  nvim_dap = "9b8c27d6dcc21b69834fe9c2d344e49030783390", -  nvim_lsp_installer = "4d4677739f52b4aeab8909548b37cc88479c315e", -  nvim_lspconfig = "c018b1e92e66b3429a2f167d59211846774f1e3b", -  nvim_notify = "ef027e34b618eac42fb0111c1db670ba01793039", -  nvim_tree = "f408781a463c2edc3a49091b1bca5a18f790ee3d", -  nvim_treesitter = "7474cb06c2be750eae92da51ff7791deb3b21397", +  lualine = "a5b3895b57a0ca2e8fec0040afc6cfa81b2a95a4", +  luasnip = "3e4da0cfea0a2f0b4749369bc7ed247c1412a854", +  nlsp_settings = "053495bfc97c9c61bebf740acbbcaeb1ebc0704c", +  null_ls = "b7de45a0e62bf93f19db2b43ecded48c5763248d", +  nvim_autopairs = "e90e12c789851f2e0a61dd63e4b2e76701a8e2b7", +  nvim_cmp = "4a19645374b3c10538bd363e92099d94221efaea", +  nvim_dap = "a6fa644f9de62c594a8a9cf6f2aaf324b5a6108b", +  nvim_lsp_installer = "81125c9d4c076f55dab58c0ec2e282412767d134", +  nvim_lspconfig = "f84f592816a6b0c55e2a655b56c480683ad92c63", +  nvim_notify = "243811198d3a937be03535bbe899446f235dda75", +  nvim_tree = "0aec64d56c9448a039408228d410a01c41125d48", +  nvim_treesitter = "56634f49ab3d8122153c8c5582c581fb6a6af075",    nvim_ts_context_commentstring = "097df33c9ef5bbd3828105e4bee99965b758dc3f", -  nvim_web_devicons = "344331467509802e1af200f08ec3da278be5cbba", +  nvim_web_devicons = "ac71ca88b1136e1ecb2aefef4948130f31aa40d1",    packer = "851c62c5ecd3b5adc91665feda8f977e104162a5", -  plenary = "e6267f79481064eee53950571f53cbaafb08417d", +  plenary = "a672e11c816d4a91ef01253ba1a2567d20e08e55",    popup = "b7404d35d5d3548a82149238289fa71f7f6de4ac",    project = "71d0e23dcfc43cfd6bb2a97dc5a7de1ab47a6538",    structlog = "6f1403a192791ff1fa7ac845a73de9e860f781f1", -  telescope = "80cdb00b221f69348afc4fb4b701f51eb8dd3120", -- see telescope.nvim#1549 +  telescope = "9aaaa0c5f3eb665b51bbcafda084de4b0952fef0",    telescope_fzf_native = "b8662b076175e75e6497c59f3e2799b879d7b954",    toggleterm = "265bbff68fbb8b2a5fb011272ec469850254ec9f",    which_key = "0fd9de78fe09215e1b7c6173ff1b0b90c8ed6ec4", | 
