summaryrefslogtreecommitdiff
path: root/lua/keymappings.lua
diff options
context:
space:
mode:
authorkylo252 <[email protected]>2021-07-18 19:49:41 +0200
committerGitHub <[email protected]>2021-07-18 17:49:41 +0000
commit59106e860edde09107d2628a81eee816871eb065 (patch)
treee6e6b777c26d5b9b64ff92251c5cb7bcb3a6318d /lua/keymappings.lua
parentf0d22b299f2a49272454f657b32dacadceeb0096 (diff)
[Refactor] Make default keybindings configurable (#988)
Diffstat (limited to 'lua/keymappings.lua')
-rw-r--r--lua/keymappings.lua109
1 files changed, 59 insertions, 50 deletions
diff --git a/lua/keymappings.lua b/lua/keymappings.lua
index fed362aa..03a1618c 100644
--- a/lua/keymappings.lua
+++ b/lua/keymappings.lua
@@ -1,42 +1,41 @@
-local function register_mappings(mappings, default_options)
- for mode, mode_mappings in pairs(mappings) do
- for _, mapping in pairs(mode_mappings) do
- local options = #mapping == 3 and table.remove(mapping) or default_options
- local prefix, cmd = unpack(mapping)
- pcall(vim.api.nvim_set_keymap, mode, prefix, cmd, options)
- end
- end
-end
+local lv_utils = require "lv-utils"
+
+local opts = {
+ nnoremap = { noremap = true, silent = true },
+ inoremap = { noremap = true, silent = true },
+ vnoremap = { noremap = true, silent = true },
+ xnoremap = { noremap = true, silent = true },
+ generic = { silent = true },
+}
-local mappings = {
- i = { -- Insert mode
+local default_keys = {
+ 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" },
-
- -- 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" },
+ -- navigation
+ { "<A-Up>", "<C-\\><C-N><C-w>h" },
+ { "<A-Down>", "<C-\\><C-N><C-w>j" },
+ { "<A-Left>", "<C-\\><C-N><C-w>k" },
+ { "<A-Right>", "<C-\\><C-N><C-w>l" },
},
- n = { -- Normal mode
+
+ normal_mode = {
-- Better window movement
- { "<C-h>", "<C-w>h", { silent = true } },
- { "<C-j>", "<C-w>j", { silent = true } },
- { "<C-k>", "<C-w>k", { silent = true } },
- { "<C-l>", "<C-w>l", { silent = true } },
+ { "<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>", { silent = true } },
- { "<C-Down>", ":resize +2<CR>", { silent = true } },
- { "<C-Left>", ":vertical resize -2<CR>", { silent = true } },
- { "<C-Right>", ":vertical resize +2<CR>", { silent = true } },
+ { "<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>" },
@@ -49,17 +48,20 @@ local mappings = {
-- QuickFix
{ "]q", ":cnext<CR>" },
{ "[q", ":cprev<CR>" },
+ { "<C-q>", ":call QuickFixToggle()<CR>" },
-- {'<C-TAB>', 'compe#complete()', {noremap = true, silent = true, expr = true}},
},
- t = { -- 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" },
},
- v = { -- Visual/Select mode
+
+ visual_mode = {
-- Better indenting
{ "<", "<gv" },
{ ">", ">gv" },
@@ -67,7 +69,8 @@ local mappings = {
-- { "p", '"0p', { silent = true } },
-- { "P", '"0P', { silent = true } },
},
- x = { -- Visual 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" },
@@ -76,31 +79,37 @@ local mappings = {
{ "<A-j>", ":m '>+1<CR>gv-gv" },
{ "<A-k>", ":m '<-2<CR>gv-gv" },
},
- [""] = {
- -- Toggle the QuickFix window
- { "<C-q>", ":call QuickFixToggle()<CR>" },
- },
}
--- TODO: fix this
if vim.fn.has "mac" == 1 then
- mappings["n"][5][1] = "<A-Up>"
- mappings["n"][6][1] = "<A-Down>"
- mappings["n"][7][1] = "<A-Left>"
- mappings["n"][8][1] = "<A-Right>"
+ -- TODO: fix this
+ default_keys.insert_mode["n"][5][1] = "<A-Up>"
+ default_keys.insert_mode["n"][6][1] = "<A-Down>"
+ default_keys.insert_mode["n"][7][1] = "<A-Left>"
+ default_keys.insert_mode["n"][8][1] = "<A-Right>"
end
-register_mappings(mappings, { silent = true, noremap = true })
+if O.keys.leader_key == " " or O.keys.leader_key == "space" then
+ vim.g.mapleader = " "
+else
+ vim.g.mapleader = O.keys.leader_key
+end
-vim.cmd 'inoremap <expr> <c-j> ("\\<C-n>")'
-vim.cmd 'inoremap <expr> <c-k> ("\\<C-p>")'
+local function get_user_keys(mode)
+ if O.keys[mode] == nil then
+ return default_keys[mode]
+ else
+ return O.keys[mode]
+ end
+end
--- vim.cmd('inoremap <expr> <TAB> (\"\\<C-n>\")')
--- vim.cmd('inoremap <expr> <S-TAB> (\"\\<C-p>\")')
+lv_utils.add_keymap_normal_mode(opts.nnoremap, get_user_keys "normal_mode")
+lv_utils.add_keymap_insert_mode(opts.inoremap, get_user_keys "insert_mode")
+lv_utils.add_keymap_visual_mode(opts.vnoremap, get_user_keys "visual_mode")
+lv_utils.add_keymap_visual_block_mode(opts.xnoremap, get_user_keys "visual_block_mode")
+lv_utils.add_keymap_term_mode(opts.generic, get_user_keys "visual_block_mode")
--- vim.cmd([[
--- map p <Plug>(miniyank-autoput)
--- map P <Plug>(miniyank-autoPut)
--- map <leader>n <Plug>(miniyank-cycle)
--- map <leader>N <Plug>(miniyank-cycleback)
--- ]])
+-- 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>"'