当前位置: 首页 > news >正文

[Repo Git] manifests的写法

  1. manifests​​是个啥

    • Repo​中manifests​描述了Repo客户端的结构,也就是可以从manifests​中知道各个模块的代码应该从代码管理仓库当中哪个位置去获取。

    • manifests​的基本结构是一个Git存储库,在顶层目录中持有一个default.xml​文件。

    由于manifests​保存在Git存储库中,在repo sync​期间会同时将manifests​的版本拉到最新

  2. manifests​格式

    <!DOCTYPE manifest [<!ELEMENT manifest (notice?,remote*,default?,manifest-server?,remove-project*,project*,extend-project*,repo-hooks?,include*)><!ELEMENT notice (#PCDATA)><!ELEMENT remote EMPTY><!ATTLIST remote name         ID    #REQUIRED><!ATTLIST remote alias        CDATA #IMPLIED><!ATTLIST remote fetch        CDATA #REQUIRED><!ATTLIST remote pushurl      CDATA #IMPLIED><!ATTLIST remote review       CDATA #IMPLIED><!ATTLIST remote revision     CDATA #IMPLIED><!ELEMENT default EMPTY><!ATTLIST default remote      IDREF #IMPLIED><!ATTLIST default revision    CDATA #IMPLIED><!ATTLIST default dest-branch CDATA #IMPLIED><!ATTLIST default upstream    CDATA #IMPLIED><!ATTLIST default sync-j      CDATA #IMPLIED><!ATTLIST default sync-c      CDATA #IMPLIED><!ATTLIST default sync-s      CDATA #IMPLIED><!ATTLIST default sync-tags   CDATA #IMPLIED><!ELEMENT manifest-server EMPTY><!ATTLIST manifest-server url CDATA #REQUIRED><!ELEMENT project (annotation*,project*,copyfile*,linkfile*)><!ATTLIST project name        CDATA #REQUIRED><!ATTLIST project path        CDATA #IMPLIED><!ATTLIST project remote      IDREF #IMPLIED><!ATTLIST project revision    CDATA #IMPLIED><!ATTLIST project dest-branch CDATA #IMPLIED><!ATTLIST project groups      CDATA #IMPLIED><!ATTLIST project sync-c      CDATA #IMPLIED><!ATTLIST project sync-s      CDATA #IMPLIED><!ATTLIST project sync-tags   CDATA #IMPLIED><!ATTLIST project upstream CDATA #IMPLIED><!ATTLIST project clone-depth CDATA #IMPLIED><!ATTLIST project force-path CDATA #IMPLIED><!ELEMENT annotation EMPTY><!ATTLIST annotation name  CDATA #REQUIRED><!ATTLIST annotation value CDATA #REQUIRED><!ATTLIST annotation keep  CDATA "true"><!ELEMENT copyfile EMPTY><!ATTLIST copyfile src  CDATA #REQUIRED><!ATTLIST copyfile dest CDATA #REQUIRED><!ELEMENT linkfile EMPTY><!ATTLIST linkfile src CDATA #REQUIRED><!ATTLIST linkfile dest CDATA #REQUIRED><!ELEMENT extend-project EMPTY><!ATTLIST extend-project name CDATA #REQUIRED><!ATTLIST extend-project path CDATA #IMPLIED><!ATTLIST extend-project groups CDATA #IMPLIED><!ATTLIST extend-project revision CDATA #IMPLIED><!ATTLIST extend-project remote CDATA #IMPLIED><!ELEMENT remove-project EMPTY><!ATTLIST remove-project name  CDATA #REQUIRED><!ELEMENT repo-hooks EMPTY><!ATTLIST repo-hooks in-project CDATA #REQUIRED><!ATTLIST repo-hooks enabled-list CDATA #REQUIRED><!ELEMENT include EMPTY><!ATTLIST include name CDATA #REQUIRED>
    ]>
    
    • <manifest>​ 配置的顶层元素

    • <remote>​ 可以指定一个或者多个远程仓库,每一个remote​元素都指定了项目上传或者下载的地址。

      • <name>必填 指定该<remote>​元素的名称,该值会被各个项目中.git/config​引用,用于git pull​、 git fetch​等操作。
      • <alias>​ 设定<name>​元素的别名,<name>​元素在manifests​中必须是唯一的,但是该元素可以重复出现在manifests​中。
      • <fetch>必填<remote>​元素的Git URL前缀,Gitlab中有群组,也就是群组的链接,例:https://android.googlesource.com/
      • <pushurl>​ 用于git push​时推送的URL前缀,如果没有指定,那就是使用<fetch>​元素的值。
      • <review>​ 指定gerrit的服务器名,用于repo upload​操作。如果没有指定,则repo upload​没有效果。
      • <revision>​ Git 分支的名称(例如master​或refs/heads/master​)。具有自己版本的遥控器将覆盖默认版本。
    • <default>​ 设定所有projects的默认属性值,如果在<project>​元素里没有指定一个属性,则使用<default>​元素的属性值。

      • <remote>​ 远程服务器的名字,<remote>​元素的<name>​元素,<project>​元素没有指定<name>​则使用该值。
      • <revision>​ 可以指定分支或者标签,如果<project>​元素里没有指定,就用这里的值。
      • <dest-branch>​ Git分支的名称(例如master)。如果没有设置自己的目标分支的<project>​元素将继承此值。如果未设置此值,则项目将默认使用版本。
      • <upstream>​ Git ref的名称,其中可以找到sha1。在-c模式下同步锁定修订manifests​时使用,以避免必须同步整个ref空间。未设置自身上游的项目元素将继承此值。
      • <sync-j>repo sync​时默认并行的核数,等同于 repo sync -j​。
      • <sync-c>​ 设置为 true 时,仅同步指定的 Git 分支,而不是整个 ref 空间。如果<project>​元素没有指定<sync-c>​元素,则使用此值。
      • <sync-s>​ 设置为true时,同时同步子项目。
      • <sync-tags>​ 将其设置为false,则只同步给定的Git分支(在revision属性中指定),而不同步其他ref标签。
    • <manifest-server>​ 它的url属性用于指定manifest服务的URL,通常是一个XML RPC 服务

    • <project>​ 单独Git 项目

      • <name>必填 项目的名称,用于和​<remote>​元素下的<fetch>​元素值合成Git URL。
      • <path>​ clone到本地的目录,如果没有指定则在<name>​元素值的文件夹下。
      • <remote>​ 远程服务器的名字,<remote>​元素的<name>​元素。
      • <revision>​ 指定分支或者标签,分支:refs/heads/master​,标签:refs/tags/tag
      • <dest-branch> ​ Git分支的名称(例如master)。
      • <groups>​ 列出<project>​所属的组,以空格或者逗号分隔多个组名。所有的<project>​都自动属于"all"组。每一个<project>​自动属于name:‘name’ 和path:'path’组。例如,它自动属于default, name:monkeys, and path:barrel-of组。如果一个project属于notdefault组,则,repo sync​时不会下载
      • <sync-c>​ 如果设置为true,则只同步指定的分支(revision 属性指定),而不是所有的ref内容。
      • <sync-s>​ 如果设置为true,则会同步git的子项目
      • <upstream>​ Git ref的名称,其中可以找到sha1。在-c模式下同步锁定修订manifests​时使用,以避免必须同步整个ref空间。
      • <clone-depth>​ 设置获取此项目使用的深度。如果已指定,此值将覆盖命令行中通过 --depth​ 选项给repo init​ 指定值。[机器翻译]
      • <force-path>​ 将此属性设置为 true 可强制此项目根据其路径属性(如果提供)而不是名称属性创建本地镜像存储库。此属性仅适用于本地镜像同步,在同步客户端工作目录中的项目时将忽略它。[机器翻译]
    • <extend-project>​修改已命名项目的属性。

      此元素在本地清单文件中最为有用,可以修改现有项目的属性而不必完全替换现有的项目定义。这使得本地清单更加健壮,不易受到原始清单更改的影响。[机器翻译]

    • <annotation>​ 一个项目元素可以指定零个或多个注释元素作为其子元素。每个元素描述了一个名称-值对,在“forall”命令期间,该名称-值对将带有REPO__前缀导出到每个项目的环境中。此外,还有一个可选属性“keep”,它接受不区分大小写的值“true”(默认值)或“false”。此属性确定在使用清单子命令导出时是否保留注释。[机器翻译]

    • <copyfile>​ 项目元素可以指定零个或多个copyfile元素作为子元素。每个元素描述一个源文件和目标文件对;在repo同步命令执行期间,将“src”文件复制到“dest”位置。[机器翻译]

    • <linkfile>​ 这就像是复制文件,并与复制文件同时运行,但它不复制文件,而是创建一个符号链接。

      符号链接在“dest”(相对于树的顶部)创建,并指向由“src”指定的路径,该路径是项目中的一个路径。

      如果“dest”的父目录缺失,将自动创建。

      符号链接的目标可以是一个文件或目录,但它不能指向存储库客户端之外的位置。[机器翻译]

    • <remove-project>​ 从内部的manifest​表中删除指定的<project>​。经常用于本地的manifest​文件,用户可以替换一个<project>​的定义

    • <include>​ 通过<name>​属性可以引入另外一个manifest​文件(路径相对与当前的manifest.xml 的路径)

      • <name>​ 引入另外一个manifest​文件名
  3. 使用例子

    Reference:https://www.cnblogs.com/helloworldtoyou/p/6430545.html

    <?xml version="1.0" encoding="UTF-8"?>
    <manifest><remote  name="github"						// 远程服务器名称是“github”,后面用github表示fetchfetch=".."							// 获取数据的位置是"..",上一级目录review="review.cyanogenmod.org" />	// gerrit审核的位置<remote  name="private"						// 远程服务器名称“private”fetch="ssh://git@github.com" />		// 从”ssh://git@github.com下载代码<remote  name="aosp"							// aospfetch="https://android.googlesource.com"		// 代码下载地址review="android-review.googlesource.com"revision="refs/tags/android-7.1.1_r6" />		// 默认的git分支<default revision="refs/heads/cm-14.1"		// 默认的代码下载地址remote="github"						// github,表示上面的remote设置的name="github"的一项,那么下载的地址fetch就是”..“sync-c="true"						// 只同步指定的分支sync-j="4" />						// repo sync 默认的并行数目// path:将代码下载到本地的build目录中
    // name:${remote fetch}/${project name}.git 
    // remote 没有指定,那么久采用default地址,name=github,从”.."上一层目录下载。
    // 结合name的值,就从../CyanogenMod/android_build.git这个仓库下载地址。查看作者github仓库,就能找到android_build这个仓库。<project path="build" name="CyanogenMod/android_build" groups="pdk,tradefed"><copyfile src="core/root.mk" dest="Makefile" /></project><project path="build/blueprint" name="platform/build/blueprint" groups="pdk,tradefed" remote="aosp" /><project path="build/kati" name="CyanogenMod/android_build_kati" groups="pdk,tradefed" /><project path="build/soong" name="platform/build/soong" groups="pdk,tradefed" remote="aosp" ><linkfile src="root.bp" dest="Android.bp" /><linkfile src="bootstrap.bash" dest="bootstrap.bash" /></project><project path="abi/cpp" name="platform/abi/cpp" groups="pdk" remote="aosp" /><project path="art" name="CyanogenMod/android_art" groups="pdk" /><project path="bionic" name="CyanogenMod/android_bionic" groups="pdk" />...
    
  4. 总结

    对于 manifests​,方便了开发者在一个项目需要控制多个代码仓库对代码版本的控制,而且manifests​使用的xml​格式的文档,对于用户而言,上手简单。

https://gerrit.googlesource.com/git-repo/+/refs/heads/master/README.md

https://blog.csdn.net/wwwlyj123321/article/details/122361538

http://www.lryc.cn/news/324514.html

相关文章:

  • 位置编码与长度外推
  • Linux信号补充——信号发送和保存
  • Vue3 中应该使用 Ref 还是 Reactive?
  • 红外相机和RGB相机标定:实现两种模态数据融合
  • 前端项目,个人笔记(五)【图片懒加载 + 路由配置 + 面包屑 + 路由行为修改】
  • 【MySQL】2.MySQL数据库的基本操作
  • 常见技术难点及方案
  • c#关键字 static
  • redis 如何保证数据同步(数据变化时)
  • Ubuntu18.04桌面版设置静态IP地址
  • Aztec的客户端证明
  • 面试官:小伙子知道synchronized的优化过程吗?我:嘚吧嘚吧嘚,面试官:出去!
  • 100天精通风控建模(原理+Python实现)——第23天:风控建模中的贝叶斯优化是什么?怎么实现?
  • Http 超文本传输协议基本概念学习摘录
  • 模拟-算法
  • 深入了解鸿鹄工程项目管理系统源码:功能清单与项目模块的深度解析
  • Unbuntu20.04 git push和pull相关问题
  • hive SQL 移位、运算符、REGEXP正则等常用函数
  • 33-Java服务定位器模式 (Service Locator Pattern)
  • 前端小卡片:vue3路由是什么,有什么作用,该如何配置?
  • Jackson 2.x 系列【2】生成器 JsonGenerator
  • 说说webpack中常见的Loader?解决了什么问题?
  • Django 铺垫
  • 浅谈C++的继承与多态(静态绑定、动态绑定和虚函数等)
  • 【无人机综合考试题】
  • JS精度计算的几种解决方法,1、转换成整数计算后再转换成小数,2、toFixed,3、math.js,4、bignumber.js,5、big.js
  • v77.递归
  • Spring Cloud微服务功能及其组件详细讲解
  • (三维重建学习)已有位姿放入colmap和3D Gaussian Splatting训练
  • 4635: 【搜索】【广度优先】回家