天天看點

【Linux基礎】vim配置及插件安裝管理

1

寫在前面

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

不該有的功能也有, 你就自己沒事偷着樂吧, 下面我開始介紹今天的工作了.

本文會教你:

本文不會教你:

1.  如何使用vim. 本文不會從零開始教你如何使用vim, 如果你是第一次接觸vim, 

   建議你先看看其他的vim入門的教程, 或者在shell下輸入指令: vimtutor, 

   這是一個簡單的入門教程.

2.  程式設計技巧.

3.  vim腳本的編寫.

我的工作環境是: Fedora Core 5

由于本人一直從事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 ---)

對照上圖的圖示, 我在本文中将教會你以下這些功能:

簡潔明了的Buffer浏覽和操作

2

檔案浏覽器

3

tag浏覽器

4

高亮的書簽

5

更豐富的文法高亮

6

成員變量的下拉, 自動補全

中文幫助手冊的安裝

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

大家看看我的中文幫助界面吧:

(--- 圖2 ---)

安裝方法:   

在下面的網站下載下傳中文幫助的檔案包:

解包後進入檔案夾,使用以下指令安裝:

$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

vim程式設計常用指令

建議先看看幫助手冊中的下面章節, 其中有關tags檔案的部分你可以先跳過, 在後面的章節中會講到, 到時候你在回來看看, 就覺得很簡單了:

:help usr_29

:help usr_30

下面是我常用的一些指令, 放在這裡供我備忘:

%

跳轉到配對的括号去

[[

跳轉到代碼塊的開頭去(但要求代碼塊中'{'必須單獨占一行)

gD

跳轉到局部變量的定義處

''

跳轉到光标上次停靠的地方, 是兩個', 而不是一個"

mx

設定書簽,x隻能是a-z的26個字母

`x

跳轉到書簽處("`"是1左邊的鍵)

>

增加縮進,"x>"表示增加以下x行的縮進

<

減少縮進,"x<"表示減少以下x行的縮進

文法高亮

寫程式沒有文法高亮将是一件多麼痛苦的事情啊, 幸虧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

在其中加入

再打開你的C檔案看看, 是不是又明亮了許多. 還有一個壓箱底的要告訴你, 如果你自己增加了一個類型或者結構之類的, 怎麼讓它也象"int", "void"這樣高亮起來呢? 再在上面的檔案~/.vim/syntax/c.vim中添加下面的東東:

這樣你自己的類型My_Type_1, My_Type_2, My_Type_3就也可以向"int"一樣高亮起來了, 這樣的缺點是每增加一個類型, 就要手動在這裡添加一下, 如果有人知道更簡單的方法請一定一定要告訴我, 用下面的位址:

Email

: lazy.fox.wu#gmail.com

Homepage

: http://blog.csdn.net/wooin

在程式中跳來跳去: 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手冊吧

不過還有一個小瑕疵, 你修改程式後, 比如增加了函數定義, 删除了變量定義, tags檔案不能自動rebuild, 你必須手動再運作一下指令:

使tags檔案更新一下, 不過讓人感到欣慰的是vim不用重新啟動, 正在編寫的程式也不用退出, 馬上就可以又正确使用<C-]>和<C-T>了. 如果有人知道更簡單的方法請一定一定要告訴我, 用下面的位址:

教你高效地浏覽源碼 -- 插件: TagList

下載下傳位址

http://www.vim.org/scripts/script.php?script_id=273

版本

4.4

安裝

在 ~/.vim 目錄下解壓taglist_xx.zip

手冊

:help taglist.txt

在Windows平台上用過Source Insight看程式的人肯定很熟悉代碼視窗左邊那個Symbol視窗, 那裡面列出了目前檔案中的所有宏, 全局變量, 函數名等, 在檢視代碼時用這個視窗總攬全局, 切換位置相當友善, 今天告訴你一個vim的插件: Taglist, 可以同樣實作這個功能.

上一節已經告訴你ctags的用法了, ctags的基本原理是将程式程式中的一些關鍵字(比如:函數名, 變量名等)的名字, 位置等資訊通過一個視窗告訴你, 如果你已經安裝好taglist, 則可以用下面的指令看看taglist自帶的幫助檔案:

下面是我翻譯的其中的第一段"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有一份詳細的幫助手冊, 用下面的指令打開手冊, 好好學習一下吧:

檔案浏覽器和視窗管理器 -- 插件: 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的功能主要就是我介紹的這些, 但是它還有其他一些進階功能, 還可以支援其他幾個插件, 如果你覺得我介紹的還不夠你用, 建議你把它的幫助手冊好好研究一下, 用下面的指令可以調出幫助手冊:

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

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視窗:

此時你就可以看如下圖所示的QuickFix視窗了:

(--- 圖12 ---)

在下面的QuickFix視窗中我們可以找到每一個編譯錯誤, 同樣你可以用滑鼠點選每一條記錄, 代碼會馬上自動跳轉到錯誤處, 你還可以用下面的指令來跳轉:

:cn        // 切換到下一個結果

:cp        // 切換到上一個結果

如果你經常使用這兩個指令, 你還可以給他們設定快捷鍵, 比如在~/.vimrc中增加:

nmap <F6> :cn<cr>

nmap <F7> :cp<cr>

其還有其他的指令/插件也會用到QuickFix視窗, 但是用法基本上的都是類似的, 本文後面還會用到QuickFix視窗, 接着往下看吧.

快速浏覽和操作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

删除光标所在的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-箭頭鍵>切換到上下左右視窗中去

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檔案間進行切換, 減少了按鍵的次數, 思路也就更流暢了, 阿彌陀佛....

在工程中查找 -- 插件: 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 ---)

其實還有一些其他功能和設定, 但是我都沒有用過, 這些功能再加上正規表達式, 已經夠我用了, 其他的你可以在網頁上看看它的文檔, 如果有什麼驚人發現記得跟我互通有無, 共同進步哦....

高亮的書簽 -- 插件: 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"

儲存即可。

我還有幾個不滿意的地方:

1 這個書簽不能自動儲存, 關閉vim就沒了. 

2 切換書簽時不能在不同檔案間切換, 隻能在同一個檔案中切換

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

自動補全

用過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檔案

随便找一個有成員變量的對象, 比如"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

拼寫建議

加速你的補全 -- 插件: 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>就好了, 夠爽吧 ....

我稍微再介紹一下上面那兩句配置資訊:

" 設定按下<Tab>後預設的補全方式, 預設是<C-P>, 

" 現在改為<C-X><C-O>. 關于<C-P>的補全方式, 

" 還有其他的補全方式, 你可以看看下面的一些幫助:

" :help ins-completion

" :help compl-omni

" 0 - 不記錄上次的補全方式

" 1 - 記住上次的補全方式,直到用其他的補全指令改變它

" 2 - 記住上次的補全方式,直到按ESC退出插入模式為止

問題:

但是現在我的<Tab>鍵不好用了, 我以前愛用<Tab>進行縮進, 如果前面有字元按下<Tab>鍵後就會進行補全, 而不是我想要的縮進功能, 不知道有沒有快捷鍵可以暫時關閉和激活SuperTab鍵的功能. 如果哪位朋友知道, 請一定記得告訴我啊....還是用下面的位址:

@

Help poor children in Uganda!

"幫助可憐的烏幹達兒童"

vim的作者開發了這麼個強大, 好用的編輯器, 并且是完全開源, 完全免費的, 不知道比爾蓋子會不會覺得這個人真是不可理喻. 作者對使用者使用者的唯一期望就是幫助烏幹達的兒童, 可以用指令:hlep kcc檢視詳細的内容,

1、捐助一個讀國小的孩子:每月 17 歐元 (或更多)。

2、捐助一個讀中學的孩子:每月 25 歐元 (或更多)。

3、捐助診所:每月或每季度,數額不限。

4、一次性捐贈。

有條件的就資助一下, 沒條件的就像我一樣幫助宣傳一下吧, 這也算是開源精神.....

1.  下載下傳與安裝

        2)進入~/.vim目錄,将Taglist安裝包解壓,解壓後會在~/.vim目錄中生成幾個新子目錄,如plugin和doc(安裝其它插件時,可能還會建立autoload等其它目錄)。

        3)進入~/.vim/doc目錄,在Vim下運作"helptags ."指令。此步驟是将doc下的幫助文檔加入到Vim的幫助主題中,這樣我們就可以通過在Vim中運作“help taglist.txt”檢視taglist幫助。

        4)打開配置檔案~/.vimrc,加入以下幾行:

let Tlist_Show_One_File=1     "不同時顯示多個檔案的tag,隻顯示目前檔案的    

let Tlist_Exit_OnlyWindow=1   "如果taglist視窗是最後一個視窗,則退出vim   

let Tlist_Ctags_Cmd="/usr/bin/ctags" "将taglist與ctags關聯

2. 基本功能和使用方法

在Vim指令行下運作":Tlist"就可以打開Taglist視窗,再次運作":Tlist"則關閉。

左右視窗切換Ctrl+w

在taglist視窗中,可以使用下面的快捷鍵:

<CR>          跳到光标下tag所定義的位置,用滑鼠輕按兩下此tag功能也一樣

o             在一個新打開的視窗中顯示光标下tag

<Space>       顯示光标下tag的原型定義

u             更新taglist視窗中的tag

s             更改排序方式,在按名字排序和按出現順序排序間切換

x             taglist視窗放大和縮小,友善檢視較長的tag

+             打開一個折疊,同zo

-             将tag折疊起來,同zc

*             打開所有的折疊,同zR

=             将所有tag折疊起來,同zM

[[            跳到前一個檔案

]]            跳到後一個檔案

q             關閉taglist視窗

<F1>          顯示幫助

但是!這些大部分可以被滑鼠取代!!快捷鍵是浮雲~~

提示:

如果滑鼠在Vim 裡面點選無效,請在~/.vimrc下加入這句話:

set mouse=a  " always use mouse

3. 常用配制選項

- Tlist_Ctags_Cmd選項用于指定你的Exuberant ctags程式的位置,如果它沒在你PATH變量所定義的路徑中,需要使用此選項設定一下;

- 如果你不想同時顯示多個檔案中的tag,設定Tlist_Show_One_File為1。預設為顯示多個檔案中的tag;

- 設定Tlist_Sort_Type為”name”可以使taglist以tag名字進行排序,預設是按tag在檔案中出現的順序進行排序。按tag出現的範圍(即所屬的namespace或class)排序,已經加入taglist的TODO List,但尚未支援;

- 如果你在想taglist視窗是最後一個視窗時退出VIM,設定Tlist_Exit_OnlyWindow為1;

- 如果你想taglist視窗出現在右側,設定Tlist_Use_Right_Window為1。預設顯示在左側。

- 在gvim中,如果你想顯示taglist菜單,設定Tlist_Show_Menu為1。你可以使用Tlist_Max_Submenu_Items和Tlist_Max_Tag_Length來控制菜單條目數和所顯示tag名字的長度;

- 預設情況下,在輕按兩下一個tag時,才會跳到該tag定義的位置,如果你想單擊tag就跳轉,設定Tlist_Use_SingleClick為1;

- 如果你想在啟動VIM後,自動打開taglist視窗,設定Tlist_Auto_Open為1;

- 如果你希望在選擇了tag後自動關閉taglist視窗,設定Tlist_Close_On_Select為1;

- 當同時顯示多個檔案中的tag時,設定Tlist_File_Fold_Auto_Close為1,可使taglist隻顯示目前檔案tag,其它檔案的tag都被折疊起來。

- 在使用:TlistToggle打開taglist視窗時,如果希望輸入焦點在taglist視窗中,設定Tlist_GainFocus_On_ToggleOpen為1;

- 如果希望taglist始終解析檔案中的tag,不管taglist視窗有沒有打開,設定Tlist_Process_File_Always為1;

- Tlist_WinHeight和Tlist_WinWidth可以設定taglist視窗的高度和寬度。Tlist_Use_Horiz_Window為1設定taglist視窗橫向顯示;

使用方法:在~/.vimrc檔案中,用類似上文提到的格式加入要設定的選項。

比如,設定單擊tag就跳到tag定義的位置,就在檔案中加入這句話:

let Tlist_Use_SingleClick=1  

4. 其他說明

  1)Vim存在多個配置檔案vimrc,比如/etc/vimrc,此檔案影響整個系統的Vim。還有~/.vimrc,此檔案隻影響本使用者的Vim。而且~/.vimrc檔案中的配置會覆寫/etc/vimrc中的配置。這裡我們隻修改~/.vimrc檔案。

    2)Vim的插件(plugin)安裝在Vim的runtimepath目錄下,你可以在Vim指令行下運作"set rtp“指令檢視。這裡我們選擇安裝在~/.vim目錄,沒有就建立一個。

    3)當本文說”在Vim指令行下運作cmdxx指令“時,意思是指在Vim的指令行模式下運作cmdxx指令,即在Vim的正常模式下通過輸入冒号":"進入指令行模式,然後緊接着輸入指令cmdxx。在後文描述中都會省略冒号":"輸入。

    4)如果沒有說明“在Vim指令行下運作某指令”,則是在shell中執行該指令。

    5)如果指令中間被空白符間隔或有與正文容易混淆的字元,我會用雙引号将指令與正文區分。是以讀者在實際操作時,不要輸入指令最前面和最後面引号。

    6)本文關于組合快捷鍵的描述,形如a-b形式的快捷鍵表示同時按下a鍵和b鍵,而形如"a-b c"形式的快捷鍵,則表示先同時按下a鍵和b鍵,然後放開ab鍵,再按下c鍵。

    7) 本人使用的系統是Ubunt 11.10 ,Vim版本是Vi IMproved 7.3

『插件介紹』

Ctags工具是用來周遊源代碼檔案生成tags檔案,這些tags檔案能被編輯器或其它工具用來快速查找定位源代碼中的符号(tag/symbol),如變量名,函數名等。比如,tags檔案就是Taglist和OmniCppComplete工作的基礎。

『下載下傳和安裝』

一、我是使用apt-get安裝的:

sudo apt-get install ctags

二、下載下傳源碼安裝(網上提供的方法)

        2)然後進入源代碼根目錄執行./configure,

        3)然後執行make,

        4)編譯成功後執行make install。

『基本功能使用方法』

常用指令清單:

        1.  $ ctags –R *      ($ 為Linux系統Shell提示符)

        2.  $ vi –t tag         (請把tag替換為您欲查找的變量或函數名)

        3. :ts                                (ts 助記字:tags list, “:”開頭的指令為VI中指令行模式指令)

        4. :tp                                (tp 助記字:tags preview)

        5. :tn                                (tn 助記字:tags next) 

        6. Ctrl + ]

        7. Ctrl + T

指令解釋:

“$ ctags –R *”:“-R”表示遞歸建立,也就包括源代碼根目錄(目前目錄)下的所有子目錄。“*”表示所有檔案。這條指令會在目前目錄下産生一個“tags”檔案,當使用者在目前目錄中運作vi時,會自動載入此tags檔案。

Tags檔案中包括這些對象的清單:

用#define定義的宏

枚舉型變量的值

函數的定義、原型和聲明

名字空間(namespace)

類型定義(typedefs)

變量(包括定義和聲明)

類(class)、結構(struct)、枚舉類型(enum)和聯合(union)

類、結構和聯合中成員變量或函數

VIM用這個“tags”檔案來定位上面這些做了标記的對象。

剩下的指令就是定位這些對象的方法:

“$ vi –t tag” :在運作vim的時候加上“-t”參數,例如:

[/usr/src]$ vim -t main

這個指令将打開定義“main”(變量或函數或其它)的檔案,并把光标定位到這一行。

如果這個變量或函數有多處定義,在VI指令行模式

“:ts”指令就能列出一個清單供使用者選擇。    

“:tp”為上一個tag标記檔案,

“:tn”為下一個tag标記檔案。當然,若目前tags檔案中使用者所查找的變量或函數名隻有一個,“:tp,:tn”指令不可用。

最友善的方法是把光标移到變量名或函數名上,然後按下“Ctrl+]”,這樣就能直接跳到這個變量或函數定義的源檔案中,并把光标定位到這一行。用“Ctrl+t”可以退回原來的地方。即使使用者使用了N次“Ctrl+]”查找了N個變量,按N次“Ctrl+t”也能回到最初打開的檔案,它會按原路傳回 。

更多功能通過指令man ctags或在Vim指令行下運作help ctags查詢。

注意:運作vim的時候,必須在“tags”檔案所在的目錄下運作。否則,運作vim的時候還要用“:settags=”指令設定“tags”檔案的路徑,這樣vim才能找到“tags”檔案。

在完成編碼時,可以手工删掉tags檔案。

參考網址二:http://blog.csdn.net/duguteng/article/details/7417276

繼續閱讀