5

看起来我有一个丢失的树错误。公平地说,我完全只是弄乱了 git 上的本地文件,受够了,在我的 repo 上做了一个完整的硬盘删除并从远程 master 重新克隆。现在我收到以下错误。我做的第一件事就是为我的工作创建一个本地分支。

如果我没有删除所有内容,我可能已经恢复了很多工作,但是嘿,通过时态 - 对吗?(这可能会显示我现在对 git 和我的项目的心态......)

如果它有什么不同,我正在制作一个android项目。

我正在阅读 这篇文章,它似乎很有帮助,但我不知道如何找到我的“a30df1173f14dea24df661f1eef749fed2f4e1ed”sha1 哈希。

正在做

git ls-tree a30df1173f14dea24df661f1eef749fed2f4e1ed

给我以下

100755 blob 2851ba4fdf2a134f8fc97fd60b3045b73cd6039b    .DS_Store
100755 blob 3f9691c5dda29b09cb96060fd6ec7017f6c671d2    .classpath
100755 blob c50d3b4fe2f6221db617840561dc94d7690bb883    .gitignore
100755 blob 6b58f1723a252cfd314d108fadac4b71a4209c1c    .project
100755 blob 39f00018845d776de324707090d26c5153720e22    AndroidManifest.xml
100755 blob 94a9ed024d3859793618152ea559a168bbcbb5e2    COPYING
100755 blob c1853e4c312a938d5890f5f4e0844782429ba11e    default.properties
040000 tree 423accda532f8788f916b26b863ddf32e2896aa6    docs
160000 commit 0000000000000000000000000000000000000000  eagle vision
100755 blob 424f2604203eabd2310165b143b430326aa87ee7    ic_launcher-web.png
040000 tree 2b83cd828cd11a11e84a2d8f646dfa40de109827    libs
100644 blob 8a7b1fac8f8c12e925e56776f225730c4712f92a    lint.xml
040000 tree c0182f719fccf5fc8b0d7658c3d15fe4deac0d9e    plugins
100755 blob f2fe1559a217865a5454add526dcc446f892385b    proguard-project.txt
100755 blob 9ae01de96458dbded45d2a442c09c0f4d33e473a    project.properties
040000 tree 3c9446b3bb23eebe80942992ee03e01a7390ba80    res
040000 tree 895e957ccc4ee642127c25a3481d784302e44a70    src

在所有这些 0 中,鹰的视野似乎很奇怪:

160000 提交 0000000000000000000000000000000000000000 鹰眼

不过,我不确定我要去哪里。试图通过 git faq 并没有走得太远。

这是整个错误:

eclipse.buildId=v22.0.0-675183
java.version=1.7.0_21
java.vendor=Oracle Corporation
BootLoader constants: OS=linux, ARCH=x86_64, WS=gtk, NL=en_US
Framework arguments:  -product com.android.ide.eclipse.adt.package.product
Command-line arguments:  -os linux -ws gtk -arch x86_64 -product com.android.ide.eclipse.adt.package.product

Error
Sun Oct 13 21:11:59 CDT 2013
Missing tree 2ec4e5b3e0e3d9ccc766fd1ed0dccaedcef3e53a

org.eclipse.jgit.errors.MissingObjectException: Missing tree 2ec4e5b3e0e3d9ccc766fd1ed0dccaedcef3e53a
    at org.eclipse.jgit.storage.file.WindowCursor.open(WindowCursor.java:127)
    at org.eclipse.jgit.treewalk.CanonicalTreeParser.reset(CanonicalTreeParser.java:201)
    at org.eclipse.jgit.treewalk.TreeWalk.parserFor(TreeWalk.java:984)
    at org.eclipse.jgit.treewalk.TreeWalk.addTree(TreeWalk.java:468)
    at org.eclipse.egit.core.synchronize.GitSyncCache.loadDataFromGit(GitSyncCache.java:130)
    at org.eclipse.egit.core.synchronize.GitSyncCache.getAllData(GitSyncCache.java:85)
    at org.eclipse.egit.core.synchronize.GitSyncCache.getAllData(GitSyncCache.java:63)
    at org.eclipse.egit.core.synchronize.GitResourceVariantTreeSubscriber.refresh(GitResourceVariantTreeSubscriber.java:180)
    at org.eclipse.team.core.subscribers.Subscriber.refresh(Subscriber.java:466)
    at org.eclipse.egit.core.synchronize.GitSubscriberMergeContext.handleRepositoryChange(GitSubscriberMergeContext.java:142)
    at org.eclipse.egit.core.synchronize.GitSubscriberMergeContext.access$0(GitSubscriberMergeContext.java:133)
    at org.eclipse.egit.core.synchronize.GitSubscriberMergeContext$1.indexDiffChanged(GitSubscriberMergeContext.java:68)
    at org.eclipse.egit.core.internal.indexdiff.IndexDiffCache.notifyListeners(IndexDiffCache.java:98)
    at org.eclipse.egit.core.internal.indexdiff.IndexDiffCache.access$0(IndexDiffCache.java:89)
    at org.eclipse.egit.core.internal.indexdiff.IndexDiffCache$1.indexDiffChanged(IndexDiffCache.java:84)
    at org.eclipse.egit.core.internal.indexdiff.IndexDiffCacheEntry.notifyListeners(IndexDiffCacheEntry.java:425)
    at org.eclipse.egit.core.internal.indexdiff.IndexDiffCacheEntry.access$8(IndexDiffCacheEntry.java:417)
    at org.eclipse.egit.core.internal.indexdiff.IndexDiffCacheEntry$5.run(IndexDiffCacheEntry.java:358)
    at org.eclipse.core.internal.jobs.Worker.run(Worker.java:53)
4

1 回答 1

2

160000是用于记录子模块的特殊条目。
SHA1 等于 40 个零表示子模块已被删除(参见git-submodule.sh)或处于未知状态

当您将某物与工作树状态进行比较时,当工作树状态为脏时,我们总是0{40}表示“它是脏的并且我们不知道该事物的对象名称是什么,直到您实际运行 git-update-索引(或 git-add)它”(那时它会停止变脏)。
对于 blob(无论是常规文件还是符号链接),这具有不必运行 hash-object 来获取如果您实际执行 git-add 将创建的对象的对象名称的优点。

当我们检查它是否脏时,我们已经执行了 lstat(2) 并知道它的类型,因此我们可以显示模式位。因此,对于 blob,您将看到 100644、100755 或 120000。对于子模块也是如此。

对于子模块,我们可以从 $sub/.git/HEAD 读取值,但在工作树一侧(通常是右侧,除非您使用 -R)显示 0{40} 更加一致。

所以检查你是否有一个.git/modules/asubmodule/HEAD.
或者尝试清理您的子模块条目,然后将该子模块重新声明为 eagle-vision url。

但是,您丢失的树可能与该条目无关。

于 2013-10-14T06:14:36.353 回答