user/nvim/init.lua (view raw)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 | vim.opt.autoindent = true vim.opt.background = "light" vim.opt.shiftwidth = 2 vim.opt.tabstop = 2 vim.opt.expandtab = false vim.opt.number = true vim.cmd.colorscheme("shine") vim.g.mapleader = "," local keyset = vim.keymap.set keyset("v", "<leader>y", "\"+y", {}) keyset("n", "<leader>Y", "\"+yg_", {}) keyset("n", "<leader>y", "\"+y", {}) keyset("v", "<leader>p", "\"+p", {}) keyset("v", "<leader>P", "\"+P", {}) keyset("n", "<leader>p", "\"+p", {}) keyset("n", "<leader>P", "\"+P", {}) -- Autocomplete function _G.check_back_space() local col = vim.fn.col('.') - 1 return col == 0 or vim.fn.getline('.'):sub(col, col):match('%s') ~= nil end -- Use Tab for trigger completion with characters ahead and navigate -- NOTE: There's always a completion item selected by default, you may want to enable -- no select by setting `"suggest.noselect": true` in your configuration file -- NOTE: Use command ':verbose imap <tab>' to make sure Tab is not mapped by -- other plugins before putting this into your config local opts = {silent = true, noremap = true, expr = true, replace_keycodes = false} keyset("i", "<TAB>", 'coc#pum#visible() ? coc#pum#next(1) : v:lua.check_back_space() ? "<TAB>" : coc#refresh()', opts) keyset("i", "<S-TAB>", [[coc#pum#visible() ? coc#pum#prev(1) : "\<C-h>"]], opts) -- Make <CR> to accept selected completion item or notify coc.nvim to format -- <C-g>u breaks current undo, please make your own choice keyset("i", "<cr>", [[coc#pum#visible() ? coc#pum#confirm() : "\<C-g>u\<CR>\<c-r>=coc#on_enter()\<CR>"]], opts) -- Use <c-j> to trigger snippets keyset("i", "<c-j>", "<Plug>(coc-snippets-expand-jump)") -- Use <c-space> to trigger completion keyset("i", "<c-space>", "coc#refresh()", {silent = true, expr = true}) -- Use `[g` and `]g` to navigate diagnostics -- Use `:CocDiagnostics` to get all diagnostics of current buffer in location list keyset("n", "[g", "<Plug>(coc-diagnostic-prev)", {silent = true}) keyset("n", "]g", "<Plug>(coc-diagnostic-next)", {silent = true}) -- GoTo code navigation keyset("n", "gd", "<Plug>(coc-definition)", {silent = true}) keyset("n", "gy", "<Plug>(coc-type-definition)", {silent = true}) keyset("n", "gi", "<Plug>(coc-implementation)", {silent = true}) keyset("n", "gr", "<Plug>(coc-references)", {silent = true}) -- Use K to show documentation in preview window function _G.show_docs() local cw = vim.fn.expand('<cword>') if vim.fn.index({'vim', 'help'}, vim.bo.filetype) >= 0 then vim.api.nvim_command('h ' .. cw) elseif vim.api.nvim_eval('coc#rpc#ready()') then vim.fn.CocActionAsync('doHover') else vim.api.nvim_command('!' .. vim.o.keywordprg .. ' ' .. cw) end end keyset("n", "K", '<CMD>lua _G.show_docs()<CR>', {silent = true}) -- Highlight the symbol and its references on a CursorHold event(cursor is idle) vim.api.nvim_create_augroup("CocGroup", {}) vim.api.nvim_create_autocmd("CursorHold", { group = "CocGroup", command = "silent call CocActionAsync('highlight')", desc = "Highlight symbol under cursor on CursorHold" }) -- Symbol renaming keyset("n", "<leader>rn", "<Plug>(coc-rename)", {silent = true}) -- Formatting selected code keyset("x", "<leader>f", "<Plug>(coc-format-selected)", {silent = true}) keyset("n", "<leader>f", "<Plug>(coc-format-selected)", {silent = true}) -- Setup formatexpr specified filetype(s) vim.api.nvim_create_autocmd("FileType", { group = "CocGroup", pattern = "typescript,json", command = "setl formatexpr=CocAction('formatSelected')", desc = "Setup formatexpr specified filetype(s)." }) -- Update signature help on jump placeholder vim.api.nvim_create_autocmd("User", { group = "CocGroup", pattern = "CocJumpPlaceholder", command = "call CocActionAsync('showSignatureHelp')", desc = "Update signature help on jump placeholder" }) -- Apply codeAction to the selected region -- Example: `<leader>aap` for current paragraph local opts = {silent = true, nowait = true} keyset("x", "<leader>a", "<Plug>(coc-codeaction-selected)", opts) keyset("n", "<leader>a", "<Plug>(coc-codeaction-selected)", opts) -- Remap keys for apply code actions at the cursor position. keyset("n", "<leader>ac", "<Plug>(coc-codeaction-cursor)", opts) -- Remap keys for apply code actions affect whole buffer. keyset("n", "<leader>as", "<Plug>(coc-codeaction-source)", opts) -- Remap keys for applying codeActions to the current buffer keyset("n", "<leader>ac", "<Plug>(coc-codeaction)", opts) -- Apply the most preferred quickfix action on the current line. keyset("n", "<leader>qf", "<Plug>(coc-fix-current)", opts) -- Remap keys for apply refactor code actions. keyset("n", "<leader>re", "<Plug>(coc-codeaction-refactor)", { silent = true }) keyset("x", "<leader>r", "<Plug>(coc-codeaction-refactor-selected)", { silent = true }) keyset("n", "<leader>r", "<Plug>(coc-codeaction-refactor-selected)", { silent = true }) -- Run the Code Lens actions on the current line keyset("n", "<leader>cl", "<Plug>(coc-codelens-action)", opts) -- Map function and class text objects -- NOTE: Requires 'textDocument.documentSymbol' support from the language server keyset("x", "if", "<Plug>(coc-funcobj-i)", opts) keyset("o", "if", "<Plug>(coc-funcobj-i)", opts) keyset("x", "af", "<Plug>(coc-funcobj-a)", opts) keyset("o", "af", "<Plug>(coc-funcobj-a)", opts) keyset("x", "ic", "<Plug>(coc-classobj-i)", opts) keyset("o", "ic", "<Plug>(coc-classobj-i)", opts) keyset("x", "ac", "<Plug>(coc-classobj-a)", opts) keyset("o", "ac", "<Plug>(coc-classobj-a)", opts) -- Remap <C-f> and <C-b> to scroll float windows/popups ---@diagnostic disable-next-line: redefined-local local opts = {silent = true, nowait = true, expr = true} keyset("n", "<C-f>", 'coc#float#has_scroll() ? coc#float#scroll(1) : "<C-f>"', opts) keyset("n", "<C-b>", 'coc#float#has_scroll() ? coc#float#scroll(0) : "<C-b>"', opts) keyset("i", "<C-f>", 'coc#float#has_scroll() ? "<c-r>=coc#float#scroll(1)<cr>" : "<Right>"', opts) keyset("i", "<C-b>", 'coc#float#has_scroll() ? "<c-r>=coc#float#scroll(0)<cr>" : "<Left>"', opts) keyset("v", "<C-f>", 'coc#float#has_scroll() ? coc#float#scroll(1) : "<C-f>"', opts) keyset("v", "<C-b>", 'coc#float#has_scroll() ? coc#float#scroll(0) : "<C-b>"', opts) -- Use CTRL-S for selections ranges -- Requires 'textDocument/selectionRange' support of language server keyset("n", "<C-s>", "<Plug>(coc-range-select)", {silent = true}) keyset("x", "<C-s>", "<Plug>(coc-range-select)", {silent = true}) -- Add `:Format` command to format current buffer vim.api.nvim_create_user_command("Format", "call CocAction('format')", {}) -- " Add `:Fold` command to fold current buffer vim.api.nvim_create_user_command("Fold", "call CocAction('fold', <f-args>)", {nargs = '?'}) -- Add `:OR` command for organize imports of the current buffer vim.api.nvim_create_user_command("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 vim.opt.statusline:prepend("%{coc#status()}%{get(b:,'coc_current_function','')}") -- Mappings for CoCList -- code actions and coc stuff ---@diagnostic disable-next-line: redefined-local local opts = {silent = true, nowait = true} -- Show all diagnostics keyset("n", "<space>a", ":<C-u>CocList diagnostics<cr>", opts) -- Manage extensions keyset("n", "<space>e", ":<C-u>CocList extensions<cr>", opts) -- Show commands keyset("n", "<space>c", ":<C-u>CocList commands<cr>", opts) -- Find symbol of current document keyset("n", "<space>o", ":<C-u>CocList outline<cr>", opts) -- Search workspace symbols keyset("n", "<space>s", ":<C-u>CocList -I symbols<cr>", opts) -- Do default action for next item keyset("n", "<space>j", ":<C-u>CocNext<cr>", opts) -- Do default action for previous item keyset("n", "<space>k", ":<C-u>CocPrev<cr>", opts) -- Resume latest coc list keyset("n", "<space>p", ":<C-u>CocListResume<cr>", opts) local telescope = require("telescope") telescope.setup { defaults = { mappings = { i ={ ["<C-h>"] = "which_key" } } }, extensions = { fzf = { fuzzy = true, override_generic_sorter = true, override_file_sorter = true, case_mode = "smart_case", } } } telescope.load_extension("fzf") local ts_builtin = require('telescope.builtin') keyset("n", "<leader>ff", ts_builtin.find_files, {}) keyset("n", "<leader>fg", ts_builtin.live_grep, {}) keyset("n", "<leader>bb", ts_builtin.buffers, {}) keyset("n", "<leader>pf", ts_builtin.git_files, {}) keyset("n", "<leader>fh", ts_builtin.help_tags, {}) |