【问题标题】:Egit in eclipse missing treeeclipse中的Egit缺少树
【发布时间】:2013-10-21 13:37:58
【问题描述】:

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

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

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

我正在阅读this 的帖子,它似乎很有帮助,但我不知道如何找到我的“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)

【问题讨论】:

    标签: eclipse git


    【解决方案1】:

    160000special entry 用于记录子模块。
    SHA1 等于 40 个零表示子模块已被删除(参见git-submodule.sh)或unknown state

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

    当我们检查它是否脏的时候,我们已经做了一个 lstat(2) 并且知道它的类型 它,所以我们可以显示模式位。所以你会看到 100644、100755 或 120000 用于 blob。对于子模块也是如此。

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

    所以请检查您是否有.git/modules/asubmodule/HEAD
    或者尝试cleanup your submodule entry,然后将该子模块重新声明为eagle-vision url。

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

    【讨论】:

    • 我按照链接清理了一个子模块条目 - 但我什至没有得到
    • @xphill64x 你能试试git rm eagle vision吗?
    • git rm 'eagle vision' 没有匹配任何文件。
    • @xphil64x git rm --cached 'eagle vision' 那么呢?
    • 仍未找到。我在 git fsck 中收到另一个错误,关于另一个提交中的错误电子邮件。我找到了有问题的标签 [extra
    猜你喜欢
    • 2014-08-06
    • 1970-01-01
    • 2013-02-14
    • 2012-07-21
    • 1970-01-01
    • 1970-01-01
    • 2015-06-14
    • 2012-05-28
    • 2012-04-07
    相关资源
    最近更新 更多