236

所以我在存储库中做了一些工作,当我即将提交时,我意识到我目前不在任何分支上。

在使用子模块时经常会发生这种情况,我能够解决它,但是这个过程很乏味,我一直在想必须有一种更简单的方法来做到这一点。

有没有一种简单的方法可以返回分支,同时保留更改?

4

10 回答 10

253

如果您还没有承诺:

git stash
git checkout some-branch
git stash pop

如果您已提交并且此后没有更改任何内容:

git log --oneline -n1 # this will give you the SHA
git checkout some-branch
git merge ${commit-sha}

如果你已经承诺然后做了额外的工作:

git stash
git log --oneline -n1 # this will give you the SHA
git checkout some-branch
git merge ${commit-sha}
git stash pop
于 2011-01-19T13:08:02.470 回答
166

这对我有帮助

git checkout -b newbranch
git checkout master
git merge newbranch
git branch -d newbranch
于 2012-03-26T11:21:55.397 回答
23
git checkout master

结果是这样的:

Warning: you are leaving 2 commits behind, not connected to
any of your branches:

1e7822f readme
0116b5b returned to clean django

If you want to keep them by creating a new branch, this may be a good time to do so with:
git branch new_branch_name 1e7822f25e376d6a1182bb86a0adf3a774920e1e

所以,让我们这样做:

git merge 1e7822f25e376d6a1182bb86a0adf3a774920e1e
于 2013-05-31T05:02:50.197 回答
11

在这里另辟蹊径

git branch newbranch
git checkout master 
git merge newbranch 
于 2012-03-24T14:44:45.640 回答
10

或者,您可以设置您的子模块,这样您就可以签出一个分支,而不是处于默认的分离头状态。

编辑添加:

一种方法是在使用 -b 标志添加子模块时检查子模块的特定分支:

git submodule add -b master <remote-repo> <path-to-add-it-to>

另一种方法是进入子模块目录并检查它

git checkout master
于 2011-01-19T13:43:51.640 回答
7

在这种情况下结束的一种方法是在从远程分支执行 rebase 之后。在这种情况下,新提交被指向HEADmaster不指向它们——它指向在你重新建立另一个分支之前它所在的位置。

您可以master通过执行以下操作使此提交成为您的新提交:

git branch -f master HEAD
git checkout master

这会强制更新master为指向HEAD(不让你打开master)然后切换到master.

于 2019-03-12T03:09:29.093 回答
4

我最近又遇到了这个问题。自从我上次使用子模块并了解了更多关于 git 的知识以来已经有一段时间了,我意识到只需检查你想要提交的分支就足够了。即使您不存储它,Git 也会保留工作树。

git checkout existing_branch_name

如果您想在新分支上工作,这应该适合您:

git checkout -b new_branch_name

如果您在工作树中存在冲突,结帐将失败,但这应该是非常不寻常的,如果发生这种情况,您可以将其隐藏、弹出并解决冲突。

与接受的答案相比,这个答案将为您节省两个命令的执行,无论如何执行这些命令并不需要那么长时间。因此,我不会接受这个答案,除非它奇迹般地获得比当前接受的答案更多的赞成票(或至少接近)。

于 2012-10-09T09:28:42.117 回答
2

以下方法可能有效:

git rebase HEAD master
git checkout master

这会将您当前的 HEAD 更改重新设置在 master 之上。然后就可以切换分支了。


另一种方法是先签出分支:

git checkout master

然后 Git 应该显示你分离提交的 SHA1,然后你可以挑选它们,例如

git cherry-pick YOURSHA1

或者你也可以合并最新的:

git merge YOURSHA1

要查看来自不同分支的所有提交(以确保您拥有它们),请运行git reflog

于 2017-01-14T13:01:36.890 回答
0

我知道我在 2012 年告诉 babay,我认为不太可能有人不会意识到他们不在分支上并提交。这只是发生在我身上,所以我想我不得不承认我错了,但考虑到直到 2016 年才发生在我身上,你可能会争辩说这实际上不太可能。

无论如何,在我看来,创建一个新分支是矫枉过正的。你所要做的就是:

git checkout some-branch
git merge commit-sha

如果您在签出另一个分支之前没有复制 commit-sha,您可以通过运行轻松找到它:

git reflog
于 2016-07-11T18:27:59.213 回答
0

我发现最好的方法是将已更改的文件复制到单独的文件夹中,然后删除我当前在计算机上的存储库文件夹,然后克隆主存储库并将文件放回原处。

于 2021-05-26T20:24:03.717 回答