From 18edf9861d1b38591b51b42465b224d77736db04 Mon Sep 17 00:00:00 2001 From: listout Date: Tue, 2 Aug 2022 01:10:05 +0530 Subject: nvim: moving init to lua Signed-off-by: listout --- lua/plugins/coc.lua | 153 +++++++++++++++++++++++++++++++++++++++++++++ lua/plugins/plugins.lua | 38 +++++++++++ lua/plugins/statusline.lua | 56 +++++++++++++++++ 3 files changed, 247 insertions(+) create mode 100644 lua/plugins/coc.lua create mode 100644 lua/plugins/plugins.lua create mode 100644 lua/plugins/statusline.lua (limited to 'lua/plugins') diff --git a/lua/plugins/coc.lua b/lua/plugins/coc.lua new file mode 100644 index 0000000..0e997a9 --- /dev/null +++ b/lua/plugins/coc.lua @@ -0,0 +1,153 @@ +-- vim.cmd('source ' .. 'lua/plugins/coc.vim') +vim.cmd([[ + " Global extensions + let g:coc_global_extensions = [ + \ 'coc-lists', + \ 'coc-snippets', + \ 'coc-highlight', + \ 'coc-json', + \ 'coc-dictionary', + \ 'coc-word', + \ 'coc-syntax', + \ 'coc-ultisnips', + \ 'coc-vimtex' + \] + + " Use tab for trigger completion with characters ahead and navigate. + " NOTE: Use command ':verbose imap ' to make sure tab is not mapped by + " other plugin before putting this into your config. + inoremap + \ coc#pum#visible() ? coc#pum#next(1): + \ CheckBackspace() ? "\" : + \ coc#refresh() + inoremap coc#pum#visible() ? coc#pum#prev(1) : "\" + + " Make to accept selected completion item or notify coc.nvim to format + " u breaks current undo, please make your own choice. + inoremap coc#pum#visible() ? coc#pum#confirm() + \: "\u\\=coc#on_enter()\" + + function! CheckBackspace() abort + let col = col('.') - 1 + return !col || getline('.')[col - 1] =~# '\s' + endfunction + + " Use to trigger completion. + if has('nvim') + inoremap coc#refresh() + else + inoremap coc#refresh() + endif + + " Use `[g` and `]g` to navigate diagnostics + " Use `:CocDiagnostics` to get all diagnostics of current buffer in location list. + nmap [g (coc-diagnostic-prev) + nmap ]g (coc-diagnostic-next) + + " GoTo code navigation. + nmap gd (coc-definition) + nmap gy (coc-type-definition) + nmap gi (coc-implementation) + nmap gr (coc-references) + + " Use K to show documentation in preview window. + nnoremap K :call ShowDocumentation() + + function! ShowDocumentation() + if CocAction('hasProvider', 'hover') + call CocActionAsync('doHover') + else + call feedkeys('K', 'in') + endif + endfunction + + " Highlight the symbol and its references when holding the cursor. + autocmd CursorHold * silent call CocActionAsync('highlight') + + " Symbol renaming. + nmap rn (coc-rename) + + " Formatting selected code. + xmap f (coc-format-selected) + nmap f (coc-format-selected) + + augroup mygroup + autocmd! + " Setup formatexpr specified filetype(s). + autocmd FileType typescript,json setl formatexpr=CocAction('formatSelected') + " Update signature help on jump placeholder. + autocmd User CocJumpPlaceholder call CocActionAsync('showSignatureHelp') + augroup end + + " Applying codeAction to the selected region. + " Example: `aap` for current paragraph + xmap a (coc-codeaction-selected) + nmap a (coc-codeaction-selected) + + " Remap keys for applying codeAction to the current buffer. + nmap ac (coc-codeaction) + " Apply AutoFix to problem on the current line. + nmap qf (coc-fix-current) + + " Run the Code Lens action on the current line. + nmap cl (coc-codelens-action) + + " Map function and class text objects + " NOTE: Requires 'textDocument.documentSymbol' support from the language server. + xmap if (coc-funcobj-i) + omap if (coc-funcobj-i) + xmap af (coc-funcobj-a) + omap af (coc-funcobj-a) + xmap ic (coc-classobj-i) + omap ic (coc-classobj-i) + xmap ac (coc-classobj-a) + omap ac (coc-classobj-a) + + " Remap and for scroll float windows/popups. + if has('nvim-0.4.0') || has('patch-8.2.0750') + nnoremap coc#float#has_scroll() ? coc#float#scroll(1) : "\" + nnoremap coc#float#has_scroll() ? coc#float#scroll(0) : "\" + inoremap coc#float#has_scroll() ? "\=coc#float#scroll(1)\" : "\" + inoremap coc#float#has_scroll() ? "\=coc#float#scroll(0)\" : "\" + vnoremap coc#float#has_scroll() ? coc#float#scroll(1) : "\" + vnoremap coc#float#has_scroll() ? coc#float#scroll(0) : "\" + endif + + " Use CTRL-S for selections ranges. + " Requires 'textDocument/selectionRange' support of language server. + nmap (coc-range-select) + xmap (coc-range-select) + + " Add `:Format` command to format current buffer. + command! -nargs=0 Format :call CocActionAsync('format') + + " Add `:Fold` command to fold current buffer. + command! -nargs=? Fold :call CocAction('fold', ) + + " Add `:OR` command for organize imports of the current buffer. + command! -nargs=0 OR :call CocActionAsync('runCommand', 'editor.action.organizeImport') + + " Add (Neo)Vim's native statusline support. + " NOTE: Please see `:h coc-status` for integrations with external plugins that + " provide custom statusline: lightline.vim, vim-airline. + set statusline^=%{coc#status()}%{get(b:,'coc_current_function','')} + + " Mappings for CoCList + " Show all diagnostics. + nnoremap a :CocList diagnostics + " Manage extensions. + nnoremap e :CocList extensions + " Show commands. + nnoremap c :CocList commands + " Find symbol of current document. + nnoremap o :CocList outline + " Search workspace symbols. + nnoremap s :CocList -I symbols + " Do default action for next item. + nnoremap j :CocNext + " Do default action for previous item. + nnoremap k :CocPrev + " Resume latest coc list. + nnoremap p :CocListResume + +]]) diff --git a/lua/plugins/plugins.lua b/lua/plugins/plugins.lua new file mode 100644 index 0000000..c78ffc1 --- /dev/null +++ b/lua/plugins/plugins.lua @@ -0,0 +1,38 @@ +-- This file can be loaded by calling `lua require('plugins')` from your init.vim + +-- Only required if you have packer configured as `opt` +vim.cmd [[packadd packer.nvim]] + +return require('packer').startup(function(use) + -- Packer can manage itself + use 'wbthomason/packer.nvim' + + -- Nord color scheme + use 'shaunsingh/nord.nvim' + + -- Completion + use {'neoclide/coc.nvim', branch = 'release'} + + + use {'ap/vim-css-color'} + + use {'jiangmiao/auto-pairs'} + use {'preservim/nerdcommenter'} + use { 'dhruvasagar/vim-table-mode', ft = {'markdown', 'markdown.pandoc'} } + + use { 'vim-pandoc/vim-pandoc-syntax', ft = { 'markdown', 'markdown.pandoc' } } + use { 'lervag/vimtex', ft = { 'tex' } } + + use { 'junegunn/fzf', run = ":call fzf#install()" } + use { 'junegunn/fzf.vim' } + + use { 'honza/vim-snippets' } + use { 'SirVer/ultisnips' } + + use {'tpope/vim-surround'} + use {'junegunn/vim-easy-align'} + + + use { 'tpope/vim-fugitive', ft = {'cpp', 'c'} } + use { 'nvim-treesitter/nvim-treesitter', run = ':TSUpdate' } +end) diff --git a/lua/plugins/statusline.lua b/lua/plugins/statusline.lua new file mode 100644 index 0000000..11c1435 --- /dev/null +++ b/lua/plugins/statusline.lua @@ -0,0 +1,56 @@ +vim.cmd([[ + function! StatusDiagnostic() abort + let info = get(b:, 'coc_diagnostic_info', {}) + if empty(info) | return '' | endif + let msgs = [] + if get(info, 'error', 0) + call add(msgs, 'E' . info['error']) + endif + if get(info, 'warning', 0) + call add(msgs, 'W' . info['warning']) + endif + return join(msgs, ' '). ' ' . get(g:, 'coc_status', '') + endfunction + + "let g:currentmode={ + "\ 'n' : 'NORMAL ', + "\ 'no' : 'N·Operator Pending ', + "\ 'v' : 'VISUAL ', + "\ 'V' : 'V·Line ', + "\ "\" : 'V·Block ', + "\ 's' : 'Select ', + "\ 'S' : 'S·Line ', + "\ 'x19' : 'S·Block ', + "\ 'i' : 'INSERT ', + "\ 'R' : 'REPLACE ', + "\ 'Rv' : 'V·Replace ', + "\ 'c' : 'Command ', + "\ 'cv' : 'Vim Ex ', + "\ 'ce' : 'Ex ', + "\ 'r' : 'Prompt ', + "\ 'rm' : 'More ', + "\ 'r?' : 'Confirm ', + "\ '!' : 'Shell ', + "\ 't' : 'Terminal ' + "\} + + function! ReadOnly() + if &readonly || !&modifiable + return '' + else + return '' + endfunction + + set statusline= + "set statusline+=\ %{toupper(g:currentmode[mode()])} + set statusline^=%{StatusDiagnostic()} + set statusline+=%8*\ %<%f\ %{ReadOnly()}\ %w + set statusline+=%{&modified?'[+]':''} + set statusline+=%= + set statusline+=\ %y + "set statusline+=\ %{&fileencoding?&fileencoding:&encoding} + "set statusline+=\[%{&fileformat}\] + set statusline+=\ %p%% + set statusline+=\ %l:%c + set statusline+=\ " +]]) -- cgit v1.2.3