error.GitError: Cannot initialize work tree for xxxxx
问题描述:从Gitee
上拉去 OpenHarmony
代码,出现了这样的错误 error.GitError: Cannot initialize work tree for xxxxx
,可以使用一下解决方案
错误代码示例
Checking out projects: 69% (232/333) third_party_ffmpeggit-lfs filter-process --skip: 1: git-lfs: not found
fatal: the remote end hung up unexpectedly
error: Cannot checkout third_party_flutter: GitError: Cannot initialize work tree for third_party_flutter
Traceback (most recent call last):
File "/home/malixian/code/openSource/openHarmony/.repo/repo/main.py", line 628, in <module>
_Main(sys.argv[1:])
File "/home/malixian/code/openSource/openHarmony/.repo/repo/main.py", line 602, in _Main
result = run()
File "/home/malixian/code/openSource/openHarmony/.repo/repo/main.py", line 595, in <lambda>
run = lambda: repo._Run(name, gopts, argv) or 0
File "/home/malixian/code/openSource/openHarmony/.repo/repo/main.py", line 264, in _Run
result = cmd.Execute(copts, cargs)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/subcmds/sync.py", line 984, in Execute
self._Checkout(all_projects, opt, err_event, err_results)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/subcmds/sync.py", line 569, in _Checkout
self._CheckoutWorker(**kwargs)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/subcmds/sync.py", line 449, in _CheckoutWorker
return self._CheckoutOne(opt, project, *args, **kwargs)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/subcmds/sync.py", line 483, in _CheckoutOne
project.Sync_LocalHalf(syncbuf, force_sync=opt.force_sync)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/project.py", line 1797, in Sync_LocalHalf
self._InitWorkTree(force_sync=force_sync, submodules=submodules)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/project.py", line 3309, in _InitWorkTree
raise GitError('Cannot initialize work tree for ' + self.name)
error.GitError: Cannot initialize work tree for third_party_flutter
解决方案
使用命令 repo --trace sync -cdf
将repo的所有动作详细输出
: export GIT_DIR=/home/malixian/code/openSource/openHarmony/.repo/projects/third_party/libnl.git
: git rev-parse --verify refs/tags/OpenHarmony-v3.1-Release^0 1>| 2>|
: cd /home/malixian/code/openSource/openHarmony/third_party/libnl
: git read-tree --reset -u -v HEAD 1>| 2>|
: load refs /home/malixian/code/openSource/openHarmony/.repo/projects/third_party/libnl.git
: git checkout -q 3fd37ca55113ce0651aadce2384521882c86667c -- 1>| 2>|
: git rev-list refs/tags/OpenHarmony-v3.1-Release -1 1>| 2>|
: parsing /home/malixian/code/openSource/openHarmony/.repo/projects/third_party/flutter.git/config
: export GIT_DIR=/home/malixian/code/openSource/openHarmony/.repo/projects/third_party/flutter.git
: git rev-parse --verify refs/tags/OpenHarmony-v3.1-Release^0 1>| 2>|
: cd /home/malixian/code/openSource/openHarmony/third_party/flutter
: git read-tree --reset -u -v HEAD 1>| 2>|
git-lfs filter-process --skip: 1: git-lfs: not found
fatal: the remote end hung up unexpectedly
error: Cannot checkout third_party_flutter: GitError: Cannot initialize work tree for third_party_flutter
: git rev-list refs/tags/OpenHarmony-v3.1-Release -1 1>| 2>|
Traceback (most recent call last):
File "/home/malixian/code/openSource/openHarmony/.repo/repo/main.py", line 628, in <module>
_Main(sys.argv[1:])
File "/home/malixian/code/openSource/openHarmony/.repo/repo/main.py", line 602, in _Main
result = run()
File "/home/malixian/code/openSource/openHarmony/.repo/repo/main.py", line 595, in <lambda>
run = lambda: repo._Run(name, gopts, argv) or 0
File "/home/malixian/code/openSource/openHarmony/.repo/repo/main.py", line 264, in _Run
result = cmd.Execute(copts, cargs)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/subcmds/sync.py", line 984, in Execute
self._Checkout(all_projects, opt, err_event, err_results)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/subcmds/sync.py", line 569, in _Checkout
self._CheckoutWorker(**kwargs)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/subcmds/sync.py", line 449, in _CheckoutWorker
return self._CheckoutOne(opt, project, *args, **kwargs)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/subcmds/sync.py", line 483, in _CheckoutOne
project.Sync_LocalHalf(syncbuf, force_sync=opt.force_sync)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/project.py", line 1797, in Sync_LocalHalf
self._InitWorkTree(force_sync=force_sync, submodules=submodules)
File "/home/malixian/code/openSource/openHarmony/.repo/repo/project.py", line 3309, in _InitWorkTree
raise GitError('Cannot initialize work tree for ' + self.name)
error.GitError: Cannot initialize work tree for third_party_flutter
可以看到最后的地址:
export GIT_DIR=/home/malixian/code/openSource/openHarmony/.repo/projects/third_party/flutter.git
是这样的,是 flutter.git 这个文件,这个文件的路径在上面也有体现,所以有直接进行删除: rm -rf .repo/projects/third_party/flutter.git
,之后继续使用命令同步代码 repo sync -c
,如果存在多个错误,请直接在对应的仓下面找到 文件的后缀,直接进行删除,而无需重复使用 repo --trace sync -cdf
命令。