svn(subversion)是近年來崛起的版本管理工具,是cvs的接班人。目前絕大多數開源軟件都使用svn作爲代碼版本管理軟件。下面介紹一下如何在Xcode上使用SCM配置源代碼版本控制SVN的方法與技巧:
Code內置版本控制客戶端SCM,可作爲SVN客戶端。前兩天組裏自己搭SVN服務器沒有弄成,可能是網絡配置問題,索性就申請了googlecode節點,用google提供的SVN服務器了。不過,前提是所有的代碼都要開源。還有就是申請之前還需要一個gmail帳號,至於如何申請,搜一下,很多答案。申請完後別忘了把團隊成員(都需要有gmail帳號)加入進來。
現在,只剩下客戶端配置了。程序員的日常版本控制操作一般是:
import --> checkout --> commit -->update
import :導入工程文件到SVN服務器。在本地建好工程文件後,第一次從客戶端上傳工程文件至SVN服務器
checkout :簽出工程文件到客戶機本地。第一次從SVN服務器上下載工程文件到客戶機本地。
commit : 提交客戶機本地的改動到SVN服務器。客戶端本地在對代碼進行修改後,將修改提交到服務器。如果服務器的版本被團隊裏的其他人更新了,那麼commit之前會提示需要先update一下。
update: 將SVN服務器上的最新版本同步到客戶端。
-----------------
很好理解,import與checkout是一組操作,用在第一次操作時。而commit和update是一組操作,分別對應2個不同方向的操作。
-----------------
1、Checkout 操作
假如SVN上已經有團隊裏其他人上傳的工程項目文件,我們需要checkout到客戶端本地。按下列圖示操作:
首先用gmail帳號登錄申請的googlecode節點,取到SVN服務器的連接串(紅字標明的部分)
緊接着我們需要知道與google SVN服務器連接的密碼,這個密碼並不是gmail帳號的密碼,而是由google幫你自動生成的,我們需要在gmail帳號的profile中找到這個隨機生成的密碼。點擊右上角的Profile,然後選中"Setting"
這時頁面顯示錯誤,這是乍整的呢?我們打開一個在線代理網頁,重新訪問我們的googlecode節點(我選擇默認S1代理仍然出不來,我換了一個S2就OK)
可以看到GOOGLE爲我們生成的SVN服務器訪問密碼,也可以按“Regenerate”按鈕隨機生成另一個密碼
打開Xcode,無需創建任何項目,直接選擇SCM菜單上的"Configure SCM Repositories"
點擊左下角的"+"號新建一個SCM配置文件,起個名字“snb”,然後填入剛纔我們找到的googlecode節點的SVN服務器連接串,以及連接帳號、密碼
接下來我們就可以Checkout代碼了
選擇代碼的本地存放路徑,checkout完成後,可以直接打開工程代碼了
接下來還需要一步:將該工程與SCM配置文件綁定在一起。首先雙擊工程名打開工程配置,選擇"Configure Roots &SCM..."按鈕
指定我們在SCM裏設計的配置文件名snb,這樣就將該工程與snb配置文件綁定在一起了。
2、Commit操作
首先,我們假如對checkout下來的代碼進行了修改,加入了一行註釋,然後我們要將更改發佈到svn服務器,可以選擇SCM菜單的“Commit Entire Project”進行提交
注意,有變更的文件都會出現在SCM分支下,可以顯示自上次update以來,本地修改的代碼文件
在commit時我們可以添加一些說明,在這一步出現了一個提交錯誤信息。不知道是什麼原因,總之我試着把https連接方式改爲了http方式就OK了,而且我發現後面出現的Error:175002 (RA layer request failed) Server sent unexpected return value(405 Method Not Allowed)
錯誤我也是用這種方式解決的,就是又把http改回https方式,真有意思!
在googlecode站點我們看到已經commit成功
3、Update操作
假如在另一臺機器上commit了一個版本,在googlecode上可以看到這個記錄,然後我們準備update到客戶端本地,選擇SCM菜單的“Update Entire Project”就OK了,更新完後我們看到代碼添加的部分
4、import操作
也很簡單,選擇SCM中的Repositories,然後選擇Import按提示操作即可(在這個菜單中可以對SVN服務器上文件進行管理,比如創建目錄和刪除文件操作等等)
import成功!
2、往版本庫中添加新的文件
3、將改動的文件提交到版本庫
4、加鎖/解鎖
5、更新到某個版本
6、查看文件或者目錄狀態
7、刪除文件
8、查看日誌
svn log path
9、查看文件詳細信息
10、比較差異
例如:svn diff -r 200:201 test.php
11、將兩個版本之間的差異合併到當前文件
12、SVN 幫助
13、版本庫下的文件和目錄列表
14、創建納入版本控制下的新目錄
1、mkdir PATH…
2、mkdir URL…
1、每一個以工作副本 PATH 指定的目錄,都會創建在本地端,並且加入新增調度,以待下一次的提交。
2、每個以URL指定的目錄,都會透過立即提交於倉庫中創建。在這兩個情況下,所有的中間目錄都必須事先存在。
15、恢復本地修改
用法: revert PATH…
注意: 本子命令不會存取網絡,並且會解除衝突的狀況。但是它不會恢復被刪除的目錄
16、代碼庫URL變更
2、switch –relocate FROM TO [PATH...]
1、更新你的工作副本,映射到一個新的URL,其行爲跟“svn update”很像,也會將服務器上文件與本地文件合併。這是將工作副本對應到同一倉庫中某個分支或者標記的方法。
2、改寫工作副本的URL元數據,以反映單純的URL上的改變。當倉庫的根URL變動(比如方案名或是主機名稱變動),但是工作副本仍舊對映到同一倉庫的同一目錄時使用這個命令更新工作副本與倉庫的對應關係。
17、解決衝突
svn resolved: 移除工作副本的目錄或文件的“衝突”狀態。
18、輸出指定文件或URL的內容。