我使用了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.
如何放弃对文件所做的更改,只保留已提取的更改?
当前回答
对于git>=1.6.1:
git merge --abort
对于旧版本的git,这将完成以下任务:
git reset --merge
or
git reset --hard
其他回答
如果您的git版本>=1.6.1,则可以使用git reset-merge。
此外,正如@Michael Johnson所提到的,如果您的git版本是>=1.7.4,您也可以使用gitmerge--abort。
一如既往,在开始合并之前,确保没有未提交的更改。
从gitmerge手册页
当存在merge_HEAD时,gitmerge--abort等同于gitreset-merge。
合并过程中,MERGE_HEAD出现。
此外,关于启动合并时未提交的更改:
如果在开始合并之前有不想提交的更改,只需在合并之前将其保存,并在完成合并或中止合并后将其弹出。
我想你需要重置一下。
请注意,git revert意味着与svn revert非常不同的东西-在Subversion中,该revert将丢弃您(未提交)的更改,将文件从存储库返回到当前版本,而git rever“撤消”提交。
gitreset应该执行与svnreset等效的操作,即丢弃不需要的更改。
您可以中止合并步骤:
git merge --abort
否则您可以保留更改(在哪个分支上)
git checkout --ours file1 file2 ...
否则您可以保留其他分支更改
git checkout --theirs file1 file2 ...
我发现以下方法对我有效(将单个文件恢复到合并前状态):
git reset *currentBranchIntoWhichYouMerged* -- *fileToBeReset*
如果最终出现合并冲突,并且没有任何要提交的内容,但仍显示合并错误。在应用所有下面提到的命令之后,
git reset --hard HEAD
git pull --strategy=theirs remote_branch
git fetch origin
git reset --hard origin
请删除
.git\index.lock
文件[恢复时剪切粘贴到其他位置],然后根据需要的版本输入以下任意命令。
git reset --hard HEAD
git reset --hard origin
希望这有帮助!!!