Repo 可以用来整合 Git 代码库,代码上传到 Gerrit 修订版本控制系统。Repo 只是为了在 Android 环境中更轻松地使用 Git。
repo 安装和配置
# Debian/Ubuntu.
$ sudo apt-get install repo
$ mkdir -p ~/.bin
$ PATH="${HOME}/.bin:${PATH}"
$ curl https://storage.googleapis.com/git-repo-downloads/repo > ~/.bin/repo
$ chmod a+rx ~/.bin/repo
1、repo命令的使用方法
$ repo [command] [options]
$ repo help //帮助
$ repo help <COMMAND>
2、repo init
该命令创建一个 .repo/ 目录,其中包含用于 Repo 源代码和标准 Android 清单文件的 Git 代码库。
$ repo init -u <URL> [<OPTIONS>] //在当前目录中安装 Repo
参数:
-u:指定要从中检索清单代码库的地址。
-m:在代码库中选择清单文件。如果未选择任何清单名称,则会默认选择 default.xml。
-b:指定分支。
#注意:对于其余的所有 Repo 命令,当前工作目录必须是 .repo/ 的父目录或相应父目录的子目录
3、repo sync
$ repo sync [<PROJECT_LIST>] //同步代码
选项:
-d:将指定项目切换回指定分支。
-f:即使某个项目同步失败,系统也会继续同步其他项目。
repo sync 运行成功后,指定项目中的代码会与远程代码库中的代码保持同步。
* 如果目标项目从未同步过,则 repo sync 相当于 git clone。
* 如果目标项目已同步过,则 repo sync 相当于以下命令:
git remote update
git rebase origin/<BRANCH>
如果 git rebase 操作导致合并冲突,那么您需要使用普通 Git 命令(例如 git rebase --continue)来解决冲突。
4、repo upload
repo upload [<PROJECT_LIST>] //上传代码
您选择一个或多个分支后,所选分支上的所有提交都会通过 HTTPS 连接传输到 Gerrit.
如果您在未使用任何参数的情况下运行 repo upload,则该操作会搜索所有项目中的更改以进行上传。
要在更改上传之后对其进行修改,应使用 git rebase -i 或 git commit --amend
5、repo diff
repo diff [<PROJECT_LIST>]
显示提交的代码和当前工作目录代码之间的差异。
6、repo download
下载特定的修改版本到本地
repo download <TARGET> <CHANGE>
例如:$ repo download platform/build 23823
repo sync 应该可以有效移除通过 repo download 检索到的任何提交
7、repo forall
这个命令会遍历所有的git仓库,并在每个仓库执行-c所指定的命令
repo forall [<PROJECT_LIST>] -c <COMMAND>
选项:
-c:要运行的命令和参数。
-p:可以在遍历到每个仓库的时候先打印出当前的pwd
-v:显示该命令向 stderr 写入的消息。
在每个项目中运行指定的 shell 命令。通过 repo forall 可使用下列额外的环境变量:
REPO_PROJECT 可设为项目的具有唯一性的名称。
REPO_PATH 是客户端根目录的相对路径。
REPO_REMOTE 是清单中远程系统的名称。
REPO_LREV 是清单中修订版本的名称,已转换为本地跟踪分支。如果您需要将清单修订版本传递到某个本地运行的 Git 命令,则可使用此变量。
REPO_RREV 是清单中修订版本的名称,与清单中显示的名称完全一致。
8、repo prune
删除已经merge的分支
repo prune [<PROJECT_LIST>]
9、repo start
创建分支
repo start <BRANCH_NAME> [<PROJECT_LIST>]
<BRANCH_NAME> 参数应简要说明您尝试对项目进行的更改。如果您不知道,则不妨考虑使用默认名称。
<PROJECT_LIST> 指定了将参与此分支的项目。
#注意:“.”是一个非常实用的简写形式,用来代表当前工作目录中的项目。
10、repo status
repo status [<PROJECT_LIST>]
显示 project 中每个仓库的状态,并打印仓库名称
要仅查看当前分支的状态,请运行 repo status。系统会按项目列出状态信息。
在第一列中,大写字母表示暂存区与上次提交状态之间的不同之处。
字母 含义 说明
- 无更改 HEAD 与索引中相同
A 已添加 不存在于 HEAD 中,但存在于索引中
M 已修改 存在于 HEAD 中,但索引中的文件已修改
D 已删除 存在于 HEAD 中,但不存在于索引中
R 已重命名 不存在于 HEAD 中,但索引中的文件的路径已更改
C 已复制 不存在于 HEAD 中,已从索引中的另一个文件复制
T 模式已更改 HEAD 与索引中的内容相同,但模式已更改
U 未合并 HEAD 与索引之间存在冲突;需要解决方案
在第二列中,小写字母表示工作区与索引之间的不同之处。
字母 含义 说明
- 新/未知 不存在于索引中,但存在于工作区中
m 已修改 存在于索引中,也存在于工作区中(但已修改)
d 已删除 存在于索引中,不存在于工作区中
11、repo foreach [ project-lists] -c command
对每一个 project 运行 command 命令
===============================================================
资料:
- Homepage:
https://gerrit.googlesource.com/git-repo/
- Mailing list:
repo-discuss on Google Groups
- Bug reports:
https://bugs.chromium.org/p/gerrit/issues/list?q=component:repo
- Source:
https://gerrit.googlesource.com/git-repo/
- Overview:
https://source.android.com/source/developing.html
- Docs:
https://source.android.com/source/using-repo.html
- repo Manifest Format:
https://gerrit.googlesource.com/git-repo/+/refs/heads/master/docs/manifest-format.md
- repo Hooks:
https://gerrit.googlesource.com/git-repo/+/refs/heads/master/docs/repo-hooks.md
- Submitting patches:
https://gerrit.googlesource.com/git-repo/+/refs/heads/master/SUBMITTING_PATCHES.md
- Running Repo in Microsoft Windows:
https://gerrit.googlesource.com/git-repo/+/refs/heads/master/docs/windows.md
- GitHub mirror:
https://github.com/GerritCodeReview/git-repo
- Postsubmit tests:
https://github.com/GerritCodeReview/git-repo/actions