1

我在 GitHub 上有一个存储库,位于此处。我为某人创建了一个工作分支,他们分叉了 repo,对工作分支进行了一些更改并提交了一个拉取请求。

我尝试了更改,一切都很好,由于 GitHub 提供自动合并拉取请求,我继续点击绿色的大“合并拉取请求”按钮。除了对工作分支的更改应用于我可以忍受的主分支之外,一切都很好。

现在的问题是我或其他任何人都无法获取存储库。我收到此错误:

dp@dpub:/tmp/gh$ git clone git://github.com/dapphp/securimage.git
Initialized empty Git repository in /tmp/gh/securimage/.git/
remote: Counting objects: 333, done.
remote: Compressing objects: 100% (269/269), done.
remote: Total 333 (delta 91), reused 297 (delta 55)
Receiving objects: 100% (333/333), 3.91 MiB | 2.78 MiB/s, done.
Resolving deltas: 100% (91/91), done.
error: refs/remotes/origin/master does not point to a valid object!
error: Trying to write ref refs/heads/master with nonexistant object 31d684d383913c4cf1a0d5ff0691c2c163284a35
fatal: Cannot update the ref 'HEAD'.

这导致没有创建目录或下载任何工作文件。我已经到处寻找可能的方法来解决这个问题,但大多数人都在谈论向 git repo 发出命令,这是我无法做到的,因为我一开始就无法获得 repo 的副本。

我发现我仍然可以使用这样的方法克隆远程分支:git clone -b audiofixes git://github.com/dapphp/securimage.git但我仍然收到有关错误 ref 的错误,并且我无法找出可以运行的任何命令来解决问题。如有必要,我愿意撤消更改。

如果它有帮助,一旦我克隆了一个不同的分支,这里是输出git branch -a

* audiofixes
  remotes/origin/2.0.2
  remotes/origin/3.0
  remotes/origin/HEAD -> origin/master
  remotes/origin/audiofixes
  remotes/origin/securimage_flash

在这一点上,我真的不知道我能做些什么(如果有的话)来修复存储库的状态。

感谢您的任何建议。

编辑:按要求输出一些命令。

$ ls .git/refs/remotes/origin
HEAD

$ ls .git/objects
info/  pack/
# info is empty, pack has pack-b8add06e9a6864ea44a58c06b8bd549eedd90c94.idx and pack-b8add06e9a6864ea44a58c06b8bd549eedd90c94.pack

$ cat .git/refs/remotes/origin/master
cat: .git/refs/remotes/origin/master: No such file or directory

$ cat .git/refs/remotes/origin/HEAD 
ref: refs/remotes/origin/master
4

1 回答 1

2

新的:

显然 1)github 不提供 ssh 访问权限:(和 2)通过 git 协议在不同机器之间共享 reflog 是不可能的。

所以......您显然已经创建了一张票,但您不一定需要它们来修复存储库。您所需要的只是让他们(因为他们具有特权访问权限)git reflog master在服务器的存储库上运行,然后粘贴结果供您查看。在该文件中,查找 master 以前的 SHA-1 值(因为当前的值似乎不起作用)。一旦你有了它,你(我认为)可以(在你自己的计算机上)执行以下操作:

$ git checkout -b temp
$ git update-ref refs/heads/temp $SHA1
$ git push -u origin +temp:master

这将撤消服务器上的合并操作。

您可能能够获得以前工作的 SHA1,而无需从服务器获取 reflog。在您的本地仓库(或您朋友的本地仓库)中,之前工作的提交确实存在于那里的某个地方。如果你能想办法在那里找到它,那么你可以继续上面的建议。

老:这是我的第一个想法。如果您能够从服务器.git/logs复制目录,则该目录中将存储分支的所有先前值。具体来说,该文件将是一个原始文本文件,其中包含该分支的先前值。例如(我不知道 github 是否允许你这样做):master.git/logs/refs/heads/master

$ git clone https://github.com/dapphp/securimage.git -b audiofixes
$ scp github.com:/dapphp/securimage.git/logs/refs/heads/master .git/logs/refs/remotes/origin/master
$ git update-ref refs/remotes/origin/master refs/remotes/origin/master@{1} #see "Date Spec" section of http://book.git-scm.com/4_git_treeishes.html

从理论上讲,这应该将值更改为 master 以前的值。但是,它只会在本地执行此操作,实际上不会更改服务器上的值,而这正是我们真正需要的。因此,如果您可以直接 ssh 到服务器并在那里运行最后一个命令,那么(再次,理论上)只需撤消合并即可永久解决问题。

.

这就是我能想到的一切。但我真的很喜欢解决这样的 git 难题,所以我会让它在我的脑海中停留更长时间:)

于 2012-04-10T22:48:17.097 回答