diff options
author | crupest <crupest@outlook.com> | 2023-09-08 17:57:37 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2023-09-13 00:35:23 +0800 |
commit | e1cf1bfebeca544abb34e860d86a89900b74df09 (patch) | |
tree | f63eab18ea75e9abdc219aa0d1a22256785cdf05 | |
parent | 653f9440d8002f6b290a8a107d5832cf395b9188 (diff) | |
download | crupest-e1cf1bfebeca544abb34e860d86a89900b74df09.tar.gz crupest-e1cf1bfebeca544abb34e860d86a89900b74df09.tar.bz2 crupest-e1cf1bfebeca544abb34e860d86a89900b74df09.zip |
Update nvim config.
-rw-r--r-- | configs/nvim/init.lua | 80 |
1 files changed, 79 insertions, 1 deletions
diff --git a/configs/nvim/init.lua b/configs/nvim/init.lua index 1529495..1b8f0f2 100644 --- a/configs/nvim/init.lua +++ b/configs/nvim/init.lua @@ -19,7 +19,7 @@ vim.opt.shiftwidth = 4; vim.opt.expandtab = true; vim.opt.wrap = false; vim.opt.number = true; -vim.keymap.set('t', '<esc>', [[<C-\><C-n>]]) +vim.keymap.set('t', '<leader><esc>', [[<C-\><C-n>]]) if vim.g.neovide then vim.opt.guifont = "FiraCode Nerd Font"; @@ -286,6 +286,84 @@ require("catppuccin").setup{ vim.cmd.colorscheme "catppuccin" +-- custom keymaps + +vim.keymap.set("n", "<c-tab>", "<cmd>bnext<cr>") +vim.keymap.set("n", "<c-s-tab>", "<cmd>bNext<cr>") +vim.keymap.set("n", "<s-tab>", "<c-o>") + +local list_listed_bufs = function () + local bufs = vim.api.nvim_list_bufs() + local result = {} + for _, v in ipairs(bufs) do + if vim.fn.buflisted(v) ~= 0 then + table.insert(result, v) + end + end + return result +end + +local get_previous_buffer = function (buf) + local bufs = list_listed_bufs() + + -- no buffers at all + if #bufs == 0 then return nil end + + -- find the buf in bufs + local index = 0 + for i, v in ipairs(bufs) do + if buf == v then + index = i + break + end + end + + -- it's the only one + if #bufs == 1 and index == 1 then + return nil + end + + -- it's the first one + if index == 1 then + return bufs[2] + end + + return bufs[index - 1] +end + +-- Delete current buffer and jump back. +-- If no previous jump, switch to previous buffer. +-- If no previous buffer (no other buffers), create a unnamed one. (So the window does not quit.) +vim.keymap.set("n", "<c-q>", function () + local current_buffer = vim.api.nvim_get_current_buf() + local jumps_info = vim.fn.getjumplist() + + local old_jump_list = { unpack(jumps_info[1], 1, jumps_info[2]) } + while #old_jump_list ~= 0 do + local last_jump = old_jump_list[#old_jump_list] + if last_jump.bufnr ~= current_buffer and vim.fn.bufexists(last_jump.bufnr) ~= 0 and vim.fn.buflisted(last_jump.bufnr) ~= 0 then + break + end + table.remove(old_jump_list, #old_jump_list) + end + + if #old_jump_list ~= 0 then + local last_jump = old_jump_list[#old_jump_list] + vim.api.nvim_win_set_buf(0, last_jump.bufnr) + vim.api.nvim_win_set_cursor(0, {last_jump.lnum, last_jump.col}) + else + local previous_buf = get_previous_buffer(current_buffer) + if previous_buf then + vim.api.nvim_win_set_buf(0, previous_buf) + else + local new_buf = vim.api.nvim_create_buf(true, false) + vim.api.nvim_win_set_buf(0, new_buf) + end + end + + vim.api.nvim_buf_delete(current_buffer, {}) +end) + vim.keymap.set("n", "<esc>", function () local wins = vim.api.nvim_list_wins() for _, v in ipairs(wins) do |