Chinaunix首页 | 论坛 | 博客
  • 博客访问: 717215
  • 博文数量: 182
  • 博客积分: 2088
  • 博客等级: 大尉
  • 技术积分: 1698
  • 用 户 组: 普通用户
  • 注册时间: 2009-12-16 15:09
个人简介

.

文章分类

全部博文(182)

文章存档

2016年(1)

2015年(18)

2014年(14)

2013年(20)

2012年(129)

分类: Python/Ruby

2012-12-27 10:43:56

repo只是google用Python脚本写的调用git的一个脚本,主要是用来下载、管理Android项目的软件仓库。


1. 下载 repo 的地址: ,可以用 wget 或者 curl >~/bin/repo 来下载 repo , chmod a+x ~/bin/repo


2. 用repo sync 抓取 android source code 的时候,会经常出现一些错误导致 repo sync 中断,每次都要手动开始。

可以在一个脚本里写如下的命令,来自动取重复:

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


repo sync [project] 下载最新本地工作文件,同步 repository 中的代码。 可以指定需要更新的project , 如果不指定任何参数,会同步整个所有的项目


如果是第一次运行 repo sync , 则这个命令相当于 git clone 会把 repository 中的所有内容都拷贝到本地

如果不是第一次运行 repo sync , 则相当于 更新 和 自动合并 动作;

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


3. repo help [ command ] , 显示command 的详细的帮助信息内容

如:可以用命令: repo help init 来获取 repo init 的其他用法


4. repo init -u URL , 在当前目录安装 repository ,会在当前目录创建一个目录 ".repo" , -u 参数指定一个URL, 从这个URL 中取得repository 的 manifest 文件。

repo init -u git://android.git.kernel.org/platform/manifest.git ,可以用 -m 参数来选择 repository 中的某一个特定的 manifest 文件,如果不具体指定,那么表示为默认的 manifest 文件 (default.xml)

repo init -u git://android.git.kernel.org/platform/manifest.git -m dalvik-plus.xml , 可以用 -b 参数来指定某个manifest 分支。

repo init -u git://android.git.kernel.org/platform/manifest.git -b release-1.0



5. repo upload[ project-list ] 上传修改的代码 ,如果你本地的代码有所修改,那么在运行 repo sync 的时候,会提示你上传修改的代码,所有修改的代码分支会上传到 Gerrit (基于web 的代码review 系统), Gerrit 受到上传的代码,会转换为一个个变更,从而可以让人们来review 修改的代码。 


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


7. repo forall -c command,对所有项目执行一个command命令,这个命令 相当 好用;


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


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


10. repo status 显示 project 的状态


转载地址:http://blog.csdn.net/wh_19910525/article/details/8164107

----------------------------------------------------------------------------------------------------
使用中更新出现uncommitted error,解决如下:
error: .repo/manifests/: contains uncommitted changes
试着通过 git reset --hard来恢复所有变化的文件之后,依然存在上述问题,
最后通过cd .repo/manifests 切换到 .repo/manifests目录下执行git stash命令,并
通过git clean -f -d命令删除变化记录目录,然后使用repo sync就可以通过了。

cd .repo/manifests
git checkout .
repo sync
vi default.xml
/*
修改USER-->xxx
:%s/USER/xxx/
*/
repo sync

阅读(1208) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~