高通的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.

repo简介的更多相关文章

  1. repo学习总结

    转载:https://blog.csdn.net/salmon_zhang/article/details/79180075 1. repo简介 repo是Google开发的用于管理Android版本 ...

  2. yum的repo文件详解、以及epel简介、yum源的更换、常用yum命令

    https://www.cnblogs.com/nineep/p/6795692.html       yum的repo文件详解.以及epel简介.yum源的更换 常用命令如下: yum list  ...

  3. yum是什么?repo文件详解,epel简介,yum源的更换,repo和epel区别

    yum是什么?repo文件详解,epel简介,yum源的更换,repo和epel区别 简单概括: repo和epel的关系 repo是配置源的,即配置从哪里下载包(以及依赖关系)的. epel是作为桥 ...

  4. yum的repo文件详解、以及epel简介、yum源的更换

    一.什么是repo文件        repo文件是Fedora中yum源(软件仓库)的配置文件,通常一个repo文件定义了一个或者多个软件仓库的细节内容,例如我们将从哪里下载需要安装或者升级的软件包 ...

  5. Openstack Day1简介及虚拟环境搭建

    本文章仅作为作者本人存档记忆!恕不详细展开内容!   openstack kilo版本重要组件(module)简介 ======================================= Ke ...

  6. YUM源的简介,配置与使用

    A.yum 简介 yum,是Yellow dog Updater, Modified 的简称,是杜克大学为了提高RPM 软件包安装性而开发的一种软件包管理器.起初是由yellow dog 这一发行版的 ...

  7. Maven3简介

    Maven3简介 百度百科 maven官网: http:\/\/maven.apache.org\/ Maven下载安装 Maven 下载:http:\/\/maven.apache.org\/dow ...

  8. git的简介,安装以及使用

    1git的简介 Git是什么? Git是目前世界上最先进的分布式版本控制系统(没有之一). Git有什么特点?简单来说就是:高端大气上档次! 2Linus一直痛恨的CVS及SVN都是集中式的版本控制系 ...

  9. varnish4.0简介

    Varnish 4.0 简介 Varnish 是一款开源的HTTP加速器和反向代理服务器,它的主要特点有: (1)是基于内存缓存,重启后数据将消失.(2)利用虚拟内存方式,io性能好.(3)支持设置0 ...

随机推荐

  1. zendstudio正则匹配查询

    Ctrl+H之后,显示的File Search标签页为Containing text. Alt+/ 帮助提示正则匹配的语法. 例子如下: select type from table where id ...

  2. 使用WebFrom来模拟一些MVC的MODEL与View的数据交互功能

    MVC中有一点非常闪瞎人眼的功能就是,可以根据Model与View视图来直接将页面也数据模型进行绑定,那么我们在想客户端发送页面时不需要进行各种控件赋值,不需要操心怎么渲染,当客户提交表单给服务器时也 ...

  3. Dapper事务操作

    1.报错信息: 如果分配给命令的连接位于本地挂起事务中,ExecuteNonQuery 要求命令拥有事务.命令的 Transaction 属性尚未初始化. 出现这种原因是在执行Execute语句时,没 ...

  4. 堆/栈的比较 以及 malloc/new动态内存的开辟

    堆与栈的比较:1.申请方式(1)栈(satck):由系统自动分配.(2)堆(heap):需程序员自己申请(c:调用malloc,realloc,calloc申请 free 来释放),并指明大小,并由程 ...

  5. mysql实现增量备份

    有点要注意 如果你误删了表 想通过这个恢复 必须恢复日志里面有创建表的日志 不然的话是无法回复的  就是必须是从你开始创建表的时候就已经记录日志了  恢复到哪个位置 就按照哪个位置来计算 mysql ...

  6. Java 的简单了解

    本文是主要根据百度百科以网上一些资料,整理的一点对Java的浅显的了解,不当之处,还请大家批评指正. 最初见到Java这个单词,是在以前的手机上,游戏启动时总会显示java的图标和名字,就感觉java ...

  7. Ubuntu 12.04更换显示器后显示“显示不支援”,只能进恢复模式工作

    以前用的一台14寸液晶,换成17寸后,进入系统显示器上“显示不支援”  .仔细观查,电脑硬盘自检能显示后,后面都是黑屏. 解决过程. 因为grub 启动菜单不能显示.盲按方向键,发现菜单里的其它项目可 ...

  8. BufferedReader

    Reader FileReader BufferedReader package file; import java.io.BufferedReader; import java.io.File; i ...

  9. C#的Reflection总结

    什么是反射 在.NET中的反射也可以实现从对象的外部来了解对象(或程序集)内部结构的功能,哪怕你不知道这个对象(或程序集)是个什么东西,另外.NET中的反射还可以运态创建出对象并执行它其中的方法. 反 ...

  10. mongodb 增加用户以及认证用户

    test>use admin switched to db admin admin>db.addUser('yshy','yshy') { "user" : " ...