vim進階 | 使用插件打造實用vim工作環(huán)境

首先曬一張我的vim截圖,基本IDE有的功能都能實現(xiàn)了,雖然在日常工作里還是用商用軟件SourceInsight,但是作為一個開發(fā)者,少不了折騰的心。

myvim

vim,作為與emacs齊名的編輯器,無需更多溢美之詞,由于學習曲線陡峭,但是學會之人,無不表示其方便,vim操作的簡潔,熟練使用后,形成的肌肉習慣讓寫代碼成為享受。在學會基本的vim使用之后,每個人都會走向使用插件的道路,或者使用業(yè)界流行的插件,或者自己造輪子,這么多的插件在過去管理非?;靵y,幸運的是我們有了插件管理器Vundle,下面正式從Vundle帶你打造實用的vim工作環(huán)境。

Vundle##

在正式引入Vundle之前,讓我們做一些準備工作
由于我們的許多插件要從github下載,所以確保本機安裝了git, 具體可以自行Google。
其次確保本機上的vim版本>7.4, 可以運行vim --version查看當前機器上的vim版本,我的就顯示:

VIM - Vi IMproved 7.4 (2013 Aug 10, compiled Dec  6 2016 12:07:41)

如果沒有安裝vim,或者版本低于7.4都可以運行下面的命令安裝或更新:
MacOS

brew update
brew install vim

Linux

apt-get install vim   # ubuntu
yum install vim       # centos

vim問題解決后,我們就進入主題,介紹下Vundle, Vundle是vim的一款插件管理器,Vundle可以讓你在配置文件中管理插件,并且非常方便的查找、安裝、更新或者刪除插件。 還可以幫你自動配置插件的執(zhí)行路徑和生成幫助文件。這里還介紹另外一個插件管理器,提個名字,pathogen,有興趣可以自行研究,但是相比于Vundle,還是弱一線的,所以我們只介紹最好的。

運行下面命令安裝Vundle:

git clone https://github.com/gmarik/Vundle.vim.git ~/.vim/bundle/Vundle.vim

然后在我們的.vimrc 中添加設(shè)置,一般.vimrc在我們的用戶主目錄下, cd ~進入當前用戶主目錄,.vimrcvim的設(shè)置文件,我們后面會添加很多設(shè)置在里面,如果沒改過設(shè)置,可能一開始不存在,總之我們使用vim .vimrc創(chuàng)建或者打開該文件,并添加以下:

set nocompatible              " required
filetype off                  " required
dd
set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin()
Plugin 'gmarik/Vundle.vim'
call vundle#end()            " required
filetype plugin indent on    " required

然后在 vim中運行:PluginInstall即可(或者在 Bash 中運行vim +PluginInstall +qall)。以后只需要在添加一行Plugin 'xxx'并運行:PluginInstall即可自動安裝插件。

NERDTree##

在我上面的圖的右側(cè),顯示出類似于IDE中的目錄樹,有了目錄樹可以更清晰地查看項目的結(jié)構(gòu),這里就使用了一個叫做NERDTree的插件。

安裝
由于上面我們介紹了Vundle,那么NERDTree的安裝也水到渠成:

set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin()
Plugin 'gmarik/Vundle.vim'
Plugin 'scrooloose/nerdtree'
call vundle#end()            " required
filetype plugin indent on    " required

我們增加了scrooloose/nerdtree,只需要github repo的作者名和項目名就可以了,執(zhí)行PluginInstal,插件就可以安裝完成。
我們在.vimrc中再添加一下設(shè)置:

" NERDTree config
" open a NERDTree automatically when vim starts up
autocmd vimenter * NERDTree
"open a NERDTree automatically when vim starts up if no files were specified
autocmd StdinReadPre * let s:std_in=1
autocmd VimEnter * if argc() == 0 && !exists("s:std_in") | NERDTree | endif
"open NERDTree automatically when vim starts up on opening a directory
autocmd StdinReadPre * let s:std_in=1
autocmd VimEnter * if argc() == 1 && isdirectory(argv()[0]) && !exists("s:std_in") | exe 'NERDTree' argv()[0] | wincmd p | ene | endif
"map F2 to open NERDTree
map <F2> :NERDTreeToggle<CR>
"close vim if the only window left open is a NERDTree
autocmd bufenter * if (winnr("$") == 1 && exists("b:NERDTree") && b:NERDTree.isTabTree()) | q | endif

上面我們設(shè)置了自動打開NERDTree,直接輸入vim會打開NERDTree,打開一個目錄也會打開NERDTree,當文件都關(guān)閉只有NERDTree時自動退出,同時也設(shè)置快捷鍵F2來自由切換打開或者關(guān)閉NERDTree。

下面我們再說一下NERDTree中的一些操作方法

窗格跳轉(zhuǎn)
一般NERDTree會把界面分成左右兩個窗格,那么在窗格之間跳轉(zhuǎn)我們可以使用<C+W><C+W>(這個意思代表連續(xù)按兩次Ctrl+W),順便普及下,當我們桌面窗格非常多時,在vim中我們可以橫向縱向打開多個窗格,那我們也可以通過<C+W><C+h/j/k/l>來執(zhí)行左/下/上/右的跳轉(zhuǎn)。在每個窗格,我們都可以輸入:q或者:wq關(guān)閉該窗格。

下面還列有一些在目錄樹中的進階操作

key 描述
o 打開文件,目錄或者書簽,和我們在對應(yīng)節(jié)點上按回車鍵一個效果
go 打開文件,但是光標仍然停留在目錄中
t 在新的tab上打開選定的節(jié)點
T 與t相同,但是光標仍然停留在目錄中
i 在新窗格中打開文件
gi 和i 相同,但是光標仍然停留在目錄中
s 在水平窗格打開一個文件
gs 和s相同,但是光標仍然停留在目錄中
A 放大NERDTree窗口
p 跳到根節(jié)點
P 跳轉(zhuǎn)到當前節(jié)點的父節(jié)點
K 跳轉(zhuǎn)到當前目錄的第一個節(jié)點
J 跳轉(zhuǎn)到當前目錄的最后一個節(jié)點
u 把上層目錄設(shè)置為根節(jié)點
C 設(shè)置當前節(jié)點為root節(jié)點

還有更多的快捷鍵,help nerdtree查看詳細文檔

YouCompleteMe##

YCM

這個大名鼎鼎的插件在github上已經(jīng)有一萬多星了,足以證明其受歡迎程度,在此之前我曾經(jīng)嘗試過多款補齊插件,但是都沒有YCM智能,我們依舊使用Vundle安裝YCM,添加這個Plugin:

Plugin 'Valloric/YouCompleteMe'

但是當vim打開一個文件時,會報錯:

The ycmd server SHUT DOWN (restart with ':YcmRestartServer'). YCM core library not detected; you need to compile YCM before using it. Follow the instructions in the documentation

YCM最復雜的部分就在于它的安裝,總是會出現(xiàn)不少問題,下面我們將詳細描述正確的安裝方式

  1. 確保你的vim版本是7.4以上的,這個我們在本文的一開始部分就已經(jīng)說明了,如果不是你還可以通過源碼安裝,當然vim8.0都出了,你也可以選擇它,其次確認你的vim是否支持python2和python3的腳本??梢栽趘im中執(zhí)行::echo has('python') || has('python3'),如果顯示1,則滿足,否則你就要安裝支持Python的vim版本;
  2. 安裝YCM,使用Vundle安裝,這一步我們已經(jīng)說過了。
  3. 這一步對于需要支持C語系的語義支持的人很重要,你需要下載libclang,CLang是開源的C/C++/Objective-C/Objective-C++編譯器,YCM使用clang來支持強大的語義分析,這樣給出的補齊或者跳轉(zhuǎn)更加精確,但是要使用最新的libclang版本,至少3.9以上的。官方下載地址,可以選擇下載二進制文件,也可以從源碼編譯,不過編譯真的很慢,建議直接下二進制,注意系統(tǒng)。
#for ubuntu14.04
wget http://releases.llvm.org/3.9.0/clang+llvm-3.9.0-x86_64-linux-gnu-ubuntu-14.04.tar.xz
#for macOS
wget http://releases.llvm.org/3.9.0/clang+llvm-3.9.0-x86_64-apple-darwin.tar.xz

下載后解壓:

xz -d  clang+llvm-3.9.0-x86_64-linux-gnu-ubuntu-14.04.tar.xz
tar -xvf clang+llvm-3.9.0-x86_64-linux-gnu-ubuntu-14.04.tar
#MacOS上命令相同
  1. 下一步,我們需要編譯一個ycm_core的庫給YCM用,這樣它就可以快速語義分析產(chǎn)生補全或者函數(shù)變量快速跳轉(zhuǎn)了。首先我們需要安裝cmake來生成makefiles文件:
 #ubuntu
 sudo apt-get install cmake  
#macOS
brew install cmake 

其次,需要安裝Python頭文件:

 sudo apt-get install python-dev python3-dev 
#mac上應(yīng)該已經(jīng)默認安裝了

我們默認你已經(jīng)使用Vundle安裝了YCM在~/.vim/bundle/YouCompleteMe中了。
下面我們創(chuàng)建一個目錄用來編譯:

cd ~
mkdir ycm_build
cd ycm_build

我們先 生成makefiles文件,如果不關(guān)心對C系語言支持的話:

cmake -G " Unix Makefiles" ~/.vim/bundle/YouCompleteMe/third_party/ycmd/cpp

當然,我們都已經(jīng)下載了Clang3.9了,最好這樣:

#將下載的clang移到一個自己建的llvm目錄中
mkdir -p ycm_temp/llvm_root_dir
mv ~/clang+llvm-3.9.0-x86_64-linux-gnu-ubuntu-14.04/* ~/ycm_temp/llvm_root_dir/
cd  ycm_build
cmake -G "Unix Makefiles" -DUSE_SYSTEM_BOOST=ON -DPATH_TO_LLVM_ROOT=~/ycm_temp/llvm_root_dir ~/.vim/bundle/YouCompleteMe/third_party/ycmd/cpp

這樣就會基于最新的clang生成makefiles文件,再下一步就可以編譯了:

cmake --build . --target ycm_core --config Release

這樣就差不多安裝完了,當然這僅僅對C系語言進行了語義支持,如果需要支持別的語言,需要自行查看官方教程。

使用教程:
要使用YCM的強大功能,就需要給libclang提供你項目的編譯標志(compile flags),也就是讓libclang能夠解析你的代碼,這樣它才能給出智能的語義分析。
有兩種方式,自動生成的編譯數(shù)據(jù)庫或者手動添加編譯標志。

  1. 自動生成:
    最簡單的方式就是使用你自己項目的編譯工具生成一個編譯數(shù)據(jù)的數(shù)據(jù)庫,如前面我們使用的CMake,當然很多時候我們在Linux下使用的都是Gun Make,我們就需要下載一個Bear的工具,下載源碼后安裝:
cmake <Bear源碼目錄>
make all
make install # to install
make check   # to run tests
make package # to make packages

然后回到你的工程,bear make整個工程, 會生成compile_commands.json文件,YCM就是利用這個文件做語義分析,使用CMake的話就不需要借助Bear,只需要在編譯時添加-DCMAKE_EXPORT_COMPILE_COMMANDS=ON或者在CMakeLists.txt添加上set( CMAKE_EXPORT_COMPILE_COMMANDS ON來把生成的編譯數(shù)據(jù)庫信息拷貝到根目錄。

  1. 手動添加
    如果無法自動生成上述文件,我們使用一個.ycm_extra_conf.py的模塊,去根據(jù)你的文件名,就可以自動給出一些編譯選項,讓YCM知道如何解析你的代碼,在~/.vim/bundle/YouCompleteMe/cpp/ycm/.ycm_extra_conf.py中提供了默認的模板, 一般我們會自定義它的flags數(shù)組,然后拷貝一份到~目錄中,因為YCM總是在當前目錄,或者遞歸上層目錄,找到一個可用的.ycm_extra_conf.py

定義跳轉(zhuǎn)

  • 跳轉(zhuǎn)到定義GoToDefinition
  • 跳轉(zhuǎn)到聲明GoToDeclaration
  • 以及兩者的合體GoToDefinitionElseDeclaration
    .vimrc中可以定義快捷鍵:
nnoremap <leader>gl :YcmCompleter GoToDeclaration<CR>
nnoremap <leader>gf :YcmCompleter GoToDefinition<CR>
nnoremap <leader>gg :YcmCompleter GoToDefinitionElseDeclaration<CR>

<leader>鍵可以自定義,有個很火的Space-vim建議定義為空格let mapleader="\<Space>",這樣我們在函數(shù)上按空格鍵加gg,就可以實現(xiàn)跳轉(zhuǎn)了。
YCM還支持語義診斷:

let g:ycm_error_symbol = '>>'
let g:ycm_warning_symbol = '>*'

這樣,不合法的語句,在行首會顯示錯誤,基本和IDE無異了。

TagBar##

使用一般IDE都會在側(cè)面生成一個當前文件的結(jié)構(gòu)圖,就不說sublime里面還有個文件縮略圖,那么在vim里我們也能添加這么一個tagbar,讓我們在處理一個文件時,快速定位到函數(shù)變量,對代碼了如指掌。但是使用TagBar之前先確保已經(jīng)有ctags。

#Linux
sudo apt-get install ctags
#MacOS
brew install ctags
tagbar

安裝

Plugin 'majutsushi/tagbar'

再運行安裝命令,然后在.vimrc中這樣設(shè)置:

" Tagbar
let g:tagbar_width=35
let g:tagbar_autofocus=1
let g:tagbar_left = 1
nmap <F3> :TagbarToggle<CR>

這樣通過按F3就可以調(diào)出TagBar的窗格。

Ctrap##

在一開始的圖中,我的下窗格是專門用來搜索文件的,使用Ctrap這個插件可以支持搜索。
安裝

Plugin 'ctrlpvim/ctrlp.vim'

執(zhí)行完安裝命令:PluginInstall后,我們做一些設(shè)置:

" 打開ctrlp搜索
let g:ctrlp_map = '<leader>ff'
let g:ctrlp_cmd = 'CtrlP'
" 相當于mru功能,show recently opened files
map <leader>fp :CtrlPMRU<CR>
"set wildignore+=*/tmp/*,*.so,*.swp,*.zip     " MacOSX/Linux"
let g:ctrlp_custom_ignore = {
    \ 'dir':  '\v[\/]\.(git|hg|svn|rvm)$',
    \ 'file': '\v\.(exe|so|dll|zip|tar|tar.gz)$',
    \ }
"\ 'link': 'SOME_BAD_SYMBOLIC_LINKS',
let g:ctrlp_working_path_mode=0
let g:ctrlp_match_window_bottom=1
let g:ctrlp_max_height=15
let g:ctrlp_match_window_reversed=0
let g:ctrlp_mruf_max=500
let g:ctrlp_follow_symlinks=1

這樣你可以空格+ff啟用搜索,空格+fp顯示最近打開文件,在文件列表里上下移動都用Ctrl+k/j,Ctrl+p/n來在輸入的搜索歷史上下切換,更多可以查看:help ctrlp-commands。搜索默認用的是grep,現(xiàn)在誰都知道ag效率更高更快,所以如果想切換搜索的工具可以這么改:

if executable('ag')
  " Use Ag over Grep
  set grepprg=ag\ --nogroup\ --nocolor
  " Use ag in CtrlP for listing files.
  let g:ctrlp_user_command = 'ag %s -l --nocolor -g ""'
  " Ag is fast enough that CtrlP doesn't need to cache
  let g:ctrlp_use_caching = 0
endif

vim-powerline

這個工具主要用來增強狀態(tài)欄的,顯示更多的信息,文件格式,當前狀態(tài),路徑

Plugin 'Lokaltog/vim-powerline'
let g:Powerline_symbols = 'fancy'
set encoding=utf-8 
set laststatus=2

其它的一些設(shè)置##

配色
對于顏值控來說,一個好看的色彩搭配也能讓工作愉悅不少。我的主題配色是solarized ,也可以用Vundle安裝。然后直接設(shè)置:

syntax enable
set background=dark
colorscheme solarized

一些基本設(shè)置

"==========================================  
"General  
"==========================================  
" history存儲長度。  
set history=1000         
"檢測文件類型  
filetype on  
" 針對不同的文件類型采用不同的縮進格式    
filetype indent on                 
允許插件    
filetype plugin on  
啟動自動補全  
filetype plugin indent on  
"兼容vi模式。去掉討厭的有關(guān)vi一致性模式,避免以前版本的一些bug和局限  
set nocompatible        
set autoread          " 文件修改之后自動載入。  
set shortmess=atI       " 啟動的時候不顯示那個援助索馬里兒童的提示  

" 取消備份。  
"urn backup off, since most stuff is in SVN, git et.c anyway...  
set nobackup  
set nowb  
set noswapfile  
  
"貼時保持格式  
set paste  
"- 則點擊光標不會換,用于復制  
set mouse-=a           " 在所有的模式下面打開鼠標。  
set selection=exclusive    
set selectmode=mouse,key  
  
" No annoying sound on errors  
" 去掉輸入錯誤的提示聲音  
set noerrorbells  
set novisualbell  
set t_vb=  
set tm=500    
  
"==========================================  
" show and format  
"==========================================  
"顯示行號:  
set number  
set nowrap                    " 取消換行。  
"為方便復制,用<F6>開啟/關(guān)閉行號顯示:  
nnoremap <F6> :set nonumber!<CR>:set foldcolumn=0<CR>  

"括號配對情況  
set showmatch  
" How many tenths of a second to blink when matching brackets  
set mat=2  
  
"設(shè)置文內(nèi)智能搜索提示  
" 高亮search命中的文本。  
set hlsearch            
" 搜索時忽略大小寫  
set ignorecase  
" 隨著鍵入即時搜索  
set incsearch  
" 有一個或以上大寫字母時仍大小寫敏感  
set smartcase  
  
" 代碼折疊  
set foldenable  
" 折疊方法  
" manual    手工折疊  
" indent    使用縮進表示折疊  
" expr      使用表達式定義折疊  
" syntax    使用語法定義折疊  
" diff      對沒有更改的文本進行折疊  
" marker    使用標記進行折疊, 默認標記是 {{{ 和 }}}  
set foldmethod=syntax  
" 在左側(cè)顯示折疊的層次  
"set foldcolumn=4  
  
set tabstop=4                " 設(shè)置Tab鍵的寬度        [等同的空格個數(shù)]  
set shiftwidth=4  
set expandtab                " 將Tab自動轉(zhuǎn)化成空格    [需要輸入真正的Tab鍵時,使用 Ctrl+V + Tab]  
" 按退格鍵時可以一次刪掉 4 個空格  
set softtabstop=4  
  
set ai "Auto indent  
set si "Smart indent  
  
"==========================================  
" status  
"==========================================  
"顯示當前的行號列號:  
set ruler  
"在狀態(tài)欄顯示正在輸入的命令  
set showcmd  
  
" Set 7 lines to the cursor - when moving vertically using j/k 上下滾動,始終在中間  
set so=7    
"set cursorline              " 突出顯示當前行    

由于篇幅問題,再推薦其它一些好用的插件

"  Improved C++ STL syntax highlighting
Plugin 'STL-improved'

" recommend fetch it from https://github.com/tczengming/autoload_cscope.vim.git which support c and cpp
Plugin 'tczengming/autoload_cscope.vim'

Plugin 'CmdlineComplete'
Plugin 'xptemplate'

"  Ultimate auto completion system for Vim
Plugin 'neocomplcache'

Plugin 'genutils'
Plugin 'lookupfile'

" Fast file navigation
Plugin 'wincent/Command-T'

" Preview the definition of variables or functions in a preview window
Plugin 'autopreview'

" Echo the function declaration in the command line for C/C++
Plugin 'echofunc.vim'

" Under linux need exec 'dos2unix ~/.vim/bundle/QFixToggle/plugin/qfixtoggle.vim'
Plugin 'Toggle'

Plugin 'Color-Sampler-Pack'
Plugin 'txt.vim'
Plugin 'mru.vim'
Plugin 'YankRing.vim'
Plugin 'tpope/vim-surround.git'
Plugin 'DoxygenToolkit.vim'
Plugin 'tczengming/headerGatesAdd.vim'
Plugin 'ShowMarks'
Plugin 'Lokaltog/vim-powerline'

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容