keymappings.lua 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. local M = {}
  2. local Log = require "core.log"
  3. local generic_opts_any = { noremap = true, silent = true }
  4. local generic_opts = {
  5. insert_mode = generic_opts_any,
  6. normal_mode = generic_opts_any,
  7. visual_mode = generic_opts_any,
  8. visual_block_mode = generic_opts_any,
  9. term_mode = { silent = true },
  10. }
  11. local mode_adapters = {
  12. insert_mode = "i",
  13. normal_mode = "n",
  14. term_mode = "t",
  15. visual_mode = "v",
  16. visual_block_mode = "x",
  17. }
  18. -- Append key mappings to lunarvim's defaults for a given mode
  19. -- @param keymaps The table of key mappings containing a list per mode (normal_mode, insert_mode, ..)
  20. function M.append_to_defaults(keymaps)
  21. for mode, mappings in pairs(keymaps) do
  22. for k, v in ipairs(mappings) do
  23. lvim.keys[mode][k] = v
  24. end
  25. end
  26. end
  27. -- Set key mappings individually
  28. -- @param mode The keymap mode, can be one of the keys of mode_adapters
  29. -- @param key The key of keymap
  30. -- @param val Can be form as a mapping or tuple of mapping and user defined opt
  31. function M.set_keymaps(mode, key, val)
  32. local opt = generic_opts[mode] and generic_opts[mode] or generic_opts_any
  33. if type(val) == "table" then
  34. opt = val[2]
  35. val = val[1]
  36. end
  37. vim.api.nvim_set_keymap(mode, key, val, opt)
  38. end
  39. -- Load key mappings for a given mode
  40. -- @param mode The keymap mode, can be one of the keys of mode_adapters
  41. -- @param keymaps The list of key mappings
  42. function M.load_mode(mode, keymaps)
  43. mode = mode_adapters[mode] and mode_adapters[mode] or mode
  44. for k, v in pairs(keymaps) do
  45. M.set_keymaps(mode, k, v)
  46. end
  47. end
  48. -- Load key mappings for all provided modes
  49. -- @param keymaps A list of key mappings for each mode
  50. function M.load(keymaps)
  51. for mode, mapping in pairs(keymaps) do
  52. M.load_mode(mode, mapping)
  53. end
  54. end
  55. function M.config()
  56. lvim.keys = {
  57. ---@usage change or add keymappings for insert mode
  58. insert_mode = {
  59. -- 'jk' for quitting insert mode
  60. ["jk"] = "<ESC>",
  61. -- 'kj' for quitting insert mode
  62. ["kj"] = "<ESC>",
  63. -- 'jj' for quitting insert mode
  64. ["jj"] = "<ESC>",
  65. -- Move current line / block with Alt-j/k ala vscode.
  66. ["<A-j>"] = "<Esc>:m .+1<CR>==gi",
  67. -- Move current line / block with Alt-j/k ala vscode.
  68. ["<A-k>"] = "<Esc>:m .-2<CR>==gi",
  69. -- navigation
  70. ["<A-Up>"] = "<C-\\><C-N><C-w>k",
  71. ["<A-Down>"] = "<C-\\><C-N><C-w>j",
  72. ["<A-Left>"] = "<C-\\><C-N><C-w>h",
  73. ["<A-Right>"] = "<C-\\><C-N><C-w>l",
  74. -- navigate tab completion with <c-j> and <c-k>
  75. -- runs conditionally
  76. ["<C-j>"] = { 'pumvisible() ? "\\<C-n>" : "\\<C-j>"', { expr = true, noremap = true } },
  77. ["<C-k>"] = { 'pumvisible() ? "\\<C-p>" : "\\<C-k>"', { expr = true, noremap = true } },
  78. },
  79. ---@usage change or add keymappings for normal mode
  80. normal_mode = {
  81. -- Better window movement
  82. ["<C-h>"] = "<C-w>h",
  83. ["<C-j>"] = "<C-w>j",
  84. ["<C-k>"] = "<C-w>k",
  85. ["<C-l>"] = "<C-w>l",
  86. -- Resize with arrows
  87. ["<C-Up>"] = ":resize -2<CR>",
  88. ["<C-Down>"] = ":resize +2<CR>",
  89. ["<C-Left>"] = ":vertical resize -2<CR>",
  90. ["<C-Right>"] = ":vertical resize +2<CR>",
  91. -- Tab switch buffer
  92. ["<S-l>"] = ":BufferNext<CR>",
  93. ["<S-h>"] = ":BufferPrevious<CR>",
  94. -- Move current line / block with Alt-j/k a la vscode.
  95. ["<A-j>"] = ":m .+1<CR>==",
  96. ["<A-k>"] = ":m .-2<CR>==",
  97. -- QuickFix
  98. ["]q"] = ":cnext<CR>",
  99. ["[q"] = ":cprev<CR>",
  100. ["<C-q>"] = ":call QuickFixToggle()<CR>",
  101. },
  102. ---@usage change or add keymappings for terminal mode
  103. term_mode = {
  104. -- Terminal window navigation
  105. ["<C-h>"] = "<C-\\><C-N><C-w>h",
  106. ["<C-j>"] = "<C-\\><C-N><C-w>j",
  107. ["<C-k>"] = "<C-\\><C-N><C-w>k",
  108. ["<C-l>"] = "<C-\\><C-N><C-w>l",
  109. },
  110. ---@usage change or add keymappings for visual mode
  111. visual_mode = {
  112. -- Better indenting
  113. ["<"] = "<gv",
  114. [">"] = ">gv",
  115. -- ["p"] = '"0p',
  116. -- ["P"] = '"0P',
  117. },
  118. ---@usage change or add keymappings for visual block mode
  119. visual_block_mode = {
  120. -- Move selected line / block of text in visual mode
  121. ["K"] = ":move '<-2<CR>gv-gv",
  122. ["J"] = ":move '>+1<CR>gv-gv",
  123. -- Move current line / block with Alt-j/k ala vscode.
  124. ["<A-j>"] = ":m '>+1<CR>gv-gv",
  125. ["<A-k>"] = ":m '<-2<CR>gv-gv",
  126. },
  127. }
  128. if vim.fn.has "mac" == 1 then
  129. lvim.keys.normal_mode["<A-Up>"] = lvim.keys.normal_mode["<C-Up>"]
  130. lvim.keys.normal_mode["<A-Down>"] = lvim.keys.normal_mode["<C-Down>"]
  131. lvim.keys.normal_mode["<A-Left>"] = lvim.keys.normal_mode["<C-Left>"]
  132. lvim.keys.normal_mode["<A-Right>"] = lvim.keys.normal_mode["<C-Right>"]
  133. if Log:get_default() then
  134. Log:get_default().info "Activated mac keymappings"
  135. end
  136. end
  137. end
  138. function M.print(mode)
  139. print "List of LunarVim's default keymappings (not including which-key)"
  140. if mode then
  141. print(vim.inspect(lvim.keys[mode]))
  142. else
  143. print(vim.inspect(lvim.keys))
  144. end
  145. end
  146. function M.setup()
  147. vim.g.mapleader = (lvim.leader == "space" and " ") or lvim.leader
  148. M.load(lvim.keys)
  149. end
  150. return M