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"一樣高亮起來了, 這樣的缺點是每增加一個類型, 就要手動在這裡添加一下, 如果有人知道更簡單的方法請一定一定要告訴我, 用下面的位址:
: 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