用vimdiff取代svn diff:比較程式碼的工具
在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中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在PHP開發中進行版本控制是很常見的操作,其中最常用的工具就是SVN(Subversion)。它可以方便地管理程式碼的歷史版本以及協同開發過程中的程式碼更新。以下將介紹如何在PHP開發中使用SVN進行版本控制。一、安裝SVN客戶端和服務端首先需要安裝SVN客戶端和服務端。 SVN客戶端可以在SVN官網上下載對應的版本,安裝即可,而服務端則需要自行搭建,具體方法可以

SVN簡介SVN(Subversion)是一種集中式版本控制系統,用於管理和維護程式碼庫。它允許多個開發者同時協作開發程式碼,並提供對程式碼歷史修改的完整記錄。透過使用SVN,開發者可以:保障程式碼穩定性,避免程式碼遺失和損壞。追蹤程式碼修改歷史,輕鬆回滾到之前的版本。協同開發,多個開發者同時修改程式碼而不會衝突。 SVN基本操作要使用SVN,需要安裝SVN客戶端,例如TortoiseSVN或SublimeMerge。然後,您可以按照以下步驟執行基本操作:1.建立程式碼庫svnmkdirHttp://exampl

EclipseSVN插件的安裝和設定方法詳解Eclipse是一個廣泛使用的整合開發環境(IDE),它支援許多不同的插件來擴展其功能。其中之一是EclipseSVN插件,它使開發人員能夠與Subversion版本控制系統進行互動。本文將詳細介紹如何安裝和設定EclipseSVN插件,並提供具體的程式碼範例。第一步:安裝EclipseSVN外掛程式開啟Eclipse

差別:1、vss是微軟開發的,是收費的,而svn是開源免費的;2、vss必須有客戶端,而svn可以用客戶端,也可以用命令列模式,還可以用網頁方式只讀存取;3、vss只支援windows系統,而svn支援windows和linux系統;4、vss是「鎖定-編輯-解鎖」模式,svn預設是「修改-衝突-合併」模式;5、vss的版本號對應的是單一文件,svn的版本號碼對應的是整個版本庫。

在linux下,直接使用svndiff指令查看程式碼的修改是很吃力的,於是在網路上搜尋了一個比較好的解決方案,就是讓vimdiff作為svndiff的檢視程式碼工具,尤其對於習慣用vim的人來說真的是很方便。當使用svndiff指令比較某個檔案的修改前後時,例如執行下列指令:$svndiff-r4420ngx_http_limit_req_module.c那麼實際上會向預設的diff程式傳送如下指令:-u-Lngx_http_limit_req_module.c(revision4420)-Lngx_

在CentOS上安裝SVN是非常常見的操作,它是一個功能強大的版本控制系統,可以用於管理和追蹤軟體開發過程中的變更,本文將詳細介紹如何在CentOS上安裝SVN,並提供一些常用的命令列安裝方法。在CentOS上安裝SVN有多種方法,以下將介紹兩種常用的安裝方式。 1.開啟終端,以root使用者身分登入。 2.執行以下命令更新系統軟體包清單:```yumupdate3.執行以下命令安裝SVN:yuminstallsubversion4.安裝完成後,可以透過執行以下命令驗證SVN是否成功安裝:svn--v

身為Linux開發人員,往往需要運用SVN控制專案版本。對於優秀開發者而言,熟知如何查閱SVN版本無疑是必備技能之一。今日,筆者想藉此機會和各位分享自己的心得,希望能助您更能掌握這項實用技巧。 1.安裝SVN命令列工具請先在Linux環境中安裝SVN命令列工具哦!請撥通終端,然後穩健地輸入下面這條指令來完成安裝吧:```尊敬的用戶,請執行sudoapt-getinstallsubversion以安裝Subversion。 2.連接到SVN伺服器安裝完畢後,我們需要連接到SVN伺服器。輸入以下命令:

作為常用的伺服器端腳本語言,PHP憑藉其開源、跨平台的優勢,被廣泛應用於Web開發領域。而在多人協作的開發中,版本控制是一個不可或缺的工具,它可以有效地管理原始碼的修改與更新,避免因團隊成員之間程式碼不同步而造成的衝突。而SVN作為一款流行的版本控制工具,在PHP開發的應用也十分廣泛。本文將為大家介紹PHP開發中的SVN版本控制的基礎知識,包括SVN的安
