From 41f8f46169e608865d6f784349cd7c8fd54e9d7c Mon Sep 17 00:00:00 2001 From: soragui Date: Tue, 28 Jan 2020 09:57:04 +0800 Subject: [PATCH] update .vimrc --- .vimrc | 259 ++++++++++++++++++++++++++++++++++++++--------- README.md | 2 +- tools/install.sh | 10 +- 3 files changed, 218 insertions(+), 53 deletions(-) diff --git a/.vimrc b/.vimrc index c625132..a0a7790 100644 --- a/.vimrc +++ b/.vimrc @@ -1,68 +1,227 @@ call plug#begin('~/.vim/bundle') -Plug 'Valloric/YouCompleteMe' +"Plug 'Valloric/YouCompleteMe' +Plug 'neoclide/coc.nvim', {'branch': 'release'} +Plug 'scrooloose/nerdtree' +"Plug 'tsony-tsonev/nerdtree-git-plugin' +Plug 'Xuyuanp/nerdtree-git-plugin' +Plug 'tiagofumo/vim-nerdtree-syntax-highlight' +Plug 'ryanoasis/vim-devicons' +Plug 'airblade/vim-gitgutter' +Plug 'ctrlpvim/ctrlp.vim' " fuzzy find files +Plug 'scrooloose/nerdcommenter' +"Plug 'prettier/vim-prettier', { 'do': 'yarn install' } + +Plug 'christoomey/vim-tmux-navigator' + +Plug 'kristijanhusak/vim-hybrid-material' + +Plug 'HerringtonDarkholme/yats.vim' " TS Syntax +Plug 'vim-airline/vim-airline' call plug#end() -set so=10 -set number -syntax on -filetype on -filetype plugin on -filetype indent on +inoremap jk +nmap :NERDTreeToggle +vmap ++ NERDCommenterToggle +nmap ++ NERDCommenterToggle -set completeopt=longest,menu +" open NERDTree automatically +"autocmd StdinReadPre * let s:std_in=1 +"autocmd VimEnter * NERDTree -if has('mouse') - set mouse=a - set selectmode=mouse,key - set nomousehide -endif - -set autoindent -set modeline -"set cursorline -"set cursorcolumn - -set shiftwidth=4 -set tabstop=4 -set softtabstop=4 - -set showmatch -set matchtime=0 -set nobackup -set nowritebackup - -set backspace=indent,eol,start - -set fenc=utf-8 -set fencs=utf-8,gbk,gb18030,gb2312,cp936,usc-bom,euc-jp -set enc=utf-8 - -set foldmethod=syntax -set foldcolumn=0 -set foldlevel=100 - -nnoremap @=((foldcolsed(line('.')) < 0 ) ? 'zc' : 'zo') +let g:NERDTreeGitStatusWithFlags = 1 +"let g:WebDevIconsUnicodeDecorateFolderNodes = 1 +"let g:NERDTreeGitStatusNodeColorization = 1 +"let g:NERDTreeColorMapCustom = { + "\ "Staged" : "#0ee375", + "\ "Modified" : "#d9bf91", + "\ "Renamed" : "#51C9FC", + "\ "Untracked" : "#FCE77C", + "\ "Unmerged" : "#FC51E6", + "\ "Dirty" : "#FFBD61", + "\ "Clean" : "#87939A", + "\ "Ignored" : "#808080" + "\ } -set smartcase -set ignorecase -set nohlsearch -set incsearch -set autochdir +let g:NERDTreeIgnore = ['^node_modules$'] -vmap j gj -vmap k gk -nmap j gj -nmap k gk +" vim-prettier +"let g:prettier#quickfix_enabled = 0 +"let g:prettier#quickfix_auto_focus = 0 +" prettier command for coc +command! -nargs=0 Prettier :CocCommand prettier.formatFile +" run prettier on save +"let g:prettier#autoformat = 0 +"autocmd BufWritePre *.js,*.jsx,*.mjs,*.ts,*.tsx,*.css,*.less,*.scss,*.json,*.graphql,*.md,*.vue,*.yaml,*.html PrettierAsync -nmap T :tabnew +" ctrlp +let g:ctrlp_user_command = ['.git/', 'git --git-dir=%s/.git ls-files -oc --exclude-standard'] -au FileType c,cpp,h,java,css,js,nginx,scala,go inoremap { {}0 +" j/k will move virtual lines (lines that wrap) +noremap j (v:count == 0 ? 'gj' : 'j') +noremap k (v:count == 0 ? 'gk' : 'k') +set relativenumber +set smarttab +set cindent +set tabstop=2 +set shiftwidth=2 +" always uses spaces instead of tab characters +set expandtab +set background=dark +colorscheme hybrid_material + +" sync open file with NERDTree +" " Check if NERDTree is open or active +function! IsNERDTreeOpen() + return exists("t:NERDTreeBufName") && (bufwinnr(t:NERDTreeBufName) != -1) +endfunction + +" Call NERDTreeFind iff NERDTree is active, current window contains a modifiable +" file, and we're not in vimdiff +function! SyncTree() + if &modifiable && IsNERDTreeOpen() && strlen(expand('%')) > 0 && !&diff + NERDTreeFind + wincmd p + endif +endfunction + +" Highlight currently open buffer in NERDTree +autocmd BufEnter * call SyncTree() + +" coc config +let g:coc_global_extensions = [ + \ 'coc-snippets', + \ 'coc-pairs', + \ 'coc-tsserver', + \ 'coc-eslint', + \ 'coc-prettier', + \ 'coc-json', + \ ] +" from readme +" 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 (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/README.md b/README.md index a0b2b72..aa94c07 100644 --- a/README.md +++ b/README.md @@ -5,7 +5,7 @@ ## 手动安装 ```bash -git clone git@github.com:BruceGui/selfvimplug.git +git clone git@github.com:soragui/selfvimplug.git cd selfvimplug cp -r autoload/ ~/.vim/ cp .vimrc ~/ diff --git a/tools/install.sh b/tools/install.sh index dd5682c..eef5191 100644 --- a/tools/install.sh +++ b/tools/install.sh @@ -1,4 +1,10 @@ -# 自动安装脚本 +#!/bin/bash + +############################## +# Vim Plugin Manager Install Tools +# A Collection of useful vim plugin for developer. +# +############################## main() { @@ -39,7 +45,7 @@ main() { exit 1 } - env git clone --depth=1 git@github.com:BruceGui/vimconfplug.git $VIM_PLUG_CONF || { + env git clone --depth=1 git@github.com:soragui/vimconfplug.git $VIM_PLUG_CONF || { printf "Error: git clone of vim plug conf repo failed\n" exit 1 }