update .vimrc
This commit is contained in:
parent
e7c85c11f0
commit
41f8f46169
259
.vimrc
259
.vimrc
@ -1,68 +1,227 @@
|
|||||||
|
|
||||||
call plug#begin('~/.vim/bundle')
|
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()
|
call plug#end()
|
||||||
|
|
||||||
set so=10
|
inoremap jk <ESC>
|
||||||
set number
|
nmap <C-n> :NERDTreeToggle<CR>
|
||||||
syntax on
|
vmap ++ <plug>NERDCommenterToggle
|
||||||
filetype on
|
nmap ++ <plug>NERDCommenterToggle
|
||||||
filetype plugin on
|
|
||||||
filetype indent on
|
|
||||||
|
|
||||||
set completeopt=longest,menu
|
" open NERDTree automatically
|
||||||
|
"autocmd StdinReadPre * let s:std_in=1
|
||||||
|
"autocmd VimEnter * NERDTree
|
||||||
|
|
||||||
if has('mouse')
|
let g:NERDTreeGitStatusWithFlags = 1
|
||||||
set mouse=a
|
"let g:WebDevIconsUnicodeDecorateFolderNodes = 1
|
||||||
set selectmode=mouse,key
|
"let g:NERDTreeGitStatusNodeColorization = 1
|
||||||
set nomousehide
|
"let g:NERDTreeColorMapCustom = {
|
||||||
endif
|
"\ "Staged" : "#0ee375",
|
||||||
|
"\ "Modified" : "#d9bf91",
|
||||||
set autoindent
|
"\ "Renamed" : "#51C9FC",
|
||||||
set modeline
|
"\ "Untracked" : "#FCE77C",
|
||||||
"set cursorline
|
"\ "Unmerged" : "#FC51E6",
|
||||||
"set cursorcolumn
|
"\ "Dirty" : "#FFBD61",
|
||||||
|
"\ "Clean" : "#87939A",
|
||||||
set shiftwidth=4
|
"\ "Ignored" : "#808080"
|
||||||
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 <space> @=((foldcolsed(line('.')) < 0 ) ? 'zc' : 'zo')<CR>
|
|
||||||
|
|
||||||
|
|
||||||
set smartcase
|
let g:NERDTreeIgnore = ['^node_modules$']
|
||||||
set ignorecase
|
|
||||||
set nohlsearch
|
|
||||||
set incsearch
|
|
||||||
set autochdir
|
|
||||||
|
|
||||||
vmap j gj
|
" vim-prettier
|
||||||
vmap k gk
|
"let g:prettier#quickfix_enabled = 0
|
||||||
nmap j gj
|
"let g:prettier#quickfix_auto_focus = 0
|
||||||
nmap k gk
|
" 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<cr>
|
" 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 <buffer> {<CR> {<CR>}<Esc>0
|
" j/k will move virtual lines (lines that wrap)
|
||||||
|
noremap <silent> <expr> j (v:count == 0 ? 'gj' : 'j')
|
||||||
|
noremap <silent> <expr> 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 <tab>' to make sure tab is not mapped by other plugin.
|
||||||
|
inoremap <silent><expr> <TAB>
|
||||||
|
\ pumvisible() ? "\<C-n>" :
|
||||||
|
\ <SID>check_back_space() ? "\<TAB>" :
|
||||||
|
\ coc#refresh()
|
||||||
|
inoremap <expr><S-TAB> pumvisible() ? "\<C-p>" : "\<C-h>"
|
||||||
|
|
||||||
|
function! s:check_back_space() abort
|
||||||
|
let col = col('.') - 1
|
||||||
|
return !col || getline('.')[col - 1] =~# '\s'
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
" Use <c-space> to trigger completion.
|
||||||
|
inoremap <silent><expr> <c-space> coc#refresh()
|
||||||
|
|
||||||
|
" Use <cr> to confirm completion, `<C-g>u` means break undo chain at current position.
|
||||||
|
" Coc only does snippet and additional edit on confirm.
|
||||||
|
inoremap <expr> <cr> pumvisible() ? "\<C-y>" : "\<C-g>u\<CR>"
|
||||||
|
" Or use `complete_info` if your vim support it, like:
|
||||||
|
" inoremap <expr> <cr> complete_info()["selected"] != "-1" ? "\<C-y>" : "\<C-g>u\<CR>"
|
||||||
|
|
||||||
|
" Use `[g` and `]g` to navigate diagnostics
|
||||||
|
nmap <silent> [g <Plug>(coc-diagnostic-prev)
|
||||||
|
nmap <silent> ]g <Plug>(coc-diagnostic-next)
|
||||||
|
|
||||||
|
" Remap keys for gotos
|
||||||
|
nmap <silent> gd <Plug>(coc-definition)
|
||||||
|
nmap <silent> gy <Plug>(coc-type-definition)
|
||||||
|
nmap <silent> gi <Plug>(coc-implementation)
|
||||||
|
nmap <silent> gr <Plug>(coc-references)
|
||||||
|
|
||||||
|
" Use K to show documentation in preview window
|
||||||
|
nnoremap <silent> K :call <SID>show_documentation()<CR>
|
||||||
|
|
||||||
|
function! s:show_documentation()
|
||||||
|
if (index(['vim','help'], &filetype) >= 0)
|
||||||
|
execute 'h '.expand('<cword>')
|
||||||
|
else
|
||||||
|
call CocAction('doHover')
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
" Highlight symbol under cursor on CursorHold
|
||||||
|
autocmd CursorHold * silent call CocActionAsync('highlight')
|
||||||
|
|
||||||
|
" Remap for rename current word
|
||||||
|
nmap <F2> <Plug>(coc-rename)
|
||||||
|
|
||||||
|
" Remap for format selected region
|
||||||
|
xmap <leader>f <Plug>(coc-format-selected)
|
||||||
|
nmap <leader>f <Plug>(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: `<leader>aap` for current paragraph
|
||||||
|
xmap <leader>a <Plug>(coc-codeaction-selected)
|
||||||
|
nmap <leader>a <Plug>(coc-codeaction-selected)
|
||||||
|
|
||||||
|
" Remap for do codeAction of current line
|
||||||
|
nmap <leader>ac <Plug>(coc-codeaction)
|
||||||
|
" Fix autofix problem of current line
|
||||||
|
nmap <leader>qf <Plug>(coc-fix-current)
|
||||||
|
|
||||||
|
" Create mappings for function text object, requires document symbols feature of languageserver.
|
||||||
|
xmap if <Plug>(coc-funcobj-i)
|
||||||
|
xmap af <Plug>(coc-funcobj-a)
|
||||||
|
omap if <Plug>(coc-funcobj-i)
|
||||||
|
omap af <Plug>(coc-funcobj-a)
|
||||||
|
|
||||||
|
" Use <C-d> for select selections ranges, needs server support, like: coc-tsserver, coc-python
|
||||||
|
nmap <silent> <C-d> <Plug>(coc-range-select)
|
||||||
|
xmap <silent> <C-d> <Plug>(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', <f-args>)
|
||||||
|
|
||||||
|
" 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 <silent> <space>a :<C-u>CocList diagnostics<cr>
|
||||||
|
" Manage extensions
|
||||||
|
nnoremap <silent> <space>e :<C-u>CocList extensions<cr>
|
||||||
|
" Show commands
|
||||||
|
nnoremap <silent> <space>c :<C-u>CocList commands<cr>
|
||||||
|
" Find symbol of current document
|
||||||
|
nnoremap <silent> <space>o :<C-u>CocList outline<cr>
|
||||||
|
" Search workspace symbols
|
||||||
|
nnoremap <silent> <space>s :<C-u>CocList -I symbols<cr>
|
||||||
|
" Do default action for next item.
|
||||||
|
nnoremap <silent> <space>j :<C-u>CocNext<CR>
|
||||||
|
" Do default action for previous item.
|
||||||
|
nnoremap <silent> <space>k :<C-u>CocPrev<CR>
|
||||||
|
" Resume latest coc list
|
||||||
|
nnoremap <silent> <space>p :<C-u>CocListResume<CR>
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
## 手动安装
|
## 手动安装
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
git clone git@github.com:BruceGui/selfvimplug.git
|
git clone git@github.com:soragui/selfvimplug.git
|
||||||
cd selfvimplug
|
cd selfvimplug
|
||||||
cp -r autoload/ ~/.vim/
|
cp -r autoload/ ~/.vim/
|
||||||
cp .vimrc ~/
|
cp .vimrc ~/
|
||||||
|
@ -1,4 +1,10 @@
|
|||||||
# 自动安装脚本
|
#!/bin/bash
|
||||||
|
|
||||||
|
##############################
|
||||||
|
# Vim Plugin Manager Install Tools
|
||||||
|
# A Collection of useful vim plugin for developer.
|
||||||
|
#
|
||||||
|
##############################
|
||||||
|
|
||||||
main() {
|
main() {
|
||||||
|
|
||||||
@ -39,7 +45,7 @@ main() {
|
|||||||
exit 1
|
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"
|
printf "Error: git clone of vim plug conf repo failed\n"
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user