來源程式檔案(通常是純文字檔案)比較和合并工具一直是軟體開發過程中比較重要的組成部分。現在市場上很多功能很強大的專用比較和合并工具,比如 BeyondCompare;很多IDE 或者軟體組態管理系統,比如Eclipse, Rational ClearCase都提供了內建的功能來支援檔案的比較和合并。
當遠程工作在Unix/Linux平台上的時候,恐怕最簡單而且到處存在的就是命令列工具,比如diff。可惜diff的功能有限,使用起來也不是很方便。作為命令列的比較工具,我們仍然希望能擁有簡單明了的介面,可以使我們能夠對比較結果一目瞭然;我們還希望能夠在比較出來的多處差異之間快速定位,希望能夠很容易的進行檔案合并……。而Vim提供的diff模式,通常稱作vimdiff,就是這樣一個能滿足所有這些需求,甚至能夠提供更多的強力工具。在最近的工作中,因為需要做很多的檔案比較和合并的工作,因此對Vimdiff的使用做了一個簡單的總結。我們先來看看vimdiff的基本使用。
啟動方法
首先保證系統中的diff命令是可用的。Vim的diff模式是依賴於diff命令的。Vimdiff的基本用法就是:
# vimdiff FILE_LEFT FILE_RIGHT |
或者
# vim -d FILE_LEFT FILE_RIGHT |
圖一就是vimdiff命令的執行結果的畫面。
從我們可以看到一個清晰的比較結果。螢幕被垂直分割,左右兩側分別顯示被比較的兩個檔案。兩個檔案中連續的相同的行被摺疊了起來,以便使用者能把注意力集中在兩個檔案的差異上。只在某一檔案中存在的行的背景色被設定為藍色,而在另一檔案中的對應位置被顯示為綠色。兩個檔案中都存在,但是包含差異的行顯示為粉色背景,引起差異的文字用紅色背景加以突出。
除了用這種方法啟動vim的diff模式之外,我們還可以用分割視窗命令來啟動diff模式:
然後在vim的ex模式(也就是"冒號"模式)下輸入:
:vertical diffsplit FILE_RIGHT |
也可以達到同樣的效果。如果希望交換兩個視窗的位置,或者希望改變視窗的分割方式,可以使用下列命令:
1.Ctrl-w K(把當前視窗移到最上邊)
2.Ctrl-w H(把當前視窗移到最左邊)
3.Ctrl-w J(把當前視窗移到最下邊)
4.Ctrl-w L(把當前視窗移到最右邊)
其中1和3兩個操作會把視窗改成水平分割方式。
回頁首
游標移動
接下來試試在行間移動游標,可以看到左右兩側的螢幕滾動是同步的。這是因為"scrollbind"選項被設定了的結果,vim會儘力保證兩側檔案的對齊。如果不想要這個特性,可以設定:
可以使用快速鍵在各個差異點之間快速移動。跳轉到下一個差異點:
反向跳轉是:
如果在命令前加上數位話,可以跳過一個或數個差異點,從而實現跳的更遠。比如如果在位於第一個差異點的行輸入"2]c",將越過下一個差異點,跳轉到第三個差異點。
回頁首
檔案合并
檔案比較的最終目的之一就是合并,以消除差異。如果希望把一個差異點中當前檔案的內容複寫到另一個檔案裡,可以使用命令
如果希望把另一個檔案的內容複寫到當前行中,可以使用命令
do (diff "get",之所以不用dg,是因為dg已經被另一個命令佔用了) |
如果希望手工修改某一行,可以使用通常的vim操作。如果希望在兩個檔案之間來回跳轉,可以用下列命令序列:
在修改一個或兩個檔案之後,vimdiff會試圖自動來重新比較檔案,來即時反映比較結果。但是也會有處理失敗的情況,這個時候需要手工來重新整理比較結果:
如果希望撤銷修改,可以和平常用vim編輯一樣,直接
但是要注意一定要將游標移動到需要撤銷修改的檔案視窗中。
回頁首
同時操作兩個檔案
在比較和合并告一段落之後,可以用下列命令對兩個檔案同時進行操作。比如同時退出:
如果希望儲存全部檔案:
或者是兩者的合并命令,儲存全部檔案,然後退出:
:wqa (write, then quit all) |
如果在退出的時候不希望儲存任何操作的結果:
回頁首
內容相關的展開和查看
比較和合并檔案的時候經常需要結合上下文來確定最終要採取的操作。Vimdiff 預設是會把不同之處上下各 6 行的文本都顯示出來以供參考。其他的相同的文本行被自動摺疊。如果希望修改預設的上下文行數,可以這樣設定:
可以用簡單的摺疊命令來臨時展開被摺疊的相同的文本行:
zo (folding open,之所以用z這個字母,是因為它看上去比較像摺疊著的紙) |
然後可以用下列命令來重新摺疊:
是設定上下文為3行,並展開了部分相同文本的vimdiff螢幕:
回頁首
結論
在無法使用圖形化的比較工具的時候,或者在需要快速比較和合并少量檔案的時候,Vimdiff是最好的選擇。
參考資料
- Vim的首頁:http://www.vim.org
- Vim中文協助:http://man.chinaunix.net/newsoft/vi/doc/help.html