您好,登錄后才能下訂單哦!
repo是Google開發的用于管理Android版本庫的一個工具,repo是使用Python對git進行了一定的封裝,并不是用于取代git,它簡化了對多個Git版本庫的管理。用repo管理的版本庫都需要使用git命令來進行操作。
清單文件是以xml的格式組織的,一個清單庫可以包含多個清單文件和多個分支,每個清單文件和分支都有對應的版本。
remote元素
定義了名為korg的遠程版本庫,庫的基址為git://172.16.1.31
project元素
用于定義一個項目,path屬性表示在工作區clone的位置,name屬性表示該項目的遠程版本庫的相對路徑。
default元素
設置各個項目默認遠程版本庫為Korg,默認的分支為gingerbread-exdroid-stable。各個項目還可以定義自己的remote和revision覆蓋默認的配置。
project元素下的子元素copyfile
定義了項目clone后的一個附件動作,從src拷貝文件到dest
新建項目存放的文件夾
mkdir mstar648
進入到項目文件夾
cd mstar648
執行代碼拉取的命令
repo init -u ssh://ppgerrit.com/Mstar648/manifest.git -b 648_cultraview -m ppos4.5.0_cultraview.xml
通過如下命令查看mstar648目錄下
ls -a
可以看到目錄下有個.repo文件夾,說明mstar648項目是一個用repo管理的版本庫。
可以看到.repo目錄下有manifest、project、repo文件夾等信息。
如果想查看Python封裝的腳本,可到.repo/repo下看到:
如果想查看某個模塊當前是在哪個分支,可以進入到manifests中去:
因為我們剛拉取代碼的時候是ppos4.5.0_cultraview.xml,所以通過vim打開ppos4.5.0_cultraview.xml,然后可以通過
/模塊名
查看到模塊的分支信息。例如我們要看到PposTv的分支信息,就可以搜索/PposTv
例如我們拉取代碼的時候的命令如下:
repo init -u ssh://ppgerrit.com/Mstar648/manifest.git -b 648_cultraview -m ppos4.5.0_cultraview.xml
其中:
-u:指定一個URL,其連接到一個manifest倉庫
-b:選擇manifest倉庫中的一個特殊分支
repo init要完成如下操作:
完成repo工具的完整下載,執行的repo腳本只是引導程序
clone清單庫manifest.git (地址是-u后面的參數)
clone的清單庫位于manifest.git中,clone到本地.repo/manifest中,.repo/manifest.xml只是符號鏈接,它指向的是.repo/manifests/default.xml
上面的拉取代碼示例選擇的是ppos4.5.0_cultraview.xml里面的配置,那么.repo/manifest.xml指向的是.repo/manifests/ppos4.5.0_cultraview.xml
執行了repo init 命令后,我們需要執行如下命令同步代碼:
repo sync
參照清單文件.repo/manifest.xml克隆并同步版本庫。如果項目版本庫不存在,則執行repo sync命令相當于執行git clone;如果項目版本庫存在,則相當于執行下面兩條指令:
git remote update
相當于對每一個remote源執行了fetch操作
git rebase origin/branch
對當前分支的跟蹤分支執行rebase操作
剛clone下來的代碼是沒有分支的,例如:
repo start 的實質就是對git checkout -b 的封裝,可以為單個項目或所有項目以清單文件中已設定的分支為基礎,在本地創建新的分支。
repo start 與 git checkout -b 的區別:
repo start 是在清單文件設定的分支基礎上創建新的分支
如果清單文件中設定的分支是remoteBranchName,創建新的分支localBranchName。
為單個項目創建localBranchName分支的命令如下:
repo start localBranchName 項目絕對路徑
為所有項目創建localBranchName分支的命令如下:
repo start localBranchName --all
本文下面所有的命令都是在單個項目中運行!!!
例如查看上面拉取的mstar648項目下各模塊的分支信息
在mstar648項目下運行如下命令:
repo branches
切換分支語法:
repo checkout brancnName
查看文件差異語法:
repo diff
該命令實際上是對git diff-index 和git diff-filse命令的封裝,同時顯示暫存區的狀態和本地文件修改的狀態
查看文件狀態語法:
repo status
其中:
每個小節的第一行顯示的是項目名稱和所在的分支名稱
每個小節的第二行的第一個字母表示暫存區文件修改的狀態
-:沒有改變
A:添加(不在HEAD中,在暫存區中)
M:修改(在HEAD中,在暫存區中,內容不同)
D:刪除(在HEAD中,不在暫存區)
R:重命名(不在HEAD中,在暫存區,路徑修改)
C:拷貝(不在HEAD中,在暫存區,從其他文件拷貝)
T:文件狀態改變(在HEAD中,在暫存區,內容相同)
每個小節的第二行的第二個字母表示工作區文件的更改狀態
-:新/未知(不在暫存區,在工作區)
m:修改(在暫存區,在工作區,被修改)
該命令實質是對git branch -D的封裝,語法如下:
repo abandon branchName
該命令實質是對git branch -d的封裝,用于掃描項目的各個分支,并刪除已經合并的分支,語法如下:
repo prune
該命令實質是對git add --interactive命令的封裝,用于將項目工作區中的改動添加到暫存區,語法如下:
repo stage -i
其中,-i表示 --interactive,給出個界面讓用戶選擇
語法如下:
repo remote addd remoteName url
例如:
repo remote add org ssh://172.16.1.31/git_repo
該命令是根據xml文件添加的遠程分支,方便于向服務器提交代碼,執行后的build目錄下看到新的遠程分支是org
該命令相當于一個迭代器,會遍歷當前項目下所有的git倉庫,在所有指定的項目中執行同一個shell命令。
語法如下:
repo forall -c 命令
其中,參數有:
-c:后面可以帶的任何可以被系統支持的shell命令(ls,cp,pwd等)
-p:在shell命令輸出之前列出項目名稱
該命令還可以添加環境變量:
環境變量的參數有如下幾種:
REPO_PROJECT:指定項目的名稱
REPO_PATH:指定項目在工作區的相對路徑
REPO_REMOTE:指定項目遠程倉庫的名稱
REPO_LREV:指定項目最后一次提交服務器倉庫對應的哈希值
如果-c后面的shell指令是上述的環境變量,則需要用單引號把shell指令括起來。
語法如下:
repo forall –c ‘echo $REPO_PROJECT’
例如將所有項目都切換到master分支。
repo forall -p -c git merge local
上面的命令就是將local分支合并到master分支上
在所有項目下打標簽的命令如下:
repo forall -c git tag 標簽名
repo安裝后,可以通過repo version命令查看版本號。
repo安裝后,可以找到總結所有命令的文檔,在終端運行如下命令:
repo help
如果想查看具體的某條命令的詳細信息,可以通過如下命令:
repo help 命令名稱
例如想看start指令的具體信息:
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。