一直很忙,忙的不可开交,以前我说有时间就来写点东西,然后最近一直很忙,连论文,加新项目,事情挺多的,android源码还是很久以前下载的,今天sync发现突然不行了,报错:
error.GitError: device/common rev-list ('^7d4526582f88808a3194e1a3b304abb369d2745c', 'HEAD', '--'): fatal: bad object 7d4526582f88808a3194e1a3b304abb369d2745c
result = cmd.Execute(copts, cargs) File "/home/thinkinbunny/mydroid/.repo/repo/subcmds/sync.py", line 466, in Execute project.Sync_LocalHalf(syncbuf) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1007, in Sync_LocalHalf lost = self._revlist(not_rev(revid), HEAD) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1785, in _revlist return self.work_git.rev_list(*a, **kw) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1930, in rev_list p.stderr)) error.GitError: platform/development rev-list ('^34ccdaa87b25c2456a76aafcf09a66b2fab236ff', 'HEAD', '--'): fatal: bad object 34ccdaa87b25c2456a76aafcf09a66b2fab236ff thinkinbunny@tib-N55SF:~/mydroid$ ./repo sync Fetching projects: 100% (247/247), done. Syncing work tree: 4% (10/247) Traceback (most recent call last): File "/home/thinkinbunny/mydroid/.repo/repo/main.py", line 385, in <module> _Main(sys.argv[1:]) File "/home/thinkinbunny/mydroid/.repo/repo/main.py", line 365, in _Main result = repo._Run(argv) or 0 File "/home/thinkinbunny/mydroid/.repo/repo/main.py", line 137, in _Run result = cmd.Execute(copts, cargs) File "/home/thinkinbunny/mydroid/.repo/repo/subcmds/sync.py", line 466, in Execute project.Sync_LocalHalf(syncbuf) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1007, in Sync_LocalHalf lost = self._revlist(not_rev(revid), HEAD) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1785, in _revlist return self.work_git.rev_list(*a, **kw) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1930, in rev_list p.stderr)) error.GitError: device/common rev-list ('^7d4526582f88808a3194e1a3b304abb369d2745c', 'HEAD', '--'): fatal: bad object 7d4526582f88808a3194e1a3b304abb369d2745c thinkinbunny@tib-N55SF:~/mydroid$ ./repo sync Fetching projects: 100% (247/247), done. Syncing work tree: 10% (25/247) Traceback (most recent call last): File "/home/thinkinbunny/mydroid/.repo/repo/main.py", line 385, in <module> _Main(sys.argv[1:]) File "/home/thinkinbunny/mydroid/.repo/repo/main.py", line 365, in _Main result = repo._Run(argv) or 0 File "/home/thinkinbunny/mydroid/.repo/repo/main.py", line 137, in _Run result = cmd.Execute(copts, cargs) File "/home/thinkinbunny/mydroid/.repo/repo/subcmds/sync.py", line 466, in Execute project.Sync_LocalHalf(syncbuf) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1007, in Sync_LocalHalf lost = self._revlist(not_rev(revid), HEAD) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1785, in _revlist return self.work_git.rev_list(*a, **kw) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1930, in rev_list p.stderr)) error.GitError: platform/docs/source.android.com rev-list ('^bce007aa754159a3c4b3894c581c53940ebc2e08', 'HEAD', '--'): fatal: bad object bce007aa754159a3c4b3894c581c53940ebc2e08 thinkinbunny@tib-N55SF:~/mydroid$ ./repo sync Fetching projects: 100% (247/247), done. Traceback (most recent call last): File "/home/thinkinbunny/mydroid/.repo/repo/main.py", line 385, in <module> _Main(sys.argv[1:]) File "/home/thinkinbunny/mydroid/.repo/repo/main.py", line 365, in _Main result = repo._Run(argv) or 0 File "/home/thinkinbunny/mydroid/.repo/repo/main.py", line 137, in _Run result = cmd.Execute(copts, cargs) File "/home/thinkinbunny/mydroid/.repo/repo/subcmds/sync.py", line 466, in Execute project.Sync_LocalHalf(syncbuf) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1007, in Sync_LocalHalf lost = self._revlist(not_rev(revid), HEAD) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1785, in _revlist return self.work_git.rev_list(*a, **kw) File "/home/thinkinbunny/mydroid/.repo/repo/project.py", line 1930, in rev_list p.stderr)) error.GitError: platform/external/bluetooth/bluez rev-list ('^5477d33e187d66961453399c53093bd18297013e', 'HEAD', '--'): fatal: bad object 5477d33e187d66961453399c53093bd18297013e
多次尝试无果,google之,发现google group上有这个问题,很多人问,不过都是不了了之,以前吧,百度过这个问题,在这个神奇的过度,人人都学会了CC和CV,然后就是,说是删除.repo目录,总之有点扯淡,删除了repo跟重新下载有什么区别呢?扯淡啊。可恶的bug。
新建了目录重新下载,最近狗日的宽带通吃屎,速度老慢。我可不想在假期下载一天源码。
折腾了一个上午,发现了解决方案。其实很简单,android源码实际上还是用git下载的。至于repo是什么东东,自己查呗,不浪费资源了。
其本来有图,无奈windows发不了图。
我就说说基本解决方法:
除了repo .repo其余的都删除,cts之类的什么删除就行了,不需要心疼,前提是你的网络通,至于出现bad object,原因不晓得,感觉是东西太老的,无法替换掉,删除了这些,sync会重新冲repo目录拷贝解析出来。如果删除了repo,后果就是你要重新下载 了。应该很长时间的。至于repo下面的东西没什么影响,但是不要删除了,不然更新就蛋疼了
最近遇到了一个大麻烦,发现以上的办法不管用了,最近换了房子,没网,要答辩了,把本子带公司,打算收拾下,顺便更新代码出错了,不记录了,没法重现了。
提供一个终极方案:
比如原来捏到源码目录是mydroid,现在新建一个droid
$ curl https://dl-ssl.google.com/dl/googlesource/git-repo/repo > ~/bin/repo
$ chmod a+x ~/bin/repo
repo init -u https://android.googlesource.com/platform/manifest
稍等,这个目录下面会有一个隐藏目录 repo,把这个目录全部复制mydroid覆盖就行,然后droid就没用了,然后再更新,这样是最省事的,网速牛逼的非要把repo删除也没办法,对于ip的并发google做了限制的。不能下载的
repo init -u https://android.googlesource.com/a/platform/manifest
只能这样下载了http://source.android.com/source/downloading.html 仔细阅读这个就好了。至于repo的各种问题可以说是bug吧。
同步出错就是某些文件校验失败,最简单的方法就是新建一个目录初始化文件覆盖旧的,语文不及格,表的的不是很明白,将就看吧