OK,有了上面的基本設置,一個好用的vim就配置好了,但是如果想讓它完美支持各種源代碼文件,想讓它方便的注釋,方便的進行代碼提示,方便的添加用戶信息,那還差的很遠哦,就請期待下一篇吧-----把VIM打造成一個真正的IDE(2)。
OK,上一篇文章,我們已經配置好了一個可以正常使用的VIM,那么在我們真正來到程序員的VIM世界之前,希望你能在VIM里面再多加下面幾個配置。
set go= "無菜單、工具欄"
對,讓我真正拋棄鼠標,進入美妙的VIM之旅吧!
首先說說一個IDE應該有的幾個功能:
1)源代碼結構及函數列表
2)變量定義支持跳轉等
3)代碼自動補全
當然VIM還給了我們幾個小驚喜:
4)快速批量注釋與反注釋
5)由注釋直接生成文檔
6)文件頭作者信息自動添加
7).cpp和.h文件之間的快速切換
那么接下來,我們久來看看我們將會用到的插件列表。
首先介紹一下一些必備知識,我們需要下面兩樣東西,來輔助完成vim成為IDE的大業--ctags和cscope,這兩樣東西不是vim的插件而
是可執行程序,linux和windows下都有。ctags主要實現了c、c++、java、c#等語言的智能分析,并聲稱tags文件,后面所有的包
括函數列表顯示,變量定義跳轉,自動補全等,都要依賴于他。有了tags文件后,只需要在變量上按下 CTRL +
]鍵,就可以自動跳到變量定義的位置。而cscope據說誕生就是為了來替代ctags的,因為他有著比ctags更加強大的功能,舉個例子,ctags
只能分析出這個函數在哪里被定義,而cscope除了這一點之外,還能分析出這個函數再哪里被調用。當然cscope目前還是有不少bug的,但是也不影
響我們的使用。
1)taglist.vim 實現了源代碼結構和函數列表的展示,功能非常強大
showfunc.vim 一個展示C/C++/java/C#函數原型的插件,原本是echofunc.vim但是不支持java,c#,所以我把他改了。下載showfunc.vim
2)有了tags就自動支持了
3)omnicppcomplete.vim 實現寫C/C++語言時自動補全
4)NERD_commenter.vim 注釋插件
5)DoxygenToolkit.vim 由注釋生成文檔,并且能夠快速生成函數標準注釋
6)這段配置是本人自己寫的稍后貼出。
7)a.vim 實現.cpp和.h快速切換
下面一個個的講解配置:
首先確認安裝了ctags和cscope,并且確認這兩個可執行程序所在的目錄已經放進環境變量里面。(必須做,否則后邊都無法操作)
在vimrc中配置如下:
map <F12> :call Do_CsTag()<CR>
nmap <C-@>s :cs find s <C-R>=expand("<cword>")<CR><CR>:copen<CR>
nmap <C-@>g :cs find g <C-R>=expand("<cword>")<CR><CR>
nmap <C-@>c :cs find c <C-R>=expand("<cword>")<CR><CR>:copen<CR>
nmap <C-@>t :cs find t <C-R>=expand("<cword>")<CR><CR>:copen<CR>
nmap <C-@>e :cs find e <C-R>=expand("<cword>")<CR><CR>:copen<CR>
nmap <C-@>f :cs find f <C-R>=expand("<cfile>")<CR><CR>:copen<CR>
nmap <C-@>i :cs find i ^<C-R>=expand("<cfile>")<CR>$<CR>:copen<CR>
nmap <C-@>d :cs find d <C-R>=expand("<cword>")<CR><CR>:copen<CR>
function Do_CsTag()
let dir = getcwd()
if filereadable("tags")
if(g:iswindows==1)
let tagsdeleted=delete(dir."\\"."tags")
else
let tagsdeleted=delete("./"."tags")
endif
if(tagsdeleted!=0)
echohl WarningMsg | echo "Fail to do tags! I cannot delete the tags" | echohl None
return
endif
endif
if has("cscope")
silent! execute "cs kill -1"
endif
if filereadable("cscope.files")
if(g:iswindows==1)
let csfilesdeleted=delete(dir."\\"."cscope.files")
else
let csfilesdeleted=delete("./"."cscope.files")
endif
if(csfilesdeleted!=0)
echohl WarningMsg | echo "Fail to do cscope! I cannot delete the cscope.files" | echohl None
return
endif
endif
if filereadable("cscope.out")
if(g:iswindows==1)
let csoutdeleted=delete(dir."\\"."cscope.out")
else
let csoutdeleted=delete("./"."cscope.out")
endif
if(csoutdeleted!=0)
echohl WarningMsg | echo "Fail to do cscope! I cannot delete the cscope.out" | echohl None
return
endif
endif
if(executable('ctags'))
"silent! execute "!ctags -R --c-types=+p --fields=+S *"
silent! execute "!ctags -R --c++-kinds=+p --fields=+iaS --extra=+q ."
endif
if(executable('cscope') && has("cscope") )
if(g:iswindows!=1)
silent! execute "!find . -name '*.h' -o -name '*.c' -o
-name '*.cpp' -o -name '*.java' -o -name '*.cs' > cscope.files"
else
silent! execute "!dir /s/b *.c,*.cpp,*.h,*.java,*.cs >> cscope.files"
endif
silent! execute "!cscope -b"
execute "normal :"
if filereadable("cscope.out")
execute "cs add cscope.out"
endif
endif
endfunction
1)taglist.vim
先截個圖給大家看下:

把taglist.vim放在plugin目錄下后,在vimrc中添加如下的配置:
"進行Tlist的設置
"TlistUpdate可以更新tags
map <F3> :silent! Tlist<CR> "按下F3就可以呼出了
let Tlist_Ctags_Cmd='ctags' "因為我們放在環境變量里,所以可以直接執行
let Tlist_Use_Right_Window=1 "讓窗口顯示在右邊,0的話就是顯示在左邊
let Tlist_Show_One_File=0 "讓taglist可以同時展示多個文件的函數列表,如果想只有1個,設置為1
let Tlist_File_Fold_Auto_Close=1 "非當前文件,函數列表折疊隱藏
let Tlist_Exit_OnlyWindow=1 "當taglist是最后一個分割窗口時,自動推出vim
"是否一直處理tags.1:處理;0:不處理
let Tlist_Process_File_Always=0 "不是一直實時更新tags,因為沒有必要
let Tlist_Inc_Winwidth=0
showfunc.vim 下載showfunc.vim
截圖如下:

這個插件實現了按下fd,就可以提示當前光標所在函數的定義,另外還實現了當輸入'('時,會自動匹配tags,展示函數的定義原型。
只需要把這個插件放到plugin下就行,不需要配置。
2)已經在上面解釋過,所以這里不再做贅述
OK,到這里,我們已經能夠成功的顯示函數列表和查看函數定義了,閱讀代碼已經沒有問題了,剩下的就是要在寫代碼過程中用到的插件啦,我們在把VIM打造成一個真正的IDE(3)中繼續~
版權所有,轉載請注明出處。 http://www.vimer.cn
好了,接著前面的兩篇,我們今天來寫《把VIM打造成一個真正的IDE》系列的終結篇。
我們之前已經讓在VIM下看代碼變得方便與簡單,現在我們來讓用Vim寫代碼也一樣方便~看完本篇之后,你就可以完全拋棄sourceinsight之類的工具啦~
3)omnicppcomplete.vim 實現寫C/C++語言時自動補全 下載插件
慣例,先截圖:

其實使用很簡單,下載 omnicppcomplete
然后按照說明將插件安裝到vimfiles下面,目錄結構如下:
after\ftplugin\cpp.vim
after\ftplugin\c.vim
autoload\omni\common\debug.vim
\utils.vim
autoload\omni\cpp\complete.vim
\includes.vim
\items.vim
\maycomplete.vim
\namespaces.vim
\settings.vim
\tokenizer.vim
\utils.vim
doc\omnicppcomplete.txt
然后需要生成tags,哈哈,記得我們之前用F12映射的命令吧(把Vim打造成真正的IDE(2)),按下F12然后去享受吧~~
順便說一下:omnicppcomplete會打開一個預覽窗口來提示變量定義,如果不想要看到詳細的信息的話,在vimrc中這樣配置:
set completeopt=menu
4)NERD_commenter.vim 注釋插件 下載插件
也是程序員非常實用的一款插件,支持各種語言的補全,只要你能想到的,放心他絕對注釋的了,而且還支持單行注釋,批量注釋,等各種命令映射,在這里,我把最常用的鍵映射在vimrc中配置了一下。
"對NERD_commenter的設置
let NERDShutUp=1
"支持單行和多行的選擇,//格式
map <c-h> ,c<space>
這樣的話,在光標所在行上,按下一次ctrl+h是注釋,再按下一次是取消注釋。
而其內建的指令,cm是多行注釋,類似C++的/**/,,cu是取消注釋。
5)DoxygenToolkit.vim 由注釋生成文檔,并且能夠快速生成函數標準注釋 下載地址
這個插件使得vim能夠生成標準的函數注釋,如圖:

map fg : Dox<cr>
let g:DoxygenToolkit_authorName="dantezhu"
let g:DoxygenToolkit_licenseTag="My own license\<enter>"
let g:DoxygenToolkit_undocTag="DOXIGEN_SKIP_BLOCK"
let g:DoxygenToolkit_briefTag_pre = "@brief\t"
let g:DoxygenToolkit_paramTag_pre = "@param\t"
let g:DoxygenToolkit_returnTag = "@return\t"
let g:DoxygenToolkit_briefTag_funcName = "no"
let g:DoxygenToolkit_maxFunctionProtoLines = 30
讀者可以需要將 DoxygenToolkit_authorName設置成為自己的名字,OK,這樣標準格式的代碼注釋就出來啦。
5)a.vim .cpp和.h文件快速切換 下載地址
把下載的a.vim放到plugin下,不需要配置。
直接可以:A,打開.cpp和.h對應的文件,:AV,打開.cpp和.h對應的文件,并且分屏,截圖如下:

OK,如果你按照我的說明將vim配置了下來,那么你的vim應該已經是一個超級強悍的IDE啦,快去寫寫代碼試試吧,是不是和之前很是不同了啊,哈哈。
版權所有,轉載請注明出處。http://www.vimer.cn