在linux下,直接使用svn diff命令查看代碼的修改是很吃力的,于是在網(wǎng)上搜索到了一個比較好的解決方案,就是讓vimdiff作為svn diff的查看代碼工具,尤其對于習(xí)慣用vim的人來說真的是很方便。
當(dāng)使用svn diff命令比較某個文件的修改前后時,例如執(zhí)行以下命令:
$ svn diff -r4420 ngx_http_limit_req_module.c
那么實(shí)際會向默認(rèn)的diff程序發(fā)送如下命令:
-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的解釋(中文、英文):
當(dāng)使用一個外部的diff命令時,Subversion會生成一個非常復(fù)雜的命令行。第一個參數(shù)就是具體的--diff-cmd,然后就是具體的 --extensions (盡管使用空白的 --符號時會忽略擴(kuò)展),或者如果沒有指定--extensions或者--extensions為空的話,就加上‘-u’參數(shù)。第三和第四個參 數(shù),Subversion會傳遞一個“-L”還有第一個文件的標(biāo)簽(例如,“"project_issues.html (revision 11209)”)。第五個和第六個就是另一個“-L”和第二個文件的標(biāo)簽。第七和第八個參數(shù)分別是第一個和第二個文件的名稱(例 如,“.svn/text-base/project_issues.html.svn-base”和“.svn/tmp /project_issues.html.tmp”)。
了解了diff的內(nèi)部調(diào)用命令,那么實(shí)現(xiàn)用vimdiff作為diff程序就比較簡單了。
vimdiff在比較2個文件時,只要知道這2個文件的路徑及文件名就可以了,也就是上述diff內(nèi)部命令中的第7個和第8個2個參數(shù);
同時也說明了由于diff內(nèi)部命令的參數(shù)過多導(dǎo)致用--diff-cmd直接調(diào)用vimdiff是行不通的(命令如下)。
$ svn diff --diff-cmd vimdiff -r4420 ngx_http_limit_req_module.c
所以,我們需要自己另外寫一個腳本,讓這個腳本作為diff程序,獲得diff的內(nèi)部命令,然后只取其中的第7個和第8個參數(shù),再傳給vimdiff,這樣就能解決參數(shù)多的問題了。
腳本(diffwrap.sh)如下:
#!/bin/sh
# 去掉前5個參數(shù)
shift 5
# 使用vimdiff比較
vimdiff "$@"
另外,svn還提供了在配置文件中修改diff默認(rèn)程序的功能,這樣就不用每次使用svn diff時再指定--diff-cmd了。
修改~/.subversion/config,找到如下配置行:
# diff-cmd = diff_program (diff, gdiff, etc.)
將上面那個腳本的路徑添加進(jìn)去就行,例如修改為
diff-cmd = /usr/local/bin/diffwrap.sh
以后,使用svn diff命令就會默認(rèn)打開vimdiff比較2個文件了。
效果圖:
到此這篇關(guān)于使用vimdiff代替svn diff的查看代碼工具的文章就介紹到這了,更多相關(guān)vimdiff 代碼比較內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!