diff --git a/nvim/init.lua b/nvim/init.lua index 7c75cc1..436bfee 100644 --- a/nvim/init.lua +++ b/nvim/init.lua @@ -9,3 +9,4 @@ require "settings.lualine" require "settings.gitsign" require "settings.toggleterm" require "settings.comment" +require "settings.coc" diff --git a/nvim/lua/settings/coc.lua b/nvim/lua/settings/coc.lua new file mode 100644 index 0000000..22cb4d4 --- /dev/null +++ b/nvim/lua/settings/coc.lua @@ -0,0 +1,178 @@ +-- Always show the signcolumn, otherwise it would shift the text each time +-- diagnostics appeared/became resolved +vim.opt.signcolumn = "yes" + +local keyset = vim.keymap.set +-- 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 ' 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", "", 'coc#pum#visible() ? coc#pum#next(1) : v:lua.check_back_space() ? "" : coc#refresh()', opts) +keyset("i", "", [[coc#pum#visible() ? coc#pum#prev(1) : "\"]], opts) + +-- Make to accept selected completion item or notify coc.nvim to format +-- u breaks current undo, please make your own choice +keyset("i", "", [[coc#pum#visible() ? coc#pum#confirm() : "\u\\=coc#on_enter()\"]], opts) + +-- Use to trigger snippets +keyset("i", "", "(coc-snippets-expand-jump)") +-- Use to trigger completion +keyset("i", "", "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", "(coc-diagnostic-prev)", {silent = true}) +keyset("n", "]g", "(coc-diagnostic-next)", {silent = true}) + +-- GoTo code navigation +keyset("n", "gd", "(coc-definition)", {silent = true}) +keyset("n", "gy", "(coc-type-definition)", {silent = true}) +keyset("n", "gi", "(coc-implementation)", {silent = true}) +keyset("n", "gr", "(coc-references)", {silent = true}) + + +-- Use K to show documentation in preview window +function _G.show_docs() + local cw = vim.fn.expand('') + 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", 'lua _G.show_docs()', {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", "rn", "(coc-rename)", {silent = true}) + + +-- Formatting selected code +keyset("x", "f", "(coc-format-selected)", {silent = true}) +keyset("n", "f", "(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: `aap` for current paragraph +local opts = {silent = true, nowait = true} +keyset("x", "a", "(coc-codeaction-selected)", opts) +keyset("n", "a", "(coc-codeaction-selected)", opts) + +-- Remap keys for apply code actions at the cursor position. +keyset("n", "ac", "(coc-codeaction-cursor)", opts) +-- Remap keys for apply code actions affect whole buffer. +keyset("n", "as", "(coc-codeaction-source)", opts) +-- Remap keys for applying codeActions to the current buffer +keyset("n", "ac", "(coc-codeaction)", opts) +-- Apply the most preferred quickfix action on the current line. +keyset("n", "qf", "(coc-fix-current)", opts) + +-- Remap keys for apply refactor code actions. +keyset("n", "re", "(coc-codeaction-refactor)", { silent = true }) +keyset("x", "r", "(coc-codeaction-refactor-selected)", { silent = true }) +keyset("n", "r", "(coc-codeaction-refactor-selected)", { silent = true }) + +-- Run the Code Lens actions on the current line +keyset("n", "cl", "(coc-codelens-action)", opts) + + +-- Map function and class text objects +-- NOTE: Requires 'textDocument.documentSymbol' support from the language server +keyset("x", "if", "(coc-funcobj-i)", opts) +keyset("o", "if", "(coc-funcobj-i)", opts) +keyset("x", "af", "(coc-funcobj-a)", opts) +keyset("o", "af", "(coc-funcobj-a)", opts) +keyset("x", "ic", "(coc-classobj-i)", opts) +keyset("o", "ic", "(coc-classobj-i)", opts) +keyset("x", "ac", "(coc-classobj-a)", opts) +keyset("o", "ac", "(coc-classobj-a)", opts) + + +-- Remap and to scroll float windows/popups +---@diagnostic disable-next-line: redefined-local +local opts = {silent = true, nowait = true, expr = true} +keyset("n", "", 'coc#float#has_scroll() ? coc#float#scroll(1) : ""', opts) +keyset("n", "", 'coc#float#has_scroll() ? coc#float#scroll(0) : ""', opts) +keyset("i", "", + 'coc#float#has_scroll() ? "=coc#float#scroll(1)" : ""', opts) +keyset("i", "", + 'coc#float#has_scroll() ? "=coc#float#scroll(0)" : ""', opts) +keyset("v", "", 'coc#float#has_scroll() ? coc#float#scroll(1) : ""', opts) +keyset("v", "", 'coc#float#has_scroll() ? coc#float#scroll(0) : ""', opts) + + +-- Use CTRL-S for selections ranges +-- Requires 'textDocument/selectionRange' support of language server +keyset("n", "", "(coc-range-select)", {silent = true}) +keyset("x", "", "(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', )", {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", "a", ":CocList diagnostics", opts) +-- Manage extensions +keyset("n", "e", ":CocList extensions", opts) +-- Show commands +keyset("n", "c", ":CocList commands", opts) +-- Find symbol of current document +keyset("n", "o", ":CocList outline", opts) +-- Search workspace symbols +keyset("n", "s", ":CocList -I symbols", opts) +-- Do default action for next item +keyset("n", "j", ":CocNext", opts) +-- Do default action for previous item +keyset("n", "k", ":CocPrev", opts) +-- Resume latest coc list +keyset("n", "p", ":CocListResume", opts) diff --git a/nvim/settings/colorscheme.lua b/nvim/lua/settings/colorscheme.lua similarity index 100% rename from nvim/settings/colorscheme.lua rename to nvim/lua/settings/colorscheme.lua diff --git a/nvim/settings/comment.lua b/nvim/lua/settings/comment.lua similarity index 100% rename from nvim/settings/comment.lua rename to nvim/lua/settings/comment.lua diff --git a/nvim/settings/gitsign.lua b/nvim/lua/settings/gitsign.lua similarity index 100% rename from nvim/settings/gitsign.lua rename to nvim/lua/settings/gitsign.lua diff --git a/nvim/settings/impatient.lua b/nvim/lua/settings/impatient.lua similarity index 100% rename from nvim/settings/impatient.lua rename to nvim/lua/settings/impatient.lua diff --git a/nvim/settings/keymaps.lua b/nvim/lua/settings/keymaps.lua similarity index 100% rename from nvim/settings/keymaps.lua rename to nvim/lua/settings/keymaps.lua diff --git a/nvim/settings/lualine.lua b/nvim/lua/settings/lualine.lua similarity index 100% rename from nvim/settings/lualine.lua rename to nvim/lua/settings/lualine.lua diff --git a/nvim/settings/nvim-tree.lua b/nvim/lua/settings/nvim-tree.lua similarity index 100% rename from nvim/settings/nvim-tree.lua rename to nvim/lua/settings/nvim-tree.lua diff --git a/nvim/settings/options.lua b/nvim/lua/settings/options.lua similarity index 98% rename from nvim/settings/options.lua rename to nvim/lua/settings/options.lua index 30f0227..b2b6d0b 100644 --- a/nvim/settings/options.lua +++ b/nvim/lua/settings/options.lua @@ -20,7 +20,6 @@ vim.opt.timeoutlen = 1000 -- time to wait for a mapped seq vim.opt.undofile = true -- enable persistent undo vim.opt.updatetime = 300 -- faster completion (4000ms default) vim.opt.writebackup = false -- if a file is being edited by another program (or was written to file while editing with another program), it is not allowed to be edited -vim.opt.expandtab = true -- convert tabs to spaces vim.opt.shiftwidth = 2 -- the number of spaces inserted for each indentation vim.opt.tabstop = 2 -- insert 2 spaces for a tab vim.opt.cursorline = true -- highlight the current line diff --git a/nvim/settings/plugins.lua b/nvim/lua/settings/plugins.lua similarity index 94% rename from nvim/settings/plugins.lua rename to nvim/lua/settings/plugins.lua index a7ecb0b..a6cbd3a 100644 --- a/nvim/settings/plugins.lua +++ b/nvim/lua/settings/plugins.lua @@ -43,7 +43,7 @@ packer.init { -- Install your plugins here return packer.startup(function(use) - -- My plugins here + -- General plugins use { "wbthomason/packer.nvim" } -- Have packer manage itself use { "nvim-lua/plenary.nvim" } -- Useful lua functions used by lots of plugins use { "windwp/nvim-autopairs" } -- Autopairs, integrates with both cmp and treesitter @@ -74,6 +74,12 @@ return packer.startup(function(use) -- Git use { "lewis6991/gitsigns.nvim" } + -- COC + use { "neoclide/coc.nvim", branch = "release" } + + -- Go + use { "fatih/vim-go", run = "GoUpdateBinaries" } + -- DAP use { "mfussenegger/nvim-dap" } use { "rcarriga/nvim-dap-ui" } diff --git a/nvim/settings/telescope.lua b/nvim/lua/settings/telescope.lua similarity index 100% rename from nvim/settings/telescope.lua rename to nvim/lua/settings/telescope.lua diff --git a/nvim/settings/toggleterm.lua b/nvim/lua/settings/toggleterm.lua similarity index 100% rename from nvim/settings/toggleterm.lua rename to nvim/lua/settings/toggleterm.lua diff --git a/nvim/plugin/packer_compiled.lua b/nvim/plugin/packer_compiled.lua index 15516ac..083e331 100644 --- a/nvim/plugin/packer_compiled.lua +++ b/nvim/plugin/packer_compiled.lua @@ -94,6 +94,11 @@ _G.packer_plugins = { path = "/Users/shuse2/.local/share/nvim/site/pack/packer/start/bufferline.nvim", url = "https://github.com/akinsho/bufferline.nvim" }, + ["coc.nvim"] = { + loaded = true, + path = "/Users/shuse2/.local/share/nvim/site/pack/packer/start/coc.nvim", + url = "https://github.com/neoclide/coc.nvim" + }, ["gitsigns.nvim"] = { loaded = true, path = "/Users/shuse2/.local/share/nvim/site/pack/packer/start/gitsigns.nvim", @@ -183,6 +188,11 @@ _G.packer_plugins = { loaded = true, path = "/Users/shuse2/.local/share/nvim/site/pack/packer/start/vim-bbye", url = "https://github.com/moll/vim-bbye" + }, + ["vim-go"] = { + loaded = true, + path = "/Users/shuse2/.local/share/nvim/site/pack/packer/start/vim-go", + url = "https://github.com/fatih/vim-go" } }