中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

一篇通俗易懂的repo教程

發布時間:2020-06-18 15:30:58 來源:網絡 閱讀:12472 作者:andywang66 欄目:軟件技術
1. repo簡介

repo是Google開發的用于管理Android版本庫的一個工具,repo是使用Python對git進行了一定的封裝,并不是用于取代git,它簡化了對多個Git版本庫的管理。用repo管理的版本庫都需要使用git命令來進行操作。

1.1 介紹清單庫文件

清單文件是以xml的格式組織的,一個清單庫可以包含多個清單文件和多個分支,每個清單文件和分支都有對應的版本。

  • remote元素

    定義了名為korg的遠程版本庫,庫的基址為git://172.16.1.31

  • project元素

    用于定義一個項目,path屬性表示在工作區clone的位置,name屬性表示該項目的遠程版本庫的相對路徑。

  • default元素

    設置各個項目默認遠程版本庫為Korg,默認的分支為gingerbread-exdroid-stable。各個項目還可以定義自己的remote和revision覆蓋默認的配置。

  • project元素下的子元素copyfile

    定義了項目clone后的一個附件動作,從src拷貝文件到dest

1.2 下載repo代碼
  • 新建項目存放的文件夾

    mkdir mstar648

  • 進入到項目文件夾

    cd mstar648

  • 執行代碼拉取的命令

    repo init -u ssh://ppgerrit.com/Mstar648/manifest.git -b 648_cultraview -m ppos4.5.0_cultraview.xml
1.3 探究repo文件夾
  • 通過如下命令查看mstar648目錄下

    ls -a

一篇通俗易懂的repo教程

可以看到目錄下有個.repo文件夾,說明mstar648項目是一個用repo管理的版本庫。

  • 進入到.repo,并查看目錄內容

一篇通俗易懂的repo教程

可以看到.repo目錄下有manifest、project、repo文件夾等信息。

如果想查看Python封裝的腳本,可到.repo/repo下看到:
一篇通俗易懂的repo教程

如果想查看某個模塊當前是在哪個分支,可以進入到manifests中去:

一篇通俗易懂的repo教程

因為我們剛拉取代碼的時候是ppos4.5.0_cultraview.xml,所以通過vim打開ppos4.5.0_cultraview.xml,然后可以通過

/模塊名

查看到模塊的分支信息。例如我們要看到PposTv的分支信息,就可以搜索/PposTv

2. repo常用命令
2.1 解析拉取代碼的命令

例如我們拉取代碼的時候的命令如下:

repo init -u ssh://ppgerrit.com/Mstar648/manifest.git -b 648_cultraview -m ppos4.5.0_cultraview.xml

其中:

  • -u:指定一個URL,其連接到一個manifest倉庫

  • -b:選擇manifest倉庫中的一個特殊分支

  • -m:在manifest倉庫中選擇一個xml文件

repo init要完成如下操作:

  • 完成repo工具的完整下載,執行的repo腳本只是引導程序

  • clone清單庫manifest.git (地址是-u后面的參數)

  • clone的清單庫位于manifest.git中,clone到本地.repo/manifest中,.repo/manifest.xml只是符號鏈接,它指向的是.repo/manifests/default.xml

  • 如果manifest中有多個xml文件,repo init可以任意選擇其中一個,默認選擇的是default.xml。

上面的拉取代碼示例選擇的是ppos4.5.0_cultraview.xml里面的配置,那么.repo/manifest.xml指向的是.repo/manifests/ppos4.5.0_cultraview.xml

2.2 同步代碼(repo sync)

執行了repo init 命令后,我們需要執行如下命令同步代碼:

repo sync

參照清單文件.repo/manifest.xml克隆并同步版本庫。如果項目版本庫不存在,則執行repo sync命令相當于執行git clone;如果項目版本庫存在,則相當于執行下面兩條指令:

  • git remote update

    相當于對每一個remote源執行了fetch操作

  • git rebase origin/branch

    對當前分支的跟蹤分支執行rebase操作

2.3 創建并切換分支(repo start)

剛clone下來的代碼是沒有分支的,例如:

一篇通俗易懂的repo教程

repo start 的實質就是對git checkout -b 的封裝,可以為單個項目或所有項目以清單文件中已設定的分支為基礎,在本地創建新的分支。

repo start 與 git checkout -b 的區別:

  • repo start 是在清單文件設定的分支基礎上創建新的分支

  • git checkout -b 是在當前所在分支的基礎上創建新的分支

如果清單文件中設定的分支是remoteBranchName,創建新的分支localBranchName。

  • 為單個項目創建localBranchName分支的命令如下:

    repo start localBranchName 項目絕對路徑
  • 為所有項目創建localBranchName分支的命令如下:

    repo start localBranchName --all
2.4 查看分支(repo branches)

本文下面所有的命令都是在單個項目中運行!!!

例如查看上面拉取的mstar648項目下各模塊的分支信息

在mstar648項目下運行如下命令:

    repo branches

一篇通俗易懂的repo教程

2.5 切換分支(repo checkout)

切換分支語法:

repo checkout brancnName

一篇通俗易懂的repo教程

2.6 查看工作區文件的差異(repo diff)

查看文件差異語法:

    repo diff 
2.7 查看文件狀態(repo status)

該命令實際上是對git diff-index 和git diff-filse命令的封裝,同時顯示暫存區的狀態和本地文件修改的狀態

查看文件狀態語法:

    repo status

一篇通俗易懂的repo教程

其中:

  • 每個小節的第一行顯示的是項目名稱和所在的分支名稱

  • 每個小節的第二行的第一個字母表示暫存區文件修改的狀態

    • -:沒有改變

    • A:添加(不在HEAD中,在暫存區中)

    • M:修改(在HEAD中,在暫存區中,內容不同)

    • D:刪除(在HEAD中,不在暫存區)

    • R:重命名(不在HEAD中,在暫存區,路徑修改)

    • C:拷貝(不在HEAD中,在暫存區,從其他文件拷貝)

    • T:文件狀態改變(在HEAD中,在暫存區,內容相同)

    • U:未合并,需要沖突解決
  • 每個小節的第二行的第二個字母表示工作區文件的更改狀態

    • -:新/未知(不在暫存區,在工作區)

    • m:修改(在暫存區,在工作區,被修改)

    • d:刪除(在暫存區,不在工作區
2.8 刪除指定分支(repo abandon)

該命令實質是對git branch -D的封裝,語法如下:

    repo abandon branchName
2.9 刪除已經合并分支(repo prune)

該命令實質是對git branch -d的封裝,用于掃描項目的各個分支,并刪除已經合并的分支,語法如下:

    repo prune
2.10 將文件添加到index表中(repo stage)

該命令實質是對git add --interactive命令的封裝,用于將項目工作區中的改動添加到暫存區,語法如下:

    repo stage -i 

其中,-i表示 --interactive,給出個界面讓用戶選擇

2.11 設置遠程倉庫(repo remote)

語法如下:

    repo remote addd remoteName url

例如:

    repo remote add org ssh://172.16.1.31/git_repo

該命令是根據xml文件添加的遠程分支,方便于向服務器提交代碼,執行后的build目錄下看到新的遠程分支是org

2.12 遍歷當前項目下的所有git倉庫(repo forall)

該命令相當于一個迭代器,會遍歷當前項目下所有的git倉庫,在所有指定的項目中執行同一個shell命令。

語法如下:

    repo forall -c 命令

其中,參數有:

  • -c:后面可以帶的任何可以被系統支持的shell命令(ls,cp,pwd等)

  • -p:在shell命令輸出之前列出項目名稱

  • -v:列出執行shell指令輸出的錯誤信息

該命令還可以添加環境變量:

環境變量的參數有如下幾種:

  • REPO_PROJECT:指定項目的名稱

  • REPO_PATH:指定項目在工作區的相對路徑

  • REPO_REMOTE:指定項目遠程倉庫的名稱

  • REPO_LREV:指定項目最后一次提交服務器倉庫對應的哈希值

  • REPO_RREV:指定項目在克隆時的指定分支,manifest里的revision屬性

如果-c后面的shell指令是上述的環境變量,則需要用單引號把shell指令括起來。

語法如下:

repo forall –c ‘echo $REPO_PROJECT’
2.13 合并多個分支(merge)

例如將所有項目都切換到master分支。

repo forall -p -c git merge local

上面的命令就是將local分支合并到master分支上

2.14 打標簽(tag)

在所有項目下打標簽的命令如下:

repo forall -c git tag 標簽名
2.15 顯示版本號(repo version)

repo安裝后,可以通過repo version命令查看版本號。

一篇通俗易懂的repo教程

2.16 幫助文檔

repo安裝后,可以找到總結所有命令的文檔,在終端運行如下命令:

repo help

一篇通俗易懂的repo教程

如果想查看具體的某條命令的詳細信息,可以通過如下命令:

repo help 命令名稱

例如想看start指令的具體信息:

一篇通俗易懂的repo教程

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

城口县| 福安市| 阿图什市| 余江县| 盘山县| 屯门区| 平利县| 德昌县| 吉水县| 贵德县| 扬州市| 从江县| 馆陶县| 屏南县| 县级市| 新闻| 铁岭市| 乡宁县| 义乌市| 潮州市| 黎平县| 黄龙县| 英吉沙县| 乌鲁木齐县| 灌阳县| 河池市| 八宿县| 周至县| 清远市| 沅江市| 扎赉特旗| 临猗县| 仁化县| 武川县| 辰溪县| 西乌珠穆沁旗| 太和县| 威信县| 原平市| 乳山市| 江孜县|