我使用了git pull并发生了合并冲突:
unmerged: some_file.txt
You are in the middle of a conflicted merge.
如何放弃对文件所做的更改,只保留已提取的更改?
我使用了git pull并发生了合并冲突:
unmerged: some_file.txt
You are in the middle of a conflicted merge.
如何放弃对文件所做的更改,只保留已提取的更改?
当前回答
由于您的拉动不成功,那么HEAD(而不是HEAD^)是分支上最后一个“有效”提交:
git reset --hard HEAD
你想要的另一件事是让他们的改变凌驾于你的改变之上。
旧版本的git允许您使用“他们的”合并策略:
git pull --strategy=theirs remote_branch
但正如Junio Hamano(Git维护者)在这条消息中所解释的那样,这条消息已经被删除。如链接中所述,您可以这样做:
git fetch origin
git reset --hard origin
其他回答
我想你需要重置一下。
请注意,git revert意味着与svn revert非常不同的东西-在Subversion中,该revert将丢弃您(未提交)的更改,将文件从存储库返回到当前版本,而git rever“撤消”提交。
gitreset应该执行与svnreset等效的操作,即丢弃不需要的更改。
由于您的拉动不成功,那么HEAD(而不是HEAD^)是分支上最后一个“有效”提交:
git reset --hard HEAD
你想要的另一件事是让他们的改变凌驾于你的改变之上。
旧版本的git允许您使用“他们的”合并策略:
git pull --strategy=theirs remote_branch
但正如Junio Hamano(Git维护者)在这条消息中所解释的那样,这条消息已经被删除。如链接中所述,您可以这样做:
git fetch origin
git reset --hard origin
git merge --abort
中止当前冲突解决过程,并尝试重建合并前状态。如果合并时存在未提交的工作树更改started,gitmerge--在某些情况下中止将无法重建这些变化。因此,建议始终在运行gitmerge之前提交或隐藏更改。git merge--abort等效于git reset--mergeMERGE_HEAD存在。
http://www.git-scm.com/docs/git-merge
评论建议git reset-merge是git merge-ort的别名。值得注意的是,如果存在merge_HEAD,gitmerge--abort仅等同于gitreset-merge。这可以在git help for merge命令中读取。
当存在merge_HEAD时,gitmerge--abort等同于gitreset-merge。
合并失败后,如果没有merge_HEAD,则可以使用git-reset-mmerge撤消失败的合并,但不必使用gitmerge-art。它们不仅是同一事物的新旧语法。
就个人而言,我发现git reset-merge对于与所描述的场景类似的场景更为强大,并且通常合并失败。
自从Git 1.6.1.3以来,Git checkout已经可以从合并的任何一侧进行签出:
git checkout --theirs _widget.html.erb