在linux下,直接使用svn diff指令查看程式碼的修改是很吃力的,於是在網路上搜尋到了一個比較好的解決方案,就是讓vimdiff作為svn diff的檢視程式碼工具,尤其對於習慣用vim的人來說真的是很方便。
當使用svn diff指令比較某個檔案的修改前後時,例如執行以下指令:
$ svn diff -r4420 ngx_http_limit_req_module.c
那麼實際上會向預設的diff程式發送以下命令:
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”)。-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##
了解了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 "$@"
修改~/.subversion/config,找到如下設定行:
# diff-cmd = diff_program (diff, gdiff, etc.)將上面那個腳本的路徑加入進去就行,例如修改為
diff-cmd = /usr/local/bin/diffwrap.sh以後,使用svn diff指令就會預設開啟vimdiff比較2個檔案了。
效果圖:
#
以上是用vimdiff取代svn diff:比較程式碼的工具的詳細內容。更多資訊請關注PHP中文網其他相關文章!