简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长!
优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀
优质专栏:多媒体系统工程师系列【原创干货持续更新中……】🚀
人生格言: 人生从来没有捷径,只有行动才是治疗恐惧和懒惰的唯一良药.
1.前言
本篇目的:Repo源码控制工具学习。
2.Repo介绍
- repo 是一个用 Go 语言编写的版本控制系统,旨在简化 Git 仓库的管理。它提供了一些有用的功能,如并行克隆、子模块支持、预提交钩子和多种存储后端。repo 是由 Google 开源的,并在其内部广泛使用。
- 主要特性
- 并行克隆:repo 可以在多个目录中并行克隆仓库,这比 Git 原生克隆的速度要快得多。
- 子模块支持:它自动处理子模块的添加和更新,无需手动操作。
- 预提交钩子:支持在提交之前运行自定义脚本,以便进行验证或其他操作。
- 多种存储后端:除了支持本地文件系统外,还支持 HTTP、HTTPS、Git 协议和 Amazon S3 等。
- 子树支持:允许你将仓库中的特定子树克隆到另一个仓库。
- 二次合并:repo 可以在合并时解决冲突,然后再次合并。
- Git 协议优化:通过 Git 协议传输数据时,repo 支持标签、提交和引用压缩,以提高传输效率。
3.Repo命令开发实例
<1>.提供帮助命令
# repo help
<2>.提供有关 repo 命令的帮助
# repo help command
<3>.生成 init 命令的说明和选项列表
# repo help init
<4>.查看某个命令的可用选项的列表
# repo command --help
# repo init --help
<5>.init
# repo init -u url [options]
-u:指定从中检索清单代码库的网址。
-m:选择代码库中的清单文件。如果未选择清单名称,则默认为 default.xml。
-b:指定修订版本,即特定的 manifest-branch。
<6>.同步
# repo sync [project-list]
下载新的更改并更新本地环境中的工作文件,基本上可以在所有 Git 代码库中完成 git fetch。如果在未使用任何参数的情况下运行 repo sync,则该命令会同步所有项目的文件。
运行 repo sync 后,将出现以下情况:
如果目标项目从未同步过,则 repo sync 相当于 git clone;远程代码库中的所有分支都会复制到本地项目目录中。
如果目标项目以前同步过,则 repo sync 相当于:
# git remote update
# git rebase origin/branch
其中 branch 是本地项目目录中当前已检出的分支。如果本地分支没有在跟踪远程代码库中的分支,则项目不会发生任何同步。
如果 Git rebase 操作导致合并冲突,请使用常规 Git 命令(例如 git rebase --continue)来解决冲突。
<7>.upload
# repo upload [project-list]将更改上传到审核服务器。 对于指定的项目,Repo 会将本地分支与最后一次 Repo sync 时更新的远程分支进行比较。Repo 会提示您选择一个或多个尚未上传以供审核的分支。接下来,所选分支上的所有提交都会通过 HTTPS 连接传输到 Gerrit。您需要配置一个 HTTPS 密码以启用上传授权。如需生成新的用户名/密码对以用于 HTTPS 传输,请访问密码生成器。当 Gerrit 通过其服务器接收对象数据时,它会将每项提交转变成一项更改,以便审核者可以针对特定提交给出意见。如需将几项“检查点”提交合并为一项提交,请运行 git rebase -i 然后再运行 upload。如果在未使用任何参数的情况下运行 repo upload,则该命令会在所有项目中搜索要上传的更改。如需在更改上传后对其进行修改,请使用 git rebase -i 或 git commit --amend 等工具更新您的本地提交内容。修改完成之后,请执行以下操作:进行验证以确保更新后的分支是当前已检出的分支。
使用 repo upload --replace PROJECT 打开更改匹配编辑器。
<8>.diff
# repo diff [project-list]
使用 git diff 显示提交与工作树之间的明显更改。
<9>.download
# repo download target change
从审核系统中下载指定更改,并放在您项目的本地工作目录中供使用。
如需将更改 23823 下载到platform/build目录,运行以下命令
# repo forall [project-list] -c command
在每个项目中运行指定的 shell 命令。通过 repo forall 可使用下列额外的环境变量:REPO_PROJECT 设为项目的唯一名称。
REPO_PATH 是相对于客户端根目录的路径。
REPO_REMOTE 是清单中远程系统的名称。
REPO_LREV 是清单中修订版本的名称,已转换为本地跟踪分支。如果您需要将清单修订版本传递到某个本地运行的 Git 命令,则可使用此变量。
REPO_RREV 是清单中修订版本的名称,与清单中显示的名称完全一致。
选项:-c:要执行的命令和参数。此命令会通过 /bin/sh 进行评估,其之后的任何参数都将作为 shell 位置参数来进行传递。
-p:在所指定命令的输出结果之前显示项目标头。这通过以下方式实现:将管道绑定到命令的 stdin、stdout 和 sterr 流,然后通过管道将所有输出结果传输到一个单页会话中显示的连续流中。
-v:显示该命令向 stderr 写入的消息。
<10>.prune
# repo prune [project-list]
删减(删除)已合并的主题。
<11>.start
# repo start branch-name [project-list]从清单中指定的修订版本开始,创建一个新的分支进行开发。BRANCH_NAME 参数用于简要说明您尝试对项目进行的更改。如果您不知道,请考虑使用名称 default。project-list 参数指定了将参与此主题分支的项目。
<12>.status
# repo status [project-list]
对于每个指定的项目,将工作树与临时区域(索引)以及此分支 (HEAD) 上的最近一次提交进行比较。
对这三种状态之间存在差异的每个文件,显示其摘要行。如需仅查看当前分支的状态,运行 repo status .系统会按项目列出状态信息。
对于项目中的每个文件,系统使用两个字母的代码来表示:
在第一列中,大写字母表示临时区域与上次提交状态之间的不同之处。