码迷,mamicode.com
首页 > 其他好文 > 详细

repo的一些用法

时间:2017-12-02 22:12:52      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:strong   本地   git clone   脚本   it管理   run   修改版本   diff   rebase   

repo的用法
注:repo只是google用Python脚本写的调用git的一个脚本,主要是用来下载、管理Android项目的软件仓库。(也就是说,他是用来管理给git管理的一个个仓库的) 

1.下载repo的地址: http://android.git.kernel.org/repo,可以用以下二者之一来下载
repo curl http://android.git.kernel.org/repo > ~/bin/repo 
下载完成后须修改repo的权限:
chmod a+x ~/bin/repo 

2.用repo sync在抓取android source code的时候,会经常出现一些错误导致repo sync中断,每次都要手动开始。
可以用如下的命令,来自动重复

$?=1; 
while [ $? -ne 0 ]  
do 
repo sync  
done

或者在.repo目录下的manifest.xml里找到fetch属性

改成

fetch= "git://Android.git.linaro.org/ "

再或者在.repo目录下的manifest.xml里找到review属性

改成

review="http://android-review.googlesource.com/"

(即将https改成http)


获取帮助:
repo help [ command ] //显示command的详细的帮助信息内容
示例:

repo help init

来获取repo init的其他用法


3.repo init -u URL

用以在当前目录安装repository,会在当前目录创建一个目录".repo" -u 参数指定一个URL,
从这个URL中取得repository的manifest文件。
示例:repo init -u git://android.git.kernel.org/platform/manifest.git 
获取的manifest文件放在.repo目录中。命名为manifest.xml。这个文件的内容其实就是所有被git管理的仓库的列表!

可以用-m 参数来选择获取repository中的某一个特定的manifest文件,如果不具体指定,那么表示为默认的manifest文件(default.xml) 

repo init -u git://android.git.kernel.org/platform/manifest.git -m dalvik-plus.xml

 (有诸多供我们选择的manifest文件,所有的manifest文件都放在目录.repo/manifests中,该目录本身亦被git所管理,你可以cd进去看看) 


可以用-b 参数来指定某个manifest分支。
repo init -u git://android.git.kernel.org/platform/manifest.git -b release-1.0 
你会发现.repo/manifests是个被git管理的仓库,这里放的是所有的manifest文件(*.xml),因为被git管理,固然有分支,-b可以切换到你想要的分支然后再
下载相关的xml文件,当然具体下载那个xml还要看-m参数了,所以如果你仅仅指定-b而没有-m的话,就是下载-b指定分支下的default.xml文件
如果不指定-b参数,那么会默认使用master分支

4.repo sync [project-list]

下载最新本地工作文件,更新成功,这本地文件和repository中的代码是一样的。
可以指定需要更新的project,如果不指定任何参数,会同步整个所有的项目。
如果是第一次运行repo sync,则这个命令相当于git clone,会把repository中的所有内容都拷贝到本地。如果不是第一次运行repo sync,
则相当于git remote update; git rebase origin/branch .

repo sync会更新.repo下面的文件。如果在merge 的过程中出现冲突,这需要手动运行
git rebase --continue 

5.repo update[ project-list ]

上传修改的代码,如果你本地的代码有所修改,那么在运行repo sync的时候,会提示你上传修改的代码,
所有修改的代码分支会上传到Gerrit (基于web的代码review 系统), Gerrit受到上传的代码,会转换为一个个变更,

从而可以让人们来review 修改的代码。

6. repo diff [ project-list ]   --显示提交的代码和当前工作目录代码之间的差异。

7. repo download target revision   --下载特定的修改版本到本地,
例如: repo download pltform/frameworks/base 1241 下载修改版本为1241的代码

8. repo start newbranchname .   --创建新的branch分支。"." 代表当前工作的branch分支。

9. repo prune [project list]   --删除已经merge的project 

10. repo foreach [ project-lists] -c command   --对每一个project运行command命令

11. repo status   --显示project中每个仓库的状态

12. repo forall -c  -- 遍历所有的git仓库,并在每个仓库执行-c所指定的命令

示例:

        repo init -u ssh://218.106.96.47:29418/sdk/manifest.git 
        repo sync    
        repo forall -c "git reset --hard sdk-3.11.0-20171201"

 

repo的一些用法

标签:strong   本地   git clone   脚本   it管理   run   修改版本   diff   rebase   

原文地址:http://www.cnblogs.com/zhangjiansheng/p/7955532.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!