首先曬一張我的vim截圖,基本IDE有的功能都能實現了,雖然在日常工作里還是用商用軟件SourceInsight,但是作為一個開發者,少不了折騰的心。
vim
,作為與emacs
齊名的編輯器,無需更多溢美之詞,由于學習曲線陡峭,但是學會之人,無不表示其方便,vim
操作的簡潔,熟練使用后,形成的肌肉習慣讓寫代碼成為享受。在學會基本的vim
使用之后,每個人都會走向使用插件的道路,或者使用業界流行的插件,或者自己造輪子,這么多的插件在過去管理非常混亂,幸運的是我們有了插件管理器Vundle
,下面正式從Vundle
帶你打造實用的vim工作環境。
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可以讓你在配置文件中管理插件,并且非常方便的查找、安裝、更新或者刪除插件。 還可以幫你自動配置插件的執行路徑和生成幫助文件。這里還介紹另外一個插件管理器,提個名字,pathogen
,有興趣可以自行研究,但是相比于Vundle
,還是弱一線的,所以我們只介紹最好的。
運行下面命令安裝Vundle
:
git clone https://github.com/gmarik/Vundle.vim.git ~/.vim/bundle/Vundle.vim
然后在我們的.vimrc
中添加設置,一般.vimrc
在我們的用戶主目錄下, cd ~
進入當前用戶主目錄,.vimrc
是vim
的設置文件,我們后面會添加很多設置在里面,如果沒改過設置,可能一開始不存在,總之我們使用vim .vimrc
創建或者打開該文件,并添加以下:
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##
在我上面的圖的右側,顯示出類似于IDE中的目錄樹,有了目錄樹可以更清晰地查看項目的結構,這里就使用了一個叫做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的作者名和項目名就可以了,執行PluginInstal
,插件就可以安裝完成。
我們在.vimrc
中再添加一下設置:
" 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
上面我們設置了自動打開NERDTree,直接輸入vim會打開NERDTree,打開一個目錄也會打開NERDTree,當文件都關閉只有NERDTree時自動退出,同時也設置快捷鍵F2
來自由切換打開或者關閉NERDTree。
下面我們再說一下NERDTree中的一些操作方法
窗格跳轉
一般NERDTree會把界面分成左右兩個窗格,那么在窗格之間跳轉我們可以使用<C+W><C+W>
(這個意思代表連續按兩次Ctrl+W),順便普及下,當我們桌面窗格非常多時,在vim中我們可以橫向縱向打開多個窗格,那我們也可以通過<C+W><C+h/j/k/l>
來執行左/下/上/右的跳轉。在每個窗格,我們都可以輸入:q
或者:wq
關閉該窗格。
下面還列有一些在目錄樹中的進階操作:
key | 描述 |
---|---|
o | 打開文件,目錄或者書簽,和我們在對應節點上按回車鍵一個效果 |
go | 打開文件,但是光標仍然停留在目錄中 |
t | 在新的tab上打開選定的節點 |
T | 與t相同,但是光標仍然停留在目錄中 |
i | 在新窗格中打開文件 |
gi | 和i 相同,但是光標仍然停留在目錄中 |
s | 在水平窗格打開一個文件 |
gs | 和s相同,但是光標仍然停留在目錄中 |
A | 放大NERDTree窗口 |
p | 跳到根節點 |
P | 跳轉到當前節點的父節點 |
K | 跳轉到當前目錄的第一個節點 |
J | 跳轉到當前目錄的最后一個節點 |
u | 把上層目錄設置為根節點 |
C | 設置當前節點為root節點 |
還有更多的快捷鍵,help nerdtree
查看詳細文檔
YouCompleteMe##
這個大名鼎鼎的插件在github上已經有一萬多星了,足以證明其受歡迎程度,在此之前我曾經嘗試過多款補齊插件,但是都沒有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最復雜的部分就在于它的安裝,總是會出現不少問題,下面我們將詳細描述正確的安裝方式:
- 確保你的vim版本是7.4以上的,這個我們在本文的一開始部分就已經說明了,如果不是你還可以通過源碼安裝,當然vim8.0都出了,你也可以選擇它,其次確認你的vim是否支持python2和python3的腳本。可以在vim中執行:
:echo has('python') || has('python3')
,如果顯示1,則滿足,否則你就要安裝支持Python的vim版本; - 安裝YCM,使用Vundle安裝,這一步我們已經說過了。
- 這一步對于需要支持C語系的語義支持的人很重要,你需要下載libclang,CLang是開源的C/C++/Objective-C/Objective-C++編譯器,YCM使用clang來支持強大的語義分析,這樣給出的補齊或者跳轉更加精確,但是要使用最新的libclang版本,至少3.9以上的。官方下載地址,可以選擇下載二進制文件,也可以從源碼編譯,不過編譯真的很慢,建議直接下二進制,注意系統。
#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上命令相同
- 下一步,我們需要編譯一個
ycm_core
的庫給YCM用,這樣它就可以快速語義分析產生補全或者函數變量快速跳轉了。首先我們需要安裝cmake
來生成makefiles
文件:
#ubuntu
sudo apt-get install cmake
#macOS
brew install cmake
其次,需要安裝Python頭文件:
sudo apt-get install python-dev python3-dev
#mac上應該已經默認安裝了
我們默認你已經使用Vundle安裝了YCM在~/.vim/bundle/YouCompleteMe
中了。
下面我們創建一個目錄用來編譯:
cd ~
mkdir ycm_build
cd ycm_build
我們先 生成makefiles
文件,如果不關心對C系語言支持的話:
cmake -G " Unix Makefiles" ~/.vim/bundle/YouCompleteMe/third_party/ycmd/cpp
當然,我們都已經下載了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能夠解析你的代碼,這樣它才能給出智能的語義分析。
有兩種方式,自動生成的編譯數據庫或者手動添加編譯標志。
-
自動生成:
最簡單的方式就是使用你自己項目的編譯工具生成一個編譯數據的數據庫,如前面我們使用的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
來把生成的編譯數據庫信息拷貝到根目錄。
-
手動添加
如果無法自動生成上述文件,我們使用一個.ycm_extra_conf.py
的模塊,去根據你的文件名,就可以自動給出一些編譯選項,讓YCM知道如何解析你的代碼,在~/.vim/bundle/YouCompleteMe/cpp/ycm/.ycm_extra_conf.py
中提供了默認的模板, 一般我們會自定義它的flags數組,然后拷貝一份到~目錄中,因為YCM總是在當前目錄,或者遞歸上層目錄,找到一個可用的.ycm_extra_conf.py
定義跳轉
- 跳轉到定義GoToDefinition
- 跳轉到聲明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>"
,這樣我們在函數上按空格鍵加gg
,就可以實現跳轉了。
YCM還支持語義診斷:
let g:ycm_error_symbol = '>>'
let g:ycm_warning_symbol = '>*'
這樣,不合法的語句,在行首會顯示錯誤,基本和IDE無異了。
TagBar##
使用一般IDE都會在側面生成一個當前文件的結構圖,就不說sublime里面還有個文件縮略圖,那么在vim里我們也能添加這么一個tagbar,讓我們在處理一個文件時,快速定位到函數變量,對代碼了如指掌。但是使用TagBar
之前先確保已經有ctags
。
#Linux
sudo apt-get install ctags
#MacOS
brew install ctags
安裝
Plugin 'majutsushi/tagbar'
再運行安裝命令,然后在.vimrc
中這樣設置:
" Tagbar
let g:tagbar_width=35
let g:tagbar_autofocus=1
let g:tagbar_left = 1
nmap <F3> :TagbarToggle<CR>
這樣通過按F3
就可以調出TagBar的窗格。
Ctrap##
在一開始的圖中,我的下窗格是專門用來搜索文件的,使用Ctrap這個插件可以支持搜索。
安裝
Plugin 'ctrlpvim/ctrlp.vim'
執行完安裝命令:PluginInstall
后,我們做一些設置:
" 打開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
,現在誰都知道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
這個工具主要用來增強狀態欄的,顯示更多的信息,文件格式,當前狀態,路徑
Plugin 'Lokaltog/vim-powerline'
let g:Powerline_symbols = 'fancy'
set encoding=utf-8
set laststatus=2
其它的一些設置##
配色
對于顏值控來說,一個好看的色彩搭配也能讓工作愉悅不少。我的主題配色是solarized ,也可以用Vundle安裝。然后直接設置:
syntax enable
set background=dark
colorscheme solarized
一些基本設置
"==========================================
"General
"==========================================
" history存儲長度。
set history=1000
"檢測文件類型
filetype on
" 針對不同的文件類型采用不同的縮進格式
filetype indent on
允許插件
filetype plugin on
啟動自動補全
filetype plugin indent on
"兼容vi模式。去掉討厭的有關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>開啟/關閉行號顯示:
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
"設置文內智能搜索提示
" 高亮search命中的文本。
set hlsearch
" 搜索時忽略大小寫
set ignorecase
" 隨著鍵入即時搜索
set incsearch
" 有一個或以上大寫字母時仍大小寫敏感
set smartcase
" 代碼折疊
set foldenable
" 折疊方法
" manual 手工折疊
" indent 使用縮進表示折疊
" expr 使用表達式定義折疊
" syntax 使用語法定義折疊
" diff 對沒有更改的文本進行折疊
" marker 使用標記進行折疊, 默認標記是 {{{ 和 }}}
set foldmethod=syntax
" 在左側顯示折疊的層次
"set foldcolumn=4
set tabstop=4 " 設置Tab鍵的寬度 [等同的空格個數]
set shiftwidth=4
set expandtab " 將Tab自動轉化成空格 [需要輸入真正的Tab鍵時,使用 Ctrl+V + Tab]
" 按退格鍵時可以一次刪掉 4 個空格
set softtabstop=4
set ai "Auto indent
set si "Smart indent
"==========================================
" status
"==========================================
"顯示當前的行號列號:
set ruler
"在狀態欄顯示正在輸入的命令
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'