23 months ago
More nvim config
new file mode 100644 --- /dev/null +++ b/.config/nvim/autoload/tig.vim @@ -0,0 +1,18 @@ +" Why this wrapper? vim :term sets $TERM to xterm but supports -256color and +" all the suggestions for fixing that involve changing $TERM for vim itself +" rather than just the subprocess. Also since this runs in place we can +" switch back after. +func! tig#Tig(...) abort + call term_start( + \ ['/usr/bin/env', 'TERM=xterm-256color', 'tig'] + a:000, + \ {'curwin': 1, 'term_name': join(['!tig'] + a:000, ' '), 'exit_cb': 'tig#TigExit'} + \ ) +endfunc + +func! tig#TigBlame() abort + call tig#Tig('blame', '+' . line('.'), '--', expand('%')) +endfunc + +func! tig#TigExit(...) abort + buffer # +endfunc
new file mode 100644 --- /dev/null +++ b/.config/nvim/autoload/vimrc.vim @@ -0,0 +1,119 @@ +func! vimrc#CommandAlias(abbrev, expand) abort + execute printf('cnoreabbrev <expr> %s (getcmdtype()==":" && getcmdline()=="%s") ? "%s" : "%s"', a:abbrev, a:abbrev, a:expand, a:abbrev) +endfunc + +func! vimrc#AutoFmtToggle() abort + if &formatoptions =~# 'a' + setl formatoptions-=a | echo '-a' + else + setl formatoptions+=a | echo '+a' + endif +endfunc + +" Make paths when writing, as necessary +func! vimrc#MkNonExDir(file, buf) abort + if empty(getbufvar(a:buf, '&buftype')) && a:file!~#'\v^\w+\:\/' + let dir=fnamemodify(a:file, ':h') + if !isdirectory(dir) + call mkdir(dir, 'p') + endif + endif +endfunc + +func! vimrc#AutoSessionCheck() abort + if strlen(v:servername) > 0 && match(v:servername, 'VIM') == -1 + let sessionfile = g:vimcache . "/session/" . tolower(v:servername) . ".vim" + + if filereadable(sessionfile) + execute "source " . sessionfile + endif + endif +endfunc + +func! vimrc#Grep(...) abort + let pattern = get(a:000, 0, expand('<cword>')) + let cmd = join([&grepprg, shellescape(pattern)] + a:000[1:], ' ') + + echo cmd + cgetexpr system(cmd) + call setqflist([], 'a', {"title": cmd}) + let @/ = '\v' . pattern + copen + cfirst +endfunc + +func! vimrc#Gcd() abort + let root = system('git rev-parse --show-toplevel 2>/dev/null')[:-2] + if ! v:shell_error + exec 'cd ' . root + endif + pwd +endfunc + +func! vimrc#Hgcd() abort + let root = system('hg root 2>/dev/null')[:-2] + if ! v:shell_error + exec 'cd ' . root + endif + pwd +endfunc + +func! vimrc#SafeFilterFile(cmd) + let errors = tempname() + try + exec 'silent %!' . a:cmd . ' 2>' . shellescape(errors) + if v:shell_error + for line in readfile(errors) + echomsg line + endfor + endif + finally + call delete(errors) + endtry +endfunc + +if has('perl') + func! vimrc#PruneSession() abort + perl <<END_PERL + my @bufs = + grep { !-e $_->Name || -d _ || (-M _ >= 30) } + grep { $_->Name } VIM::Buffers(); + + while (my $b = shift @bufs) { + VIM::Msg 'pruned: ' . $b->Name, 'Comment'; + VIM::DoCommand 'bwipeout ' . $b->Number; + } + VIM::DoCommand 'bprev' + unless $curbuf->Name; +END_PERL + endfunc +endif + +func! vimrc#PrepDir(path) abort + if !filewritable(a:path) + call mkdir(a:path, 'p', 0700) + endif +endfunc + +if has('ruby') + func! s:PruneFiles(path, days) abort + ruby <<END_RUBY + require 'pathname' + + (path, days) = VIM.evaluate('[a:path, a:days]') + sunset = Time.now - (days * 86400) + + Pathname(path).realpath.each_child do |file| + file.delete if file.mtime < sunset + end +END_RUBY + endfunc +else + func! s:PruneFiles(path, days) abort + endfunc +endif + +func! vimrc#PruneFiles(path, days) abort + call s:PruneFiles(a:path, a:days) +endfunc +
--- a/.config/nvim/init.lua +++ b/.config/nvim/init.lua @@ -1,14 +1,20 @@ +local g = vim.g + require("config.options") require("lazy-bootstrap") require("config.maps") require("config.lsp") -local g = vim.g - -- >> Builtin g.netrw_altfile = 1 g.netrw_use_errorwindow = 0 +-- >> Perl +g.perl_include_pod = 1 +g.perl_sub_signatures = 1 +g.perl_sync_dist = 300 +g.perl_compiler_force_warnings = 0 + -- >> Undotree g.undotree_SplitWidth = 45 g.undotree_SetFocusWhenToggle = 1 @@ -21,3 +27,6 @@ g.tagbar_autofocus = 1 g.tagbar_compact = 1 g.tagbar_width = 30 +-- >> Viewdoc +g.viewdoc_open = "topleft new" +g.viewdoc_winwidth_max = 100
--- a/.config/nvim/lua/config/lsp.lua +++ b/.config/nvim/lua/config/lsp.lua @@ -8,34 +8,3 @@ vim.api.nvim_create_autocmd("LspAttach", vim.opt.number = true end, }) - -local opts = { noremap=true, silent=true } -vim.keymap.set('n', '<leader>d', vim.diagnostic.open_float, opts) -vim.keymap.set('n', '[d', vim.diagnostic.goto_prev, opts) -vim.keymap.set('n', ']d', vim.diagnostic.goto_next, opts) -vim.keymap.set('n', '<leader>ld', vim.diagnostic.setloclist, opts) - -vim.api.nvim_create_autocmd("LspAttach", { - callback = function(args) - local bufnr = args.buf - local bufopts = { noremap=true, silent=true, buffer=bufnr } - - vim.keymap.set('n', 'gD', vim.lsp.buf.declaration, bufopts) - vim.keymap.set('n', 'gd', vim.lsp.buf.definition, bufopts) - vim.keymap.set('n', 'K', vim.lsp.buf.hover, bufopts) - vim.keymap.set('n', 'gi', vim.lsp.buf.implementation, bufopts) - vim.keymap.set('n', '<C-k>', vim.lsp.buf.signature_help, bufopts) - vim.keymap.set('n', '<leader>wa', vim.lsp.buf.add_workspace_folder, bufopts) - vim.keymap.set('n', '<leader>wr', vim.lsp.buf.remove_workspace_folder, bufopts) - vim.keymap.set('n', '<leader>wl', function() - print(vim.inspect(vim.lsp.buf.list_workspace_folders())) - end, bufopts) - vim.keymap.set('n', '<leader>D', vim.lsp.buf.type_definition, bufopts) - vim.keymap.set('n', '<leader>rn', vim.lsp.buf.rename, bufopts) - vim.keymap.set('n', '<leader>ca', vim.lsp.buf.code_action, bufopts) - vim.keymap.set('n', 'gr', vim.lsp.buf.references, bufopts) - vim.keymap.set('n', '<leader>f', function() vim.lsp.buf.format { async = true } end, bufopts) - end, -}) - -
--- a/.config/nvim/lua/config/maps.lua +++ b/.config/nvim/lua/config/maps.lua @@ -15,13 +15,72 @@ map.set("i", "<F4>", "<C-O><F4>") -- cover for search habit map.set("c", "<F3>", "<CR>", opts) +-- change to file's directory map.set("n", "<leader>cd", ":cd %:p:h<CR>:pwd<CR>", opts) +-- window switching map.set("n", "<C-h>", "<C-w>h", opts) map.set("n", "<C-j>", "<C-w>j", opts) map.set("n", "<C-k>", "<C-w>k", opts) map.set("n", "<C-l>", "<C-w>l", opts) map.set("n", "<C-\\>", "<C-w>p", opts) +-- buffer switching map.set("n", "gb", "<C-^>", opts) map.set("n", "gB", ":ls<CR>:b ", {noremap = true}) + +-- Select last paste, in the same mode it was pasted in +map.set("n", "gV", "'`[' . strpart(getregtype(), 0, 1) . '`]'", {noremap=true, expr=true}) + +-- Use ltag over tselect +map.set("n", "g<C-]>", ":exe 'ltag ' . expand('<cword>') | lopen<CR>", opts) + +-- clear all interestingwords with \\k since \K is ri.vim +map.set("n", "<leader><leader>k", ":call UncolorAllWords()<CR>", opts) + +-- mark line +map.set("n", "<leader>l", "V<leader>k", opts) + +-- use Grep for a recursive * +map.set("n", "g*", ":Grep<CR>", opts) + +-- K: doc, gKK: doc current filename +map.set("n", "gKK", ":call ViewDoc('doc', expand('%:p'))<CR>", opts) + +-- Tabular shortcuts +map.set("n", "<leader>ta", ":Tabularize first_arrow<CR>", opts) +map.set("n", "<leader>te", ":Tabularize first_eq<CR>", opts) +map.set("n", "<leader>tc", ":Tabularize first_colon<CR>", opts) +map.set("n", "<leader>tm", ":Tabularize methods<CR>", opts) + +map.set("n", "<leader>a", ":call vimrc#AutoFmtToggle()<CR>", opts) + +-- LSP features +map.set('n', '<leader>d', vim.diagnostic.open_float, opts) +map.set('n', '[d', vim.diagnostic.goto_prev, opts) +map.set('n', ']d', vim.diagnostic.goto_next, opts) +map.set('n', '<leader>ld', vim.diagnostic.setloclist, opts) + +vim.api.nvim_create_autocmd("LspAttach", { + callback = function(args) + local bufnr = args.buf + local bufopts = { noremap=true, silent=true, buffer=bufnr } + + map.set('n', 'gD', vim.lsp.buf.declaration, bufopts) + map.set('n', 'gd', vim.lsp.buf.definition, bufopts) + map.set('n', 'K', vim.lsp.buf.hover, bufopts) + map.set('n', 'gi', vim.lsp.buf.implementation, bufopts) + map.set('n', '<C-k>', vim.lsp.buf.signature_help, bufopts) + map.set('n', '<leader>wa', vim.lsp.buf.add_workspace_folder, bufopts) + map.set('n', '<leader>wr', vim.lsp.buf.remove_workspace_folder, bufopts) + map.set('n', '<leader>wl', function() + print(vim.inspect(vim.lsp.buf.list_workspace_folders())) + end, bufopts) + map.set('n', '<leader>D', vim.lsp.buf.type_definition, bufopts) + map.set('n', '<leader>rn', vim.lsp.buf.rename, bufopts) + map.set('n', '<leader>ca', vim.lsp.buf.code_action, bufopts) + map.set('n', 'gr', vim.lsp.buf.references, bufopts) + map.set('n', '<leader>f', function() vim.lsp.buf.format { async = true } end, bufopts) + end, +}) +
--- a/.config/nvim/lua/config/options.lua +++ b/.config/nvim/lua/config/options.lua @@ -45,7 +45,6 @@ o.wildignore = "*~,*.o,*.pyc,.git/*,hg/* if vim.fn.executable("ag") then o.grepprg = "ag --vimgrep" - o.grepformat:prepend({"%f:%l:%c:%m", "%f"}) - o.errorformat:append("%f") + -- o.grepformat:prepend({"%f:%l:%c:%m", "%f"}) + -- o.errorformat:append("%f") end -
--- a/.config/nvim/lua/plugins/editing.lua +++ b/.config/nvim/lua/plugins/editing.lua @@ -1,9 +1,24 @@ +local g = vim.g + +-- >> Undotree +g.undotree_SplitWidth = 45 +g.undotree_SetFocusWhenToggle = 1 +g.undotree_ShortIndicators = 1 +g.undotree_DiffCommand = "diff -dp -U 1" + +-- >> Tagbar +g.tagbar_autoclose = 1 +g.tagbar_autofocus = 1 +g.tagbar_compact = 1 +g.tagbar_width = 30 + return { "editorconfig/editorconfig-vim", + "tpope/vim-unimpaired", - "godlygeek/tabular", "tomtom/tcomment_vim", "tpope/vim-endwise", + {"godlygeek/tabular", cmd = "Tabularize"}, {"mbbill/undotree", cmd = "UndotreeToggle"}, "tpope/vim-vinegar",
new file mode 100644 --- /dev/null +++ b/.config/nvim/lua/plugins/etc.lua @@ -0,0 +1,20 @@ +local g = vim.g + +g.vimwiki_auto_chdir = 1 +g.vimwiki_auto_header = 1 +g.vimwiki_ext2syntax = {[vim.type_idx]=vim.types.dictionary} + +g.vimwiki_list = { + { + path = '~/vimwiki/', + auto_tags = 1, auto_toc = 1, automatic_nested_syntaxes = 1 + }, + { + path = '~/Documents/SpiderOak Hive/vimwiki', + auto_tags = 1, auto_toc = 1, automatic_nested_syntaxes = 1 + } +} + +return { + 'vimwiki/vimwiki', +}
new file mode 100644 --- /dev/null +++ b/.config/nvim/lua/plugins/filetype.lua @@ -0,0 +1,18 @@ +local g = vim.g + +-- >> Polyglot +g.polyglot_disabled = {'autoindent', 'sensible', 'vifm', 'perl', 'go'} + +-- >> Perl +g.perl_include_pod = 1 +g.perl_sub_signatures = 1 +g.perl_sync_dist = 300 +g.perl_compiler_force_warnings = 0 + +return { + 'Shougo/vinarise.vim', + 'asciidoc/vim-asciidoc', + {'vim-perl/vim-perl', branch = 'dev'}, + 'sheerun/vim-polyglot', + 'yko/mojo.vim', +}
--- a/.config/nvim/lua/plugins/lsp.lua +++ b/.config/nvim/lua/plugins/lsp.lua @@ -11,6 +11,11 @@ return { function(server) require("lspconfig")[server].setup({}) end, + gopls = function () + require("lspconfig").gopls.setup({ + settings = { gopls = { gofumpt = true } } + }) + end }) end, },
--- a/.config/nvim/lua/plugins/ui.lua +++ b/.config/nvim/lua/plugins/ui.lua @@ -1,4 +1,13 @@ +local g = vim.g + +-- >> Viewdoc +g.no_viewdoc_abbrev = 1 +g.viewdoc_open = "topleft new" +g.viewdoc_winwidth_max = 100 + return { + "powerman/vim-plugin-viewdoc", + { "nvim-lualine/lualine.nvim", opts = { @@ -24,7 +33,7 @@ return { opts = { enabled = false, char = "│", - filetype_exclude = { "help", "alpha", "dashboard", "neo-tree", "Trouble", "lazy" }, + -- filetype_exclude = { "help", "alpha", "dashboard", "neo-tree", "Trouble", "lazy" }, show_trailing_blankline_indent = false, show_current_context = false, },
new file mode 100644 --- /dev/null +++ b/.config/nvim/plugin/vimrc/autocmds.vim @@ -0,0 +1,51 @@ +augroup vimrc + autocmd! + + autocmd WinLeave * if !pumvisible() | stopinsert | endif + + " complement to autowriteall + autocmd FocusLost * silent! wa + + " Make paths when writing, as necessary + autocmd BufWritePre * :call vimrc#MkNonExDir(expand('<afile>'), +expand('<abuf>')) + + if ! &diff + " set and load a session based on servername + autocmd VimEnter * nested call vimrc#AutoSessionCheck() + + " Jump to last known pos + autocmd BufReadPost * + \ if &filetype !~# 'mail\|^git\|^hg' && line("'\"") >= 1 && line("'\"") <= line("$") | + \ exe "normal! g`\"" | + \ endif + + " Simple highlight conflict markers + autocmd BufReadPost * + \ match Error "^\([<>|]\)\{7} \@=\|^=\{7}$" + endif + + " Simplify noisy ltag output + autocmd BufReadPost quickfix + \ if w:quickfix_title =~# '^:ltag' | + \ setl modifiable | + \ silent exe ':%s/\^\\V\s*\|\\\$|.*//g' | + \ setl nomodifiable | + \ endif + + " easy close quickfix + autocmd BufReadPost quickfix nmap <buffer> q <C-w>c + + " Neomutt changed their tmpfile pattern, ugh + autocmd BufNewFile,BufRead neomutt-*-\w\+ setf mail +augroup END + +" https://mjj.io/2015/01/27/encrypting-files-with-gpg-and-vim/ +" hacked to work with vimwiki +augroup encrypted + autocmd! + autocmd BufReadPre,FileReadPre *.gpg,*.gpg.* setl noswapfile noundofile nobackup viminfo= + autocmd BufReadPost *.gpg,*.gpg.* call vimrc#SafeFilterFile('gpg2 -d') + autocmd BufWritePre *.gpg,*.gpg.* call vimrc#SafeFilterFile('gpg2 -se -a --default-recipient-self') + autocmd BufWritePost *.gpg,*.gpg.* :sil undo +augroup END +
new file mode 100644 --- /dev/null +++ b/.config/nvim/plugin/vimrc/commands.vim @@ -0,0 +1,35 @@ +command! -nargs=+ CAlias call vimrc#CommandAlias(<f-args>) + +command! Gcd call vimrc#Gcd() +command! Hgcd call vimrc#Hgcd() + +command! SyntaxCompleteOn setl omnifunc=syntaxcomplete#Complete + +command! Mksession execute "mksession! " . v:this_session +command! PruneSession call vimrc#PruneSession() + +command! -nargs=* -complete=file Tig call tig#Tig(<f-args>) +command! TigBlame call tig#TigBlame() +command! TigLog call tig#Tig('log', '-p', '--', expand('%')) + +" Preview markdown mail -- I edit with headers so I box them in a code block. +command! MailPreview enew | set bt=nofile | 0r # | exe 'norm! 0O```<Esc>}O```' | silent exe '%!mutt-md2html | mutt-html2txt' | 0 +command! MailPreviewHTML enew | set bt=nofile | setf html | 0r # | exe 'norm! 0O```<Esc>}O```' | silent exe '%!mutt-md2html' | 0 + +command! -nargs=* -complete=file Grep call vimrc#Grep(<f-args>) +CAlias Ag Grep +CAlias grep Grep + +CAlias Q q +CAlias Qa qa +CAlias W w + +CAlias gcd Gcd +CAlias hgcd Hgcd + +" make these default to one window/buffer too +CAlias doc ViewDoc! +CAlias help ViewDocHelp! +CAlias man ViewDocMan! +CAlias perldoc ViewDocPerl! +