zoukankan      html  css  js  c++  java
  • repo简介

    高通的Android JellyBean库已经建立完成,目前已经可以正常访问,可以正常提交。
    Repo获取代码注意:
    1. 首先应有一个repo脚本,并将脚本放到环境变量里,此脚本的配置方法
    a) 进入用户主目录
    b) git clone git@172.16.98.152:git-repo.git
    c) mkdir ~/bin
    d) 拷贝repo工具:cp ~/git-repo/repo ~/bin
    e) 添加环境变量:vi ~/.bashrc 在最后加入PATH=$PATH:~/bin
    f) 重新进入shell或者执行 source ~/.bashrc,OK
    2. 添加gitserver和gerrit的ssh host名称和添加gerrit 的http host名称
    a) vi ~/.ssh/config
    b) 在文件中加入如下:
    host gitserver
    hostname 172.16.98.152
    user git
    port 22

    host gerrit
    hostname 172.16.98.152
    user zan.wang
    port 29418

    如果有些同学已经加过了,略过此步骤,不加入,会无法解析manifest文件中的remote url,详细查看i800JB.xml文件。
    c) sudo vi /etc/hosts
    d) 在文件中加入:
    172.16.98.152 gerrit
    如果不加入则无法解析在manifest文件中的review url,详细请查看i800JB.xml文件。

    3. 创建repo工作目录,并同步代码
    a) mkdir ~/work/i800JB && cd ~/work/i800JB
    b) repo init -u gitserver:manifests.git -m i800JB.xml
    c) repo sync -j8 (最好不要太多会死机)

    4. 编译代码
    a) 远程同步下来的代码是没有分支的,用repo branch会显示no branch
    b) 远程的代码目前建立了一个i800JB的分支,本地创建的分支尽量和远程项目分支同名,就好比我们之前操作的git一样。
    c) 创建本地工作分支用 repo start i800JB --all
    d) 此时用repo branch会出现你刚才建立的分支
    e) . build/envsetup.sh
    f) choosecombo 选择1.release 2.msm8625(后续如果有其他相应device,请依据项目选择) 3.eng(暂时选择eng)
    g) make -j4

    5. 提交和上传代码
    a) 如果本地有代码修改,需要提交,请到相应的工作目录,按照git的commit方式提交,上传的时候才需要用到repo
    b) 如果改动的工程较多,建议用repo stage命令来增加文件的track动作,但是提交就要到相应的目录里面老老实实的用git commit来提交了。
    c) Repo upload 命令在上传代码时,仅是上传到gerrit,还需要进行review后才会在代码库中体现。格式为 repo upload --re=zan.wang kernel。这里的kernel为project名称。这里的--re添加review人员命令,我试过是无效的,不知道是否是本地服务器有问题。Upload过程根据屏幕提示,确认几次。成功后,到172.16.99.44:8080 gerrit服务器添加审核人员。
    d) 如果远程的git库有可写权限,也可以在每个project下面用git进行提交,不过目前仅是可读权限,如果个别人员开放了写权限,可以进行此操作,和单独操作git库无异。
    e) 目前i800JB项目的remote名称为phicomm,可以查看在manifests库里面的i800JB.xml文件。用git上传某个project的修改时需注意这里的remote为phicomm,而非origin。

    6. Repo使用介绍
    a) repo是一个用来管理多个git库的工具
    b) 在repo中,每一个git库都称为一个project
    c) repo list 可以查看repo所管理的projects,目前project的名称是和所在路径是同名的
    d) repo status 可以查看本地修改的文件
    e) repo branch 可以查看每一个project所有的分支名称
    f) repo start 创建本地的工作分支,比如:repo start 分支名 --all为所有project创建分支,repo start 分支名 kernel 为kernel project创建分支名
    g) repo abandon 删除分支,用法和start差不多。比如:已经为kernel project创建了i800JB分支,用repo abandon i800JB kernel 命令,可以删除kernel project中的i800JB分支。如果执行repo abandon i800JB --all就会删除所有project上面名字为i800JB的分支。执行完repo abandon后,project会工作在no branch状态,还需手工start一个分支。
    h) repo forall 为所有project执行命令。比如:repo forall -c git tag XXXX_XXX_V1.0_SH 代表为每一个project加入tag
    i) repo init 初始化repo库,-u 代表url,-b代表branch,-m 代表manifest文件。比如:repo init -u gitserver:manifests.git -m i800JB.xml 代表的是从gitserver服务器上的manifests.git库中,选择i800JB.xml作为manifest文件。
    这里没有-b,是由于目前所建立的manifests.git库中,仅有一个master分支。没有-b选项,默认是从manifests.git库的HEAD指针处取得manifest文件
    如果没有-m选项,则代表使用的默认的manifest文件,默认的文件名称为default.xml
    j) repo overview 查看project里面没有提交的记录。
    k) repo upload 的时候,请用repo upload --re=REVIEW人员(比如zan.wang),系统会自动发邮件告知REVIEW人员,我试过是无效的,不知是否是本地gerrit服务器的问题。


    4.1代码库升级2050版本完成,Android 版本变为4.1.2,可以编译通过,可以开机,可以上网,可以打电话等。

    本次服务器分支i800JB-2050的建立不再基于高通的tag来建立了,是基于本地tag i800JB-2050-begin 来建立,因此各位同事请大胆sync,不会再出现因高通修改tag位置而导致的编译不过问题了。

    请大家按照以下方式更新:
    1. repo init -m i800JB-2050.xml (如果是新建目录,repo init -u gitserver:manifests.git -m i800JB-2050.xml)
    2. repo sync
    3. sync过程中有可能会出现类似error: device/qcom/msm7627a/: branch i800JB is published (but not merged) and is now 28 commits behind 的提示,请忽略它。
    4. 更新完成后,repo start i800JB-2050 --all
    5. 如果本地有修改,即modified,added状态的文件,在start新分支时会报错,请提交或者还原他们。部分untracked的文件不受影响。
    6. . build/envsetup.sh
    7. choosecomboext 0,1,9,1 (default,release,msm8625,user)
    8. make -j4
    9.

  • 相关阅读:
    PHP数据采集curl常用的5个例子
    【荐】PHP采集工具curl快速入门教程
    PHP常用正则表达式
    JavaScript方法call、apply、caller、callee、bind的使用详解及区别
    axf、elf文件转换成bin、hex脚本工具
    为什么数据须要做爱
    POJ 3978 Primes(求范围素数个数)
    Facebook Hacker Cup 2015 Round 1--Homework(筛选法求素数)
    后台进程整理
    Nginx优化具体,应对高并发
  • 原文地址:https://www.cnblogs.com/dreamy890322/p/4076319.html
Copyright © 2011-2022 走看看