利用Vim打造自己的IDE環境, vim超級棒的插件

1

  Linux下編程一直被詬病的一點是: 沒有一個好用的IDE, 但是聽說Linux牛人, 黑客之類的也都不用IDE. 但是對我等從Windows平臺轉移過來的Coder來說, 一個好用的IDE是何等的重要啊, 估計很多人就是卡在這個門檻上了, "工欲善其事, 必先利其器"嘛, 我想如果有一個很好用的IDE, 那些Linux牛人也會歡迎的. 這都是勞動人民的美好願望罷了, 我今天教大家把gvim改裝成一個簡易IDE, 說它"簡易"是界面上看起來"簡易", 但功能絕對不比一個好的IDE差, 該有的功能都有, 不該有的功能也有, 你就自己沒事偷着樂吧, 下面我開始介紹今天的工作了.

本文會教你:
1.  中文幫助手冊的安裝
2.  vim編程常用命令
3.  語法高亮
4.  在程序中跳來跳去: Ctags 的使用
5.  教你高效地瀏覽源碼 -- 插件: TagList
6.  文件瀏覽器和窗口管理器 -- 插件: WinManager
7.  Cscope 的使用
8.  QuickFix 窗口
9.  快速瀏覽和操作Buffer -- 插件: MiniBufExplorer
10.  c/h文件間相互切換 -- 插件: A
11. 在工程中查找 -- 插件: Grep
12. 高亮的書籤 -- 插件: VisualMark
13. 自動補全
14. 加速你的補全 -- 插件: SuperTab

本文不會教你:
1.  如何使用vim. 本文不會從零開始教你如何使用vim, 如果你是第一次接觸vim,
   建議你先看看其他的vim入門的教程, 或者在shell下輸入命令: vimtutor,
   這是一個簡單的入門教程.
2.  編程技巧.
3.  vim腳本的編寫.

我的工作環境是: Fedora Core 5
gvim是自己編譯的7.0, 如果你還沒有安裝gvim, 請看我的這篇文章<在Redhat Linux 9中編譯和配置gvim 7.0>
由於本人一直從事C語言工作, 所以下面這些例子都是在C語言程序中演示的, 其他語言的沒有試過, 如果有朋友在別的語言下有問題, 可以跟我討論一些, 我會盡量幫助你們的.

本文用的示範源碼是vim7.1的源碼, 可以在www.vim.org下載到源碼包:vim-7.1.tar.bz2, 你也可以不用下載, 就用你自己程序的源碼, 關係不大的. 我把源碼解壓在我的home目錄下: ~/vim71

下面對文中的一些名字定義一下:
1. 文中用到的一些用<>括起來的符號比如<C-T>, <C-S-A>, 之類的, 你可以用下面的命令看看解釋:
:help keycodes
2. 文中說的一些路徑, 比如:
  ~/.vim/plugin
  ~/.vim/doc
  ~/.vim/syntax
  如果你沒有, 就自己創建.
3. 文中說到的.vimrc文件都是指 ~/.vimrc

先給大家看張圖片, 我是vim的界面, 解解饞先^_^

(--- 圖1 ---)
對照上圖的圖標, 我在本文中將教會你以下這些功能:
1 簡潔明瞭的Buffer瀏覽和操作
2 文件瀏覽器
3 tag瀏覽器
4 高亮的書籤
5 更豐富的語法高亮
6 成員變量的下拉, 自動補全

2 中文幫助手冊的安裝
 

vim自帶的幫助手冊是英文的, 對平時編程的人來說沒有多大閱讀困難, 何況還有"星級譯王"呢, 可偏偏有一幫人將其翻譯成了中文, 可偏偏我又擋不住誘惑將它安裝了, 唉.......又痛失一個學習英文的好機會, 下不爲例.
大家看看我的中文幫助界面吧:

(--- 圖2 ---)
安裝方法:  
在下面的網站下載中文幫助的文件包:
$wget http://nchc.dl.sourceforge.net/sourceforge/vimcdoc/vimcdoc-1.5.0.tar.gz

解包後進入文件夾,使用以下命令安裝:
$sudo ./vimcdoc.sh -i
啓動vim,輸入:help,看看幫助文檔是否已經便成中文了?

一些注意事項:
1.vim中文文檔不會覆蓋原英文文檔,安裝後vim默認使用中文文檔。若想使用英文文檔,可在vim中執行以下命令:
     set helplang=en
同理,使用以下命令可重新使用中文文檔:
     set helplang=cn
2. 幫助文件的文本是utf-8編碼的, 如果想用vim直接查看, 需要在~/.vimrc中設置:
   set encoding=utf-8

3 vim編程常用命令
  建議先看看幫助手冊中的下面章節, 其中有關tags文件的部分你可以先跳過, 在後面的章節中會講到, 到時候你在回來看看, 就覺得很簡單了:
:help usr_29
:help usr_30
下面是我常用的一些命令, 放在這裏供我備忘:
% 跳轉到配對的括號去
[[ 跳轉到代碼塊的開頭去(但要求代碼塊中'{'必須單獨佔一行)
gD 跳轉到局部變量的定義處
'' 跳轉到光標上次停靠的地方, 是兩個', 而不是一個"
mx 設置書籤,x只能是a-z的26個字母
`x 跳轉到書籤處("`"是1左邊的鍵)
> 增加縮進,"x>"表示增加以下x行的縮進
< 減少縮進,"x<"表示減少以下x行的縮進
    
4 語法高亮
  寫程序沒有語法高亮將是一件多麼痛苦的事情啊, 幸虧vim的作者是個程序員(如果不是, 那可NB大了), 提供了語法高亮功能, 在上面的圖片中大家也可以看到那些註釋, 關鍵字, 字符串等, 都用不同顏色顯示出來了, 要做到這樣, 首先要在你的 ~/.vimrc 文件中增加下面幾句話:
syntax enable
syntax on
再重新啓動vim, 並打開一個c程序文件, 是不是覺得眼前突然色彩繽紛了起來...
如果你不喜歡這個配色方案你可以在"編輯->配色方案"(gvim)中選擇一個你滿意的配色方案, 然後在~/.vimrc文件中增加下面這句:
colorscheme desert
desert是我喜歡的配色方案, 你可以改成你的. 如果菜單中的配色方案你還不滿意(你也太花了吧), 沒關係, 在 vim.org 上跟你一樣的人很多, 他們做了各種各樣的顏色主題, 你可以下載下來一個一個的試, 多地可以看到你眼花. 如果這樣你還不滿意(你還真是XXXX), 沒關係, vim的作者早想到會有你這種人了, 你可以創建你自己的顏色主題, 把下面的這篇文檔好好學習一些一下吧:
:help syntax.txt

更炫的語法高亮:
你可能會發現很多東西沒有高亮起來, 比如運算符號, 各種括號, 函數名, 自定義類型等, 但是看上面的圖片, 我的運算符號和函數名都加亮了^_^, 想知道爲什麼嗎? 哇哈哈哈哈.... 讓我來教你吧 ...

主要的思路是新建一個語法文件, 在文件中定義你要高亮的東東, 想高亮什麼就高亮什麼, 用vim就是這麼自信. 所謂的語法文件就是vim用來高亮各種源文件的一個腳本, vim靠這個腳本的描述來使文件中的不同文本顯示不同的顏色, 比如C語言的語法文件放在類似於這樣的一個路徑中:
/usr/share/vim/vim64/syntax/c.vim
其他語言的語法文件也可以在這個路徑中找到, 你的也許不在這個路徑中, 不管它, 在你自己的HOME下新建一個語法文件, 新建一個空文件:
~/.vim/syntax/c.vim
在其中加入
"========================================================
" Highlight All Function
"========================================================
syn match   cFunction "/<[a-zA-Z_][a-zA-Z_0-9]*/>[^()]*)("me=e-2
syn match   cFunction "/<[a-zA-Z_][a-zA-Z_0-9]*/>/s*("me=e-1
hi cFunction        gui=NONE guifg=#B5A1FF

"========================================================
" Highlight All Math Operator
"========================================================
" C math operators
syn match       cMathOperator     display "[-+/*/%=]"
" C pointer operators
syn match       cPointerOperator  display "->/|/."
" C logical   operators - boolean results
syn match       cLogicalOperator  display "[!<>]=/="
syn match       cLogicalOperator  display "=="
" C bit operators
syn match       cBinaryOperator   display "/(&/||/|/^/|<</|>>/)=/="
syn match       cBinaryOperator   display "/~"
syn match       cBinaryOperatorError display "/~="
" More C logical operators - highlight in preference to binary
syn match       cLogicalOperator  display "&&/|||"
syn match       cLogicalOperatorError display "/(&&/|||/)="

" Math Operator
hi cMathOperator            guifg=#3EFFE2
hi cPointerOperator         guifg=#3EFFE2
hi cLogicalOperator         guifg=#3EFFE2
hi cBinaryOperator          guifg=#3EFFE2
hi cBinaryOperatorError     guifg=#3EFFE2
hi cLogicalOperator         guifg=#3EFFE2
hi cLogicalOperatorError    guifg=#3EFFE2

再打開你的C文件看看, 是不是又明亮了許多. 還有一個壓箱底的要告訴你, 如果你自己增加了一個類型或者結構之類的, 怎麼讓它也象"int", "void"這樣高亮起來呢? 再在上面的文件~/.vim/syntax/c.vim中添加下面的東東:
"========================================================
" My Own DataType
"========================================================
syn keyword cType       My_Type_1 My_Type_2 My_Type_3
這樣你自己的類型My_Type_1, My_Type_2, My_Type_3就也可以向"int"一樣高亮起來了, 這樣的缺點是每增加一個類型, 就要手動在這裏添加一下, 如果有人知道更簡單的方法請一定一定要告訴我, 用下面的地址:
Email : lazy.fox.wu#gmail.com
Homepage : http://blog.csdn.net/wooin

5 在程序中跳來跳去: Ctags 的使用
  哇, 這下可厲害了, Tag文件(標籤文件)可是程序員的看家寶呀, 你可以不用它, 但你不能不知道它, 因爲Linux內核源碼都提供了"make tags"這個選項. 下面我們就來介紹Tag文件.

tags文件是由ctags程序產生的一個索引文件, ctags程序其是叫"Exuberant Ctags", 是Unix上面ctags程序的替代品, 並且比它功能強大, 是大多數Linux發行版上默認的ctags程序. 那麼tags文件是做什麼用的呢? 如果你在讀程序時看了一個函數調用, 或者一個變量, 或者一個宏等等, 你想知道它們的定義在哪兒, 怎麼辦呢? 用grep? 那會搜出很多不相干的地方. 現在流行用是的<C-]>, 誰用誰知道呀, 當光標在某個函數或變量上時, 按下"Ctrl+]", 光標會自動跳轉到其定義處, 夠厲害吧, 你不用再羨慕Visual Studio的程序員了, 開始羨慕我吧~_~.

你現在先別急着去按<C-]>, 你按沒用的, 要不要我幹什麼呀, 你現在要做的是查查你電腦裏有沒有ctags這個程序, 如果有, 是什麼版本的, 如果是Ctags 5.5.4, 就象我一樣, 你最好去裝一個Ctags 5.6, 這個在後面的自動補全章節中會用到. 在這個網站: http://ctags.sourceforge.net, 下載一個類似 ctags-5.6.tar.gz 的文件下來(現在好像5.7版的也出來了, 不過我還沒用過):

用下面的命令解壓安裝:
$ tar -xzvf ctags-5.6.tar.gz
$ cd ctags-5.6
$ make
# make install   // 需要root權限

然後去你的源碼目錄, 如果你的源碼是多層的目錄, 就去最上層的目錄, 在該目錄下運行命令: ctags -R
我現在以 vim71 的源碼目錄做演示
$ cd /home/wooin/vim71
$ ctags -R
此時在/home/wooin/vim71目錄下會生成一個 tags 文件, 現在用vim打開 /home/wooin/vim71/src/main.c
$ vim /home/wooin/vim71/src/main.c
再在vim中運行命令:
:set tags=/home/wooin/vim71/tags
該命令將tags文件加入到vim中來, 你也可以將這句話放到~/.vimrc中去, 如果你經常在這個工程編程的話.
下面要開始真刀實槍的開幹了, 如下圖, 將光標放在setmouse()函數上

(--- 圖3 ---)

此時按下<C-]>, 光標會自動跳到setmouse()函數的定義處, 見下圖:

(--- 圖4 ---)

如果此時你還想再跳回剛纔的位置, 你還可以按<C-T>, 這樣又跳回到setmouse()函數被調用的地方了, 變量, 結構, 宏, 等等, 都可以的, 趕快試試吧.....

此時在回頭學習一下第3節中說的vim手冊吧
:help usr_29

不過還有一個小瑕疵, 你修改程序後, 比如增加了函數定義, 刪除了變量定義, tags文件不能自動rebuild, 你必須手動再運行一下命令:
$ ctags -R
使tags文件更新一下, 不過讓人感到欣慰的是vim不用重新啓動, 正在編寫的程序也不用退出, 馬上就可以又正確使用<C-]>和<C-T>了. 如果有人知道更簡單的方法請一定一定要告訴我, 用下面的地址:
Email : lazy.fox.wu#gmail.com
Homepage : http://blog.csdn.net/wooin

6. 教你高效地瀏覽源碼 -- 插件: TagList
 
下載地址 http://www.vim.org/scripts/script.php?script_id=273
版本 4.4
安裝 首先在.vimrc文件中,添加:filetype on;  然後在 ~/.vim 目錄下解壓taglist_xx.zip
手冊 :help taglist.txt

在Windows平臺上用過Source Insight看程序的人肯定很熟悉代碼窗口左邊那個Symbol窗口, 那裏面列出了當前文件中的所有宏, 全局變量, 函數名等, 在查看代碼時用這個窗口總攬全局, 切換位置相當方便, 今天告訴你一個vim的插件: Taglist, 可以同樣實現這個功能.

上一節已經告訴你ctags的用法了, ctags的基本原理是將程序程序中的一些關鍵字(比如:函數名, 變量名等)的名字, 位置等信息通過一個窗口告訴你, 如果你已經安裝好taglist, 則可以用下面的命令看看taglist自帶的幫助文件:
:help taglist.txt
下面是我翻譯的其中的第一段"Overview", 供大家現瞭解一下taglist, 翻譯的不好, 請指教:
"Tab List"是一個用來瀏覽源代碼的Vim插件, 這個插件可以讓你高效地瀏覽各種不同語言編寫的的源代碼, "Tag List"有以下一些特點:
    * 在Vim的一個垂直或水平的分割窗口中顯示一個文件中定義的tags(函數, 類, 結構,
      變量, 等)
    * 在GUI Vim中, 可以選擇把tags顯示在下拉菜單和彈出菜單中
    * 當你在多個源文件/緩衝區間切換時, taglist窗口會自動進行相應地更新.
      當你打開新文件時, 新文件中定義的tags會被添加到已經存在的文件列表中,
      並且所有文件中定義的tags會以文件名來分組顯示
    * 當你在taglist窗口中選中一個tag名時, 源文件中的光標會自動跳轉到該tag的定
      義處
    * 自動高亮當前的tag名
    * 按類型分組各tag, 並且將各組顯示在一個可摺疊的樹形結構中
    * 可以顯示tag的原始類型和作用域
    * 在taglist窗口可選擇顯示tag的原始類型替代tag名
    * tag列表可以按照tag名, 或者時間進行排序
    * 支持以下語言的源文件: Assembly, ASP, Awk, Beta, C,
      C++, C#, Cobol, Eiffel, Erlang, Fortran, HTML, Java, Javascript, Lisp,
      Lua, Make, Pascal, Perl, PHP, Python, Rexx, Ruby, Scheme, Shell, Slang,
      SML, Sql, TCL, Verilog, Vim and Yacc.
    * 可以很簡單的擴展支持新的語言. 對新語言支持的修改也很簡單.
    * 提供了一些函數, 可以用來在Vim的狀態欄或者在窗口的標題欄顯示當前的tag名
    * taglist中的文件和tags的列表可以在被保存和在vim會話間加載
    * 提供了一些用來取得tag名和原始類型的命令
    * 在控制檯vim和GUI vim中都可以使用
    * 可以和winmanager插件一起使用. winmanager插件可以讓你同時使用文件瀏覽器,
      緩衝區瀏覽器和taglist插件, 就像一個IDE一樣.
    * 可以在Unix和MS-Windows系統中使用

首先請先在你的~/.vimrc文件中添加下面兩句:
let Tlist_Show_One_File=1
let Tlist_Exit_OnlyWindow=1
此時用vim打開一個c源文件試試:
$ vim ~/vim/src/main.c
進入vim後用下面的命令打開taglist窗口, 如圖5:
:Tlist


(--- 圖5 ---)
左邊的窗口就是前面介紹的TagList窗口, 其中列出了main.c文件中的tag, 並且按照"typedef", "variable", "function"等進行了分類. 將光標移到VimMain上, 如圖中左邊紅色的方框, 按下回車後, 源程序會自動跳轉到VimMain的定義處, 如圖中右邊的紅色方框. 這就是TagList最基本也是最常用的操作. 再教你一個常用的操作, 你在瀏覽TagList窗口時, 如果還不想讓源碼跳轉, 但是想看看tag在源碼中完整的表達, 可以將光標移到你想要看的tag上, 如圖中上邊黃色的方框, 然後按下空格鍵, 在下面的命令欄中, 如圖下邊黃色的方框, 會顯示該tag在源碼中完整的寫法, 而不會跳轉到源碼處.

TagList插件我就介紹到這裏, 其實它還有很多用法和設置, 我沒法一一地教你了, 好在TagList有一份詳細的幫助手冊, 用下面的命令打開手冊, 好好學習一下吧:
:help taglist.txt

7. 文件瀏覽器和窗口管理器 -- 插件: WinManager
 
下載地址 http://www.vim.org/scripts/script.php?script_id=95
版本 2.x
安裝 在 ~/.vim 目錄下解壓winmanager.zip
手冊 :help winmanager

在圖1中大家可以看到在圖標2標識的地方是一個文件瀏覽器, 裏面列出了當前目錄中的文件, 可以通過這個瀏覽器來瀏覽工程中的源文件, 是不是越來越像常見的IDE了, 當光標停在某個文件或文件夾的時候, 按下回車, 可以打開該文件或文件夾.
這個東東是怎麼調出來的呢? 其實這個也是由插件實現的, 這個插件是netrw.vim, 只不過你不用下載和安裝, 這個插件已經是標準的vim插件, 已經隨vim一起安裝進你的系統裏了, 現在先簡單演示一下, 進入"~/vim71"文件夾後運行vim, 然後在vim中運行命令:
:e ~/vim71
你將在vim看到如下圖所示的界面:

(--- 圖6 ---)
在該界面上你可以用下面的一些命令來進行常用的目錄和文件操作:
<F1> 顯示幫助
<cr> 如果光標下是目錄, 則進入該目錄; 如果光標下文件, 則打開該文件
- 返回上級目錄
c 切換vim 當前工作目錄正在瀏覽的目錄
d 創建目錄
D 刪除目錄或文件
i 切換顯示方式
R 文件或目錄重命名
s 選擇排序方式
x 定製瀏覽方式, 使用你指定的程序打開該文件

我這裏不是教你怎麼用netrw.vim插件, 而是要教你通過WinManager插件來將TagList窗口和netrw窗口整合起來, 就像圖1中的圖標2和3組成的那個效果
現在在你的~/.vimrc中增加下面兩句
let g:winManagerWindowLayout='FileExplorer|TagList'
nmap wm :WMToggle<cr>
然後重啓vim, 打開~/vim71/src/main.c, 在normal狀態下輸入"wm", 你將看到圖7的樣子:

(--- 圖7 ---)
其中左上邊是netrw窗口, 左下邊是TagList窗口, 當再次輸入"wm"命令時這兩個窗口又關閉了.

WinManager的功能主要就是我介紹的這些, 但是它還有其他一些高級功能, 還可以支持其他幾個插件, 如果你覺得我介紹的還不夠你用, 建議你把它的幫助手冊好好研究一下, 用下面的命令可以調出幫助手冊:
:help winmanager

8. Cscope 的使用
  這下更厲害了, 用Cscope自己的話說 - "你可以把它當做是超過頻的ctags", 其功能和強大程度可見一斑吧, 關於它的介紹我就不詳細說了, 如果你安裝好了前文介紹的中文幫助手冊, 用下面的命令看看介紹吧:
:help if_cscop.txt
我在這裏簡單摘抄一點, 供還在猶豫的朋友看看:
Cscope 是一個交互式的屏幕下使用的工具,用來幫助你:
* 無須在厚厚的程序清單中翻來翻去就可以認識一個 C 程序的工作原理。
* 無須熟悉整個程序就可以知道清楚程序 bug 所要修改的代碼位置。
* 檢查提議的改動 (如添加一個枚舉值) 可能會產生的效果。
* 驗證所有的源文件都已經作了需要的修改;例如給某一個現存的函數添加一個參數。
* 在所有相關的源文件中對一個全局變量改名。
* 在所有相關的位置將一個常數改爲一個預處理符號。

它被設計用來回答以下的問題:
* 什麼地方用到了這個符號?
* 這是在什麼地方定義的?
* 這個變量在哪裏被賦值?
* 這個全局符號的定義在哪裏?
* 這個函數在源文件中的哪個地方?
* 哪些函數調用了這個函數?
* 這個函數調用了哪些函數?
* 信息 "out of space" 從哪來?
* 這個源文件在整個目錄結構中處於什麼位置?
* 哪些文件包含這個頭文件?

安裝Cscope:
如果你的系統中有cscope命令, 則可以跳過這一小段, 如果沒有, 就先跟着我一起安裝一個吧.
在Cscope的主頁: http://cscope.sourceforge.net 下載一個源碼包, 解壓後編譯安裝:
# ./configure
# make
# make install       // 需要root權限

先在~/vimrc中增加一句:
:set cscopequickfix=s-,c-,d-,i-,t-,e-
這個是設定是否使用 quickfix 窗口來顯示 cscope 結果, 用法在後面會說到。

跟Ctags一樣, 要使用其功能必須先爲你的代碼生成一個cscope的數據庫, 在項目的根目錄運行下面的命令:
$ cd /home/wooin/vim71/
$ cscope -Rbq
# 此後會生成三個文件
$ ll cscope.*
-rw-rw-r-- 1 wooin wooin 1.1M 2007-09-30 10:56 cscope.in.out
-rw-rw-r-- 1 wooin wooin 6.7M 2007-09-30 10:56 cscope.out
-rw-rw-r-- 1 wooin wooin 5.1M 2007-09-30 10:56 cscope.po.out
# 打開文件, 開始Coding
$ cd src
$ vi main.c
進入vim後第一件事是要把剛纔生成的cscope文件導入到vim中來, 用下面的命令:
:cs add /home/wooin/vim71/cscope.out /home/wooin/vim71
上面這條命令很重要, 必須寫全, 不能只寫前半句:
:cs add /home/wooin/vim71/cscope.out
因爲源碼是多級目錄的, 如果這樣寫, cscope是無法在子目錄中的源碼中工作的, 當然, 如果你的源碼都在同一級目錄中就無所謂了. 如果你要經常用cscope的話, 可以把上面那句加到~/.vimrc中去.

下面我們來操練一下, 查找函數vim_strsave()的定義, 用命令:
:cs find g vim_strsave
如下圖:

(--- 圖8 ---)
按下回車後會自動跳轉到vim_strsave()的定義處. 此時你肯定會說Ctags也可以做到這個呀, 那麼下面說的這個Ctags就無法做到了, 我想查找vim_strsave()到底在那些地方被調用過了, 用命令:
:cs find c vim_strsave
按下回車後vim會自動跳轉到第一個符合要求的地方, 並且在命令欄顯示有多少符合要求的結果, 如圖:

(--- 圖9 ---)
如果自動跳轉的位置你不滿意, 想看其他的結果, 可以用下面的命令打開QuickFix窗口:
:cw
如圖:

(--- 圖10 ---)
這時你就可以慢慢挑選了^_^

cscope的主要功能是通過同的子命令"find"來實現的
"cscope find"的用法:
cs find c|d|e|f|g|i|s|t name
0 或 s 查找本 C 符號(可以跳過註釋)
1 或 g 查找本定義
2 或 d 查找本函數調用的函數
3 或 c 查找調用本函數的函數
4 或 t 查找本字符串
6 或 e 查找本 egrep 模式
7 或 f 查找本文件
8 或 i 查找包含本文件的文件

如果每次查找都要輸入一長串命令的話還真是件討人厭的事情, Cscope的幫助手冊中推薦了一些快捷鍵的用法, 下面是其中一組, 也是我用的, 將下面的內容添加到~/.vimrc中, 並重啓vim:
nmap <C-_>s :cs find s <C-R>=expand("<cword>")<CR><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>
nmap <C-_>t :cs find t <C-R>=expand("<cword>")<CR><CR>
nmap <C-_>e :cs find e <C-R>=expand("<cword>")<CR><CR>
nmap <C-_>f :cs find f <C-R>=expand("<cfile>")<CR><CR>
nmap <C-_>i :cs find i ^<C-R>=expand("<cfile>")<CR><CR>
nmap <C-_>d :cs find d <C-R>=expand("<cword>")<CR><CR>
當光標停在某個你要查找的詞上時, 按下<C-_>g, 就是查找該對象的定義, 其他的同理.
按這種組合鍵有一點技巧,按了<C-_>後要馬上按下一個鍵,否則屏幕一閃就回到nomal狀態了
<C-_>g的按法是先按"Ctrl+Shift+-", 然後很快再按"g"

很奇怪, 其中的這句:
nmap <C-_>i :cs find i ^<C-R>=expand("<cfile>")<CR>$<CR>
在我的vim中無法工作, 但是我改成:
nmap <C-_>i :cs find i <C-R>=expand("<cfile>")<CR><CR>
就可以正常工作了, 不知道是什麼原因? 有哪位朋友知道請告訴我.

cscope的其他功能你可以通過幫助手冊自己慢慢學習

reset : 重新初始化所有連接。
用法  : cs reset

9. QuickFix 窗口
  在上一節的圖10中大家可以看到在窗口下面有一個顯示查詢結果的窗口, 這個窗口中列出了查詢命令的查詢結果, 用戶可以從這個窗口中選擇每個結果進行查看, 這個窗口叫"QuickFix"窗口, 以前也是一個vim的插件來的, 只不過現在成了vim的標準插件, 不用你在去安裝了, QuickFix窗口的主要作用就是上面看到的那個功能: 輸出一些供選擇的結果, 可以被很多命令調用, 更詳細的介紹和使用方法請用下面的命令打開QuickFix的手冊來學習吧:
:help quickfix
這裏我一個常用的例子來再介紹一種QuickFix窗口的使用方法. 這個例子是要模仿平時我們編程時, 當編譯出錯時, QuickFix會把出錯的信息列出來, 供我們一條條地查看和修改. 首先還是用vim打開~/vim71/src/main.c, 事先最好先編譯過vim71, 否則一會兒編譯的時候有點慢, 或者你也可以自己寫一個小的有錯誤的程序來跟着我做下面的步驟, 見下圖:

(--- 圖11 ---)
我們修改一下main.c, 人爲地造成幾處錯誤, 在第1019行增加了一個baobao_wu的沒有任何定義的字符串, 刪除了第1020行最後的一個括號")", 然後用下面的命令進行編譯:
:make
顯然編譯會報很多錯誤, 當編譯結束並退出到源碼界面時, 剛纔編譯器報的錯誤都已經看不到了, 但是我們可以用QuickFix窗口再將錯誤信息找出來, 用下面的命令調出QuickFix窗口:
:cw
此時你就可以看如下圖所示的QuickFix窗口了:

(--- 圖12 ---)
在下面的QuickFix窗口中我們可以找到每一個編譯錯誤, 同樣你可以用鼠標點擊每一條記錄, 代碼會馬上自動跳轉到錯誤處, 你還可以用下面的命令來跳轉:
:cn        // 切換到下一個結果
:cp        // 切換到上一個結果
如果你經常使用這兩個命令, 你還可以給他們設定快捷鍵, 比如在~/.vimrc中增加:
nmap <F6> :cn<cr>
nmap <F7> :cp<cr>

其還有其他的命令/插件也會用到QuickFix窗口, 但是用法基本上的都是類似的, 本文後面還會用到QuickFix窗口, 接着往下看吧.
10. 快速瀏覽和操作Buffer -- 插件: MiniBufExplorer
 
下載地址 http://www.vim.org/scripts/script.php?script_id=159
版本 6.3.2
安裝 將下載的 minibufexpl.vim文件丟到 ~/.vim/plugin 文件夾中即可
手冊 在minibufexpl.vim 文件的頭部

在編程的時候不可能永遠只編輯一個文件, 你肯定會打開很多源文件進行編輯, 如果每個文件都打開一個vim進行編輯的話那操作起來將是多麻煩啊, 所以vim有buffer(緩衝區)的概念, 可以看vim的幫助:
:help buffer
vim自帶的buffer管理工具只有:ls, :bnext, :bdelete 等的命令, 既不好用, 又不直觀. 現在隆重向你推薦一款vim插件(plugin): MiniBufExplorer

使用方法:
重新啓動vim, 當你只編輯一個buffer的時候
MiniBufExplorer派不上用場, 當你打開第二個buffer的時候, MiniBufExplorer窗口就自動彈出來了, 見下圖:

(--- 圖13 ---)
上面那個狹長的窗口就是MiniBufExplorer窗口, 其中列出了當前所有已經打開的buffer, 當你把光標置於這個窗口時, 有下面幾個快捷鍵可以用:
<Tab> 向前循環切換到每個buffer名上
<S-Tab> 向後循環切換到每個buffer名上
<Enter> 在打開光標所在的buffer
d 刪除光標所在的buffer

以下的兩個功能需要在~/.vimrc中增加:
let g:miniBufExplMapCTabSwitchBufs = 1

<C-Tab> 向前循環切換到每個buffer上,並在但前窗口打開
<C-S-Tab> 向後循環切換到每個buffer上,並在但前窗口打開

如果在~/.vimrc中設置了下面這句:
let g:miniBufExplMapWindowNavVim = 1
則可以用<C-h,j,k,l>切換到上下左右的窗口中去,就像:
C-w,h j k l    向"左,下,上,右"切換窗口.
在~/.vimrc中設置:
let g:miniBufExplMapWindowNavArrows = 1
是用<C-箭頭鍵>切換到上下左右窗口中去
11. c/h文件間相互切換 -- 插件: A
 
下載地址 http://www.vim.org/scripts/script.php?script_id=31
版本  
安裝 將a.vim 放到 ~/.vim/plugin 文件夾中
手冊

下面介紹它的用法:
作爲一個C程序員, 日常Coding時在源文件與頭文件間進行切換是再平常不過的事了, 直接用vim打開其源/頭文件其實也不是什麼麻煩事, 但是隻用一個按鍵就切換過來了, 這是多麼貼心的功能啊....
安裝好a.vim後有下面的幾個命令可以用了:
:A 在新Buffer中切換到c/h文件
:AS 橫向分割窗口並打開c/h文件
:AV 縱向分割窗口並打開c/h文件
:AT 新建一個標籤頁並打開c/h文件
其他還有一些命令, 你可以在它的網頁上看看, 我都沒用過, 其實也都是大同小異, 找到自己最順手的就行了.

我在~/.vimrc中增加了一句:
nnoremap <silent> <F12> :A<CR>
意思是按F12時在一個新的buffer中打開c/h文件, 這樣在寫程序的時候就可以不假思索地在c/h文件間進行切換, 減少了按鍵的次數, 思路也就更流暢了, 阿彌陀佛....
12. 在工程中查找 -- 插件: Grep
 
下載地址 http://www.vim.org/scripts/script.php?script_id=311
版本 1.8
安裝 把grep.vim 文件丟到 ~/.vim/plugin 文件夾就好了
手冊 在grep.vim 文件頭部

下面介紹它的用法:
vim有自己的查找功能, 但是跟shell中的grep比起來還是有些差距的, 有時Coding正火急火燎的時候, 真想按下F3, 對光標所在的詞來個全工程範圍的grep, 不用敲那些繁瑣的命令, 現在福音來了, 跟我同樣懶的人不在少數, 在grep.vim腳本的前部可以找到一些說明文檔:
:Grep 按照指定的規則在指定的文件中查找
:Rgrep 同上, 但是是遞歸的grep
:GrepBuffer 在所有打開的緩衝區中查找
:Bgrep 同上
:GrepArgs 在vim的argument filenames (:args)中查找
:Fgrep 運行fgrep
:Rfgrep 運行遞歸的fgrep
:Egrep 運行egrep
:Regrep 運行遞歸的egrep
:Agrep 運行agrep
:Ragrep 運行遞歸的agrep

上面的命令是類似這樣調用的:
:Grep   [<grep_options>] [<search_pattern> [<file_name(s)>]]
:Rgrep  [<grep_options>] [<search_pattern> [<file_name(s)>]]
:Fgrep  [<grep_options>] [<search_pattern> [<file_name(s)>]]
:Rfgrep [<grep_options>] [<search_pattern> [<file_name(s)>]]
:Egrep  [<grep_options>] [<search_pattern> [<file_name(s)>]]
:Regrep [<grep_options>] [<search_pattern> [<file_name(s)>]]
:Agrep  [<grep_options>] [<search_pattern> [<file_name(s)>]]
:Ragrep [<grep_options>] [<search_pattern> [<file_name(s)>]]
:GrepBuffer [<grep_options>] [<search_pattern>]
:Bgrep [<grep_options>] [<search_pattern>]
:GrepArgs [<grep_options>] [<search_pattern>]

但是我從來都不用敲上面那些命令的^_^, 因爲我在~/.vimrc中增加了下面這句:
nnoremap <silent> <F3> :Grep<CR>
比如你想在/home/wooin/vim71/src/main.c中查找"FEAT_QUICKFIX", 則將光標移到"FEAT_QUICKFIX"上, 然後按下F3鍵, 如下圖:

(--- 圖14 ---)
在最下面的命令行會顯示:
Search for pattern: FEAT_QUICKFIX
此時你還可以編輯該行, grep支持正則表達式, 你想全詞匹配的話可以改成:
Search for pattern: /<FEAT_QUICKFIX/>
然後按下回車:

(--- 圖15 ---)
在最下面的命令行會顯示:
Search in files: *
是問你搜索範圍, 默認是該目錄下的所有文件, 此時你還可以編輯該行, 比如你只想搜索源碼文件:
Search in files: *.c *.h
然後在按下回車, 會在彈出的QuickFix窗口中列出所有符合條件的搜索結果, 你可以在其中查找你想要的結果, 如下圖:

(--- 圖16 ---)

其實還有一些其他功能和設置, 但是我都沒有用過, 這些功能再加上正則表達式, 已經夠我用了, 其他的你可以在網頁上看看它的文檔, 如果有什麼驚人發現記得跟我互通有無, 共同進步哦....
13. 高亮的書籤 -- 插件: VisualMark
 
下載地址 http://www.vim.org/scripts/script.php?script_id=1026
版本  
安裝 把visualmark.vim 文件丟到 ~/.vim/plugin 文件夾就好了
手冊

下面介紹它的用法:
vim也和其他編輯器一樣有"書籤"概念, 在vim中叫"Mark", 可以用下面的命令查看相關說明:
:help Mark
該"書籤"有個很很大的缺點: 不可見.
我下面要介紹的Visual Mark插件跟vim中的"Mark"沒有什麼關係, 並不是使其可見, 而是自己本身就是"可見的書籤", 接着往下看就明白了, 用作者的話說就是"類似UltraEdit中的書籤".
另外, 網上也有使vim中的Mark可見的插件, 但是我試了一下, 好像沒Visual Mark好用, 我就不介紹了.

按照上面的方法安裝好Visual Mark後, 你什麼也不用設置, 如果是gvim, 直接在代碼上按下Ctrl+F2, 如果是vim, 用"mm", 怎麼樣, 發現光標所在的行變高亮了吧, 見下圖:

(--- 圖17 ---)
如果你設置了多個書籤, 你可以用F2鍵正向在期間切換, 用Shift+F2反向在期間切換.
好了, 我Visual Mark介紹完了, 夠簡單吧^_^.

如果你嫌書籤的顏色不好看, 你還可以自己定義, 不過是修改這個插件腳本的的源碼, 在目錄~/.vim/plugin/中找到並打開visualmark.vim, 找到下面這段代碼:
if &bg == "dark" // 根據你的背景色風格來設置不同的書籤顏色
 highlight SignColor ctermfg=white ctermbg=blue guifg=wheat guibg=peru
else             // 主要就是修改guibg的值來設置書籤的顏色
 highlight SignColor ctermbg=white ctermfg=blue guibg=grey guifg=RoyalBlue3
endif

 

安裝 visualmark.vim 後,如果是在 Ubuntu 下做標記,會報一個“E197 不能設定語言爲'en_US'"的錯誤,但是在 Windows 下卻不會。在網上找了一下,發現修復方法。
只要將exec ":lan mes en_US" 修改爲 exec ":lan POSIX" 即可,爲了能夠在兩個系統中都能使用,於是修改了一下 visualmark.vim 源碼,就是在 exec 外加了一個判斷系統的語句。本來還想直接上傳一份供大家下載使用,才發現 Iteye 居然只能上傳圖像....
這裏就提供具體修改方法:
使用文本編輯器打開 visualmark.vim
定位到
exec ":lan mes en_US"
修改爲
if has("win32") || has("win95") || has("win64") || has("win16")
    exec ":lan mes en_US"
else
    exec ":lan POSIX"
endif
保存即可。

 


我還有幾個不滿意的地方:
1 這個書籤不能自動保存, 關閉vim就沒了.
2 切換書籤時不能在不同文件間切換, 只能在同一個文件中切換

如果哪位朋友能解決這兩個問題, 請一定要告訴寡人啊....還是用下面的地址:

Email : lazy.fox.wu#gmail.com
Homepage : http://blog.csdn.net/wooin

14. 自動補全
  用過Microsoft Visual Studio的朋友一定知道代碼補全功能, 輸入一個對象名後再輸入"."或者"->", 則其成員名都可以列出來, 使Coding流暢了許多, 實現很多懶人的夢想, 現在我要告訴你, 這不再是Microsoft Visual Studio的專利了, vim也可以做到! 下面由我來教你, 該功能要tags文件的支持, 並且是ctags 5.6版本, 可以看看前文介紹tags文件的章節.

我這裏要介紹的功能叫"new-omni-completion(全能補全)", 你可以用下面的命令看看介紹:
:help new-omni-completion

你還需要在~/.vimrc文件中增加下面兩句:
filetype plugin indent on
打開文件類型檢測, 加了這句纔可以用智能補全
set completeopt=longest,menu
關掉智能補全時的預覽窗口

請確定你的Ctags 5.6已經安裝好, 並且生成的tags文件已經可以用了, 那麼我們就要抄傢伙開搞了.
用vim打開源文件
$ vi /home/wooin/vim71/src/main.c
設置tags文件
:set tags=/home/wooin/vim71/tags
隨便找一個有成員變量的對象, 比如"parmp", 進入Insert模式, 將光標放在"->"後面,
然後按下"Ctrl+X Ctrl+O", 此時會彈出一個下列菜單, 顯示所有匹配的標籤, 如下圖:

(--- 圖18 ---)
此時有一些快捷鍵可以用:
Ctrl+P 向前切換成員
Ctrl+N 向後切換成員
Ctrl+E 表示退出下拉窗口, 並退回到原來錄入的文字
Ctrl+Y 表示退出下拉窗口, 並接受當前選項

如果你增加了一些成員變量, 全能補全還不能馬上將新成員補全, 需要你重新生成一下tags文件, 但是你不用重啓vim, 只是重新生成一下tags文件就行了, 這時全能補全已經可以自動補全了, 還真夠"全能"吧.

vim中的其他補全方式還有:
Ctrl+X Ctrl+L 整行補全
Ctrl+X Ctrl+N 根據當前文件裏關鍵字補全
Ctrl+X Ctrl+K 根據字典補全
Ctrl+X Ctrl+T 根據同義詞字典補全
Ctrl+X Ctrl+I 根據頭文件內關鍵字補全
Ctrl+X Ctrl+] 根據標籤補全
Ctrl+X Ctrl+F 補全文件名
Ctrl+X Ctrl+D 補全宏定義
Ctrl+X Ctrl+V 補全vim命令
Ctrl+X Ctrl+U 用戶自定義補全方式
Ctrl+X Ctrl+S 拼寫建議

15. 加速你的補全 -- 插件: SuperTab
 
下載地址 http://www.vim.org/scripts/script.php?script_id=1643
版本 0.43
安裝 把supertab.vim 文件丟到 ~/.vim/plugin 文件夾就好了
手冊 supertab.vim 文件頭部, 和命令 ":SuperTabHelp"

在上面一節中你應該學會了自動補全代碼的功能, 按下"Ctrl+X Ctrl+O"就搞定了, 如果你夠懶的話肯定會說"這麼麻煩啊, 居然要按四個鍵", 不必爲此自責, 因爲Gergely Kontra 和 Eric Van Dewoestine也跟你差不多, 只不過人家開發了supertab.vim這個插件, 可以永遠懶下去了, 下面我來教你偷懶吧.

在你的~/.vimrc文件中加上這兩句:
let g:SuperTabRetainCompletionType=2
let g:SuperTabDefaultCompletionType="<C-X><C-O>"
以後當你準備按"Ctrl+X Ctrl+O"的時候直接按<Tab>就好了, 夠爽吧 ....

我稍微再介紹一下上面那兩句配置信息:
let g:SuperTabDefaultCompletionType="<C-X><C-O>"
" 設置按下<Tab>後默認的補全方式, 默認是<C-P>,
" 現在改爲<C-X><C-O>. 關於<C-P>的補全方式,

" 還有其他的補全方式, 你可以看看下面的一些幫助:
" :help ins-completion
" :help compl-omni

let g:SuperTabRetainCompletionType=2
" 0 - 不記錄上次的補全方式
" 1 - 記住上次的補全方式,直到用其他的補全命令改變它
" 2 - 記住上次的補全方式,直到按ESC退出插入模式爲止
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章