diff options
Diffstat (limited to 'lua')
| -rw-r--r-- | lua/core/bufferline.lua | 15 | ||||
| -rw-r--r-- | lua/core/compe.lua | 14 | ||||
| -rw-r--r-- | lua/core/which-key.lua | 4 | ||||
| -rw-r--r-- | lua/default-config.lua | 1 | ||||
| -rw-r--r-- | lua/keymappings.lua | 252 | ||||
| -rw-r--r-- | lua/lsp/init.lua | 19 | ||||
| -rw-r--r-- | lua/utils/init.lua | 1 | 
7 files changed, 187 insertions, 119 deletions
| diff --git a/lua/core/bufferline.lua b/lua/core/bufferline.lua index 35831d03..68030c81 100644 --- a/lua/core/bufferline.lua +++ b/lua/core/bufferline.lua @@ -1,16 +1,11 @@  lvim.builtin.bufferline = {    keymap = { -    values = { -      normal_mode = { -        ["<S-l>"] = { ":BufferNext<CR>" }, -        ["<S-h>"] = { ":BufferPrevious<CR>" }, -      }, -    }, -    opts = { -      normal_mode = { noremap = true, silent = true }, +    normal_mode = { +      ["<S-l>"] = ":BufferNext<CR>", +      ["<S-h>"] = ":BufferPrevious<CR>",      },    },  } -local keymap = require "utils.keymap" -keymap.load(lvim.builtin.bufferline.keymap.values, lvim.builtin.bufferline.keymap.opts) +local keymap = require "keymappings" +keymap.append_to_defaults(lvim.builtin.bufferline.keymap) diff --git a/lua/core/compe.lua b/lua/core/compe.lua index 5f1632f9..2d183683 100644 --- a/lua/core/compe.lua +++ b/lua/core/compe.lua @@ -42,12 +42,12 @@ M.config = function()      keymap = {        values = {          insert_mode = { -          ["<Tab>"] = { 'pumvisible() ? "<C-n>" : "<Tab>"' }, -          ["<S-Tab>"] = { 'pumvisible() ? "<C-p>" : "<S-Tab>"' }, -          ["<C-Space>"] = { "compe#complete()" }, -          ["<C-e>"] = { "compe#close('<C-e>')" }, -          ["<C-f>"] = { "compe#scroll({ 'delta': +4 })" }, -          ["<C-d>"] = { "compe#scroll({ 'delta': -4 })" }, +          ["<Tab>"] = 'pumvisible() ? "<C-n>" : "<Tab>"', +          ["<S-Tab>"] = 'pumvisible() ? "<C-p>" : "<S-Tab>"', +          ["<C-Space>"] = "compe#complete()", +          ["<C-e>"] = "compe#close('<C-e>')", +          ["<C-f>"] = "compe#scroll({ 'delta': +4 })", +          ["<C-d>"] = "compe#scroll({ 'delta': -4 })",          },        },        opts = { @@ -105,7 +105,7 @@ M.setup = function()      end    end -  local keymap = require "utils.keymap" +  local keymap = require "keymappings"    keymap.load(lvim.builtin.compe.keymap.values, lvim.builtin.compe.keymap.opts)  end diff --git a/lua/core/which-key.lua b/lua/core/which-key.lua index 17995e87..eab9266a 100644 --- a/lua/core/which-key.lua +++ b/lua/core/which-key.lua @@ -166,6 +166,10 @@ M.config = function()            "Workspace Symbols",          },        }, +      L = { +        name = "+LunarVim", +        k = { "<cmd>lua require('keymappings').print()<cr>", "View LunarVim's default keymappings" }, +      },        s = {          name = "Search", diff --git a/lua/default-config.lua b/lua/default-config.lua index e7d0bfa7..7563d36d 100644 --- a/lua/default-config.lua +++ b/lua/default-config.lua @@ -1237,6 +1237,7 @@ lvim.lang = {    },  } +require("keymappings").config()  require("core.which-key").config()  require "core.status_colors"  require("core.gitsigns").config() diff --git a/lua/keymappings.lua b/lua/keymappings.lua index 9ef37a39..038ebed4 100644 --- a/lua/keymappings.lua +++ b/lua/keymappings.lua @@ -1,109 +1,157 @@ -local opts = { -  insert_mode = { noremap = true, silent = true }, -  normal_mode = { noremap = true, silent = true }, -  visual_mode = { noremap = true, silent = true }, -  visual_block_mode = { noremap = true, silent = true }, -  term_mode = { silent = true }, -} +local M = {} + +local generic_opts_any = { noremap = true, silent = true } -local keymaps = { -  insert_mode = { -    -- I hate escape -    ["jk"] = { "<ESC>" }, -    ["kj"] = { "<ESC>" }, -    ["jj"] = { "<ESC>" }, -    -- Move current line / block with Alt-j/k ala vscode. -    ["<A-j>"] = { "<Esc>:m .+1<CR>==gi" }, -    ["<A-k>"] = { "<Esc>:m .-2<CR>==gi" }, -    -- navigation -    ["<A-Up>"] = { "<C-\\><C-N><C-w>k" }, -    ["<A-Down>"] = { "<C-\\><C-N><C-w>j" }, -    ["<A-Left>"] = { "<C-\\><C-N><C-w>h" }, -    ["<A-Right>"] = { "<C-\\><C-N><C-w>l" }, -  }, - -  normal_mode = { -    -- Better window movement -    ["<C-h>"] = { "<C-w>h" }, -    ["<C-j>"] = { "<C-w>j" }, -    ["<C-k>"] = { "<C-w>k" }, -    ["<C-l>"] = { "<C-w>l" }, - -    -- Resize with arrows -    ["<C-Up>"] = { ":resize -2<CR>" }, -    ["<C-Down>"] = { ":resize +2<CR>" }, -    ["<C-Left>"] = { ":vertical resize -2<CR>" }, -    ["<C-Right>"] = { ":vertical resize +2<CR>" }, - -    -- Tab switch buffer -    -- { "<TAB>", ":bnext<CR>" }, -    -- { "<S-TAB>", ":bprevious<CR>" }, - -    -- Move current line / block with Alt-j/k a la vscode. -    ["<A-j>"] = { ":m .+1<CR>==" }, -    ["<A-k>"] = { ":m .-2<CR>==" }, - -    -- QuickFix -    ["]q"] = { ":cnext<CR>" }, -    ["[q"] = { ":cprev<CR>" }, -    ["<C-q>"] = { ":call QuickFixToggle()<CR>" }, - -    -- {'<C-TAB>', 'compe#complete()', {noremap = true, silent = true, expr = true}}, - -    -- LSP -    ["gd"] = { "<cmd>lua vim.lsp.buf.definition()<CR>" }, -    ["gD"] = { "<cmd>lua vim.lsp.buf.declaration()<CR>" }, -    ["gr"] = { "<cmd>lua vim.lsp.buf.references()<CR>" }, -    ["gi"] = { "<cmd>lua vim.lsp.buf.implementation()<CR>" }, -    ["gl"] = { "<cmd>lua vim.lsp.diagnostic.show_line_diagnostics({ show_header = false, border = 'single' })<CR>" }, -    ["gs"] = { "<cmd>lua vim.lsp.buf.signature_help()<CR>" }, -    ["gp"] = { "<cmd>lua require'lsp.peek'.Peek('definition')<CR>" }, -    ["K"] = { "<cmd>lua vim.lsp.buf.hover()<CR>" }, -    ["<C-p>"] = { "<cmd>lua vim.lsp.diagnostic.goto_prev({popup_opts = {border = lvim.lsp.popup_border}})<CR>" }, -    ["<C-n>"] = { "<cmd>lua vim.lsp.diagnostic.goto_next({popup_opts = {border = lvim.lsp.popup_border}})<CR>" }, -  }, - -  term_mode = { -    -- Terminal window navigation -    ["<C-h>"] = { "<C-\\><C-N><C-w>h" }, -    ["<C-j>"] = { "<C-\\><C-N><C-w>j" }, -    ["<C-k>"] = { "<C-\\><C-N><C-w>k" }, -    ["<C-l>"] = { "<C-\\><C-N><C-w>l" }, -  }, - -  visual_mode = { -    -- Better indenting -    ["<"] = { "<gv" }, -    [">"] = { ">gv" }, - -    -- { "p", '"0p', { silent = true } }, -    -- { "P", '"0P', { silent = true } }, -  }, - -  visual_block_mode = { -    -- Move selected line / block of text in visual mode -    ["K"] = { ":move '<-2<CR>gv-gv" }, -    ["J"] = { ":move '>+1<CR>gv-gv" }, - -    -- Move current line / block with Alt-j/k ala vscode. -    ["<A-j>"] = { ":m '>+1<CR>gv-gv" }, -    ["<A-k>"] = { ":m '<-2<CR>gv-gv" }, -  }, +local mode_adapters = { +  insert_mode = "i", +  normal_mode = "n", +  term_mode = "t", +  visual_mode = "v", +  visual_block_mode = "x",  } -if vim.fn.has "mac" == 1 then -  -- TODO: fix this -  keymaps.normal_mode["<A-Up>"] = keymaps.normal_mode["<C-Up>"] -  keymaps.normal_mode["<A-Down>"] = keymaps.normal_mode["<C-Down>"] -  keymaps.normal_mode["<A-Left>"] = keymaps.normal_mode["<C-Left>"] -  keymaps.normal_mode["<A-Right>"] = keymaps.normal_mode["<C-Right>"] +-- Append key mappings to lunarvim's defaults for a given mode +-- @param keymaps The table of key mappings containing a list per mode (normal_mode, insert_mode, ..) +function M.append_to_defaults(keymaps) +  for mode, mappings in pairs(keymaps) do +    for k, v in ipairs(mappings) do +      lvim.keys[mode][k] = v +    end +  end +end + +-- Load key mappings for a given mode +-- @param mode The keymap mode, can be one of the keys of mode_adapters +-- @param keymaps The list of key mappings +-- @param opts The mapping options +function M.load_mode(mode, keymaps, opts) +  mode = mode_adapters[mode] and mode_adapters[mode] or mode +  for k, v in pairs(keymaps) do +    vim.api.nvim_set_keymap(mode, k, v, opts) +  end +end + +-- Load key mappings for all provided modes +-- @param keymaps A list of key mappings for each mode +-- @param opts The mapping options for each mode +function M.load(keymaps, opts) +  for mode, mapping in pairs(keymaps) do +    M.load_mode(mode, mapping, opts[mode]) +  end  end -vim.g.mapleader = (lvim.leader == "space" and " ") or lvim.leader +function M.config() +  lvim.keys = { +    ---@usage change or add keymappings for insert mode +    insert_mode = { +      -- 'jk' for quitting insert mode +      ["jk"] = "<ESC>", +      -- 'kj' for quitting insert mode +      ["kj"] = "<ESC>", +      -- 'jj' for quitting insert mode +      ["jj"] = "<ESC>", +      -- Move current line / block with Alt-j/k ala vscode. +      ["<A-j>"] = "<Esc>:m .+1<CR>==gi", +      -- Move current line / block with Alt-j/k ala vscode. +      ["<A-k>"] = "<Esc>:m .-2<CR>==gi", +      -- navigation +      ["<A-Up>"] = "<C-\\><C-N><C-w>k", +      ["<A-Down>"] = "<C-\\><C-N><C-w>j", +      ["<A-Left>"] = "<C-\\><C-N><C-w>h", +      ["<A-Right>"] = "<C-\\><C-N><C-w>l", +    }, + +    ---@usage change or add keymappings for normal mode +    normal_mode = { +      -- Better window movement +      ["<C-h>"] = "<C-w>h", +      ["<C-j>"] = "<C-w>j", +      ["<C-k>"] = "<C-w>k", +      ["<C-l>"] = "<C-w>l", + +      -- Resize with arrows +      ["<C-Up>"] = ":resize -2<CR>", +      ["<C-Down>"] = ":resize +2<CR>", +      ["<C-Left>"] = ":vertical resize -2<CR>", +      ["<C-Right>"] = ":vertical resize +2<CR>", + +      -- Tab switch buffer +      ["<S-l>"] = ":BufferNext<CR>", +      ["<S-h>"] = ":BufferPrevious<CR>", + +      -- Move current line / block with Alt-j/k a la vscode. +      ["<A-j>"] = ":m .+1<CR>==", +      ["<A-k>"] = ":m .-2<CR>==", + +      -- QuickFix +      ["]q"] = ":cnext<CR>", +      ["[q"] = ":cprev<CR>", +      ["<C-q>"] = ":call QuickFixToggle()<CR>", +    }, + +    ---@usage change or add keymappings for terminal mode +    term_mode = { +      -- Terminal window navigation +      ["<C-h>"] = "<C-\\><C-N><C-w>h", +      ["<C-j>"] = "<C-\\><C-N><C-w>j", +      ["<C-k>"] = "<C-\\><C-N><C-w>k", +      ["<C-l>"] = "<C-\\><C-N><C-w>l", +    }, + +    ---@usage change or add keymappings for visual mode +    visual_mode = { +      -- Better indenting +      ["<"] = "<gv", +      [">"] = ">gv", + +      -- ["p"] = '"0p', +      -- ["P"] = '"0P', +    }, + +    ---@usage change or add keymappings for visual block mode +    visual_block_mode = { +      -- Move selected line / block of text in visual mode +      ["K"] = ":move '<-2<CR>gv-gv", +      ["J"] = ":move '>+1<CR>gv-gv", + +      -- Move current line / block with Alt-j/k ala vscode. +      ["<A-j>"] = ":m '>+1<CR>gv-gv", +      ["<A-k>"] = ":m '<-2<CR>gv-gv", +    }, +  } + +  if vim.fn.has "mac" == 1 then +    lvim.keys.normal_mode["<A-Up>"] = lvim.keys.normal_mode["<C-Up>"] +    lvim.keys.normal_mode["<A-Down>"] = lvim.keys.normal_mode["<C-Down>"] +    lvim.keys.normal_mode["<A-Left>"] = lvim.keys.normal_mode["<C-Left>"] +    lvim.keys.normal_mode["<A-Right>"] = lvim.keys.normal_mode["<C-Right>"] +  end +end --- navigate tab completion with <c-j> and <c-k> --- runs conditionally -vim.cmd 'inoremap <expr> <C-j> pumvisible() ? "\\<C-n>" : "\\<C-j>"' -vim.cmd 'inoremap <expr> <C-k> pumvisible() ? "\\<C-p>" : "\\<C-k>"' +function M.print(mode) +  print "List of LunarVim's default keymappings (not including which-key)" +  if mode then +    print(vim.inspect(lvim.keys[mode])) +  else +    print(vim.inspect(lvim.keys)) +  end +end + +function M.setup() +  -- navigate tab completion with <c-j> and <c-k> +  -- runs conditionally +  vim.cmd 'inoremap <expr> <C-j> pumvisible() ? "\\<C-n>" : "\\<C-j>"' +  vim.cmd 'inoremap <expr> <C-k> pumvisible() ? "\\<C-p>" : "\\<C-k>"' +  local generic_opts = { +    insert_mode = generic_opts_any, +    normal_mode = generic_opts_any, +    visual_mode = generic_opts_any, +    visual_block_mode = generic_opts_any, +    term_mode = { silent = true }, +  } + +  vim.g.mapleader = (lvim.leader == "space" and " ") or lvim.leader +  M.load(lvim.keys, generic_opts) +end -return { keymaps = keymaps, opts = opts } +return M diff --git a/lua/lsp/init.lua b/lua/lsp/init.lua index 3373ac46..b85dfcd2 100644 --- a/lua/lsp/init.lua +++ b/lua/lsp/init.lua @@ -33,6 +33,24 @@ local function lsp_highlight_document(client)    end  end +local function add_lsp_buffer_keybindings(bufnr) +  local wk = require "which-key" +  local keys = { +    ["K"] = { "<cmd>lua vim.lsp.buf.hover()<CR>", "Show hover" }, +    ["gd"] = { "<cmd>lua vim.lsp.buf.definition()<CR>", "Goto Definition" }, +    ["gD"] = { "<cmd>lua vim.lsp.buf.declaration()<CR>", "Goto declaration" }, +    ["gr"] = { "<cmd>lua vim.lsp.buf.references()<CR>", "Goto references" }, +    ["gi"] = { "<cmd>lua vim.lsp.buf.implementation()<CR>", "Goto implementation" }, +    ["gs"] = { "<cmd>lua vim.lsp.buf.signature_help()<CR>", "show signature help" }, +    ["gp"] = { "<cmd>lua require'lsp.peek'.Peek('definition')<CR>", "Peek definition" }, +    ["gl"] = { +      "<cmd>lua vim.lsp.diagnostic.show_line_diagnostics({ show_header = false, border = 'single' })<CR>", +      "Show line diagnostics", +    }, +  } +  wk.register(keys, { mode = "n", buffer = bufnr }) +end +  function M.common_capabilities()    local capabilities = vim.lsp.protocol.make_client_capabilities()    capabilities.textDocument.completion.completionItem.snippetSupport = true @@ -64,6 +82,7 @@ function M.common_on_attach(client, bufnr)      lvim.lsp.on_attach_callback(client, bufnr)    end    lsp_highlight_document(client) +  add_lsp_buffer_keybindings(bufnr)    require("lsp.null-ls").setup(vim.bo.filetype)  end diff --git a/lua/utils/init.lua b/lua/utils/init.lua index 9f0064e1..9c9b8523 100644 --- a/lua/utils/init.lua +++ b/lua/utils/init.lua @@ -98,6 +98,7 @@ function utils.reload_lv_config()    plugin_loader:load { plugins, lvim.plugins }    vim.cmd ":PackerCompile"    vim.cmd ":PackerInstall" +  require("keymappings").setup()    -- vim.cmd ":PackerClean"  end | 
