1 repo介绍
Android 使用 Git 作为代码管理工具,开发了 Gerrit 进行代码审核以便更好的对代码进行集中式管理,还开发了 Repo 命令行工具,对 Git 部分命令封装,将百多个 Git 库有效的进行组织。
1.1 清单库文件介绍
一个清单库可以包含多个清单文件和多个分支,每个清单文件和分支都有对应的版本。清单文件以xml格式组织的。举个例子:
Ø
Ø
Ø
Ø
1.2 下载repo代码
$mkdir android2.3.4
$cd android2.3.4
$git clone git://172.16.1.31/repo.git
在本地开发的用户需要下载repo代码,在172.16.1.7服务器上开发的用户则不用下载repo代码,因为已经把repo脚本添加到了环境变量,执行repo init 就会附加的下载repo代码。
2 repo常用指令
备注:“*”表示新添加的指令
2.1 repo init (下载repo并克隆manifest)
Usage:
repo init –u URL [OPTIONS]
Options:
l
l
l
命令repo init 要完成如下操作:
Ø
Ø
Ø
Ø
Example:
repo init
在 android2.3.4 目录下面出现了 .repo 文件夹。
repo
选择的是android.xml里面的配置,.repo/manifest.xml便指向.repo/manifests/android.xml
2.2 repo sync(下载代码)
Usage:
repo sync [<project>…]
用于参照清单文件.repo/manifest.xml克隆并同步版本库。如果某个项目版本库尚不存在,则执行repo sync 命令相当于执行git clone,如果项目版本库已经存在,则相当于执行下面的两条指令:
l
相当于对每一个remote源执行了fetch操作
l
针对当前分支的跟踪分支执行rebase操作。
Example:
repo sync
也可以选择克隆其中的一个项目:
repo sync platform/build
2.3 repo start(创建并切换分支)
Usage:
repo start
Example:
假设清单文件中设定的分支是gingerbread-exdroid-stable,那么执行以上指令就是对所有项目,在gingerbread-exdroid-stable的基础上创建特性分支stable。
假设清单文件中设定的分支是gingerbread-exdroid-stable,那么执行以上指令就是对platform/build、platform/bionic项目,在gingerbread-exdroid-stable的基础上创建特性分支stable
2.4 repo checkout(切换分支)
repo checkout <branchname>
实际上是对git checkout 命令的封装,但不能带-b参数,所以不能用此命令来创建特性分支。
Example:
repo checkout crane-dev
repo checkout crane-dev
2.5 repo branches(查看分支)
Usage:
repo branches [<project>…]
Example:
repo branches
repo branches platform/build platform/bionic
2.6 repo diff(查看工作区文件差异)
repo diff [<project>…]
Example:
repo diff
repo diff platform/build platform/bionic
2.7 repo stage(把文件添加到index表中)
Usage:
repo stage -i [<project>…]
2.8 repo prune(删除已经合并分支)
repo prune [<project>…]
2.9 repo abandon(删除指定分支)
repo abandon <branchname> [<project>…]
2.10 repo status(查看文件状态)
实际上是对git diff-index、git diff-filse命令的封装,同时显示暂存区的状态和本地文件修改的状态
$repo/repo status platform/bionic
以上的实例输出显示了platform/bionic项目分支的修改状态
Ø
Ø
l
l
l
l
l
l
l
l
Ø
l
l
l
Ø
2.11 *repo remote(设置远程仓库)
Usage:
repo remote add <remotename>
repo remote rm <remotename>
Example:
repo remote add org ssh://172.16.1.31/git_repo
这个指令是根据xml文件添加的远程分支,方便于向服务器提交代码,执行之后的build目录下看到新的远程分支org:
删除远程仓库:
$repo
2.12 *repo push
repo push org
repo push <remotename> [--all |<project>…]
repo会自己查询需要向服务器提交的项目并提示用户。
2.13repo forall
repo forall [<project>…] –c <command>
迭代器,可以在所有指定的项目中执行同一个shell指令
l
l
l
l
l
l
l
l
3.13.1 添加的环境变量
$repo forall
3.13.2 merge(合并多个分支)
3.13.3 tag(打标签)
在所有项目下打标签
repo forall –c git tag crane-stable-1.6
3.13.4 remote (设置远程仓库)
引用环境变量REPO_PROJECT添加远程仓库:
repo forall –c ‘git remote add korg ssh://xiong@172.16.31/$REPO_PROJECT.git’
删除远程仓库:
repo forall –c git remote add korg
3.13.5 branch(创建特性分支)
repo forall –c git branch crane-dev
repo forall –c git checkout –b crane-dev
3 repo的额外命令集
3.1 repo grep
相当于对git grep 的封装,用于在项目文件中进行内容查找
3.2 repo manifest
显示manifest文件内容
Usage:
repo manifest –o android.xml
3.3 repo version
显示repo的版本号
3.4 repo upload
repo upload相当于git push,但是又有很大的不同。它不是将版本库改动推送到克隆时的远程服务器,而是推送到代码审核服务器(Gerrit软件架设)的特殊引用上,使用SSH协议。代码审核服务器会对推送的提交进行特殊处理,将新的提交显示为一个待审核的修改集,并进入代码审查流程,只有当审核通过后,才会合并到官方正式的版本库中。
因为全志没有代码审核服务器,所以这条指令用不到。
repo upload [--re --cc] {[<project>]… | --replace <project>}
l
l
l
l
l
3.5 repo download
主要用于代码审核者下载和评估贡献者提交的修订
Usage
repo download {project change [patchset]}…
3.6 repo selfupdate