我想要等价于cd -的git。如果我在master分支,我签出foo,我希望能够键入类似git checkout的东西-返回到master,并能够再次键入它返回到foo。

这样的东西存在吗?实施起来会很难吗?


当前回答

正如@Karl在git签出手册中指出的那样:

作为一种特殊情况,检查第n个分支的“@{-N}”语法 出分支(而不是分离)。您还可以指定-哪个是 与“@{-1}”同义。

所以git checkout -和git checkout @{-1}在这种情况下都可以工作

我认为最接近的是使用git reflog和解析最新的移动从branch1到branch2和git签出branch1

其他回答

最流行的解决方案是:

git checkout @{-N}

其中N步计数的分支移动回签历史。

在我的情况下,我已经从master切换到gh-pages,这导致我所有的组件都消失了,取而代之的是一个文件名“static”和其他。

Git checkout -m master帮助

我带着同样的想法来到了这个问题,去结账我的前一个分支。我在Mac中使用ohmyz。下面的命令帮助了我。

$ gco -
$ git checkout -

只是在前面的回答中添加了一些细节,以理解git checkout @{-N}的工作机制。它会遍历reflog来检查签出历史,所以如果你想自己实现类似的东西,你应该能够解析git reflog的输出,寻找签出:行。你可以在git源代码sha1_name.c中检查实现,特别是interpret_nth_prior_checkout函数。

现在最简单的方法是:

git checkout -

…这是一个别名:

git checkout @{-1}

如果你想了解更多,我在这里写了一篇完整的文章:Checkout The Previous Branch In Git。