Updates neovim config
This commit is contained in:
parent
074bccdb21
commit
117ccbf4b5
5 changed files with 323 additions and 203 deletions
|
|
@ -1,8 +1,9 @@
|
||||||
local opts = { noremap = true, silent = true, expr = true }
|
local opts = { noremap = true, silent = true, expr = true }
|
||||||
|
|
||||||
|
-- Non-leader general keybindings
|
||||||
vim.keymap.set("n", "k", "v:count == 0 ? 'gk' : 'k'", opts)
|
vim.keymap.set("n", "k", "v:count == 0 ? 'gk' : 'k'", opts)
|
||||||
vim.keymap.set("n", "j", "v:count == 0 ? 'gj' : 'j'", opts)
|
vim.keymap.set("n", "j", "v:count == 0 ? 'gj' : 'j'", opts)
|
||||||
vim.keymap.set("n", "<C-d>", "<C-d>zz")
|
vim.keymap.set("n", "<C-d>", "<C-d>zz", { desc = "Move down" })
|
||||||
vim.keymap.set("n", "<C-u>", "<C-u>zz")
|
vim.keymap.set("n", "<C-u>", "<C-u>zz", { desc = "Move up" })
|
||||||
vim.keymap.set("n", "n", "nzzzv")
|
vim.keymap.set("n", "n", "nzzzv", { desc = "Move to next occurence" })
|
||||||
vim.keymap.set("n", "N", "Nzzzv")
|
vim.keymap.set("n", "N", "Nzzzv", { desc = "Move to next occurence" })
|
||||||
|
|
|
||||||
|
|
@ -15,11 +15,8 @@ if not (vim.uv or vim.loop).fs_stat(lazypath) then
|
||||||
end
|
end
|
||||||
vim.opt.rtp:prepend(lazypath)
|
vim.opt.rtp:prepend(lazypath)
|
||||||
|
|
||||||
local opts = { noremap = true, silent = true, expr = true }
|
|
||||||
|
|
||||||
vim.g.mapleader = " "
|
vim.g.mapleader = " "
|
||||||
vim.g.maplocalleader = " "
|
vim.g.maplocalleader = " "
|
||||||
vim.keymap.set("", "<Space>", "<Nop>", opts)
|
|
||||||
|
|
||||||
local options = {
|
local options = {
|
||||||
backup = false, -- creates a backup file
|
backup = false, -- creates a backup file
|
||||||
|
|
|
||||||
|
|
@ -13,9 +13,17 @@ vim.diagnostic.config({
|
||||||
|
|
||||||
vim.api.nvim_create_autocmd("LspAttach", {
|
vim.api.nvim_create_autocmd("LspAttach", {
|
||||||
callback = function(args)
|
callback = function(args)
|
||||||
local opts = { buffer = args.buf }
|
vim.keymap.set(
|
||||||
|
"n",
|
||||||
vim.keymap.set("n", "<leader>e", "<cmd>lua vim.diagnostic.open_float()<cr>", opts)
|
"<leader>e",
|
||||||
vim.keymap.set("n", "<leader>ca", "<cmd>lua vim.lsp.buf.code_action()<cr>", opts)
|
"<cmd>lua vim.diagnostic.open_float()<cr>",
|
||||||
|
{ buffer = args.buf, desc = "Show diagnostics on current line" }
|
||||||
|
)
|
||||||
|
vim.keymap.set(
|
||||||
|
"n",
|
||||||
|
"<leader>ca",
|
||||||
|
"<cmd>lua vim.lsp.buf.code_action()<cr>",
|
||||||
|
{ buffer = args.buf, desc = "Code actions for current line" }
|
||||||
|
)
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
|
||||||
|
|
@ -14,64 +14,167 @@ return {
|
||||||
lazy = false,
|
lazy = false,
|
||||||
opts = {
|
opts = {
|
||||||
bigfile = { enabled = true },
|
bigfile = { enabled = true },
|
||||||
dashboard = {
|
|
||||||
enabled = false,
|
|
||||||
sections = {
|
|
||||||
{ section = "keys", gap = 1, padding = 1 },
|
|
||||||
{ section = "startup" },
|
|
||||||
{
|
|
||||||
section = "terminal",
|
|
||||||
cmd = "pokemon-colorscripts -r --no-title; sleep .1",
|
|
||||||
random = 10,
|
|
||||||
pane = 2,
|
|
||||||
indent = 8,
|
|
||||||
height = 30,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
git = { enabled = true },
|
git = { enabled = true },
|
||||||
gitbrowse = { enabled = true },
|
gitbrowse = {
|
||||||
|
enabled = true,
|
||||||
|
what = "commit",
|
||||||
|
},
|
||||||
indent = { enabled = true },
|
indent = { enabled = true },
|
||||||
|
input = { enabled = true },
|
||||||
lazygit = {
|
lazygit = {
|
||||||
enabled = true,
|
enabled = true,
|
||||||
configure = true,
|
configure = true,
|
||||||
},
|
},
|
||||||
|
notifier = { enabled = true },
|
||||||
picker = {
|
picker = {
|
||||||
enabled = true,
|
enabled = true,
|
||||||
prompt = "λ ",
|
prompt = "λ ",
|
||||||
preset = "ivy",
|
|
||||||
layout = { position = "bottom" },
|
|
||||||
},
|
},
|
||||||
statuscolumn = { enabled = true },
|
statuscolumn = { enabled = true },
|
||||||
zen = { enabled = true },
|
zen = { enabled = true },
|
||||||
},
|
},
|
||||||
-- stylua: ignore
|
|
||||||
keys = {
|
keys = {
|
||||||
-- Git
|
-- Git
|
||||||
{ "<leader>gg", function() Snacks.lazygit() end, desc = "Lazygit" },
|
{
|
||||||
{ "<leader>gb", function() Snacks.git.blame_line() end, desc = "Show git blame for current line" },
|
"<leader>gg",
|
||||||
{ "<leader>gl", function() Snacks.gitbrowse() end, desc = "Open link to line at git remote" },
|
function()
|
||||||
|
Snacks.lazygit()
|
||||||
|
end,
|
||||||
|
desc = "Lazygit",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>gb",
|
||||||
|
function()
|
||||||
|
Snacks.git.blame_line()
|
||||||
|
end,
|
||||||
|
desc = "Show git blame for current line",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>gl",
|
||||||
|
function()
|
||||||
|
Snacks.gitbrowse()
|
||||||
|
end,
|
||||||
|
desc = "Open link to line at git remote",
|
||||||
|
},
|
||||||
-- Zen Mode
|
-- Zen Mode
|
||||||
{ "<leader>z", function() Snacks.zen() end, desc = "Toggle Zen Mode" },
|
{
|
||||||
|
"<leader>z",
|
||||||
|
function()
|
||||||
|
Snacks.zen()
|
||||||
|
end,
|
||||||
|
desc = "Toggle Zen Mode",
|
||||||
|
},
|
||||||
-- Picker
|
-- Picker
|
||||||
{ "<leader>", function() end, desc = "" },
|
{
|
||||||
{ "<leader>.", function() Snacks.picker.files() end, desc = "" },
|
"<leader>.",
|
||||||
{ "<leader><leader>", function() Snacks.picker.git_files() end, desc = "Git files" },
|
function()
|
||||||
|
Snacks.picker.files()
|
||||||
|
end,
|
||||||
|
desc = "",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader><leader>",
|
||||||
|
function()
|
||||||
|
Snacks.picker.git_files()
|
||||||
|
end,
|
||||||
|
desc = "Git files",
|
||||||
|
},
|
||||||
-- Find
|
-- Find
|
||||||
{ "<leader>fr", function() Snacks.picker.recent() end, desc = "Recent" },
|
{
|
||||||
{ "<leader>fp", function() Snacks.picker.projects() end, desc = "Projects" },
|
"<leader>fr",
|
||||||
|
function()
|
||||||
|
Snacks.picker.recent()
|
||||||
|
end,
|
||||||
|
desc = "Recent",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>fp",
|
||||||
|
function()
|
||||||
|
Snacks.picker.projects()
|
||||||
|
end,
|
||||||
|
desc = "Projects",
|
||||||
|
},
|
||||||
-- Search
|
-- Search
|
||||||
{ "<leader>ss", function() Snacks.picker.grep() end, desc = "Grep" },
|
{
|
||||||
{ "<leader>sw", function() Snacks.picker.grep_word() end, desc = "Visual selection or word", mode = { "n", "x" } },
|
"<leader>ss",
|
||||||
{ "<leader>su", function() Snacks.picker.undo() end, desc = "Undo History" },
|
function()
|
||||||
|
Snacks.picker.grep()
|
||||||
|
end,
|
||||||
|
desc = "Grep",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>sw",
|
||||||
|
function()
|
||||||
|
Snacks.picker.grep_word()
|
||||||
|
end,
|
||||||
|
desc = "Visual selection or word",
|
||||||
|
mode = { "n", "x" },
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>su",
|
||||||
|
function()
|
||||||
|
Snacks.picker.undo()
|
||||||
|
end,
|
||||||
|
desc = "Undo History",
|
||||||
|
},
|
||||||
-- Diagnostics
|
-- Diagnostics
|
||||||
{ "<leader>td", function() Snacks.picker.diagnostics_buffer() end, desc = "Buffer Diagnostics" },
|
{
|
||||||
{ "<leader>ta", function() Snacks.picker.diagnostics() end, desc = "Diagnostics" },
|
"<leader>td",
|
||||||
|
function()
|
||||||
|
Snacks.picker.diagnostics_buffer()
|
||||||
|
end,
|
||||||
|
desc = "Buffer Diagnostics",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>ta",
|
||||||
|
function()
|
||||||
|
Snacks.picker.diagnostics()
|
||||||
|
end,
|
||||||
|
desc = "Diagnostics",
|
||||||
|
},
|
||||||
-- LSP
|
-- LSP
|
||||||
{ "gd", function() Snacks.picker.lsp_definitions({ filter = { filter = filter_lsp_definitions } }) end, desc = "Goto Definition" },
|
{
|
||||||
{ "gD", function() Snacks.picker.lsp_declarations() end, desc = "Goto Declaration" },
|
"gd",
|
||||||
{ "grr", function() Snacks.picker.lsp_references() end, nowait = true, desc = "References" },
|
function()
|
||||||
{ "gI", function() Snacks.picker.lsp_implementations() end, desc = "Goto Implementation" },
|
Snacks.picker.lsp_definitions({ filter = { filter = filter_lsp_definitions } })
|
||||||
{ "gy", function() Snacks.picker.lsp_type_definitions() end, desc = "Goto T[y]pe Definition" },
|
end,
|
||||||
|
desc = "Goto Definition",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"gD",
|
||||||
|
function()
|
||||||
|
Snacks.picker.lsp_declarations()
|
||||||
|
end,
|
||||||
|
desc = "Goto Declaration",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"grr",
|
||||||
|
function()
|
||||||
|
Snacks.picker.lsp_references()
|
||||||
|
end,
|
||||||
|
nowait = true,
|
||||||
|
desc = "References",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"gI",
|
||||||
|
function()
|
||||||
|
Snacks.picker.lsp_implementations()
|
||||||
|
end,
|
||||||
|
desc = "Goto Implementation",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"gy",
|
||||||
|
function()
|
||||||
|
Snacks.picker.lsp_type_definitions()
|
||||||
|
end,
|
||||||
|
desc = "Goto T[y]pe Definition",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>on",
|
||||||
|
function()
|
||||||
|
Snacks.notifier.show_history()
|
||||||
|
end,
|
||||||
|
desc = "Open notification history",
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -3,15 +3,23 @@ local utils = require("dnsc.utils")
|
||||||
return {
|
return {
|
||||||
"folke/which-key.nvim",
|
"folke/which-key.nvim",
|
||||||
event = "VeryLazy",
|
event = "VeryLazy",
|
||||||
opts = {
|
config = function()
|
||||||
|
local wk = require("which-key")
|
||||||
|
|
||||||
|
---@class wk.Opts
|
||||||
|
local opts = {
|
||||||
icons = { mappings = false },
|
icons = { mappings = false },
|
||||||
},
|
win = { border = "rounded" },
|
||||||
keys = {
|
}
|
||||||
{ "<leader>o", group = "open", mode = "n" },
|
|
||||||
{ "<leader>ot", ":e ~/notes/todo.txt<cr>", desc = "Open todos", mode = "n" },
|
wk.setup(opts)
|
||||||
{ "<leader>od", ":80 vsplit | :VimwikiMakeDiaryNote<cr>", desc = "Open diary note in split", mode = "n" },
|
wk.add({
|
||||||
{ "<leader>b", group = "buffer", mode = "n" },
|
{ "<leader>o", group = "+open", mode = "n" },
|
||||||
{ "<leader>b,", "<Cmd>BufferMovePrevious<CR>", desc = "Move buffer back", mode = "n" },
|
{ "<leader>ot", ":e ~/notes/todo.txt<cr>", desc = "Open tasks", mode = "n" },
|
||||||
|
{ "<leader>od", ":80 vsplit | :VimwikiMakeDiaryNote<cr>", desc = "Open daily note", mode = "n" },
|
||||||
|
|
||||||
|
{ "<leader>b", group = "+buffer", mode = "n" },
|
||||||
|
{ "<leader>b,", "<Cmd>BufferMovePrevious<CR>", desc = "Move buffer backwards", mode = "n" },
|
||||||
{
|
{
|
||||||
"<leader>b.",
|
"<leader>b.",
|
||||||
"<Cmd>BufferMoveNext<CR>",
|
"<Cmd>BufferMoveNext<CR>",
|
||||||
|
|
@ -49,22 +57,18 @@ return {
|
||||||
desc = "Delete all buffers",
|
desc = "Delete all buffers",
|
||||||
mode = "n",
|
mode = "n",
|
||||||
},
|
},
|
||||||
{ "<leader>c", group = "code/compile", mode = "n" },
|
|
||||||
|
{ "<leader>c", group = "+code", mode = "n" },
|
||||||
{
|
{
|
||||||
"<leader>cr",
|
"<leader>cr",
|
||||||
function()
|
function()
|
||||||
utils.compile_project()
|
utils.compile_project()
|
||||||
end,
|
end,
|
||||||
desc = "Run current project",
|
desc = "Compile project",
|
||||||
mode = "n",
|
mode = "n",
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"<leader>q",
|
{ "<leader>f", group = "+file", mode = "n" },
|
||||||
"<cmd>wq<cr>",
|
|
||||||
desc = "Close window and buffer",
|
|
||||||
mode = "n",
|
|
||||||
},
|
|
||||||
{ "<leader>f", group = "file", mode = "n" },
|
|
||||||
{
|
{
|
||||||
"<leader>fn",
|
"<leader>fn",
|
||||||
"<cmd>enew<cr>",
|
"<cmd>enew<cr>",
|
||||||
|
|
@ -77,11 +81,16 @@ return {
|
||||||
desc = "Save currently opened file",
|
desc = "Save currently opened file",
|
||||||
mode = "n",
|
mode = "n",
|
||||||
},
|
},
|
||||||
{ "<leader>q", "<cmd>qa!<cr>", desc = "Leave neovim", mode = "n" },
|
|
||||||
{ "<leader>s", group = "search", mode = "n" },
|
{ "<leader>qq", "<cmd>qa!<cr>", desc = "Leave neovim", mode = "n" },
|
||||||
{ "<leader>t", group = "diagnostics (lsp)", mode = "n" },
|
|
||||||
|
{ "<leader>s", group = "+search", mode = "n" },
|
||||||
|
{ "<leader>g", group = "+git", mode = "n" },
|
||||||
|
|
||||||
|
{ "<leader>t", group = "+diagnostics", mode = "n" },
|
||||||
{ "<leader>ta", "<cmd>TodoQuickFix<cr>", desc = "Show all todo comments", mode = "n" },
|
{ "<leader>ta", "<cmd>TodoQuickFix<cr>", desc = "Show all todo comments", mode = "n" },
|
||||||
{ "<leader>w", group = "window", mode = "n" },
|
|
||||||
|
{ "<leader>w", group = "+window", mode = "n" },
|
||||||
{
|
{
|
||||||
"<leader>w+",
|
"<leader>w+",
|
||||||
":vertical resize +4<CR>",
|
":vertical resize +4<CR>",
|
||||||
|
|
@ -148,7 +157,8 @@ return {
|
||||||
desc = "Delete buffer and window",
|
desc = "Delete buffer and window",
|
||||||
mode = "n",
|
mode = "n",
|
||||||
},
|
},
|
||||||
{ "<leader>x", group = "config", mode = "n" },
|
|
||||||
|
{ "<leader>x", group = "+config", mode = "n" },
|
||||||
{
|
{
|
||||||
"<leader>xn",
|
"<leader>xn",
|
||||||
"<cmd>set number relativenumber<cr>",
|
"<cmd>set number relativenumber<cr>",
|
||||||
|
|
@ -156,5 +166,6 @@ return {
|
||||||
mode = "n",
|
mode = "n",
|
||||||
},
|
},
|
||||||
{ "<leader>xr", "<cmd>source $MYVIMRC<cr>", desc = "Reload config", mode = "n" },
|
{ "<leader>xr", "<cmd>source $MYVIMRC<cr>", desc = "Reload config", mode = "n" },
|
||||||
},
|
})
|
||||||
|
end,
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue