首頁  >  文章  >  系統教程  >  用vimdiff取代svn diff:比較程式碼的工具

用vimdiff取代svn diff:比較程式碼的工具

PHPz
PHPz轉載
2024-01-09 19:54:13416瀏覽

在linux下,直接使用svn diff指令查看程式碼的修改是很吃力的,於是在網路上搜尋到了一個比較好的解決方案,就是讓vimdiff作為svn diff的檢視程式碼工具,尤其對於習慣用vim的人來說真的是很方便。

當使用svn diff指令比較某個檔案的修改前後時,例如執行以下指令:

$ svn diff -r4420 ngx_http_limit_req_module.c

那麼實際上會向預設的diff程式發送以下命令:

-u -L ngx_http_limit_req_module.c (revision 4420) -L ngx_http_limit_req_module.c (working copy) .svn/tmp/tempfile.tmp ngx_http_limit_req_module.c##  

svn官方FAQ中對於svn diff的解釋(

中文英文):

當使用一個外部的diff指令時,Subversion會產生一個非常複雜的命令列。第一個參數就是具體的--diff-cmd,然後就是具體的--extensions (儘管使用空白的--符號時會忽略擴展),或者如果沒有指定--extensions或者--extensions為空的話,就加上'-u'參數。第三和第四個參數,Subversion會傳遞一個“-L”還有第一個檔案的標籤(例如,“"project_issues.html (revision 11209)”)。第五個和第六個就是另一個“ -L」和第二個檔案的標籤。第七和第八個參數分別是第一個和第二個檔案的名稱(例如,「.svn/text-base/project_issues.html.svn-base」和“.svn/tmp /project_issues.html.tmp”)。

了解了diff的內部呼叫指令,那麼實作用vimdiff當diff程式就比較簡單了。

vimdiff在比較2個檔案時,只要知道這2個檔案的路徑及檔案名稱就可以了,也就是上述diff內部指令中的第7個和第8個2個參數;

同時也說明了由於diff內部指令的參數過多導致用--diff-cmd直接呼叫vimdiff是行不通的(指令如下)。

 $ svn diff --diff-cmd vimdiff -r4420 ngx_http_limit_req_module.c

所以,我們需要自己另外寫一個腳本,讓這個腳本作為diff程序,得到diff的內部命令,然後只取其中的第7個和第8個參數,再傳給vimdiff,這樣就能解決參數多的問題了。

腳本(diffwrap.sh)如下:

#!/bin/sh
# 去掉前5个参数
shift 5
# 使用vimdiff比较
vimdiff "$@"

 另外,svn還提供了在設定檔中修改diff預設程式的功能,這樣就不用每次使用svn diff時再指定--diff-cmd了。

修改~/.subversion/config,找到如下設定行:

# diff-cmd = diff_program (diff, gdiff, etc.)

將上面那個腳本的路徑加入進去就行,例如修改為

diff-cmd = /usr/local/bin/diffwrap.sh

以後,使用svn diff指令就會預設開啟vimdiff比較2個檔案了。

效果圖: 

使用vimdiff代替svn diff的查看代码工具#

以上是用vimdiff取代svn diff:比較程式碼的工具的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:jb51.net。如有侵權,請聯絡admin@php.cn刪除