diff --git a/after/ftplugin/haskell.vim b/after/ftplugin/haskell.vim index 2481eaa..124d675 100644 --- a/after/ftplugin/haskell.vim +++ b/after/ftplugin/haskell.vim @@ -15,7 +15,7 @@ map ctg :codex set tags=tags;/,codex.tags;/ " classic ctags jump -nnoremap gd +" nnoremap gd nnoremap cgd :cs find g =expand("") nnoremap :cs find c =expand("") @@ -96,26 +96,33 @@ let g:vim_annotations_offset = '/.liquid/' " LSP let g:LanguageClient_autoStart = 0 let g:LanguageClient_serverCommands = { - \ 'haskell': ['hie-wrapper', '--lsp', '-d', '-l', $HOME.'/lang-server.log'], + \ 'haskell': ['hie-wrapper', '--lsp', '-d', '-l', $HOME.'/lang-server-lnvim.log'], \ } " we use ALE instead let g:LanguageClient_diagnosticsEnable = 0 -nnoremap lc :call LanguageClient_contextMenu() -" nnoremap gd :call LanguageClient#textDocument_definition() -nnoremap :call LanguageClient#textDocument_hover() -vnoremap :call LanguageClient#textDocument_hover() -nnoremap :call LanguageClient#textDocument_rename() +" nnoremap ld :call LanguageClient#textDocument_definition() +" nnoremap lr :call LanguageClient#textDocument_rename() +" nnoremap lf :call LanguageClient#textDocument_formatting() +" nnoremap lt :call LanguageClient#textDocument_typeDefinition() +" nnoremap lx :call LanguageClient#textDocument_references() +" nnoremap la :call LanguageClient_workspace_applyEdit() +" nnoremap lc :call LanguageClient#textDocument_completion() +" nnoremap lh :call LanguageClient#textDocument_hover() +" nnoremap ls :call LanguageClient_textDocument_documentSymbol() +" nnoremap lm :call LanguageClient_contextMenu() +" nnoremap :call LanguageClient#textDocument_hover() + " deoplete -call deoplete#custom#option('sources',{ - \ '_': ['buffer'], - \ 'haskell': ['neosnippet', 'buffer', 'file', 'neco-ghc'] - \ }) - " \ 'haskell': ['neosnippet', 'buffer', 'file', 'neco-ghc'] -" inoremap pumvisible() ? "\" : "\" -call deoplete#enable() -call deoplete#enable_logging('DEBUG', $HOME . '/deoplete.log') +"call deoplete#custom#option('sources',{ +" \ '_': ['buffer'], +" \ 'haskell': ['neosnippet', 'buffer', 'file', 'neco-ghc'] +" \ }) +" " \ 'haskell': ['neosnippet', 'buffer', 'file', 'neco-ghc'] +"call deoplete#enable() +"call deoplete#enable_logging('DEBUG', $HOME . '/deoplete.log') +"" inoremap pumvisible() ? "\" : "\" let g:ghcmod_hlint_options = ['--ignore=Eta reduce $'] @@ -139,17 +146,18 @@ let g:ale_haskell_argon_info_level = 6 " autocmd FileType haskell setlocal omnifunc=necoghc#omnifunc " let g:ycm_semantic_triggers = {'haskell' : ['.']} +" let g:ycm_language_server = [ { 'name': 'haskell', 'filetypes': [ 'haskell', 'hs', 'lhs' ], 'cmdline': [ 'hie-wrapper' ], 'project_root_files': [ '.stack.yaml', 'cabal.config', 'package.yaml', 'cabal.project' ] } ] " clear search -nmap :noh:GhcModTypeClear -imap :noh:GhcModTypeClear +" nmap :noh:GhcModTypeClear +" imap :noh:GhcModTypeClear " unmap " unmap -nmap :GhcModType +" nmap :GhcModType " for intero " if has("nvim") @@ -188,3 +196,139 @@ let g:neoformat_enabled_haskell = ['brittany'] " nnoremap it :InteroTypeInsert " nnoremap ist :InteroSetTargets " endif + + + + +" ============ coc.nvim =========== +" markdown rendering of code blocks +let g:markdown_fenced_languages = ['haskell'] + +" if hidden is not set, TextEdit might fail. +set hidden + +" Some servers have issues with backup files, see #649 +set nobackup +set nowritebackup + +" Better display for messages +"set cmdheight=2 + +" You will have bad experience for diagnostic messages when it's default 4000. +set updatetime=300 + +" don't give |ins-completion-menu| messages. +set shortmess+=c + +" always show signcolumns +set signcolumn=yes + +" Use tab for trigger completion with characters ahead and navigate. +" Use command ':verbose imap ' to make sure tab is not mapped by other plugin. +inoremap + \ pumvisible() ? "\" : + \ check_back_space() ? "\" : + \ coc#refresh() +inoremap pumvisible() ? "\" : "\" + +function! s:check_back_space() abort + let col = col('.') - 1 + return !col || getline('.')[col - 1] =~# '\s' +endfunction + +" Use to trigger completion. +inoremap coc#refresh() + +" Use to confirm completion, `u` means break undo chain at current position. +" Coc only does snippet and additional edit on confirm. +inoremap pumvisible() ? "\" : "\u\" +" Or use `complete_info` if your vim support it, like: +" inoremap complete_info()["selected"] != "-1" ? "\" : "\u\" + +" Use `[g` and `]g` to navigate diagnostics +nmap [g (coc-diagnostic-prev) +nmap ]g (coc-diagnostic-next) + +" Remap keys for gotos +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 show_documentation() + +function! s:show_documentation() + if (index(['vim','help'], &filetype) >= 0) + execute 'h '.expand('') + else + call CocAction('doHover') + endif +endfunction + +" Highlight symbol under cursor on CursorHold +autocmd CursorHold * silent call CocActionAsync('highlight') + +" Remap for rename current word +nmap rn (coc-rename) + +" Remap for format selected region +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 + +" Remap for do codeAction of selected region, ex: `aap` for current paragraph +xmap a (coc-codeaction-selected) +nmap a (coc-codeaction-selected) + +" Remap for do codeAction of current line +nmap ac (coc-codeaction) +" Fix autofix problem of current line +nmap qf (coc-fix-current) + +" Create mappings for function text object, requires document symbols feature of languageserver. +xmap if (coc-funcobj-i) +xmap af (coc-funcobj-a) +omap if (coc-funcobj-i) +omap af (coc-funcobj-a) + +" Use for select selections ranges, needs server support, like: coc-tsserver, coc-python +nmap (coc-range-select) +xmap (coc-range-select) + +" Use `:Format` to format current buffer +command! -nargs=0 Format :call CocAction('format') + +" Use `:Fold` to fold current buffer +command! -nargs=? Fold :call CocAction('fold', ) + +" use `:OR` for organize import of current buffer +command! -nargs=0 OR :call CocAction('runCommand', 'editor.action.organizeImport') + +" Add status line support, for integration with other plugin, checkout `:h coc-status` +set statusline^=%{coc#status()}%{get(b:,'coc_current_function','')} + +" Using 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/coc-settings.json b/coc-settings.json new file mode 100644 index 0000000..55bc38c --- /dev/null +++ b/coc-settings.json @@ -0,0 +1,27 @@ +{ + "languageserver": { + "haskell": { + "trace.server": "verbose", + "command": "hie-wrapper", + "args": ["--lsp", "-d", "-l", "/home/jule/lang-server.log"], + "rootPatterns": [ + "stack.yaml", + "cabal.config", + "cabal.project", + "package.yaml" + ], + "filetypes": [ + "hs", + "lhs", + "haskell" + ], + "initializationOptions": { + "languageServerHaskell": { + "hlintOn": false + } + } + } + }, + "coc.preferences.hoverTarget": "preview", + "suggest.floatEnable": true +} diff --git a/vimrc b/vimrc index 9dec29c..45fff0a 100644 --- a/vimrc +++ b/vimrc @@ -53,17 +53,17 @@ Plug 'LucHermitte/lh-vim-lib' Plug 'LucHermitte/local_vimrc' " completion -" Plug 'Valloric/YouCompleteMe', { 'do': './install.py --clang-completer --go-completer --rust-completer --system-boost --system-libclang', - " \ 'for': ['c', 'python', 'sh', 'go', 'clojure'], - " \ } +Plug 'Valloric/YouCompleteMe', { 'do': './install.py --clang-completer --go-completer --rust-completer --system-boost --system-libclang', + \ 'for': ['c', 'python', 'sh', 'go', 'clojure'], + \ } " deoplete for haskell if has('nvim') - Plug 'Shougo/deoplete.nvim', { 'do': ':UpdateRemotePlugins', - \ } + " Plug 'Shougo/deoplete.nvim', { 'do': ':UpdateRemotePlugins', + " \ } else - Plug 'Shougo/deoplete.nvim' - Plug 'roxma/nvim-yarp' - Plug 'roxma/vim-hug-neovim-rpc' + " Plug 'Shougo/deoplete.nvim' + " Plug 'roxma/nvim-yarp' + " Plug 'roxma/vim-hug-neovim-rpc' endif " snippets @@ -72,10 +72,24 @@ Plug 'honza/vim-snippets' " LSP " setting this per-language breaks "let g:LanguageClient_autoStart = 1", -Plug 'autozimu/LanguageClient-neovim', { - \ 'branch': 'next', - \ 'do': 'bash install.sh', - \ } +" Plug 'autozimu/LanguageClient-neovim', { + " \ 'branch': 'next', + " \ 'do': 'bash install.sh', + " \ } + +" Use release branch (Recommend) +Plug 'neoclide/coc.nvim', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +Plug 'neoclide/coc-tsserver', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +Plug 'neoclide/coc-git', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +Plug 'neoclide/coc-rls', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +Plug 'neoclide/coc-prettier', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +Plug 'neoclide/coc-python', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +"Plug 'neoclide/coc-vetur', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +Plug 'neoclide/coc-json', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +Plug 'neoclide/coc-eslint', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +Plug 'neoclide/coc-yaml', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +Plug 'neoclide/coc-highlight', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} +Plug 'neoclide/coc-json', {'do': 'yarn install --frozen-lockfile', 'for': ['haskell']} " linting/compilation Plug 'w0rp/ale', {