一 基本操作
- svn checkout : 將服務器代碼完整的下載到本地
- svn commit : 將本地修改的內容,提交到服務器
- svn update : 將服務器最新的代碼下載帶本地
Checkout只需要做一次!
要想利用SVN管理源代碼,必須得有2套環境
服務器
- 用於存儲客戶端上傳的源代碼
- 可以在Windows上安裝Visual SVN Server
- 大部分情況下,公司的開發人員不必親自搭建SVN服務器
客戶端
- 上傳本地的源代碼到服務器,或者更新服務器的代碼到本地,保持同步
- 可以在Mac上使用命令行、Versions、Cornerstone、Xcode
- 開發人員就屬於客戶端這個角色
二 SVN 服務器搭建
安裝步驟
- 第一步: 雙擊打開VisualSVN-Server-2.7.7.msi
- 第二步:同意遵守協議
- 第三步: 選擇Visual VSN 服務器和管理控制檯, 和添加SVN命令行工具到系統Path路徑, 然後下一步
- 第四步: 選擇標準版本
- 第五步:選擇程序安裝的路徑、SVN代碼倉庫的路徑、所使用的協議和端口
- 第六步:開始安裝
- 第七步:安裝完成後會詢問你是否需要運行
- 第八步:檢查是否安裝成功
- 打開VisualSVN Server Manager查看狀態或在命令行輸入svnserve –help
創建代碼倉庫
添加用戶
設置權限
訪問SVN服務器
三 UNIX 常見指令
cd 改變工作目錄
pwd 輸出當前工作目錄的絕對路徑
- 在UNIX中要執行什麼命令,一定要知道自己當前所在的工作目錄
ls 查看文件
- $ ls 顯示文件
- $ ls -a 顯示所有文件
- $ ls -l 列表顯示文件
- $ ls -la 列表顯示所有文件
- $ ls -G 帶顏色顯示
touch 用於更改文件訪問和修改時間的標準UNIX程序,也被用於創建新文件
- $ touch myfile.txt
- 注意:touch不修改myfile.txt內容,只更改它的訪問、修改時間,如果myfile.txt不存在,它會被創建
cat 連續查看文件內容
- more 分頁查看文件內容
提示:
- 1> 命令和參數之間需要添加空格
- 2> 如果要使用當前目錄中的文件名,輸入到一半時,按TAB鍵能夠補全
四 SVN客戶端命令
svn checkout :下載服務器的代碼到本地 (簡寫svn co)
svn commit :將改動的文件提交到服務器(簡寫svn ci)
svn update :更新服務器的代碼到本地 (簡寫svn up)
svn add :向本地的版本控制庫中添加新文件
svn delete、svn remove :從本地的版本控制庫中刪除文件(簡寫svn del、svn rm)
svn move :移動文件或者目錄或文件更名
svn mkdir :創建納入版本控制下的新目錄
svn revert :撤銷之前的一切修改
svn merge :將兩個版本之間的差異合併到當前文件
svn info :查看文件的詳細信息
svn diff :查看不同版本的區別
svn log :查看日誌信息
svn list :列出版本庫下的文件和目錄列表
svn status :查看文件狀態(簡寫svn st)
svn help :獲取幫助信息(比如svn help ci)
svn lock :加鎖
svn unlock :解鎖
- 1> SVN基本命令
- 命令行格式:
svn <subcommand> [options] [args]
- 說明
svn 子命令 [選項] [參數]
- 命令行格式:
提示:
[中括號]中包含的內容是可選的
(子命令縮寫)
- 2> 查看幫助信息
- $ svn help
- 查看svn所有命令的幫助
- $ svn help 子命令
- $ svn help
檢出
- 將項目檢出(下載) 至本地
- svn checkout URL [PATH]
- svn co URL [PATH]
- 注意:這裏的中括號[ ]代表可選(可以省略)
// 示例
svn checkout https://192.168.1.106/svn/Weibo/ /Users/Documents/workspace
藍色代表的是:代碼倉庫的遠程地址
橙色代表的是:將代碼下載到本地的哪個路徑
如果省略橙色的路徑,就下載到命令行當前所在的路徑
提交
- 將改動過的文件提交至服務器
- svn commit -m “註釋” [PATH]
- svn ci -m “註釋” [PATH]
// 示例
svn commit -m “修改了User.m文件” /Users/Desktop/workspace/Weibo/branches/User.m
橙色代表的是:提交哪個文件到服務器
如果省略橙色的路徑,就將命令行所在路徑中所有改動過的文件提交到服務器
添加
提交一個新建的文件到服務器,需要2個步驟
- 添加新建的文件到本地的版本控制庫中:svn add
- 提交剛纔的添加操作到服務器:svn commit
如果直接提交一個沒有添加到本地版本控制庫中的文件,會報下面的錯誤
- is not a working copy
向本地的版本控制庫中添加一個新文件
- svn add PATH
示例
- svn add /Users/Desktop/workspace/Weibo/branches/User.m
- 橙色代表的是:添加哪個文件到版本控制庫中
刪除
刪除服務器上的某個文件,需要做2個步驟
- 將文件從本地的版本控制庫中移除:svn delete 、svn remove
- 提交剛纔的刪除操作到服務器:svn commit
將文件從本地的版本控制庫中移除
- svn delete PATH
示例
- svn delete /Users/Desktop/workspace/Weibo/branches/User.m
- 橙色代表的是:將哪個文件從版本控制庫中移除
更新
將服務器的最新代碼更新到本地
- svn update [PATH]
示例
- svn update /Users/lnj/Desktop/workspace/Weibo/branches/User.m
- 橙色代表的是:更新哪個文件的內容
- 如果省略橙色的路徑,就更新命令行所在路徑的所有內容
將文件恢復至某個版本
- svn update -r 版本號 [PATH]
五 加入開發
- 1>將服務器所有的內容下載到本地
- svn checkout 服務器地址 —username=zs —password=zs
- 2>開始開發
- touch person.h person.m : 創建person類
- svn add person.h person.m : 將person類添加到本地svn管理中
- svn commit -m “創建了person類” : 將person類提交到服務器
3>項目經理更新代碼
- svn update : 將服務器最新的代碼更新到本地(如果是新文件則下載,如果已有文件,則更新)
代碼衝突
- out of date : 過期
- df : 在命令行中給展示所有的不同的地方
- e : 在命令行編輯衝突
- s : 展示可解決衝突的選項
- mc : 使用我的代碼,來覆蓋服務器代碼
- tc : 使用服務器的代碼,來覆蓋我的代碼
- p : 對比所有的版本變化,手動解決衝突—>svn resolved person.h
注意:
1>在修改公共文件之前,最好先update,然後再修改
2>在修改公共文件之前,可以和同事說一聲,先不要修改文件,修改完之後讓同事更新
六 圖形化界⾯面⼯工具
- 1.項⺫目經理初始化項目
- 1>項目經理將服務器已有的內容下載到本地
- 記住選擇正確的svn版本號—>1.7
- 2>項目經理創建項目到code文件夾
- 3>項目經理忽略掉一些不需要的文件
- Xcode會幫我們記錄當前正在編輯的文件,下次打開時停留在該文件
 - Xcode會幫我們記錄目錄打開情況,同事不需要共享 - 斷點信息同事不需要共享,所有也需要忽略
- xcuserdata
- Xcode會幫我們記錄當前正在編輯的文件,下次打開時停留在該文件
- 1>項目經理將服務器已有的內容下載到本地
- 2.使⽤用Xcode的svn注意點
- 1>當項目中如果使用到了靜態庫,必須使用命令行將靜態庫添加到svn管理之下
- 2>項目中如果使⽤用storyboard,svn的管理也需要特別注意
- 如果可以使用xib那麼儘量使用xib
- 保證同時只有一個人在修改storyboard